001: /*
002: * ====================================================================
003: * The JRefactory License, Version 1.0
004: *
005: * Copyright (c) 2001 JRefactory. All rights reserved.
006: *
007: * Redistribution and use in source and binary forms, with or without
008: * modification, are permitted provided that the following conditions
009: * are met:
010: *
011: * 1. Redistributions of source code must retain the above copyright
012: * notice, this list of conditions and the following disclaimer.
013: *
014: * 2. Redistributions in binary form must reproduce the above copyright
015: * notice, this list of conditions and the following disclaimer in
016: * the documentation and/or other materials provided with the
017: * distribution.
018: *
019: * 3. The end-user documentation included with the redistribution,
020: * if any, must include the following acknowledgment:
021: * "This product includes software developed by the
022: * JRefactory (http://www.sourceforge.org/projects/jrefactory)."
023: * Alternately, this acknowledgment may appear in the software itself,
024: * if and wherever such third-party acknowledgments normally appear.
025: *
026: * 4. The names "JRefactory" must not be used to endorse or promote
027: * products derived from this software without prior written
028: * permission. For written permission, please contact seguin@acm.org.
029: *
030: * 5. Products derived from this software may not be called "JRefactory",
031: * nor may "JRefactory" appear in their name, without prior written
032: * permission of Chris Seguin.
033: *
034: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
035: * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
036: * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
037: * DISCLAIMED. IN NO EVENT SHALL THE CHRIS SEGUIN OR
038: * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
039: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
040: * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
041: * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
042: * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
043: * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
044: * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
045: * SUCH DAMAGE.
046: * ====================================================================
047: *
048: * This software consists of voluntary contributions made by many
049: * individuals on behalf of JRefactory. For more information on
050: * JRefactory, please see
051: * <http://www.sourceforge.org/projects/jrefactory>.
052: */
053: package org.acm.seguin.tools.install;
054:
055: import java.io.PrintWriter;
056: import org.acm.seguin.util.MissingSettingsException;
057:
058: /**
059: * Description of the Class
060: *
061: *@author Chris Seguin
062: *@created September 12, 2001
063: */
064: class InitializerOrderPanel extends SortSettingPanel {
065: /**
066: * Constructor for the InitializerOrderPanel object
067: */
068: public InitializerOrderPanel() {
069: super ();
070:
071: addDescription("Maintain the order of fields with initializers");
072:
073: addListener();
074: setSortEnabled(findProperty("FieldInitializers"));
075: }
076:
077: public void reload() {
078: setSortEnabled(findProperty("FieldInitializers"));
079: }
080:
081: /**
082: * Gets the SortName attribute of the SortSettingPanel object
083: *
084: *@return The SortName value
085: */
086: protected String getSortName() {
087: return "FieldInitializers";
088: }
089:
090: /**
091: * Description of the Method
092: *
093: *@param output Description of Parameter
094: *@param index Description of Parameter
095: */
096: public void generateSetting(PrintWriter output, int index) {
097: printDescription(output);
098: if (!isSortEnabled()) {
099: output.print("#");
100: }
101: output.println("sort." + index + "=FieldInitializers()");
102: output.println("");
103: }
104:
105: /**
106: * Finds the property that should be enabled
107: *
108: *@param key Description of Parameter
109: *@return Description of the Returned Value
110: */
111: protected boolean findProperty(String key) {
112: try {
113: int index = 1;
114: while (index < 50) {
115: String value = SettingPanel.bundle.getString("sort."
116: + index);
117: if (value.startsWith(key)) {
118: setOrder(index);
119: return true;
120: }
121: index++;
122: }
123: } catch (MissingSettingsException mse) {
124: // Handle this below
125: }
126: return false;
127: }
128: }
129:
130: // This is the end of the file
|