Skip to content

Commit

Permalink
Merge branch 'develop' into stable
Browse files Browse the repository at this point in the history
  • Loading branch information
Pathoschild committed Dec 30, 2018
2 parents f046091 + 72888fe commit 79c6166
Show file tree
Hide file tree
Showing 12 changed files with 47 additions and 35 deletions.
4 changes: 2 additions & 2 deletions build/GlobalAssemblyInfo.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System.Reflection;

[assembly: AssemblyProduct("SMAPI")]
[assembly: AssemblyVersion("2.10.0")]
[assembly: AssemblyFileVersion("2.10.0")]
[assembly: AssemblyVersion("2.10.1")]
[assembly: AssemblyFileVersion("2.10.1")]
6 changes: 6 additions & 0 deletions docs/release-notes.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,10 @@
# Release notes
## 2.10.1
Released 30 December 2018 for Stardew Valley 1.3.32.

* For players:
* Fixed some mod integrations not working correctly in SMAPI 2.10.

## 2.10
Released 29 December 2018 for Stardew Valley 1.3.32.

Expand Down
4 changes: 2 additions & 2 deletions src/SMAPI.Mods.ConsoleCommands/manifest.json
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
{
"Name": "Console Commands",
"Author": "SMAPI",
"Version": "2.10.0",
"Version": "2.10.1",
"Description": "Adds SMAPI console commands that let you manipulate the game.",
"UniqueID": "SMAPI.ConsoleCommands",
"EntryDll": "ConsoleCommands.dll",
"MinimumApiVersion": "2.10.0"
"MinimumApiVersion": "2.10.1"
}
4 changes: 2 additions & 2 deletions src/SMAPI.Mods.SaveBackup/manifest.json
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
{
"Name": "Save Backup",
"Author": "SMAPI",
"Version": "2.10.0",
"Version": "2.10.1",
"Description": "Automatically backs up all your saves once per day into its folder.",
"UniqueID": "SMAPI.SaveBackup",
"EntryDll": "SaveBackup.dll",
"MinimumApiVersion": "2.10.0"
"MinimumApiVersion": "2.10.1"
}
2 changes: 1 addition & 1 deletion src/SMAPI/Constants.cs
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ public static class Constants
** Public
****/
/// <summary>SMAPI's current semantic version.</summary>
public static ISemanticVersion ApiVersion { get; } = new Toolkit.SemanticVersion("2.10.0");
public static ISemanticVersion ApiVersion { get; } = new Toolkit.SemanticVersion("2.10.1");

/// <summary>The minimum supported version of Stardew Valley.</summary>
public static ISemanticVersion MinimumGameVersion { get; } = new GameVersion("1.3.32");
Expand Down
4 changes: 2 additions & 2 deletions src/SMAPI/Events/OneSecondUpdateTickedEventArgs.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System;
using StardewValley;
using StardewModdingAPI.Framework;

namespace StardewModdingAPI.Events
{
Expand All @@ -10,7 +10,7 @@ public class OneSecondUpdateTickedEventArgs : EventArgs
** Accessors
*********/
/// <summary>The number of ticks elapsed since the game started, including the current tick.</summary>
public uint Ticks => (uint)Game1.ticks;
public uint Ticks => SGame.TicksElapsed;


/*********
Expand Down
6 changes: 3 additions & 3 deletions src/SMAPI/Events/OneSecondUpdateTickingEventArgs.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System;
using StardewValley;
using StardewModdingAPI.Framework;

namespace StardewModdingAPI.Events
{
Expand All @@ -9,8 +9,8 @@ public class OneSecondUpdateTickingEventArgs : EventArgs
/*********
** Accessors
*********/
/// <summary>The number of ticks elapsed since the game started, including the current tick.</summary>
public uint Ticks => (uint)Game1.ticks;
/// <summary>The number of ticks elapsed since the game started, excluding the upcoming tick.</summary>
public uint Ticks => SGame.TicksElapsed;


/*********
Expand Down
6 changes: 3 additions & 3 deletions src/SMAPI/Events/UnvalidatedUpdateTickedEventArgs.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System;
using StardewValley;
using StardewModdingAPI.Framework;

namespace StardewModdingAPI.Events
{
Expand All @@ -10,10 +10,10 @@ public class UnvalidatedUpdateTickedEventArgs : EventArgs
** Accessors
*********/
/// <summary>The number of ticks elapsed since the game started, including the current tick.</summary>
public uint Ticks => (uint)Game1.ticks;
public uint Ticks => SGame.TicksElapsed;

/// <summary>Whether <see cref="Ticks"/> is a multiple of 60, which happens approximately once per second.</summary>
public bool IsOneSecond => Game1.ticks % 60 == 0;
public bool IsOneSecond => this.Ticks % 60 == 0;


/*********
Expand Down
8 changes: 4 additions & 4 deletions src/SMAPI/Events/UnvalidatedUpdateTickingEventArgs.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System;
using StardewValley;
using StardewModdingAPI.Framework;

namespace StardewModdingAPI.Events
{
Expand All @@ -9,11 +9,11 @@ public class UnvalidatedUpdateTickingEventArgs : EventArgs
/*********
** Accessors
*********/
/// <summary>The number of ticks elapsed since the game started, including the current tick.</summary>
public uint Ticks => (uint)Game1.ticks;
/// <summary>The number of ticks elapsed since the game started, excluding the upcoming tick.</summary>
public uint Ticks => SGame.TicksElapsed;

/// <summary>Whether <see cref="Ticks"/> is a multiple of 60, which happens approximately once per second.</summary>
public bool IsOneSecond => Game1.ticks % 60 == 0;
public bool IsOneSecond => this.Ticks % 60 == 0;


/*********
Expand Down
6 changes: 3 additions & 3 deletions src/SMAPI/Events/UpdateTickedEventArgs.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System;
using StardewValley;
using StardewModdingAPI.Framework;

namespace StardewModdingAPI.Events
{
Expand All @@ -10,10 +10,10 @@ public class UpdateTickedEventArgs : EventArgs
** Accessors
*********/
/// <summary>The number of ticks elapsed since the game started, including the current tick.</summary>
public uint Ticks => (uint)Game1.ticks;
public uint Ticks => SGame.TicksElapsed;

/// <summary>Whether <see cref="Ticks"/> is a multiple of 60, which happens approximately once per second.</summary>
public bool IsOneSecond => Game1.ticks % 60 == 0;
public bool IsOneSecond => this.Ticks % 60 == 0;


/*********
Expand Down
8 changes: 4 additions & 4 deletions src/SMAPI/Events/UpdateTickingEventArgs.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using System;
using StardewValley;
using StardewModdingAPI.Framework;

namespace StardewModdingAPI.Events
{
Expand All @@ -9,11 +9,11 @@ public class UpdateTickingEventArgs : EventArgs
/*********
** Accessors
*********/
/// <summary>The number of ticks elapsed since the game started, including the current tick.</summary>
public uint Ticks => (uint)Game1.ticks;
/// <summary>The number of ticks elapsed since the game started, excluding the upcoming tick.</summary>
public uint Ticks => SGame.TicksElapsed;

/// <summary>Whether <see cref="Ticks"/> is a multiple of 60, which happens approximately once per second.</summary>
public bool IsOneSecond => Game1.ticks % 60 == 0;
public bool IsOneSecond => this.Ticks % 60 == 0;


/*********
Expand Down
24 changes: 15 additions & 9 deletions src/SMAPI/Framework/SGame.cs
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,9 @@ internal class SGame : Game1
/// <summary>Static state to use while <see cref="Game1"/> is initialising, which happens before the <see cref="SGame"/> constructor runs.</summary>
internal static SGameConstructorHack ConstructorHack { get; set; }

/// <summary>The number of update ticks which have already executed. This is similar to <see cref="Game1.ticks"/>, but incremented more consistently for every tick.</summary>
internal static uint TicksElapsed { get; private set; }

/// <summary>SMAPI's content manager.</summary>
public ContentCoordinator ContentCore { get; private set; }

Expand Down Expand Up @@ -339,6 +342,7 @@ protected override void Update(GameTime gameTime)
if (Game1._newDayTask != null || Game1.gameMode == Game1.loadingMode)
{
events.UnvalidatedUpdateTicking.RaiseEmpty();
SGame.TicksElapsed++;
base.Update(gameTime);
events.UnvalidatedUpdateTicked.RaiseEmpty();
#if !SMAPI_3_0_STRICT
Expand Down Expand Up @@ -431,6 +435,7 @@ protected override void Update(GameTime gameTime)

// suppress non-save events
events.UnvalidatedUpdateTicking.RaiseEmpty();
SGame.TicksElapsed++;
base.Update(gameTime);
events.UnvalidatedUpdateTicked.RaiseEmpty();
#if !SMAPI_3_0_STRICT
Expand Down Expand Up @@ -874,7 +879,7 @@ protected override void Update(GameTime gameTime)
** Game update
*********/
// game launched
bool isFirstTick = Game1.ticks == 0;
bool isFirstTick = SGame.TicksElapsed == 0;
if (isFirstTick)
events.GameLaunched.Raise(new GameLaunchedEventArgs());

Expand All @@ -883,14 +888,15 @@ protected override void Update(GameTime gameTime)
this.OnLoadStageChanged(LoadStage.Loaded);

// update tick
bool isOneSecond = Game1.ticks % 60 == 0;
bool isOneSecond = SGame.TicksElapsed % 60 == 0;
events.UnvalidatedUpdateTicking.RaiseEmpty();
events.UpdateTicking.RaiseEmpty();
if (isOneSecond)
events.OneSecondUpdateTicking.RaiseEmpty();
try
{
this.Input.UpdateSuppression();
SGame.TicksElapsed++;
base.Update(gameTime);
}
catch (Exception ex)
Expand All @@ -910,17 +916,17 @@ protected override void Update(GameTime gameTime)
if (isFirstTick)
events.Legacy_FirstUpdateTick.Raise();
events.Legacy_UpdateTick.Raise();
if (Game1.ticks % 2 == 0)
if (SGame.TicksElapsed % 2 == 0)
events.Legacy_SecondUpdateTick.Raise();
if (Game1.ticks % 4 == 0)
if (SGame.TicksElapsed % 4 == 0)
events.Legacy_FourthUpdateTick.Raise();
if (Game1.ticks % 8 == 0)
if (SGame.TicksElapsed % 8 == 0)
events.Legacy_EighthUpdateTick.Raise();
if (Game1.ticks % 15 == 0)
if (SGame.TicksElapsed % 15 == 0)
events.Legacy_QuarterSecondTick.Raise();
if (Game1.ticks % 30 == 0)
if (SGame.TicksElapsed % 30 == 0)
events.Legacy_HalfSecondTick.Raise();
if (Game1.ticks % 60 == 0)
if (SGame.TicksElapsed % 60 == 0)
events.Legacy_OneSecondTick.Raise();
#endif

Expand Down Expand Up @@ -1384,7 +1390,7 @@ private void DrawImpl(GameTime gameTime)
}
Game1.drawPlayerHeldObject(Game1.player);
}
label_129:
label_129:
if ((Game1.player.UsingTool || Game1.pickingTool) && Game1.player.CurrentTool != null && ((!Game1.player.CurrentTool.Name.Equals("Seeds") || Game1.pickingTool) && (Game1.currentLocation.Map.GetLayer("Front").PickTile(new Location(Game1.player.getStandingX(), (int)Game1.player.Position.Y - 38), Game1.viewport.Size) != null && Game1.currentLocation.Map.GetLayer("Front").PickTile(new Location(Game1.player.getStandingX(), Game1.player.getStandingY()), Game1.viewport.Size) == null)))
Game1.drawTool(Game1.player);
if (Game1.currentLocation.Map.GetLayer("AlwaysFront") != null)
Expand Down

0 comments on commit 79c6166

Please sign in to comment.