From c149663e54327bfcbec0b596aa7921801baaf239 Mon Sep 17 00:00:00 2001 From: Dvir <39403717+dvir001@users.noreply.github.com> Date: Wed, 25 Dec 2024 04:31:37 +0200 Subject: [PATCH 01/14] Update EECCVars.cs (#2605) --- Content.Shared/_EE/CCVar/EECCVars.cs | 127 +++++++++++++-------------- 1 file changed, 62 insertions(+), 65 deletions(-) diff --git a/Content.Shared/_EE/CCVar/EECCVars.cs b/Content.Shared/_EE/CCVar/EECCVars.cs index b16d1fa01f0..378559a5037 100644 --- a/Content.Shared/_EE/CCVar/EECCVars.cs +++ b/Content.Shared/_EE/CCVar/EECCVars.cs @@ -1,81 +1,78 @@ -using Robust.Shared; using Robust.Shared.Configuration; -namespace Content.Shared._EE.CCVar +namespace Content.Shared._EE.CCVar; + +[CVarDefs] // ReSharper disable once InconsistentNaming +public sealed class EECCVars { - // ReSharper disable once InconsistentNaming - [CVarDefs] - public sealed class EECCVars : CVars - { - #region Jetpack System + #region Jetpack System - /// - /// When true, Jetpacks can be enabled anywhere, even in gravity. - /// - public static readonly CVarDef JetpackEnableAnywhere = - CVarDef.Create("ee.jetpack.enable_anywhere", false, CVar.REPLICATED); + /// + /// When true, Jetpacks can be enabled anywhere, even in gravity. + /// + public static readonly CVarDef JetpackEnableAnywhere = + CVarDef.Create("ee.jetpack.enable_anywhere", false, CVar.REPLICATED); - /// - /// When true, jetpacks can be enabled on grids that have zero gravity. - /// - public static readonly CVarDef JetpackEnableInNoGravity = - CVarDef.Create("ee.jetpack.enable_in_no_gravity", true, CVar.REPLICATED); + /// + /// When true, jetpacks can be enabled on grids that have zero gravity. + /// + public static readonly CVarDef JetpackEnableInNoGravity = + CVarDef.Create("ee.jetpack.enable_in_no_gravity", true, CVar.REPLICATED); - #endregion + #endregion - #region Contests System + #region Contests System - /// - /// The MASTER TOGGLE for the entire Contests System. - /// ALL CONTESTS BELOW, regardless of type or setting will output 1f when false. - /// - public static readonly CVarDef DoContestsSystem = - CVarDef.Create("contests.do_contests_system", true, CVar.REPLICATED | CVar.SERVER); + /// + /// The MASTER TOGGLE for the entire Contests System. + /// ALL CONTESTS BELOW, regardless of type or setting will output 1f when false. + /// + public static readonly CVarDef DoContestsSystem = + CVarDef.Create("ee.contests.do_contests_system", true, CVar.REPLICATED | CVar.SERVER); - /// - /// Contest functions normally include an optional override to bypass the clamp set by max_percentage. - /// This CVar disables the bypass when false, forcing all implementations to comply with max_percentage. - /// - public static readonly CVarDef AllowClampOverride = - CVarDef.Create("contests.allow_clamp_override", true, CVar.REPLICATED | CVar.SERVER); - /// - /// Toggles all MassContest functions. All mass contests output 1f when false - /// - public static readonly CVarDef DoMassContests = - CVarDef.Create("contests.do_mass_contests", true, CVar.REPLICATED | CVar.SERVER); + /// + /// Contest functions normally include an optional override to bypass the clamp set by max_percentage. + /// This CVar disables the bypass when false, forcing all implementations to comply with max_percentage. + /// + public static readonly CVarDef AllowClampOverride = + CVarDef.Create("ee.contests.allow_clamp_override", true, CVar.REPLICATED | CVar.SERVER); + /// + /// Toggles all MassContest functions. All mass contests output 1f when false + /// + public static readonly CVarDef DoMassContests = + CVarDef.Create("ee.contests.do_mass_contests", true, CVar.REPLICATED | CVar.SERVER); - /// - /// Toggles all StaminaContest functions. All stamina contests output 1f when false - /// - public static readonly CVarDef DoStaminaContests = - CVarDef.Create("contests.do_stamina_contests", true, CVar.REPLICATED | CVar.SERVER); + /// + /// Toggles all StaminaContest functions. All stamina contests output 1f when false + /// + public static readonly CVarDef DoStaminaContests = + CVarDef.Create("ee.contests.do_stamina_contests", true, CVar.REPLICATED | CVar.SERVER); - /// - /// Toggles all HealthContest functions. All health contests output 1f when false - /// - public static readonly CVarDef DoHealthContests = - CVarDef.Create("contests.do_health_contests", true, CVar.REPLICATED | CVar.SERVER); + /// + /// Toggles all HealthContest functions. All health contests output 1f when false + /// + public static readonly CVarDef DoHealthContests = + CVarDef.Create("ee.contests.do_health_contests", true, CVar.REPLICATED | CVar.SERVER); - /// - /// Toggles all MindContest functions. All mind contests output 1f when false. - /// MindContests are not currently implemented, and are awaiting completion of the Psionic Refactor - /// - public static readonly CVarDef DoMindContests = - CVarDef.Create("contests.do_mind_contests", true, CVar.REPLICATED | CVar.SERVER); + /// + /// Toggles all MindContest functions. All mind contests output 1f when false. + /// MindContests are not currently implemented, and are awaiting completion of the Psionic Refactor + /// + public static readonly CVarDef DoMindContests = + CVarDef.Create("ee.contests.do_mind_contests", true, CVar.REPLICATED | CVar.SERVER); - /// - /// Toggles all MoodContest functions. All mood contests output 1f when false. - /// - public static readonly CVarDef DoMoodContests = - CVarDef.Create("contests.do_mood_contests", true, CVar.REPLICATED | CVar.SERVER); + /// + /// Toggles all MoodContest functions. All mood contests output 1f when false. + /// + public static readonly CVarDef DoMoodContests = + CVarDef.Create("ee.contests.do_mood_contests", true, CVar.REPLICATED | CVar.SERVER); - /// - /// The maximum amount that Mass Contests can modify a physics multiplier, given as a +/- percentage - /// Default of 0.25f outputs between * 0.75f and 1.25f - /// - public static readonly CVarDef MassContestsMaxPercentage = - CVarDef.Create("contests.max_percentage", 0.25f, CVar.REPLICATED | CVar.SERVER); + /// + /// The maximum amount that Mass Contests can modify a physics multiplier, given as a +/- percentage + /// Default of 0.25f outputs between * 0.75f and 1.25f + /// + public static readonly CVarDef MassContestsMaxPercentage = + CVarDef.Create("ee.contests.max_percentage", 0.25f, CVar.REPLICATED | CVar.SERVER); - #endregion - } + #endregion } From bef531774520f16db52b5154d221984062455a23 Mon Sep 17 00:00:00 2001 From: Whatstone <166147148+whatston3@users.noreply.github.com> Date: Wed, 25 Dec 2024 19:49:53 -0500 Subject: [PATCH 02/14] Flatpacks: rotatable, soil needs a shovel (#2608) * Rotatable flatpacks * soil crates need to be dug * Directional sprites for docking airlock flatpacks --- .../Construction/SharedFlatpackSystem.cs | 2 ++ .../Entities/Objects/Devices/flatpack.yml | 1 + .../_NF/Entities/Objects/Devices/flatpacks.yml | 17 ++++++++++++----- .../command_airlock_directional.png | Bin 0 -> 464 bytes .../_NF/Objects/Devices/flatpack.rsi/meta.json | 3 +++ 5 files changed, 18 insertions(+), 5 deletions(-) create mode 100644 Resources/Textures/_NF/Objects/Devices/flatpack.rsi/command_airlock_directional.png diff --git a/Content.Shared/Construction/SharedFlatpackSystem.cs b/Content.Shared/Construction/SharedFlatpackSystem.cs index a83948b1674..9644800d773 100644 --- a/Content.Shared/Construction/SharedFlatpackSystem.cs +++ b/Content.Shared/Construction/SharedFlatpackSystem.cs @@ -93,6 +93,8 @@ private void OnFlatpackInteractUsing(Entity ent, ref Interact if (_net.IsServer) { var spawn = Spawn(comp.Entity, _map.GridTileToLocal(grid, gridComp, buildPos)); + if (TryComp(spawn, out TransformComponent? spawnXform)) // Frontier: rotatable flatpacks + spawnXform.LocalRotation = xform.LocalRotation.GetCardinalDir().ToAngle(); // Frontier: rotatable flatpacks _adminLogger.Add(LogType.Construction, LogImpact.Low, $"{ToPrettyString(args.User):player} unpacked {ToPrettyString(spawn):entity} at {xform.Coordinates} from {ToPrettyString(uid):entity}"); diff --git a/Resources/Prototypes/Entities/Objects/Devices/flatpack.yml b/Resources/Prototypes/Entities/Objects/Devices/flatpack.yml index 8a6424ffcc7..c6f9c7449f9 100644 --- a/Resources/Prototypes/Entities/Objects/Devices/flatpack.yml +++ b/Resources/Prototypes/Entities/Objects/Devices/flatpack.yml @@ -35,6 +35,7 @@ cpu_supply: "#A46106" - type: StaticPrice price: 250 + - type: Rotatable # Frontier - type: entity parent: BaseFlatpack diff --git a/Resources/Prototypes/_NF/Entities/Objects/Devices/flatpacks.yml b/Resources/Prototypes/_NF/Entities/Objects/Devices/flatpacks.yml index 12971234f6b..27abddaeaa7 100644 --- a/Resources/Prototypes/_NF/Entities/Objects/Devices/flatpacks.yml +++ b/Resources/Prototypes/_NF/Entities/Objects/Devices/flatpacks.yml @@ -370,11 +370,13 @@ - type: entity parent: UniformPrinterFlatpack id: HydroponicsSoilNutritionFlatpack - name: crate with fertile soil - description: A crate with fertile soil used for constructing a soil bed for growing. + name: crate of fertile soil + description: A crate of fertile soil used for constructing a soil bed for growing. Spread it around with a shovel. components: - type: Flatpack entity: HydroponicsSoilNutrition + qualityNeeded: Digging + unpackSound: /Audio/Items/shovel_dig.ogg - type: Sprite layers: - state: soil @@ -382,11 +384,13 @@ - type: entity parent: UniformPrinterFlatpack id: HydroponicsSoilEmptyFlatpack - name: crate with soil - description: A crate with soil used for constructing a soil bed for growing. + name: crate of soil + description: A crate of soil used for constructing a soil bed for growing. Spread it around with a shovel. components: - type: Flatpack entity: HydroponicsSoilEmpty + qualityNeeded: Digging + unpackSound: /Audio/Items/shovel_dig.ogg - type: Sprite layers: - state: soil @@ -669,9 +673,12 @@ components: - type: Flatpack entity: AirlockShuttle + - type: Sprite + layers: + - state: command_airlock_directional - type: entity - parent: AirlockFlatpack + parent: AirlockShuttleFlatpack id: AirlockGlassShuttleFlatpack name: docking glass airlock flatpack description: A flatpack used for constructing a glass docking airlock. diff --git a/Resources/Textures/_NF/Objects/Devices/flatpack.rsi/command_airlock_directional.png b/Resources/Textures/_NF/Objects/Devices/flatpack.rsi/command_airlock_directional.png new file mode 100644 index 0000000000000000000000000000000000000000..49f01a01d363dc3c5c37ca96cc52d05a5603201d GIT binary patch literal 464 zcmV;>0WbcEP)U#buwr|RDgxW2mmGNVr?JRXmA z9PBtQI{Ur^NTsLhv$Hc8g92HS)F)P`Rm&~D;lw17`vXkN#Cug-TwF4pn&$E0;b#Ev z708lA2m{<>qWx`*ZUuyaEJ?=35?YmO0RU8bGekv=!d@}(uv|V%r8h%_YWDzY)v~YZ zTt3_4`3P65mKo8Ghn^0+tz$1g>rtQOauz^(z1XYujf4+}%}t^FIUVwmJsb z-Ixa;nH=}ce+^(bG1(j!_KFB$u)o!~^Zl(XLKwbB_|dPUz+YeuNTl+75T8jY4{KB+ zy9oebS|;}LJVF@kEIcz3i#OMvT!;13A(ZkkEz`HpaooVO1Fyh)Rn75B%*H-U^W-|s zaQiULOU!QZ-(24WHX_jIhKoyc-|B=XN9S6dHdLrkq22&D0)qfGL`@_B0000 Date: Thu, 26 Dec 2024 00:50:19 +0000 Subject: [PATCH 03/14] Automatic Changelog (#2608) --- Resources/Changelog/Frontier.yml | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Resources/Changelog/Frontier.yml b/Resources/Changelog/Frontier.yml index 62a7ab1e93d..12d09316d55 100644 --- a/Resources/Changelog/Frontier.yml +++ b/Resources/Changelog/Frontier.yml @@ -6096,3 +6096,11 @@ Entries: shots. id: 5610 time: '2024-12-24T23:05:02.0000000+00:00' +- author: whatston3 + changes: + - type: Add + message: Flatpacks can be rotated, and respect their rotation when unpacked. + - type: Tweak + message: Soil crates now must be "assembled" with a shovel. + id: 5611 + time: '2024-12-26T00:49:53.0000000+00:00' From 33126876b3cb0bb4403b1ad81dca23119d2d4fbc Mon Sep 17 00:00:00 2001 From: Whatstone <166147148+whatston3@users.noreply.github.com> Date: Thu, 26 Dec 2024 01:05:24 -0500 Subject: [PATCH 04/14] trade outpost: catwalks in cb1 (#2611) --- Resources/Maps/_NF/POI/trade.yml | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/Resources/Maps/_NF/POI/trade.yml b/Resources/Maps/_NF/POI/trade.yml index 1fab43e1778..27b2a1d9789 100644 --- a/Resources/Maps/_NF/POI/trade.yml +++ b/Resources/Maps/_NF/POI/trade.yml @@ -9219,18 +9219,6 @@ entities: parent: 1 - proto: CargoPalletSell entities: - - uid: 225 - components: - - type: Transform - rot: 3.141592653589793 rad - pos: 61.5,22.5 - parent: 1 - - uid: 226 - components: - - type: Transform - rot: 3.141592653589793 rad - pos: 63.5,22.5 - parent: 1 - uid: 228 components: - type: Transform @@ -9461,6 +9449,16 @@ entities: - type: Transform pos: 81.5,-7.5 parent: 1 + - uid: 225 + components: + - type: Transform + pos: 61.5,22.5 + parent: 1 + - uid: 226 + components: + - type: Transform + pos: 63.5,22.5 + parent: 1 - uid: 341 components: - type: Transform From fa4b9fd9fdf85aa848fd8654d13bc5f414b5f2ef Mon Sep 17 00:00:00 2001 From: Whatstone <166147148+whatston3@users.noreply.github.com> Date: Thu, 26 Dec 2024 10:21:56 -0500 Subject: [PATCH 05/14] alt depot needs presets (#2613) --- Resources/Prototypes/_NF/PointsOfInterest/depots.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/Resources/Prototypes/_NF/PointsOfInterest/depots.yml b/Resources/Prototypes/_NF/PointsOfInterest/depots.yml index 0b8eae5b82c..d6c3105327d 100644 --- a/Resources/Prototypes/_NF/PointsOfInterest/depots.yml +++ b/Resources/Prototypes/_NF/PointsOfInterest/depots.yml @@ -31,6 +31,7 @@ name: Cargo Depot minimumDistance: 4500 maximumDistance: 6000 + spawnGamePreset: [ NFAdventure, NFPirate ] spawnGroup: CargoDepot gridPath: /Maps/_NF/POI/cargodepotalt.yml addComponents: From cb6514197459774e92bc983f1848038a3ef522f3 Mon Sep 17 00:00:00 2001 From: FrontierATC Date: Thu, 26 Dec 2024 15:22:25 +0000 Subject: [PATCH 06/14] Automatic Changelog (#2613) --- Resources/Changelog/Frontier.yml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Resources/Changelog/Frontier.yml b/Resources/Changelog/Frontier.yml index 12d09316d55..99b83bb1457 100644 --- a/Resources/Changelog/Frontier.yml +++ b/Resources/Changelog/Frontier.yml @@ -6104,3 +6104,9 @@ Entries: message: Soil crates now must be "assembled" with a shovel. id: 5611 time: '2024-12-26T00:49:53.0000000+00:00' +- author: whatston3 + changes: + - type: Fix + message: Cargo Depots should be spawning normally now. + id: 5612 + time: '2024-12-26T15:21:56.0000000+00:00' From 6e11ad492e82a1de79eac0f125fe44a013319382 Mon Sep 17 00:00:00 2001 From: Whatstone <166147148+whatston3@users.noreply.github.com> Date: Thu, 26 Dec 2024 15:18:09 -0500 Subject: [PATCH 07/14] Random appearance for random pills (#2612) * Better random pills * Namespace matches folder * Milon's suggestions --- .../_NF/Chemistry/RandomPillSystem.cs | 26 +++++++++++++++++++ .../Chemistry/Components/PillComponent.cs | 6 +++++ .../Objects/Specific/Medical/randompill.yml | 2 ++ 3 files changed, 34 insertions(+) create mode 100644 Content.Server/_NF/Chemistry/RandomPillSystem.cs diff --git a/Content.Server/_NF/Chemistry/RandomPillSystem.cs b/Content.Server/_NF/Chemistry/RandomPillSystem.cs new file mode 100644 index 00000000000..9326703f323 --- /dev/null +++ b/Content.Server/_NF/Chemistry/RandomPillSystem.cs @@ -0,0 +1,26 @@ +using Content.Shared.Chemistry.Components; +using Robust.Shared.Random; + +namespace Content.Server._NF.Chemistry; + +public sealed class RandomPillSystem : EntitySystem +{ + [Dependency] private readonly IRobustRandom _random = default!; + + public const int MaxPillType = 21; + + public override void Initialize() + { + base.Initialize(); + SubscribeLocalEvent(OnMapInit); + } + + private void OnMapInit(Entity ent, ref MapInitEvent componentInit) + { + if (ent.Comp.Random) + { + ent.Comp.PillType = (uint)_random.Next(MaxPillType); + Dirty(ent); + } + } +} diff --git a/Content.Shared/Chemistry/Components/PillComponent.cs b/Content.Shared/Chemistry/Components/PillComponent.cs index ad32aa750a4..0cb356454d6 100644 --- a/Content.Shared/Chemistry/Components/PillComponent.cs +++ b/Content.Shared/Chemistry/Components/PillComponent.cs @@ -12,4 +12,10 @@ public sealed partial class PillComponent : Component [DataField("pillType")] [ViewVariables(VVAccess.ReadWrite)] public uint PillType; + + /// + /// Frontier: if true, pill appearance will be randomly generated on init. + /// + [DataField(serverOnly: true)] + public bool Random; } diff --git a/Resources/Prototypes/Entities/Objects/Specific/Medical/randompill.yml b/Resources/Prototypes/Entities/Objects/Specific/Medical/randompill.yml index cdff0cdbe4a..26714e22ada 100644 --- a/Resources/Prototypes/Entities/Objects/Specific/Medical/randompill.yml +++ b/Resources/Prototypes/Entities/Objects/Specific/Medical/randompill.yml @@ -86,6 +86,8 @@ - type: RandomFillSolution solution: food weightedRandomId: RandomFillStrangePill + - type: Pill # Frontier + random: true # Frontier # RandomSprite does not work with pill component # - type: Sprite # sprite: Objects/Specific/Chemistry/pills.rsi From 6c50bddd754df671485fa93359e15197489823b5 Mon Sep 17 00:00:00 2001 From: Whatstone <166147148+whatston3@users.noreply.github.com> Date: Thu, 26 Dec 2024 15:21:41 -0500 Subject: [PATCH 08/14] Selectively cherry-pick ss#32936 (thanks ilya246) (#2610) --- .../StackCustomSplitBoundUserInterface.cs | 41 +++++++++++++++++++ .../Stack/StackCustomSplitWindow.xaml | 15 +++++++ .../Stack/StackCustomSplitWindow.xaml.cs | 35 ++++++++++++++++ Content.Server/Stack/StackSystem.cs | 36 +++++++++++++++- Content.Shared/Stacks/SharedStackSystem.cs | 6 +++ Content.Shared/Stacks/StackCustomSplit.cs | 22 ++++++++++ .../Locale/en-US/stack/stack-component.ftl | 9 ++++ .../Entities/Objects/Misc/space_cash.yml | 6 +++ .../_NF/Entities/Objects/Misc/space_cash.yml | 28 +++++++------ 9 files changed, 184 insertions(+), 14 deletions(-) create mode 100644 Content.Client/Stack/StackCustomSplitBoundUserInterface.cs create mode 100644 Content.Client/Stack/StackCustomSplitWindow.xaml create mode 100644 Content.Client/Stack/StackCustomSplitWindow.xaml.cs create mode 100644 Content.Shared/Stacks/StackCustomSplit.cs diff --git a/Content.Client/Stack/StackCustomSplitBoundUserInterface.cs b/Content.Client/Stack/StackCustomSplitBoundUserInterface.cs new file mode 100644 index 00000000000..ff9a03580a9 --- /dev/null +++ b/Content.Client/Stack/StackCustomSplitBoundUserInterface.cs @@ -0,0 +1,41 @@ +// Cherry-picked from space-station-14#32938 courtesy of Ilya246 +using JetBrains.Annotations; +using Content.Shared.Stacks; +using Robust.Client.GameObjects; +using Robust.Client.UserInterface; + +namespace Content.Client.Stack +{ + [UsedImplicitly] + public sealed class StackCustomSplitBoundUserInterface : BoundUserInterface + { + private IEntityManager _entManager; + private EntityUid _owner; + [ViewVariables] + private StackCustomSplitWindow? _window; + + public StackCustomSplitBoundUserInterface(EntityUid owner, Enum uiKey) : base(owner, uiKey) + { + _owner = owner; + _entManager = IoCManager.Resolve(); + } + + protected override void Open() + { + base.Open(); + _window = this.CreateWindow(); + + if (_entManager.TryGetComponent(_owner, out var comp)) + _window.SetMax(comp.Count); + + _window.ApplyButton.OnPressed += _ => + { + if (int.TryParse(_window.AmountLineEdit.Text, out var i)) + { + SendMessage(new StackCustomSplitAmountMessage(i)); + _window.Close(); + } + }; + } + } +} diff --git a/Content.Client/Stack/StackCustomSplitWindow.xaml b/Content.Client/Stack/StackCustomSplitWindow.xaml new file mode 100644 index 00000000000..2294d459415 --- /dev/null +++ b/Content.Client/Stack/StackCustomSplitWindow.xaml @@ -0,0 +1,15 @@ + + + + + + + + + +