001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041:
042: package org.netbeans.modules.cnd.editor.fortran;
043:
044: import java.util.Map;
045:
046: import org.netbeans.editor.*;
047: import org.netbeans.editor.ext.ExtSettingsNames;
048: import org.openide.actions.CutAction;
049: import org.openide.actions.CopyAction;
050: import org.openide.actions.PasteAction;
051: import org.openide.actions.DeleteAction;
052: import org.openide.actions.NewAction;
053: import org.openide.actions.ToolsAction;
054: import org.openide.actions.PropertiesAction;
055: import org.openide.windows.TopComponent;
056:
057: /**
058: * Extended settings for Fortran.
059: *
060: */
061:
062: public class FSettingsInitializer extends Settings.AbstractInitializer {
063:
064: /** Name assigned to initializer */
065: public static final String NAME = "f-settings-initializer"; //NOI18N
066:
067: private Class fKitClass;
068:
069: /** Construct new f-settings-initializer.
070: * @param fKitClass the real kit class for which the settings are created.
071: * It's unknown here so it must be passed to this constructor.
072: */
073: public FSettingsInitializer(Class fKitClass) {
074: super (NAME);
075: this .fKitClass = fKitClass;
076: }
077:
078: /** Update map filled with the settings.
079: * @param kitClass kit class for which the settings are being updated.
080: * It is always non-null value.
081: * @param settingsMap map holding [setting-name, setting-value] pairs.
082: * The map can be empty if this is the first initializer
083: * that updates it or if no previous initializers updated it.
084: */
085: @SuppressWarnings("unchecked")
086: public void updateSettingsMap(Class kitClass, Map settingsMap) {
087:
088: if (kitClass == fKitClass) {
089: SettingsUtil.updateListSetting(settingsMap,
090: SettingsNames.TOKEN_CONTEXT_LIST,
091: new TokenContext[] { FTokenContext.context,
092: //FLayerTokenContext.context
093: });
094:
095: SettingsUtil.updateListSetting(settingsMap,
096: ExtSettingsNames.POPUP_MENU_ACTION_NAME_LIST,
097: new String[] {
098: BaseKit.formatAction,
099: null,
100: TopComponent.class.getName(),
101: null,
102: //CompileAction.class.getName(),
103: //null,
104: //org.openide.actions.ToggleBreakpointAction.class.getName(),
105: //org.openide.actions.AddWatchAction.class.getName(),
106: //null,
107: CutAction.class.getName(),
108: CopyAction.class.getName(),
109: PasteAction.class.getName(), null,
110: DeleteAction.class.getName(), null,
111: NewAction.class.getName(), null,
112: FKit.gotoHelpAction, null,
113: ToolsAction.class.getName(),
114: BaseKit.generateGutterPopupAction,
115: PropertiesAction.class.getName() });
116:
117: settingsMap.put(SettingsNames.IDENTIFIER_ACCEPTOR,
118: FSettingsDefaults.defaultIdentifierAcceptor);
119:
120: settingsMap.put(SettingsNames.ABBREV_RESET_ACCEPTOR,
121: FSettingsDefaults.defaultAbbrevResetAcceptor);
122:
123: settingsMap.put(SettingsNames.WORD_MATCH_MATCH_CASE,
124: FSettingsDefaults.defaultFortranWordMatchMatchCase);
125:
126: settingsMap.put(SettingsNames.WORD_MATCH_STATIC_WORDS,
127: FSettingsDefaults.defaultWordMatchStaticWords);
128:
129: // Formatting settings
130: /* remove settings XXX not needed yet
131: settingsMap.put(FSettingsNames.FORMAT_SPACE_AFTER_COMMA,
132: FSettingsDefaults.defaultFormatSpaceAfterComma);
133:
134: settingsMap.put(FSettingsNames.FREE_FORMAT,
135: FSettingsDefaults.defaultFreeFormat);
136: */
137:
138: settingsMap.put(FSettingsNames.INDENT_HOT_CHARS_ACCEPTOR,
139: FSettingsDefaults.defaultIndentHotCharsAcceptor);
140:
141: // Separator line at 72: everything else is ignored...
142: settingsMap.put(SettingsNames.TEXT_LIMIT_WIDTH,
143: new Integer(FSettingsDefaults.maximumTextWidth));
144: }//if
145:
146: }//updateSettingsMap
147:
148: }
|