Reintroduction of CopyOnWriteArrayList for storing QuestTimers.
This commit is contained in:
@@ -28,6 +28,7 @@ import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
import java.util.concurrent.CopyOnWriteArrayList;
|
||||
import java.util.function.Predicate;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
@@ -86,7 +87,7 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
public static final Logger LOGGER = Logger.getLogger(Quest.class.getName());
|
||||
|
||||
/** Map containing lists of timers from the name of the timer. */
|
||||
private final Map<String, Set<QuestTimer>> _questTimers = new HashMap<>();
|
||||
private final Map<String, List<QuestTimer>> _questTimers = new HashMap<>();
|
||||
/** Map containing all the start conditions. */
|
||||
private final Set<QuestCondition> _startCondition = ConcurrentHashMap.newKeySet(1);
|
||||
|
||||
@@ -262,7 +263,7 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
* Gets the quest timers.
|
||||
* @return the quest timers
|
||||
*/
|
||||
public Map<String, Set<QuestTimer>> getQuestTimers()
|
||||
public Map<String, List<QuestTimer>> getQuestTimers()
|
||||
{
|
||||
return _questTimers;
|
||||
}
|
||||
@@ -285,11 +286,15 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
|
||||
synchronized (_questTimers)
|
||||
{
|
||||
final Set<QuestTimer> timers = _questTimers.getOrDefault(name, ConcurrentHashMap.newKeySet(1));
|
||||
if (!_questTimers.containsKey(name))
|
||||
{
|
||||
_questTimers.put(name, new CopyOnWriteArrayList<>());
|
||||
}
|
||||
|
||||
// If there exists a timer with this name, allow the timer only if the [npc, player] set is unique nulls act as wildcards.
|
||||
if (getQuestTimer(name, npc, player) == null)
|
||||
{
|
||||
timers.add(new QuestTimer(this, name, time, npc, player, repeating));
|
||||
_questTimers.get(name).add(new QuestTimer(this, name, time, npc, player, repeating));
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -308,7 +313,7 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
return null;
|
||||
}
|
||||
|
||||
final Set<QuestTimer> timers = _questTimers.get(name);
|
||||
final List<QuestTimer> timers = _questTimers.get(name);
|
||||
if ((timers == null) || timers.isEmpty())
|
||||
{
|
||||
return null;
|
||||
@@ -336,7 +341,7 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
return;
|
||||
}
|
||||
|
||||
final Set<QuestTimer> timers = _questTimers.get(name);
|
||||
final List<QuestTimer> timers = _questTimers.get(name);
|
||||
if ((timers == null) || timers.isEmpty())
|
||||
{
|
||||
return;
|
||||
@@ -366,7 +371,7 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
return;
|
||||
}
|
||||
|
||||
final Set<QuestTimer> timers = _questTimers.get(name);
|
||||
final List<QuestTimer> timers = _questTimers.get(name);
|
||||
if ((timers == null) || timers.isEmpty())
|
||||
{
|
||||
return;
|
||||
@@ -377,7 +382,6 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
if ((timer != null) && timer.equals(this, name, npc, player))
|
||||
{
|
||||
timer.cancel();
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -394,7 +398,7 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
return;
|
||||
}
|
||||
|
||||
final Set<QuestTimer> timers = _questTimers.get(timer.toString());
|
||||
final List<QuestTimer> timers = _questTimers.get(timer.toString());
|
||||
if (timers != null)
|
||||
{
|
||||
timers.remove(timer);
|
||||
@@ -2814,16 +2818,14 @@ public class Quest extends AbstractScript implements IIdentifiable
|
||||
|
||||
// Cancel all pending timers before reloading.
|
||||
// If timers ought to be restarted, the quest can take care of it with its code (example: save global data indicating what timer must be restarted).
|
||||
for (Set<QuestTimer> timers : _questTimers.values())
|
||||
for (List<QuestTimer> timers : _questTimers.values())
|
||||
{
|
||||
for (QuestTimer timer : timers)
|
||||
{
|
||||
timer.cancel();
|
||||
}
|
||||
|
||||
timers.clear();
|
||||
}
|
||||
|
||||
_questTimers.clear();
|
||||
|
||||
if (removeFromList)
|
||||
|
Reference in New Issue
Block a user