mirror of
https://github.com/Zrips/Jobs.git
synced 2025-01-02 14:29:07 +01:00
Fixed timed boosts
This commit is contained in:
parent
33d14cf927
commit
3b0cfc662f
@ -5,8 +5,7 @@ import java.util.HashMap;
|
||||
public class BoostMultiplier implements Cloneable {
|
||||
|
||||
private final java.util.Map<CurrencyType, Double> map = new HashMap<>();
|
||||
|
||||
private Long time = 0L;
|
||||
private final java.util.Map<CurrencyType, Long> timers = new HashMap<>();
|
||||
|
||||
@Override
|
||||
public BoostMultiplier clone() {
|
||||
@ -29,7 +28,7 @@ public class BoostMultiplier implements Cloneable {
|
||||
}
|
||||
|
||||
public BoostMultiplier add(CurrencyType type, double amount, long time) {
|
||||
this.time = time;
|
||||
timers.put(type, time);
|
||||
return add(type, amount);
|
||||
}
|
||||
|
||||
@ -39,27 +38,31 @@ public class BoostMultiplier implements Cloneable {
|
||||
map.put(one, amount);
|
||||
}
|
||||
}
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
public double get(CurrencyType type) {
|
||||
isValid(type); // Call without check to make sure map cache is removed
|
||||
if (!isValid(type))
|
||||
return 0D;
|
||||
return map.getOrDefault(type, 0D);
|
||||
}
|
||||
|
||||
public Long getTime() {
|
||||
return time;
|
||||
public Long getTime(CurrencyType type) {
|
||||
return timers.get(type);
|
||||
}
|
||||
|
||||
public boolean isValid(CurrencyType type) {
|
||||
boolean valid = time > System.currentTimeMillis();
|
||||
if (time != 0L && !valid) {
|
||||
Long time = getTime(type);
|
||||
if (time == null)
|
||||
return true;
|
||||
|
||||
if (time < System.currentTimeMillis()) {
|
||||
map.remove(type);
|
||||
time = 0L;
|
||||
timers.remove(type);
|
||||
return false;
|
||||
}
|
||||
|
||||
return time == 0L || valid;
|
||||
return true;
|
||||
}
|
||||
|
||||
public void add(BoostMultiplier armorboost) {
|
||||
|
@ -158,34 +158,16 @@ public class Job {
|
||||
*
|
||||
* @param type the type of {@link CurrencyType}}
|
||||
* @param point the amount of boost to add
|
||||
* @param times the array of integer of when to remove the boost
|
||||
* @param duration boost duration in seconds
|
||||
*/
|
||||
public void addBoost(CurrencyType type, double point, int[] times) {
|
||||
if (times.length < 3)
|
||||
return;
|
||||
public void addBoost(CurrencyType type, double point, long duration) {
|
||||
|
||||
final int h = times[2], m = times[1], s = times[0];
|
||||
if (h == 0 && m == 0 && s == 0) {
|
||||
if (duration <= 0) {
|
||||
addBoost(type, point);
|
||||
return;
|
||||
}
|
||||
|
||||
final Calendar cal = Calendar.getInstance();
|
||||
cal.setTime(new Date());
|
||||
|
||||
if (h > 0) {
|
||||
cal.set(Calendar.HOUR_OF_DAY, cal.get(Calendar.HOUR_OF_DAY) + h);
|
||||
}
|
||||
|
||||
if (m > 0) {
|
||||
cal.set(Calendar.MINUTE, cal.get(Calendar.MINUTE) + m);
|
||||
}
|
||||
|
||||
if (s > 0) {
|
||||
cal.set(Calendar.SECOND, cal.get(Calendar.SECOND) + s);
|
||||
}
|
||||
|
||||
boost.add(type, point, cal.getTimeInMillis());
|
||||
boost.add(type, point, System.currentTimeMillis() + (duration * 1000L));
|
||||
}
|
||||
|
||||
public void setBoost(BoostMultiplier boost) {
|
||||
|
@ -99,57 +99,6 @@ public final class Util {
|
||||
}
|
||||
}
|
||||
|
||||
public static int[] parseTime(String[] args) {
|
||||
int[] arr = new int[3];
|
||||
|
||||
if (args.length < 2) {
|
||||
return arr;
|
||||
}
|
||||
|
||||
String time = args[1].toLowerCase();
|
||||
if (time.isEmpty()) {
|
||||
return arr;
|
||||
}
|
||||
|
||||
String[] split = time.split("h|hour", 2);
|
||||
|
||||
if (split.length > 0) {
|
||||
try {
|
||||
arr[2] = Integer.parseInt(split[0]);
|
||||
} catch (NumberFormatException e) {
|
||||
arr[2] = 0;
|
||||
}
|
||||
|
||||
time = time.replaceAll(arr[2] + "+[h|hour]+", "");
|
||||
}
|
||||
|
||||
if ((split = time.split("m|minute", 2)).length > 0) {
|
||||
try {
|
||||
arr[1] = Integer.parseInt(split[0]);
|
||||
} catch (NumberFormatException e) {
|
||||
arr[1] = 0;
|
||||
}
|
||||
|
||||
time = time.replaceAll(arr[1] + "+[m|minute]+", "");
|
||||
}
|
||||
|
||||
if ((split = time.split("s|second", 2)).length > 0) {
|
||||
try {
|
||||
arr[0] = Integer.parseInt(split[0]);
|
||||
} catch (NumberFormatException e) {
|
||||
arr[0] = 0;
|
||||
}
|
||||
|
||||
time = time.replaceAll(arr[0] + "+[s|second]+", "");
|
||||
}
|
||||
|
||||
if (arr[0] == 0 && arr[1] == 0 && arr[2] == 0) {
|
||||
return new int[3];
|
||||
}
|
||||
|
||||
return arr;
|
||||
}
|
||||
|
||||
public static String getRealType(Entity entity) {
|
||||
if (Version.isCurrentEqualOrHigher(Version.v1_11_R1)) {
|
||||
return entity.getType().name();
|
||||
|
Loading…
Reference in New Issue
Block a user