Jump to content

Recommended Posts

Posted

This will allow you to set multiple different competition start times for Olympiad.

 

Use AltOlyCompStart to set the times in General.properties.

Time is in military format, ie: 18:00 (6:00 PM). Separate times with commas, ie: 18:00,19:00,20:00

Note: Be sure to adjust your AltOlyCPeriod in the config as well, in respect to your start times.

 

Tested and working (...however, not tested live so please use at your own discretion)

 

Enjoy,

mackry (moooo)

 

Index: /java/com/l2jserver/gameserver/model/olympiad/Olympiad.java
===================================================================
--- /java/com/l2jserver/gameserver/model/olympiad/Olympiad.java	(revision 0)
+++ /java/com/l2jserver/gameserver/model/olympiad/Olympiad.java	(working copy)

	protected int _currentCycle;
	private long _compEnd;
	private Calendar _compStart;
+	private Calendar _nextCompStart;
+	
	protected static boolean _inCompPeriod;
	protected static boolean _compStarted = false;
	protected ScheduledFuture<?> _scheduledCompStart;
@@ -403,11 +405,35 @@
		_nonClassBasedRegisters = new L2FastList<L2PcInstance>();
		_classBasedRegisters = new FastMap<Integer, L2FastList<L2PcInstance>>();

-		_compStart = Calendar.getInstance();
-		_compStart.set(Calendar.HOUR_OF_DAY, COMP_START);
-		_compStart.set(Calendar.MINUTE, COMP_MIN);
-		_compEnd = _compStart.getTimeInMillis() + COMP_PERIOD;
+		try
+		{
+			Calendar currentTime = Calendar.getInstance();
+
+			for (String timeOfDay : Config.ALT_OLY_COMP_INTERVAL)
+			{
+				_compStart = Calendar.getInstance();
+				_compStart.setLenient(true);
+				String [] splitTimeOfDay = timeOfDay.split(":");
+				_compStart.set(Calendar.HOUR_OF_DAY, Integer.parseInt(splitTimeOfDay[0]));
+				_compStart.set(Calendar.MINUTE, Integer.parseInt(splitTimeOfDay[1]));
+				if (_compStart.getTimeInMillis() < currentTime.getTimeInMillis())
+				{
+					_compStart.add(Calendar.DAY_OF_MONTH, 1);
+				}
+				_compEnd = _compStart.getTimeInMillis() + COMP_PERIOD;
+			}
+		}
+		catch (Exception e)
+		{
+			_log.warning("Olympiad[Olympiad.init()]: Error figuring out a start time. Check OlyCompInterval in config file.");
+		}

+		
+		//_compStart = Calendar.getInstance();
+		//_compStart.set(Calendar.HOUR_OF_DAY, COMP_START);
+		//_compStart.set(Calendar.MINUTE, COMP_MIN);
+		//_compEnd = _compStart.getTimeInMillis() + COMP_PERIOD;
+		
		if (_scheduledOlympiadEnd != null)
			_scheduledOlympiadEnd.cancel(true);

@@ -901,15 +927,18 @@

	private long setNewCompBegin()
	{
-		_compStart = Calendar.getInstance();
-		_compStart.set(Calendar.HOUR_OF_DAY, COMP_START);
-		_compStart.set(Calendar.MINUTE, COMP_MIN);
-		_compStart.add(Calendar.HOUR_OF_DAY, 24);
+		Calendar nextCompStart = null;
+		nextCompStart = Calendar.getInstance();
+		if (nextCompStart == null || _compStart.getTimeInMillis() < nextCompStart.getTimeInMillis())
+		{
+			nextCompStart = _compStart;
+			
+		}
		_compEnd = _compStart.getTimeInMillis() + COMP_PERIOD;

-		_log.info("Olympiad System: New Schedule @ " + _compStart.getTime());
+		_log.info("Olympiad System: New Schedule @ " + nextCompStart.getTime());

-		return (_compStart.getTimeInMillis() - Calendar.getInstance().getTimeInMillis());
+		return (nextCompStart.getTimeInMillis() - Calendar.getInstance().getTimeInMillis());
	}

	protected long getMillisToCompEnd()


Index: /java/config/General.properties
===================================================================
--- /java/config/General.properties	(revision 0)
+++ /java/config/General.properties	(working copy)
@@ -439,6 +439,10 @@
# Default: 18
AltOlyStartTime = 18

+# Olympiad Start Time in Military hours Default 6pm (18) 
+# Default: 18
+AltOlyCompStart = 04:00,8:00,12:00,16:00,20:00,00:00
+
# Olympiad Start Time for Min's, Default 00 so at the start of the hour.
# Default: 00
AltOlyMin = 00
@@ -446,7 +450,7 @@
# Olympiad Competition Period, Default 6 hours.
# (If set different, should be increment by 10mins)
# Default: 21600000
-AltOlyCPeriod = 21600000
+AltOlyCPeriod = 3600000

# Olympiad Battle Period, Default 6 minutes.
# Default: 360000

Index: /java/com/l2jserver/Config.java
===================================================================
--- : /java/com/l2jserver/Config.java	(revision 0)
+++ : /java/com/l2jserver/Config.java	(working copy)
@@ -456,6 +456,7 @@
	public static int NAME_PAGE_SIZE_COMMUNITYBOARD;
	public static int NAME_PER_ROW_COMMUNITYBOARD;
	public static int ALT_OLY_START_TIME;
+	public static String[] ALT_OLY_COMP_INTERVAL;
	public static int ALT_OLY_MIN;
	public static long ALT_OLY_CPERIOD;
	public static long ALT_OLY_BATTLE;
@@ -1621,6 +1622,7 @@
					NAME_PAGE_SIZE_COMMUNITYBOARD = Integer.parseInt(General.getProperty("NamePageSizeOnCommunityBoard", "50"));
					NAME_PER_ROW_COMMUNITYBOARD = Integer.parseInt(General.getProperty("NamePerRowOnCommunityBoard", "5"));
					ALT_OLY_START_TIME = Integer.parseInt(General.getProperty("AltOlyStartTime", "18"));
+					ALT_OLY_COMP_INTERVAL = General.getProperty("AltOlyCompStart", "20:00").split(",");
					ALT_OLY_MIN = Integer.parseInt(General.getProperty("AltOlyMin","00"));
					ALT_OLY_CPERIOD = Long.parseLong(General.getProperty("AltOlyCPeriod","21600000"));
					ALT_OLY_BATTLE = Long.parseLong(General.getProperty("AltOlyBattle","360000"));

Posted

I thing that you forget the Config.java side ...

When you add it I will give it a test !

 

Doh! Thanks SkyLanceя, this was an old mod I did so some of it got lost somehow >.< Fixed.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...