mirror of
https://github.com/boldsuck/haveno.git
synced 2025-01-03 14:49:25 +00:00
make Capabilities thread safe to fix concurrent modification exception
This commit is contained in:
parent
5fc67ec65a
commit
8b58b5b235
1 changed files with 33 additions and 14 deletions
|
@ -59,7 +59,9 @@ public class Capabilities {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Capabilities(Collection<Capability> capabilities) {
|
public Capabilities(Collection<Capability> capabilities) {
|
||||||
this.capabilities.addAll(capabilities);
|
synchronized (this.capabilities) {
|
||||||
|
this.capabilities.addAll(capabilities);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void set(Capability... capabilities) {
|
public void set(Capability... capabilities) {
|
||||||
|
@ -71,21 +73,30 @@ public class Capabilities {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void set(Collection<Capability> capabilities) {
|
public void set(Collection<Capability> capabilities) {
|
||||||
this.capabilities.clear();
|
synchronized (this.capabilities) {
|
||||||
this.capabilities.addAll(capabilities);
|
this.capabilities.clear();
|
||||||
|
this.capabilities.addAll(capabilities);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addAll(Capability... capabilities) {
|
public void addAll(Capability... capabilities) {
|
||||||
this.capabilities.addAll(Arrays.asList(capabilities));
|
synchronized (this.capabilities) {
|
||||||
|
this.capabilities.addAll(Arrays.asList(capabilities));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addAll(Capabilities capabilities) {
|
public void addAll(Capabilities capabilities) {
|
||||||
if (capabilities != null)
|
if (capabilities != null) {
|
||||||
this.capabilities.addAll(capabilities.capabilities);
|
synchronized (this.capabilities) {
|
||||||
|
this.capabilities.addAll(capabilities.capabilities);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean containsAll(final Set<Capability> requiredItems) {
|
public boolean containsAll(final Set<Capability> requiredItems) {
|
||||||
return capabilities.containsAll(requiredItems);
|
synchronized (this.capabilities) {
|
||||||
|
return capabilities.containsAll(requiredItems);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean containsAll(final Capabilities capabilities) {
|
public boolean containsAll(final Capabilities capabilities) {
|
||||||
|
@ -93,15 +104,21 @@ public class Capabilities {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean containsAll(Capability... capabilities) {
|
public boolean containsAll(Capability... capabilities) {
|
||||||
return this.capabilities.containsAll(Arrays.asList(capabilities));
|
synchronized (this.capabilities) {
|
||||||
|
return this.capabilities.containsAll(Arrays.asList(capabilities));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean contains(Capability capability) {
|
public boolean contains(Capability capability) {
|
||||||
return this.capabilities.contains(capability);
|
synchronized (this.capabilities) {
|
||||||
|
return this.capabilities.contains(capability);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isEmpty() {
|
public boolean isEmpty() {
|
||||||
return capabilities.isEmpty();
|
synchronized (this.capabilities) {
|
||||||
|
return capabilities.isEmpty();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -173,10 +190,12 @@ public class Capabilities {
|
||||||
}
|
}
|
||||||
|
|
||||||
public String prettyPrint() {
|
public String prettyPrint() {
|
||||||
return capabilities.stream()
|
synchronized (capabilities) {
|
||||||
.sorted(Comparator.comparingInt(Enum::ordinal))
|
return capabilities.stream()
|
||||||
.map(e -> e.name() + " [" + e.ordinal() + "]")
|
.sorted(Comparator.comparingInt(Enum::ordinal))
|
||||||
.collect(Collectors.joining(", "));
|
.map(e -> e.name() + " [" + e.ordinal() + "]")
|
||||||
|
.collect(Collectors.joining(", "));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public int size() {
|
public int size() {
|
||||||
|
|
Loading…
Reference in a new issue