@@ -115,6 +115,7 @@ namespace Content.Client.Entry
|
||||
_prototypeManager.RegisterIgnore("htnCompound");
|
||||
_prototypeManager.RegisterIgnore("htnPrimitive");
|
||||
_prototypeManager.RegisterIgnore("gameMap");
|
||||
_prototypeManager.RegisterIgnore("gameMapPool");
|
||||
_prototypeManager.RegisterIgnore("faction");
|
||||
_prototypeManager.RegisterIgnore("lobbyBackground");
|
||||
_prototypeManager.RegisterIgnore("advertisementsPack");
|
||||
|
||||
@@ -68,7 +68,22 @@ public sealed class GameMapManager : IGameMapManager
|
||||
|
||||
public IEnumerable<GameMapPrototype> AllVotableMaps()
|
||||
{
|
||||
return _prototypeManager.EnumeratePrototypes<GameMapPrototype>().Where(x => x.Votable);
|
||||
if (_prototypeManager.TryIndex<GameMapPoolPrototype>(_configurationManager.GetCVar(CCVars.GameMapPool), out var pool))
|
||||
{
|
||||
foreach (var map in pool.Maps)
|
||||
{
|
||||
if (!_prototypeManager.TryIndex<GameMapPrototype>(map, out var mapProto))
|
||||
{
|
||||
Logger.Error("Couldn't index map " + map + " in pool " + pool.ID);
|
||||
continue;
|
||||
}
|
||||
|
||||
yield return mapProto;
|
||||
}
|
||||
} else
|
||||
{
|
||||
throw new Exception("Could not index map pool prototype " + _configurationManager.GetCVar(CCVars.GameMapPool) + "!");
|
||||
}
|
||||
}
|
||||
|
||||
public IEnumerable<GameMapPrototype> AllMaps()
|
||||
@@ -170,7 +185,6 @@ public sealed class GameMapManager : IGameMapManager
|
||||
{
|
||||
Logger.InfoS("mapsel", string.Join(", ", _previousMaps));
|
||||
var eligible = CurrentlyEligibleMaps()
|
||||
.Where(x => x.Votable)
|
||||
.Select(x => (proto: x, weight: GetMapQueuePriority(x.ID)))
|
||||
.OrderByDescending(x => x.weight).ToArray();
|
||||
Logger.InfoS("mapsel", string.Join(", ", eligible.Select(x => (x.proto.ID, x.weight))));
|
||||
|
||||
22
Content.Server/Maps/GameMapPoolPrototype.cs
Normal file
22
Content.Server/Maps/GameMapPoolPrototype.cs
Normal file
@@ -0,0 +1,22 @@
|
||||
using JetBrains.Annotations;
|
||||
using Robust.Shared.Prototypes;
|
||||
using Robust.Shared.Serialization.TypeSerializers.Implementations.Custom.Prototype.Set;
|
||||
|
||||
namespace Content.Server.Maps;
|
||||
|
||||
/// <summary>
|
||||
/// Prototype that holds a pool of maps that can be indexed based on the map pool CCVar.
|
||||
/// </summary>
|
||||
[Prototype("gameMapPool"), PublicAPI]
|
||||
public sealed class GameMapPoolPrototype : IPrototype
|
||||
{
|
||||
/// <inheritdoc/>
|
||||
[IdDataField]
|
||||
public string ID { get; } = default!;
|
||||
|
||||
/// <summary>
|
||||
/// Which maps are in this pool.
|
||||
/// </summary>
|
||||
[DataField("maps", customTypeSerializer:typeof(PrototypeIdHashSetSerializer<GameMapPrototype>), required: true)]
|
||||
public readonly HashSet<string> Maps = new(0);
|
||||
}
|
||||
@@ -8,12 +8,6 @@ public sealed partial class GameMapPrototype
|
||||
[DataField("fallback")]
|
||||
public bool Fallback { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Controls if the map can be voted for.
|
||||
/// </summary>
|
||||
[DataField("votable")]
|
||||
public bool Votable { get; } = true;
|
||||
|
||||
/// <summary>
|
||||
/// Minimum players for the given map.
|
||||
/// </summary>
|
||||
|
||||
@@ -184,6 +184,12 @@ namespace Content.Shared.CCVar
|
||||
public static readonly CVarDef<string>
|
||||
GameMap = CVarDef.Create("game.map", "Saltern", CVar.SERVERONLY);
|
||||
|
||||
/// <summary>
|
||||
/// Prototype to use for map pool.
|
||||
/// </summary>
|
||||
public static readonly CVarDef<string>
|
||||
GameMapPool = CVarDef.Create("game.map_pool", "DefaultMapPool", CVar.SERVERONLY);
|
||||
|
||||
/// <summary>
|
||||
/// Controls if the game should obey map criteria or not. Overriden if a map vote or similar occurs.
|
||||
/// </summary>
|
||||
|
||||
13
Resources/Prototypes/Maps/Pools/default.yml
Normal file
13
Resources/Prototypes/Maps/Pools/default.yml
Normal file
@@ -0,0 +1,13 @@
|
||||
- type: gameMapPool
|
||||
id: DefaultMapPool
|
||||
maps:
|
||||
- Bagel
|
||||
- Box
|
||||
- Cluster
|
||||
- Kettle
|
||||
- Lighthouse
|
||||
- Marathon
|
||||
- Omega
|
||||
- Origin
|
||||
- Pillar
|
||||
- Saltern
|
||||
@@ -3,7 +3,6 @@
|
||||
mapName: 'Central Command'
|
||||
mapPath: /Maps/centcomm.yml
|
||||
minPlayers: 10
|
||||
votable: false
|
||||
stations:
|
||||
centcomm:
|
||||
mapNameTemplate: '{0} Central Command {1}'
|
||||
|
||||
@@ -4,7 +4,6 @@
|
||||
mapPath: /Maps/cluster.yml
|
||||
minPlayers: 0
|
||||
maxPlayers: 35
|
||||
votable: true
|
||||
stations:
|
||||
Cluster:
|
||||
mapNameTemplate: '{0} Cluster Station {1}'
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
mapName: 'Dart ERT'
|
||||
mapPath: /Maps/dart.yml
|
||||
minPlayers: 0
|
||||
votable: false
|
||||
stations:
|
||||
Dart:
|
||||
mapNameTemplate: '{0} Dart ERT {1}'
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
mapName: 'Syndicate Infiltrator'
|
||||
mapPath: /Maps/infiltrator.yml
|
||||
minPlayers: 0
|
||||
votable: false
|
||||
stations:
|
||||
Station: #TODO: Mapper, add a BecomesStation component to the primary grid of the map.
|
||||
mapNameTemplate: '{0} Infiltrator {1}'
|
||||
|
||||
@@ -4,7 +4,6 @@
|
||||
mapPath: /Maps/omega.yml
|
||||
minPlayers: 0
|
||||
maxPlayers: 35
|
||||
votable: true
|
||||
stations:
|
||||
Omega:
|
||||
mapNameTemplate: '{0} Omega Station {1}'
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
mapName: 'Pirate Ship'
|
||||
mapPath: /Maps/pirate.yml
|
||||
minPlayers: 0
|
||||
votable: false
|
||||
stations:
|
||||
Station: #TODO: Mapper, add a BecomesStation component to the primary grid of the map.
|
||||
mapNameTemplate: '{0} Pirate {1}'
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
mapName: Empty
|
||||
mapPath: /Maps/Test/empty.yml
|
||||
minPlayers: 0
|
||||
votable: false
|
||||
stations:
|
||||
Empty:
|
||||
mapNameTemplate: "Empty"
|
||||
|
||||
Reference in New Issue
Block a user