Compare commits

...

3 commits

21 changed files with 142 additions and 170 deletions

4
.readme_generator.py Normal file → Executable file
View file

@ -21,8 +21,8 @@ def main():
doc += f"## {mod['Title']}\n" doc += f"## {mod['Title']}\n"
doc += str( doc += str(
f'<img src="{dir.name}{sep}{mod["ImagePath"]}" ' f'<img src="{dir.name}{sep}{mod["ImagePath"]}" '
+ 'alt="mod preview"' + 'alt="mod preview" '
+ ' width="48" height="48" /><br/>\n\n', + 'width="48" height="48" /><br/>\n\n',
) )
doc += f"{mod['Description']}\n\n" doc += f"{mod['Description']}\n\n"
doc += "[Link to the Steam Workshop page]" doc += "[Link to the Steam Workshop page]"

0
AutoDropBedding/AutoDropBeddingMenu.cs Executable file → Normal file
View file

0
AutoDropBedding/Config.cs Executable file → Normal file
View file

0
AutoDropBedding/Extensions.cs Executable file → Normal file
View file

0
AutoDropBedding/HarmonyPatches/Patch_Survival_Camp.cs Executable file → Normal file
View file

0
AutoDropBedding/Helpers.cs Executable file → Normal file
View file

0
AutoDropBedding/ObjectBlueprints.xml Executable file → Normal file
View file

0
AutoDropBedding/Options.xml Executable file → Normal file
View file

0
AutoDropBedding/manifest.json Executable file → Normal file
View file

0
AutoDropBedding/preview.png Executable file → Normal file
View file

Before

Width:  |  Height:  |  Size: 25 KiB

After

Width:  |  Height:  |  Size: 25 KiB

0
AutoDropBedding/screenshot_campfire.png Executable file → Normal file
View file

Before

Width:  |  Height:  |  Size: 25 KiB

After

Width:  |  Height:  |  Size: 25 KiB

0
AutoDropBedding/screenshot_menu.png Executable file → Normal file
View file

Before

Width:  |  Height:  |  Size: 45 KiB

After

Width:  |  Height:  |  Size: 45 KiB

0
AutoDropBedding/workshop.json Executable file → Normal file
View file

138
CyberneticHearingAid/CyberneticHeightenedHearingEffect.cs Executable file → Normal file
View file

@ -2,6 +2,7 @@ using System;
using XRL.UI; using XRL.UI;
using XRL.World.Capabilities; using XRL.World.Capabilities;
using XRL.World.Parts; using XRL.World.Parts;
using XRL.World.Parts.Mutation;
// this is 95% copy/pasted from decompiled vanilla HeightenedHearingEffect // this is 95% copy/pasted from decompiled vanilla HeightenedHearingEffect
// only thing added was a reference to the implant because it has the part rather than the implantee // only thing added was a reference to the implant because it has the part rather than the implantee
@ -10,18 +11,12 @@ namespace XRL.World.Effects
[Serializable] [Serializable]
public class CyberneticHeightenedHearingEffect : Effect public class CyberneticHeightenedHearingEffect : Effect
{ {
public bool bIdentified; public bool Identified;
public int Level = 1; public int Level = 1;
public GameObject Listener; public GameObject Listener;
public GameObject Implant; public GameObject Implant;
public CyberneticHeightenedHearingEffect() => Duration = 1;
public CyberneticHeightenedHearingEffect(int Level, GameObject Listener) public CyberneticHeightenedHearingEffect() => this.Duration = 1;
: this()
{
this.Level = Level;
this.Listener = Listener;
}
public CyberneticHeightenedHearingEffect(int Level, GameObject Listener, GameObject Implant) public CyberneticHeightenedHearingEffect(int Level, GameObject Listener, GameObject Implant)
: this() : this()
@ -37,78 +32,65 @@ namespace XRL.World.Effects
public override string GetDescription() => (string)null; public override string GetDescription() => (string)null;
public override bool WantEvent(int ID, int cascade) => base.WantEvent(ID, cascade) || ID == SingletonEvent<EndTurnEvent>.ID || ID == EnteringCellEvent.ID;
public override bool HandleEvent(AfterPlayerBodyChangeEvent E)
{
this.CheckListen();
return base.HandleEvent(E);
}
public override bool HandleEvent(EndTurnEvent E)
{
this.CheckListen();
return base.HandleEvent(E);
}
public override bool HandleEvent(EnteringCellEvent E)
{
this.CheckListen();
return base.HandleEvent(E);
}
private bool BadListener() private bool BadListener()
{ {
Listener = null; this.Listener = (GameObject)null;
Object.RemoveEffect(this); this.Object?.RemoveEffect((Effect)this);
return true; return true;
} }
public bool CheckListen() public bool CheckListen()
{ {
if (!GameObject.validate(ref Listener) || !Listener.IsPlayer()) if (!GameObject.Validate(this.Object))
{
return BadListener();
}
if (!(Implant.GetPart("CyberneticsHearingAid") is CyberneticsHearingAid part))
{
return BadListener();
}
int num = Object.DistanceTo(Listener);
if (num > part.Radius)
{
return BadListener();
}
if (bIdentified)
{
CheckInterruptAutoExplore();
return true; return true;
} if (!GameObject.Validate(ref this.Listener) || !this.Listener.IsPlayer())
return this.BadListener();
if (Object.CurrentCell == null) CyberneticsHearingAid part = this.Listener.GetPart<CyberneticsHearingAid>();
{ if (part == null || part.Level <= 0)
return this.BadListener();
if (!(Implant.GetPart("CyberneticsHearingAid") is CyberneticsHearingAid otherpart))
return this.BadListener();
int num = this.Object.DistanceTo(this.Listener);
if (num > part.GetRadius())
return this.BadListener();
if (this.Identified || this.Object.CurrentCell == null)
return true; return true;
} if (((int)((double)(100 + 10 * this.Level) / Math.Pow((double)(num + 9), 2.0) * 100.0)).in100())
if (((int)((100 + (10 * Level)) / Math.Pow(num + 9, 2.0) * 100.0)).in100())
{ {
bIdentified = true; this.Identified = true;
CheckInterruptAutoExplore(); if (this.Listener.IsPlayer())
AutoAct.CheckHostileInterrupt();
} }
return false; return false;
} }
public void CheckInterruptAutoExplore()
{
if (!bIdentified || !GameObject.validate(ref Listener) || !Listener.IsPlayer() || !AutoAct.IsInterruptable() || AutoAct.IsGathering() || !Listener.IsRelevantHostile(Object))
return;
AddPlayerMessage(Listener.GenerateSpotMessage(Object, verb: "hear"));
AutoAct.Interrupt(null, null, Object);
}
public override bool Apply(GameObject Object) public override bool Apply(GameObject Object)
{ {
if (Object.pBrain != null) this.CheckListen();
Object.pBrain.Hibernating = false;
CheckListen();
return true; return true;
} }
public override void Register(GameObject Object) public override void RegisterActive(GameObject Object, IEventRegistrar Registrar) => Registrar.Register((IEventSource)The.Game, (IEventHandler)this, PooledEvent<AfterPlayerBodyChangeEvent>.ID);
{
Object.RegisterEffectEvent(this, "EndTurn");
base.Register(Object);
}
public override void Unregister(GameObject Object)
{
Object.UnregisterEffectEvent(this, "EndTurn");
base.Unregister(Object);
}
public bool HeardAndNotSeen(GameObject obj) public bool HeardAndNotSeen(GameObject obj)
{ {
@ -122,36 +104,24 @@ namespace XRL.World.Effects
public override bool FinalRender(RenderEvent E, bool bAlt) public override bool FinalRender(RenderEvent E, bool bAlt)
{ {
if (!HeardAndNotSeen(Object) || !Object.CanHypersensesDetect()) if (!this.HeardAndNotSeen(this.Object) || !this.Object.CanHypersensesDetect())
{
return true; return true;
} E.Tile = (string)null;
if (this.Identified)
if (bIdentified)
{ {
E.HighestLayer = 0; E.HighestLayer = 0;
Object.Render(E); E.NoWake = true;
E.ColorString = "&K"; this.Object.ComponentRender(E);
E.DetailColor = "K"; E.RenderString = this.Object.Render.RenderString;
E.RenderString = Object.pRender.RenderString; if (Options.UseTiles)
E.Tile = !Options.UseTiles ? null : Object.pRender.Tile; E.Tile = this.Object.Render.Tile;
E.CustomDraw = true;
} }
else else
{ E.RenderString = "?";
E.RenderString = "&K?"; E.ColorString = "&K";
E.Tile = null; E.DetailColor = "K";
E.CustomDraw = true; E.CustomDraw = true;
}
return false; return false;
} }
public override bool FireEvent(Event E)
{
if (E.ID == "EndTurn" && Object != null)
CheckListen();
return base.FireEvent(E);
}
} }
} }

4
CyberneticHearingAid/CyberneticsHearingAid.cs Executable file → Normal file
View file

@ -16,7 +16,9 @@ namespace XRL.World.Parts
get { return GetAvailableComputePowerEvent.GetFor(ParentObject.Implantee) + 1; } get { return GetAvailableComputePowerEvent.GetFor(ParentObject.Implantee) + 1; }
} }
public override bool SameAs(IPart p) => false; public static int GetRadius(int Level) => Level < 10 ? 3 + Level * 2 : 40;
public int GetRadius() => CyberneticsHearingAid.GetRadius(this.Level);
public override bool WantEvent(int ID, int cascade) => base.WantEvent(ID, cascade) || ID == EndTurnEvent.ID || ID == GetShortDescriptionEvent.ID; public override bool WantEvent(int ID, int cascade) => base.WantEvent(ID, cascade) || ID == EndTurnEvent.ID || ID == GetShortDescriptionEvent.ID;

0
CyberneticHearingAid/ObjectBlueprints.xml Executable file → Normal file
View file

0
CyberneticHearingAid/Textures/Items/hearingaid.png Executable file → Normal file
View file

Before

Width:  |  Height:  |  Size: 726 B

After

Width:  |  Height:  |  Size: 726 B

2
CyberneticHearingAid/manifest.json Executable file → Normal file
View file

@ -2,7 +2,7 @@
"id": "CyberneticHearingAid", "id": "CyberneticHearingAid",
"title": "{{cybernetic hearing aid|Cybernetic Hearing Aid}}", "title": "{{cybernetic hearing aid|Cybernetic Hearing Aid}}",
"description": "Enhanced hearing mutation but in cybernetics form.", "description": "Enhanced hearing mutation but in cybernetics form.",
"version": "1.0.0", "version": "1.0.1",
"author": "{{paisley|Celediel}}", "author": "{{paisley|Celediel}}",
"previewImage": "preview.png" "previewImage": "preview.png"
} }

0
CyberneticHearingAid/preview.png Executable file → Normal file
View file

Before

Width:  |  Height:  |  Size: 12 KiB

After

Width:  |  Height:  |  Size: 12 KiB

2
CyberneticHearingAid/workshop.json Executable file → Normal file
View file

@ -3,6 +3,6 @@
"Title": "Cybernetic Hearing Aid", "Title": "Cybernetic Hearing Aid",
"Description": "Like the Enhanced Hearing mutation, but a cybernetic.", "Description": "Like the Enhanced Hearing mutation, but a cybernetic.",
"Tags": "Script,Cybernetic", "Tags": "Script,Cybernetic",
"Visibility": "0", "Visibility": "2",
"ImagePath": "preview.png" "ImagePath": "preview.png"
} }

0
QudMods.csproj Executable file → Normal file
View file