1 // =================================================================================================
2 // ADOBE SYSTEMS INCORPORATED
3 // Copyright 2006 Adobe Systems Incorporated
4 // All Rights Reserved
5 //
6 // NOTICE:  Adobe permits you to use, modify, and distribute this file in accordance with the terms
7 // of the Adobe license agreement accompanying it.
8 // =================================================================================================
9 
10 package com.adobe.xmp.options;
11 
12 
13 /**
14  * Options for <code>XMPIterator</code> construction.
15  *
16  * @since 24.01.2006
17  */
18 public final class IteratorOptions extends Options
19 {
20 	/** Just do the immediate children of the root, default is subtree. */
21 	public static final int JUST_CHILDREN = 0x0100;
22 	/** Just do the leaf nodes, default is all nodes in the subtree. */
23 	public static final int JUST_LEAFNODES = 0x0200;
24 	/** Return just the leaf part of the path, default is the full path. */
25 	public static final int JUST_LEAFNAME = 0x0400;
26 	/** Include aliases, default is just actual properties. <em>Note:</em> Not supported.
27 	 *  @deprecated it is commonly preferred to work with the base properties */
28 	public static final int INCLUDE_ALIASES = 0x0800;
29 	/** Omit all qualifiers. */
30 	public static final int OMIT_QUALIFIERS = 0x1000;
31 
32 
33 	/**
34 	 * @return Returns whether the option is set.
35 	 */
isJustChildren()36 	public boolean isJustChildren()
37 	{
38 		return getOption(JUST_CHILDREN);
39 	}
40 
41 
42 	/**
43 	 * @return Returns whether the option is set.
44 	 */
isJustLeafname()45 	public boolean isJustLeafname()
46 	{
47 		return getOption(JUST_LEAFNAME);
48 	}
49 
50 
51 	/**
52 	 * @return Returns whether the option is set.
53 	 */
isJustLeafnodes()54 	public boolean isJustLeafnodes()
55 	{
56 		return getOption(JUST_LEAFNODES);
57 	}
58 
59 
60 	/**
61 	 * @return Returns whether the option is set.
62 	 */
isOmitQualifiers()63 	public boolean isOmitQualifiers()
64 	{
65 		return getOption(OMIT_QUALIFIERS);
66 	}
67 
68 
69 	/**
70 	 * Sets the option and returns the instance.
71 	 *
72 	 * @param value the value to set
73 	 * @return Returns the instance to call more set-methods.
74 	 */
setJustChildren(boolean value)75 	public IteratorOptions setJustChildren(boolean value)
76 	{
77 		setOption(JUST_CHILDREN, value);
78 		return this;
79 	}
80 
81 
82 	/**
83 	 * Sets the option and returns the instance.
84 	 *
85 	 * @param value the value to set
86 	 * @return Returns the instance to call more set-methods.
87 	 */
setJustLeafname(boolean value)88 	public IteratorOptions setJustLeafname(boolean value)
89 	{
90 		setOption(JUST_LEAFNAME, value);
91 		return this;
92 	}
93 
94 
95 	/**
96 	 * Sets the option and returns the instance.
97 	 *
98 	 * @param value the value to set
99 	 * @return Returns the instance to call more set-methods.
100 	 */
setJustLeafnodes(boolean value)101 	public IteratorOptions setJustLeafnodes(boolean value)
102 	{
103 		setOption(JUST_LEAFNODES, value);
104 		return this;
105 	}
106 
107 
108 	/**
109 	 * Sets the option and returns the instance.
110 	 *
111 	 * @param value the value to set
112 	 * @return Returns the instance to call more set-methods.
113 	 */
setOmitQualifiers(boolean value)114 	public IteratorOptions setOmitQualifiers(boolean value)
115 	{
116 		setOption(OMIT_QUALIFIERS, value);
117 		return this;
118 	}
119 
120 
121 	/**
122 	 * @see Options#defineOptionName(int)
123 	 */
defineOptionName(int option)124 	protected String defineOptionName(int option)
125 	{
126 		switch (option)
127 		{
128 			case JUST_CHILDREN : 	return "JUST_CHILDREN";
129 			case JUST_LEAFNODES :	return "JUST_LEAFNODES";
130 			case JUST_LEAFNAME :	return "JUST_LEAFNAME";
131 			case OMIT_QUALIFIERS :	return "OMIT_QUALIFIERS";
132 			default: 				return null;
133 		}
134 	}
135 
136 
137 	/**
138 	 * @see Options#getValidOptions()
139 	 */
getValidOptions()140 	protected int getValidOptions()
141 	{
142 		return
143 			JUST_CHILDREN |
144 			JUST_LEAFNODES |
145 			JUST_LEAFNAME |
146 			OMIT_QUALIFIERS;
147 	}
148 }