I shortened the list to just manufacturers that have one or more
decoders defined. That does make it cleaner, thanks. A manufacturer
will also show up if one of their decoder is seen when doing an
identify, just so it's clear what was seen by the programmer; in that
case there's still no decoder name shown though.
This is the first time I have tried this for a while so I haven't seen all
the intermediate versions but I like this a lot more that what we had
before. I think it is good.
I guess the smoke is still comming off this version, but after I first went
in, created a new roster entry, read all the CVs from one of my locos
values, saved the config and then tried to reload by selecting the roster
entry at the top of the screen, it throws a NullPointerExecption at this
line in CombinedLocoSelListPane:
String modelString = locoEntry.getDecoderModel();
Here is the stack trace
Exception occurred during event dispatching:
java.lang.NullPointerException
at
jmri.jmrit.symbolicprog.CombinedLocoSelListPane.setDecoderSelectionFromLoco(
CombinedLocoSelListPane.java:233)
at
jmri.jmrit.symbolicprog.CombinedLocoSelPane$3.actionPerformed(CombinedLocoSe
lPane.java:135)
at javax.swing.JComboBox.fireActionEvent(JComboBox.java:870)
at javax.swing.JComboBox.selectedItemChanged(JComboBox.java:894)
at javax.swing.JComboBox.contentsChanged(JComboBox.java:950)
at javax.swing.JComboBox.intervalRemoved(JComboBox.java:1017)
at
javax.swing.AbstractListModel.fireIntervalRemoved(AbstractListModel.java:137
)
at
javax.swing.DefaultComboBoxModel.removeAllElements(DefaultComboBoxModel.java
:167)
at javax.swing.JComboBox.removeAllItems(JComboBox.java:568)
at jmri.jmrit.roster.Roster.updateComboBox(Roster.java:107)
at
jmri.jmrit.symbolicprog.CombinedLocoSelPane.propertyChange(CombinedLocoSelPa
ne.java:245)
at
java.beans.PropertyChangeSupport.firePropertyChange(PropertyChangeSupport.ja
va:152)
at jmri.jmrit.roster.Roster.firePropertyChange(Roster.java:290)
at jmri.jmrit.roster.Roster.addEntry(Roster.java:70)
at
jmri.jmrit.symbolicprog.CombinedLocoSelPane.openNewLoco(CombinedLocoSelPane.
java:403)
at
jmri.jmrit.symbolicprog.CombinedLocoSelPane.openButton(CombinedLocoSelPane.j
ava:362)
at
jmri.jmrit.symbolicprog.CombinedLocoSelPane$5.actionPerformed(CombinedLocoSe
lPane.java:175)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1450)
at
javax.swing.AbstractButton$ForwardActionEvents.actionPerformed(AbstractButto
n.java:1504)
at
javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:3
78)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:250)
at
javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener
.java:216)
at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:230)
at java.awt.Component.processMouseEvent(Component.java:3715)
at java.awt.Component.processEvent(Component.java:3544)
at java.awt.Container.processEvent(Container.java:1164)
at java.awt.Component.dispatchEventImpl(Component.java:2593)
at java.awt.Container.dispatchEventImpl(Container.java:1213)
at java.awt.Component.dispatchEvent(Component.java:2497)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:2451)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:2216)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:2125)
at java.awt.Container.dispatchEventImpl(Container.java:1200)
at java.awt.Window.dispatchEventImpl(Window.java:926)
at java.awt.Component.dispatchEvent(Component.java:2497)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:339)
at
java.awt.EventDispatchThread.pumpOneEventForHierarchy(EventDispatchThread.ja
va:131)
at
java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java
:98)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:85)
It seems that there is a problem with either
locoBox.getSelectedIndex()
or
locoBox.getSelectedItem()
in CombinedLocoSelPane around line 133
IMHO I think the whole roster thing is overkill and has added a level of
complexity that we could do without right now. I would be happier with just
saving a locos config to discrete files with the decoder address as the
filename and pop-up a file Load/Save dialog box that would let me choose
subdirectories etc so I can manage where things end up.
Anyway no matter how this stuff works - this is way better than fumbling
with the manual and my DT400 while doing hex conversions in my head... even
if I don't save anything to rosters etc and load it all from scratch out of
the loco...
Cheers
Alex