| /******************************************************************************* |
| * Copyright (c) 2004, 2006 IBM Corporation and others. |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Eclipse Public License v2.0 |
| * which accompanies this distribution, and is available at |
| * https://www.eclipse.org/legal/epl-2.0/ |
| * |
| * Contributors: |
| * Miguel Garcia (Tech Univ Hamburg-Harburg) - customization for EMF Generics |
| *******************************************************************************/ |
| |
| package org.eclipse.emf.emfatic.ui.preferences; |
| |
| import org.eclipse.emf.emfatic.ui.EmfaticUIPlugin; |
| import org.eclipse.jface.preference.BooleanFieldEditor; |
| import org.eclipse.jface.preference.DirectoryFieldEditor; |
| import org.eclipse.jface.preference.FieldEditorPreferencePage; |
| import org.eclipse.jface.preference.RadioGroupFieldEditor; |
| import org.eclipse.jface.preference.StringFieldEditor; |
| import org.eclipse.ui.IWorkbench; |
| import org.eclipse.ui.IWorkbenchPreferencePage; |
| |
| /** |
| * This class represents a preference page that |
| * is contributed to the Preferences dialog. By |
| * subclassing <samp>FieldEditorPreferencePage</samp>, we |
| * can use the field support built into JFace that allows |
| * us to create a page that is small and knows how to |
| * save, restore and apply itself. |
| * <p> |
| * This page is used to modify preferences only. They |
| * are stored in the preference store that belongs to |
| * the main plug-in class. That way, preferences can |
| * be accessed directly via the preference store. |
| */ |
| |
| public class EmfaticPreferencePage |
| extends FieldEditorPreferencePage |
| implements IWorkbenchPreferencePage { |
| |
| public EmfaticPreferencePage() { |
| super(GRID); |
| setPreferenceStore(EmfaticUIPlugin.getDefault().getPreferenceStore()); |
| setDescription("Emfatic editor preferences"); |
| } |
| |
| /** |
| * Creates the field editors. Field editors are abstractions of |
| * the common GUI blocks needed to manipulate various types |
| * of preferences. Each field editor knows how to save and |
| * restore itself. |
| */ |
| public void createFieldEditors() { |
| // addField(new DirectoryFieldEditor(PreferenceConstants.P_PATH, |
| // "&Directory preference:", getFieldEditorParent())); |
| addField( |
| new BooleanFieldEditor( |
| PreferenceConstants.P_BOOLEAN, |
| "&SmartBrace (add closing brace automatically)", |
| getFieldEditorParent())); |
| addField( |
| new BooleanFieldEditor( |
| PreferenceConstants.AUTO_GENERATE_ECORE, |
| "&Automatically greate Ecore (*.ecore) file when saving emfatic (*.emf) file.", |
| getFieldEditorParent())); |
| |
| // addField(new RadioGroupFieldEditor( |
| // PreferenceConstants.P_CHOICE, |
| // "An example of a multiple-choice preference", |
| // 1, |
| // new String[][] { { "&Choice 1", "choice1" }, { |
| // "C&hoice 2", "choice2" } |
| // }, getFieldEditorParent())); |
| // addField( |
| // new StringFieldEditor(PreferenceConstants.P_STRING, "A &text preference:", getFieldEditorParent())); |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.ui.IWorkbenchPreferencePage#init(org.eclipse.ui.IWorkbench) |
| */ |
| public void init(IWorkbench workbench) { |
| } |
| |
| } |