diff options
author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2012-08-06 14:57:48 +0000 |
---|---|---|
committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2012-08-06 14:57:48 +0000 |
commit | a072b394a2ea71c424cd80c2541492724448b6d2 (patch) | |
tree | 00ddc173a2b8ee440381b42eec56f182f7718225 | |
parent | 52dc5338772fa93dc6ad1c4bd0b8245a9db59405 (diff) | |
download | ChibiOS-a072b394a2ea71c424cd80c2541492724448b6d2.tar.gz ChibiOS-a072b394a2ea71c424cd80c2541492724448b6d2.tar.bz2 ChibiOS-a072b394a2ea71c424cd80c2541492724448b6d2.zip |
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@4537 35acf78f-673a-0410-8e92-d51de3d6d3f4
13 files changed, 175 insertions, 253 deletions
diff --git a/tools/eclipse/config_wizard/META-INF/MANIFEST.MF b/tools/eclipse/config_wizard/META-INF/MANIFEST.MF index fb3d848cd..6b14e432e 100644 --- a/tools/eclipse/config_wizard/META-INF/MANIFEST.MF +++ b/tools/eclipse/config_wizard/META-INF/MANIFEST.MF @@ -2,7 +2,7 @@ Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: ChibiOS-RT_Configuration_Support Bundle-SymbolicName: org.chibios.tools.eclipse.config;singleton:=true -Bundle-Version: 1.0.4 +Bundle-Version: 1.1.0 Bundle-Activator: config_wizard.Activator Require-Bundle: org.eclipse.core.resources, org.eclipse.core.runtime, diff --git a/tools/eclipse/config_wizard/build.properties b/tools/eclipse/config_wizard/build.properties index 05b402447..81715159f 100644 --- a/tools/eclipse/config_wizard/build.properties +++ b/tools/eclipse/config_wizard/build.properties @@ -32,4 +32,5 @@ bin.includes = plugin.xml,\ resources/gencfg/processors/boards/stm32l1xx/templates/board.h.ftl,\
resources/gencfg/processors/boards/stm32l1xx/templates/board.mk.ftl,\
resources/gencfg/schema/boards/stm32l1xx_board.xsd,\
- resources/gencfg/xml/stm32l1board.xml
+ resources/gencfg/xml/stm32l1board.xml,\
+ resources/gencfg/schema/common/config_settings.xsd
diff --git a/tools/eclipse/config_wizard/plugin.xml b/tools/eclipse/config_wizard/plugin.xml index e2163c8fb..84ca332e5 100644 --- a/tools/eclipse/config_wizard/plugin.xml +++ b/tools/eclipse/config_wizard/plugin.xml @@ -17,14 +17,29 @@ </wizard>
</extension>
- <!-- Registers the file extension .chxml as an XML type. -->
+ <!-- Registers the file extension .chcfg as an XML type. -->
<extension point="org.eclipse.core.contenttype.contentTypes">
<file-association
content-type="org.eclipse.core.runtime.xml"
- file-extensions="chxml">
+ file-extensions="chcfg">
</file-association>
</extension>
+ <!-- XML catalog extensions. -->
+ <extension point="org.eclipse.wst.xml.core.catalogContributions">
+ <catalogContribution id="default">
+ <uri
+ name="http://www.chibios.org/xml/schema/boards/stm32f0xx_board.xsd"
+ uri="resources/gencfg/schema/boards/stm32f0xx_board.xsd" />
+ <uri
+ name="http://www.chibios.org/xml/schema/boards/stm32f4xx_board.xsd"
+ uri="resources/gencfg/schema/boards/stm32f4xx_board.xsd" />
+ <uri
+ name="http://www.chibios.org/xml/schema/boards/stm32l1xx_board.xsd"
+ uri="resources/gencfg/schema/boards/stm32l1xx_board.xsd" />
+ </catalogContribution>
+ </extension>
+
<!-- Commands. -->
<extension
point="org.eclipse.ui.commands">
diff --git a/tools/eclipse/config_wizard/resources/gencfg/schema/boards/abstract_board.xsd b/tools/eclipse/config_wizard/resources/gencfg/schema/boards/abstract_board.xsd index c4c953240..a1c696339 100644 --- a/tools/eclipse/config_wizard/resources/gencfg/schema/boards/abstract_board.xsd +++ b/tools/eclipse/config_wizard/resources/gencfg/schema/boards/abstract_board.xsd @@ -3,10 +3,12 @@ xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:include schemaLocation="../common/doc.xsd" />
+ <xs:include schemaLocation="../common/config_settings.xsd" />
<xs:complexType name="AbstractBoardType" abstract="true">
<xs:sequence>
- <xs:element name="board_name" maxOccurs="1" minOccurs="1">
+ <xs:element name="configuration_settings" type="ConfigurationSettingsType" maxOccurs="1" minOccurs="1"></xs:element> + <xs:element name="board_name" maxOccurs="1" minOccurs="1">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:whiteSpace value="collapse"></xs:whiteSpace>
@@ -21,25 +23,36 @@ </xs:restriction>
</xs:simpleType>
</xs:element>
- <xs:element name="board_functions" maxOccurs="1" minOccurs="1">
+ <xs:element name="board_functions" maxOccurs="1"
+ minOccurs="1">
<xs:complexType>
<xs:sequence>
- <xs:element name="__early_init" type="xs:string" maxOccurs="1" minOccurs="0"></xs:element> - <xs:element name="boardInit" type="xs:string" maxOccurs="1" minOccurs="0">
- </xs:element>
- <xs:element name="sdc_lld_is_card_inserted" type="xs:string" maxOccurs="1" minOccurs="0">
+ <xs:element name="__early_init" type="xs:string"
+ maxOccurs="1" minOccurs="0">
</xs:element>
- <xs:element name="sdc_lld_is_write_protected" type="xs:string" maxOccurs="1" minOccurs="0">
+ <xs:element name="boardInit" type="xs:string"
+ maxOccurs="1" minOccurs="0">
</xs:element>
- <xs:element name="mmc_lld_is_card_inserted" type="xs:string" maxOccurs="1" minOccurs="0">
+
+ <xs:element name="sdc_lld_is_card_inserted"
+ type="xs:string" maxOccurs="1" minOccurs="0">
+ </xs:element>
+ <xs:element name="sdc_lld_is_write_protected"
+ type="xs:string" maxOccurs="1" minOccurs="0">
+ </xs:element>
+ <xs:element name="mmc_lld_is_card_inserted"
+ type="xs:string" maxOccurs="1" minOccurs="0">
</xs:element>
- <xs:element name="mmc_lld_is_write_protected" type="xs:string" maxOccurs="1" minOccurs="0">
+ <xs:element name="mmc_lld_is_write_protected"
+ type="xs:string" maxOccurs="1" minOccurs="0">
</xs:element>
</xs:sequence>
- </xs:complexType></xs:element> - <xs:element name="ethernet_phy" type="EthernetPHYType"
+ </xs:complexType>
+ </xs:element>
+ <xs:element name="ethernet_phy" type="EthernetPHYType"
maxOccurs="1" minOccurs="0">
- </xs:element>
+ </xs:element>
+
</xs:sequence>
</xs:complexType>
diff --git a/tools/eclipse/config_wizard/resources/gencfg/schema/boards/stm32f4xx_board.xsd b/tools/eclipse/config_wizard/resources/gencfg/schema/boards/stm32f4xx_board.xsd index ace3b5acb..072880711 100644 --- a/tools/eclipse/config_wizard/resources/gencfg/schema/boards/stm32f4xx_board.xsd +++ b/tools/eclipse/config_wizard/resources/gencfg/schema/boards/stm32f4xx_board.xsd @@ -1,63 +1,61 @@ <?xml version="1.0" encoding="UTF-8"?>
<xs:schema elementFormDefault="qualified"
- xmlns:xs="http://www.w3.org/2001/XMLSchema">
+ xmlns:xs="http://www.w3.org/2001/XMLSchema">
- <xs:include schemaLocation="../common/doc.xsd" />
- <xs:include schemaLocation="../common/stm32/stm32_gpiov2_port.xsd" />
- <xs:include schemaLocation="abstract_board.xsd" />
+ <xs:include schemaLocation="../common/doc.xsd" />
+ <xs:include schemaLocation="../common/stm32/stm32_gpiov2_port.xsd" />
+ <xs:include schemaLocation="abstract_board.xsd" /> - <xs:complexType name="STM32F4xxBoardType"> - <xs:complexContent> - <xs:extension base="AbstractBoardType"> - <xs:sequence> - <xs:element name="clocks" maxOccurs="1" minOccurs="1"> - <xs:complexType> - <xs:attribute name="HSEBypass" use="required"> - <xs:simpleType> - <xs:restriction base="xs:string"> - <xs:whiteSpace value="collapse"></xs:whiteSpace> - <xs:enumeration value="false"></xs:enumeration> - <xs:enumeration value="true"></xs:enumeration> - </xs:restriction> - </xs:simpleType> - </xs:attribute>
- <xs:attribute name="HSEFrequency"
- use="required">
- <xs:simpleType>
- <xs:restriction base="xs:int">
- <xs:whiteSpace value="collapse"></xs:whiteSpace>
- <xs:minInclusive value="0"></xs:minInclusive>
- </xs:restriction>
- </xs:simpleType>
- </xs:attribute>
- <xs:attribute name="LSEFrequency"
- use="required">
- <xs:simpleType>
- <xs:restriction base="xs:int">
- <xs:whiteSpace value="collapse"></xs:whiteSpace>
+ <xs:complexType name="STM32F4xxBoardType"> + <xs:complexContent> + <xs:extension base="AbstractBoardType"> + <xs:sequence> + <xs:element name="clocks" maxOccurs="1" minOccurs="1"> + <xs:complexType> + <xs:attribute name="HSEBypass" use="required"> + <xs:simpleType> + <xs:restriction base="xs:string"> + <xs:whiteSpace value="collapse"></xs:whiteSpace> + <xs:enumeration value="false"></xs:enumeration> + <xs:enumeration value="true"></xs:enumeration> + </xs:restriction> + </xs:simpleType> + </xs:attribute>
+ <xs:attribute name="HSEFrequency" use="required">
+ <xs:simpleType>
+ <xs:restriction base="xs:int">
+ <xs:whiteSpace value="collapse"></xs:whiteSpace>
+ <xs:minInclusive value="0"></xs:minInclusive>
+ </xs:restriction>
+ </xs:simpleType>
+ </xs:attribute>
+ <xs:attribute name="LSEFrequency" use="required">
+ <xs:simpleType>
+ <xs:restriction base="xs:int">
+ <xs:whiteSpace value="collapse"></xs:whiteSpace>
- <xs:minInclusive value="0"></xs:minInclusive>
- </xs:restriction>
- </xs:simpleType>
- </xs:attribute>
- <xs:attribute name="VDD" use="required">
- <xs:simpleType>
- <xs:restriction base="xs:int">
- <xs:whiteSpace value="collapse"></xs:whiteSpace>
+ <xs:minInclusive value="0"></xs:minInclusive>
+ </xs:restriction>
+ </xs:simpleType>
+ </xs:attribute>
+ <xs:attribute name="VDD" use="required">
+ <xs:simpleType>
+ <xs:restriction base="xs:int">
+ <xs:whiteSpace value="collapse"></xs:whiteSpace>
- <xs:minInclusive value="180"></xs:minInclusive>
+ <xs:minInclusive value="180"></xs:minInclusive>
- <xs:maxInclusive value="360"></xs:maxInclusive>
- </xs:restriction>
- </xs:simpleType>
- </xs:attribute>
- </xs:complexType></xs:element> - <xs:element name="ports" type="portsType" maxOccurs="1"
- minOccurs="1">
- </xs:element>
- </xs:sequence>
+ <xs:maxInclusive value="360"></xs:maxInclusive>
+ </xs:restriction>
+ </xs:simpleType>
+ </xs:attribute>
+ </xs:complexType>
+ </xs:element> + <xs:element name="ports" type="portsType" maxOccurs="1" minOccurs="1">
+ </xs:element>
+ </xs:sequence>
- </xs:extension>
+ </xs:extension>
</xs:complexContent>
</xs:complexType>
diff --git a/tools/eclipse/config_wizard/resources/gencfg/schema/common/config_settings.xsd b/tools/eclipse/config_wizard/resources/gencfg/schema/common/config_settings.xsd new file mode 100644 index 000000000..45d228142 --- /dev/null +++ b/tools/eclipse/config_wizard/resources/gencfg/schema/common/config_settings.xsd @@ -0,0 +1,36 @@ +<?xml version="1.0" encoding="UTF-8"?>
+<xs:schema elementFormDefault="qualified"
+ xmlns:xs="http://www.w3.org/2001/XMLSchema">
+ + <xs:complexType name="ConfigurationSettingsType"> + <xs:sequence> + <xs:element name="templates_path" minOccurs="1"
+ maxOccurs="1">
+ <xs:annotation>
+ <xs:documentation>Templates resources associated to the configuration.</xs:documentation>
+ </xs:annotation>
+ <xs:simpleType>
+ <xs:restriction base="xs:string">
+ <xs:minLength value="1"></xs:minLength>
+ <xs:whiteSpace value="collapse"></xs:whiteSpace>
+ <xs:pattern value="[\w\d_/.]+"></xs:pattern>
+ </xs:restriction>
+ </xs:simpleType>
+ </xs:element>
+ <xs:element name="output_path" maxOccurs="1"
+ minOccurs="1">
+ <xs:annotation>
+ <xs:documentation>Output directory relative to the configuration file.</xs:documentation>
+ </xs:annotation>
+ <xs:simpleType>
+ <xs:restriction base="xs:string">
+ <xs:minLength value="1"></xs:minLength>
+ <xs:whiteSpace value="collapse"></xs:whiteSpace>
+ <xs:pattern value="[\w\d_/.]+"></xs:pattern>
+ </xs:restriction>
+ </xs:simpleType>
+ </xs:element>
+ </xs:sequence>
+ </xs:complexType>
+
+</xs:schema>
diff --git a/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f0board.xml b/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f0board.xml index 7e4dd5459..843dfe925 100644 --- a/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f0board.xml +++ b/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f0board.xml @@ -3,6 +3,10 @@ <board
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://www.chibios.org/xml/schema/boards/stm32f0xx_board.xsd">
+ <configuration_settings>
+ <templates_path>resources/gencfg/processors/boards/stm32f0xx/templates</templates_path>
+ <output_path>.</output_path>
+ </configuration_settings>
<board_name>-----human readable board name-----</board_name>
<board_id>BOARD_IDENTIFIER</board_id>
<board_functions></board_functions>
diff --git a/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f4board.xml b/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f4board.xml index 7becd89df..66a09d0d6 100644 --- a/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f4board.xml +++ b/tools/eclipse/config_wizard/resources/gencfg/xml/stm32f4board.xml @@ -3,6 +3,10 @@ <board
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://www.chibios.org/xml/schema/boards/stm32f4xx_board.xsd">
+ <configuration_settings>
+ <templates_path>resources/gencfg/processors/boards/stm32f4xx/templates</templates_path>
+ <output_path>.</output_path>
+ </configuration_settings>
<board_name>-----human readable board name-----</board_name>
<board_id>BOARD_IDENTIFIER</board_id>
<board_functions></board_functions>
diff --git a/tools/eclipse/config_wizard/resources/gencfg/xml/stm32l1board.xml b/tools/eclipse/config_wizard/resources/gencfg/xml/stm32l1board.xml index 1f6554026..00e5b5319 100644 --- a/tools/eclipse/config_wizard/resources/gencfg/xml/stm32l1board.xml +++ b/tools/eclipse/config_wizard/resources/gencfg/xml/stm32l1board.xml @@ -3,6 +3,10 @@ <board
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://www.chibios.org/xml/schema/boards/stm32l1xx_board.xsd">
+ <configuration_settings>
+ <templates_path>resources/gencfg/processors/boards/stm32l1xx/templates</templates_path>
+ <output_path>.</output_path>
+ </configuration_settings>
<board_name>-----human readable board name-----</board_name>
<board_id>BOARD_IDENTIFIER</board_id>
<board_functions></board_functions>
diff --git a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/handlers/GenerateFiles.java b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/handlers/GenerateFiles.java index e10d4c667..e6e9b3790 100644 --- a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/handlers/GenerateFiles.java +++ b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/handlers/GenerateFiles.java @@ -21,9 +21,7 @@ package org.chibios.tools.eclipse.config.handlers; import java.io.File; -import java.io.FileReader; import java.io.IOException; -import java.util.Properties; import org.chibios.tools.eclipse.config.utils.TemplateEngine; import org.chibios.tools.eclipse.config.utils.TemplateException; @@ -40,6 +38,10 @@ import org.eclipse.ui.handlers.HandlerUtil; import org.eclipse.jface.dialogs.MessageDialog; import org.eclipse.jface.viewers.ISelection; import org.eclipse.jface.viewers.IStructuredSelection; +import org.jdom2.Document; +import org.jdom2.Element; +import org.jdom2.JDOMException; +import org.jdom2.input.SAXBuilder; import org.osgi.framework.Bundle; import config_wizard.Activator; @@ -70,53 +72,32 @@ public class GenerateFiles extends AbstractHandler { if (selection instanceof IStructuredSelection) { /* Retrieves the full path of the configuration file. */ - IPath cfgfilepath = ((IFile) ((IStructuredSelection) selection) + IPath cfgfilepath = ((IFile)((IStructuredSelection)selection) .getFirstElement()).getLocation(); - - /* Determines the base path as the parent of the configuration file.*/ - IPath basepath = cfgfilepath.removeLastSegments(1); - /* Reads the configuration file into a Properties object. */ - Properties cfgfile = new Properties(); + /* DOM tree creation. */ + SAXBuilder builder = new SAXBuilder(); + Document document; try { - cfgfile.load(new FileReader(cfgfilepath.toFile())); - } catch (IOException e) { - MessageDialog.openInformation(window.getShell(), "I/O Error", - e.getMessage()); - return null; - } - - /* Retrieves source property. */ - String source = cfgfile.getProperty("source"); - if (source == null) { - MessageDialog.openInformation(window.getShell(), "Properties Error", - "Property \"source\" not found in configuration file."); + document = builder.build(cfgfilepath.toFile()); + } catch (JDOMException e) { return null; - } - - /* Retrieves xmlfile property. */ - String xmlfile = cfgfile.getProperty("xmlfile"); - if (xmlfile == null) { - MessageDialog.openInformation(window.getShell(), "Properties Error", - "Property \"xmlfile\" not found in configuration file."); + } catch (IOException e) { return null; } - /* Retrieves output property. */ - String output = cfgfile.getProperty("output"); - if (output == null) { - MessageDialog.openInformation(window.getShell(), "Properties Error", - "Property \"output\" not found in configuration file."); - return null; - } + /* Retrieving configuration settings info.*/ + Element settings = document.getRootElement().getChild("configuration_settings"); + String templates_path = settings.getChildText("templates_path"); + String output_path = settings.getChildText("output_path"); /* Calculating derived paths. */ - IPath sourcepath = new Path(source); + IPath tpath = new Path(templates_path); IPath libpath = new Path("resources/gencfg/lib"); try { Bundle bundle = Platform.getBundle(Activator.PLUGIN_ID); - sourcepath = new Path(FileLocator.toFileURL( - FileLocator.find(bundle, sourcepath, null)).getFile()); + tpath = new Path(FileLocator.toFileURL( + FileLocator.find(bundle, tpath, null)).getFile()); libpath = new Path(FileLocator.toFileURL( FileLocator.find(bundle, libpath, null)).getFile()); } catch (IOException e) { @@ -127,9 +108,10 @@ public class GenerateFiles extends AbstractHandler { /* Templates execution. */ try { - TemplateEngine.process(basepath.addTrailingSeparator().append(xmlfile) - .toFile(), libpath.toFile(), sourcepath.toFile(), - basepath.toFile(), new File(output)); + TemplateEngine.process(cfgfilepath.toFile(), + libpath.toFile(), + tpath.toFile(), + new File(output_path)); } catch (TemplateException e) { MessageDialog.openInformation(window.getShell(), "Processing Error", e.getMessage()); diff --git a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/utils/TemplateEngine.java b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/utils/TemplateEngine.java index 892c9c99b..272d6a5c2 100644 --- a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/utils/TemplateEngine.java +++ b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/utils/TemplateEngine.java @@ -80,16 +80,15 @@ public class TemplateEngine { * absolute path to libraries directory
* @param sourcedir
* absolute path to templates directory
- * @param basedir
- * absolute path to project directory
* @param outputdir
- * output directory relative to basedir
+ * output directory relative to xmldata
*
* @throws SettingException
* @throws ProcessingException
*/
- public static void process(java.io.File xmldata, java.io.File libdir,
- java.io.File sourcedir, java.io.File basedir,
+ public static void process(java.io.File xmldata,
+ java.io.File libdir,
+ java.io.File sourcedir,
java.io.File outputdir) throws TemplateException {
/* Finds or creates a named console. */
@@ -110,7 +109,7 @@ public class TemplateEngine { * events to be logged.
*/
try {
- settings = new Settings(basedir);
+ settings = new Settings(xmldata.getParentFile());
} catch (SettingException e) {
e.printStackTrace();
return;
diff --git a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizard.java b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizard.java index e6c309b43..28ee7e6e7 100644 --- a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizard.java +++ b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizard.java @@ -54,9 +54,6 @@ public class ConfigurationNewWizard extends Wizard implements INewWizard { private String containerName; private String projectFileName; - private String dataFileName; - private String templatesPath; - private String outputDirName; private String defaultDataFile; /** @@ -91,9 +88,6 @@ public class ConfigurationNewWizard extends Wizard implements INewWizard { containerName = page.getContainerName(); projectFileName = page.getProjectFileName(); - dataFileName = page.getDataFileName(); - templatesPath = page.getTemplatesPath(); - outputDirName = page.getOutputDirName(); defaultDataFile = page.getDefaultDataFile(); IRunnableWithProgress op = new IRunnableWithProgress() { @@ -133,36 +127,20 @@ public class ConfigurationNewWizard extends Wizard implements INewWizard { throwCoreException("Container \"" + containerName + "\" does not exist."); } IContainer container = (IContainer)resource; - monitor.beginTask("Creating " + projectFileName, 4); + monitor.beginTask("Creating " + projectFileName, 3); /* Step #1, creates the project file.*/ final IFile projectFile = container.getFile(new Path(projectFileName)); - try { - InputStream stream = openProjectContentStream(templatesPath, - dataFileName, - outputDirName); - if (projectFile.exists()) { - projectFile.setContents(stream, true, true, monitor); - } else { - projectFile.create(stream, true, monitor); - } - stream.close(); - } catch (IOException e) { - } - monitor.worked(1); - - /* Step #2, creates the XML data file.*/ - final IFile dataFile = container.getFile(new Path(dataFileName)); Bundle bundle = Platform.getBundle(Activator.PLUGIN_ID); IPath path = new Path(defaultDataFile); String s; try { s = FileLocator.toFileURL(FileLocator.find(bundle, path, null)).getFile(); InputStream stream = new FileInputStream(s); - if (dataFile.exists()) { - dataFile.setContents(stream, true, true, monitor); + if (projectFile.exists()) { + projectFile.setContents(stream, true, true, monitor); } else { - dataFile.create(stream, true, monitor); + projectFile.create(stream, true, monitor); } stream.close(); } catch (IOException e) { @@ -183,29 +161,11 @@ public class ConfigurationNewWizard extends Wizard implements INewWizard { }); monitor.worked(1); - /* Step #4, refreshing local resources.*/ + /* Step #3, refreshing local resources.*/ container.refreshLocal(IResource.DEPTH_INFINITE, monitor); monitor.worked(1); } - /** - * We will initialize file contents with a sample text. - */ - private InputStream openProjectContentStream(String templatesPath, - String dataFileName, - String outputDirName) { - - String contents = "# Automatically generated configuration project file.\n\n" + - "# Templates path in the configuration plugin resources, do not modify.\n" + - "source=" + templatesPath + "\n\n" + - "# XML configuration data file path relative to this configuration file.\n" + - "xmlfile=" + dataFileName + "\n\n" + - "# Output directory path relative to directory containing this configuration\n" + - "# file.\n" + - "output=" + outputDirName + "\n"; - return new ByteArrayInputStream(contents.getBytes()); - } - private void throwCoreException(String message) throws CoreException { IStatus status = new Status(IStatus.ERROR, "org.chibios.tools.eclipse.config", IStatus.OK, diff --git a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizardPage.java b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizardPage.java index 599c17af0..dde12645b 100644 --- a/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizardPage.java +++ b/tools/eclipse/config_wizard/src/org/chibios/tools/eclipse/config/wizards/ConfigurationNewWizardPage.java @@ -24,8 +24,6 @@ import java.io.IOException; import org.eclipse.core.resources.IContainer; import org.eclipse.core.resources.IResource; -import org.eclipse.core.resources.IWorkspaceRoot; -import org.eclipse.core.resources.ResourcesPlugin; import org.eclipse.core.runtime.FileLocator; import org.eclipse.core.runtime.IPath; import org.eclipse.core.runtime.Path; @@ -65,14 +63,11 @@ public class ConfigurationNewWizardPage extends WizardPage { private IContainer resourceContainer; private Document processorsDocument; - private String currentTemplatesPath; private String currentDefaultDataFile; private Composite container; private Combo configurationTemplatesCombo; private Text confProjectFilenameText; - private Text confDataFilenameText; - private Text confOutputDirectoryText; /** * Constructor for SampleNewWizardPage. @@ -118,43 +113,15 @@ public class ConfigurationNewWizardPage extends WizardPage { } }); - Label lbl3 = new Label(container, SWT.NONE); - lbl3.setText("Configuration data filename:"); - - confDataFilenameText = new Text(container, SWT.BORDER); - confDataFilenameText.setText("config.chxml"); - confDataFilenameText.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, - false, 1, 1)); - confDataFilenameText.addModifyListener(new ModifyListener() { - public void modifyText(ModifyEvent e) { - confDataFilenameUpdated(); - } - }); - - Label lbl4 = new Label(container, SWT.NONE); - lbl4.setText("Configuration output directory:"); - - confOutputDirectoryText = new Text(container, SWT.BORDER); - confOutputDirectoryText.setText("."); - confOutputDirectoryText.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, - true, false, 1, 1)); - /* Note, it must stay after the creation of the text fields. */ configurationTemplatesCombo.addModifyListener(new ModifyListener() { public void modifyText(ModifyEvent e) { Element processor = getSelectedTemplate(); String basefilename = processor.getChildText("basefilename"); confProjectFilenameText.setText(basefilename.concat(".chcfg")); - confDataFilenameText.setText(basefilename.concat(".chxml")); - currentTemplatesPath = processor.getChildText("path"); currentDefaultDataFile = processor.getChildText("default"); } }); - confOutputDirectoryText.addModifyListener(new ModifyListener() { - public void modifyText(ModifyEvent e) { - confOutputDirectoryUpdated(); - } - }); populateWizardPanel(); initialize(); @@ -171,21 +138,6 @@ public class ConfigurationNewWizardPage extends WizardPage { return confProjectFilenameText.getText(); } - public String getDataFileName() { - - return confDataFilenameText.getText(); - } - - public String getOutputDirName() { - - return confOutputDirectoryText.getText(); - } - - public String getTemplatesPath() { - - return currentTemplatesPath; - } - public String getDefaultDataFile() { return currentDefaultDataFile; @@ -292,52 +244,6 @@ public class ConfigurationNewWizardPage extends WizardPage { } /** - * Checks the content of the confProjectFilenameText field. - */ - private void confDataFilenameUpdated() { - String fileName = getDataFileName(); - - if (fileName.length() == 0) { - updateStatus("File name must be specified"); - return; - } - if (fileName.replace('\\', '/').indexOf('/', 1) > 0) { - updateStatus("File name must be valid"); - return; - } - int dotLoc = fileName.lastIndexOf('.'); - if (dotLoc != -1) { - String ext = fileName.substring(dotLoc + 1); - if (ext.equalsIgnoreCase("chxml") == false) { - updateStatus("Configuration project filename extension must be \"chxml\""); - return; - } - } - updateStatus(null); - } - - /** - * Checks the content of the confOutputDirectoryText field. - */ - private void confOutputDirectoryUpdated() { - - IWorkspaceRoot root = ResourcesPlugin.getWorkspace().getRoot(); - IPath outputPath = resourceContainer.getFullPath().addTrailingSeparator() - .append(getOutputDirName()); - IResource outputContainer = root.findMember(outputPath); - - if (outputContainer == null) { - updateStatus("The directory must exists"); - return; - } - if (!(outputContainer instanceof IContainer)) { - updateStatus("A directory must be specified"); - return; - } - updateStatus(null); - } - - /** * Returns the XML Element associated to the current selection in the combo * box. * |