git://git.nikiroo.be
/
fanfix.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
changelog
[fanfix.git]
/
src
/
be
/
nikiroo
/
utils
/
resources
/
MetaInfo.java
diff --git
a/src/be/nikiroo/utils/resources/MetaInfo.java
b/src/be/nikiroo/utils/resources/MetaInfo.java
index 8ec98f9935168b9f0dbe231b1af917e5ce21a316..70c6c43181bbff8f8885c1eca15a792eef03eac1 100644
(file)
--- a/
src/be/nikiroo/utils/resources/MetaInfo.java
+++ b/
src/be/nikiroo/utils/resources/MetaInfo.java
@@
-27,6
+27,7
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
private List<Runnable> saveListeners = new ArrayList<Runnable>();
private String name;
private List<Runnable> saveListeners = new ArrayList<Runnable>();
private String name;
+ private boolean hidden;
private String description;
private boolean dirty;
private String description;
private boolean dirty;
@@
-90,6
+91,7
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
}
this.name = name;
}
this.name = name;
+ this.hidden = meta.hidden();
this.description = description;
reload();
this.description = description;
reload();
@@
-110,6
+112,16
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
public String getName() {
return name;
}
public String getName() {
return name;
}
+
+ /**
+ * This item should be hidden from the user (she will still be able to
+ * modify it if she opens the file manually).
+ *
+ * @return TRUE if it should stay hidden
+ */
+ public boolean isHidden() {
+ return hidden;
+ }
/**
* A description for this item: what it is or does, how to explain that item
/**
* A description for this item: what it is or does, how to explain that item
@@
-477,12
+489,7
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
*/
public void setString(String value, int item) {
if (isArray() && item >= 0) {
*/
public void setString(String value, int item) {
if (isArray() && item >= 0) {
- List<String> values = BundleHelper.parseList(this.value, -1);
- for (int i = values.size(); i <= item; i++) {
- values.add(null);
- }
- values.set(item, value);
- this.value = BundleHelper.fromList(values);
+ this.value = BundleHelper.fromList(this.value, value, item);
} else {
this.value = value;
}
} else {
this.value = value;
}
@@
-575,7
+582,8
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
value = null;
}
value = null;
}
- for (Runnable listener : reloadedListeners) {
+ // Copy the list so we can create new listener in a listener
+ for (Runnable listener : new ArrayList<Runnable>(reloadedListeners)) {
try {
listener.run();
} catch (Exception e) {
try {
listener.run();
} catch (Exception e) {
@@
-607,7
+615,8
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
* dirty flag)
*/
public void save(boolean onlyIfDirty) {
* dirty flag)
*/
public void save(boolean onlyIfDirty) {
- for (Runnable listener : saveListeners) {
+ // Copy the list so we can create new listener in a listener
+ for (Runnable listener : new ArrayList<Runnable>(saveListeners)) {
try {
listener.run();
} catch (Exception e) {
try {
listener.run();
} catch (Exception e) {
@@
-652,6
+661,15
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
return children;
}
return children;
}
+ /**
+ * The number of sub-items, if any.
+ *
+ * @return the number or 0
+ */
+ public int size() {
+ return children.size();
+ }
+
@Override
public Iterator<MetaInfo<E>> iterator() {
return children.iterator();
@Override
public Iterator<MetaInfo<E>> iterator() {
return children.iterator();
@@
-676,8
+694,10
@@
public class MetaInfo<E extends Enum<E>> implements Iterable<MetaInfo<E>> {
List<MetaInfo<E>> shadow = new ArrayList<MetaInfo<E>>();
for (E id : type.getEnumConstants()) {
MetaInfo<E> info = new MetaInfo<E>(type, bundle, id);
List<MetaInfo<E>> shadow = new ArrayList<MetaInfo<E>>();
for (E id : type.getEnumConstants()) {
MetaInfo<E> info = new MetaInfo<E>(type, bundle, id);
- list.add(info);
- shadow.add(info);
+ if (!info.hidden) {
+ list.add(info);
+ shadow.add(info);
+ }
}
for (int i = 0; i < list.size(); i++) {
}
for (int i = 0; i < list.size(); i++) {