summaryrefslogtreecommitdiffstats
path: root/EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java
diff options
context:
space:
mode:
authorsnowleo <schneeleo@gmail.com>2011-11-25 21:12:38 +0100
committersnowleo <schneeleo@gmail.com>2011-11-25 21:12:38 +0100
commit6ba02c7f74652565b2918e1591bee4c56adf6e34 (patch)
treebf6b9f61a3c0eb7f0a8d4f0b28b6144dfa607d0f /EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java
parentcc155b145b8b51e34c0031ae22b5f14c8b6d196a (diff)
parentbefbb4d0e51db31270c9d7b42fc3e4c3b8983b08 (diff)
downloadEssentials-6ba02c7f74652565b2918e1591bee4c56adf6e34.tar
Essentials-6ba02c7f74652565b2918e1591bee4c56adf6e34.tar.gz
Essentials-6ba02c7f74652565b2918e1591bee4c56adf6e34.tar.lz
Essentials-6ba02c7f74652565b2918e1591bee4c56adf6e34.tar.xz
Essentials-6ba02c7f74652565b2918e1591bee4c56adf6e34.zip
Merge branch 'refs/heads/groupmanager'
Diffstat (limited to 'EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java')
-rw-r--r--EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java18
1 files changed, 14 insertions, 4 deletions
diff --git a/EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java b/EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java
index 924da3616..a35b5aeee 100644
--- a/EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java
+++ b/EssentialsGroupManager/src/org/anjocaido/groupmanager/data/DataUnit.java
@@ -6,6 +6,8 @@ package org.anjocaido.groupmanager.data;
import java.util.ArrayList;
import java.util.Collections;
+import java.util.List;
+
import org.anjocaido.groupmanager.GroupManager;
import org.anjocaido.groupmanager.dataholder.WorldDataHolder;
import org.anjocaido.groupmanager.utils.StringPermissionComparator;
@@ -18,7 +20,7 @@ public abstract class DataUnit {
private WorldDataHolder dataSource;
private String name;
- private boolean changed;
+ private boolean changed, sorted = false;
private ArrayList<String> permissions = new ArrayList<String>();
public DataUnit(WorldDataHolder dataSource, String name) {
@@ -91,6 +93,7 @@ public abstract class DataUnit {
// for(StackTraceElement st: Thread.currentThread().getStackTrace()){
// GroupManager.logger.finest(st.toString());
// }
+ sorted = false;
changed = true;
}
@@ -132,11 +135,18 @@ public abstract class DataUnit {
* You can't edit the permissions using the returned ArrayList instance
* @return a copy of the permission list
*/
- public ArrayList<String> getPermissionList() {
- return new ArrayList<String>(permissions);
+ public List<String> getPermissionList() {
+ return Collections.unmodifiableList(permissions);
+ }
+
+ public boolean isSorted() {
+ return this.sorted;
}
public void sortPermissions() {
- Collections.sort(permissions, StringPermissionComparator.getInstance());
+ if (!isSorted()) {
+ Collections.sort(permissions, StringPermissionComparator.getInstance());
+ sorted = true;
+ }
}
} \ No newline at end of file