| This is an old revision of the document! Table of ContentsA plan for managing construction and property setup on QActions for menus and toolbarsThere are three “developer roles” here which can readily be done by different people with very little interaction – so I suggest we do that, unless we can't find three, erm, “volunteers”. Developer A: Boilerplate code.Currently handled by: Chris (I think I can mostly script this, in fact) This task is almost complete – I'll look at the Developer C task and then return to tidy up some loose ends later Go through the code, particularly RosegardenGUIApp, MatrixView and NotationView. Find all the cases where actions are constructed with fixed data (not the completely dynamic actions such as the note font menu – those will need to continue having a full setup in the code). For each of these fixed actions, replace all the existing action setup code with the lines    createAction("action_name", SLOT(slotWhatever()));
where  Remove any code that sets the action label, icon, shortcut, action group, or toggleable status for these actions. Remove any code that places the actions into menus or toolbars (unless it looks like it's doing something clever!). 
Where we used to call  http://developer.kde.org/documentation/library/3.3-api/kdeui/html/kstdaction__p_8h-source.html 
(see the  
Finally, calls to  If anything is not clear about what to do with any of the actions, please discuss it – it's possible there will be all sorts of special cases and problems. Developer B: GUI definition files.Currently handled by: Julie 
For each of the .rc files in  Change e.g. <Action name="open_in_event_list"/> to e.g. <Action name="open_in_event_list" text="Open in &Event List Editor" icon="eventlist"/> 
That example does not have a shortcut or radio group and is not toggleable.  If the action has a shortcut, add a  The labels, icons and key sequences must match those used in the existing Rosegarden in US English locale. Gleaning these from the source code can sometimes be tricky; they're quite dispersed. For the labels in particular the easiest thing may even be to run up RG in US English and just copy what you see in the GUI (don't forget to put & before the underscored letter, and make sure you include “…” at the end where it appears in the GUI and nowhere else). Some actions appear in the menus but not in the .rc files. Many of these will be KDE standard actions (File|Open etc). These need to be added to the .rc files in the proper places using the action names, labels, and icon names found here: http://developer.kde.org/documentation/library/3.3-api/kdeui/html/kstdaction__p_8h-source.html and the shortcuts that appear in the GUI. Where an action appears in the file more than once (e.g. in a menubar and toolbar, or in a menubar and <State> element), leave the second and subsequent occurrences just as they are – all this extra information only needs to appear the first time. Leave the <State> elements completely unchanged, in fact (for the moment). Developer C: Action loading code.Currently handled by: Chris 
Implement the  
Implement a new  |