manual sync
This commit is contained in:
parent
d3db6d706c
commit
a7a4027b6f
|
@ -1,23 +1,23 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
</component>
|
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/CmpMerge.iml" filepath="$PROJECT_DIR$/CmpMerge.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/CmpMerge.iml" filepath="$PROJECT_DIR$/CmpMerge.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
</component>
|
|
@ -1,125 +1,125 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,431 +1,431 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" readonly="true" id="76c7538a-4244-42e9-b994-c6c9cbca491e" name="Default" comment="" />
|
||||
<ignored path="CmpMerge.iws" />
|
||||
<ignored path=".idea/workspace.xml" />
|
||||
<file path="/CmpMerge.java" changelist="76c7538a-4244-42e9-b994-c6c9cbca491e" time="1386564780632" ignored="false" />
|
||||
<file path="/fragment.java" changelist="76c7538a-4244-42e9-b994-c6c9cbca491e" time="1386564800959" ignored="false" />
|
||||
<option name="TRACKING_ENABLED" value="true" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
|
||||
<component name="CreatePatchCommitExecutor">
|
||||
<option name="PATCH_PATH" value="" />
|
||||
</component>
|
||||
<component name="DaemonCodeAnalyzer">
|
||||
<disable_hints />
|
||||
</component>
|
||||
<component name="DebuggerManager">
|
||||
<ui_properties default_suspend_policy="SuspendAll" default_condition_enabled="true" />
|
||||
<breakpoint_any default_suspend_policy="SuspendAll" default_condition_enabled="true">
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
</breakpoint_any>
|
||||
<breakpoint_rules />
|
||||
<ui_properties />
|
||||
</component>
|
||||
<component name="ExecutionTargetManager" SELECTED_TARGET="default_target" />
|
||||
<component name="FavoritesManager">
|
||||
<favorites_list name="CmpMerge" />
|
||||
</component>
|
||||
<component name="FileEditorManager">
|
||||
<leaf>
|
||||
<file leaf-file-name="CmpMerge.java" pinned="false" current="true" current-in-tab="true">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/CmpMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#1326#1334#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
</leaf>
|
||||
</component>
|
||||
<component name="FindManager">
|
||||
<FindUsagesManager>
|
||||
<setting name="OPEN_NEW_TAB" value="false" />
|
||||
</FindUsagesManager>
|
||||
</component>
|
||||
<component name="IdeDocumentHistory">
|
||||
<option name="changedFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/src/rusefi/CmpMerge.java" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectFrameBounds">
|
||||
<option name="x" value="-9" />
|
||||
<option name="y" value="-9" />
|
||||
<option name="width" value="1698" />
|
||||
<option name="height" value="1020" />
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectReloadState">
|
||||
<option name="STATE" value="0" />
|
||||
</component>
|
||||
<component name="ProjectView">
|
||||
<navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
|
||||
<flattenPackages />
|
||||
<showMembers />
|
||||
<showModules />
|
||||
<showLibraryContents />
|
||||
<hideEmptyPackages />
|
||||
<abbreviatePackageNames />
|
||||
<autoscrollToSource />
|
||||
<autoscrollFromSource />
|
||||
<sortByType />
|
||||
</navigator>
|
||||
<panes>
|
||||
<pane id="ProjectPane">
|
||||
<subPane>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="CmpMerge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="CmpMerge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="cmp_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
</subPane>
|
||||
</pane>
|
||||
<pane id="Scope" />
|
||||
<pane id="PackagesPane" />
|
||||
</panes>
|
||||
</component>
|
||||
<component name="PropertiesComponent">
|
||||
<property name="GoToFile.includeJavaFiles" value="false" />
|
||||
<property name="GoToClass.toSaveIncludeLibraries" value="false" />
|
||||
<property name="recentsLimit" value="5" />
|
||||
<property name="MemberChooser.sorted" value="false" />
|
||||
<property name="restartRequiresConfirmation" value="true" />
|
||||
<property name="last_opened_file_path" value="$PROJECT_DIR$" />
|
||||
<property name="MemberChooser.showClasses" value="true" />
|
||||
<property name="GoToClass.includeLibraries" value="false" />
|
||||
<property name="dynamic.classpath" value="false" />
|
||||
<property name="MemberChooser.copyJavadoc" value="false" />
|
||||
</component>
|
||||
<component name="RunManager" selected="Application.CmpMerge">
|
||||
<configuration default="false" name="CmpMerge" type="Application" factoryName="Application" temporary="true">
|
||||
<option name="MAIN_CLASS_NAME" value="rusefi.CmpMerge" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="out.cmp 1.cmp 2.cmp" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="CmpMerge" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Profile ">
|
||||
<option name="myExternalizedOptions" value=" additional-options2=onexit\=snapshot " />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="#org.jetbrains.idea.devkit.run.PluginConfigurationType" factoryName="Plugin">
|
||||
<module name="" />
|
||||
<option name="VM_PARAMETERS" value="-Xmx512m -Xms256m -XX:MaxPermSize=250m" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Remote" factoryName="Remote">
|
||||
<option name="USE_SOCKET_TRANSPORT" value="true" />
|
||||
<option name="SERVER_MODE" value="false" />
|
||||
<option name="SHMEM_ADDRESS" value="javadebug" />
|
||||
<option name="HOST" value="localhost" />
|
||||
<option name="PORT" value="5005" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Applet" factoryName="Applet">
|
||||
<module name="" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="HTML_FILE_NAME" />
|
||||
<option name="HTML_USED" value="false" />
|
||||
<option name="WIDTH" value="400" />
|
||||
<option name="HEIGHT" value="300" />
|
||||
<option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="TestNG" factoryName="TestNG">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="SUITE_NAME" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="GROUP_NAME" />
|
||||
<option name="TEST_OBJECT" value="CLASS" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="OUTPUT_DIRECTORY" />
|
||||
<option name="ANNOTATION_TYPE" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<option name="USE_DEFAULT_REPORTERS" value="false" />
|
||||
<option name="PROPERTIES_FILE" />
|
||||
<envs />
|
||||
<properties />
|
||||
<listeners />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="" />
|
||||
<envs />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="JUnit" factoryName="JUnit">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="TEST_OBJECT" value="class" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<envs />
|
||||
<patterns />
|
||||
<method />
|
||||
</configuration>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.CmpMerge" />
|
||||
</list>
|
||||
<recent_temporary>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.CmpMerge" />
|
||||
</list>
|
||||
</recent_temporary>
|
||||
<configuration name="<template>" type="WebApp" default="true" selected="false">
|
||||
<Host>localhost</Host>
|
||||
<Port>5050</Port>
|
||||
</configuration>
|
||||
</component>
|
||||
<component name="ShelveChangesManager" show_recycled="false" />
|
||||
<component name="SvnConfiguration" maxAnnotateRevisions="500" myUseAcceleration="nothing" myAutoUpdateAfterCommit="false" cleanupOnStartRun="true" SSL_PROTOCOLS="all">
|
||||
<option name="USER" value="" />
|
||||
<option name="PASSWORD" value="" />
|
||||
<option name="mySSHConnectionTimeout" value="30000" />
|
||||
<option name="mySSHReadTimeout" value="30000" />
|
||||
<option name="LAST_MERGED_REVISION" />
|
||||
<option name="MERGE_DRY_RUN" value="false" />
|
||||
<option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
|
||||
<option name="UPDATE_LOCK_ON_DEMAND" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_MERGE" value="false" />
|
||||
<option name="CHECK_NESTED_FOR_QUICK_MERGE" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
|
||||
<option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
|
||||
<option name="FORCE_UPDATE" value="false" />
|
||||
<option name="IGNORE_EXTERNALS" value="false" />
|
||||
<configuration useDefault="false">C:\Users\pc\AppData\Roaming\Subversion</configuration>
|
||||
<myIsUseDefaultProxy>false</myIsUseDefaultProxy>
|
||||
<supportedVersion>125</supportedVersion>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="76c7538a-4244-42e9-b994-c6c9cbca491e" name="Default" comment="" />
|
||||
<created>1386564339147</created>
|
||||
<updated>1386564339147</updated>
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="ToolWindowManager">
|
||||
<frame x="-9" y="-9" width="1698" height="1020" extended-state="6" />
|
||||
<editor active="true" />
|
||||
<layout>
|
||||
<window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="JetGradle" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3995327" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.249694" sideWeight="0.6705608" order="0" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.32943925" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
|
||||
</layout>
|
||||
</component>
|
||||
<component name="VcsContentAnnotationSettings">
|
||||
<option name="myLimit" value="2678400000" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
|
||||
<option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
|
||||
<option name="CHECK_NEW_TODO" value="true" />
|
||||
<option name="myTodoPanelSettings">
|
||||
<value>
|
||||
<are-packages-shown value="false" />
|
||||
<are-modules-shown value="false" />
|
||||
<flatten-packages value="false" />
|
||||
<is-autoscroll-to-source value="false" />
|
||||
</value>
|
||||
</option>
|
||||
<option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
|
||||
<option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="false" />
|
||||
<option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
|
||||
<option name="SHOW_ONLY_CHANGED_IN_SELECTION_DIFF" value="true" />
|
||||
<option name="CHECK_COMMIT_MESSAGE_SPELLING" value="true" />
|
||||
<option name="DEFAULT_PATCH_EXTENSION" value="patch" />
|
||||
<option name="SHORT_DIFF_HORIZONTALLY" value="true" />
|
||||
<option name="SHORT_DIFF_EXTRA_LINES" value="2" />
|
||||
<option name="SOFT_WRAPS_IN_SHORT_DIFF" value="true" />
|
||||
<option name="INCLUDE_TEXT_INTO_PATCH" value="false" />
|
||||
<option name="INCLUDE_TEXT_INTO_SHELF" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_DETAILS" value="true" />
|
||||
<option name="SHOW_VCS_ERROR_NOTIFICATIONS" value="true" />
|
||||
<option name="SHOW_DIRTY_RECURSIVELY" value="false" />
|
||||
<option name="LIMIT_HISTORY" value="true" />
|
||||
<option name="MAXIMUM_HISTORY_ROWS" value="1000" />
|
||||
<option name="UPDATE_FILTER_SCOPE_NAME" />
|
||||
<option name="USE_COMMIT_MESSAGE_MARGIN" value="false" />
|
||||
<option name="COMMIT_MESSAGE_MARGIN_SIZE" value="72" />
|
||||
<option name="WRAP_WHEN_TYPING_REACHES_RIGHT_MARGIN" value="false" />
|
||||
<option name="FORCE_NON_EMPTY_COMMENT" value="false" />
|
||||
<option name="CLEAR_INITIAL_COMMIT_MESSAGE" value="false" />
|
||||
<option name="LAST_COMMIT_MESSAGE" />
|
||||
<option name="MAKE_NEW_CHANGELIST_ACTIVE" value="false" />
|
||||
<option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
|
||||
<option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
|
||||
<option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
|
||||
<option name="ACTIVE_VCS_NAME" />
|
||||
<option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
|
||||
<option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
|
||||
<option name="UPDATE_FILTER_BY_SCOPE" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
|
||||
<option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
|
||||
</component>
|
||||
<component name="XDebuggerManager">
|
||||
<breakpoint-manager />
|
||||
</component>
|
||||
<component name="antWorkspaceConfiguration">
|
||||
<option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
|
||||
<option name="FILTER_TARGETS" value="false" />
|
||||
</component>
|
||||
<component name="editorHistoryManager">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/CmpMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#1326#1334#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/CmpMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#1326#1334#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" readonly="true" id="76c7538a-4244-42e9-b994-c6c9cbca491e" name="Default" comment="" />
|
||||
<ignored path="CmpMerge.iws" />
|
||||
<ignored path=".idea/workspace.xml" />
|
||||
<file path="/CmpMerge.java" changelist="76c7538a-4244-42e9-b994-c6c9cbca491e" time="1386564780632" ignored="false" />
|
||||
<file path="/fragment.java" changelist="76c7538a-4244-42e9-b994-c6c9cbca491e" time="1386564800959" ignored="false" />
|
||||
<option name="TRACKING_ENABLED" value="true" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
|
||||
<component name="CreatePatchCommitExecutor">
|
||||
<option name="PATCH_PATH" value="" />
|
||||
</component>
|
||||
<component name="DaemonCodeAnalyzer">
|
||||
<disable_hints />
|
||||
</component>
|
||||
<component name="DebuggerManager">
|
||||
<ui_properties default_suspend_policy="SuspendAll" default_condition_enabled="true" />
|
||||
<breakpoint_any default_suspend_policy="SuspendAll" default_condition_enabled="true">
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
</breakpoint_any>
|
||||
<breakpoint_rules />
|
||||
<ui_properties />
|
||||
</component>
|
||||
<component name="ExecutionTargetManager" SELECTED_TARGET="default_target" />
|
||||
<component name="FavoritesManager">
|
||||
<favorites_list name="CmpMerge" />
|
||||
</component>
|
||||
<component name="FileEditorManager">
|
||||
<leaf>
|
||||
<file leaf-file-name="CmpMerge.java" pinned="false" current="true" current-in-tab="true">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/CmpMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#1326#1334#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
</leaf>
|
||||
</component>
|
||||
<component name="FindManager">
|
||||
<FindUsagesManager>
|
||||
<setting name="OPEN_NEW_TAB" value="false" />
|
||||
</FindUsagesManager>
|
||||
</component>
|
||||
<component name="IdeDocumentHistory">
|
||||
<option name="changedFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/src/rusefi/CmpMerge.java" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectFrameBounds">
|
||||
<option name="x" value="-9" />
|
||||
<option name="y" value="-9" />
|
||||
<option name="width" value="1698" />
|
||||
<option name="height" value="1020" />
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectReloadState">
|
||||
<option name="STATE" value="0" />
|
||||
</component>
|
||||
<component name="ProjectView">
|
||||
<navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
|
||||
<flattenPackages />
|
||||
<showMembers />
|
||||
<showModules />
|
||||
<showLibraryContents />
|
||||
<hideEmptyPackages />
|
||||
<abbreviatePackageNames />
|
||||
<autoscrollToSource />
|
||||
<autoscrollFromSource />
|
||||
<sortByType />
|
||||
</navigator>
|
||||
<panes>
|
||||
<pane id="ProjectPane">
|
||||
<subPane>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="CmpMerge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="CmpMerge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="cmp_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
</subPane>
|
||||
</pane>
|
||||
<pane id="Scope" />
|
||||
<pane id="PackagesPane" />
|
||||
</panes>
|
||||
</component>
|
||||
<component name="PropertiesComponent">
|
||||
<property name="GoToFile.includeJavaFiles" value="false" />
|
||||
<property name="GoToClass.toSaveIncludeLibraries" value="false" />
|
||||
<property name="recentsLimit" value="5" />
|
||||
<property name="MemberChooser.sorted" value="false" />
|
||||
<property name="restartRequiresConfirmation" value="true" />
|
||||
<property name="last_opened_file_path" value="$PROJECT_DIR$" />
|
||||
<property name="MemberChooser.showClasses" value="true" />
|
||||
<property name="GoToClass.includeLibraries" value="false" />
|
||||
<property name="dynamic.classpath" value="false" />
|
||||
<property name="MemberChooser.copyJavadoc" value="false" />
|
||||
</component>
|
||||
<component name="RunManager" selected="Application.CmpMerge">
|
||||
<configuration default="false" name="CmpMerge" type="Application" factoryName="Application" temporary="true">
|
||||
<option name="MAIN_CLASS_NAME" value="rusefi.CmpMerge" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="out.cmp 1.cmp 2.cmp" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="CmpMerge" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Profile ">
|
||||
<option name="myExternalizedOptions" value=" additional-options2=onexit\=snapshot " />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="#org.jetbrains.idea.devkit.run.PluginConfigurationType" factoryName="Plugin">
|
||||
<module name="" />
|
||||
<option name="VM_PARAMETERS" value="-Xmx512m -Xms256m -XX:MaxPermSize=250m" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Remote" factoryName="Remote">
|
||||
<option name="USE_SOCKET_TRANSPORT" value="true" />
|
||||
<option name="SERVER_MODE" value="false" />
|
||||
<option name="SHMEM_ADDRESS" value="javadebug" />
|
||||
<option name="HOST" value="localhost" />
|
||||
<option name="PORT" value="5005" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Applet" factoryName="Applet">
|
||||
<module name="" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="HTML_FILE_NAME" />
|
||||
<option name="HTML_USED" value="false" />
|
||||
<option name="WIDTH" value="400" />
|
||||
<option name="HEIGHT" value="300" />
|
||||
<option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="TestNG" factoryName="TestNG">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="SUITE_NAME" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="GROUP_NAME" />
|
||||
<option name="TEST_OBJECT" value="CLASS" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="OUTPUT_DIRECTORY" />
|
||||
<option name="ANNOTATION_TYPE" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<option name="USE_DEFAULT_REPORTERS" value="false" />
|
||||
<option name="PROPERTIES_FILE" />
|
||||
<envs />
|
||||
<properties />
|
||||
<listeners />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="" />
|
||||
<envs />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="JUnit" factoryName="JUnit">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="TEST_OBJECT" value="class" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<envs />
|
||||
<patterns />
|
||||
<method />
|
||||
</configuration>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.CmpMerge" />
|
||||
</list>
|
||||
<recent_temporary>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.CmpMerge" />
|
||||
</list>
|
||||
</recent_temporary>
|
||||
<configuration name="<template>" type="WebApp" default="true" selected="false">
|
||||
<Host>localhost</Host>
|
||||
<Port>5050</Port>
|
||||
</configuration>
|
||||
</component>
|
||||
<component name="ShelveChangesManager" show_recycled="false" />
|
||||
<component name="SvnConfiguration" maxAnnotateRevisions="500" myUseAcceleration="nothing" myAutoUpdateAfterCommit="false" cleanupOnStartRun="true" SSL_PROTOCOLS="all">
|
||||
<option name="USER" value="" />
|
||||
<option name="PASSWORD" value="" />
|
||||
<option name="mySSHConnectionTimeout" value="30000" />
|
||||
<option name="mySSHReadTimeout" value="30000" />
|
||||
<option name="LAST_MERGED_REVISION" />
|
||||
<option name="MERGE_DRY_RUN" value="false" />
|
||||
<option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
|
||||
<option name="UPDATE_LOCK_ON_DEMAND" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_MERGE" value="false" />
|
||||
<option name="CHECK_NESTED_FOR_QUICK_MERGE" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
|
||||
<option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
|
||||
<option name="FORCE_UPDATE" value="false" />
|
||||
<option name="IGNORE_EXTERNALS" value="false" />
|
||||
<configuration useDefault="false">C:\Users\pc\AppData\Roaming\Subversion</configuration>
|
||||
<myIsUseDefaultProxy>false</myIsUseDefaultProxy>
|
||||
<supportedVersion>125</supportedVersion>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="76c7538a-4244-42e9-b994-c6c9cbca491e" name="Default" comment="" />
|
||||
<created>1386564339147</created>
|
||||
<updated>1386564339147</updated>
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="ToolWindowManager">
|
||||
<frame x="-9" y="-9" width="1698" height="1020" extended-state="6" />
|
||||
<editor active="true" />
|
||||
<layout>
|
||||
<window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="JetGradle" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3995327" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.249694" sideWeight="0.6705608" order="0" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.32943925" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
|
||||
</layout>
|
||||
</component>
|
||||
<component name="VcsContentAnnotationSettings">
|
||||
<option name="myLimit" value="2678400000" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
|
||||
<option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
|
||||
<option name="CHECK_NEW_TODO" value="true" />
|
||||
<option name="myTodoPanelSettings">
|
||||
<value>
|
||||
<are-packages-shown value="false" />
|
||||
<are-modules-shown value="false" />
|
||||
<flatten-packages value="false" />
|
||||
<is-autoscroll-to-source value="false" />
|
||||
</value>
|
||||
</option>
|
||||
<option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
|
||||
<option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="false" />
|
||||
<option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
|
||||
<option name="SHOW_ONLY_CHANGED_IN_SELECTION_DIFF" value="true" />
|
||||
<option name="CHECK_COMMIT_MESSAGE_SPELLING" value="true" />
|
||||
<option name="DEFAULT_PATCH_EXTENSION" value="patch" />
|
||||
<option name="SHORT_DIFF_HORIZONTALLY" value="true" />
|
||||
<option name="SHORT_DIFF_EXTRA_LINES" value="2" />
|
||||
<option name="SOFT_WRAPS_IN_SHORT_DIFF" value="true" />
|
||||
<option name="INCLUDE_TEXT_INTO_PATCH" value="false" />
|
||||
<option name="INCLUDE_TEXT_INTO_SHELF" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_DETAILS" value="true" />
|
||||
<option name="SHOW_VCS_ERROR_NOTIFICATIONS" value="true" />
|
||||
<option name="SHOW_DIRTY_RECURSIVELY" value="false" />
|
||||
<option name="LIMIT_HISTORY" value="true" />
|
||||
<option name="MAXIMUM_HISTORY_ROWS" value="1000" />
|
||||
<option name="UPDATE_FILTER_SCOPE_NAME" />
|
||||
<option name="USE_COMMIT_MESSAGE_MARGIN" value="false" />
|
||||
<option name="COMMIT_MESSAGE_MARGIN_SIZE" value="72" />
|
||||
<option name="WRAP_WHEN_TYPING_REACHES_RIGHT_MARGIN" value="false" />
|
||||
<option name="FORCE_NON_EMPTY_COMMENT" value="false" />
|
||||
<option name="CLEAR_INITIAL_COMMIT_MESSAGE" value="false" />
|
||||
<option name="LAST_COMMIT_MESSAGE" />
|
||||
<option name="MAKE_NEW_CHANGELIST_ACTIVE" value="false" />
|
||||
<option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
|
||||
<option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
|
||||
<option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
|
||||
<option name="ACTIVE_VCS_NAME" />
|
||||
<option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
|
||||
<option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
|
||||
<option name="UPDATE_FILTER_BY_SCOPE" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
|
||||
<option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
|
||||
</component>
|
||||
<component name="XDebuggerManager">
|
||||
<breakpoint-manager />
|
||||
</component>
|
||||
<component name="antWorkspaceConfiguration">
|
||||
<option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
|
||||
<option name="FILTER_TARGETS" value="false" />
|
||||
</component>
|
||||
<component name="editorHistoryManager">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/CmpMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#1326#1334#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/CmpMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#1326#1334#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,12 +1,12 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
|
|
|
@ -1,24 +1,24 @@
|
|||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../cmp_merge.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="rusefi.CmpMerge"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../cmp_merge.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="rusefi.CmpMerge"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
</project>
|
|
@ -1,63 +1,63 @@
|
|||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class CmpMerge {
|
||||
private CmpMerge() {
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 2) {
|
||||
System.out.println("This tool merges .cmp KiCad component mappting files");
|
||||
System.out.println("usage:");
|
||||
System.out.println("NetListMerge DEST_FILE SOURCE_1 SOURCE_2 [SOURCE_x]*");
|
||||
return;
|
||||
}
|
||||
|
||||
String destinationFile = args[0];
|
||||
|
||||
System.out.println("Writing result into " + destinationFile);
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(destinationFile));
|
||||
|
||||
bw.write("Cmp-Mod V01 Created by CvPcb (2013-07-07 BZR 4022)-stable date = 01/12/2013 21:54:01\r\n");
|
||||
|
||||
for (int i = 1; i < args.length; i++) {
|
||||
String sourceFile = args[i];
|
||||
|
||||
List<String> list = readFileToList(sourceFile);
|
||||
|
||||
for (String line : list.subList(1, list.size() - 2))
|
||||
bw.write(line + "\r\n");
|
||||
}
|
||||
|
||||
bw.write("\r\nEndListe\r\n");
|
||||
bw.close();
|
||||
}
|
||||
|
||||
static List<String> readFileToList(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
List<String> result = new ArrayList<String>();
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
result.add(line);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void checkExistence(String fileName) {
|
||||
if (!new File(fileName).isFile()) {
|
||||
System.err.println("File not found: " + fileName);
|
||||
System.exit(-1);
|
||||
}
|
||||
}
|
||||
}
|
||||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class CmpMerge {
|
||||
private CmpMerge() {
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 2) {
|
||||
System.out.println("This tool merges .cmp KiCad component mappting files");
|
||||
System.out.println("usage:");
|
||||
System.out.println("NetListMerge DEST_FILE SOURCE_1 SOURCE_2 [SOURCE_x]*");
|
||||
return;
|
||||
}
|
||||
|
||||
String destinationFile = args[0];
|
||||
|
||||
System.out.println("Writing result into " + destinationFile);
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(destinationFile));
|
||||
|
||||
bw.write("Cmp-Mod V01 Created by CvPcb (2013-07-07 BZR 4022)-stable date = 01/12/2013 21:54:01\r\n");
|
||||
|
||||
for (int i = 1; i < args.length; i++) {
|
||||
String sourceFile = args[i];
|
||||
|
||||
List<String> list = readFileToList(sourceFile);
|
||||
|
||||
for (String line : list.subList(1, list.size() - 2))
|
||||
bw.write(line + "\r\n");
|
||||
}
|
||||
|
||||
bw.write("\r\nEndListe\r\n");
|
||||
bw.close();
|
||||
}
|
||||
|
||||
static List<String> readFileToList(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
List<String> result = new ArrayList<String>();
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
result.add(line);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void checkExistence(String fileName) {
|
||||
if (!new File(fileName).isFile()) {
|
||||
System.err.println("File not found: " + fileName);
|
||||
System.exit(-1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Binary file not shown.
|
@ -1,23 +1,23 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
</component>
|
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/gcc_map_reader.iml" filepath="$PROJECT_DIR$/gcc_map_reader.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/gcc_map_reader.iml" filepath="$PROJECT_DIR$/gcc_map_reader.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
</component>
|
|
@ -1,125 +1,125 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,460 +1,460 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" readonly="true" id="d25d16f1-bb3a-4204-ac14-48526d2df69c" name="Default" comment="" />
|
||||
<ignored path="gcc_map_reader.iws" />
|
||||
<ignored path=".idea/workspace.xml" />
|
||||
<file path="/GccMapReader.java" changelist="d25d16f1-bb3a-4204-ac14-48526d2df69c" time="1385943544305" ignored="false" />
|
||||
<file path="/fragment.java" changelist="d25d16f1-bb3a-4204-ac14-48526d2df69c" time="1381937073931" ignored="false" />
|
||||
<option name="TRACKING_ENABLED" value="true" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
|
||||
<component name="CreatePatchCommitExecutor">
|
||||
<option name="PATCH_PATH" value="" />
|
||||
</component>
|
||||
<component name="DaemonCodeAnalyzer">
|
||||
<disable_hints />
|
||||
</component>
|
||||
<component name="DebuggerManager">
|
||||
<breakpoint_any default_suspend_policy="SuspendAll" default_condition_enabled="true">
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
</breakpoint_any>
|
||||
<ui_properties default_suspend_policy="SuspendAll" default_condition_enabled="true" />
|
||||
<breakpoint_rules />
|
||||
<ui_properties />
|
||||
</component>
|
||||
<component name="ExecutionTargetManager" SELECTED_TARGET="default_target" />
|
||||
<component name="FavoritesManager">
|
||||
<favorites_list name="gcc_map_reader" />
|
||||
</component>
|
||||
<component name="FileEditorManager">
|
||||
<leaf>
|
||||
<file leaf-file-name="GccMapReader.java" pinned="false" current="true" current-in-tab="true">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="56" column="17" selection-start="1616" selection-end="1616" vertical-scroll-proportion="1.0455374">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
</leaf>
|
||||
</component>
|
||||
<component name="FindManager">
|
||||
<FindUsagesManager>
|
||||
<setting name="OPEN_NEW_TAB" value="false" />
|
||||
</FindUsagesManager>
|
||||
</component>
|
||||
<component name="IdeDocumentHistory">
|
||||
<option name="changedFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/src/rusefi/GccMapReader.java" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectFrameBounds">
|
||||
<option name="x" value="-9" />
|
||||
<option name="y" value="-9" />
|
||||
<option name="width" value="1698" />
|
||||
<option name="height" value="1020" />
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectReloadState">
|
||||
<option name="STATE" value="0" />
|
||||
</component>
|
||||
<component name="ProjectView">
|
||||
<navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
|
||||
<flattenPackages />
|
||||
<showMembers />
|
||||
<showModules />
|
||||
<showLibraryContents />
|
||||
<hideEmptyPackages />
|
||||
<abbreviatePackageNames />
|
||||
<autoscrollToSource />
|
||||
<autoscrollFromSource />
|
||||
<sortByType />
|
||||
</navigator>
|
||||
<panes>
|
||||
<pane id="ProjectPane">
|
||||
<subPane>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="src" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="rusefi" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
</subPane>
|
||||
</pane>
|
||||
<pane id="Scope" />
|
||||
<pane id="PackagesPane" />
|
||||
</panes>
|
||||
</component>
|
||||
<component name="PropertiesComponent">
|
||||
<property name="GoToFile.includeJavaFiles" value="false" />
|
||||
<property name="OverrideImplement.combined" value="true" />
|
||||
<property name="GoToClass.toSaveIncludeLibraries" value="false" />
|
||||
<property name="recentsLimit" value="5" />
|
||||
<property name="MemberChooser.sorted" value="false" />
|
||||
<property name="FullScreen" value="false" />
|
||||
<property name="MemberChooser.showClasses" value="true" />
|
||||
<property name="GoToClass.includeLibraries" value="false" />
|
||||
<property name="dynamic.classpath" value="false" />
|
||||
<property name="MemberChooser.copyJavadoc" value="false" />
|
||||
</component>
|
||||
<component name="RunManager" selected="Application.GccMapReader">
|
||||
<configuration default="false" name="GccMapReader" type="Application" factoryName="Application" temporary="true">
|
||||
<option name="MAIN_CLASS_NAME" value="rusefi.GccMapReader" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="gcc_map_reader" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="#org.jetbrains.idea.devkit.run.PluginConfigurationType" factoryName="Plugin">
|
||||
<module name="" />
|
||||
<option name="VM_PARAMETERS" value="-Xmx512m -Xms256m -XX:MaxPermSize=250m" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Remote" factoryName="Remote">
|
||||
<option name="USE_SOCKET_TRANSPORT" value="true" />
|
||||
<option name="SERVER_MODE" value="false" />
|
||||
<option name="SHMEM_ADDRESS" value="javadebug" />
|
||||
<option name="HOST" value="localhost" />
|
||||
<option name="PORT" value="5005" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="TestNG" factoryName="TestNG">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="SUITE_NAME" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="GROUP_NAME" />
|
||||
<option name="TEST_OBJECT" value="CLASS" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="OUTPUT_DIRECTORY" />
|
||||
<option name="ANNOTATION_TYPE" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<option name="USE_DEFAULT_REPORTERS" value="false" />
|
||||
<option name="PROPERTIES_FILE" />
|
||||
<envs />
|
||||
<properties />
|
||||
<listeners />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Applet" factoryName="Applet">
|
||||
<module name="" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="HTML_FILE_NAME" />
|
||||
<option name="HTML_USED" value="false" />
|
||||
<option name="WIDTH" value="400" />
|
||||
<option name="HEIGHT" value="300" />
|
||||
<option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="" />
|
||||
<envs />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="JUnit" factoryName="JUnit">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="TEST_OBJECT" value="class" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<envs />
|
||||
<patterns />
|
||||
<method />
|
||||
</configuration>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.GccMapReader" />
|
||||
</list>
|
||||
<recent_temporary>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.GccMapReader" />
|
||||
</list>
|
||||
</recent_temporary>
|
||||
<configuration name="<template>" type="WebApp" default="true" selected="false">
|
||||
<Host>localhost</Host>
|
||||
<Port>5050</Port>
|
||||
</configuration>
|
||||
</component>
|
||||
<component name="ShelveChangesManager" show_recycled="false" />
|
||||
<component name="SvnConfiguration" maxAnnotateRevisions="500" myUseAcceleration="nothing" myAutoUpdateAfterCommit="false" cleanupOnStartRun="true" SSL_PROTOCOLS="all">
|
||||
<option name="USER" value="" />
|
||||
<option name="PASSWORD" value="" />
|
||||
<option name="mySSHConnectionTimeout" value="30000" />
|
||||
<option name="mySSHReadTimeout" value="30000" />
|
||||
<option name="LAST_MERGED_REVISION" />
|
||||
<option name="MERGE_DRY_RUN" value="false" />
|
||||
<option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
|
||||
<option name="UPDATE_LOCK_ON_DEMAND" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_MERGE" value="false" />
|
||||
<option name="CHECK_NESTED_FOR_QUICK_MERGE" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
|
||||
<option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
|
||||
<option name="FORCE_UPDATE" value="false" />
|
||||
<option name="IGNORE_EXTERNALS" value="false" />
|
||||
<configuration useDefault="false">C:\Users\Andrey\AppData\Roaming\Subversion</configuration>
|
||||
<myIsUseDefaultProxy>false</myIsUseDefaultProxy>
|
||||
<supportedVersion>125</supportedVersion>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="d25d16f1-bb3a-4204-ac14-48526d2df69c" name="Default" comment="" />
|
||||
<created>1381936593168</created>
|
||||
<updated>1381936593168</updated>
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="ToolWindowManager">
|
||||
<frame x="-9" y="-9" width="1698" height="1020" extended-state="6" />
|
||||
<editor active="false" />
|
||||
<layout>
|
||||
<window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="JetGradle" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.39836448" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3286119" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.24602203" sideWeight="0.67172897" order="0" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Run" active="true" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.32827103" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
|
||||
</layout>
|
||||
</component>
|
||||
<component name="VcsContentAnnotationSettings">
|
||||
<option name="myLimit" value="2678400000" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
|
||||
<option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
|
||||
<option name="CHECK_NEW_TODO" value="true" />
|
||||
<option name="myTodoPanelSettings">
|
||||
<value>
|
||||
<are-packages-shown value="false" />
|
||||
<are-modules-shown value="false" />
|
||||
<flatten-packages value="false" />
|
||||
<is-autoscroll-to-source value="false" />
|
||||
</value>
|
||||
</option>
|
||||
<option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
|
||||
<option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="false" />
|
||||
<option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
|
||||
<option name="SHOW_ONLY_CHANGED_IN_SELECTION_DIFF" value="true" />
|
||||
<option name="CHECK_COMMIT_MESSAGE_SPELLING" value="true" />
|
||||
<option name="DEFAULT_PATCH_EXTENSION" value="patch" />
|
||||
<option name="SHORT_DIFF_HORIZONTALLY" value="true" />
|
||||
<option name="SHORT_DIFF_EXTRA_LINES" value="2" />
|
||||
<option name="SOFT_WRAPS_IN_SHORT_DIFF" value="true" />
|
||||
<option name="INCLUDE_TEXT_INTO_PATCH" value="false" />
|
||||
<option name="INCLUDE_TEXT_INTO_SHELF" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_DETAILS" value="true" />
|
||||
<option name="SHOW_VCS_ERROR_NOTIFICATIONS" value="true" />
|
||||
<option name="SHOW_DIRTY_RECURSIVELY" value="false" />
|
||||
<option name="LIMIT_HISTORY" value="true" />
|
||||
<option name="MAXIMUM_HISTORY_ROWS" value="1000" />
|
||||
<option name="UPDATE_FILTER_SCOPE_NAME" />
|
||||
<option name="USE_COMMIT_MESSAGE_MARGIN" value="false" />
|
||||
<option name="COMMIT_MESSAGE_MARGIN_SIZE" value="72" />
|
||||
<option name="WRAP_WHEN_TYPING_REACHES_RIGHT_MARGIN" value="false" />
|
||||
<option name="FORCE_NON_EMPTY_COMMENT" value="false" />
|
||||
<option name="CLEAR_INITIAL_COMMIT_MESSAGE" value="false" />
|
||||
<option name="LAST_COMMIT_MESSAGE" />
|
||||
<option name="MAKE_NEW_CHANGELIST_ACTIVE" value="false" />
|
||||
<option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
|
||||
<option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
|
||||
<option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
|
||||
<option name="ACTIVE_VCS_NAME" />
|
||||
<option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
|
||||
<option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
|
||||
<option name="UPDATE_FILTER_BY_SCOPE" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
|
||||
<option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
|
||||
</component>
|
||||
<component name="XDebuggerManager">
|
||||
<breakpoint-manager />
|
||||
</component>
|
||||
<component name="antWorkspaceConfiguration">
|
||||
<option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
|
||||
<option name="FILTER_TARGETS" value="false" />
|
||||
</component>
|
||||
<component name="editorHistoryManager">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="56" column="17" selection-start="1616" selection-end="1616" vertical-scroll-proportion="1.0455374">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" readonly="true" id="d25d16f1-bb3a-4204-ac14-48526d2df69c" name="Default" comment="" />
|
||||
<ignored path="gcc_map_reader.iws" />
|
||||
<ignored path=".idea/workspace.xml" />
|
||||
<file path="/GccMapReader.java" changelist="d25d16f1-bb3a-4204-ac14-48526d2df69c" time="1385943544305" ignored="false" />
|
||||
<file path="/fragment.java" changelist="d25d16f1-bb3a-4204-ac14-48526d2df69c" time="1381937073931" ignored="false" />
|
||||
<option name="TRACKING_ENABLED" value="true" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
|
||||
<component name="CreatePatchCommitExecutor">
|
||||
<option name="PATCH_PATH" value="" />
|
||||
</component>
|
||||
<component name="DaemonCodeAnalyzer">
|
||||
<disable_hints />
|
||||
</component>
|
||||
<component name="DebuggerManager">
|
||||
<breakpoint_any default_suspend_policy="SuspendAll" default_condition_enabled="true">
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
</breakpoint_any>
|
||||
<ui_properties default_suspend_policy="SuspendAll" default_condition_enabled="true" />
|
||||
<breakpoint_rules />
|
||||
<ui_properties />
|
||||
</component>
|
||||
<component name="ExecutionTargetManager" SELECTED_TARGET="default_target" />
|
||||
<component name="FavoritesManager">
|
||||
<favorites_list name="gcc_map_reader" />
|
||||
</component>
|
||||
<component name="FileEditorManager">
|
||||
<leaf>
|
||||
<file leaf-file-name="GccMapReader.java" pinned="false" current="true" current-in-tab="true">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="56" column="17" selection-start="1616" selection-end="1616" vertical-scroll-proportion="1.0455374">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
</leaf>
|
||||
</component>
|
||||
<component name="FindManager">
|
||||
<FindUsagesManager>
|
||||
<setting name="OPEN_NEW_TAB" value="false" />
|
||||
</FindUsagesManager>
|
||||
</component>
|
||||
<component name="IdeDocumentHistory">
|
||||
<option name="changedFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/src/rusefi/GccMapReader.java" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectFrameBounds">
|
||||
<option name="x" value="-9" />
|
||||
<option name="y" value="-9" />
|
||||
<option name="width" value="1698" />
|
||||
<option name="height" value="1020" />
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectReloadState">
|
||||
<option name="STATE" value="0" />
|
||||
</component>
|
||||
<component name="ProjectView">
|
||||
<navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
|
||||
<flattenPackages />
|
||||
<showMembers />
|
||||
<showModules />
|
||||
<showLibraryContents />
|
||||
<hideEmptyPackages />
|
||||
<abbreviatePackageNames />
|
||||
<autoscrollToSource />
|
||||
<autoscrollFromSource />
|
||||
<sortByType />
|
||||
</navigator>
|
||||
<panes>
|
||||
<pane id="ProjectPane">
|
||||
<subPane>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="gcc_map_reader" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="src" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="rusefi" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
</subPane>
|
||||
</pane>
|
||||
<pane id="Scope" />
|
||||
<pane id="PackagesPane" />
|
||||
</panes>
|
||||
</component>
|
||||
<component name="PropertiesComponent">
|
||||
<property name="GoToFile.includeJavaFiles" value="false" />
|
||||
<property name="OverrideImplement.combined" value="true" />
|
||||
<property name="GoToClass.toSaveIncludeLibraries" value="false" />
|
||||
<property name="recentsLimit" value="5" />
|
||||
<property name="MemberChooser.sorted" value="false" />
|
||||
<property name="FullScreen" value="false" />
|
||||
<property name="MemberChooser.showClasses" value="true" />
|
||||
<property name="GoToClass.includeLibraries" value="false" />
|
||||
<property name="dynamic.classpath" value="false" />
|
||||
<property name="MemberChooser.copyJavadoc" value="false" />
|
||||
</component>
|
||||
<component name="RunManager" selected="Application.GccMapReader">
|
||||
<configuration default="false" name="GccMapReader" type="Application" factoryName="Application" temporary="true">
|
||||
<option name="MAIN_CLASS_NAME" value="rusefi.GccMapReader" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="gcc_map_reader" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="#org.jetbrains.idea.devkit.run.PluginConfigurationType" factoryName="Plugin">
|
||||
<module name="" />
|
||||
<option name="VM_PARAMETERS" value="-Xmx512m -Xms256m -XX:MaxPermSize=250m" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Remote" factoryName="Remote">
|
||||
<option name="USE_SOCKET_TRANSPORT" value="true" />
|
||||
<option name="SERVER_MODE" value="false" />
|
||||
<option name="SHMEM_ADDRESS" value="javadebug" />
|
||||
<option name="HOST" value="localhost" />
|
||||
<option name="PORT" value="5005" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="TestNG" factoryName="TestNG">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="SUITE_NAME" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="GROUP_NAME" />
|
||||
<option name="TEST_OBJECT" value="CLASS" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="OUTPUT_DIRECTORY" />
|
||||
<option name="ANNOTATION_TYPE" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<option name="USE_DEFAULT_REPORTERS" value="false" />
|
||||
<option name="PROPERTIES_FILE" />
|
||||
<envs />
|
||||
<properties />
|
||||
<listeners />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Applet" factoryName="Applet">
|
||||
<module name="" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="HTML_FILE_NAME" />
|
||||
<option name="HTML_USED" value="false" />
|
||||
<option name="WIDTH" value="400" />
|
||||
<option name="HEIGHT" value="300" />
|
||||
<option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="" />
|
||||
<envs />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="JUnit" factoryName="JUnit">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="TEST_OBJECT" value="class" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<envs />
|
||||
<patterns />
|
||||
<method />
|
||||
</configuration>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.GccMapReader" />
|
||||
</list>
|
||||
<recent_temporary>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.GccMapReader" />
|
||||
</list>
|
||||
</recent_temporary>
|
||||
<configuration name="<template>" type="WebApp" default="true" selected="false">
|
||||
<Host>localhost</Host>
|
||||
<Port>5050</Port>
|
||||
</configuration>
|
||||
</component>
|
||||
<component name="ShelveChangesManager" show_recycled="false" />
|
||||
<component name="SvnConfiguration" maxAnnotateRevisions="500" myUseAcceleration="nothing" myAutoUpdateAfterCommit="false" cleanupOnStartRun="true" SSL_PROTOCOLS="all">
|
||||
<option name="USER" value="" />
|
||||
<option name="PASSWORD" value="" />
|
||||
<option name="mySSHConnectionTimeout" value="30000" />
|
||||
<option name="mySSHReadTimeout" value="30000" />
|
||||
<option name="LAST_MERGED_REVISION" />
|
||||
<option name="MERGE_DRY_RUN" value="false" />
|
||||
<option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
|
||||
<option name="UPDATE_LOCK_ON_DEMAND" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_MERGE" value="false" />
|
||||
<option name="CHECK_NESTED_FOR_QUICK_MERGE" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
|
||||
<option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
|
||||
<option name="FORCE_UPDATE" value="false" />
|
||||
<option name="IGNORE_EXTERNALS" value="false" />
|
||||
<configuration useDefault="false">C:\Users\Andrey\AppData\Roaming\Subversion</configuration>
|
||||
<myIsUseDefaultProxy>false</myIsUseDefaultProxy>
|
||||
<supportedVersion>125</supportedVersion>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="d25d16f1-bb3a-4204-ac14-48526d2df69c" name="Default" comment="" />
|
||||
<created>1381936593168</created>
|
||||
<updated>1381936593168</updated>
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="ToolWindowManager">
|
||||
<frame x="-9" y="-9" width="1698" height="1020" extended-state="6" />
|
||||
<editor active="false" />
|
||||
<layout>
|
||||
<window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="JetGradle" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.39836448" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3286119" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.24602203" sideWeight="0.67172897" order="0" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Run" active="true" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.32827103" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
|
||||
</layout>
|
||||
</component>
|
||||
<component name="VcsContentAnnotationSettings">
|
||||
<option name="myLimit" value="2678400000" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
|
||||
<option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
|
||||
<option name="CHECK_NEW_TODO" value="true" />
|
||||
<option name="myTodoPanelSettings">
|
||||
<value>
|
||||
<are-packages-shown value="false" />
|
||||
<are-modules-shown value="false" />
|
||||
<flatten-packages value="false" />
|
||||
<is-autoscroll-to-source value="false" />
|
||||
</value>
|
||||
</option>
|
||||
<option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
|
||||
<option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="false" />
|
||||
<option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
|
||||
<option name="SHOW_ONLY_CHANGED_IN_SELECTION_DIFF" value="true" />
|
||||
<option name="CHECK_COMMIT_MESSAGE_SPELLING" value="true" />
|
||||
<option name="DEFAULT_PATCH_EXTENSION" value="patch" />
|
||||
<option name="SHORT_DIFF_HORIZONTALLY" value="true" />
|
||||
<option name="SHORT_DIFF_EXTRA_LINES" value="2" />
|
||||
<option name="SOFT_WRAPS_IN_SHORT_DIFF" value="true" />
|
||||
<option name="INCLUDE_TEXT_INTO_PATCH" value="false" />
|
||||
<option name="INCLUDE_TEXT_INTO_SHELF" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_DETAILS" value="true" />
|
||||
<option name="SHOW_VCS_ERROR_NOTIFICATIONS" value="true" />
|
||||
<option name="SHOW_DIRTY_RECURSIVELY" value="false" />
|
||||
<option name="LIMIT_HISTORY" value="true" />
|
||||
<option name="MAXIMUM_HISTORY_ROWS" value="1000" />
|
||||
<option name="UPDATE_FILTER_SCOPE_NAME" />
|
||||
<option name="USE_COMMIT_MESSAGE_MARGIN" value="false" />
|
||||
<option name="COMMIT_MESSAGE_MARGIN_SIZE" value="72" />
|
||||
<option name="WRAP_WHEN_TYPING_REACHES_RIGHT_MARGIN" value="false" />
|
||||
<option name="FORCE_NON_EMPTY_COMMENT" value="false" />
|
||||
<option name="CLEAR_INITIAL_COMMIT_MESSAGE" value="false" />
|
||||
<option name="LAST_COMMIT_MESSAGE" />
|
||||
<option name="MAKE_NEW_CHANGELIST_ACTIVE" value="false" />
|
||||
<option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
|
||||
<option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
|
||||
<option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
|
||||
<option name="ACTIVE_VCS_NAME" />
|
||||
<option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
|
||||
<option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
|
||||
<option name="UPDATE_FILTER_BY_SCOPE" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
|
||||
<option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
|
||||
</component>
|
||||
<component name="XDebuggerManager">
|
||||
<breakpoint-manager />
|
||||
</component>
|
||||
<component name="antWorkspaceConfiguration">
|
||||
<option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
|
||||
<option name="FILTER_TARGETS" value="false" />
|
||||
</component>
|
||||
<component name="editorHistoryManager">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/GccMapReader.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="56" column="17" selection-start="1616" selection-end="1616" vertical-scroll-proportion="1.0455374">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
<element signature="e#578#586#0" expanded="true" />
|
||||
<element signature="e#1431#1439#0" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,28 +1,28 @@
|
|||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../gcc_map_reader.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="rusefi.GccMapReader"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
<target name="run" depends="jar">
|
||||
<java jar="../java_console_binary/rusefi_console.jar" fork="true"/>
|
||||
</target>
|
||||
|
||||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../gcc_map_reader.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="rusefi.GccMapReader"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
<target name="run" depends="jar">
|
||||
<java jar="../java_console_binary/rusefi_console.jar" fork="true"/>
|
||||
</target>
|
||||
|
||||
</project>
|
|
@ -1,12 +1,12 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
|
|
|
@ -1,135 +1,160 @@
|
|||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.Comparator;
|
||||
import java.util.List;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
/**
|
||||
* This is an utility to print the information from GCC linked .map file
|
||||
*
|
||||
* @author Andrey Belomutskiy
|
||||
* 10/16/13
|
||||
*/
|
||||
public class GccMapReader {
|
||||
public static void main(String[] args) throws IOException {
|
||||
BufferedReader fr = new BufferedReader(new FileReader("rusefi.map"));
|
||||
|
||||
String line;
|
||||
List<String> lines = new ArrayList<String>();
|
||||
|
||||
while ((line = fr.readLine()) != null)
|
||||
lines.add(line);
|
||||
|
||||
debug("Got " + lines.size() + " lines");
|
||||
|
||||
List<Record> records = process(lines);
|
||||
|
||||
Collections.sort(records, new Comparator<Record>() {
|
||||
@Override
|
||||
public int compare(Record o1, Record o2) {
|
||||
return o2.compareTo(o1);
|
||||
}
|
||||
});
|
||||
|
||||
int totalSize = 0;
|
||||
for (Record record : records) {
|
||||
System.out.println(record);
|
||||
totalSize += record.size;
|
||||
}
|
||||
|
||||
System.out.println("Total size: " + totalSize);
|
||||
}
|
||||
|
||||
private static List<Record> process(List<String> lines) {
|
||||
Pattern p1 = Pattern.compile(".*\\.bss\\.(\\S*).*0x.*0x(\\S*)(.*)");
|
||||
|
||||
Pattern p2 = Pattern.compile(".*0x(\\S*)(.*)");
|
||||
|
||||
List<Record> result = new ArrayList<Record>();
|
||||
for (int i = 0; i < lines.size(); i++) {
|
||||
String line = lines.get(i);
|
||||
if (!line.contains(".bss."))
|
||||
continue;
|
||||
debug(line);
|
||||
|
||||
Matcher m1 = p1.matcher(line);
|
||||
|
||||
if (m1.matches()) {
|
||||
debug("Single-line " + line);
|
||||
|
||||
String suffix = m1.group(1);
|
||||
String sizeString = m1.group(2);
|
||||
String prefix = m1.group(3);
|
||||
|
||||
String name = prefix + "@" + suffix;
|
||||
|
||||
int size = Integer.parseInt(sizeString, 16);
|
||||
|
||||
debug("Name " + name);
|
||||
debug("size " + size);
|
||||
|
||||
result.add(new Record(size, name));
|
||||
} else {
|
||||
debug("Multi-line " + line);
|
||||
String suffix = line;
|
||||
line = lines.get(++i);
|
||||
|
||||
Matcher m2 = p2.matcher(line);
|
||||
|
||||
if (!m2.matches()) {
|
||||
debug("Skipping " + line);
|
||||
continue;
|
||||
}
|
||||
|
||||
String sizeString = m2.group(1);
|
||||
String prefix = m2.group(2);
|
||||
|
||||
debug("Next line " + line);
|
||||
|
||||
String name = prefix + "@" + suffix;
|
||||
|
||||
int size = Integer.parseInt(sizeString, 16);
|
||||
|
||||
debug("Name " + name);
|
||||
debug("size " + size);
|
||||
|
||||
result.add(new Record(size, name));
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void debug(String s) {
|
||||
// System.out.println(s);
|
||||
}
|
||||
|
||||
static class Record implements Comparable<Record> {
|
||||
private final int size;
|
||||
private final String name;
|
||||
|
||||
public Record(int size, String name) {
|
||||
this.size = size;
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int compareTo(Record o) {
|
||||
int d = size - o.size;
|
||||
if (d != 0)
|
||||
return d;
|
||||
return name.compareTo(o.name);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Record{" +
|
||||
"size=" + size +
|
||||
", name='" + name + '\'' +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
}
|
||||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.Comparator;
|
||||
import java.util.List;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
/**
|
||||
* This is an utility to print the information from GCC linked .map file
|
||||
*
|
||||
* @author Andrey Belomutskiy
|
||||
* 10/16/13
|
||||
*/
|
||||
public class GccMapReader {
|
||||
private static final Pattern p2 = Pattern.compile(".*0x(\\S*)(.*)");
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
BufferedReader fr = new BufferedReader(new FileReader("rusefi.map"));
|
||||
|
||||
String line;
|
||||
List<String> lines = new ArrayList<String>();
|
||||
|
||||
while ((line = fr.readLine()) != null)
|
||||
lines.add(line);
|
||||
|
||||
debug("Got " + lines.size() + " lines");
|
||||
|
||||
List<Record> records = process(lines);
|
||||
|
||||
Collections.sort(records, new Comparator<Record>() {
|
||||
@Override
|
||||
public int compare(Record o1, Record o2) {
|
||||
return o2.compareTo(o1);
|
||||
}
|
||||
});
|
||||
|
||||
int totalSize = 0;
|
||||
for (Record record : records) {
|
||||
System.out.println(record);
|
||||
totalSize += record.size;
|
||||
}
|
||||
|
||||
System.out.println("Total size: " + totalSize);
|
||||
}
|
||||
|
||||
private static List<Record> process(List<String> lines) {
|
||||
Pattern p1 = Pattern.compile(".*\\.bss\\.(\\S*).*0x.*0x(\\S*)(.*)");
|
||||
|
||||
|
||||
List<Record> result = new ArrayList<Record>();
|
||||
for (int i = 0; i < lines.size(); i++) {
|
||||
String line = lines.get(i);
|
||||
if (!line.contains(".bss."))
|
||||
continue;
|
||||
debug(line);
|
||||
|
||||
Matcher m1 = p1.matcher(line);
|
||||
|
||||
if (m1.matches()) {
|
||||
parseSingleLine(result, line, m1, i);
|
||||
} else {
|
||||
i = parseMultiLine(lines, result, i, line);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
private static int parseMultiLine(List<String> lines, List<Record> result, int lineIndex, String line) {
|
||||
debug("Multi-line " + line);
|
||||
String suffix = line;
|
||||
line = lines.get(++lineIndex);
|
||||
|
||||
Matcher m2 = p2.matcher(line);
|
||||
|
||||
if (!m2.matches()) {
|
||||
debug("Skipping " + line);
|
||||
return lineIndex;
|
||||
}
|
||||
|
||||
String sizeString = m2.group(1);
|
||||
String prefix = m2.group(2);
|
||||
|
||||
debug("Next line " + line);
|
||||
|
||||
String name = prefix + "@" + suffix;
|
||||
|
||||
if (line.contains("ALIGN")) {
|
||||
System.out.println("TODO: better handle " + line);
|
||||
return lineIndex;
|
||||
}
|
||||
|
||||
int size;
|
||||
try {
|
||||
size = Integer.parseInt(sizeString, 16);
|
||||
} catch (NumberFormatException e) {
|
||||
throw new IllegalStateException("While parsing @ " + lineIndex);
|
||||
}
|
||||
|
||||
debug("Name " + name);
|
||||
debug("size " + size);
|
||||
|
||||
result.add(new Record(size, name));
|
||||
return lineIndex;
|
||||
}
|
||||
|
||||
private static void parseSingleLine(List<Record> result, String line, Matcher m1, int lineIndex) {
|
||||
debug("Single-line " + line);
|
||||
|
||||
String suffix = m1.group(1);
|
||||
String sizeString = m1.group(2);
|
||||
String prefix = m1.group(3);
|
||||
|
||||
String name = prefix + "@" + suffix;
|
||||
|
||||
int size;
|
||||
try {
|
||||
size = Integer.parseInt(sizeString, 16);
|
||||
} catch (NumberFormatException e) {
|
||||
throw new IllegalStateException("While parsing @ " + lineIndex);
|
||||
}
|
||||
|
||||
debug("Name " + name);
|
||||
debug("size " + size);
|
||||
|
||||
result.add(new Record(size, name));
|
||||
}
|
||||
|
||||
private static void debug(String s) {
|
||||
// System.out.println(s);
|
||||
}
|
||||
|
||||
static class Record implements Comparable<Record> {
|
||||
private final int size;
|
||||
private final String name;
|
||||
|
||||
public Record(int size, String name) {
|
||||
this.size = size;
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int compareTo(Record o) {
|
||||
int d = size - o.size;
|
||||
if (d != 0)
|
||||
return d;
|
||||
return name.compareTo(o.name);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Record{" +
|
||||
"size=" + size +
|
||||
", name='" + name + '\'' +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,23 +1,23 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
</component>
|
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/net_list_merge.iml" filepath="$PROJECT_DIR$/net_list_merge.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/net_list_merge.iml" filepath="$PROJECT_DIR$/net_list_merge.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
</component>
|
|
@ -1,125 +1,125 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,494 +1,494 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" readonly="true" id="4d0f1321-4620-4101-a21a-49927b2a9419" name="Default" comment="">
|
||||
<change type="NEW" beforePath="" afterPath="$PROJECT_DIR$/src/rusefi/NetListMergeUtil.java" />
|
||||
<change type="MODIFICATION" beforePath="$PROJECT_DIR$" afterPath="$PROJECT_DIR$" />
|
||||
<change type="MODIFICATION" beforePath="$PROJECT_DIR$/src/rusefi/NetListMerge.java" afterPath="$PROJECT_DIR$/src/rusefi/NetListMerge.java" />
|
||||
<change type="MODIFICATION" beforePath="$PROJECT_DIR$/.idea/workspace.xml" afterPath="$PROJECT_DIR$/.idea/workspace.xml" />
|
||||
</list>
|
||||
<ignored path="net_list_merge.iws" />
|
||||
<ignored path=".idea/workspace.xml" />
|
||||
<file path="/NetListMerge.java" changelist="4d0f1321-4620-4101-a21a-49927b2a9419" time="1386563096595" ignored="false" />
|
||||
<file path="/fragment.java" changelist="4d0f1321-4620-4101-a21a-49927b2a9419" time="1386562535344" ignored="false" />
|
||||
<option name="TRACKING_ENABLED" value="true" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
|
||||
<component name="CreatePatchCommitExecutor">
|
||||
<option name="PATCH_PATH" value="" />
|
||||
</component>
|
||||
<component name="DaemonCodeAnalyzer">
|
||||
<disable_hints />
|
||||
</component>
|
||||
<component name="DebuggerManager">
|
||||
<breakpoint_any default_suspend_policy="SuspendAll" default_condition_enabled="true">
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
</breakpoint_any>
|
||||
<ui_properties default_suspend_policy="SuspendAll" default_condition_enabled="true" />
|
||||
<breakpoint_rules />
|
||||
<ui_properties />
|
||||
</component>
|
||||
<component name="ExecutionTargetManager" SELECTED_TARGET="default_target" />
|
||||
<component name="FavoritesManager">
|
||||
<favorites_list name="net_list_merge" />
|
||||
</component>
|
||||
<component name="FileEditorManager">
|
||||
<leaf>
|
||||
<file leaf-file-name="NetListMerge.java" pinned="false" current="true" current-in-tab="true">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="50" column="79" selection-start="2052" selection-end="2052" vertical-scroll-proportion="0.52737224">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
<file leaf-file-name="NetListMergeUtil.java" pinned="false" current="false" current-in-tab="false">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMergeUtil.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="36" column="23" selection-start="1045" selection-end="1045" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
<file leaf-file-name="Pattern.java" pinned="false" current="false" current-in-tab="false">
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Pattern.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="4169" column="0" selection-start="152719" selection-end="152719" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
<file leaf-file-name="Matcher.java" pinned="false" current="false" current-in-tab="false">
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Matcher.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="576" column="19" selection-start="20769" selection-end="20769" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
</leaf>
|
||||
</component>
|
||||
<component name="FindManager">
|
||||
<FindUsagesManager>
|
||||
<setting name="OPEN_NEW_TAB" value="false" />
|
||||
</FindUsagesManager>
|
||||
</component>
|
||||
<component name="IdeDocumentHistory">
|
||||
<option name="changedFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/src/rusefi/NetListMerge.java" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectFrameBounds">
|
||||
<option name="x" value="-9" />
|
||||
<option name="y" value="-9" />
|
||||
<option name="width" value="1698" />
|
||||
<option name="height" value="1020" />
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectReloadState">
|
||||
<option name="STATE" value="0" />
|
||||
</component>
|
||||
<component name="ProjectView">
|
||||
<navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
|
||||
<flattenPackages />
|
||||
<showMembers />
|
||||
<showModules />
|
||||
<showLibraryContents />
|
||||
<hideEmptyPackages />
|
||||
<abbreviatePackageNames />
|
||||
<autoscrollToSource />
|
||||
<autoscrollFromSource />
|
||||
<sortByType />
|
||||
</navigator>
|
||||
<panes>
|
||||
<pane id="Scope" />
|
||||
<pane id="ProjectPane">
|
||||
<subPane>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="src" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="rusefi" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
</subPane>
|
||||
</pane>
|
||||
<pane id="PackagesPane" />
|
||||
</panes>
|
||||
</component>
|
||||
<component name="PropertiesComponent">
|
||||
<property name="GoToFile.includeJavaFiles" value="false" />
|
||||
<property name="GoToClass.toSaveIncludeLibraries" value="false" />
|
||||
<property name="recentsLimit" value="5" />
|
||||
<property name="MemberChooser.sorted" value="false" />
|
||||
<property name="restartRequiresConfirmation" value="true" />
|
||||
<property name="MemberChooser.showClasses" value="true" />
|
||||
<property name="GoToClass.includeLibraries" value="false" />
|
||||
<property name="dynamic.classpath" value="false" />
|
||||
<property name="MemberChooser.copyJavadoc" value="false" />
|
||||
</component>
|
||||
<component name="RecentsManager">
|
||||
<key name="MoveMembersDialog.RECENTS_KEY">
|
||||
<recent name="rusefi.NetListMergeUtil" />
|
||||
</key>
|
||||
</component>
|
||||
<component name="RunManager" selected="Application.NetListMerge">
|
||||
<configuration default="false" name="NetListMerge" type="Application" factoryName="Application" temporary="true">
|
||||
<option name="MAIN_CLASS_NAME" value="rusefi.NetListMerge" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="dest.net s.net" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="net_list_merge" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Profile ">
|
||||
<option name="myExternalizedOptions" value=" additional-options2=onexit\=snapshot " />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="#org.jetbrains.idea.devkit.run.PluginConfigurationType" factoryName="Plugin">
|
||||
<module name="" />
|
||||
<option name="VM_PARAMETERS" value="-Xmx512m -Xms256m -XX:MaxPermSize=250m" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Remote" factoryName="Remote">
|
||||
<option name="USE_SOCKET_TRANSPORT" value="true" />
|
||||
<option name="SERVER_MODE" value="false" />
|
||||
<option name="SHMEM_ADDRESS" value="javadebug" />
|
||||
<option name="HOST" value="localhost" />
|
||||
<option name="PORT" value="5005" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Applet" factoryName="Applet">
|
||||
<module name="" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="HTML_FILE_NAME" />
|
||||
<option name="HTML_USED" value="false" />
|
||||
<option name="WIDTH" value="400" />
|
||||
<option name="HEIGHT" value="300" />
|
||||
<option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="TestNG" factoryName="TestNG">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="SUITE_NAME" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="GROUP_NAME" />
|
||||
<option name="TEST_OBJECT" value="CLASS" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="OUTPUT_DIRECTORY" />
|
||||
<option name="ANNOTATION_TYPE" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<option name="USE_DEFAULT_REPORTERS" value="false" />
|
||||
<option name="PROPERTIES_FILE" />
|
||||
<envs />
|
||||
<properties />
|
||||
<listeners />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="" />
|
||||
<envs />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="JUnit" factoryName="JUnit">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="TEST_OBJECT" value="class" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<envs />
|
||||
<patterns />
|
||||
<method />
|
||||
</configuration>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.NetListMerge" />
|
||||
</list>
|
||||
<recent_temporary>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.NetListMerge" />
|
||||
</list>
|
||||
</recent_temporary>
|
||||
<configuration name="<template>" type="WebApp" default="true" selected="false">
|
||||
<Host>localhost</Host>
|
||||
<Port>5050</Port>
|
||||
</configuration>
|
||||
</component>
|
||||
<component name="ShelveChangesManager" show_recycled="false" />
|
||||
<component name="SvnConfiguration" maxAnnotateRevisions="500" myUseAcceleration="nothing" myAutoUpdateAfterCommit="false" cleanupOnStartRun="true" SSL_PROTOCOLS="all">
|
||||
<option name="USER" value="" />
|
||||
<option name="PASSWORD" value="" />
|
||||
<option name="mySSHConnectionTimeout" value="30000" />
|
||||
<option name="mySSHReadTimeout" value="30000" />
|
||||
<option name="LAST_MERGED_REVISION" />
|
||||
<option name="MERGE_DRY_RUN" value="false" />
|
||||
<option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
|
||||
<option name="UPDATE_LOCK_ON_DEMAND" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_MERGE" value="false" />
|
||||
<option name="CHECK_NESTED_FOR_QUICK_MERGE" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
|
||||
<option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
|
||||
<option name="FORCE_UPDATE" value="false" />
|
||||
<option name="IGNORE_EXTERNALS" value="false" />
|
||||
<configuration useDefault="false">C:\Users\pc\AppData\Roaming\Subversion</configuration>
|
||||
<myIsUseDefaultProxy>false</myIsUseDefaultProxy>
|
||||
<supportedVersion>125</supportedVersion>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="4d0f1321-4620-4101-a21a-49927b2a9419" name="Default" comment="" />
|
||||
<created>1386559155621</created>
|
||||
<updated>1386559155621</updated>
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="ToolWindowManager">
|
||||
<frame x="-9" y="-9" width="1698" height="1020" extended-state="6" />
|
||||
<editor active="true" />
|
||||
<layout>
|
||||
<window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="JetGradle" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.32943925" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3995327" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.32943925" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.249694" sideWeight="0.6705608" order="0" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Run" active="true" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.32943925" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
|
||||
</layout>
|
||||
</component>
|
||||
<component name="VcsContentAnnotationSettings">
|
||||
<option name="myLimit" value="2678400000" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
|
||||
<option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
|
||||
<option name="CHECK_NEW_TODO" value="true" />
|
||||
<option name="myTodoPanelSettings">
|
||||
<value>
|
||||
<are-packages-shown value="false" />
|
||||
<are-modules-shown value="false" />
|
||||
<flatten-packages value="false" />
|
||||
<is-autoscroll-to-source value="false" />
|
||||
</value>
|
||||
</option>
|
||||
<option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
|
||||
<option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="false" />
|
||||
<option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
|
||||
<option name="SHOW_ONLY_CHANGED_IN_SELECTION_DIFF" value="true" />
|
||||
<option name="CHECK_COMMIT_MESSAGE_SPELLING" value="true" />
|
||||
<option name="DEFAULT_PATCH_EXTENSION" value="patch" />
|
||||
<option name="SHORT_DIFF_HORIZONTALLY" value="true" />
|
||||
<option name="SHORT_DIFF_EXTRA_LINES" value="2" />
|
||||
<option name="SOFT_WRAPS_IN_SHORT_DIFF" value="true" />
|
||||
<option name="INCLUDE_TEXT_INTO_PATCH" value="false" />
|
||||
<option name="INCLUDE_TEXT_INTO_SHELF" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_DETAILS" value="true" />
|
||||
<option name="SHOW_VCS_ERROR_NOTIFICATIONS" value="true" />
|
||||
<option name="SHOW_DIRTY_RECURSIVELY" value="false" />
|
||||
<option name="LIMIT_HISTORY" value="true" />
|
||||
<option name="MAXIMUM_HISTORY_ROWS" value="1000" />
|
||||
<option name="UPDATE_FILTER_SCOPE_NAME" />
|
||||
<option name="USE_COMMIT_MESSAGE_MARGIN" value="false" />
|
||||
<option name="COMMIT_MESSAGE_MARGIN_SIZE" value="72" />
|
||||
<option name="WRAP_WHEN_TYPING_REACHES_RIGHT_MARGIN" value="false" />
|
||||
<option name="FORCE_NON_EMPTY_COMMENT" value="false" />
|
||||
<option name="CLEAR_INITIAL_COMMIT_MESSAGE" value="false" />
|
||||
<option name="LAST_COMMIT_MESSAGE" />
|
||||
<option name="MAKE_NEW_CHANGELIST_ACTIVE" value="false" />
|
||||
<option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
|
||||
<option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
|
||||
<option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
|
||||
<option name="ACTIVE_VCS_NAME" />
|
||||
<option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
|
||||
<option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
|
||||
<option name="UPDATE_FILTER_BY_SCOPE" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
|
||||
<option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
|
||||
</component>
|
||||
<component name="XDebuggerManager">
|
||||
<breakpoint-manager />
|
||||
</component>
|
||||
<component name="antWorkspaceConfiguration">
|
||||
<option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
|
||||
<option name="FILTER_TARGETS" value="false" />
|
||||
</component>
|
||||
<component name="editorHistoryManager">
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Matcher.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="576" column="19" selection-start="20769" selection-end="20769" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Pattern.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="4169" column="0" selection-start="152719" selection-end="152719" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMergeUtil.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="36" column="23" selection-start="1045" selection-end="1045" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="50" column="79" selection-start="2052" selection-end="2052" vertical-scroll-proportion="0.52737224">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" readonly="true" id="4d0f1321-4620-4101-a21a-49927b2a9419" name="Default" comment="">
|
||||
<change type="NEW" beforePath="" afterPath="$PROJECT_DIR$/src/rusefi/NetListMergeUtil.java" />
|
||||
<change type="MODIFICATION" beforePath="$PROJECT_DIR$" afterPath="$PROJECT_DIR$" />
|
||||
<change type="MODIFICATION" beforePath="$PROJECT_DIR$/src/rusefi/NetListMerge.java" afterPath="$PROJECT_DIR$/src/rusefi/NetListMerge.java" />
|
||||
<change type="MODIFICATION" beforePath="$PROJECT_DIR$/.idea/workspace.xml" afterPath="$PROJECT_DIR$/.idea/workspace.xml" />
|
||||
</list>
|
||||
<ignored path="net_list_merge.iws" />
|
||||
<ignored path=".idea/workspace.xml" />
|
||||
<file path="/NetListMerge.java" changelist="4d0f1321-4620-4101-a21a-49927b2a9419" time="1386563096595" ignored="false" />
|
||||
<file path="/fragment.java" changelist="4d0f1321-4620-4101-a21a-49927b2a9419" time="1386562535344" ignored="false" />
|
||||
<option name="TRACKING_ENABLED" value="true" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
|
||||
<component name="CreatePatchCommitExecutor">
|
||||
<option name="PATCH_PATH" value="" />
|
||||
</component>
|
||||
<component name="DaemonCodeAnalyzer">
|
||||
<disable_hints />
|
||||
</component>
|
||||
<component name="DebuggerManager">
|
||||
<breakpoint_any default_suspend_policy="SuspendAll" default_condition_enabled="true">
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
<breakpoint>
|
||||
<option name="NOTIFY_CAUGHT" value="true" />
|
||||
<option name="NOTIFY_UNCAUGHT" value="true" />
|
||||
<option name="ENABLED" value="false" />
|
||||
<option name="LOG_ENABLED" value="false" />
|
||||
<option name="LOG_EXPRESSION_ENABLED" value="false" />
|
||||
<option name="REMOVE_AFTER_HIT" value="false" />
|
||||
<option name="SUSPEND_POLICY" value="SuspendAll" />
|
||||
<option name="SUSPEND" value="true" />
|
||||
<option name="COUNT_FILTER_ENABLED" value="false" />
|
||||
<option name="COUNT_FILTER" value="0" />
|
||||
<option name="CONDITION_ENABLED" value="true" />
|
||||
<option name="CLASS_FILTERS_ENABLED" value="false" />
|
||||
<option name="INSTANCE_FILTERS_ENABLED" value="false" />
|
||||
<option name="CONDITION" value="" />
|
||||
<option name="LOG_MESSAGE" value="" />
|
||||
</breakpoint>
|
||||
</breakpoint_any>
|
||||
<ui_properties default_suspend_policy="SuspendAll" default_condition_enabled="true" />
|
||||
<breakpoint_rules />
|
||||
<ui_properties />
|
||||
</component>
|
||||
<component name="ExecutionTargetManager" SELECTED_TARGET="default_target" />
|
||||
<component name="FavoritesManager">
|
||||
<favorites_list name="net_list_merge" />
|
||||
</component>
|
||||
<component name="FileEditorManager">
|
||||
<leaf>
|
||||
<file leaf-file-name="NetListMerge.java" pinned="false" current="true" current-in-tab="true">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="50" column="79" selection-start="2052" selection-end="2052" vertical-scroll-proportion="0.52737224">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
<file leaf-file-name="NetListMergeUtil.java" pinned="false" current="false" current-in-tab="false">
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMergeUtil.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="36" column="23" selection-start="1045" selection-end="1045" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
<file leaf-file-name="Pattern.java" pinned="false" current="false" current-in-tab="false">
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Pattern.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="4169" column="0" selection-start="152719" selection-end="152719" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
<file leaf-file-name="Matcher.java" pinned="false" current="false" current-in-tab="false">
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Matcher.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="576" column="19" selection-start="20769" selection-end="20769" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</file>
|
||||
</leaf>
|
||||
</component>
|
||||
<component name="FindManager">
|
||||
<FindUsagesManager>
|
||||
<setting name="OPEN_NEW_TAB" value="false" />
|
||||
</FindUsagesManager>
|
||||
</component>
|
||||
<component name="IdeDocumentHistory">
|
||||
<option name="changedFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/src/rusefi/NetListMerge.java" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectFrameBounds">
|
||||
<option name="x" value="-9" />
|
||||
<option name="y" value="-9" />
|
||||
<option name="width" value="1698" />
|
||||
<option name="height" value="1020" />
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectReloadState">
|
||||
<option name="STATE" value="0" />
|
||||
</component>
|
||||
<component name="ProjectView">
|
||||
<navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
|
||||
<flattenPackages />
|
||||
<showMembers />
|
||||
<showModules />
|
||||
<showLibraryContents />
|
||||
<hideEmptyPackages />
|
||||
<abbreviatePackageNames />
|
||||
<autoscrollToSource />
|
||||
<autoscrollFromSource />
|
||||
<sortByType />
|
||||
</navigator>
|
||||
<panes>
|
||||
<pane id="Scope" />
|
||||
<pane id="ProjectPane">
|
||||
<subPane>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
<PATH>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="net_list_merge" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="src" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
<PATH_ELEMENT>
|
||||
<option name="myItemId" value="rusefi" />
|
||||
<option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
|
||||
</PATH_ELEMENT>
|
||||
</PATH>
|
||||
</subPane>
|
||||
</pane>
|
||||
<pane id="PackagesPane" />
|
||||
</panes>
|
||||
</component>
|
||||
<component name="PropertiesComponent">
|
||||
<property name="GoToFile.includeJavaFiles" value="false" />
|
||||
<property name="GoToClass.toSaveIncludeLibraries" value="false" />
|
||||
<property name="recentsLimit" value="5" />
|
||||
<property name="MemberChooser.sorted" value="false" />
|
||||
<property name="restartRequiresConfirmation" value="true" />
|
||||
<property name="MemberChooser.showClasses" value="true" />
|
||||
<property name="GoToClass.includeLibraries" value="false" />
|
||||
<property name="dynamic.classpath" value="false" />
|
||||
<property name="MemberChooser.copyJavadoc" value="false" />
|
||||
</component>
|
||||
<component name="RecentsManager">
|
||||
<key name="MoveMembersDialog.RECENTS_KEY">
|
||||
<recent name="rusefi.NetListMergeUtil" />
|
||||
</key>
|
||||
</component>
|
||||
<component name="RunManager" selected="Application.NetListMerge">
|
||||
<configuration default="false" name="NetListMerge" type="Application" factoryName="Application" temporary="true">
|
||||
<option name="MAIN_CLASS_NAME" value="rusefi.NetListMerge" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="dest.net s.net" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="net_list_merge" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Profile ">
|
||||
<option name="myExternalizedOptions" value=" additional-options2=onexit\=snapshot " />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="#org.jetbrains.idea.devkit.run.PluginConfigurationType" factoryName="Plugin">
|
||||
<module name="" />
|
||||
<option name="VM_PARAMETERS" value="-Xmx512m -Xms256m -XX:MaxPermSize=250m" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Remote" factoryName="Remote">
|
||||
<option name="USE_SOCKET_TRANSPORT" value="true" />
|
||||
<option name="SERVER_MODE" value="false" />
|
||||
<option name="SHMEM_ADDRESS" value="javadebug" />
|
||||
<option name="HOST" value="localhost" />
|
||||
<option name="PORT" value="5005" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Applet" factoryName="Applet">
|
||||
<module name="" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="HTML_FILE_NAME" />
|
||||
<option name="HTML_USED" value="false" />
|
||||
<option name="WIDTH" value="400" />
|
||||
<option name="HEIGHT" value="300" />
|
||||
<option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="TestNG" factoryName="TestNG">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="SUITE_NAME" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="GROUP_NAME" />
|
||||
<option name="TEST_OBJECT" value="CLASS" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="OUTPUT_DIRECTORY" />
|
||||
<option name="ANNOTATION_TYPE" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<option name="USE_DEFAULT_REPORTERS" value="false" />
|
||||
<option name="PROPERTIES_FILE" />
|
||||
<envs />
|
||||
<properties />
|
||||
<listeners />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="VM_PARAMETERS" />
|
||||
<option name="PROGRAM_PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="" />
|
||||
<envs />
|
||||
<method />
|
||||
</configuration>
|
||||
<configuration default="true" type="JUnit" factoryName="JUnit">
|
||||
<module name="" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" />
|
||||
<option name="PACKAGE_NAME" />
|
||||
<option name="MAIN_CLASS_NAME" />
|
||||
<option name="METHOD_NAME" />
|
||||
<option name="TEST_OBJECT" value="class" />
|
||||
<option name="VM_PARAMETERS" value="-ea" />
|
||||
<option name="PARAMETERS" />
|
||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<option name="TEST_SEARCH_SCOPE">
|
||||
<value defaultName="moduleWithDependencies" />
|
||||
</option>
|
||||
<envs />
|
||||
<patterns />
|
||||
<method />
|
||||
</configuration>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.NetListMerge" />
|
||||
</list>
|
||||
<recent_temporary>
|
||||
<list size="1">
|
||||
<item index="0" class="java.lang.String" itemvalue="Application.NetListMerge" />
|
||||
</list>
|
||||
</recent_temporary>
|
||||
<configuration name="<template>" type="WebApp" default="true" selected="false">
|
||||
<Host>localhost</Host>
|
||||
<Port>5050</Port>
|
||||
</configuration>
|
||||
</component>
|
||||
<component name="ShelveChangesManager" show_recycled="false" />
|
||||
<component name="SvnConfiguration" maxAnnotateRevisions="500" myUseAcceleration="nothing" myAutoUpdateAfterCommit="false" cleanupOnStartRun="true" SSL_PROTOCOLS="all">
|
||||
<option name="USER" value="" />
|
||||
<option name="PASSWORD" value="" />
|
||||
<option name="mySSHConnectionTimeout" value="30000" />
|
||||
<option name="mySSHReadTimeout" value="30000" />
|
||||
<option name="LAST_MERGED_REVISION" />
|
||||
<option name="MERGE_DRY_RUN" value="false" />
|
||||
<option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
|
||||
<option name="UPDATE_LOCK_ON_DEMAND" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_MERGE" value="false" />
|
||||
<option name="CHECK_NESTED_FOR_QUICK_MERGE" value="false" />
|
||||
<option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
|
||||
<option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
|
||||
<option name="FORCE_UPDATE" value="false" />
|
||||
<option name="IGNORE_EXTERNALS" value="false" />
|
||||
<configuration useDefault="false">C:\Users\pc\AppData\Roaming\Subversion</configuration>
|
||||
<myIsUseDefaultProxy>false</myIsUseDefaultProxy>
|
||||
<supportedVersion>125</supportedVersion>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="4d0f1321-4620-4101-a21a-49927b2a9419" name="Default" comment="" />
|
||||
<created>1386559155621</created>
|
||||
<updated>1386559155621</updated>
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="ToolWindowManager">
|
||||
<frame x="-9" y="-9" width="1698" height="1020" extended-state="6" />
|
||||
<editor active="true" />
|
||||
<layout>
|
||||
<window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="JetGradle" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.32943925" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3995327" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
|
||||
<window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.32943925" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.249694" sideWeight="0.6705608" order="0" side_tool="false" content_ui="combo" />
|
||||
<window_info id="Run" active="true" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.32943925" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
|
||||
<window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
|
||||
</layout>
|
||||
</component>
|
||||
<component name="VcsContentAnnotationSettings">
|
||||
<option name="myLimit" value="2678400000" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
|
||||
<option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
|
||||
<option name="CHECK_NEW_TODO" value="true" />
|
||||
<option name="myTodoPanelSettings">
|
||||
<value>
|
||||
<are-packages-shown value="false" />
|
||||
<are-modules-shown value="false" />
|
||||
<flatten-packages value="false" />
|
||||
<is-autoscroll-to-source value="false" />
|
||||
</value>
|
||||
</option>
|
||||
<option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
|
||||
<option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
|
||||
<option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="false" />
|
||||
<option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
|
||||
<option name="SHOW_ONLY_CHANGED_IN_SELECTION_DIFF" value="true" />
|
||||
<option name="CHECK_COMMIT_MESSAGE_SPELLING" value="true" />
|
||||
<option name="DEFAULT_PATCH_EXTENSION" value="patch" />
|
||||
<option name="SHORT_DIFF_HORIZONTALLY" value="true" />
|
||||
<option name="SHORT_DIFF_EXTRA_LINES" value="2" />
|
||||
<option name="SOFT_WRAPS_IN_SHORT_DIFF" value="true" />
|
||||
<option name="INCLUDE_TEXT_INTO_PATCH" value="false" />
|
||||
<option name="INCLUDE_TEXT_INTO_SHELF" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_DETAILS" value="true" />
|
||||
<option name="SHOW_VCS_ERROR_NOTIFICATIONS" value="true" />
|
||||
<option name="SHOW_DIRTY_RECURSIVELY" value="false" />
|
||||
<option name="LIMIT_HISTORY" value="true" />
|
||||
<option name="MAXIMUM_HISTORY_ROWS" value="1000" />
|
||||
<option name="UPDATE_FILTER_SCOPE_NAME" />
|
||||
<option name="USE_COMMIT_MESSAGE_MARGIN" value="false" />
|
||||
<option name="COMMIT_MESSAGE_MARGIN_SIZE" value="72" />
|
||||
<option name="WRAP_WHEN_TYPING_REACHES_RIGHT_MARGIN" value="false" />
|
||||
<option name="FORCE_NON_EMPTY_COMMENT" value="false" />
|
||||
<option name="CLEAR_INITIAL_COMMIT_MESSAGE" value="false" />
|
||||
<option name="LAST_COMMIT_MESSAGE" />
|
||||
<option name="MAKE_NEW_CHANGELIST_ACTIVE" value="false" />
|
||||
<option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
|
||||
<option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
|
||||
<option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
|
||||
<option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
|
||||
<option name="ACTIVE_VCS_NAME" />
|
||||
<option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
|
||||
<option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
|
||||
<option name="UPDATE_FILTER_BY_SCOPE" value="false" />
|
||||
<option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
|
||||
<option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
|
||||
</component>
|
||||
<component name="XDebuggerManager">
|
||||
<breakpoint-manager />
|
||||
</component>
|
||||
<component name="antWorkspaceConfiguration">
|
||||
<option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
|
||||
<option name="FILTER_TARGETS" value="false" />
|
||||
</component>
|
||||
<component name="editorHistoryManager">
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Matcher.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="576" column="19" selection-start="20769" selection-end="20769" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="jar://C:/Program Files/Java/jdk1.7.0_45/src.zip!/java/util/regex/Pattern.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="4169" column="0" selection-start="152719" selection-end="152719" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMergeUtil.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="36" column="23" selection-start="1045" selection-end="1045" vertical-scroll-proportion="0.0">
|
||||
<folding />
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
<entry file="file://$PROJECT_DIR$/src/rusefi/NetListMerge.java">
|
||||
<provider selected="true" editor-type-id="text-editor">
|
||||
<state line="50" column="79" selection-start="2052" selection-end="2052" vertical-scroll-proportion="0.52737224">
|
||||
<folding>
|
||||
<element signature="imports" expanded="true" />
|
||||
</folding>
|
||||
</state>
|
||||
</provider>
|
||||
</entry>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,24 +1,24 @@
|
|||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../net_list_merge.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="rusefi.NetListMerge"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../net_list_merge.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="rusefi.NetListMerge"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
</project>
|
|
@ -1,12 +1,12 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
|
|
|
@ -1,123 +1,123 @@
|
|||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import static rusefi.NetListMergeUtil.validateSection;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class NetListMerge {
|
||||
private static final Pattern GET_HEADER = Pattern.compile("(.*)\\(components(.*)\\s*$", Pattern.DOTALL);
|
||||
|
||||
private static final Pattern GET_COMPONENTS = Pattern.compile("(.*)\\)\\s*\\(libparts(.*)\\)\\)\\s*$", Pattern.DOTALL);
|
||||
|
||||
private static final Pattern GET_LIBRARTS = Pattern.compile("(.*)\\)\\s*\\(libraries(.*)", Pattern.DOTALL);
|
||||
private static final Pattern GET_LIBRARIES = Pattern.compile("(.*)\\)\\s*\\(nets(.*)", Pattern.DOTALL);
|
||||
|
||||
|
||||
private NetListMerge() {
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 2) {
|
||||
System.out.println("This tool takes 'components' sections of multiple KiCad .net files and merges them into one");
|
||||
System.out.println("usage:");
|
||||
System.out.println("NetListMerge DEST_FILE SOURCE_1 SOURCE_2 [SOURCE_x]*");
|
||||
return;
|
||||
}
|
||||
|
||||
String destinationFile = args[0];
|
||||
NetContent destination = parse(NetListMergeUtil.readFile(destinationFile));
|
||||
|
||||
StringBuilder components = new StringBuilder();
|
||||
StringBuilder libparts = new StringBuilder();
|
||||
StringBuilder libraries = new StringBuilder();
|
||||
StringBuilder nets = new StringBuilder();
|
||||
for (int i = 1; i < args.length; i++) {
|
||||
String sourceFile = args[i];
|
||||
NetContent source = parse(NetListMergeUtil.readFile(sourceFile));
|
||||
components.append(source.components);
|
||||
libparts.append(source.libparts);
|
||||
libraries.append(source.libraries);
|
||||
nets.append(source.nets);
|
||||
}
|
||||
|
||||
System.out.println("Total " + components.length() + " bytes of components");
|
||||
System.out.println("Total " + libparts.length() + " bytes of libparts");
|
||||
System.out.println("Total " + libraries.length() + " bytes of libraries");
|
||||
System.out.println("Total " + nets.length() + " bytes of nets");
|
||||
|
||||
StringBuilder result = new StringBuilder(destination.header);
|
||||
result.append(" (components").append(components).append(")\r\n");
|
||||
result.append(" (libparts").append(libparts).append(")\n");
|
||||
result.append(" (libraries").append(libraries).append(")\n");
|
||||
result.append(" (nets").append(nets).append(")");
|
||||
result.append(")");
|
||||
validateSection(result.toString());
|
||||
NetListMergeUtil.writeResult(result.toString(), "out.txt");
|
||||
}
|
||||
|
||||
private static class NetContent {
|
||||
private final String header;
|
||||
private final String components;
|
||||
private final String libparts;
|
||||
private final String nets;
|
||||
private final String libraries;
|
||||
|
||||
private NetContent(String header, String components, String libparts, String libraries, String nets) {
|
||||
this.header = header;
|
||||
this.components = components;
|
||||
this.libparts = libparts;
|
||||
this.nets = nets;
|
||||
this.libraries = libraries;
|
||||
System.out.println("Got " + components.length() + " bytes of components");
|
||||
System.out.println("Got " + libparts.length() + " bytes of libparts");
|
||||
System.out.println("Got " + libraries.length() + " bytes of libraries");
|
||||
System.out.println("Got " + nets.length() + " bytes of nets");
|
||||
}
|
||||
}
|
||||
|
||||
private static NetContent parse(String content) {
|
||||
Matcher headerMatcher = GET_HEADER.matcher(content);
|
||||
headerMatcher.find();
|
||||
if (!headerMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for header");
|
||||
|
||||
String header = headerMatcher.group(1);
|
||||
String nonHeader = headerMatcher.group(2);
|
||||
|
||||
Matcher componentsMatcher = GET_COMPONENTS.matcher(nonHeader);
|
||||
if (!componentsMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for components");
|
||||
|
||||
String components = componentsMatcher.group(1);
|
||||
String nonComponents = componentsMatcher.group(2);
|
||||
validateSection(components);
|
||||
|
||||
Matcher libpartsMatcher = GET_LIBRARTS.matcher(nonComponents);
|
||||
if (!libpartsMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for libparts");
|
||||
|
||||
String libparts = libpartsMatcher.group(1);
|
||||
String nonlibparts = libpartsMatcher.group(2);
|
||||
validateSection(libparts);
|
||||
|
||||
Matcher librariesMatcher = GET_LIBRARIES.matcher(nonlibparts);
|
||||
if (!librariesMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for nets");
|
||||
|
||||
String libraries = librariesMatcher.group(1);
|
||||
String nets = librariesMatcher.group(2);
|
||||
validateSection(libraries);
|
||||
validateSection(nets);
|
||||
|
||||
// System.out.println("components: " + components);
|
||||
|
||||
return new NetContent(header, components, libparts, libraries, nets);
|
||||
}
|
||||
|
||||
}
|
||||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import static rusefi.NetListMergeUtil.validateSection;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class NetListMerge {
|
||||
private static final Pattern GET_HEADER = Pattern.compile("(.*)\\(components(.*)\\s*$", Pattern.DOTALL);
|
||||
|
||||
private static final Pattern GET_COMPONENTS = Pattern.compile("(.*)\\)\\s*\\(libparts(.*)\\)\\)\\s*$", Pattern.DOTALL);
|
||||
|
||||
private static final Pattern GET_LIBRARTS = Pattern.compile("(.*)\\)\\s*\\(libraries(.*)", Pattern.DOTALL);
|
||||
private static final Pattern GET_LIBRARIES = Pattern.compile("(.*)\\)\\s*\\(nets(.*)", Pattern.DOTALL);
|
||||
|
||||
|
||||
private NetListMerge() {
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 2) {
|
||||
System.out.println("This tool takes 'components' sections of multiple KiCad .net files and merges them into one");
|
||||
System.out.println("usage:");
|
||||
System.out.println("NetListMerge DEST_FILE SOURCE_1 SOURCE_2 [SOURCE_x]*");
|
||||
return;
|
||||
}
|
||||
|
||||
String destinationFile = args[0];
|
||||
NetContent destination = parse(NetListMergeUtil.readFile(destinationFile));
|
||||
|
||||
StringBuilder components = new StringBuilder();
|
||||
StringBuilder libparts = new StringBuilder();
|
||||
StringBuilder libraries = new StringBuilder();
|
||||
StringBuilder nets = new StringBuilder();
|
||||
for (int i = 1; i < args.length; i++) {
|
||||
String sourceFile = args[i];
|
||||
NetContent source = parse(NetListMergeUtil.readFile(sourceFile));
|
||||
components.append(source.components);
|
||||
libparts.append(source.libparts);
|
||||
libraries.append(source.libraries);
|
||||
nets.append(source.nets);
|
||||
}
|
||||
|
||||
System.out.println("Total " + components.length() + " bytes of components");
|
||||
System.out.println("Total " + libparts.length() + " bytes of libparts");
|
||||
System.out.println("Total " + libraries.length() + " bytes of libraries");
|
||||
System.out.println("Total " + nets.length() + " bytes of nets");
|
||||
|
||||
StringBuilder result = new StringBuilder(destination.header);
|
||||
result.append(" (components").append(components).append(")\r\n");
|
||||
result.append(" (libparts").append(libparts).append(")\n");
|
||||
result.append(" (libraries").append(libraries).append(")\n");
|
||||
result.append(" (nets").append(nets).append(")");
|
||||
result.append(")");
|
||||
validateSection(result.toString());
|
||||
NetListMergeUtil.writeResult(result.toString(), "out.txt");
|
||||
}
|
||||
|
||||
private static class NetContent {
|
||||
private final String header;
|
||||
private final String components;
|
||||
private final String libparts;
|
||||
private final String nets;
|
||||
private final String libraries;
|
||||
|
||||
private NetContent(String header, String components, String libparts, String libraries, String nets) {
|
||||
this.header = header;
|
||||
this.components = components;
|
||||
this.libparts = libparts;
|
||||
this.nets = nets;
|
||||
this.libraries = libraries;
|
||||
System.out.println("Got " + components.length() + " bytes of components");
|
||||
System.out.println("Got " + libparts.length() + " bytes of libparts");
|
||||
System.out.println("Got " + libraries.length() + " bytes of libraries");
|
||||
System.out.println("Got " + nets.length() + " bytes of nets");
|
||||
}
|
||||
}
|
||||
|
||||
private static NetContent parse(String content) {
|
||||
Matcher headerMatcher = GET_HEADER.matcher(content);
|
||||
headerMatcher.find();
|
||||
if (!headerMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for header");
|
||||
|
||||
String header = headerMatcher.group(1);
|
||||
String nonHeader = headerMatcher.group(2);
|
||||
|
||||
Matcher componentsMatcher = GET_COMPONENTS.matcher(nonHeader);
|
||||
if (!componentsMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for components");
|
||||
|
||||
String components = componentsMatcher.group(1);
|
||||
String nonComponents = componentsMatcher.group(2);
|
||||
validateSection(components);
|
||||
|
||||
Matcher libpartsMatcher = GET_LIBRARTS.matcher(nonComponents);
|
||||
if (!libpartsMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for libparts");
|
||||
|
||||
String libparts = libpartsMatcher.group(1);
|
||||
String nonlibparts = libpartsMatcher.group(2);
|
||||
validateSection(libparts);
|
||||
|
||||
Matcher librariesMatcher = GET_LIBRARIES.matcher(nonlibparts);
|
||||
if (!librariesMatcher.matches())
|
||||
throw new IllegalStateException("Does not match expected patten for nets");
|
||||
|
||||
String libraries = librariesMatcher.group(1);
|
||||
String nets = librariesMatcher.group(2);
|
||||
validateSection(libraries);
|
||||
validateSection(nets);
|
||||
|
||||
// System.out.println("components: " + components);
|
||||
|
||||
return new NetContent(header, components, libparts, libraries, nets);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,51 +1,51 @@
|
|||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class NetListMergeUtil {
|
||||
static void writeResult(String content, String fileName) throws IOException {
|
||||
System.out.println("Writing result into " + fileName);
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(fileName));
|
||||
bw.write(content);
|
||||
bw.close();
|
||||
}
|
||||
|
||||
static String readFile(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
StringBuilder sb = new StringBuilder();
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
sb.append(line).append("\r\n");
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private static void checkExistence(String fileName) {
|
||||
if (!new File(fileName).isFile()) {
|
||||
System.err.println("File not found: " + fileName);
|
||||
System.exit(-1);
|
||||
}
|
||||
}
|
||||
|
||||
static void validateSection(String section) {
|
||||
int counter = 0;
|
||||
for (int i = 0; i < section.length(); i++) {
|
||||
char c = section.charAt(i);
|
||||
if (c == '(')
|
||||
counter++;
|
||||
else if (c == ')')
|
||||
counter--;
|
||||
if (counter < 0)
|
||||
throw new IllegalStateException("Invalid section: " + section);
|
||||
}
|
||||
if (counter != 0)
|
||||
throw new IllegalStateException("Invalid section: " + section + " balance: " + counter);
|
||||
}
|
||||
}
|
||||
package rusefi;
|
||||
|
||||
import java.io.*;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class NetListMergeUtil {
|
||||
static void writeResult(String content, String fileName) throws IOException {
|
||||
System.out.println("Writing result into " + fileName);
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(fileName));
|
||||
bw.write(content);
|
||||
bw.close();
|
||||
}
|
||||
|
||||
static String readFile(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
StringBuilder sb = new StringBuilder();
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
sb.append(line).append("\r\n");
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private static void checkExistence(String fileName) {
|
||||
if (!new File(fileName).isFile()) {
|
||||
System.err.println("File not found: " + fileName);
|
||||
System.exit(-1);
|
||||
}
|
||||
}
|
||||
|
||||
static void validateSection(String section) {
|
||||
int counter = 0;
|
||||
for (int i = 0; i < section.length(); i++) {
|
||||
char c = section.charAt(i);
|
||||
if (c == '(')
|
||||
counter++;
|
||||
else if (c == ')')
|
||||
counter--;
|
||||
if (counter < 0)
|
||||
throw new IllegalStateException("Invalid section: " + section);
|
||||
}
|
||||
if (counter != 0)
|
||||
throw new IllegalStateException("Invalid section: " + section + " balance: " + counter);
|
||||
}
|
||||
}
|
||||
|
|
Binary file not shown.
|
@ -1,7 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="AntConfiguration">
|
||||
<buildFile url="file://$PROJECT_DIR$/build.xml" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="AntConfiguration">
|
||||
<buildFile url="file://$PROJECT_DIR$/build.xml" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,23 +1,23 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,3 @@
|
|||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
<component name="CopyrightManager">
|
||||
<settings default="" />
|
||||
</component>
|
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<component name="libraryTable">
|
||||
<library name="junit">
|
||||
<CLASSES>
|
||||
<root url="jar://$PROJECT_DIR$/lib/junit.jar!/" />
|
||||
</CLASSES>
|
||||
<JAVADOC />
|
||||
<SOURCES />
|
||||
</library>
|
||||
<component name="libraryTable">
|
||||
<library name="junit">
|
||||
<CLASSES>
|
||||
<root url="jar://$PROJECT_DIR$/lib/junit.jar!/" />
|
||||
</CLASSES>
|
||||
<JAVADOC />
|
||||
<SOURCES />
|
||||
</library>
|
||||
</component>
|
|
@ -1,13 +1,12 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_5" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_7" default="false" assert-keyword="true" jdk-15="true" project-jdk-name="1.7 64b" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
|
@ -1,9 +1,9 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/pcb_sync.iml" filepath="$PROJECT_DIR$/pcb_sync.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/pcb_sync.iml" filepath="$PROJECT_DIR$/pcb_sync.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,24 +1,25 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="BomBuilder" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.bom.BomBuilder" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="in.cmp comp.csv out.csv" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="BomBuilder" type="Application" factoryName="Application">
|
||||
<extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" />
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.bom.BomBuilder" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="in.cmp comp.csv out.csv" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
</component>
|
|
@ -1,22 +1,25 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="Main move" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="pcb_move can_brd_1.kicad_pcb -43.18 58.928" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<method />
|
||||
</configuration>
|
||||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="Main move" type="Application" factoryName="Application">
|
||||
<extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" />
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="pcb_move frankenso_foundation.kicad_pcb frankenso_foundation.kicad_pcb 0 25.4" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
</component>
|
|
@ -1,24 +1,25 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="Main pcb_merge" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="pcb_merge frankenstein_foundation.kicad_pcb out.kicad_pcb changes.txt" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="Main pcb_merge" type="Application" factoryName="Application">
|
||||
<extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" />
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="pcb_merge test.kicad_pcb out.kicad_pcb changes.txt" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
</component>
|
|
@ -1,24 +1,25 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="Main rename" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="rename mmc_replace.txt in out" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="Main rename" type="Application" factoryName="Application">
|
||||
<extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" />
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="rename mmc_replace.txt in out" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
</component>
|
|
@ -1,24 +1,25 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="RemoveUnneededTraces" type="Application" factoryName="Application" nameIsGenerated="true">
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.misc.RemoveUnneededTraces" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="test.kicad_pcb test.kicad_pcb" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="RemoveUnneededTraces" type="Application" factoryName="Application" nameIsGenerated="true">
|
||||
<extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" />
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.misc.RemoveUnneededTraces" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="test.kicad_pcb test.kicad_pcb" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<RunnerSettings RunnerId="Run" />
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<ConfigurationWrapper RunnerId="Run" />
|
||||
<method />
|
||||
</configuration>
|
||||
</component>
|
|
@ -1,22 +1,23 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="main cmp_merge" type="Application" factoryName="Application">
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="cmp_merge output\res.cmp 1.cmp 2.cmp" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<method />
|
||||
</configuration>
|
||||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="main cmp_merge" type="Application" factoryName="Application">
|
||||
<extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" />
|
||||
<option name="MAIN_CLASS_NAME" value="com.rusefi.Main" />
|
||||
<option name="VM_PARAMETERS" value="" />
|
||||
<option name="PROGRAM_PARAMETERS" value="cmp_merge output\res.cmp 1.cmp 2.cmp" />
|
||||
<option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" />
|
||||
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
|
||||
<option name="ALTERNATIVE_JRE_PATH" value="" />
|
||||
<option name="ENABLE_SWING_INSPECTOR" value="false" />
|
||||
<option name="ENV_VARIABLES" />
|
||||
<option name="PASS_PARENT_ENVS" value="true" />
|
||||
<module name="pcb_sync" />
|
||||
<envs />
|
||||
<RunnerSettings RunnerId="Debug">
|
||||
<option name="DEBUG_PORT" value="" />
|
||||
<option name="TRANSPORT" value="0" />
|
||||
<option name="LOCAL" value="true" />
|
||||
</RunnerSettings>
|
||||
<ConfigurationWrapper RunnerId="Debug" />
|
||||
<method />
|
||||
</configuration>
|
||||
</component>
|
|
@ -1,5 +1,5 @@
|
|||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
<component name="DependencyValidationManager">
|
||||
<state>
|
||||
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
|
||||
</state>
|
||||
</component>
|
|
@ -1,125 +1,125 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,48 +1,48 @@
|
|||
P1;P401
|
||||
P2;P402
|
||||
P3;P403
|
||||
P4;P404
|
||||
P5;P405
|
||||
P7;P406
|
||||
|
||||
R4;R401
|
||||
R18;R402
|
||||
|
||||
R5;R403
|
||||
R16;R404
|
||||
|
||||
R6;R405
|
||||
R14;R406
|
||||
|
||||
R7;R407
|
||||
R17;R408
|
||||
|
||||
R8;R409
|
||||
R15;R410
|
||||
|
||||
R9;R411
|
||||
R13;R412
|
||||
|
||||
|
||||
R1;R451
|
||||
R2;R452
|
||||
R3;R453
|
||||
|
||||
|
||||
Q1;Q401
|
||||
Q2;Q402
|
||||
Q3;Q403
|
||||
Q4;Q404
|
||||
Q5;Q405
|
||||
Q6;Q406
|
||||
|
||||
|
||||
D1;D401
|
||||
D2;D402
|
||||
D3;D403
|
||||
D4;D404
|
||||
D5;D405
|
||||
D6;D406
|
||||
D7;D407
|
||||
D8;D408
|
||||
|
||||
P1;P401
|
||||
P2;P402
|
||||
P3;P403
|
||||
P4;P404
|
||||
P5;P405
|
||||
P7;P406
|
||||
|
||||
R4;R401
|
||||
R18;R402
|
||||
|
||||
R5;R403
|
||||
R16;R404
|
||||
|
||||
R6;R405
|
||||
R14;R406
|
||||
|
||||
R7;R407
|
||||
R17;R408
|
||||
|
||||
R8;R409
|
||||
R15;R410
|
||||
|
||||
R9;R411
|
||||
R13;R412
|
||||
|
||||
|
||||
R1;R451
|
||||
R2;R452
|
||||
R3;R453
|
||||
|
||||
|
||||
Q1;Q401
|
||||
Q2;Q402
|
||||
Q3;Q403
|
||||
Q4;Q404
|
||||
Q5;Q405
|
||||
Q6;Q406
|
||||
|
||||
|
||||
D1;D401
|
||||
D2;D402
|
||||
D3;D403
|
||||
D4;D404
|
||||
D5;D405
|
||||
D6;D406
|
||||
D7;D407
|
||||
D8;D408
|
||||
|
||||
|
|
|
@ -1,24 +1,24 @@
|
|||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../pcb_sync.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="com.rusefi.Main"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
<project default="jar">
|
||||
|
||||
<target name="clean">
|
||||
<delete dir="build"/>
|
||||
</target>
|
||||
|
||||
<target name="compile">
|
||||
<mkdir dir="build/classes"/>
|
||||
<javac destdir="build/classes" classpath="lib/junit.jar:lib/annotations.jar">
|
||||
<src path="src"/>
|
||||
</javac>
|
||||
</target>
|
||||
|
||||
<target name="jar" depends="compile">
|
||||
<mkdir dir="build/jar"/>
|
||||
<jar destfile="../pcb_sync.jar" basedir="build/classes">
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="com.rusefi.Main"/>
|
||||
</manifest>
|
||||
<zipfileset dir="build/classes" includes="**/*.class"/>
|
||||
</jar>
|
||||
</target>
|
||||
|
||||
</project>
|
|
@ -1,6 +1,6 @@
|
|||
|
||||
# move_module P353 -50 0
|
||||
|
||||
add adc_amp_divider.kicad_pcb
|
||||
|
||||
|
||||
# move_module P353 -50 0
|
||||
|
||||
add adc_amp_divider.kicad_pcb
|
||||
|
||||
remove P_VOID1
|
|
@ -1,5 +1,5 @@
|
|||
#comment
|
||||
|
||||
SM0805_500K,resistor,resistto_part,hi resistor
|
||||
|
||||
#comment
|
||||
|
||||
SM0805_500K,resistor,resistto_part,hi resistor
|
||||
|
||||
LOGO_LOGO,ignore,ignore,ignore
|
|
|
@ -1,41 +1,41 @@
|
|||
C5;C101
|
||||
C6;C102
|
||||
C10;C103
|
||||
C13;C104
|
||||
C31;C105
|
||||
C32;C106
|
||||
C33;C107
|
||||
C34;C108
|
||||
|
||||
D1;D101
|
||||
D2;D102
|
||||
|
||||
G1;G101
|
||||
|
||||
P1;P101
|
||||
P2;P102
|
||||
P3;P103
|
||||
P4;P104
|
||||
|
||||
R1;R101
|
||||
R38;R102
|
||||
R39;R103
|
||||
R40;R104
|
||||
R41;R105
|
||||
R42;R106
|
||||
R43;R107
|
||||
R44;R108
|
||||
R45;R109
|
||||
R46;R110
|
||||
R48;R111
|
||||
R49;R112
|
||||
R52;R113
|
||||
R53;R114
|
||||
R62;R115
|
||||
R64;R116
|
||||
R65;R117
|
||||
R66;R118
|
||||
|
||||
|
||||
U20;U101
|
||||
C5;C101
|
||||
C6;C102
|
||||
C10;C103
|
||||
C13;C104
|
||||
C31;C105
|
||||
C32;C106
|
||||
C33;C107
|
||||
C34;C108
|
||||
|
||||
D1;D101
|
||||
D2;D102
|
||||
|
||||
G1;G101
|
||||
|
||||
P1;P101
|
||||
P2;P102
|
||||
P3;P103
|
||||
P4;P104
|
||||
|
||||
R1;R101
|
||||
R38;R102
|
||||
R39;R103
|
||||
R40;R104
|
||||
R41;R105
|
||||
R42;R106
|
||||
R43;R107
|
||||
R44;R108
|
||||
R45;R109
|
||||
R46;R110
|
||||
R48;R111
|
||||
R49;R112
|
||||
R52;R113
|
||||
R53;R114
|
||||
R62;R115
|
||||
R64;R116
|
||||
R65;R117
|
||||
R66;R118
|
||||
|
||||
|
||||
U20;U101
|
||||
U24;U102
|
|
@ -1,55 +1,55 @@
|
|||
|
||||
optimize ../can_board/can_brd_1.kicad_pcb can_brd_1.kicad_pcb
|
||||
|
||||
|
||||
add ../adc_amp_divider.vertical12/adc_amp_divider.kicad_pcb
|
||||
add ../usb_mmc_spi/mmc_usb_1.kicad_pcb
|
||||
add ../knock_VR_Art_ELectro/cps_vrs_io_1.kicad_pcb
|
||||
add can_brd_1.kicad_pcb
|
||||
|
||||
|
||||
# DD from the VR board
|
||||
# knock in
|
||||
remove P101
|
||||
# amp chip
|
||||
remove U102
|
||||
# data out
|
||||
remove P103
|
||||
|
||||
remove R115
|
||||
remove R116
|
||||
remove R117
|
||||
remove R118
|
||||
|
||||
|
||||
remove C105
|
||||
remove C106
|
||||
remove C107
|
||||
remove C108
|
||||
|
||||
|
||||
# VR board power LED
|
||||
remove R101
|
||||
remove D102
|
||||
remove D101
|
||||
remove R105
|
||||
|
||||
|
||||
|
||||
|
||||
# CAN module connector
|
||||
remove P471
|
||||
# CAN module power LED
|
||||
remove R471
|
||||
remove D471
|
||||
|
||||
# SD/TTL module 3.3v LED
|
||||
remove R354
|
||||
remove D353
|
||||
|
||||
# SD/TTL module 5v LED
|
||||
remove R353
|
||||
remove D352
|
||||
|
||||
# SD/TTL right 10x2
|
||||
|
||||
optimize ../can_board/can_brd_1.kicad_pcb can_brd_1.kicad_pcb
|
||||
|
||||
|
||||
add ../adc_amp_divider.vertical12/adc_amp_divider.kicad_pcb
|
||||
add ../usb_mmc_spi/mmc_usb_1.kicad_pcb
|
||||
add ../knock_VR_Art_ELectro/cps_vrs_io_1.kicad_pcb
|
||||
add can_brd_1.kicad_pcb
|
||||
|
||||
|
||||
# DD from the VR board
|
||||
# knock in
|
||||
remove P101
|
||||
# amp chip
|
||||
remove U102
|
||||
# data out
|
||||
remove P103
|
||||
|
||||
remove R115
|
||||
remove R116
|
||||
remove R117
|
||||
remove R118
|
||||
|
||||
|
||||
remove C105
|
||||
remove C106
|
||||
remove C107
|
||||
remove C108
|
||||
|
||||
|
||||
# VR board power LED
|
||||
remove R101
|
||||
remove D102
|
||||
remove D101
|
||||
remove R105
|
||||
|
||||
|
||||
|
||||
|
||||
# CAN module connector
|
||||
remove P471
|
||||
# CAN module power LED
|
||||
remove R471
|
||||
remove D471
|
||||
|
||||
# SD/TTL module 3.3v LED
|
||||
remove R354
|
||||
remove D353
|
||||
|
||||
# SD/TTL module 5v LED
|
||||
remove R353
|
||||
remove D352
|
||||
|
||||
# SD/TTL right 10x2
|
||||
remove P354
|
|
@ -1,13 +1,13 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
<orderEntry type="library" name="junit" level="project" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
<orderEntry type="library" name="junit" level="project" />
|
||||
</component>
|
||||
</module>
|
||||
|
||||
|
|
|
@ -1,61 +1,61 @@
|
|||
package com.rusefi;
|
||||
|
||||
import com.rusefi.bom.BomBuilder;
|
||||
import com.rusefi.misc.CmpMergeTool;
|
||||
import com.rusefi.misc.RemoveUnneededTraces;
|
||||
import com.rusefi.pcb.PcbMergeTool;
|
||||
import com.rusefi.pcb.PcbMoveTool;
|
||||
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.TreeMap;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/16/13.
|
||||
*/
|
||||
public class Main {
|
||||
private static final Map<String, Class> TOOLS = new TreeMap<String, Class>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
static {
|
||||
registerTool("pcb_move", PcbMoveTool.class);
|
||||
registerTool("pcb_merge", PcbMergeTool.class);
|
||||
|
||||
registerTool("copy", PcbCopyTool.class);
|
||||
|
||||
registerTool("cmp_merge", CmpMergeTool.class);
|
||||
registerTool("rename", RenameComponents.class);
|
||||
|
||||
registerTool("optimize", RemoveUnneededTraces.class);
|
||||
|
||||
registerTool("bom_builder", BomBuilder.class);
|
||||
}
|
||||
|
||||
private static void registerTool(String name, Class<?> clazz) {
|
||||
TOOLS.put(name, clazz);
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException {
|
||||
if (args.length < 1) {
|
||||
System.out.println("At least tool name parameter expected");
|
||||
System.out.println(TOOLS.size() + " tools available:");
|
||||
for (String name : TOOLS.keySet())
|
||||
System.out.println("\t\t" + name);
|
||||
return;
|
||||
}
|
||||
String name = args[0];
|
||||
Class c = TOOLS.get(name);
|
||||
if (c == null)
|
||||
throw new NullPointerException("No tool: " + name);
|
||||
|
||||
Method main = c.getMethod("main", String[].class);
|
||||
|
||||
List<String> asList = Arrays.asList(args);
|
||||
String[] a = asList.subList(1, asList.size()).toArray(new String[args.length - 1]);
|
||||
|
||||
main.invoke(null, new Object[]{a});
|
||||
}
|
||||
}
|
||||
package com.rusefi;
|
||||
|
||||
import com.rusefi.bom.BomBuilder;
|
||||
import com.rusefi.misc.CmpMergeTool;
|
||||
import com.rusefi.misc.RemoveUnneededTraces;
|
||||
import com.rusefi.pcb.PcbMergeTool;
|
||||
import com.rusefi.pcb.PcbMoveTool;
|
||||
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.TreeMap;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/16/13.
|
||||
*/
|
||||
public class Main {
|
||||
private static final Map<String, Class> TOOLS = new TreeMap<String, Class>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
static {
|
||||
registerTool("pcb_move", PcbMoveTool.class);
|
||||
registerTool("pcb_merge", PcbMergeTool.class);
|
||||
|
||||
registerTool("copy", PcbCopyTool.class);
|
||||
|
||||
registerTool("cmp_merge", CmpMergeTool.class);
|
||||
registerTool("rename", RenameComponents.class);
|
||||
|
||||
registerTool("optimize", RemoveUnneededTraces.class);
|
||||
|
||||
registerTool("bom_builder", BomBuilder.class);
|
||||
}
|
||||
|
||||
private static void registerTool(String name, Class<?> clazz) {
|
||||
TOOLS.put(name, clazz);
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException {
|
||||
if (args.length < 1) {
|
||||
System.out.println("At least tool name parameter expected");
|
||||
System.out.println(TOOLS.size() + " tools available:");
|
||||
for (String name : TOOLS.keySet())
|
||||
System.out.println("\t\t" + name);
|
||||
return;
|
||||
}
|
||||
String name = args[0];
|
||||
Class c = TOOLS.get(name);
|
||||
if (c == null)
|
||||
throw new NullPointerException("No tool: " + name);
|
||||
|
||||
Method main = c.getMethod("main", String[].class);
|
||||
|
||||
List<String> asList = Arrays.asList(args);
|
||||
String[] a = asList.subList(1, asList.size()).toArray(new String[args.length - 1]);
|
||||
|
||||
main.invoke(null, new Object[]{a});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,36 +1,36 @@
|
|||
package com.rusefi;
|
||||
|
||||
import com.rusefi.misc.ChangesModel;
|
||||
import com.rusefi.pcb.PcbMergeTool;
|
||||
import com.rusefi.pcb.PcbNode;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class PcbCopyTool {
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 2) {
|
||||
System.out.println("Two parameters expected: SOURCE DESTINATION");
|
||||
return;
|
||||
}
|
||||
|
||||
ChangesModel.readConfiguration("pcb_merge_changes.txt");
|
||||
|
||||
String input = args[0];
|
||||
String output = args[1];
|
||||
|
||||
copy(input, output);
|
||||
}
|
||||
|
||||
public static void copy(String input, String output) throws IOException {
|
||||
System.out.println("From " + input + " to " + output);
|
||||
PcbNode node = PcbNode.readFromFile(input);
|
||||
|
||||
PcbMergeTool.removeNodes(node);
|
||||
|
||||
node.write(output);
|
||||
}
|
||||
}
|
||||
package com.rusefi;
|
||||
|
||||
import com.rusefi.misc.ChangesModel;
|
||||
import com.rusefi.pcb.PcbMergeTool;
|
||||
import com.rusefi.pcb.PcbNode;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class PcbCopyTool {
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 2) {
|
||||
System.out.println("Two parameters expected: SOURCE DESTINATION");
|
||||
return;
|
||||
}
|
||||
|
||||
ChangesModel.readConfiguration("pcb_merge_changes.txt");
|
||||
|
||||
String input = args[0];
|
||||
String output = args[1];
|
||||
|
||||
copy(input, output);
|
||||
}
|
||||
|
||||
public static void copy(String input, String output) throws IOException {
|
||||
System.out.println("From " + input + " to " + output);
|
||||
PcbNode node = PcbNode.readFromFile(input);
|
||||
|
||||
PcbMergeTool.removeNodes(node);
|
||||
|
||||
node.write(output);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,106 +1,106 @@
|
|||
package com.rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
public class RenameComponents {
|
||||
private static final Map<String, String> replaceMap = new HashMap<String, String>();
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 3) {
|
||||
System.out.println("Three paramters expected:");
|
||||
System.out.println(" replace_replace_file source_folder destination_folder");
|
||||
return;
|
||||
}
|
||||
String requestFileName = args[0];
|
||||
File file = new File(requestFileName);
|
||||
if (!file.exists() || !file.isFile())
|
||||
throw new IllegalArgumentException("No replace_request_file");
|
||||
String sourceDir = args[1];
|
||||
assertFolder(sourceDir);
|
||||
String destinationDir = args[2];
|
||||
assertFolder(destinationDir);
|
||||
|
||||
readReplaceRequest(file);
|
||||
for (String fileName : new File(sourceDir).list())
|
||||
processFile(sourceDir, destinationDir, fileName);
|
||||
}
|
||||
|
||||
private static void processFile(String sourceDir, String destinationDir, String fileName) throws IOException {
|
||||
String newFileName = destinationDir + File.separator + fileName;
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(newFileName));
|
||||
|
||||
String sourceFile = sourceDir + File.separator + fileName;
|
||||
BufferedReader br = new BufferedReader(new FileReader(sourceFile));
|
||||
|
||||
System.out.println("Making " + newFileName + " from " + sourceFile);
|
||||
|
||||
String line;
|
||||
while ((line = br.readLine()) != null) {
|
||||
line = processLine(line);
|
||||
bw.append(line + "\r\n");
|
||||
}
|
||||
|
||||
bw.close();
|
||||
}
|
||||
|
||||
private static String processLine(String line) {
|
||||
for (Map.Entry<String, String> e : replaceMap.entrySet()) {
|
||||
String from = e.getKey();
|
||||
String to = e.getValue();
|
||||
|
||||
line = Pattern.compile(" " + from + "$").matcher(
|
||||
line).replaceAll(Matcher.quoteReplacement(" " + to));
|
||||
|
||||
line = processLine(line, " " + from + ";", " " + to + ";");
|
||||
line = processLine(line, " " + from + ")", " " + to + ")");
|
||||
line = processLine(line, " " + from + " ", " " + to + " ");
|
||||
line = processLine(line, " " + from + "-", " " + to + "-");
|
||||
line = processLine(line, "\"" + from + "\"", "\"" + to + "\"");
|
||||
}
|
||||
return line;
|
||||
}
|
||||
|
||||
private static String processLine(String line, String s, String s1) {
|
||||
return line.replace(s, s1);
|
||||
}
|
||||
|
||||
private static void readReplaceRequest(File file) throws IOException {
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(file));
|
||||
int lineNumber = 0;
|
||||
|
||||
while ((line = br.readLine()) != null) {
|
||||
lineNumber++;
|
||||
line = line.trim();
|
||||
if (line.isEmpty())
|
||||
continue;
|
||||
String[] s = line.split("\\;");
|
||||
if (s.length != 2)
|
||||
throw new IllegalArgumentException("Invalid replace request: " + line);
|
||||
|
||||
String from = s[0];
|
||||
String to = s[1];
|
||||
|
||||
|
||||
if (replaceMap.containsKey(from) || replaceMap.containsValue(from))
|
||||
throw new IllegalArgumentException("Name already mentioned: " + from + " @" + lineNumber);
|
||||
|
||||
if (replaceMap.containsKey(to) || replaceMap.containsValue(to))
|
||||
throw new IllegalArgumentException("Name already mentioned: " + to + " @" + lineNumber);
|
||||
|
||||
replaceMap.put(from, to);
|
||||
|
||||
System.out.println("Replacing [" + from + "] by [" + to + "]");
|
||||
}
|
||||
}
|
||||
|
||||
private static void assertFolder(String dir) {
|
||||
File d = new File(dir);
|
||||
if (!d.exists() || !d.isDirectory())
|
||||
throw new IllegalArgumentException("No such folder: " + dir);
|
||||
}
|
||||
}
|
||||
package com.rusefi;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
public class RenameComponents {
|
||||
private static final Map<String, String> replaceMap = new HashMap<String, String>();
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 3) {
|
||||
System.out.println("Three paramters expected:");
|
||||
System.out.println(" replace_replace_file source_folder destination_folder");
|
||||
return;
|
||||
}
|
||||
String requestFileName = args[0];
|
||||
File file = new File(requestFileName);
|
||||
if (!file.exists() || !file.isFile())
|
||||
throw new IllegalArgumentException("No replace_request_file");
|
||||
String sourceDir = args[1];
|
||||
assertFolder(sourceDir);
|
||||
String destinationDir = args[2];
|
||||
assertFolder(destinationDir);
|
||||
|
||||
readReplaceRequest(file);
|
||||
for (String fileName : new File(sourceDir).list())
|
||||
processFile(sourceDir, destinationDir, fileName);
|
||||
}
|
||||
|
||||
private static void processFile(String sourceDir, String destinationDir, String fileName) throws IOException {
|
||||
String newFileName = destinationDir + File.separator + fileName;
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(newFileName));
|
||||
|
||||
String sourceFile = sourceDir + File.separator + fileName;
|
||||
BufferedReader br = new BufferedReader(new FileReader(sourceFile));
|
||||
|
||||
System.out.println("Making " + newFileName + " from " + sourceFile);
|
||||
|
||||
String line;
|
||||
while ((line = br.readLine()) != null) {
|
||||
line = processLine(line);
|
||||
bw.append(line + "\r\n");
|
||||
}
|
||||
|
||||
bw.close();
|
||||
}
|
||||
|
||||
private static String processLine(String line) {
|
||||
for (Map.Entry<String, String> e : replaceMap.entrySet()) {
|
||||
String from = e.getKey();
|
||||
String to = e.getValue();
|
||||
|
||||
line = Pattern.compile(" " + from + "$").matcher(
|
||||
line).replaceAll(Matcher.quoteReplacement(" " + to));
|
||||
|
||||
line = processLine(line, " " + from + ";", " " + to + ";");
|
||||
line = processLine(line, " " + from + ")", " " + to + ")");
|
||||
line = processLine(line, " " + from + " ", " " + to + " ");
|
||||
line = processLine(line, " " + from + "-", " " + to + "-");
|
||||
line = processLine(line, "\"" + from + "\"", "\"" + to + "\"");
|
||||
}
|
||||
return line;
|
||||
}
|
||||
|
||||
private static String processLine(String line, String s, String s1) {
|
||||
return line.replace(s, s1);
|
||||
}
|
||||
|
||||
private static void readReplaceRequest(File file) throws IOException {
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(file));
|
||||
int lineNumber = 0;
|
||||
|
||||
while ((line = br.readLine()) != null) {
|
||||
lineNumber++;
|
||||
line = line.trim();
|
||||
if (line.isEmpty())
|
||||
continue;
|
||||
String[] s = line.split("\\;");
|
||||
if (s.length != 2)
|
||||
throw new IllegalArgumentException("Invalid replace request: " + line);
|
||||
|
||||
String from = s[0];
|
||||
String to = s[1];
|
||||
|
||||
|
||||
if (replaceMap.containsKey(from) || replaceMap.containsValue(from))
|
||||
throw new IllegalArgumentException("Name already mentioned: " + from + " @" + lineNumber);
|
||||
|
||||
if (replaceMap.containsKey(to) || replaceMap.containsValue(to))
|
||||
throw new IllegalArgumentException("Name already mentioned: " + to + " @" + lineNumber);
|
||||
|
||||
replaceMap.put(from, to);
|
||||
|
||||
System.out.println("Replacing [" + from + "] by [" + to + "]");
|
||||
}
|
||||
}
|
||||
|
||||
private static void assertFolder(String dir) {
|
||||
File d = new File(dir);
|
||||
if (!d.exists() || !d.isDirectory())
|
||||
throw new IllegalArgumentException("No such folder: " + dir);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,168 +1,230 @@
|
|||
package com.rusefi.bom;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.FileWriter;
|
||||
import java.io.IOException;
|
||||
import java.util.*;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/2/14
|
||||
*/
|
||||
public class BomBuilder {
|
||||
private static final String DELIMITER = ",";
|
||||
|
||||
private static final CpmFileModel allComponents = new CpmFileModel();
|
||||
private static final String IGNORE_TAG = "ignore";
|
||||
private static String cmpFileName;
|
||||
private static String bomDictionaryName;
|
||||
private static Map<String, BomRecord> bomDictionary;
|
||||
private static Set<String> ignoreList = new TreeSet<String>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 3) {
|
||||
System.out.println("bom_builder [FILE_NAME.CMP] COMPONENTS_DICTIONARY.CSV OUTPUT_FILE.CSV");
|
||||
return;
|
||||
}
|
||||
cmpFileName = args[0];
|
||||
bomDictionaryName = args[1];
|
||||
String outputFileName = args[2];
|
||||
|
||||
allComponents.readCmpFile(FileUtils.readFileToList(cmpFileName));
|
||||
|
||||
bomDictionary = readBomDictionary(FileUtils.readFileToList(bomDictionaryName));
|
||||
|
||||
writeCompactPartList(outputFileName + "_compact.csv", bomDictionary);
|
||||
writeFullPartList(outputFileName + "_full.csv", bomDictionary);
|
||||
}
|
||||
|
||||
private static void writeMissingElements(Map<String, BomRecord> bomDictionary, BufferedWriter bw, Map<String, List<BomComponent>> componentsByKey) throws IOException {
|
||||
for (Iterator<Map.Entry<String, List<BomComponent>>> i = componentsByKey.entrySet().iterator(); i.hasNext(); ) {
|
||||
Map.Entry<String, List<BomComponent>> e = i.next();
|
||||
String key = e.getKey();
|
||||
|
||||
if (ignoreList.contains(key))
|
||||
continue;
|
||||
|
||||
BomRecord bomRecord = bomDictionary.get(key);
|
||||
if (bomRecord == null) {
|
||||
bw.write("### no BOM record for " + key + ": " + e.getValue() + "\r\n");
|
||||
i.remove();
|
||||
}
|
||||
}
|
||||
bw.write("\r\n\n\n\n");
|
||||
}
|
||||
|
||||
private static void writeFullPartList(String outputFileName, Map<String, BomRecord> bomDictionary) throws IOException {
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(outputFileName));
|
||||
|
||||
Map<String, List<BomComponent>> componentsByKey = new TreeMap<String, List<BomComponent>>(allComponents.componentsByKey);
|
||||
|
||||
log("Writing full parts list to " + outputFileName);
|
||||
writeCommonHeader(bw);
|
||||
writeMissingElements(bomDictionary, bw, componentsByKey);
|
||||
|
||||
for (Map.Entry<String, List<BomComponent>> e : componentsByKey.entrySet()) {
|
||||
String key = e.getKey();
|
||||
List<BomComponent> list = e.getValue();
|
||||
|
||||
if (ignoreList.contains(key))
|
||||
continue;
|
||||
|
||||
BomRecord bomRecord = bomDictionary.get(key);
|
||||
if (bomRecord == null)
|
||||
throw new NullPointerException();
|
||||
|
||||
for (BomComponent c : list)
|
||||
writeLine(bw, bomRecord, 1, c.getReference() + ": ");
|
||||
}
|
||||
bw.close();
|
||||
}
|
||||
|
||||
private static void writeCompactPartList(String outputFileName, Map<String, BomRecord> bomDictionary) throws IOException {
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(outputFileName));
|
||||
Map<String, List<BomComponent>> componentsByKey = new TreeMap<String, List<BomComponent>>(allComponents.componentsByKey);
|
||||
|
||||
log("Writing compact parts list to " + outputFileName);
|
||||
writeCommonHeader(bw);
|
||||
writeMissingElements(bomDictionary, bw, componentsByKey);
|
||||
|
||||
for (Map.Entry<String, List<BomComponent>> e : componentsByKey.entrySet()) {
|
||||
String key = e.getKey();
|
||||
|
||||
if (ignoreList.contains(key))
|
||||
continue;
|
||||
|
||||
List<BomComponent> list = e.getValue();
|
||||
log(list.size() + " items of " + key);
|
||||
|
||||
BomRecord bomRecord = bomDictionary.get(key);
|
||||
if (bomRecord == null)
|
||||
throw new NullPointerException();
|
||||
writeLine(bw, bomRecord, list.size(), "");
|
||||
}
|
||||
bw.close();
|
||||
}
|
||||
|
||||
private static void writeCommonHeader(BufferedWriter bw) throws IOException {
|
||||
bw.write("### this file was generated by rusEfi bom_builder on " + new Date() + "\r\n");
|
||||
bw.write("### " + allComponents.componentsCount + " components in " + allComponents.linesCount + " lines of " + cmpFileName + "\r\n");
|
||||
bw.write("### " + allComponents.componentsByKey.size() + " kinds of components in input file\r\n");
|
||||
bw.write("### " + bomDictionary.size() + " entries in BOM dictionary " + bomDictionaryName + "\r\n");
|
||||
bw.write("### " + ignoreList.size() + " entries in ignore list\r\n");
|
||||
}
|
||||
|
||||
private static void writeLine(BufferedWriter bw, BomRecord bomRecord, int quantity, String prefix) throws IOException {
|
||||
bw.write(quantity + DELIMITER +
|
||||
bomRecord.getStorePart() + DELIMITER +
|
||||
prefix + bomRecord.getCustomerRef() + "\r\n");
|
||||
}
|
||||
|
||||
private static Map<String, BomRecord> readBomDictionary(List<String> strings) {
|
||||
Map<String, BomRecord> result = new TreeMap<String, BomRecord>(String.CASE_INSENSITIVE_ORDER);
|
||||
for (String line : strings) {
|
||||
line = line.trim();
|
||||
if (line.isEmpty())
|
||||
continue;
|
||||
|
||||
if (line.startsWith("#")) {
|
||||
log("Skipping comment: " + line);
|
||||
continue;
|
||||
}
|
||||
|
||||
String[] tokens = line.split(",");
|
||||
|
||||
if (tokens.length != 4) {
|
||||
log("Unexpected line: " + line + " Expected 4 tokens but " + tokens.length);
|
||||
System.exit(-1);
|
||||
}
|
||||
|
||||
String ref = tokens[0];
|
||||
String mfgPart = tokens[1];
|
||||
String storePart = tokens[2];
|
||||
String customerRef = tokens[3];
|
||||
|
||||
if (storePart.equalsIgnoreCase(IGNORE_TAG)) {
|
||||
log("Ignore entry: " + ref);
|
||||
ignoreList.add(ref);
|
||||
continue;
|
||||
}
|
||||
|
||||
result.put(ref, new BomRecord(mfgPart, storePart, customerRef));
|
||||
|
||||
log("BOM key: " + ref);
|
||||
log("mfgPartNo: " + mfgPart);
|
||||
log("storePartNo: " + storePart);
|
||||
}
|
||||
|
||||
log("Got " + result.size() + " entries in BOM dictionary");
|
||||
log("Got " + ignoreList.size() + " entries in ignore list");
|
||||
return result;
|
||||
}
|
||||
|
||||
protected static void log(String msg) {
|
||||
System.out.println(msg);
|
||||
}
|
||||
}
|
||||
package com.rusefi.bom;
|
||||
|
||||
import com.rusefi.pcb.ModuleNode;
|
||||
import com.rusefi.pcb.PcbNode;
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.FileWriter;
|
||||
import java.io.IOException;
|
||||
import java.util.*;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/2/14
|
||||
*/
|
||||
public class BomBuilder {
|
||||
private static final String DELIMITER = ",";
|
||||
|
||||
private static final CpmFileModel allComponents = new CpmFileModel();
|
||||
private static final String IGNORE_TAG = "ignore";
|
||||
private static String cmpFileName;
|
||||
private static String bomDictionaryName;
|
||||
private static Map<String, BomRecord> bomDictionary;
|
||||
private static Set<String> ignoreList = new TreeSet<String>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
private static boolean printQtyInFull = true;
|
||||
private static boolean printPadCount = false;
|
||||
private static boolean printReference = false;
|
||||
private static boolean printUserComment = false;
|
||||
private static PcbNode pcb;
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 3) {
|
||||
System.out.println("bom_builder FILE_NAME.CMP PCB.kicad_pcb COMPONENTS_DICTIONARY.CSV OUTPUT_FILE.CSV");
|
||||
return;
|
||||
}
|
||||
cmpFileName = args[0];
|
||||
String pcbFileName = args[1];
|
||||
bomDictionaryName = args[2];
|
||||
String outputFileName = args[3];
|
||||
|
||||
pcb = PcbNode.readFromFile(pcbFileName);
|
||||
|
||||
for (int i = 4; i < args.length; i++) {
|
||||
String option = args[i].trim();
|
||||
if (option.equalsIgnoreCase("printUserComment")) {
|
||||
printUserComment = true;
|
||||
} else if (option.equalsIgnoreCase("printreference")) {
|
||||
printReference = true;
|
||||
} else if (option.equalsIgnoreCase("printpadcount")) {
|
||||
printPadCount = true;
|
||||
} else if (option.equalsIgnoreCase("skipqtyinfull")) {
|
||||
printQtyInFull = false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
allComponents.readCmpFile(FileUtils.readFileToList(cmpFileName));
|
||||
|
||||
bomDictionary = readBomDictionary(FileUtils.readFileToList(bomDictionaryName));
|
||||
|
||||
writeCompactPartList(outputFileName + "_compact.csv", bomDictionary);
|
||||
writeFullPartList(outputFileName + "_full.csv", bomDictionary);
|
||||
}
|
||||
|
||||
private static void writeMissingElements(Map<String, BomRecord> bomDictionary, BufferedWriter bw, Map<String, List<BomComponent>> componentsByKey) throws IOException {
|
||||
for (Iterator<Map.Entry<String, List<BomComponent>>> i = componentsByKey.entrySet().iterator(); i.hasNext(); ) {
|
||||
Map.Entry<String, List<BomComponent>> e = i.next();
|
||||
String key = e.getKey();
|
||||
|
||||
if (ignoreList.contains(key))
|
||||
continue;
|
||||
|
||||
BomRecord bomRecord = bomDictionary.get(key);
|
||||
if (bomRecord == null) {
|
||||
bw.write("### no BOM record for " + key + ": " + e.getValue() + "\r\n");
|
||||
i.remove();
|
||||
}
|
||||
}
|
||||
bw.write("\r\n\n\n\n");
|
||||
}
|
||||
|
||||
private static void writeFullPartList(String outputFileName, Map<String, BomRecord> bomDictionary) throws IOException {
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(outputFileName));
|
||||
|
||||
Map<String, List<BomComponent>> componentsByKey = new TreeMap<String, List<BomComponent>>(allComponents.componentsByKey);
|
||||
|
||||
log("Writing full parts list to " + outputFileName);
|
||||
writeCommonHeader(bw);
|
||||
writeMissingElements(bomDictionary, bw, componentsByKey);
|
||||
|
||||
StringBuilder notMounted = new StringBuilder();
|
||||
|
||||
for (Map.Entry<String, List<BomComponent>> e : componentsByKey.entrySet()) {
|
||||
// for instance, SM0805_47pF
|
||||
String componentName = e.getKey();
|
||||
|
||||
List<BomComponent> list = e.getValue();
|
||||
|
||||
if (ignoreList.contains(componentName))
|
||||
continue;
|
||||
|
||||
BomRecord bomRecord = bomDictionary.get(componentName);
|
||||
if (bomRecord == null)
|
||||
throw new NullPointerException();
|
||||
|
||||
|
||||
|
||||
|
||||
for (BomComponent c : list) {
|
||||
if (!findModule(c.getReference())) {
|
||||
bw.write("Not mounted: " + c.getReference() + "\r\n");
|
||||
continue;
|
||||
}
|
||||
writeLine(bw, bomRecord, 1, c.getReference() + ": ", c.getReference());
|
||||
}
|
||||
}
|
||||
bw.close();
|
||||
}
|
||||
|
||||
private static boolean findModule(String reference) {
|
||||
for (PcbNode node : pcb.iterate("module")) {
|
||||
if (node instanceof ModuleNode) {
|
||||
ModuleNode mn = (ModuleNode) node;
|
||||
if (mn.getReference().equalsIgnoreCase(reference))
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private static void writeCompactPartList(String outputFileName, Map<String, BomRecord> bomDictionary) throws IOException {
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(outputFileName));
|
||||
Map<String, List<BomComponent>> componentsByKey = new TreeMap<String, List<BomComponent>>(allComponents.componentsByKey);
|
||||
|
||||
log("Writing compact parts list to " + outputFileName);
|
||||
writeCommonHeader(bw);
|
||||
writeMissingElements(bomDictionary, bw, componentsByKey);
|
||||
|
||||
for (Map.Entry<String, List<BomComponent>> e : componentsByKey.entrySet()) {
|
||||
// for instance, SM0805_47pF
|
||||
String componentName = e.getKey();
|
||||
|
||||
if (ignoreList.contains(componentName))
|
||||
continue;
|
||||
|
||||
List<BomComponent> list = e.getValue();
|
||||
log(list.size() + " items of " + componentName);
|
||||
|
||||
BomRecord bomRecord = bomDictionary.get(componentName);
|
||||
if (bomRecord == null)
|
||||
throw new NullPointerException();
|
||||
writeLine(bw, bomRecord, list.size(), "", "");
|
||||
}
|
||||
bw.close();
|
||||
}
|
||||
|
||||
private static void writeCommonHeader(BufferedWriter bw) throws IOException {
|
||||
bw.write("### this file was generated by rusEfi bom_builder on " + new Date() + "\r\n");
|
||||
bw.write("### " + allComponents.componentsCount + " components in " + allComponents.linesCount + " lines of " + cmpFileName + "\r\n");
|
||||
bw.write("### " + allComponents.componentsByKey.size() + " kinds of components in input file\r\n");
|
||||
bw.write("### " + bomDictionary.size() + " entries in BOM dictionary " + bomDictionaryName + "\r\n");
|
||||
bw.write("### " + ignoreList.size() + " entries in ignore list\r\n");
|
||||
}
|
||||
|
||||
private static void writeLine(BufferedWriter bw, BomRecord bomRecord, int quantity, String prefix, String reference) throws IOException {
|
||||
bw.write(quantity + DELIMITER +
|
||||
bomRecord.getStorePart() + DELIMITER +
|
||||
prefix + bomRecord.getCustomerRef() + DELIMITER +
|
||||
(printReference ? reference + DELIMITER : "") +
|
||||
(printUserComment ? bomRecord.getUserComment() + DELIMITER : "") +
|
||||
(printPadCount ? bomRecord.getPadCount() + DELIMITER : "") +
|
||||
"\r\n"
|
||||
);
|
||||
}
|
||||
|
||||
private static Map<String, BomRecord> readBomDictionary(List<String> strings) {
|
||||
Map<String, BomRecord> result = new TreeMap<String, BomRecord>(String.CASE_INSENSITIVE_ORDER);
|
||||
for (String line : strings) {
|
||||
line = line.trim();
|
||||
if (line.isEmpty())
|
||||
continue;
|
||||
|
||||
if (line.startsWith("#")) {
|
||||
log("Skipping comment: " + line);
|
||||
continue;
|
||||
}
|
||||
|
||||
String[] tokens = line.split(",");
|
||||
|
||||
if (tokens.length < 2) {
|
||||
log("Unexpected line: " + line + " Expected at least two tokens but " + tokens.length);
|
||||
System.exit(-1);
|
||||
}
|
||||
|
||||
String ref = tokens[0];
|
||||
String mfgPart = tokens[1];
|
||||
|
||||
if (mfgPart.equalsIgnoreCase(IGNORE_TAG)) {
|
||||
log("Ignoring entry: " + ref);
|
||||
ignoreList.add(ref);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (tokens.length != 6) {
|
||||
log("Unexpected line: [" + line + "] Expected 6 tokens but " + tokens.length);
|
||||
System.exit(-1);
|
||||
}
|
||||
|
||||
String storePart = tokens[2];
|
||||
String componentName = tokens[3];
|
||||
int padCount = Integer.parseInt(tokens[4]);
|
||||
String customerRef = tokens[5];
|
||||
|
||||
result.put(ref, new BomRecord(mfgPart, storePart, customerRef, padCount, componentName));
|
||||
|
||||
log("BOM key: " + ref);
|
||||
log("mfgPartNo: " + mfgPart);
|
||||
log("storePartNo: " + storePart);
|
||||
}
|
||||
|
||||
log("Got " + result.size() + " entries in BOM dictionary");
|
||||
log("Got " + ignoreList.size() + " entries in ignore list");
|
||||
return result;
|
||||
}
|
||||
|
||||
protected static void log(String msg) {
|
||||
System.out.println(msg);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
package com.rusefi.bom;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/2/14
|
||||
*/
|
||||
public class BomComponent {
|
||||
private final String reference;
|
||||
|
||||
public BomComponent(String reference) {
|
||||
this.reference = reference;
|
||||
}
|
||||
|
||||
public String getReference() {
|
||||
return reference;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return reference;
|
||||
}
|
||||
}
|
||||
package com.rusefi.bom;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/2/14
|
||||
*/
|
||||
public class BomComponent {
|
||||
private final String reference;
|
||||
|
||||
public BomComponent(String reference) {
|
||||
this.reference = reference;
|
||||
}
|
||||
|
||||
public String getReference() {
|
||||
return reference;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return reference;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,29 +1,41 @@
|
|||
package com.rusefi.bom;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/2/14
|
||||
*/
|
||||
public class BomRecord {
|
||||
private final String mfgPart;
|
||||
private final String storePart;
|
||||
private final String customerRef;
|
||||
|
||||
public BomRecord(String mfgPart, String storePart, String customerRef) {
|
||||
this.mfgPart = mfgPart;
|
||||
this.storePart = storePart;
|
||||
this.customerRef = customerRef;
|
||||
}
|
||||
|
||||
public String getMfgPart() {
|
||||
return mfgPart;
|
||||
}
|
||||
|
||||
public String getStorePart() {
|
||||
return storePart;
|
||||
}
|
||||
|
||||
public String getCustomerRef() {
|
||||
return customerRef;
|
||||
}
|
||||
}
|
||||
package com.rusefi.bom;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/2/14
|
||||
*/
|
||||
public class BomRecord {
|
||||
private final String mfgPart;
|
||||
private final String storePart;
|
||||
private final String customerRef;
|
||||
private final int padCount;
|
||||
private final String userComment;
|
||||
|
||||
public BomRecord(String mfgPart, String storePart, String customerRef, int padCount, String userComment) {
|
||||
this.mfgPart = mfgPart;
|
||||
this.storePart = storePart;
|
||||
this.customerRef = customerRef;
|
||||
this.padCount = padCount;
|
||||
this.userComment = userComment;
|
||||
}
|
||||
|
||||
public String getMfgPart() {
|
||||
return mfgPart;
|
||||
}
|
||||
|
||||
public String getStorePart() {
|
||||
return storePart;
|
||||
}
|
||||
|
||||
public String getCustomerRef() {
|
||||
return customerRef;
|
||||
}
|
||||
|
||||
public int getPadCount() {
|
||||
return padCount;
|
||||
}
|
||||
|
||||
public String getUserComment() {
|
||||
return userComment;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,75 +1,75 @@
|
|||
package com.rusefi.bom;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.TreeMap;
|
||||
|
||||
import static com.rusefi.bom.BomBuilder.log;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/22/14
|
||||
*/
|
||||
public class CpmFileModel {
|
||||
|
||||
public final Map<String, List<BomComponent>> componentsByKey = new TreeMap<String, List<BomComponent>>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
public int linesCount;
|
||||
public int componentsCount;
|
||||
|
||||
|
||||
public void readCmpFile(List<String> list) throws IOException {
|
||||
linesCount = list.size();
|
||||
componentsCount = 0;
|
||||
|
||||
for (int lineIndex = 0; lineIndex < list.size(); lineIndex++) {
|
||||
String line = list.get(lineIndex);
|
||||
if ("BeginCmp".equals(line)) {
|
||||
componentsCount++;
|
||||
|
||||
lineIndex += 2; // skipping 'TimeStamp' line
|
||||
|
||||
String a = list.get(lineIndex);
|
||||
String reference = parseReferenceLine(a);
|
||||
log(lineIndex + ": reference: " + reference);
|
||||
lineIndex++;
|
||||
|
||||
String valueLine = list.get(lineIndex);
|
||||
String value = parseValueLine(valueLine);
|
||||
log(lineIndex + ": value: " + value);
|
||||
lineIndex++;
|
||||
|
||||
String packageLine = list.get(lineIndex);
|
||||
|
||||
String packageName = packageLine.split("=")[1].trim();
|
||||
packageName = cutLastSymbol(packageName);
|
||||
log(lineIndex + ": package: " + packageName);
|
||||
lineIndex++;
|
||||
|
||||
String package_value = packageName + "_" + value;
|
||||
List<BomComponent> l = componentsByKey.get(package_value);
|
||||
if (l == null) {
|
||||
l = new ArrayList<BomComponent>();
|
||||
componentsByKey.put(package_value, l);
|
||||
}
|
||||
l.add(new BomComponent(reference));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static String parseValueLine(String s) {
|
||||
String value = s.split("=")[1].trim();
|
||||
return cutLastSymbol(value);
|
||||
}
|
||||
|
||||
private static String parseReferenceLine(String line) {
|
||||
String reference = line.split("=")[1].trim();
|
||||
return cutLastSymbol(reference);
|
||||
}
|
||||
|
||||
private static String cutLastSymbol(String reference) {
|
||||
return reference.substring(0, reference.length() - 1);
|
||||
}
|
||||
}
|
||||
package com.rusefi.bom;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.TreeMap;
|
||||
|
||||
import static com.rusefi.bom.BomBuilder.log;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/22/14
|
||||
*/
|
||||
public class CpmFileModel {
|
||||
|
||||
public final Map<String, List<BomComponent>> componentsByKey = new TreeMap<String, List<BomComponent>>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
public int linesCount;
|
||||
public int componentsCount;
|
||||
|
||||
|
||||
public void readCmpFile(List<String> list) throws IOException {
|
||||
linesCount = list.size();
|
||||
componentsCount = 0;
|
||||
|
||||
for (int lineIndex = 0; lineIndex < list.size(); lineIndex++) {
|
||||
String line = list.get(lineIndex);
|
||||
if ("BeginCmp".equals(line)) {
|
||||
componentsCount++;
|
||||
|
||||
lineIndex += 2; // skipping 'TimeStamp' line
|
||||
|
||||
String a = list.get(lineIndex);
|
||||
String reference = parseReferenceLine(a);
|
||||
log(lineIndex + ": reference: " + reference);
|
||||
lineIndex++;
|
||||
|
||||
String valueLine = list.get(lineIndex);
|
||||
String value = parseValueLine(valueLine);
|
||||
log(lineIndex + ": value: " + value);
|
||||
lineIndex++;
|
||||
|
||||
String packageLine = list.get(lineIndex);
|
||||
|
||||
String packageName = packageLine.split("=")[1].trim();
|
||||
packageName = cutLastSymbol(packageName);
|
||||
log(lineIndex + ": package: " + packageName);
|
||||
lineIndex++;
|
||||
|
||||
String package_value = packageName + "_" + value;
|
||||
List<BomComponent> l = componentsByKey.get(package_value);
|
||||
if (l == null) {
|
||||
l = new ArrayList<BomComponent>();
|
||||
componentsByKey.put(package_value, l);
|
||||
}
|
||||
l.add(new BomComponent(reference));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static String parseValueLine(String s) {
|
||||
String value = s.split("=")[1].trim();
|
||||
return cutLastSymbol(value);
|
||||
}
|
||||
|
||||
private static String parseReferenceLine(String line) {
|
||||
String reference = line.split("=")[1].trim();
|
||||
return cutLastSymbol(reference);
|
||||
}
|
||||
|
||||
private static String cutLastSymbol(String reference) {
|
||||
return reference.substring(0, reference.length() - 1);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,97 +1,105 @@
|
|||
package com.rusefi.misc;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
import java.util.TreeSet;
|
||||
|
||||
import static com.rusefi.pcb.PcbMergeTool.log;
|
||||
|
||||
/**
|
||||
* 1/19/14
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class ChangesModel {
|
||||
private static final ChangesModel instance = new ChangesModel();
|
||||
private static final String REMOVE = "remove";
|
||||
private static final String ADD = "add";
|
||||
private static final String MOVE = "move_module";
|
||||
private static final String OPTIMIZE = "optimize";
|
||||
private static final String COPY = "copy";
|
||||
|
||||
public final Set<String> DEL_REQUESTS = new TreeSet<String>(String.CASE_INSENSITIVE_ORDER);
|
||||
public final List<NameAndOffset> ADD_REQUESTS = new ArrayList<NameAndOffset>();
|
||||
public final List<NameAndOffset> MOVE_REQUESTS = new ArrayList<NameAndOffset>();
|
||||
|
||||
public final List<TwoFileRequest> OPTIMIZE_REQUESTS = new ArrayList<TwoFileRequest>();
|
||||
public final List<TwoFileRequest> COPY_REQUESTS = new ArrayList<TwoFileRequest>();
|
||||
|
||||
public static ChangesModel getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
public static void readConfiguration(String fileName) throws IOException {
|
||||
if (!new File(fileName).isFile()) {
|
||||
log("No such file: " + fileName);
|
||||
return;
|
||||
}
|
||||
log("Reading commands from " + fileName);
|
||||
List<String> a = FileUtils.readFileToList(fileName);
|
||||
|
||||
getInstance().read(a);
|
||||
}
|
||||
|
||||
public void read(List<String> lines) {
|
||||
int lineIndex = 0;
|
||||
for (String line : lines) {
|
||||
lineIndex++;
|
||||
line = line.trim();
|
||||
if (line.isEmpty())
|
||||
continue;
|
||||
if (line.startsWith("#"))
|
||||
continue; // this line is a comment
|
||||
|
||||
if (line.toLowerCase().startsWith(REMOVE)) {
|
||||
DEL_REQUESTS.add(line.substring(REMOVE.length()).trim());
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(ADD)) {
|
||||
addAddRequest(line.substring(ADD.length()).trim());
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(MOVE)) {
|
||||
addMoveRequest(line.substring(MOVE.length()).trim());
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(OPTIMIZE)) {
|
||||
OPTIMIZE_REQUESTS.add(TwoFileRequest.parseTwoFile(line.substring(OPTIMIZE.length()).trim(), lineIndex));
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(COPY)) {
|
||||
COPY_REQUESTS.add(TwoFileRequest.parseTwoFile(line.substring(COPY.length()).trim(), lineIndex));
|
||||
continue;
|
||||
}
|
||||
|
||||
System.err.println("ChangesModel: Ignoring invalid line: " + line);
|
||||
|
||||
}
|
||||
log("Got " + DEL_REQUESTS.size() + " remove request(s)");
|
||||
log("Got " + ADD_REQUESTS.size() + " add request(s)");
|
||||
log("Got " + OPTIMIZE_REQUESTS.size() + " optimize request(s)");
|
||||
}
|
||||
|
||||
private void addMoveRequest(String request) {
|
||||
MOVE_REQUESTS.add(NameAndOffset.parseNameAndOffset(request));
|
||||
}
|
||||
|
||||
private void addAddRequest(String request) {
|
||||
ADD_REQUESTS.add(NameAndOffset.parseNameAndOffset(request));
|
||||
}
|
||||
|
||||
public void clear() {
|
||||
DEL_REQUESTS.clear();
|
||||
ADD_REQUESTS.clear();
|
||||
OPTIMIZE_REQUESTS.clear();
|
||||
MOVE_REQUESTS.clear();
|
||||
}
|
||||
}
|
||||
package com.rusefi.misc;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.*;
|
||||
|
||||
import static com.rusefi.pcb.PcbMergeTool.log;
|
||||
|
||||
/**
|
||||
* 1/19/14
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class ChangesModel {
|
||||
private static final ChangesModel instance = new ChangesModel();
|
||||
private static final String REMOVE = "remove";
|
||||
private static final String ADD = "add";
|
||||
private static final String MOVE = "move_module";
|
||||
private static final String OPTIMIZE = "optimize";
|
||||
private static final String COPY = "copy";
|
||||
private static final String MERGE_NET = "merge_net";
|
||||
|
||||
public final Set<String> DEL_REQUESTS = new TreeSet<String>(String.CASE_INSENSITIVE_ORDER);
|
||||
public final List<NameAndOffset> ADD_REQUESTS = new ArrayList<NameAndOffset>();
|
||||
public final List<NameAndOffset> MOVE_REQUESTS = new ArrayList<NameAndOffset>();
|
||||
|
||||
public final List<TwoFileRequest> OPTIMIZE_REQUESTS = new ArrayList<TwoFileRequest>();
|
||||
public final List<TwoFileRequest> COPY_REQUESTS = new ArrayList<TwoFileRequest>();
|
||||
/**
|
||||
* Old net name > New net name
|
||||
*/
|
||||
public final Map<String, String> NET_MERGE_REQUESTS = new TreeMap<String, String>(String.CASE_INSENSITIVE_ORDER);
|
||||
|
||||
public static ChangesModel getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
public static void readConfiguration(String fileName) throws IOException {
|
||||
if (!new File(fileName).isFile()) {
|
||||
log("No such file: " + fileName);
|
||||
return;
|
||||
}
|
||||
log("Reading commands from " + fileName);
|
||||
List<String> a = FileUtils.readFileToList(fileName);
|
||||
|
||||
getInstance().read(a);
|
||||
}
|
||||
|
||||
public void read(List<String> lines) {
|
||||
int lineIndex = 0;
|
||||
for (String line : lines) {
|
||||
lineIndex++;
|
||||
line = line.trim();
|
||||
if (line.isEmpty())
|
||||
continue;
|
||||
if (line.startsWith("#"))
|
||||
continue; // this line is a comment
|
||||
|
||||
if (line.toLowerCase().startsWith(REMOVE)) {
|
||||
DEL_REQUESTS.add(line.substring(REMOVE.length()).trim());
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(ADD)) {
|
||||
addAddRequest(line.substring(ADD.length()).trim());
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(MOVE)) {
|
||||
addMoveRequest(line.substring(MOVE.length()).trim());
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(OPTIMIZE)) {
|
||||
OPTIMIZE_REQUESTS.add(TwoFileRequest.parseTwoFile(line.substring(OPTIMIZE.length()).trim(), lineIndex));
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(COPY)) {
|
||||
COPY_REQUESTS.add(TwoFileRequest.parseTwoFile(line.substring(COPY.length()).trim(), lineIndex));
|
||||
continue;
|
||||
} else if (line.toLowerCase().startsWith(MERGE_NET)) {
|
||||
TwoFileRequest req = TwoFileRequest.parseTwoFile(line.substring(MERGE_NET.length()).trim(), lineIndex);
|
||||
NET_MERGE_REQUESTS.put(req.input, req.output);
|
||||
log("Net " + req.input + " to be merged into " + req.output);
|
||||
continue;
|
||||
}
|
||||
|
||||
System.err.println("ChangesModel: Ignoring invalid line: " + line);
|
||||
|
||||
}
|
||||
log("Got " + DEL_REQUESTS.size() + " remove request(s)");
|
||||
log("Got " + ADD_REQUESTS.size() + " add request(s)");
|
||||
log("Got " + OPTIMIZE_REQUESTS.size() + " optimize request(s)");
|
||||
log("Got " + NET_MERGE_REQUESTS.size() + " merge net request(s)");
|
||||
}
|
||||
|
||||
private void addMoveRequest(String request) {
|
||||
MOVE_REQUESTS.add(NameAndOffset.parseNameAndOffset(request));
|
||||
}
|
||||
|
||||
private void addAddRequest(String request) {
|
||||
ADD_REQUESTS.add(NameAndOffset.parseNameAndOffset(request));
|
||||
}
|
||||
|
||||
public void clear() {
|
||||
DEL_REQUESTS.clear();
|
||||
ADD_REQUESTS.clear();
|
||||
OPTIMIZE_REQUESTS.clear();
|
||||
MOVE_REQUESTS.clear();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,43 +1,43 @@
|
|||
package com.rusefi.misc;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class CmpMergeTool {
|
||||
private CmpMergeTool() {
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 2) {
|
||||
System.out.println("This tool merges .cmp KiCad component mappting files");
|
||||
System.out.println("usage:");
|
||||
System.out.println("NetListMerge DEST_FILE SOURCE_1 SOURCE_2 [SOURCE_x]*");
|
||||
return;
|
||||
}
|
||||
|
||||
String destinationFile = args[0];
|
||||
|
||||
System.out.println("Writing result into " + destinationFile);
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(destinationFile));
|
||||
|
||||
bw.write("Cmp-Mod V01 Created by CvPcb (2013-07-07 BZR 4022)-stable date = 01/12/2013 21:54:01\r\n");
|
||||
|
||||
for (int i = 1; i < args.length; i++) {
|
||||
String sourceFile = args[i];
|
||||
|
||||
List<String> list = FileUtils.readFileToList(sourceFile);
|
||||
|
||||
for (String line : list.subList(1, list.size() - 2))
|
||||
bw.write(line + "\r\n");
|
||||
}
|
||||
|
||||
bw.write("\r\nEndListe\r\n");
|
||||
bw.close();
|
||||
}
|
||||
}
|
||||
package com.rusefi.misc;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 12/8/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class CmpMergeTool {
|
||||
private CmpMergeTool() {
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length < 2) {
|
||||
System.out.println("This tool merges .cmp KiCad component mappting files");
|
||||
System.out.println("usage:");
|
||||
System.out.println("NetListMerge DEST_FILE SOURCE_1 SOURCE_2 [SOURCE_x]*");
|
||||
return;
|
||||
}
|
||||
|
||||
String destinationFile = args[0];
|
||||
|
||||
System.out.println("Writing result into " + destinationFile);
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(destinationFile));
|
||||
|
||||
bw.write("Cmp-Mod V01 Created by CvPcb (2013-07-07 BZR 4022)-stable date = 01/12/2013 21:54:01\r\n");
|
||||
|
||||
for (int i = 1; i < args.length; i++) {
|
||||
String sourceFile = args[i];
|
||||
|
||||
List<String> list = FileUtils.readFileToList(sourceFile);
|
||||
|
||||
for (String line : list.subList(1, list.size() - 2))
|
||||
bw.write(line + "\r\n");
|
||||
}
|
||||
|
||||
bw.write("\r\nEndListe\r\n");
|
||||
bw.close();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,36 +1,36 @@
|
|||
package com.rusefi.misc;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class NameAndOffset {
|
||||
private final String name;
|
||||
public final double x;
|
||||
public final double y;
|
||||
|
||||
public NameAndOffset(String name, double x, double y) {
|
||||
this.name = name;
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
}
|
||||
|
||||
static NameAndOffset parseNameAndOffset(String request) {
|
||||
String[] tokens = request.split(" ");
|
||||
NameAndOffset result;
|
||||
if (tokens.length == 1) {
|
||||
result = new NameAndOffset(tokens[0], 0, 0);
|
||||
} else if (tokens.length == 3) {
|
||||
double x = Double.parseDouble(tokens[1]);
|
||||
double y = Double.parseDouble(tokens[2]);
|
||||
result = new NameAndOffset(tokens[0], x, y);
|
||||
} else {
|
||||
throw new IllegalArgumentException("Invalid: " + request);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
package com.rusefi.misc;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class NameAndOffset {
|
||||
private final String name;
|
||||
public final double x;
|
||||
public final double y;
|
||||
|
||||
public NameAndOffset(String name, double x, double y) {
|
||||
this.name = name;
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
}
|
||||
|
||||
static NameAndOffset parseNameAndOffset(String request) {
|
||||
String[] tokens = request.split(" ");
|
||||
NameAndOffset result;
|
||||
if (tokens.length == 1) {
|
||||
result = new NameAndOffset(tokens[0], 0, 0);
|
||||
} else if (tokens.length == 3) {
|
||||
double x = Double.parseDouble(tokens[1]);
|
||||
double y = Double.parseDouble(tokens[2]);
|
||||
result = new NameAndOffset(tokens[0], x, y);
|
||||
} else {
|
||||
throw new IllegalArgumentException("Invalid: " + request);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,138 +1,138 @@
|
|||
package com.rusefi.misc;
|
||||
|
||||
import com.rusefi.pcb.*;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class RemoveUnneededTraces {
|
||||
private final static Set<String> alreadyRemoved = new HashSet<String>();
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 2) {
|
||||
System.out.println("two parameters expected: INPUT_FILE OUTPUT_FILE");
|
||||
return;
|
||||
}
|
||||
String input = args[0];
|
||||
String output = args[1];
|
||||
|
||||
optimize(input, output);
|
||||
}
|
||||
|
||||
public static void optimize(String input, String output) throws IOException {
|
||||
PcbNode destNode = PcbNode.readFromFile(input);
|
||||
|
||||
|
||||
while (removeUnusedSegments(destNode) || removeUnusedVias(destNode)) {
|
||||
System.out.println("Still removing...");
|
||||
}
|
||||
|
||||
destNode.write(output);
|
||||
}
|
||||
|
||||
private static boolean removeUnusedVias(PcbNode destNode) {
|
||||
List<ViaNode> unused = findUnusedVias(destNode);
|
||||
for (ViaNode via : unused) {
|
||||
System.out.println("Removing via: " + via);
|
||||
boolean removed = destNode.removeChild(via);
|
||||
if (!removed)
|
||||
throw new IllegalStateException("not removed: " + removed);
|
||||
|
||||
}
|
||||
return !unused.isEmpty();
|
||||
}
|
||||
|
||||
private static List<ViaNode> findUnusedVias(PcbNode destNode) {
|
||||
List<ViaNode> result = new ArrayList<ViaNode>();
|
||||
|
||||
List<PcbNode> stuff = destNode.iterate("segment");
|
||||
// stuff.addAll(destNode.iterate("segment"));
|
||||
|
||||
for (PcbNode n : destNode.iterate("via")) {
|
||||
ViaNode via = (ViaNode) n;
|
||||
|
||||
int count = 0;
|
||||
|
||||
for (PcbNode segment : stuff)
|
||||
if (segment.isConnected(via.location))
|
||||
count++;
|
||||
|
||||
if (via.netId == NetNode.GND_NET_ID) {
|
||||
if (count == 0)
|
||||
result.add(via);
|
||||
} else {
|
||||
if (count < 2)
|
||||
result.add(via);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
private static boolean removeUnusedSegments(PcbNode destNode) {
|
||||
List<PcbNode> stuff = new ArrayList<PcbNode>(destNode.iterate("module"));
|
||||
stuff.addAll(destNode.iterate("via"));
|
||||
|
||||
|
||||
Object o = destNode.iterate("segment");
|
||||
List<SegmentNode> segments = (List<SegmentNode>) o;
|
||||
System.out.println(segments.size() + " segment(s)");
|
||||
|
||||
List<SegmentNode> unused = findUnusedSegments(segments, stuff);
|
||||
for (SegmentNode segment : unused) {
|
||||
boolean removed = destNode.removeChild(segment);
|
||||
if (!removed)
|
||||
throw new IllegalStateException();
|
||||
String netName = segment.net.id;
|
||||
if (!alreadyRemoved.contains(netName)) {
|
||||
alreadyRemoved.add(netName);
|
||||
System.out.println("Unused segment in network " + netName + ": " + segment);
|
||||
}
|
||||
}
|
||||
return !unused.isEmpty();
|
||||
}
|
||||
|
||||
private static List<SegmentNode> findUnusedSegments(List<SegmentNode> segments, List<PcbNode> modules) {
|
||||
List<SegmentNode> unused = new ArrayList<SegmentNode>();
|
||||
for (SegmentNode segment : segments) {
|
||||
if (isUnused(segments, segment, modules)) {
|
||||
// System.out.println("Unused on " + segment.net.id + ": " + segment);
|
||||
unused.add(segment);
|
||||
}
|
||||
}
|
||||
return unused;
|
||||
}
|
||||
|
||||
public static boolean isUnused(List<SegmentNode> segments, SegmentNode segment, List<PcbNode> modules) {
|
||||
PointNode start = segment.start;
|
||||
PointNode end = segment.end;
|
||||
if (isConnected(start, segments, segment) == null && isConnected(start, modules, null) == null) {
|
||||
System.out.println("Not connected start: " + segment);
|
||||
return true;
|
||||
}
|
||||
|
||||
PcbNode endModule = isConnected(end, modules, null);
|
||||
if (isConnected(end, segments, segment) == null && endModule == null) {
|
||||
System.out.println("Not connected end: " + segment);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private static PcbNode isConnected(PointNode point, List<? extends PcbNode> elements, SegmentNode parent) {
|
||||
for (PcbNode segmentNode : elements) {
|
||||
if (segmentNode == parent)
|
||||
continue;
|
||||
|
||||
if (segmentNode.isConnected(point))
|
||||
return segmentNode;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
||||
package com.rusefi.misc;
|
||||
|
||||
import com.rusefi.pcb.*;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class RemoveUnneededTraces {
|
||||
private final static Set<String> alreadyRemoved = new HashSet<String>();
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 2) {
|
||||
System.out.println("two parameters expected: INPUT_FILE OUTPUT_FILE");
|
||||
return;
|
||||
}
|
||||
String input = args[0];
|
||||
String output = args[1];
|
||||
|
||||
optimize(input, output);
|
||||
}
|
||||
|
||||
public static void optimize(String input, String output) throws IOException {
|
||||
PcbNode destNode = PcbNode.readFromFile(input);
|
||||
|
||||
|
||||
while (removeUnusedSegments(destNode) || removeUnusedVias(destNode)) {
|
||||
System.out.println("Still removing...");
|
||||
}
|
||||
|
||||
destNode.write(output);
|
||||
}
|
||||
|
||||
private static boolean removeUnusedVias(PcbNode destNode) {
|
||||
List<ViaNode> unused = findUnusedVias(destNode);
|
||||
for (ViaNode via : unused) {
|
||||
System.out.println("Removing via: " + via);
|
||||
boolean removed = destNode.removeChild(via);
|
||||
if (!removed)
|
||||
throw new IllegalStateException("not removed: " + removed);
|
||||
|
||||
}
|
||||
return !unused.isEmpty();
|
||||
}
|
||||
|
||||
private static List<ViaNode> findUnusedVias(PcbNode destNode) {
|
||||
List<ViaNode> result = new ArrayList<ViaNode>();
|
||||
|
||||
List<PcbNode> stuff = destNode.iterate("segment");
|
||||
// stuff.addAll(destNode.iterate("segment"));
|
||||
|
||||
for (PcbNode n : destNode.iterate("via")) {
|
||||
ViaNode via = (ViaNode) n;
|
||||
|
||||
int count = 0;
|
||||
|
||||
for (PcbNode segment : stuff)
|
||||
if (segment.isConnected(via.location))
|
||||
count++;
|
||||
|
||||
if (via.netId == NetNode.GND_NET_ID) {
|
||||
if (count == 0)
|
||||
result.add(via);
|
||||
} else {
|
||||
if (count < 2)
|
||||
result.add(via);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
private static boolean removeUnusedSegments(PcbNode destNode) {
|
||||
List<PcbNode> stuff = new ArrayList<PcbNode>(destNode.iterate("module"));
|
||||
stuff.addAll(destNode.iterate("via"));
|
||||
|
||||
|
||||
Object o = destNode.iterate("segment");
|
||||
List<SegmentNode> segments = (List<SegmentNode>) o;
|
||||
System.out.println(segments.size() + " segment(s)");
|
||||
|
||||
List<SegmentNode> unused = findUnusedSegments(segments, stuff);
|
||||
for (SegmentNode segment : unused) {
|
||||
boolean removed = destNode.removeChild(segment);
|
||||
if (!removed)
|
||||
throw new IllegalStateException();
|
||||
String netName = segment.net.id;
|
||||
if (!alreadyRemoved.contains(netName)) {
|
||||
alreadyRemoved.add(netName);
|
||||
System.out.println("Unused segment in network " + netName + ": " + segment);
|
||||
}
|
||||
}
|
||||
return !unused.isEmpty();
|
||||
}
|
||||
|
||||
private static List<SegmentNode> findUnusedSegments(List<SegmentNode> segments, List<PcbNode> modules) {
|
||||
List<SegmentNode> unused = new ArrayList<SegmentNode>();
|
||||
for (SegmentNode segment : segments) {
|
||||
if (isUnused(segments, segment, modules)) {
|
||||
// System.out.println("Unused on " + segment.net.id + ": " + segment);
|
||||
unused.add(segment);
|
||||
}
|
||||
}
|
||||
return unused;
|
||||
}
|
||||
|
||||
public static boolean isUnused(List<SegmentNode> segments, SegmentNode segment, List<PcbNode> modules) {
|
||||
PointNode start = segment.start;
|
||||
PointNode end = segment.end;
|
||||
if (isConnected(start, segments, segment) == null && isConnected(start, modules, null) == null) {
|
||||
System.out.println("Not connected start: " + segment);
|
||||
return true;
|
||||
}
|
||||
|
||||
PcbNode endModule = isConnected(end, modules, null);
|
||||
if (isConnected(end, segments, segment) == null && endModule == null) {
|
||||
System.out.println("Not connected end: " + segment);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private static PcbNode isConnected(PointNode point, List<? extends PcbNode> elements, SegmentNode parent) {
|
||||
for (PcbNode segmentNode : elements) {
|
||||
if (segmentNode == parent)
|
||||
continue;
|
||||
|
||||
if (segmentNode.isConnected(point))
|
||||
return segmentNode;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,23 +1,23 @@
|
|||
package com.rusefi.misc;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class TwoFileRequest {
|
||||
public final String input;
|
||||
public final String output;
|
||||
|
||||
public TwoFileRequest(String input, String output) {
|
||||
this.input = input;
|
||||
this.output = output;
|
||||
}
|
||||
|
||||
static TwoFileRequest parseTwoFile(String request, int lineIndex) {
|
||||
String[] tokens = request.split(" ");
|
||||
if (tokens.length != 2)
|
||||
throw new IllegalArgumentException("Unexpected token count in [" + request + "] @" + lineIndex);
|
||||
|
||||
return new TwoFileRequest(tokens[0], tokens[1]);
|
||||
}
|
||||
}
|
||||
package com.rusefi.misc;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class TwoFileRequest {
|
||||
public final String input;
|
||||
public final String output;
|
||||
|
||||
public TwoFileRequest(String input, String output) {
|
||||
this.input = input;
|
||||
this.output = output;
|
||||
}
|
||||
|
||||
static TwoFileRequest parseTwoFile(String request, int lineIndex) {
|
||||
String[] tokens = request.split(" ");
|
||||
if (tokens.length != 2)
|
||||
throw new IllegalArgumentException("Unexpected token count in [" + request + "] @" + lineIndex);
|
||||
|
||||
return new TwoFileRequest(tokens[0], tokens[1]);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 1/21/14.
|
||||
*/
|
||||
public class CirclePadNode extends PadNode {
|
||||
public CirclePadNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "CirclePadNode{" +
|
||||
"at=" + at +
|
||||
", size=" + size +
|
||||
'}';
|
||||
}
|
||||
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 1/21/14.
|
||||
*/
|
||||
public class CirclePadNode extends PadNode {
|
||||
public CirclePadNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "CirclePadNode{" +
|
||||
"at=" + at +
|
||||
", size=" + size +
|
||||
'}';
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 2/7/14.
|
||||
*/
|
||||
public class GrLineNode extends PcbNode {
|
||||
public final LayerNode layerNode;
|
||||
public GrLineNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
layerNode = (LayerNode) find("layer");
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 2/7/14.
|
||||
*/
|
||||
public class GrLineNode extends PcbNode {
|
||||
public final LayerNode layerNode;
|
||||
public GrLineNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
layerNode = (LayerNode) find("layer");
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,20 +1,20 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 2/7/14.
|
||||
*/
|
||||
public class LayerNode extends PcbNode {
|
||||
public final String name;
|
||||
|
||||
public LayerNode(String nodeName, int closingIndex, List<Object> children) {
|
||||
super(nodeName, closingIndex, children);
|
||||
name = (String) children.get(0);
|
||||
}
|
||||
|
||||
boolean isSikscreenLayer() {
|
||||
return name.equals("B.SilkS") || name.equals("F.SilkS");
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 2/7/14.
|
||||
*/
|
||||
public class LayerNode extends PcbNode {
|
||||
public final String name;
|
||||
|
||||
public LayerNode(String nodeName, int closingIndex, List<Object> children) {
|
||||
super(nodeName, closingIndex, children);
|
||||
name = (String) children.get(0);
|
||||
}
|
||||
|
||||
boolean isSikscreenLayer() {
|
||||
return name.equals("B.SilkS") || name.equals("F.SilkS");
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,41 +1,45 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class ModuleNode extends PcbNode {
|
||||
final List<PadNode> pads;
|
||||
public final PointNode at;
|
||||
public final String name;
|
||||
|
||||
public ModuleNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
Object o = iterate("pad");
|
||||
pads = (List<PadNode>) o;
|
||||
at = (PointNode) find("at");
|
||||
|
||||
name = iterate("fp_text").get(0).getChild(1);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "ModuleNode{" +
|
||||
"name=" + name +
|
||||
", pads.size=" + pads.size() +
|
||||
'}';
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isConnected(PointNode point) {
|
||||
PointNode offsetPoint = at.translate(point);
|
||||
|
||||
for (PadNode pad : pads) {
|
||||
if (pad.isConnected(offsetPoint))
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class ModuleNode extends PcbNode {
|
||||
final List<PadNode> pads;
|
||||
public final PointNode at;
|
||||
private final String reference;
|
||||
|
||||
public ModuleNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
Object o = iterate("pad");
|
||||
pads = (List<PadNode>) o;
|
||||
at = (PointNode) find("at");
|
||||
|
||||
reference = iterate("fp_text").get(0).getChild(1);
|
||||
}
|
||||
|
||||
public String getReference() {
|
||||
return reference;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "ModuleNode{" +
|
||||
"reference=" + reference +
|
||||
", pads.size=" + pads.size() +
|
||||
'}';
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isConnected(PointNode point) {
|
||||
PointNode offsetPoint = at.translate(point);
|
||||
|
||||
for (PadNode pad : pads) {
|
||||
if (pad.isConnected(offsetPoint))
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,31 +1,31 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class NetNode extends PcbNode {
|
||||
public final String id;
|
||||
final String name;
|
||||
public static int GND_NET_ID;
|
||||
|
||||
public NetNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
id = getChild(0);
|
||||
name = children.size() > 1 ? getChild(1) : null;
|
||||
if (name != null)
|
||||
System.out.println(name + " network: " + id);
|
||||
|
||||
if ("GND".equalsIgnoreCase(name))
|
||||
GND_NET_ID = Integer.parseInt(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "NetNode{" +
|
||||
"id='" + id + '\'' +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class NetNode extends PcbNode {
|
||||
public final String id;
|
||||
final String name;
|
||||
public static int GND_NET_ID;
|
||||
|
||||
public NetNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
id = getChild(0);
|
||||
name = children.size() > 1 ? getChild(1) : null;
|
||||
if (name != null)
|
||||
System.out.println("NetNode(" + name + " network: " + id + ")");
|
||||
|
||||
if ("GND".equalsIgnoreCase(name))
|
||||
GND_NET_ID = Integer.parseInt(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "NetNode{" +
|
||||
"id='" + id + '\'' +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,42 +1,44 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 1/21/14.
|
||||
*/
|
||||
public abstract class PadNode extends PcbNode {
|
||||
protected final PointNode at;
|
||||
protected final SizeNode size;
|
||||
protected final String name;
|
||||
|
||||
public PadNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
name = (String) children.get(0);
|
||||
at = (PointNode) find("at");
|
||||
size = (SizeNode) find("size");
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isConnected(PointNode point) {
|
||||
return point.isConnected(at, size);
|
||||
}
|
||||
|
||||
public static PcbNode parse(String nodeName, int i, List<Object> children) {
|
||||
Object shape = children.get(2);
|
||||
if ("rect".equals(shape))
|
||||
return new RectPadNode(nodeName, i, children);
|
||||
if ("circle".equals(shape))
|
||||
return new CirclePadNode(nodeName, i, children);
|
||||
throw new IllegalStateException(shape.toString());
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "PadNode{" +
|
||||
"at=" + at +
|
||||
", size=" + size +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 1/21/14.
|
||||
*/
|
||||
public abstract class PadNode extends PcbNode {
|
||||
protected final PointNode at;
|
||||
protected final SizeNode size;
|
||||
protected final String name;
|
||||
|
||||
public PadNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
name = (String) children.get(0);
|
||||
at = (PointNode) find("at");
|
||||
size = (SizeNode) find("size");
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isConnected(PointNode point) {
|
||||
return point.isConnected(at, size);
|
||||
}
|
||||
|
||||
public static PcbNode parse(String nodeName, int i, List<Object> children) {
|
||||
Object shape = children.get(2);
|
||||
if ("rect".equals(shape))
|
||||
return new RectPadNode(nodeName, i, children);
|
||||
if ("circle".equals(shape))
|
||||
return new CirclePadNode(nodeName, i, children);
|
||||
if ("oval".equals(shape))
|
||||
return new CirclePadNode(nodeName, i, children); // yes, let's treat oval as circle. good enough
|
||||
throw new IllegalStateException("Unknown pad shape: " + shape.toString());
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "PadNode{" +
|
||||
"at=" + at +
|
||||
", size=" + size +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,214 +1,260 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import com.rusefi.PcbCopyTool;
|
||||
import com.rusefi.misc.NameAndOffset;
|
||||
import com.rusefi.misc.ChangesModel;
|
||||
import com.rusefi.misc.RemoveUnneededTraces;
|
||||
import com.rusefi.misc.TwoFileRequest;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/16/13.
|
||||
*/
|
||||
public class PcbMergeTool {
|
||||
private static Networks networks = new Networks();
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 3) {
|
||||
System.out.println("Three parameters expected: SOURCE_PCB_FILENAME DESTINATION_PCB_FILENAME CHANGES_LIST_FILENAME");
|
||||
return;
|
||||
}
|
||||
String sourcePcb = args[0];
|
||||
String destination = args[1];
|
||||
String changes = args[2];
|
||||
|
||||
ChangesModel.readConfiguration(changes);
|
||||
|
||||
log("Running COPY commands");
|
||||
for (TwoFileRequest or : ChangesModel.getInstance().COPY_REQUESTS)
|
||||
PcbCopyTool.copy(or.input, or.output);
|
||||
|
||||
log("Running OPTIMIZE commands");
|
||||
for (TwoFileRequest or : ChangesModel.getInstance().OPTIMIZE_REQUESTS)
|
||||
RemoveUnneededTraces.optimize(or.input, or.output);
|
||||
|
||||
PcbNode destNode = PcbNode.readFromFile(sourcePcb);
|
||||
|
||||
log("Running ADD commands");
|
||||
for (NameAndOffset addRequest : ChangesModel.getInstance().ADD_REQUESTS) {
|
||||
PcbNode node = PcbMoveTool.readAndMove(addRequest.getName(), addRequest.x, addRequest.y);
|
||||
|
||||
mergePcb(destNode, node);
|
||||
}
|
||||
|
||||
log("Running MOVE commands");
|
||||
for (NameAndOffset moveRequest : ChangesModel.getInstance().MOVE_REQUESTS) {
|
||||
String moduleName = moveRequest.getName();
|
||||
ModuleNode module = findModuleByName(destNode, moduleName);
|
||||
if (module == null) {
|
||||
log("Module not found: " + moduleName);
|
||||
continue;
|
||||
}
|
||||
|
||||
PointNode at = module.at;
|
||||
at.setLocation(at.x + moveRequest.x, at.y + moveRequest.y);
|
||||
}
|
||||
|
||||
removeNodes(destNode);
|
||||
|
||||
destNode.write(destination);
|
||||
|
||||
RemoveUnneededTraces.optimize(destination, destination);
|
||||
}
|
||||
|
||||
private static ModuleNode findModuleByName(PcbNode destNode, String moduleName) {
|
||||
for (PcbNode node : destNode.iterate("module")) {
|
||||
ModuleNode mn = (ModuleNode) node;
|
||||
if (moduleName.toLowerCase().equals(mn.name.toLowerCase()))
|
||||
return mn;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private static void mergePcb(PcbNode destNode, PcbNode source) throws IOException {
|
||||
Map<String, String> netNameMapping = new HashMap<String, String>();
|
||||
Map<String, Integer> netIdMapping = new HashMap<String, Integer>();
|
||||
|
||||
for (PcbNode net : source.iterate("net")) {
|
||||
String netId = net.getChild(0);
|
||||
String netName = net.getChild(1);
|
||||
String newName = networks.registerNetworkIfPcbSpecific(netName);
|
||||
netNameMapping.put(netName, newName);
|
||||
netIdMapping.put(netId, networks.getId(newName));
|
||||
}
|
||||
|
||||
List<PcbNode> zones = source.iterate("zone");
|
||||
log("Processing " + zones.size() + " zone(s)");
|
||||
for (PcbNode z : zones) {
|
||||
ZoneNode zone = (ZoneNode) z;
|
||||
if (zone.getLayerNode().isSikscreenLayer())
|
||||
destNode.addChild(zone);
|
||||
}
|
||||
|
||||
List<PcbNode> arcs = source.iterate("gr_arc");
|
||||
log("Processing " + arcs.size() + " arc(s)");
|
||||
for (PcbNode arc : arcs)
|
||||
destNode.addChild(arc);
|
||||
|
||||
|
||||
List<PcbNode> lines = source.iterate("gr_line");
|
||||
log("Processing " + lines.size() + " line(s)");
|
||||
for (PcbNode l : lines) {
|
||||
GrLineNode line = (GrLineNode) l;
|
||||
if (line.layerNode.isSikscreenLayer())
|
||||
destNode.addChild(line);
|
||||
}
|
||||
|
||||
|
||||
List<PcbNode> labels = source.iterate("gr_text");
|
||||
log("Processing " + labels.size() + " label(s)");
|
||||
for (PcbNode label : labels) {
|
||||
destNode.addChild(label);
|
||||
}
|
||||
|
||||
List<PcbNode> modules = source.iterate("module");
|
||||
log("Processing " + modules.size() + " module(s)");
|
||||
for (PcbNode module : modules) {
|
||||
for (PcbNode pad : module.iterate("pad")) {
|
||||
if (!pad.hasChild("net"))
|
||||
continue;
|
||||
PcbNode net = pad.find("net");
|
||||
String localName = netNameMapping.get(net.getChild(1));
|
||||
net.setString(1, localName);
|
||||
net.setInt(0, networks.getId(localName));
|
||||
}
|
||||
destNode.addChild(module);
|
||||
}
|
||||
|
||||
List<PcbNode> segments = source.iterate("segment");
|
||||
log("Processing " + segments.size() + " segments");
|
||||
for (PcbNode segment : segments) {
|
||||
// if (!segment.hasChild("net"))
|
||||
// continue;
|
||||
fixNetId(netIdMapping, segment);
|
||||
|
||||
destNode.addChild(segment);
|
||||
}
|
||||
|
||||
List<PcbNode> vias = source.iterate("via");
|
||||
log("Processing " + vias.size() + " vias");
|
||||
for (PcbNode via : vias) {
|
||||
fixNetId(netIdMapping, via);
|
||||
|
||||
destNode.addChild(via);
|
||||
}
|
||||
|
||||
// for (PcbNode zone : source.iterate("zone")) {
|
||||
// fixNetId(netIdMapping, zone);
|
||||
// destNode.addChild(zone);
|
||||
// }
|
||||
}
|
||||
|
||||
public static void removeNodes(PcbNode source) {
|
||||
for (PcbNode module : source.iterate("module")) {
|
||||
if (shouldRemove((ModuleNode) module))
|
||||
source.removeChild(module);
|
||||
}
|
||||
}
|
||||
|
||||
private static boolean shouldRemove(ModuleNode module) {
|
||||
for (PcbNode fp_text : module.iterate("fp_text")) {
|
||||
if ("reference".equals(fp_text.getChild(0))) {
|
||||
String name = fp_text.getChild(1);
|
||||
if (ChangesModel.getInstance().DEL_REQUESTS.contains(name))
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private static void fixNetId(Map<String, Integer> netIdMapping, PcbNode via) {
|
||||
PcbNode net = via.find("net");
|
||||
String originalId = net.getChild(0);
|
||||
net.setInt(0, netIdMapping.get(originalId));
|
||||
}
|
||||
|
||||
private static class Networks {
|
||||
private Map<String, Integer> networks = new HashMap<String, Integer>();
|
||||
|
||||
public String registerNetworkIfPcbSpecific(String name) {
|
||||
if (name.startsWith("N-00")) {
|
||||
String newName = "F-0000" + networks.size();
|
||||
log("Board-specific net: " + name + " would be " + newName);
|
||||
|
||||
networks.put(newName, networks.size());
|
||||
return newName;
|
||||
} else {
|
||||
if (networks.containsKey(name)) {
|
||||
log("Existing global net: " + name);
|
||||
return name;
|
||||
}
|
||||
|
||||
log("New global net: " + name);
|
||||
networks.put(name, networks.size());
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public int getId(String localName) {
|
||||
Integer value = networks.get(localName);
|
||||
if (value == null)
|
||||
throw new NullPointerException("No id for " + localName);
|
||||
return value;
|
||||
}
|
||||
}
|
||||
|
||||
public static void log(String s) {
|
||||
System.out.println(s);
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import com.rusefi.PcbCopyTool;
|
||||
import com.rusefi.misc.NameAndOffset;
|
||||
import com.rusefi.misc.ChangesModel;
|
||||
import com.rusefi.misc.RemoveUnneededTraces;
|
||||
import com.rusefi.misc.TwoFileRequest;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/16/13.
|
||||
*/
|
||||
public class PcbMergeTool {
|
||||
private static Networks networks = new Networks();
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 3) {
|
||||
System.out.println("Three parameters expected: SOURCE_PCB_FILENAME DESTINATION_PCB_FILENAME CHANGES_LIST_FILENAME");
|
||||
return;
|
||||
}
|
||||
String sourcePcb = args[0];
|
||||
String destination = args[1];
|
||||
String changes = args[2];
|
||||
|
||||
ChangesModel.readConfiguration(changes);
|
||||
|
||||
log("Running COPY commands");
|
||||
for (TwoFileRequest or : ChangesModel.getInstance().COPY_REQUESTS)
|
||||
PcbCopyTool.copy(or.input, or.output);
|
||||
|
||||
log("Running OPTIMIZE commands");
|
||||
for (TwoFileRequest or : ChangesModel.getInstance().OPTIMIZE_REQUESTS)
|
||||
RemoveUnneededTraces.optimize(or.input, or.output);
|
||||
|
||||
PcbNode destNode = PcbNode.readFromFile(sourcePcb);
|
||||
|
||||
|
||||
for (PcbNode net : destNode.iterate("net")) {
|
||||
String netName = net.getChild(1); // todo: nicer method?
|
||||
if (!Networks.isLocalNetwork(netName))
|
||||
networks.registerNetworkIfPcbSpecific(netName);
|
||||
}
|
||||
|
||||
log("Running ADD commands");
|
||||
for (NameAndOffset addRequest : ChangesModel.getInstance().ADD_REQUESTS) {
|
||||
PcbNode node = PcbMoveTool.readAndMove(addRequest.getName(), addRequest.x, addRequest.y);
|
||||
|
||||
mergePcb(destNode, node);
|
||||
}
|
||||
|
||||
log("Running MOVE commands");
|
||||
for (NameAndOffset moveRequest : ChangesModel.getInstance().MOVE_REQUESTS) {
|
||||
String moduleName = moveRequest.getName();
|
||||
ModuleNode module = findModuleByName(destNode, moduleName);
|
||||
if (module == null) {
|
||||
log("Module not found: " + moduleName);
|
||||
continue;
|
||||
}
|
||||
|
||||
PointNode at = module.at;
|
||||
at.setLocation(at.x + moveRequest.x, at.y + moveRequest.y);
|
||||
}
|
||||
|
||||
removeNodes(destNode);
|
||||
|
||||
destNode.write(destination);
|
||||
|
||||
RemoveUnneededTraces.optimize(destination, destination);
|
||||
}
|
||||
|
||||
private static ModuleNode findModuleByName(PcbNode destNode, String moduleName) {
|
||||
for (PcbNode node : destNode.iterate("module")) {
|
||||
ModuleNode mn = (ModuleNode) node;
|
||||
if (moduleName.toLowerCase().equals(mn.getReference().toLowerCase()))
|
||||
return mn;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private static void mergePcb(PcbNode destNode, PcbNode source) throws IOException {
|
||||
/**
|
||||
* original local net name > new net name in combined PCB
|
||||
*/
|
||||
Map<String, String> netNameMapping = new HashMap<>();
|
||||
/**
|
||||
* original local net ID (as string) > new net ID
|
||||
*/
|
||||
Map<String, Integer> netIdMapping = new HashMap<>();
|
||||
|
||||
for (PcbNode net : source.iterate("net")) {
|
||||
String netId = net.getChild(0);
|
||||
String netName = net.getChild(1); // todo: nicer method?
|
||||
String newName = networks.registerNetworkIfPcbSpecific(netName);
|
||||
netNameMapping.put(netName, newName);
|
||||
netIdMapping.put(netId, networks.getId(newName));
|
||||
}
|
||||
|
||||
List<PcbNode> zones = source.iterate("zone");
|
||||
log("Processing " + zones.size() + " zone(s)");
|
||||
for (PcbNode z : zones) {
|
||||
ZoneNode zone = (ZoneNode) z;
|
||||
if (zone.getLayerNode().isSikscreenLayer())
|
||||
destNode.addChild(zone);
|
||||
}
|
||||
|
||||
List<PcbNode> arcs = source.iterate("gr_arc");
|
||||
log("Processing " + arcs.size() + " arc(s)");
|
||||
for (PcbNode arc : arcs)
|
||||
destNode.addChild(arc);
|
||||
|
||||
|
||||
List<PcbNode> lines = source.iterate("gr_line");
|
||||
log("Processing " + lines.size() + " line(s)");
|
||||
for (PcbNode l : lines) {
|
||||
GrLineNode line = (GrLineNode) l;
|
||||
if (line.layerNode.isSikscreenLayer())
|
||||
destNode.addChild(line);
|
||||
}
|
||||
|
||||
|
||||
List<PcbNode> labels = source.iterate("gr_text");
|
||||
log("Processing " + labels.size() + " label(s)");
|
||||
for (PcbNode label : labels) {
|
||||
destNode.addChild(label);
|
||||
}
|
||||
|
||||
List<PcbNode> modules = source.iterate("module");
|
||||
log("Processing " + modules.size() + " module(s)");
|
||||
for (PcbNode module : modules) {
|
||||
for (PcbNode pad : module.iterate("pad")) {
|
||||
if (!pad.hasChild("net"))
|
||||
continue;
|
||||
fixNetId(netIdMapping, netNameMapping, pad);
|
||||
// PcbNode net = pad.find("net");
|
||||
// String localName = netNameMapping.get(net.getChild(1));
|
||||
// net.setString(1, localName);
|
||||
// net.setInt(0, networks.getId(localName));
|
||||
}
|
||||
destNode.addChild(module);
|
||||
}
|
||||
|
||||
List<PcbNode> segments = source.iterate("segment");
|
||||
log("Processing " + segments.size() + " segments");
|
||||
for (PcbNode segment : segments) {
|
||||
// if (!segment.hasChild("net"))
|
||||
// continue;
|
||||
fixNetId(netIdMapping, netNameMapping, segment);
|
||||
|
||||
destNode.addChild(segment);
|
||||
}
|
||||
|
||||
List<PcbNode> vias = source.iterate("via");
|
||||
log("Processing " + vias.size() + " vias");
|
||||
for (PcbNode via : vias) {
|
||||
fixNetId(netIdMapping, netNameMapping, via);
|
||||
|
||||
destNode.addChild(via);
|
||||
}
|
||||
|
||||
// for (PcbNode zone : source.iterate("zone")) {
|
||||
// fixNetId(netIdMapping, zone);
|
||||
// destNode.addChild(zone);
|
||||
// }
|
||||
}
|
||||
|
||||
public static void removeNodes(PcbNode source) {
|
||||
for (PcbNode module : source.iterate("module")) {
|
||||
if (shouldRemove((ModuleNode) module))
|
||||
source.removeChild(module);
|
||||
}
|
||||
}
|
||||
|
||||
private static boolean shouldRemove(ModuleNode module) {
|
||||
for (PcbNode fp_text : module.iterate("fp_text")) {
|
||||
if ("reference".equals(fp_text.getChild(0))) {
|
||||
String name = fp_text.getChild(1);
|
||||
if (ChangesModel.getInstance().DEL_REQUESTS.contains(name))
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private static void fixNetId(Map<String, Integer> netIdMapping, Map<String, String> netNameMapping, PcbNode node) {
|
||||
NetNode net = (NetNode) node.find("net");
|
||||
String originalId = net.id;
|
||||
Integer currentNetId = netIdMapping.get(originalId);
|
||||
String globalName = networks.nameById.get(currentNetId);
|
||||
// String newName = netNameMapping.get(originalName);
|
||||
// if (newName == null)
|
||||
// throw new NullPointerException("?");
|
||||
|
||||
if (ChangesModel.getInstance().NET_MERGE_REQUESTS.containsKey(globalName)) {
|
||||
String newName = ChangesModel.getInstance().NET_MERGE_REQUESTS.get(globalName);
|
||||
log("Will merge " + globalName + " into " + newName + ". ID was " + currentNetId);
|
||||
currentNetId = networks.networks.get(newName);
|
||||
if (currentNetId == null)
|
||||
throw new NullPointerException("Cannot find net: " + newName);
|
||||
log("New ID: " + currentNetId);
|
||||
globalName = newName;
|
||||
}
|
||||
net.setInt(0, currentNetId);
|
||||
if (net.name != null)
|
||||
net.setString(1, globalName);
|
||||
}
|
||||
|
||||
private static class Networks {
|
||||
/**
|
||||
* Net name > Net Id
|
||||
*/
|
||||
private Map<String, Integer> networks = new HashMap<>();
|
||||
private Map<Integer, String> nameById = new HashMap<>();
|
||||
|
||||
public String registerNetworkIfPcbSpecific(String name) {
|
||||
if (isLocalNetwork(name)) {
|
||||
String newName = "F-0000" + networks.size();
|
||||
log("Board-specific net: " + name + " would be " + newName);
|
||||
|
||||
registerNet(newName);
|
||||
int newId = networks.get(newName);
|
||||
log(newName + " is " + newId);
|
||||
return newName;
|
||||
} else {
|
||||
if (networks.containsKey(name)) {
|
||||
log("Existing global net: " + name);
|
||||
return name;
|
||||
}
|
||||
|
||||
log("New global net: " + name);
|
||||
registerNet(name);
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
private static boolean isLocalNetwork(String name) {
|
||||
return name.startsWith("N-00");
|
||||
}
|
||||
|
||||
private void registerNet(String name) {
|
||||
networks.put(name, networks.size());
|
||||
nameById.put(networks.get(name), name);
|
||||
}
|
||||
|
||||
public int getId(String localName) {
|
||||
Integer value = networks.get(localName);
|
||||
if (value == null)
|
||||
throw new NullPointerException("No id for " + localName);
|
||||
return value;
|
||||
}
|
||||
}
|
||||
|
||||
public static void log(String s) {
|
||||
System.out.println(s);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,127 +1,137 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/8/13
|
||||
*/
|
||||
public class PcbMoveTool {
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 4) {
|
||||
System.out.println("Four parameters expected: SRC_FILENAME DST_FILENAME X Y");
|
||||
return;
|
||||
}
|
||||
String srcFileName = args[0];
|
||||
String dstFileName = args[1];
|
||||
double x = Double.parseDouble(args[2]);
|
||||
double y = Double.parseDouble(args[3]);
|
||||
|
||||
PcbNode node = readAndMove(srcFileName, x, y);
|
||||
node.write(dstFileName);
|
||||
}
|
||||
|
||||
public static PcbNode readAndMove(String fileName, double x, double y) throws IOException {
|
||||
PcbNode node = PcbNode.readFromFile(fileName);
|
||||
|
||||
move(node, x, y);
|
||||
return node;
|
||||
}
|
||||
|
||||
public static void move(PcbNode pcbNode, double dx, double dy) {
|
||||
System.out.println("Moving " + pcbNode + ": dx=" +dx + " dy=" + dy);
|
||||
|
||||
List<PcbNode> dimensions = pcbNode.iterate("dimension");
|
||||
System.out.println("Moving " + dimensions.size() + " dimension");
|
||||
for (PcbNode dimension : dimensions) {
|
||||
moveAt(dx, dy, dimension.find("gr_text"));
|
||||
movePts(dx, dy, dimension.find("feature1"));
|
||||
movePts(dx, dy, dimension.find("feature2"));
|
||||
movePts(dx, dy, dimension.find("crossbar"));
|
||||
movePts(dx, dy, dimension.find("arrow1a"));
|
||||
movePts(dx, dy, dimension.find("arrow1b"));
|
||||
movePts(dx, dy, dimension.find("arrow2a"));
|
||||
movePts(dx, dy, dimension.find("arrow2b"));
|
||||
}
|
||||
|
||||
List<PcbNode> gr_lines = pcbNode.iterate("gr_line");
|
||||
System.out.println("Moving " + gr_lines.size() + " gr_lines");
|
||||
for (PcbNode gr_line : gr_lines)
|
||||
moveStartEnd(dx, dy, gr_line);
|
||||
|
||||
List<PcbNode> gr_circles = pcbNode.iterate("gr_circle");
|
||||
System.out.println("Moving " + gr_circles.size() + " gr_circles");
|
||||
for (PcbNode gr_circle : gr_circles) {
|
||||
PcbNode start = gr_circle.find("center");
|
||||
moveCoordinatesInFirstChildren(dx, dy, start);
|
||||
|
||||
PcbNode end = gr_circle.find("end");
|
||||
moveCoordinatesInFirstChildren(dx, dy, end);
|
||||
}
|
||||
|
||||
List<PcbNode> gr_texts = pcbNode.iterate("gr_text");
|
||||
System.out.println("Moving " + gr_texts.size() + " gr_texts");
|
||||
for (PcbNode gr_text : gr_texts)
|
||||
moveAt(dx, dy, gr_text);
|
||||
|
||||
List<PcbNode> zones = pcbNode.iterate("zone");
|
||||
System.out.println("Moving " + zones.size() + " zones");
|
||||
for (PcbNode zone : zones) {
|
||||
List<PcbNode> filledPolygons = zone.iterate("filled_polygon");
|
||||
for (PcbNode filledPolygon : filledPolygons)
|
||||
movePts(dx, dy, filledPolygon);
|
||||
List<PcbNode> polygons = zone.iterate("polygon");
|
||||
for (PcbNode polygon : polygons)
|
||||
movePts(dx, dy, polygon);
|
||||
}
|
||||
|
||||
|
||||
List<PcbNode> segments = pcbNode.iterate("segment");
|
||||
System.out.println("Moving " + segments.size() + " segments");
|
||||
for (PcbNode segment : segments)
|
||||
moveStartEnd(dx, dy, segment);
|
||||
|
||||
List<PcbNode> vias = pcbNode.iterate("via");
|
||||
System.out.println("Moving " + vias.size() + " vias");
|
||||
for (PcbNode via : vias)
|
||||
moveAt(dx, dy, via);
|
||||
|
||||
|
||||
List<PcbNode> modules = pcbNode.iterate("module");
|
||||
System.out.println("Moving " + modules.size() + " modules");
|
||||
for (PcbNode module : modules)
|
||||
moveAt(dx, dy, module);
|
||||
}
|
||||
|
||||
public static void movePts(double dx, double dy, PcbNode polygon) {
|
||||
PcbNode pts = polygon.find("pts");
|
||||
|
||||
for (PcbNode point : pts.nodes())
|
||||
moveCoordinatesInFirstChildren(dx, dy, point);
|
||||
}
|
||||
|
||||
public static void moveStartEnd(double dx, double dy, PcbNode segment) {
|
||||
PcbNode start = segment.find("start");
|
||||
moveCoordinatesInFirstChildren(dx, dy, start);
|
||||
|
||||
PcbNode end = segment.find("end");
|
||||
moveCoordinatesInFirstChildren(dx, dy, end);
|
||||
}
|
||||
|
||||
public static void moveAt(double dx, double dy, PcbNode module) {
|
||||
PcbNode at = module.find("at");
|
||||
moveCoordinatesInFirstChildren(dx, dy, at);
|
||||
}
|
||||
|
||||
public static void moveCoordinatesInFirstChildren(double dx, double dy, PcbNode at) {
|
||||
moveCoordinates(dx, dy, at, 0);
|
||||
}
|
||||
|
||||
private static void moveCoordinates(double dx, double dy, PcbNode at, int index) {
|
||||
double x = at.asDouble(index);
|
||||
double y = at.asDouble(index + 1);
|
||||
at.setDouble(index, x + dx);
|
||||
at.setDouble(index + 1, y + dy);
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/8/13
|
||||
*/
|
||||
public class PcbMoveTool {
|
||||
public static void main(String[] args) throws IOException {
|
||||
if (args.length != 4) {
|
||||
System.out.println("Four parameters expected: SRC_FILENAME DST_FILENAME X Y");
|
||||
return;
|
||||
}
|
||||
String srcFileName = args[0];
|
||||
String dstFileName = args[1];
|
||||
double x = Double.parseDouble(args[2]);
|
||||
double y = Double.parseDouble(args[3]);
|
||||
|
||||
PcbNode node = readAndMove(srcFileName, x, y);
|
||||
node.write(dstFileName);
|
||||
}
|
||||
|
||||
public static PcbNode readAndMove(String fileName, double x, double y) throws IOException {
|
||||
PcbNode node = PcbNode.readFromFile(fileName);
|
||||
|
||||
move(node, x, y);
|
||||
return node;
|
||||
}
|
||||
|
||||
public static void move(PcbNode pcbNode, double dx, double dy) {
|
||||
System.out.println("Moving " + pcbNode + ": dx=" +dx + " dy=" + dy);
|
||||
|
||||
List<PcbNode> dimensions = pcbNode.iterate("dimension");
|
||||
System.out.println("Moving " + dimensions.size() + " dimension");
|
||||
for (PcbNode dimension : dimensions) {
|
||||
moveAt(dx, dy, dimension.find("gr_text"));
|
||||
movePts(dx, dy, dimension.find("feature1"));
|
||||
movePts(dx, dy, dimension.find("feature2"));
|
||||
movePts(dx, dy, dimension.find("crossbar"));
|
||||
movePts(dx, dy, dimension.find("arrow1a"));
|
||||
movePts(dx, dy, dimension.find("arrow1b"));
|
||||
movePts(dx, dy, dimension.find("arrow2a"));
|
||||
movePts(dx, dy, dimension.find("arrow2b"));
|
||||
}
|
||||
|
||||
List<PcbNode> gr_lines = pcbNode.iterate("gr_line");
|
||||
System.out.println("Moving " + gr_lines.size() + " gr_lines");
|
||||
for (PcbNode gr_line : gr_lines)
|
||||
moveStartEnd(dx, dy, gr_line);
|
||||
|
||||
List<PcbNode> gr_arcs = pcbNode.iterate("gr_arc");
|
||||
System.out.println("Moving " + gr_arcs.size() + " gr_arcs");
|
||||
for (PcbNode gr_arc : gr_arcs) {
|
||||
PcbNode start = gr_arc.find("start");
|
||||
moveCoordinatesInFirstChildren(dx, dy, start);
|
||||
|
||||
PcbNode end = gr_arc.find("end");
|
||||
moveCoordinatesInFirstChildren(dx, dy, end);
|
||||
}
|
||||
|
||||
List<PcbNode> gr_circles = pcbNode.iterate("gr_circle");
|
||||
System.out.println("Moving " + gr_circles.size() + " gr_circles");
|
||||
for (PcbNode gr_circle : gr_circles) {
|
||||
PcbNode start = gr_circle.find("center");
|
||||
moveCoordinatesInFirstChildren(dx, dy, start);
|
||||
|
||||
PcbNode end = gr_circle.find("end");
|
||||
moveCoordinatesInFirstChildren(dx, dy, end);
|
||||
}
|
||||
|
||||
List<PcbNode> gr_texts = pcbNode.iterate("gr_text");
|
||||
System.out.println("Moving " + gr_texts.size() + " gr_texts");
|
||||
for (PcbNode gr_text : gr_texts)
|
||||
moveAt(dx, dy, gr_text);
|
||||
|
||||
List<PcbNode> zones = pcbNode.iterate("zone");
|
||||
System.out.println("Moving " + zones.size() + " zones");
|
||||
for (PcbNode zone : zones) {
|
||||
List<PcbNode> filledPolygons = zone.iterate("filled_polygon");
|
||||
for (PcbNode filledPolygon : filledPolygons)
|
||||
movePts(dx, dy, filledPolygon);
|
||||
List<PcbNode> polygons = zone.iterate("polygon");
|
||||
for (PcbNode polygon : polygons)
|
||||
movePts(dx, dy, polygon);
|
||||
}
|
||||
|
||||
|
||||
List<PcbNode> segments = pcbNode.iterate("segment");
|
||||
System.out.println("Moving " + segments.size() + " segments");
|
||||
for (PcbNode segment : segments)
|
||||
moveStartEnd(dx, dy, segment);
|
||||
|
||||
List<PcbNode> vias = pcbNode.iterate("via");
|
||||
System.out.println("Moving " + vias.size() + " vias");
|
||||
for (PcbNode via : vias)
|
||||
moveAt(dx, dy, via);
|
||||
|
||||
|
||||
List<PcbNode> modules = pcbNode.iterate("module");
|
||||
System.out.println("Moving " + modules.size() + " modules");
|
||||
for (PcbNode module : modules)
|
||||
moveAt(dx, dy, module);
|
||||
}
|
||||
|
||||
public static void movePts(double dx, double dy, PcbNode polygon) {
|
||||
PcbNode pts = polygon.find("pts");
|
||||
|
||||
for (PcbNode point : pts.nodes())
|
||||
moveCoordinatesInFirstChildren(dx, dy, point);
|
||||
}
|
||||
|
||||
public static void moveStartEnd(double dx, double dy, PcbNode segment) {
|
||||
PcbNode start = segment.find("start");
|
||||
moveCoordinatesInFirstChildren(dx, dy, start);
|
||||
|
||||
PcbNode end = segment.find("end");
|
||||
moveCoordinatesInFirstChildren(dx, dy, end);
|
||||
}
|
||||
|
||||
public static void moveAt(double dx, double dy, PcbNode module) {
|
||||
PcbNode at = module.find("at");
|
||||
moveCoordinatesInFirstChildren(dx, dy, at);
|
||||
}
|
||||
|
||||
public static void moveCoordinatesInFirstChildren(double dx, double dy, PcbNode at) {
|
||||
moveCoordinates(dx, dy, at, 0);
|
||||
}
|
||||
|
||||
private static void moveCoordinates(double dx, double dy, PcbNode at, int index) {
|
||||
double x = at.asDouble(index);
|
||||
double y = at.asDouble(index + 1);
|
||||
at.setDouble(index, x + dx);
|
||||
at.setDouble(index + 1, y + dy);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,243 +1,247 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.FileWriter;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/8/13
|
||||
*/
|
||||
public class PcbNode {
|
||||
public final String nodeName;
|
||||
public final int closingIndex;
|
||||
public final List<Object> children;
|
||||
|
||||
public PcbNode(String nodeName, int closingIndex, List<Object> children) {
|
||||
this.nodeName = nodeName;
|
||||
this.closingIndex = closingIndex;
|
||||
this.children = children;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see #write
|
||||
*/
|
||||
public static PcbNode readFromFile(String fileName) throws IOException {
|
||||
String content = FileUtils.readFile(fileName);
|
||||
PcbNode node = parse(content);
|
||||
System.out.println("GND network: " + NetNode.GND_NET_ID);
|
||||
return node;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "PcbNode{" +
|
||||
nodeName +
|
||||
", children=" + children.size() +
|
||||
'}';
|
||||
}
|
||||
|
||||
private static PcbNode parse(String s, int index, int depth) {
|
||||
log("Reading node from " + index, depth);
|
||||
if (s.charAt(index) != '(')
|
||||
throw new IllegalStateException("opening bracket expected");
|
||||
index++;
|
||||
String nodeName = readToken(s, index, depth);
|
||||
index += nodeName.length();
|
||||
|
||||
List<Object> children = new ArrayList<Object>();
|
||||
while (true) {
|
||||
while (isWhitespace(s.charAt(index)))
|
||||
index++;
|
||||
|
||||
char c = s.charAt(index);
|
||||
if (c == ')')
|
||||
break;
|
||||
|
||||
if (s.charAt(index) == '(') {
|
||||
PcbNode child = parse(s, index, depth + 1);
|
||||
children.add(child);
|
||||
index = child.closingIndex;
|
||||
continue;
|
||||
}
|
||||
|
||||
String child = readToken(s, index, depth);
|
||||
children.add(child);
|
||||
index += child.length();
|
||||
}
|
||||
if ("segment".equals(nodeName)) {
|
||||
return new SegmentNode(nodeName, index + 1, children);
|
||||
} else if ("pad".equals(nodeName)) {
|
||||
return PadNode.parse(nodeName, index + 1, children);
|
||||
} else if ("net".equals(nodeName)) {
|
||||
return new NetNode(nodeName, index + 1, children);
|
||||
} else if ("gr_line".equals(nodeName)) {
|
||||
return new GrLineNode(nodeName, index + 1, children);
|
||||
} else if ("layer".equals(nodeName)) {
|
||||
return new LayerNode(nodeName, index + 1, children);
|
||||
} else if ("module".equals(nodeName)) {
|
||||
return new ModuleNode(nodeName, index + 1, children);
|
||||
} else if ("size".equals(nodeName) || "width".equals(nodeName)) {
|
||||
return new SizeNode(nodeName, index + 1, children);
|
||||
} else if ("zone".equals(nodeName)) {
|
||||
return new ZoneNode(nodeName, index + 1, children);
|
||||
} else if ("via".equals(nodeName)) {
|
||||
return new ViaNode(nodeName, index + 1, children);
|
||||
} else if ("start".equals(nodeName) || "end".equals(nodeName) || "at".equals(nodeName)) {
|
||||
return new PointNode(nodeName, index + 1, children);
|
||||
}
|
||||
|
||||
return new PcbNode(nodeName, index + 1, children);
|
||||
}
|
||||
|
||||
private static String readToken(String s, int index, int depth) {
|
||||
log("Reading token from " + index, depth);
|
||||
if (s.charAt(index) == '"') {
|
||||
String result = s.substring(index, s.indexOf('"', index + 1) + 1);
|
||||
log("Got quoted token: " + result, depth);
|
||||
return result;
|
||||
}
|
||||
|
||||
String result = "";
|
||||
while (index < s.length()) {
|
||||
char c = s.charAt(index);
|
||||
if (c == ')' || isWhitespace(c))
|
||||
break;
|
||||
result += c;
|
||||
index++;
|
||||
}
|
||||
if (result.length() == 0)
|
||||
throw new IllegalStateException("Empty token");
|
||||
log("Got token: " + result, depth);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void log(String s, int depth) {
|
||||
// for (int i = 0; i < depth; i++)
|
||||
// System.out.print(' ');
|
||||
// System.out.println(s);
|
||||
}
|
||||
|
||||
private static void log(String s) {
|
||||
log(s, 0);
|
||||
}
|
||||
|
||||
private static boolean isWhitespace(char c) {
|
||||
return c == ' ' || c == '\r' || c == '\n';
|
||||
}
|
||||
|
||||
public static PcbNode parse(String content) {
|
||||
return parse(content, 0, 0);
|
||||
}
|
||||
|
||||
public String pack() {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
pack(sb, "");
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private void pack(StringBuilder sb, String prefix) {
|
||||
sb.append(prefix).append("(").append(nodeName);
|
||||
|
||||
for (Object child : children) {
|
||||
if (child instanceof String) {
|
||||
sb.append(" ").append(child);
|
||||
continue;
|
||||
}
|
||||
PcbNode p = (PcbNode) child;
|
||||
sb.append("\r\n");
|
||||
p.pack(sb, prefix + " ");
|
||||
}
|
||||
|
||||
|
||||
sb.append(")\r\n");
|
||||
}
|
||||
|
||||
public void write(String fileName) throws IOException {
|
||||
System.out.println("Writing to " + fileName);
|
||||
String content = pack();
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(fileName));
|
||||
bw.write(content);
|
||||
bw.close();
|
||||
}
|
||||
|
||||
public void setDouble(int i, double value) {
|
||||
children.set(i, "" + value);
|
||||
}
|
||||
|
||||
public double asDouble(int index) {
|
||||
return Double.parseDouble((String) children.get(index));
|
||||
}
|
||||
|
||||
public boolean hasChild(String key) {
|
||||
return !iterate(key).isEmpty();
|
||||
}
|
||||
|
||||
// @Nullable
|
||||
public PcbNode findIfExists(String key) {
|
||||
List<PcbNode> r = iterate(key);
|
||||
if (r.isEmpty())
|
||||
return null;
|
||||
return find(key);
|
||||
}
|
||||
|
||||
// @NotNull
|
||||
public PcbNode find(String key) {
|
||||
List<PcbNode> r = iterate(key);
|
||||
if (r.size() != 1)
|
||||
throw new IllegalStateException("More that one " + key + " in " + nodeName);
|
||||
return r.get(0);
|
||||
}
|
||||
|
||||
public List<PcbNode> nodes() {
|
||||
List<PcbNode> result = new ArrayList<PcbNode>();
|
||||
for (Object child : children) {
|
||||
if (child instanceof String)
|
||||
continue;
|
||||
result.add((PcbNode) child);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public List<PcbNode> iterate(String key) {
|
||||
List<PcbNode> result = new ArrayList<PcbNode>();
|
||||
for (PcbNode p : nodes()) {
|
||||
if (p.nodeName.equals(key))
|
||||
result.add(p);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public void addChild(PcbNode node) {
|
||||
children.add(node);
|
||||
}
|
||||
|
||||
public List<Object> getChildren() {
|
||||
return Collections.unmodifiableList(children);
|
||||
}
|
||||
|
||||
public String getChild(int index) {
|
||||
return (String) children.get(index);
|
||||
}
|
||||
|
||||
public void setString(int index, String value) {
|
||||
children.set(index, value);
|
||||
}
|
||||
|
||||
public void setInt(int index, int value) {
|
||||
children.set(index, "" + value);
|
||||
}
|
||||
|
||||
public boolean removeChild(Object child) {
|
||||
return children.remove(child);
|
||||
}
|
||||
|
||||
public boolean isConnected(PointNode point) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import com.rusefi.util.FileUtils;
|
||||
|
||||
import java.io.BufferedWriter;
|
||||
import java.io.FileWriter;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/8/13
|
||||
*/
|
||||
public class PcbNode {
|
||||
public final String nodeName;
|
||||
public final int closingIndex;
|
||||
public final List<Object> children;
|
||||
|
||||
public PcbNode(String nodeName, int closingIndex, List<Object> children) {
|
||||
this.nodeName = nodeName;
|
||||
this.closingIndex = closingIndex;
|
||||
this.children = children;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see #write
|
||||
*/
|
||||
public static PcbNode readFromFile(String fileName) throws IOException {
|
||||
String content = FileUtils.readFile(fileName);
|
||||
PcbNode node = parse(content);
|
||||
System.out.println("GND network: " + NetNode.GND_NET_ID);
|
||||
return node;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "PcbNode{" +
|
||||
nodeName +
|
||||
", children=" + children.size() +
|
||||
'}';
|
||||
}
|
||||
|
||||
private static PcbNode parse(String s, int index, int depth) {
|
||||
log("Reading node from " + index, depth);
|
||||
if (s.charAt(index) != '(')
|
||||
throw new IllegalStateException("opening bracket expected");
|
||||
index++;
|
||||
String nodeName = readToken(s, index, depth);
|
||||
index += nodeName.length();
|
||||
|
||||
List<Object> children = new ArrayList<Object>();
|
||||
while (true) {
|
||||
while (isWhitespace(s.charAt(index)))
|
||||
index++;
|
||||
|
||||
char c = s.charAt(index);
|
||||
if (c == ')')
|
||||
break;
|
||||
|
||||
if (s.charAt(index) == '(') {
|
||||
PcbNode child = parse(s, index, depth + 1);
|
||||
children.add(child);
|
||||
index = child.closingIndex;
|
||||
continue;
|
||||
}
|
||||
|
||||
String child = readToken(s, index, depth);
|
||||
children.add(child);
|
||||
index += child.length();
|
||||
}
|
||||
if ("segment".equals(nodeName)) {
|
||||
return new SegmentNode(nodeName, index + 1, children);
|
||||
} else if ("pad".equals(nodeName)) {
|
||||
return PadNode.parse(nodeName, index + 1, children);
|
||||
} else if ("net".equals(nodeName)) {
|
||||
return new NetNode(nodeName, index + 1, children);
|
||||
} else if ("add_net".equals(nodeName)) {
|
||||
return new AddNetNode(nodeName, index + 1, children);
|
||||
} else if ("gr_line".equals(nodeName)) {
|
||||
return new GrLineNode(nodeName, index + 1, children);
|
||||
} else if ("layer".equals(nodeName)) {
|
||||
return new LayerNode(nodeName, index + 1, children);
|
||||
} else if ("module".equals(nodeName)) {
|
||||
return new ModuleNode(nodeName, index + 1, children);
|
||||
} else if ("size".equals(nodeName) || "width".equals(nodeName)) {
|
||||
return new SizeNode(nodeName, index + 1, children);
|
||||
} else if ("zone".equals(nodeName)) {
|
||||
return new ZoneNode(nodeName, index + 1, children);
|
||||
} else if ("via".equals(nodeName)) {
|
||||
return new ViaNode(nodeName, index + 1, children);
|
||||
} else if ("start".equals(nodeName) || "end".equals(nodeName) || "at".equals(nodeName)) {
|
||||
return new PointNode(nodeName, index + 1, children);
|
||||
}
|
||||
|
||||
return new PcbNode(nodeName, index + 1, children);
|
||||
}
|
||||
|
||||
private static String readToken(String s, int index, int depth) {
|
||||
log("Reading token from " + index, depth);
|
||||
if (s.charAt(index) == '"') {
|
||||
String result = s.substring(index, s.indexOf('"', index + 1) + 1);
|
||||
log("Got quoted token: " + result, depth);
|
||||
return result;
|
||||
}
|
||||
|
||||
String result = "";
|
||||
while (index < s.length()) {
|
||||
char c = s.charAt(index);
|
||||
if (c == ')' || isWhitespace(c))
|
||||
break;
|
||||
result += c;
|
||||
index++;
|
||||
}
|
||||
if (result.length() == 0)
|
||||
throw new IllegalStateException("Empty token");
|
||||
log("Got token: " + result, depth);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void log(String s, int depth) {
|
||||
// for (int i = 0; i < depth; i++)
|
||||
// System.out.print(' ');
|
||||
// System.out.println(s);
|
||||
}
|
||||
|
||||
private static void log(String s) {
|
||||
log(s, 0);
|
||||
}
|
||||
|
||||
private static boolean isWhitespace(char c) {
|
||||
return c == ' ' || c == '\r' || c == '\n';
|
||||
}
|
||||
|
||||
public static PcbNode parse(String content) {
|
||||
return parse(content, 0, 0);
|
||||
}
|
||||
|
||||
public String pack() {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
pack(sb, "");
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private void pack(StringBuilder sb, String prefix) {
|
||||
sb.append(prefix).append("(").append(nodeName);
|
||||
|
||||
for (Object child : children) {
|
||||
if (child instanceof String) {
|
||||
sb.append(" ").append(child);
|
||||
continue;
|
||||
}
|
||||
PcbNode p = (PcbNode) child;
|
||||
if (p == null)
|
||||
throw new NullPointerException("Null child node");
|
||||
sb.append("\r\n");
|
||||
p.pack(sb, prefix + " ");
|
||||
}
|
||||
|
||||
|
||||
sb.append(")\r\n");
|
||||
}
|
||||
|
||||
public void write(String fileName) throws IOException {
|
||||
System.out.println("Writing to " + fileName);
|
||||
String content = pack();
|
||||
BufferedWriter bw = new BufferedWriter(new FileWriter(fileName));
|
||||
bw.write(content);
|
||||
bw.close();
|
||||
}
|
||||
|
||||
public void setDouble(int i, double value) {
|
||||
children.set(i, "" + value);
|
||||
}
|
||||
|
||||
public double asDouble(int index) {
|
||||
return Double.parseDouble((String) children.get(index));
|
||||
}
|
||||
|
||||
public boolean hasChild(String key) {
|
||||
return !iterate(key).isEmpty();
|
||||
}
|
||||
|
||||
// @Nullable
|
||||
public PcbNode findIfExists(String key) {
|
||||
List<PcbNode> r = iterate(key);
|
||||
if (r.isEmpty())
|
||||
return null;
|
||||
return find(key);
|
||||
}
|
||||
|
||||
// @NotNull
|
||||
public PcbNode find(String key) {
|
||||
List<PcbNode> r = iterate(key);
|
||||
if (r.size() != 1)
|
||||
throw new IllegalStateException("More that one " + key + " in " + nodeName);
|
||||
return r.get(0);
|
||||
}
|
||||
|
||||
public List<PcbNode> nodes() {
|
||||
List<PcbNode> result = new ArrayList<PcbNode>();
|
||||
for (Object child : children) {
|
||||
if (child instanceof String)
|
||||
continue;
|
||||
result.add((PcbNode) child);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public List<PcbNode> iterate(String key) {
|
||||
List<PcbNode> result = new ArrayList<PcbNode>();
|
||||
for (PcbNode p : nodes()) {
|
||||
if (p.nodeName.equals(key))
|
||||
result.add(p);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public void addChild(PcbNode node) {
|
||||
children.add(node);
|
||||
}
|
||||
|
||||
public List<Object> getChildren() {
|
||||
return Collections.unmodifiableList(children);
|
||||
}
|
||||
|
||||
public String getChild(int index) {
|
||||
return (String) children.get(index);
|
||||
}
|
||||
|
||||
public void setString(int index, String value) {
|
||||
children.set(index, value);
|
||||
}
|
||||
|
||||
public void setInt(int index, int value) {
|
||||
children.set(index, "" + value);
|
||||
}
|
||||
|
||||
public boolean removeChild(Object child) {
|
||||
return children.remove(child);
|
||||
}
|
||||
|
||||
public boolean isConnected(PointNode point) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,76 +1,77 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class PointNode extends PcbNode {
|
||||
public final double x;
|
||||
public final double y;
|
||||
public final double angle;
|
||||
|
||||
public PointNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
if (children.size() == 1) {
|
||||
// xyz use-case
|
||||
x = 0;
|
||||
y = 0;
|
||||
angle = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
if (children.size() != 2 && children.size() != 3)
|
||||
throw new IllegalStateException("Unexpected children count");
|
||||
x = Double.parseDouble((String) children.get(0));
|
||||
y = Double.parseDouble((String) children.get(1));
|
||||
angle = children.size() == 2 ? 0 : Double.parseDouble((String) children.get(2));
|
||||
}
|
||||
|
||||
public PointNode(double x, double y) {
|
||||
super("", 0, Collections.emptyList());
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
angle = 0;
|
||||
}
|
||||
|
||||
public boolean isConnected(PointNode at, SizeNode size) {
|
||||
boolean isConnectedX = (x >= at.x - size.w / 2) && (x <= at.x + size.w / 2);
|
||||
boolean isConnectedY = (y >= at.y - size.h / 2) && (y <= at.y + size.h / 2);
|
||||
return isConnectedX && isConnectedY;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "PointNode{" +
|
||||
"x=" + x +
|
||||
", y=" + y +
|
||||
", angle=" + angle +
|
||||
'}';
|
||||
}
|
||||
|
||||
public boolean isSameLocation(PointNode point) {
|
||||
return x == point.x && y == point.y;
|
||||
}
|
||||
|
||||
public PointNode translate(PointNode at) {
|
||||
double nx = at.x - x;
|
||||
double ny = at.y - y;
|
||||
if (angle == 0)
|
||||
return new PointNode(nx, ny);
|
||||
if (angle == 270)
|
||||
return new PointNode(ny, -nx);
|
||||
if (angle == 90)
|
||||
return new PointNode(-ny, nx);
|
||||
if (angle == 180)
|
||||
return new PointNode(-nx, -ny);
|
||||
throw new IllegalStateException("Angle not supported: " + angle);
|
||||
}
|
||||
|
||||
public void setLocation(double x, double y) {
|
||||
children.set(0, Double.toString(x));
|
||||
children.set(1, Double.toString(y));
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class PointNode extends PcbNode {
|
||||
public final double x;
|
||||
public final double y;
|
||||
public final double angle;
|
||||
|
||||
public PointNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
if (children.size() == 1) {
|
||||
// xyz use-case
|
||||
x = 0;
|
||||
y = 0;
|
||||
angle = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
if (children.size() != 2 && children.size() != 3)
|
||||
throw new IllegalStateException("Unexpected children count");
|
||||
x = Double.parseDouble((String) children.get(0));
|
||||
y = Double.parseDouble((String) children.get(1));
|
||||
angle = children.size() == 2 ? 0 : Double.parseDouble((String) children.get(2));
|
||||
}
|
||||
|
||||
public PointNode(double x, double y) {
|
||||
this(x, y, 0);
|
||||
}
|
||||
|
||||
public PointNode(double x, double y, double angle) {
|
||||
super("", 0, Collections.emptyList());
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
this.angle = angle;
|
||||
}
|
||||
|
||||
public boolean isConnected(PointNode at, SizeNode size) {
|
||||
boolean isConnectedX = (x >= at.x - size.w / 2) && (x <= at.x + size.w / 2);
|
||||
boolean isConnectedY = (y >= at.y - size.h / 2) && (y <= at.y + size.h / 2);
|
||||
return isConnectedX && isConnectedY;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "PointNode{" +
|
||||
"x=" + x +
|
||||
", y=" + y +
|
||||
", angle=" + angle +
|
||||
'}';
|
||||
}
|
||||
|
||||
// public boolean isSameLocation(PointNode point) {
|
||||
// return x == point.x && y == point.y;
|
||||
// }
|
||||
|
||||
public PointNode translate(PointNode at) {
|
||||
double nx = at.x - x;
|
||||
double ny = at.y - y;
|
||||
|
||||
double radian = angle / 180 * Math.PI;
|
||||
double rx = Math.cos(radian) * nx - Math.sin(radian) * ny;
|
||||
double ry = Math.sin(radian) * nx + Math.cos(radian) * ny;
|
||||
|
||||
return new PointNode(rx, ry);
|
||||
}
|
||||
|
||||
public void setLocation(double x, double y) {
|
||||
children.set(0, Double.toString(x));
|
||||
children.set(1, Double.toString(y));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 1/21/14.
|
||||
*/
|
||||
public class RectPadNode extends PadNode {
|
||||
public RectPadNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "RectPadNode{" +
|
||||
"name=" + name +
|
||||
", at=" + at +
|
||||
", size=" + size +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 1/21/14.
|
||||
*/
|
||||
public class RectPadNode extends PadNode {
|
||||
public RectPadNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "RectPadNode{" +
|
||||
"name=" + name +
|
||||
", at=" + at +
|
||||
", size=" + size +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,35 +1,35 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class SegmentNode extends PcbNode {
|
||||
public final NetNode net;
|
||||
public final PointNode start;
|
||||
public final PointNode end;
|
||||
private final SizeNode size;
|
||||
|
||||
public SegmentNode(String nodeName, int closingIndex, List<Object> children) {
|
||||
super(nodeName, closingIndex, children);
|
||||
net = (NetNode) find("net");
|
||||
start = (PointNode) find("start");
|
||||
end = (PointNode) find("end");
|
||||
size = (SizeNode) find("width");
|
||||
}
|
||||
|
||||
public boolean isConnected(PointNode point) {
|
||||
return point.isConnected(start, size) || point.isConnected(end, size);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "SegmentNode{" +
|
||||
"net=" + net +
|
||||
", start=" + start +
|
||||
", end=" + end +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class SegmentNode extends PcbNode {
|
||||
public final NetNode net;
|
||||
public final PointNode start;
|
||||
public final PointNode end;
|
||||
private final SizeNode size;
|
||||
|
||||
public SegmentNode(String nodeName, int closingIndex, List<Object> children) {
|
||||
super(nodeName, closingIndex, children);
|
||||
net = (NetNode) find("net");
|
||||
start = (PointNode) find("start");
|
||||
end = (PointNode) find("end");
|
||||
size = (SizeNode) find("width");
|
||||
}
|
||||
|
||||
public boolean isConnected(PointNode point) {
|
||||
return point.isConnected(start, size) || point.isConnected(end, size);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "SegmentNode{" +
|
||||
"net=" + net +
|
||||
", start=" + start +
|
||||
", end=" + end +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,33 +1,33 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class SizeNode extends PcbNode {
|
||||
public final double w;
|
||||
public final double h;
|
||||
|
||||
public SizeNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
if (children.size() == 1) {
|
||||
w = h = Double.parseDouble((String) children.get(0));
|
||||
return;
|
||||
}
|
||||
|
||||
if (children.size() != 2)
|
||||
throw new IllegalStateException("Size: " + children.size());
|
||||
w = Double.parseDouble((String) children.get(0));
|
||||
h = Double.parseDouble((String) children.get(1));
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "SizeNode{" +
|
||||
"w=" + w +
|
||||
", h=" + h +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class SizeNode extends PcbNode {
|
||||
public final double w;
|
||||
public final double h;
|
||||
|
||||
public SizeNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
if (children.size() == 1) {
|
||||
w = h = Double.parseDouble((String) children.get(0));
|
||||
return;
|
||||
}
|
||||
|
||||
if (children.size() != 2)
|
||||
throw new IllegalStateException("Size: " + children.size());
|
||||
w = Double.parseDouble((String) children.get(0));
|
||||
h = Double.parseDouble((String) children.get(1));
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "SizeNode{" +
|
||||
"w=" + w +
|
||||
", h=" + h +
|
||||
'}';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,32 +1,32 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class ViaNode extends PcbNode {
|
||||
public final PointNode location;
|
||||
final SizeNode size;
|
||||
public final int netId;
|
||||
|
||||
public ViaNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
location = (PointNode) find("at");
|
||||
size = (SizeNode) find("size");
|
||||
netId = Integer.parseInt(find("net").getChild(0));
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "ViaNode{" +
|
||||
"location=" + location +
|
||||
'}';
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isConnected(PointNode point) {
|
||||
return point.isConnected(location, size);
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/21/14
|
||||
*/
|
||||
public class ViaNode extends PcbNode {
|
||||
public final PointNode location;
|
||||
final SizeNode size;
|
||||
public final int netId;
|
||||
|
||||
public ViaNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
location = (PointNode) find("at");
|
||||
size = (SizeNode) find("size");
|
||||
netId = Integer.parseInt(find("net").getChild(0));
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "ViaNode{" +
|
||||
"location=" + location +
|
||||
'}';
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isConnected(PointNode point) {
|
||||
return point.isConnected(location, size);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,20 +1,20 @@
|
|||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/11/14.
|
||||
*/
|
||||
public class ZoneNode extends PcbNode {
|
||||
private final LayerNode layerNode;
|
||||
|
||||
public ZoneNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
layerNode = (LayerNode) find("layer");
|
||||
}
|
||||
|
||||
public LayerNode getLayerNode() {
|
||||
return layerNode;
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 2/11/14.
|
||||
*/
|
||||
public class ZoneNode extends PcbNode {
|
||||
private final LayerNode layerNode;
|
||||
|
||||
public ZoneNode(String nodeName, int i, List<Object> children) {
|
||||
super(nodeName, i, children);
|
||||
layerNode = (LayerNode) find("layer");
|
||||
}
|
||||
|
||||
public LayerNode getLayerNode() {
|
||||
return layerNode;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,40 +1,40 @@
|
|||
package com.rusefi.pcb.test;
|
||||
|
||||
|
||||
import com.rusefi.misc.NameAndOffset;
|
||||
import com.rusefi.misc.ChangesModel;
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.Arrays;
|
||||
|
||||
import static junit.framework.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class ChangesModelTest {
|
||||
@Test
|
||||
public void testConfigParser() {
|
||||
|
||||
ChangesModel model = ChangesModel.getInstance();
|
||||
model.clear();
|
||||
|
||||
model.read(Arrays.asList("reMove c1", "add mmc_usb_1.kicad_pcb",
|
||||
"adD mmc_usb_1.kicad_pcb 4 6",
|
||||
"optimize mmc_usb_1.kicad_pcb out.x"));
|
||||
|
||||
assertEquals(1, model.DEL_REQUESTS.size());
|
||||
assertTrue(model.DEL_REQUESTS.contains("C1"));
|
||||
|
||||
assertEquals(2, model.ADD_REQUESTS.size());
|
||||
|
||||
NameAndOffset ar = model.ADD_REQUESTS.get(1);
|
||||
Assert.assertEquals(4.0, ar.x, 0);
|
||||
Assert.assertEquals(6.0, ar.y, 0);
|
||||
|
||||
assertEquals(1, model.OPTIMIZE_REQUESTS.size());
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb.test;
|
||||
|
||||
|
||||
import com.rusefi.misc.NameAndOffset;
|
||||
import com.rusefi.misc.ChangesModel;
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.Arrays;
|
||||
|
||||
import static junit.framework.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Andrey Belomutskiy
|
||||
* 1/24/14
|
||||
*/
|
||||
public class ChangesModelTest {
|
||||
@Test
|
||||
public void testConfigParser() {
|
||||
|
||||
ChangesModel model = ChangesModel.getInstance();
|
||||
model.clear();
|
||||
|
||||
model.read(Arrays.asList("reMove c1", "add mmc_usb_1.kicad_pcb",
|
||||
"adD mmc_usb_1.kicad_pcb 4 6",
|
||||
"optimize mmc_usb_1.kicad_pcb out.x"));
|
||||
|
||||
assertEquals(1, model.DEL_REQUESTS.size());
|
||||
assertTrue(model.DEL_REQUESTS.contains("C1"));
|
||||
|
||||
assertEquals(2, model.ADD_REQUESTS.size());
|
||||
|
||||
NameAndOffset ar = model.ADD_REQUESTS.get(1);
|
||||
Assert.assertEquals(4.0, ar.x, 0);
|
||||
Assert.assertEquals(6.0, ar.y, 0);
|
||||
|
||||
assertEquals(1, model.OPTIMIZE_REQUESTS.size());
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,271 +1,271 @@
|
|||
package com.rusefi.pcb.test;
|
||||
|
||||
import com.rusefi.misc.RemoveUnneededTraces;
|
||||
import com.rusefi.pcb.ModuleNode;
|
||||
import com.rusefi.pcb.PcbNode;
|
||||
import com.rusefi.pcb.SegmentNode;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Collections;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/8/13
|
||||
*/
|
||||
public class PcbNodeTest {
|
||||
@Test
|
||||
public void testParser() {
|
||||
PcbNode n = PcbNode.parse("(version 3\r\n)");
|
||||
assertEquals("version", n.nodeName);
|
||||
assertEquals(1, n.getChildren().size());
|
||||
|
||||
assertEquals("(version 3)\r\n", n.pack());
|
||||
|
||||
|
||||
n = PcbNode.parse("(host pcbnew \"(2013-07-07 BZR 4022)-stable\")");
|
||||
assertEquals(2, n.getChildren().size());
|
||||
assertEquals("pcbnew", n.getChildren().get(0));
|
||||
assertEquals("\"(2013-07-07 BZR 4022)-stable\"", n.getChildren().get(1));
|
||||
|
||||
|
||||
n = PcbNode.parse("(area 68.835001 116.9924 170.180001 180.5)");
|
||||
assertEquals(4, n.getChildren().size());
|
||||
|
||||
n = PcbNode.parse("(kicad_pcb\n (version 3)\r\n (host pcbnew \"(2013-07-07 BZR 4022)-stable\")\n)");
|
||||
assertEquals(2, n.getChildren().size());
|
||||
assertEquals("(kicad_pcb\r\n" +
|
||||
" (version 3)\r\n" +
|
||||
"\r\n" +
|
||||
" (host pcbnew \"(2013-07-07 BZR 4022)-stable\")\r\n" +
|
||||
")\r\n", n.pack());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseModule() {
|
||||
ModuleNode module = (ModuleNode) PcbNode.parse("(module SM0805 (layer F.Cu) (tedit 52BF06CE) (tstamp 52A5B5B5)\n" +
|
||||
" (at 205.359 170.688 180)\n" +
|
||||
" (path /52A59B3A)\n" +
|
||||
" (attr smd)\n" +
|
||||
" (fp_text reference R351 (at -0.127 0 270) (layer F.SilkS)\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.1016)))\n" +
|
||||
" )\n" +
|
||||
" (fp_text value 1M (at 0 -1.143 180) (layer F.SilkS) hide\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.10922)))\n" +
|
||||
" )\n" +
|
||||
" (fp_circle (center -1.651 0.762) (end -1.651 0.635) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -0.508 0.762) (end -1.524 0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -1.524 0.762) (end -1.524 -0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -1.524 -0.762) (end -0.508 -0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 0.508 -0.762) (end 1.524 -0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 1.524 -0.762) (end 1.524 0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 1.524 0.762) (end 0.508 0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (pad 1 smd rect (at -0.9525 0 180) (size 0.889 1.397)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 2 smd rect (at 0.9525 0 180) (size 0.889 1.397)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 14 GND)\n" +
|
||||
" )\n" +
|
||||
" (model smd/chip_cms.wrl\n" +
|
||||
" (at (xyz 0 0 0))\n" +
|
||||
" (scale (xyz 0.1 0.1 0.1))\n" +
|
||||
" (rotate (xyz 0 0 0))\n" +
|
||||
" )\n" +
|
||||
" )");
|
||||
assertEquals("R351", module.name);
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testConnected() {
|
||||
ModuleNode p353 = (ModuleNode) PcbNode.parse("(module PIN_ARRAY_10X2 (layer F.Cu) (tedit 52BF05FA) (tstamp 52B9B18D)\n" +
|
||||
" (at 179.07 166.37 270)\n" +
|
||||
" (path /52B479E1)\n" +
|
||||
" (fp_text reference P353 (at 2.667 -3.048 360) (layer F.SilkS)\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.1016)))\n" +
|
||||
" )\n" +
|
||||
" (fp_text value CONN_10X2 (at 0.254 4.318 270) (layer F.SilkS) hide\n" +
|
||||
" (effects (font (size 1.016 1.016) (thickness 0.2032)))\n" +
|
||||
" )\n" +
|
||||
" (fp_line (start 12.49934 2.49936) (end 12.49934 -2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 12.49934 -2.49936) (end -12.7508 -2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -12.7508 -2.49936) (end -12.7508 2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -12.7508 2.49936) (end 12.49934 2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (pad 1 thru_hole rect (at -11.47064 1.27 270) (size 1.524 1.524) (drill 0.8128)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 3 /CAN_TX)\n" +
|
||||
" )\n" +
|
||||
" (pad 2 thru_hole circle (at -11.47064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 5 /CS2)\n" +
|
||||
" )\n" +
|
||||
" (pad 3 thru_hole circle (at -8.93064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 9 /SPI_MISO)\n" +
|
||||
" )\n" +
|
||||
" (pad 4 thru_hole circle (at -8.93064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 10 /SPI_MOSI)\n" +
|
||||
" )\n" +
|
||||
" (pad 5 thru_hole circle (at -6.39064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 4 /CS1)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 thru_hole circle (at -6.39064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 11 /SPI_SCK)\n" +
|
||||
" )\n" +
|
||||
" (pad 7 thru_hole circle (at -3.85064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 6 /CS3)\n" +
|
||||
" )\n" +
|
||||
" (pad 8 thru_hole circle (at -3.85064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 9 thru_hole circle (at -1.31064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 7 /CS4)\n" +
|
||||
" )\n" +
|
||||
" (pad 10 thru_hole circle (at -1.31064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 8 /CS_SD_MODULE)\n" +
|
||||
" )\n" +
|
||||
" (pad 11 thru_hole circle (at 1.22936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 12 thru_hole circle (at 1.22936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 13 thru_hole circle (at 3.76936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 14 thru_hole circle (at 3.76936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 15 thru_hole circle (at 6.30936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 13 /USART_TX)\n" +
|
||||
" )\n" +
|
||||
" (pad 16 thru_hole circle (at 6.30936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 12 /USART_RX)\n" +
|
||||
" )\n" +
|
||||
" (pad 17 thru_hole circle (at 8.84936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 18 thru_hole circle (at 8.84936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 19 thru_hole circle (at 11.38936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 20 thru_hole circle (at 11.38936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (model lib/3d/M_header_10x2.wrl\n" +
|
||||
" (at (xyz 0 0 0))\n" +
|
||||
" (scale (xyz 1 1 1))\n" +
|
||||
" (rotate (xyz -90 0 0))\n" +
|
||||
" )\n" +
|
||||
" )\n");
|
||||
|
||||
SegmentNode segment = (SegmentNode) PcbNode.parse("(segment (start 221.32036 156.21) (end 222.631 154.89936) (width 0.254) (layer B.Cu) (net 5) (tstamp 52BE7B1B))");
|
||||
|
||||
assertFalse(p353.isConnected(segment.end));
|
||||
assertFalse(p353.isConnected(segment.start));
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testSegmentConnected() {
|
||||
SegmentNode s1 = (SegmentNode) PcbNode.parse("(segment (start 219.075 162.941) (end 219.075 163.322) (width 0.254) (layer F.Cu) (net 7) (tstamp 52BC5D9B))");
|
||||
|
||||
SegmentNode s0 = (SegmentNode) PcbNode.parse("(segment (start 216.662 161.544) (end 217.678 161.544) (width 0.254) (layer B.Cu) (net 7) (tstamp 52BC5D95))");
|
||||
SegmentNode s2 = (SegmentNode) PcbNode.parse("(segment (start 219.075 162.941) (end 219.075 163.322) (width 0.254) (layer F.Cu) (net 7) (tstamp 52BC5D9B))");
|
||||
|
||||
assertFalse(RemoveUnneededTraces.isUnused(Arrays.asList(s0, s2), s1, Collections.<PcbNode>emptyList()));
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testSegmentConnected2() {
|
||||
SegmentNode s = (SegmentNode) PcbNode.parse("(segment (start 213.106 171.069) (end 213.106 166.3065) (width 0.254) (layer F.Cu) (net 22))");
|
||||
|
||||
|
||||
ModuleNode mn = (ModuleNode) PcbNode.parse("(module MINI-USB-5P-3400020P1 (layer F.Cu) (tedit 52C0C373) (tstamp 52BAC27E)\n" +
|
||||
" (at 213.106 175.26)\n" +
|
||||
" (descr OPL)\n" +
|
||||
" (tags \"USB MINI 5 SMD-1\")\n" +
|
||||
" (path /52C034E1)\n" +
|
||||
" (attr smd)\n" +
|
||||
" (fp_text reference J351 (at 0 -1.905) (layer F.SilkS)\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.1016)))\n" +
|
||||
" )\n" +
|
||||
" (fp_text value MINI-USB-5P-3400020P1 (at 0.762 -0.254) (layer F.SilkS) hide\n" +
|
||||
" (effects (font (size 0.4318 0.4318) (thickness 0.0508)))\n" +
|
||||
" )\n" +
|
||||
" (fp_line (start 3.81 4.572) (end 3.81 3.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.81 4.572) (end -3.81 3.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start 2.032 -4.572) (end 3.302 -4.572) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start 3.81 -2.297) (end 3.81 0.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.81 4.572) (end 3.81 4.572) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.81 -2.297) (end -3.81 0.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.3 -4.572) (end -2.1 -4.572) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (pad 5 smd rect (at -1.6 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 14 GND)\n" +
|
||||
" )\n" +
|
||||
" (pad 4 smd rect (at -0.8 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" )\n" +
|
||||
" (pad 3 smd rect (at 0 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 22 N-0000056)\n" +
|
||||
" )\n" +
|
||||
" (pad 2 smd rect (at 0.8 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 19 N-000003)\n" +
|
||||
" )\n" +
|
||||
" (pad 1 smd rect (at 1.6 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 15 N-000001)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at -4.5 1.603 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at 4.5 1.603 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at -4.5 -3.897 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at 4.5 -3.897 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad \"\" np_thru_hole circle (at -2.159 -1.397 90) (size 1.016 1.016) (drill 0.762)\n" +
|
||||
" (layers *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad \"\" np_thru_hole circle (at 2.159 -1.397 90) (size 1.016 1.016) (drill 0.762)\n" +
|
||||
" (layers *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (model lib/3d/usb-2.wrl\n" +
|
||||
" (at (xyz 0 0 0))\n" +
|
||||
" (scale (xyz 1 1 1))\n" +
|
||||
" (rotate (xyz -90 0 -90))\n" +
|
||||
" )\n" +
|
||||
" )");
|
||||
|
||||
assertTrue(mn.isConnected(s.start));
|
||||
}
|
||||
}
|
||||
package com.rusefi.pcb.test;
|
||||
|
||||
import com.rusefi.misc.RemoveUnneededTraces;
|
||||
import com.rusefi.pcb.ModuleNode;
|
||||
import com.rusefi.pcb.PcbNode;
|
||||
import com.rusefi.pcb.SegmentNode;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Collections;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* (c) Andrey Belomutskiy
|
||||
* 12/8/13
|
||||
*/
|
||||
public class PcbNodeTest {
|
||||
@Test
|
||||
public void testParser() {
|
||||
PcbNode n = PcbNode.parse("(version 3\r\n)");
|
||||
assertEquals("version", n.nodeName);
|
||||
assertEquals(1, n.getChildren().size());
|
||||
|
||||
assertEquals("(version 3)\r\n", n.pack());
|
||||
|
||||
|
||||
n = PcbNode.parse("(host pcbnew \"(2013-07-07 BZR 4022)-stable\")");
|
||||
assertEquals(2, n.getChildren().size());
|
||||
assertEquals("pcbnew", n.getChildren().get(0));
|
||||
assertEquals("\"(2013-07-07 BZR 4022)-stable\"", n.getChildren().get(1));
|
||||
|
||||
|
||||
n = PcbNode.parse("(area 68.835001 116.9924 170.180001 180.5)");
|
||||
assertEquals(4, n.getChildren().size());
|
||||
|
||||
n = PcbNode.parse("(kicad_pcb\n (version 3)\r\n (host pcbnew \"(2013-07-07 BZR 4022)-stable\")\n)");
|
||||
assertEquals(2, n.getChildren().size());
|
||||
assertEquals("(kicad_pcb\r\n" +
|
||||
" (version 3)\r\n" +
|
||||
"\r\n" +
|
||||
" (host pcbnew \"(2013-07-07 BZR 4022)-stable\")\r\n" +
|
||||
")\r\n", n.pack());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseModule() {
|
||||
ModuleNode module = (ModuleNode) PcbNode.parse("(module SM0805 (layer F.Cu) (tedit 52BF06CE) (tstamp 52A5B5B5)\n" +
|
||||
" (at 205.359 170.688 180)\n" +
|
||||
" (path /52A59B3A)\n" +
|
||||
" (attr smd)\n" +
|
||||
" (fp_text reference R351 (at -0.127 0 270) (layer F.SilkS)\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.1016)))\n" +
|
||||
" )\n" +
|
||||
" (fp_text value 1M (at 0 -1.143 180) (layer F.SilkS) hide\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.10922)))\n" +
|
||||
" )\n" +
|
||||
" (fp_circle (center -1.651 0.762) (end -1.651 0.635) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -0.508 0.762) (end -1.524 0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -1.524 0.762) (end -1.524 -0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -1.524 -0.762) (end -0.508 -0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 0.508 -0.762) (end 1.524 -0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 1.524 -0.762) (end 1.524 0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 1.524 0.762) (end 0.508 0.762) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (pad 1 smd rect (at -0.9525 0 180) (size 0.889 1.397)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 2 smd rect (at 0.9525 0 180) (size 0.889 1.397)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 14 GND)\n" +
|
||||
" )\n" +
|
||||
" (model smd/chip_cms.wrl\n" +
|
||||
" (at (xyz 0 0 0))\n" +
|
||||
" (scale (xyz 0.1 0.1 0.1))\n" +
|
||||
" (rotate (xyz 0 0 0))\n" +
|
||||
" )\n" +
|
||||
" )");
|
||||
assertEquals("R351", module.getReference());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testConnected() {
|
||||
ModuleNode p353 = (ModuleNode) PcbNode.parse("(module PIN_ARRAY_10X2 (layer F.Cu) (tedit 52BF05FA) (tstamp 52B9B18D)\n" +
|
||||
" (at 179.07 166.37 270)\n" +
|
||||
" (path /52B479E1)\n" +
|
||||
" (fp_text reference P353 (at 2.667 -3.048 360) (layer F.SilkS)\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.1016)))\n" +
|
||||
" )\n" +
|
||||
" (fp_text value CONN_10X2 (at 0.254 4.318 270) (layer F.SilkS) hide\n" +
|
||||
" (effects (font (size 1.016 1.016) (thickness 0.2032)))\n" +
|
||||
" )\n" +
|
||||
" (fp_line (start 12.49934 2.49936) (end 12.49934 -2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start 12.49934 -2.49936) (end -12.7508 -2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -12.7508 -2.49936) (end -12.7508 2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (fp_line (start -12.7508 2.49936) (end 12.49934 2.49936) (layer F.SilkS) (width 0.09906))\n" +
|
||||
" (pad 1 thru_hole rect (at -11.47064 1.27 270) (size 1.524 1.524) (drill 0.8128)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 3 /CAN_TX)\n" +
|
||||
" )\n" +
|
||||
" (pad 2 thru_hole circle (at -11.47064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 5 /CS2)\n" +
|
||||
" )\n" +
|
||||
" (pad 3 thru_hole circle (at -8.93064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 9 /SPI_MISO)\n" +
|
||||
" )\n" +
|
||||
" (pad 4 thru_hole circle (at -8.93064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 10 /SPI_MOSI)\n" +
|
||||
" )\n" +
|
||||
" (pad 5 thru_hole circle (at -6.39064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 4 /CS1)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 thru_hole circle (at -6.39064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 11 /SPI_SCK)\n" +
|
||||
" )\n" +
|
||||
" (pad 7 thru_hole circle (at -3.85064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 6 /CS3)\n" +
|
||||
" )\n" +
|
||||
" (pad 8 thru_hole circle (at -3.85064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 9 thru_hole circle (at -1.31064 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 7 /CS4)\n" +
|
||||
" )\n" +
|
||||
" (pad 10 thru_hole circle (at -1.31064 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 8 /CS_SD_MODULE)\n" +
|
||||
" )\n" +
|
||||
" (pad 11 thru_hole circle (at 1.22936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 12 thru_hole circle (at 1.22936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 13 thru_hole circle (at 3.76936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 14 thru_hole circle (at 3.76936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 15 thru_hole circle (at 6.30936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 13 /USART_TX)\n" +
|
||||
" )\n" +
|
||||
" (pad 16 thru_hole circle (at 6.30936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" (net 12 /USART_RX)\n" +
|
||||
" )\n" +
|
||||
" (pad 17 thru_hole circle (at 8.84936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 18 thru_hole circle (at 8.84936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 19 thru_hole circle (at 11.38936 1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad 20 thru_hole circle (at 11.38936 -1.27 270) (size 1.524 1.524) (drill 1.016)\n" +
|
||||
" (layers *.Cu *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (model lib/3d/M_header_10x2.wrl\n" +
|
||||
" (at (xyz 0 0 0))\n" +
|
||||
" (scale (xyz 1 1 1))\n" +
|
||||
" (rotate (xyz -90 0 0))\n" +
|
||||
" )\n" +
|
||||
" )\n");
|
||||
|
||||
SegmentNode segment = (SegmentNode) PcbNode.parse("(segment (start 221.32036 156.21) (end 222.631 154.89936) (width 0.254) (layer B.Cu) (net 5) (tstamp 52BE7B1B))");
|
||||
|
||||
assertFalse(p353.isConnected(segment.end));
|
||||
assertFalse(p353.isConnected(segment.start));
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testSegmentConnected() {
|
||||
SegmentNode s1 = (SegmentNode) PcbNode.parse("(segment (start 219.075 162.941) (end 219.075 163.322) (width 0.254) (layer F.Cu) (net 7) (tstamp 52BC5D9B))");
|
||||
|
||||
SegmentNode s0 = (SegmentNode) PcbNode.parse("(segment (start 216.662 161.544) (end 217.678 161.544) (width 0.254) (layer B.Cu) (net 7) (tstamp 52BC5D95))");
|
||||
SegmentNode s2 = (SegmentNode) PcbNode.parse("(segment (start 219.075 162.941) (end 219.075 163.322) (width 0.254) (layer F.Cu) (net 7) (tstamp 52BC5D9B))");
|
||||
|
||||
assertFalse(RemoveUnneededTraces.isUnused(Arrays.asList(s0, s2), s1, Collections.<PcbNode>emptyList()));
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testSegmentConnected2() {
|
||||
SegmentNode s = (SegmentNode) PcbNode.parse("(segment (start 213.106 171.069) (end 213.106 166.3065) (width 0.254) (layer F.Cu) (net 22))");
|
||||
|
||||
|
||||
ModuleNode mn = (ModuleNode) PcbNode.parse("(module MINI-USB-5P-3400020P1 (layer F.Cu) (tedit 52C0C373) (tstamp 52BAC27E)\n" +
|
||||
" (at 213.106 175.26)\n" +
|
||||
" (descr OPL)\n" +
|
||||
" (tags \"USB MINI 5 SMD-1\")\n" +
|
||||
" (path /52C034E1)\n" +
|
||||
" (attr smd)\n" +
|
||||
" (fp_text reference J351 (at 0 -1.905) (layer F.SilkS)\n" +
|
||||
" (effects (font (size 0.50038 0.50038) (thickness 0.1016)))\n" +
|
||||
" )\n" +
|
||||
" (fp_text value MINI-USB-5P-3400020P1 (at 0.762 -0.254) (layer F.SilkS) hide\n" +
|
||||
" (effects (font (size 0.4318 0.4318) (thickness 0.0508)))\n" +
|
||||
" )\n" +
|
||||
" (fp_line (start 3.81 4.572) (end 3.81 3.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.81 4.572) (end -3.81 3.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start 2.032 -4.572) (end 3.302 -4.572) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start 3.81 -2.297) (end 3.81 0.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.81 4.572) (end 3.81 4.572) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.81 -2.297) (end -3.81 0.103) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (fp_line (start -3.3 -4.572) (end -2.1 -4.572) (layer F.SilkS) (width 0.127))\n" +
|
||||
" (pad 5 smd rect (at -1.6 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 14 GND)\n" +
|
||||
" )\n" +
|
||||
" (pad 4 smd rect (at -0.8 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" )\n" +
|
||||
" (pad 3 smd rect (at 0 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 22 N-0000056)\n" +
|
||||
" )\n" +
|
||||
" (pad 2 smd rect (at 0.8 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 19 N-000003)\n" +
|
||||
" )\n" +
|
||||
" (pad 1 smd rect (at 1.6 -4.191) (size 0.508 2.54)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 15 N-000001)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at -4.5 1.603 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at 4.5 1.603 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at -4.5 -3.897 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad 6 smd rect (at 4.5 -3.897 90) (size 2.794 2)\n" +
|
||||
" (layers F.Cu F.Paste F.Mask)\n" +
|
||||
" (net 18 N-000002)\n" +
|
||||
" )\n" +
|
||||
" (pad \"\" np_thru_hole circle (at -2.159 -1.397 90) (size 1.016 1.016) (drill 0.762)\n" +
|
||||
" (layers *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (pad \"\" np_thru_hole circle (at 2.159 -1.397 90) (size 1.016 1.016) (drill 0.762)\n" +
|
||||
" (layers *.Mask F.SilkS)\n" +
|
||||
" )\n" +
|
||||
" (model lib/3d/usb-2.wrl\n" +
|
||||
" (at (xyz 0 0 0))\n" +
|
||||
" (scale (xyz 1 1 1))\n" +
|
||||
" (rotate (xyz -90 0 -90))\n" +
|
||||
" )\n" +
|
||||
" )");
|
||||
|
||||
assertTrue(mn.isConnected(s.start));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,59 +1,59 @@
|
|||
package com.rusefi.util;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.File;
|
||||
import java.io.FileReader;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Generic file utilities
|
||||
* <p/>
|
||||
* 12/9/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class FileUtils {
|
||||
private FileUtils() {
|
||||
}
|
||||
|
||||
/**
|
||||
* @param fileName
|
||||
* @return Full content of the file as one String
|
||||
* @throws IOException
|
||||
*/
|
||||
public static String readFile(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
StringBuilder sb = new StringBuilder();
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
sb.append(line).append("\r\n");
|
||||
br.close();
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private static void checkExistence(String fileName) {
|
||||
if (!new File(fileName).isFile()) {
|
||||
System.err.println("File not found: " + fileName);
|
||||
System.exit(-1);
|
||||
}
|
||||
}
|
||||
|
||||
public static List<String> readFileToList(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
List<String> result = new ArrayList<String>();
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
result.add(line);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
package com.rusefi.util;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.File;
|
||||
import java.io.FileReader;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Generic file utilities
|
||||
* <p/>
|
||||
* 12/9/13
|
||||
* (c) Andrey Belomutskiy
|
||||
*/
|
||||
public class FileUtils {
|
||||
private FileUtils() {
|
||||
}
|
||||
|
||||
/**
|
||||
* @param fileName
|
||||
* @return Full content of the file as one String
|
||||
* @throws IOException
|
||||
*/
|
||||
public static String readFile(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
StringBuilder sb = new StringBuilder();
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
sb.append(line).append("\r\n");
|
||||
br.close();
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private static void checkExistence(String fileName) {
|
||||
if (!new File(fileName).isFile()) {
|
||||
System.err.println("File not found: " + fileName);
|
||||
System.exit(-1);
|
||||
}
|
||||
}
|
||||
|
||||
public static List<String> readFileToList(String fileName) throws IOException {
|
||||
checkExistence(fileName);
|
||||
|
||||
List<String> result = new ArrayList<String>();
|
||||
|
||||
System.out.println("Reading " + fileName);
|
||||
String line;
|
||||
BufferedReader br = new BufferedReader(new FileReader(fileName));
|
||||
|
||||
while (((line = br.readLine()) != null))
|
||||
result.add(line);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,2 +1,10 @@
|
|||
Here we have some tiny utilities
|
||||
gcc_map_reader reads the .map file produced by GCC and prints some details on what is RAM used for
|
||||
Here we have some tiny dev utilities - average rusEfi user would not need to use any of these!
|
||||
|
||||
|
||||
gcc_map_reader reads the .map file produced by GCC and prints some details on what is RAM used for
|
||||
|
||||
ts2c reads a piece of TunerStudio map and produces a matching C language piece of code
|
||||
|
||||
version2header creates a C language header containting current SVN version
|
||||
|
||||
enum2string
|
Binary file not shown.
|
@ -1,23 +1,23 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<option name="DEFAULT_COMPILER" value="Javac" />
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
<component name="CopyrightManager">
|
||||
<settings default="">
|
||||
<module2copyright />
|
||||
</settings>
|
||||
</component>
|
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
|
||||
</project>
|
||||
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue