1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
/*****************************************************************************
* Copyright (c) 2011 Nicolas Deblock & Manuel Giles.
*
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Nicolas Deblock nico.deblock@gmail.com - Initial API and implementation
* Manuel Giles giles.manu@live.fr - Initial API and implementation
* Cedric Dumoulin Cedric.dumoulin@lifl.fr - Idea of the java generator project & help for the conception
*
*****************************************************************************/
package org.eclipse.papyrus.java.generator.ui.preference;
import org.eclipse.jface.preference.BooleanFieldEditor;
import org.eclipse.jface.preference.FieldEditorPreferencePage;
import org.eclipse.papyrus.java.generator.ui.Activator;
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 PreferencePage
extends FieldEditorPreferencePage
implements IWorkbenchPreferencePage {
public PreferencePage() {
super(GRID);
}
/**
* 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() {
// implements methods of inherits interfaces and abstract class
addField(new BooleanFieldEditor(
PreferenceConstants.P_STOP_ON_FIRST_ERROR,
"Stop on first error",
getFieldEditorParent()));
// implements methods of inherits interfaces and abstract class
addField(new BooleanFieldEditor(
PreferenceConstants.P_IMPLEMENT_METHODS_OF_INTERFACES_AND_ABSTRACT_CLASS,
"Implement methods of inherits interfaces and abstract class",
getFieldEditorParent()));
// generate getters setters
addField(new BooleanFieldEditor(
PreferenceConstants.P_GENERATE_GETTERS,
"Generate getters",
getFieldEditorParent()));
addField(new BooleanFieldEditor(
PreferenceConstants.P_GENERATE_SETTERS,
"Generate setters",
getFieldEditorParent()));
// filter of package not to generate
addField(new PackageListEditor(
PreferenceConstants.P_FILTER_OF_PACKAGE_NOT_TO_GENERATE,
"Filter of package to not generate",
getFieldEditorParent()));
addField(new GenericClassFieldEditor(
PreferenceConstants.P_GENERIC_CLASS_FOR_MULTIVALUE,
"Generic class to use for association * ",
getFieldEditorParent()));
// text input field for the default source folder name
addField(new GenericClassFieldEditor(
PreferenceConstants.P_DEFAULT_SOURCE_FOLDER_NAME,
PreferenceConstants.LABEL_DEFAULT_SOURCE_FOLDER_NAME,
getFieldEditorParent()));
}
/*
* (non-Javadoc)
*
* @see org.eclipse.ui.IWorkbenchPreferencePage#init(org.eclipse.ui.IWorkbench)
*/
public void init(IWorkbench workbench) {
setPreferenceStore(Activator.getDefault().getPreferenceStore());
setDescription("Edit your preferences to generate Java classes with papyrus");
}
}
|