#21730 closed defect (fixed)
[patch] Not all JosmActions registering in toolbar
Reported by: | gaben | Owned by: | GerdP |
---|---|---|---|
Priority: | normal | Milestone: | |
Component: | Core | Version: | tested |
Keywords: | regression toolbar plugin | Cc: | GerdP |
Description (last modified by )
Changes made in r18321 blocks some core and custom actions, possibly added by a plugin (MainApplication.getToolbar().addCustomButton()
) from registering into the toolbar settings.
See the screenshot
Attachments (3)
Change History (24)
by , 3 years ago
Attachment: | JOSM_toolbar_actions.png added |
---|
comment:1 by , 3 years ago
Summary: | Not all JosmActions not registering in toolbar → Not all JosmActions registering in toolbar |
---|
comment:2 by , 3 years ago
comment:5 by , 3 years ago
Hmm, I don't understand why e.g. "Orthogonalize Shape / Undo" no longer appears and I think it was never meant to appear at that place. Instead it should appear somewehere under Tools.
comment:6 by , 3 years ago
I have no idea either. Also don't know why the phone action (provided by my plugin) forego the "move up" action. I think the move actions supposed to follow each other as they created at the same time(?).
The whole thing affects me in a way, that I can't use the JOSM core toolbar settings. So either I need to code it myself or have to choose fixing the button into the toolbar. Mostly inconvenience, but bothering.
comment:8 by , 3 years ago
Keywords: | toolbar added |
---|---|
Version: | → tested |
comment:9 by , 3 years ago
Description: | modified (diff) |
---|---|
Keywords: | plugin added |
comment:10 by , 3 years ago
I think I understand now better.
"Orthogonalize Shape" and "Orthogonalize Shape / Undo" both use the same icon "ortho" in the constructor and don't provide a specific toolbarId
. In this case the icon name is used as toolbarId
and my code change probably removes the duplicated entry.
I am not sure but I think there should be a warning logged when different actions use the same toolbarId
and the code for the corresponding actions should be fixed?
comment:11 by , 3 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
by , 3 years ago
Attachment: | 21730.patch added |
---|
comment:12 by , 3 years ago
@gaben: Problem was this part of the code:
for (Map.Entry<String, Action> a : regactions.entrySet()) { if (actions.get(a.getKey()) == null) { rootActionsNode.add(new DefaultMutableTreeNode(a.getValue())); } }
With my changes the actions.get(a.getKey()) == null
was never true and thus only actions which appear in a menu were added. I've renamed actions
to actionsInMenu
to make that clearer and now the map is cleared first in loadActions()
.
comment:13 by , 3 years ago
Have to think again about this. The new patch probably re-introduces the memory leak...
by , 3 years ago
Attachment: | 21730-2.patch added |
---|
comment:14 by , 3 years ago
2nd patch should also fix the memory leak as the map itself should be GCed now.
There's probably no need to use a ConcurrentHashMap, but my understanding of that is small.
comment:15 by , 3 years ago
[patch v2]
Something strange going on. Now I got the cycle layer actions in the toolbar settings. That's fine, but where were they until now? They are missing completely in previous versions too.They seem to appear based on layer availability, interesting.- The
actions
class variable was moved, but javadoc remains and now it is javadoc ofregactions
variable. Is this intended?
- unrelated, but the public
getToolString()
javadoc is missing
I can't comment on other changes, as I don't understand much of the GUI code :(
comment:16 by , 3 years ago
The javadoc is OK for regactions, too.
Does the patch solve your plugin problem?
comment:18 by , 3 years ago
OK, I think I'll wait a few days before committing this. Or do you think it is worth a hotfix?
comment:19 by , 3 years ago
Ah, you are kind. I'm fine with waiting, as the plugin is not released yet.
It will be my first public code repository, and I'm not sure about licensing stuff and also accidentally used my private email in commits, so I need to rewrite the whole repo history before making it public... Otherwise the plugin is usable. See #15250 for request.
comment:20 by , 3 years ago
Summary: | Not all JosmActions registering in toolbar → [patch] Not all JosmActions registering in toolbar |
---|
Cannot reproduce this with r18303, tried my normal config and also a clean one.