diff --git a/eeschema/help_common_strings.h b/eeschema/help_common_strings.h index f1f8515b82..4a69e6131f 100644 --- a/eeschema/help_common_strings.h +++ b/eeschema/help_common_strings.h @@ -78,7 +78,7 @@ #define HELP_RUN_LIB_VIEWER _( "Library Browser - Browse components" ) #define HELP_GENERATE_BOM _( "Generate bill of materials and/or cross references" ) #define HELP_IMPORT_FOOTPRINTS \ - _( "Back-import component footprint fields via CvPcb .cmp file" ) + _( "Back-import component footprint association fields from the .cmp back import file created by Pcbnew" ) // Component editor: #define HELP_ADD_PIN _( "Add pins to component" ) diff --git a/eeschema/menubar.cpp b/eeschema/menubar.cpp index 8271b9c138..106a30b1d5 100644 --- a/eeschema/menubar.cpp +++ b/eeschema/menubar.cpp @@ -1,7 +1,7 @@ /* * This program source code file is part of KiCad, a free EDA CAD application. * - * Copyright (C) 2014 Jean-Pierre Charras, jp.charras at wanadoo.fr + * Copyright (C) 2016 Jean-Pierre Charras, jp.charras at wanadoo.fr * Copyright (C) 2009-2014 Wayne Stambaugh * Copyright (C) 1992-2016 KiCad Developers, see AUTHORS.txt for contributors. * @@ -39,6 +39,32 @@ #include "hotkeys.h" #include "schframe.h" +// helper functions that build specific submenus: + +// Build the place submenu +static void preparePlaceMenu( wxMenu* aParentMenu ); + +// Build the files menu. Because some commands are available only if +// Eeschemat is run outside a project (run alone), aIsOutsideProject is false +// when Eeschema is run from Kicad manager, and true is run as stand alone app. +static void prepareFilesMenu( wxMenu* aParentMenu, bool aIsOutsideProject ); + +// Build the tools menu +static void prepareToolsMenu( wxMenu* aParentMenu ); + +// Build the help menu +static void prepareHelpMenu( wxMenu* aParentMenu ); + +// Build the help submenu +static void prepareImportExportMenu( wxMenu* aParentMenu ); + +// Build the edit menu +static void prepareEditMenu( wxMenu* aParentMenu ); + +// Build the view menu +static void prepareViewMenu( wxMenu* aParentMenu ); + + void SCH_EDIT_FRAME::ReCreateMenuBar() { // Create and try to get the current menubar @@ -59,17 +85,258 @@ void SCH_EDIT_FRAME::ReCreateMenuBar() // Menu File: wxMenu* fileMenu = new wxMenu; + prepareFilesMenu( fileMenu, Kiface().IsSingle() ); - if( Kiface().IsSingle() ) // not when under a project mgr + // Menu Edit: + wxMenu* editMenu = new wxMenu; + prepareEditMenu( editMenu ); + + // Menu View: + wxMenu* viewMenu = new wxMenu; + prepareViewMenu( viewMenu ); + + // Menu place: + wxMenu* placeMenu = new wxMenu; + preparePlaceMenu( placeMenu ); + + // Menu Preferences: + wxMenu* preferencesMenu = new wxMenu; + + // Library + AddMenuItem( preferencesMenu, + ID_CONFIG_REQ, + _( "Component &Libraries" ), + _( "Configure component libraries and paths" ), + KiBitmap( library_xpm ) ); + + // Options (Preferences on WXMAC) +#ifdef __WXMAC__ + preferencesMenu->Append( wxID_PREFERENCES ); +#else + AddMenuItem( preferencesMenu, + wxID_PREFERENCES, + _( "Schematic Editor &Options" ), + _( "Set Eeschema preferences" ), + KiBitmap( preference_xpm ) ); +#endif // __WXMAC__ + + // Language submenu + Pgm().AddMenuLanguageList( preferencesMenu ); + + // Import/export (submenu in preferences menu) + wxMenu* importExportSubmenu = new wxMenu(); + prepareImportExportMenu( importExportSubmenu ); + + AddMenuItem( preferencesMenu, importExportSubmenu, + wxID_ANY, + _( "&Import and export" ), + _( "Import and export settings" ), + KiBitmap( save_setup_xpm ) ); + + // Menu Tools: + wxMenu* toolsMenu = new wxMenu; + prepareToolsMenu( toolsMenu ); + + // Help Menu: + wxMenu* helpMenu = new wxMenu; + prepareHelpMenu( helpMenu ); + + // Create the menubar and append all submenus + menuBar->Append( fileMenu, _( "&File" ) ); + menuBar->Append( editMenu, _( "&Edit" ) ); + menuBar->Append( viewMenu, _( "&View" ) ); + menuBar->Append( placeMenu, _( "&Place" ) ); + menuBar->Append( preferencesMenu, _( "P&references" ) ); + menuBar->Append( toolsMenu, _( "&Tools" ) ); + menuBar->Append( helpMenu, _( "&Help" ) ); + + menuBar->Thaw(); + + // Associate the menu bar with the frame, if no previous menubar + if( GetMenuBar() == NULL ) + SetMenuBar( menuBar ); + else + menuBar->Refresh(); +} + + +void prepareViewMenu( wxMenu* aParentMenu ) +{ + wxString text; + + /** + * Important Note for ZOOM IN and ZOOM OUT commands from menubar: + * we cannot add hotkey shortcut here, because the hotkey HK_ZOOM_IN and HK_ZOOM_OUT + * events(default = WXK_F1 and WXK_F2) are *NOT* equivalent to this menu command: + * zoom in and out from hotkeys are equivalent to the pop up menu zoom + * From here, zooming is made around the screen center + * From hotkeys, zooming is made around the mouse cursor position + * (obviously not possible from the toolbar or menubar command) + * + * in others words HK_ZOOM_IN and HK_ZOOM_OUT *are NOT* accelerators + * for Zoom in and Zoom out sub menus + * SO WE ADD THE NAME OF THE CORRESPONDING HOTKEY AS A COMMENT, NOT AS A SHORTCUT + * using in AddHotkeyName call the option "false" (not a shortcut) + */ + + text = AddHotkeyName( _( "Zoom &In" ), g_Schematic_Hokeys_Descr, + HK_ZOOM_IN, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_ZOOM_IN, text, HELP_ZOOM_IN, KiBitmap( zoom_in_xpm ) ); + + text = AddHotkeyName( _( "Zoom &Out" ), g_Schematic_Hokeys_Descr, + HK_ZOOM_OUT, IS_ACCELERATOR ); // add accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_ZOOM_OUT, text, HELP_ZOOM_OUT, KiBitmap( zoom_out_xpm ) ); + + text = AddHotkeyName( _( "&Fit on Screen" ), g_Schematic_Hokeys_Descr, HK_ZOOM_AUTO ); + + AddMenuItem( aParentMenu, ID_ZOOM_PAGE, text, HELP_ZOOM_FIT, KiBitmap( zoom_fit_in_page_xpm ) ); + + text = AddHotkeyName( _( "&Redraw" ), g_Schematic_Hokeys_Descr, HK_ZOOM_REDRAW ); + + AddMenuItem( aParentMenu, ID_ZOOM_REDRAW, text, HELP_ZOOM_REDRAW, KiBitmap( zoom_redraw_xpm ) ); + + aParentMenu->AppendSeparator(); + + AddMenuItem( aParentMenu, + ID_HIERARCHY, + _( "Show &Hierarchical Navigator" ), + _( "Navigate hierarchical sheets" ), + KiBitmap( hierarchy_nav_xpm ) ); + + text = AddHotkeyName( _( "&Leave Sheet" ), g_Schematic_Hokeys_Descr, HK_LEAVE_SHEET ); + + AddMenuItem( aParentMenu, + ID_POPUP_SCH_LEAVE_SHEET, + text, + _( "Leave Sheet" ), + KiBitmap( leave_sheet_xpm ) ); +} + + +void preparePlaceMenu( wxMenu* aParentMenu ) +{ + wxString text; + + text = AddHotkeyName( _( "&Component" ), g_Schematic_Hokeys_Descr, + HK_ADD_NEW_COMPONENT, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_SCH_PLACE_COMPONENT, text, + HELP_PLACE_COMPONENTS, + KiBitmap( add_component_xpm ) ); + + text = AddHotkeyName( _( "&Power Port" ), g_Schematic_Hokeys_Descr, + HK_ADD_NEW_POWER, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_PLACE_POWER_BUTT, text, + HELP_PLACE_POWERPORT, + KiBitmap( add_power_xpm ) ); + + text = AddHotkeyName( _( "&Wire" ), g_Schematic_Hokeys_Descr, + HK_BEGIN_WIRE, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_WIRE_BUTT, text, + HELP_PLACE_WIRE, + KiBitmap( add_line_xpm ) ); + + text = AddHotkeyName( _( "&Bus" ), g_Schematic_Hokeys_Descr, + HK_BEGIN_BUS, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_BUS_BUTT, text, + HELP_PLACE_BUS, + KiBitmap( add_bus_xpm ) ); + + text = AddHotkeyName( _( "Wire to Bus &Entry" ), g_Schematic_Hokeys_Descr, + HK_ADD_WIRE_ENTRY, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_WIRETOBUS_ENTRY_BUTT, text, + HELP_PLACE_WIRE2BUS_ENTRY, + KiBitmap( add_line2bus_xpm ) ); + + text = AddHotkeyName( _( "Bus &to Bus Entry" ), g_Schematic_Hokeys_Descr, + HK_ADD_BUS_ENTRY, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_BUSTOBUS_ENTRY_BUTT, text, + HELP_PLACE_BUS2BUS_ENTRY, + KiBitmap( add_bus2bus_xpm ) ); + + text = AddHotkeyName( _( "&No Connect Flag" ), g_Schematic_Hokeys_Descr, + HK_ADD_NOCONN_FLAG, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_NOCONN_BUTT, text, HELP_PLACE_NC_FLAG, KiBitmap( noconn_xpm ) ); + + text = AddHotkeyName( _( "&Junction" ), g_Schematic_Hokeys_Descr, + HK_ADD_JUNCTION, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_JUNCTION_BUTT, text, + HELP_PLACE_JUNCTION, + KiBitmap( add_junction_xpm ) ); + + text = AddHotkeyName( _( "&Label" ), g_Schematic_Hokeys_Descr, + HK_ADD_LABEL, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_LABEL_BUTT, text, + HELP_PLACE_NETLABEL, + KiBitmap( add_line_label_xpm ) ); + + text = AddHotkeyName( _( "Gl&obal Label" ), g_Schematic_Hokeys_Descr, + HK_ADD_GLABEL, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_GLABEL_BUTT, text, + HELP_PLACE_GLOBALLABEL, + KiBitmap( add_glabel_xpm ) ); + + aParentMenu->AppendSeparator(); + + text = AddHotkeyName( _( "&Hierarchical Label" ), g_Schematic_Hokeys_Descr, + HK_ADD_HLABEL, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_HIERLABEL_BUTT, + text, HELP_PLACE_HIER_LABEL, + KiBitmap( add_hierarchical_label_xpm ) ); + + + text = AddHotkeyName( _( "Hierarchical &Sheet" ), g_Schematic_Hokeys_Descr, + HK_ADD_HIER_SHEET, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_SHEET_SYMBOL_BUTT, text, + HELP_PLACE_SHEET, + KiBitmap( add_hierarchical_subsheet_xpm ) ); + + AddMenuItem( aParentMenu, + ID_IMPORT_HLABEL_BUTT, + _( "I&mport Hierarchical Label" ), + HELP_IMPORT_SHEETPIN, + KiBitmap( import_hierarchical_label_xpm ) ); + + AddMenuItem( aParentMenu, + ID_SHEET_PIN_BUTT, + _( "Hierarchical Pi&n to Sheet" ), + HELP_PLACE_SHEETPIN, + KiBitmap( add_hierar_pin_xpm ) ); + + aParentMenu->AppendSeparator(); + + text = AddHotkeyName( _( "Graphic Pol&yline" ), g_Schematic_Hokeys_Descr, + HK_ADD_GRAPHIC_POLYLINE, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_LINE_COMMENT_BUTT, text, + HELP_PLACE_GRAPHICLINES, + KiBitmap( add_dashed_line_xpm ) ); + + text = AddHotkeyName( _( "&Graphic Text" ), g_Schematic_Hokeys_Descr, + HK_ADD_GRAPHIC_TEXT, IS_ACCELERATOR ); // add an accelerator, not a shortcut + AddMenuItem( aParentMenu, ID_TEXT_COMMENT_BUTT, text, + HELP_PLACE_GRAPHICTEXTS, + KiBitmap( add_text_xpm ) ); + + // Add graphic image + AddMenuItem( aParentMenu, ID_ADD_IMAGE_BUTT, _( "&Image" ), + HELP_PLACE_GRAPHICIMAGES, + KiBitmap( image_xpm ) ); +} + + +void prepareFilesMenu( wxMenu* aParentMenu, bool aIsOutsideProject ) +{ + wxString text; + + if( aIsOutsideProject ) // not when under a project mgr { - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, ID_NEW_PROJECT, _( "&New Schematic Project" ), _( "Clear current schematic hierarchy and start a new schematic root sheet" ), KiBitmap( new_sch_xpm ) ); text = AddHotkeyName( _( "&Open Schematic Project" ), g_Schematic_Hokeys_Descr, HK_LOAD_SCH ); - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, ID_LOAD_PROJECT, text, _( "Open an existing schematic hierarchy" ), KiBitmap( open_document_xpm ) ); @@ -91,50 +358,44 @@ void SCH_EDIT_FRAME::ReCreateMenuBar() if( Kiface().IsSingle() ) // not when under a project mgr { - AddMenuItem( fileMenu, openRecentMenu, + AddMenuItem( aParentMenu, openRecentMenu, wxID_ANY, _( "Open &Recent" ), _( "Open a recent opened schematic project" ), KiBitmap( open_project_xpm ) ); } - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, ID_APPEND_PROJECT, _( "Imp&ort Schematic Sheet Content" ), _( "Import a schematic sheet content from an other project in the current sheet" ), KiBitmap( open_document_xpm ) ); - fileMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); text = AddHotkeyName( _( "&Save Schematic Project" ), g_Schematic_Hokeys_Descr, HK_SAVE_SCH ); - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, ID_SAVE_PROJECT, text, _( "Save all sheets in schematic project" ), KiBitmap( save_project_xpm ) ); - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, ID_UPDATE_ONE_SHEET, _( "Save &Current Sheet Only" ), _( "Save only current schematic sheet" ), KiBitmap( save_xpm ) ); - if( Kiface().IsSingle() ) // not when under a project mgr + if( aIsOutsideProject ) // not when under a project mgr { - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, ID_SAVE_ONE_SHEET_UNDER_NEW_NAME, _( "Save C&urrent Sheet As" ), _( "Save current schematic sheet as..." ), KiBitmap( save_as_xpm ) ); } - fileMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); - AddMenuItem( fileMenu, - ID_SHEET_SET, - _( "Pa&ge Settings" ), - _( "Setting for sheet size and frame references" ), - KiBitmap( sheetset_xpm ) ); - - AddMenuItem( fileMenu, + AddMenuItem( aParentMenu, wxID_PRINT, _( "Pri&nt" ), _( "Print schematic sheet" ), @@ -142,8 +403,8 @@ void SCH_EDIT_FRAME::ReCreateMenuBar() // Plot submenu wxMenu* choice_plot_fmt = new wxMenu; - AddMenuItem( choice_plot_fmt, ID_GEN_PLOT_SCHEMATIC, - _( "&Plot" ), + + AddMenuItem( choice_plot_fmt, ID_GEN_PLOT_SCHEMATIC, _( "&Plot" ), _( "Plot schematic sheet in PostScript, PDF, SVG, DXF or HPGL format" ), KiBitmap( plot_xpm ) ); @@ -153,403 +414,210 @@ void SCH_EDIT_FRAME::ReCreateMenuBar() _( "Export drawings to clipboard" ), KiBitmap( copy_button_xpm ) ); - // Plot - AddMenuItem( fileMenu, choice_plot_fmt, + // Add plot submenu + AddMenuItem( aParentMenu, choice_plot_fmt, ID_GEN_PLOT, _( "&Plot" ), _( "Plot schematic sheet in HPGL, PostScript or SVG format" ), KiBitmap( plot_xpm ) ); - // Separator - fileMenu->AppendSeparator(); - // Quit - AddMenuItem( fileMenu, - wxID_EXIT, - _( "&Close" ), - _( "Close Eeschema" ), + aParentMenu->AppendSeparator(); + AddMenuItem( aParentMenu, wxID_EXIT, _( "&Close" ), _( "Close Eeschema" ), KiBitmap( exit_xpm ) ); +} - // Menu Edit: - wxMenu* editMenu = new wxMenu; + +void prepareEditMenu( wxMenu* aParentMenu ) +{ + wxString text; // Undo text = AddHotkeyName( _( "&Undo" ), g_Schematic_Hokeys_Descr, HK_UNDO ); - AddMenuItem( editMenu, wxID_UNDO, text, HELP_UNDO, KiBitmap( undo_xpm ) ); + AddMenuItem( aParentMenu, wxID_UNDO, text, HELP_UNDO, KiBitmap( undo_xpm ) ); // Redo text = AddHotkeyName( _( "&Redo" ), g_Schematic_Hokeys_Descr, HK_REDO ); - AddMenuItem( editMenu, wxID_REDO, text, HELP_REDO, KiBitmap( redo_xpm ) ); + AddMenuItem( aParentMenu, wxID_REDO, text, HELP_REDO, KiBitmap( redo_xpm ) ); // Delete - editMenu->AppendSeparator(); - AddMenuItem( editMenu, ID_SCHEMATIC_DELETE_ITEM_BUTT, + aParentMenu->AppendSeparator(); + AddMenuItem( aParentMenu, ID_SCHEMATIC_DELETE_ITEM_BUTT, _( "&Delete" ), HELP_DELETE_ITEMS, KiBitmap( delete_xpm ) ); // Find - editMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); text = AddHotkeyName( _( "&Find" ), g_Schematic_Hokeys_Descr, HK_FIND_ITEM ); - AddMenuItem( editMenu, ID_FIND_ITEMS, text, HELP_FIND, KiBitmap( find_xpm ) ); + AddMenuItem( aParentMenu, ID_FIND_ITEMS, text, HELP_FIND, KiBitmap( find_xpm ) ); // Find/Replace text = AddHotkeyName( _( "Find and Re&place" ), g_Schematic_Hokeys_Descr, HK_FIND_REPLACE ); - AddMenuItem( editMenu, wxID_REPLACE, text, HELP_REPLACE, + AddMenuItem( aParentMenu, wxID_REPLACE, text, HELP_REPLACE, KiBitmap( find_replace_xpm ) ); - // Import footprint association from the CvPcb cmp file: - editMenu->AppendSeparator(); - AddMenuItem( editMenu, ID_BACKANNO_ITEMS, - _( "Import Footprint Selection" ), + // Edit page layout: + aParentMenu->AppendSeparator(); + AddMenuItem( aParentMenu, ID_SHEET_SET, + _( "Pa&ge Settings (Size and Texts)" ), + _( "Settings for sheet size and frame references" ), + KiBitmap( sheetset_xpm ) ); + + // Import footprint association .cmp file which can be created by Pcbnew: + aParentMenu->AppendSeparator(); + AddMenuItem( aParentMenu, ID_BACKANNO_ITEMS, + _( "Import Footprint Association File" ), HELP_IMPORT_FOOTPRINTS, KiBitmap( import_footprint_names_xpm ) ); - - // Menu View: - wxMenu* viewMenu = new wxMenu; - - /** - * Important Note for ZOOM IN and ZOOM OUT commands from menubar: - * we cannot add hotkey shortcut here, because the hotkey HK_ZOOM_IN and HK_ZOOM_OUT - * events(default = WXK_F1 and WXK_F2) are *NOT* equivalent to this menu command: - * zoom in and out from hotkeys are equivalent to the pop up menu zoom - * From here, zooming is made around the screen center - * From hotkeys, zooming is made around the mouse cursor position - * (obviously not possible from the toolbar or menubar command) - * - * in others words HK_ZOOM_IN and HK_ZOOM_OUT *are NOT* accelerators - * for Zoom in and Zoom out sub menus - * SO WE ADD THE NAME OF THE CORRESPONDING HOTKEY AS A COMMENT, NOT AS A SHORTCUT - * using in AddHotkeyName call the option "false" (not a shortcut) - */ - - text = AddHotkeyName( _( "Zoom &In" ), g_Schematic_Hokeys_Descr, - HK_ZOOM_IN, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( viewMenu, ID_ZOOM_IN, text, HELP_ZOOM_IN, KiBitmap( zoom_in_xpm ) ); - - text = AddHotkeyName( _( "Zoom &Out" ), g_Schematic_Hokeys_Descr, - HK_ZOOM_OUT, IS_ACCELERATOR ); // add accelerator, not a shortcut - AddMenuItem( viewMenu, ID_ZOOM_OUT, text, HELP_ZOOM_OUT, KiBitmap( zoom_out_xpm ) ); - - text = AddHotkeyName( _( "&Fit on Screen" ), g_Schematic_Hokeys_Descr, HK_ZOOM_AUTO ); - - AddMenuItem( viewMenu, ID_ZOOM_PAGE, text, HELP_ZOOM_FIT, KiBitmap( zoom_fit_in_page_xpm ) ); - - text = AddHotkeyName( _( "&Redraw" ), g_Schematic_Hokeys_Descr, HK_ZOOM_REDRAW ); - - AddMenuItem( viewMenu, ID_ZOOM_REDRAW, text, HELP_ZOOM_REDRAW, KiBitmap( zoom_redraw_xpm ) ); - - viewMenu->AppendSeparator(); - - AddMenuItem( viewMenu, - ID_HIERARCHY, - _( "Show &Hierarchical Navigator" ), - _( "Navigate hierarchical sheets" ), - KiBitmap( hierarchy_nav_xpm ) ); - - text = AddHotkeyName( _( "&Leave Sheet" ), g_Schematic_Hokeys_Descr, HK_LEAVE_SHEET ); - - AddMenuItem( viewMenu, - ID_POPUP_SCH_LEAVE_SHEET, - text, - _( "Leave Sheet" ), - KiBitmap( leave_sheet_xpm ) ); - - // Menu place: - wxMenu* placeMenu = new wxMenu; - - text = AddHotkeyName( _( "&Component" ), g_Schematic_Hokeys_Descr, - HK_ADD_NEW_COMPONENT, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_SCH_PLACE_COMPONENT, text, - HELP_PLACE_COMPONENTS, - KiBitmap( add_component_xpm ) ); - - text = AddHotkeyName( _( "&Power Port" ), g_Schematic_Hokeys_Descr, - HK_ADD_NEW_POWER, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_PLACE_POWER_BUTT, text, - HELP_PLACE_POWERPORT, - KiBitmap( add_power_xpm ) ); - - text = AddHotkeyName( _( "&Wire" ), g_Schematic_Hokeys_Descr, - HK_BEGIN_WIRE, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_WIRE_BUTT, text, - HELP_PLACE_WIRE, - KiBitmap( add_line_xpm ) ); - - text = AddHotkeyName( _( "&Bus" ), g_Schematic_Hokeys_Descr, - HK_BEGIN_BUS, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_BUS_BUTT, text, - HELP_PLACE_BUS, - KiBitmap( add_bus_xpm ) ); - - text = AddHotkeyName( _( "Wire to Bus &Entry" ), g_Schematic_Hokeys_Descr, - HK_ADD_WIRE_ENTRY, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_WIRETOBUS_ENTRY_BUTT, text, - HELP_PLACE_WIRE2BUS_ENTRY, - KiBitmap( add_line2bus_xpm ) ); - - text = AddHotkeyName( _( "Bus &to Bus Entry" ), g_Schematic_Hokeys_Descr, - HK_ADD_BUS_ENTRY, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_BUSTOBUS_ENTRY_BUTT, text, - HELP_PLACE_BUS2BUS_ENTRY, - KiBitmap( add_bus2bus_xpm ) ); - - text = AddHotkeyName( _( "&No Connect Flag" ), g_Schematic_Hokeys_Descr, - HK_ADD_NOCONN_FLAG, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_NOCONN_BUTT, text, HELP_PLACE_NC_FLAG, KiBitmap( noconn_xpm ) ); - - text = AddHotkeyName( _( "&Junction" ), g_Schematic_Hokeys_Descr, - HK_ADD_JUNCTION, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_JUNCTION_BUTT, text, - HELP_PLACE_JUNCTION, - KiBitmap( add_junction_xpm ) ); - - text = AddHotkeyName( _( "&Label" ), g_Schematic_Hokeys_Descr, - HK_ADD_LABEL, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_LABEL_BUTT, text, - HELP_PLACE_NETLABEL, - KiBitmap( add_line_label_xpm ) ); - - text = AddHotkeyName( _( "Gl&obal Label" ), g_Schematic_Hokeys_Descr, - HK_ADD_GLABEL, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_GLABEL_BUTT, text, - HELP_PLACE_GLOBALLABEL, - KiBitmap( add_glabel_xpm ) ); - - placeMenu->AppendSeparator(); - - text = AddHotkeyName( _( "&Hierarchical Label" ), g_Schematic_Hokeys_Descr, - HK_ADD_HLABEL, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_HIERLABEL_BUTT, - text, HELP_PLACE_HIER_LABEL, - KiBitmap( add_hierarchical_label_xpm ) ); +} - text = AddHotkeyName( _( "Hierarchical &Sheet" ), g_Schematic_Hokeys_Descr, - HK_ADD_HIER_SHEET, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_SHEET_SYMBOL_BUTT, text, - HELP_PLACE_SHEET, - KiBitmap( add_hierarchical_subsheet_xpm ) ); - - AddMenuItem( placeMenu, - ID_IMPORT_HLABEL_BUTT, - _( "I&mport Hierarchical Label" ), - HELP_IMPORT_SHEETPIN, - KiBitmap( import_hierarchical_label_xpm ) ); - - AddMenuItem( placeMenu, - ID_SHEET_PIN_BUTT, - _( "Hierarchical Pi&n to Sheet" ), - HELP_PLACE_SHEETPIN, - KiBitmap( add_hierar_pin_xpm ) ); - - placeMenu->AppendSeparator(); - - text = AddHotkeyName( _( "Graphic Pol&yline" ), g_Schematic_Hokeys_Descr, - HK_ADD_GRAPHIC_POLYLINE, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_LINE_COMMENT_BUTT, text, - HELP_PLACE_GRAPHICLINES, - KiBitmap( add_dashed_line_xpm ) ); - - text = AddHotkeyName( _( "&Graphic Text" ), g_Schematic_Hokeys_Descr, - HK_ADD_GRAPHIC_TEXT, IS_ACCELERATOR ); // add an accelerator, not a shortcut - AddMenuItem( placeMenu, ID_TEXT_COMMENT_BUTT, text, - HELP_PLACE_GRAPHICTEXTS, - KiBitmap( add_text_xpm ) ); - - // Graphic image - AddMenuItem( placeMenu, ID_ADD_IMAGE_BUTT, _( "&Image" ), - HELP_PLACE_GRAPHICIMAGES, - KiBitmap( image_xpm ) ); - - // Menu Preferences: - wxMenu* preferencesMenu = new wxMenu; - - // Library - AddMenuItem( preferencesMenu, - ID_CONFIG_REQ, - _( "Component &Libraries" ), - _( "Configure component libraries and paths" ), - KiBitmap( library_xpm ) ); - - // Options (Preferences on WXMAC) - -#ifdef __WXMAC__ - preferencesMenu->Append( wxID_PREFERENCES ); -#else - AddMenuItem( preferencesMenu, - wxID_PREFERENCES, - _( "Schematic Editor &Options" ), - _( "Set Eeschema preferences" ), - KiBitmap( preference_xpm ) ); -#endif // __WXMAC__ - - - // Language submenu - Pgm().AddMenuLanguageList( preferencesMenu ); - - // Import/export - wxMenu* importExportSubmenu = new wxMenu(); - - AddMenuItem( importExportSubmenu, - ID_CONFIG_SAVE, - _( "&Save Preferences" ), - _( "Save application preferences" ), - KiBitmap( save_setup_xpm ) ); - - AddMenuItem( importExportSubmenu, - ID_CONFIG_READ, - _( "Load Prefe&rences" ), - _( "Load application preferences" ), - KiBitmap( import_setup_xpm ) ); - - AddMenuItem( importExportSubmenu, - ID_PREFERENCES_HOTKEY_EXPORT_CONFIG, - _( "E&xport Hotkeys" ), - _( "Create a hotkey configuration file to export the current hotkeys" ), - KiBitmap( hotkeys_export_xpm ) ); - - AddMenuItem( importExportSubmenu, - ID_PREFERENCES_HOTKEY_IMPORT_CONFIG, - _( "&Import Hotkeys" ), - _( "Load an existing hotkey configuration file" ), - KiBitmap( hotkeys_import_xpm ) ); - - AddMenuItem( preferencesMenu, importExportSubmenu, - wxID_ANY, - _( "&Import and export" ), - _( "Import and export settings" ), - KiBitmap( save_setup_xpm ) ); - - // Menu Tools: - wxMenu* toolsMenu = new wxMenu; +void prepareToolsMenu( wxMenu* aParentMenu ) +{ + wxString text; text = AddHotkeyName( _( "Update PCB from Schematics" ), g_Schematic_Hokeys_Descr, HK_UPDATE_PCB_FROM_SCH ); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_UPDATE_PCB_FROM_SCH, text, _( "Updates the PCB design with the current schematic (forward annotation)." ), KiBitmap( pcbnew_xpm ) ); // Run Pcbnew - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_RUN_PCB, _( "&Open PCB Editor" ), _( "Run Pcbnew" ), KiBitmap( pcbnew_xpm ) ); - toolsMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_RUN_LIBRARY, _( "Library &Editor" ), HELP_RUN_LIB_EDITOR, KiBitmap( libedit_xpm ) ); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_TO_LIBVIEW, _( "Library &Browser" ), HELP_RUN_LIB_VIEWER, KiBitmap( library_browse_xpm ) ); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_RESCUE_CACHED, _( "&Rescue Old Components" ), _( "Find old components in the project and rename/rescue them" ), KiBitmap( copycomponent_xpm ) ); - toolsMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_GET_ANNOTATE, _( "&Annotate Schematic" ), HELP_ANNOTATE, KiBitmap( annotate_xpm ) ); // ERC - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_GET_ERC, _( "Electrical Rules &Checker" ), _( "Perform electrical rules check" ), KiBitmap( erc_xpm ) ); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_GET_NETLIST, _( "Generate &Netlist File" ), _( "Generate the component netlist file" ), KiBitmap( netlist_xpm ) ); - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_GET_TOOLS, _( "Generate Bill of &Materials" ), HELP_GENERATE_BOM, KiBitmap( bom_xpm ) ); - toolsMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); // Run CvPcb - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_RUN_CVPCB, _( "A&ssign Component Footprints" ), _( "Run CvPcb" ), KiBitmap( cvpcb_xpm ) ); - toolsMenu->AppendSeparator(); + aParentMenu->AppendSeparator(); #ifdef KICAD_SPICE // Simulator - AddMenuItem( toolsMenu, + AddMenuItem( aParentMenu, ID_SIM_SHOW, _("Simula&tor"), _( "Simulate the circuit" ), KiBitmap( simulator_xpm ) ); #endif /* KICAD_SPICE */ - // Help Menu: - wxMenu* helpMenu = new wxMenu; +} - AddMenuItem( helpMenu, + +void prepareHelpMenu( wxMenu* aParentMenu ) +{ + AddMenuItem( aParentMenu, wxID_HELP, _( "Eeschema &Manual" ), _( "Open Eeschema Manual" ), KiBitmap( online_help_xpm ) ); - AddMenuItem( helpMenu, + AddMenuItem( aParentMenu, wxID_INDEX, _( "&Getting Started in KiCad" ), _( "Open \"Getting Started in KiCad\" guide for beginners" ), KiBitmap( help_xpm ) ); - AddMenuItem( helpMenu, + AddMenuItem( aParentMenu, ID_PREFERENCES_HOTKEY_SHOW_CURRENT_LIST, _( "&List Hotkeys" ), _( "Displays the current hotkeys list and corresponding commands" ), KiBitmap( hotkeys_xpm ) ); - helpMenu->AppendSeparator(); - AddMenuItem( helpMenu, ID_HELP_GET_INVOLVED, + aParentMenu->AppendSeparator(); + AddMenuItem( aParentMenu, ID_HELP_GET_INVOLVED, _( "Get &Involved" ), _( "Contribute to KiCad (opens a web browser)" ), KiBitmap( info_xpm ) ); - helpMenu->AppendSeparator(); - AddMenuItem( helpMenu, + aParentMenu->AppendSeparator(); + AddMenuItem( aParentMenu, wxID_ABOUT, _( "&About KiCad" ), _( "About KiCad" ), KiBitmap( info_xpm ) ); - - // Create the menubar and append all submenus - menuBar->Append( fileMenu, _( "&File" ) ); - menuBar->Append( editMenu, _( "&Edit" ) ); - menuBar->Append( viewMenu, _( "&View" ) ); - menuBar->Append( placeMenu, _( "&Place" ) ); - menuBar->Append( preferencesMenu, _( "P&references" ) ); - menuBar->Append( toolsMenu, _( "&Tools" ) ); - menuBar->Append( helpMenu, _( "&Help" ) ); - - menuBar->Thaw(); - - // Associate the menu bar with the frame, if no previous menubar - if( GetMenuBar() == NULL ) - SetMenuBar( menuBar ); - else - menuBar->Refresh(); } + + +void prepareImportExportMenu( wxMenu* aParentMenu ) +{ + AddMenuItem( aParentMenu, + ID_CONFIG_SAVE, + _( "&Save Preferences" ), + _( "Save application preferences" ), + KiBitmap( save_setup_xpm ) ); + + AddMenuItem( aParentMenu, + ID_CONFIG_READ, + _( "Load Prefe&rences" ), + _( "Load application preferences" ), + KiBitmap( import_setup_xpm ) ); + + aParentMenu->AppendSeparator(); + + AddMenuItem( aParentMenu, + ID_PREFERENCES_HOTKEY_EXPORT_CONFIG, + _( "E&xport Hotkeys" ), + _( "Create a hotkey configuration file to export the current hotkeys" ), + KiBitmap( hotkeys_export_xpm ) ); + + AddMenuItem( aParentMenu, + ID_PREFERENCES_HOTKEY_IMPORT_CONFIG, + _( "&Import Hotkeys" ), + _( "Load an existing hotkey configuration file" ), + KiBitmap( hotkeys_import_xpm ) ); +} \ No newline at end of file