From fe10a9938fa1017cbeee1366569a35081533ae4d Mon Sep 17 00:00:00 2001 From: charras Date: Wed, 21 Oct 2009 19:16:25 +0000 Subject: [PATCH] Removed global default clearance, track size and vias drill. Use netclasses values only. --- CHANGELOG.txt | 23 + common/base_struct.cpp | 15 + copyright.h | 2 +- include/base_struct.h | 14 + ...board_item_struct.h => class_board_item.h} | 9 +- include/pcbstruct.h | 19 +- include/wxPcbStruct.h | 9 + internat/fr/kicad.mo | Bin 197944 -> 199431 bytes internat/fr/kicad.po | 2311 +++++++------ pcbnew/class_board.cpp | 16 + pcbnew/class_board.h | 11 +- pcbnew/class_board_connected_item.cpp | 49 +- pcbnew/class_module.cpp | 3 +- pcbnew/class_netclass.cpp | 11 +- pcbnew/class_netclass.h | 9 +- pcbnew/class_pad_draw_functions.cpp | 48 +- pcbnew/class_track.cpp | 21 +- pcbnew/class_track.h | 6 - pcbnew/class_zone.cpp | 14 +- pcbnew/class_zone.h | 22 +- pcbnew/classpcb.cpp | 5 +- pcbnew/dialog_design_rules.cpp | 102 +- pcbnew/dialog_design_rules.h | 2 + pcbnew/dialog_design_rules_base.cpp | 172 +- pcbnew/dialog_design_rules_base.fbp | 2380 +++++++++---- pcbnew/dialog_design_rules_base.h | 25 +- pcbnew/dialog_drc.cpp | 8 +- pcbnew/dialog_drc.h | 2 +- pcbnew/dialog_drc_base.cpp | 436 +-- pcbnew/dialog_drc_base.fbp | 2942 ++++++++--------- pcbnew/dialog_drc_base.h | 204 +- pcbnew/dialog_track_options.cpp | 12 - pcbnew/dialog_track_options_base.cpp | 37 +- pcbnew/dialog_track_options_base.fbp | 242 +- pcbnew/dialog_track_options_base.h | 9 +- pcbnew/drc.cpp | 14 +- pcbnew/export_gencad.cpp | 2 +- pcbnew/gendrill.cpp | 85 +- pcbnew/ioascii.cpp | 38 +- pcbnew/pcbcfg.cpp | 34 +- pcbnew/pcbcfg.h | 64 +- pcbnew/pcbnew.cpp | 2 +- pcbnew/print_board_functions.cpp | 2 +- pcbnew/protos.h | 1 - pcbnew/solve.cpp | 11 +- pcbnew/specctra_export.cpp | 14 +- pcbnew/specctra_import.cpp | 6 +- .../zones_convert_brd_items_to_polygons.cpp | 37 +- pcbnew/zones_test_and_combine_areas.cpp | 16 +- 49 files changed, 5210 insertions(+), 4306 deletions(-) rename include/{board_item_struct.h => class_board_item.h} (98%) diff --git a/CHANGELOG.txt b/CHANGELOG.txt index 06a93babc2..deb9c82dc7 100644 --- a/CHANGELOG.txt +++ b/CHANGELOG.txt @@ -4,6 +4,29 @@ KiCad ChangeLog 2009 Please add newer entries at the top, list the date and your name with email address. +2009-oct-20 UPDATE Wayne Stambaugh +================================================================================ +Replace component library editor draw item dialog box. +* Created new component library editor draw item dialog box with + wxFormBuilder. +* Removed previous DialogBlocks version of the draw item dialog box. +* Removed some additional global variables used in component library + editor. +* Add IsFillable() method to draw item base object. + +wxWidgets 2.9 string fixes and other minor updates. +* Replace all known instances of (const wxChar*) casts to GetChars() for + wxWidgets 2.9 compatibility. +* Cleaned up get component dialog so last part gets saved on wild card + selections. +* Remove redundant schematic component drawing code. +* Added SCH_COMPONENT constructor to create new component from library + component object. +* Add message panel helpers to WinEDA_DrawFrame and update old message + panel access code. +* Using library viewer to add component to schematic now respects unit + and body style selection. + 2009-oct-14 UPDATE Wayne Stambaugh ================================================================================ Fix save last grid size and other minor updates. diff --git a/common/base_struct.cpp b/common/base_struct.cpp index bece3de2d9..4bb619258b 100644 --- a/common/base_struct.cpp +++ b/common/base_struct.cpp @@ -526,6 +526,21 @@ bool EDA_Rect::Intersects( const EDA_Rect aRect ) const } +/**************************************************/ +EDA_Rect& EDA_Rect::Inflate( int aDelta ) +/**************************************************/ + +/** Function Inflate + * Inflate "this": move each horizontal edgeand each vertical edge by aDelta + * toward rect outside + * if aDelta is negative, move toward rect inside (deflate) + * Works for positive and negative rect size + * + */ +{ + Inflate( aDelta, aDelta ); +} + /**************************************************/ EDA_Rect& EDA_Rect::Inflate( wxCoord dx, wxCoord dy ) /**************************************************/ diff --git a/copyright.h b/copyright.h index bc012ac046..7e5ca37737 100644 --- a/copyright.h +++ b/copyright.h @@ -12,7 +12,7 @@ may choose to document this corresponding work in the CHANGELOG.txt file. /* * This program source code file is part of KICAD, a free EDA CAD application. * - * Copyright (C) 1992-2008 Jean-Pierre Charras, jean-pierre.charras@inpg.fr + * Copyright (C) 1992-2008 Jean-Pierre Charras, jean-pierre.charras@gipsa-lab.inpg.fr * Copyright (C) 1992-2008 Kicad Developers, see change_log.txt for contributors. * * This program is free software; you can redistribute it and/or diff --git a/include/base_struct.h b/include/base_struct.h index 51dfa8c215..67bed4e858 100644 --- a/include/base_struct.h +++ b/include/base_struct.h @@ -207,8 +207,22 @@ public: */ operator wxRect() const { return wxRect( m_Pos, m_Size ); } + /** Inflate + * Inflate this object: move each horizontal edge by dx and each vertical edge by dy + * toward rect outside + * if dx and/or dy is negative, move toward rect inside (deflate) + * Works for positive and negative rect size + */ EDA_Rect& Inflate( wxCoord dx, wxCoord dy ); + /** Inflate + * Inflate this object: move each horizontal edge and each vertical edge by aDelta + * toward rect outside + * if aDelta is negative, move toward rect inside (deflate) + * Works for positive and negative rect size + */ + EDA_Rect& Inflate( int aDelta ); + /** Function Merge * Modify Position and Size of this in order to contain the given rect * mainly used to calculate bounding boxes diff --git a/include/board_item_struct.h b/include/class_board_item.h similarity index 98% rename from include/board_item_struct.h rename to include/class_board_item.h index 589ed931a7..8fae5c2085 100644 --- a/include/board_item_struct.h +++ b/include/class_board_item.h @@ -224,7 +224,8 @@ class NETCLASS; /** * Class BOARD_CONNECTED_ITEM * This is a base class derived from BOARD_ITEM for items that can be connected - * mainly: tracks and pads + * and have a net, a netname, a clearance ... + * mainly: tracks, pads and zones * Handle connection info */ class BOARD_CONNECTED_ITEM : public BOARD_ITEM @@ -248,7 +249,7 @@ public: * @return int - the net code. */ int GetNet() const; - void SetNet( int aNetCode ); + virtual void SetNet( int aNetCode ); /** * Function GetSubNet @@ -289,6 +290,10 @@ public: }; +/* + * class BOARD_ITEM_LIST + * Handles a collection of BOARD_ITEM elements +*/ class BOARD_ITEM_LIST : public BOARD_ITEM { typedef boost::ptr_vector ITEM_ARRAY; diff --git a/include/pcbstruct.h b/include/pcbstruct.h index 6056eb218f..db4f552bfd 100644 --- a/include/pcbstruct.h +++ b/include/pcbstruct.h @@ -7,7 +7,7 @@ #include "base_struct.h" #include "class_base_screen.h" -#include "board_item_struct.h" +#include "class_board_item.h" // Definitions relatives aux libariries #define ENTETE_LIBRAIRIE "PCBNEW-LibModule-V1" @@ -148,7 +148,7 @@ enum ELEMENTS_NUMBERS PAD_CU_VISIBLE, PAD_CMP_VISIBLE }; - + /** * Function IsValidLayerIndex * tests whether a given integer is a valid layer index @@ -170,7 +170,7 @@ inline bool IsValidCopperLayerIndex( int aLayerIndex ) { return aLayerIndex >= FIRST_COPPER_LAYER && aLayerIndex <= LAST_COPPER_LAYER; } - + /** * Function IsValidNonCopperLayerIndex * tests whether an integer is a valid non copper layer index @@ -181,15 +181,13 @@ inline bool IsValidNonCopperLayerIndex( int aLayerIndex ) { return aLayerIndex >= FIRST_NO_COPPER_LAYER && aLayerIndex <= LAST_NO_COPPER_LAYER; } - + // Class for handle current printed board design settings class EDA_BoardDesignSettings { public: int m_CopperLayerCount; // Number of copper layers for this design - int m_ViaDrill; // via drill (for the entire board) - int m_ViaDrillCustomValue; // via drill for vias which must have a defined drill value - int m_MicroViaDrill; // micro via drill (for the entire board) + int m_ViaDrillCustomValue; // via drill for vias that have a specific drill value int m_CurrentViaSize; // Current via size int m_CurrentMicroViaSize; // Current micro via size bool m_MicroViasAllowed; // true to allow micro vias @@ -200,10 +198,11 @@ public: int m_EdgeSegmentWidth; // current graphic line width (EDGE layer only) int m_PcbTextWidth; // current Pcb (not module) Text width wxSize m_PcbTextSize; // current Pcb (not module) Text size - int m_TrackClearance; // track to track and track to pads clearance int m_TrackMinWidth; // track min value for width ((min copper size value int m_ViasMinSize; // vias (not micro vias) min diameter + int m_ViasMinDrill; // vias (not micro vias) min drill diameter int m_MicroViasMinSize; // micro vias (not vias) min diameter + int m_MicroViasMinDrill; // micro vias (not vias) min drill diameter int m_MaskMargin; // Solder mask margin int m_LayerThickness; // Layer Thickness for 3D viewer @@ -239,7 +238,7 @@ public: * @param aMask = The new bit-mask of visible layers */ void SetVisibleLayers( int aMask ); - + /** * Function IsLayerVisible * tests whether a given layer is visible @@ -281,7 +280,7 @@ public: { m_VisibleElements = aMask; } - + /** * Function IsElementVisible * tests whether a given element category is visible diff --git a/include/wxPcbStruct.h b/include/wxPcbStruct.h index 0889efec48..6db769a767 100644 --- a/include/wxPcbStruct.h +++ b/include/wxPcbStruct.h @@ -87,6 +87,15 @@ public: void InstallConfigFrame( const wxPoint& pos ); void Process_Config( wxCommandEvent& event ); void Update_config( wxWindow* displayframe ); + /** Function Read_Config + * Read the project configuration file + * @param projectFileName = the config filename + * if not found use kicad.pro + * if not found : initialize default values + * @return true if the current config is modified, false if no change + */ + bool Read_Config( const wxString& projectFileName ); + void OnHotKey( wxDC* DC, int hotkey, EDA_BaseStruct* DrawStruct ); bool OnHotkeyDeleteItem( wxDC* DC, EDA_BaseStruct* DrawStruct ); diff --git a/internat/fr/kicad.mo b/internat/fr/kicad.mo index af0b084758eb6a3b189cfc13ea606f6da387e04b..b005efc605e1500839a9f8e758f524658838a541 100644 GIT binary patch delta 63003 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 delta 61663 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 diff --git a/internat/fr/kicad.po b/internat/fr/kicad.po index 94b2e4f19e..8c85adfb68 100644 --- a/internat/fr/kicad.po +++ b/internat/fr/kicad.po @@ -2,8 +2,8 @@ msgid "" msgstr "" "Project-Id-Version: kicad\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2009-10-18 14:36+0100\n" -"PO-Revision-Date: 2009-10-18 14:39+0100\n" +"POT-Creation-Date: 2009-10-21 13:43+0100\n" +"PO-Revision-Date: 2009-10-21 13:45+0100\n" "Last-Translator: \n" "Language-Team: kicad team \n" "MIME-Version: 1.0\n" @@ -23,6 +23,7 @@ msgstr "" "X-Poedit-SearchPath-7: share\n" #: pcbnew/pcbnew.cpp:80 +#, fuzzy msgid "Pcbnew is already running, Continue?" msgstr "Pcbnew est en cours d'exécution. Continuer ?" @@ -81,11 +82,11 @@ msgstr "Choisir la précision des nombres en format EXCELLON" #: pcbnew/dialog_gendrill.cpp:192 msgid "absolute" -msgstr "Absolu" +msgstr "absolu" #: pcbnew/dialog_gendrill.cpp:193 msgid "auxiliary axis" -msgstr "Axe Auxiliaire" +msgstr "axe auxiliaire" #: pcbnew/dialog_gendrill.cpp:194 msgid "Drill Origin:" @@ -463,6 +464,22 @@ msgstr "Le texte est la REFERENCE!" msgid "Text is VALUE!" msgstr "Le texte est la VALEUR!" +#: pcbnew/pcbframe.cpp:293 +msgid "Board modified, Save before exit ?" +msgstr "Circuit Imprimé modifié, Sauver avant de quitter ?" + +#: pcbnew/pcbframe.cpp:294 +msgid "Confirmation" +msgstr "Confirmation" + +#: pcbnew/pcbframe.cpp:332 +msgid "3D Frame already opened" +msgstr "Fenêtre 3D déjà ouverte" + +#: pcbnew/pcbframe.cpp:336 +msgid "3D Viewer" +msgstr "Visu 3D" + #: pcbnew/solve.cpp:240 msgid "Abort routing?" msgstr "Arrêter le routage?" @@ -618,6 +635,10 @@ msgstr "" "Plan de perçage: trop de diamètres différents pour tracer 1 symbole par diamètre (max 13)\n" "Le tracé utilise des cercles pour quelques valeurs " +#: pcbnew/ioascii.cpp:175 +msgid "Error: Unexpected end of file !" +msgstr "Erreur: Fin de fichier inattendue !" + #: pcbnew/modedit_onclick.cpp:203 msgid "End Tool" msgstr "Fin Outil" @@ -1127,6 +1148,54 @@ msgstr "Forme X" msgid "Target Shape:" msgstr "Forme Mire:" +#: pcbnew/dialog_initpcb.cpp:103 +msgid "Items to delete" +msgstr "Eléments à effacer" + +#: pcbnew/dialog_initpcb.cpp:107 +msgid "Delete Zones" +msgstr "Effacer Zones" + +#: pcbnew/dialog_initpcb.cpp:111 +msgid "Delete Texts" +msgstr "Effacer Textes" + +#: pcbnew/dialog_initpcb.cpp:115 +msgid "Delete Edges" +msgstr "Effacements des contours" + +#: pcbnew/dialog_initpcb.cpp:119 +msgid "Delete Drawings" +msgstr "Effacement éléments de tracé" + +#: pcbnew/dialog_initpcb.cpp:123 +msgid "Delete Modules" +msgstr "Effacement des Modules" + +#: pcbnew/dialog_initpcb.cpp:127 +msgid "Delete Tracks" +msgstr "Effacer Pistes" + +#: pcbnew/dialog_initpcb.cpp:131 +msgid "Delete Markers" +msgstr "Effacer Marqueurs" + +#: pcbnew/dialog_initpcb.cpp:135 +msgid "Clear Board" +msgstr "Effacement du C.I." + +#: pcbnew/dialog_initpcb.cpp:142 +msgid "Track Filter" +msgstr "Filtre Piste" + +#: pcbnew/dialog_initpcb.cpp:146 +msgid "Include AutoRouted Tracks" +msgstr "Inclure Pistes Autoroutées" + +#: pcbnew/dialog_initpcb.cpp:150 +msgid "Include Locked Tracks" +msgstr "Inclure Pistes Verrouillées" + #: pcbnew/tool_pcb.cpp:29 msgid "" "Show active layer selections\n" @@ -1403,74 +1472,10 @@ msgstr "Grille" msgid "User Grid" msgstr "Grille perso" -#: pcbnew/tool_pcb.cpp:778 +#: pcbnew/tool_pcb.cpp:779 msgid "+/- to switch" msgstr "+/- pour commuter" -#: pcbnew/dialog_initpcb.cpp:103 -msgid "Items to delete" -msgstr "Eléments à effacer" - -#: pcbnew/dialog_initpcb.cpp:107 -msgid "Delete Zones" -msgstr "Effacer Zones" - -#: pcbnew/dialog_initpcb.cpp:111 -msgid "Delete Texts" -msgstr "Effacer Textes" - -#: pcbnew/dialog_initpcb.cpp:115 -msgid "Delete Edges" -msgstr "Effacements des contours" - -#: pcbnew/dialog_initpcb.cpp:119 -msgid "Delete Drawings" -msgstr "Effacement éléments de tracé" - -#: pcbnew/dialog_initpcb.cpp:123 -msgid "Delete Modules" -msgstr "Effacement des Modules" - -#: pcbnew/dialog_initpcb.cpp:127 -msgid "Delete Tracks" -msgstr "Effacer Pistes" - -#: pcbnew/dialog_initpcb.cpp:131 -msgid "Delete Markers" -msgstr "Effacer Marqueurs" - -#: pcbnew/dialog_initpcb.cpp:135 -msgid "Clear Board" -msgstr "Effacement du C.I." - -#: pcbnew/dialog_initpcb.cpp:142 -msgid "Track Filter" -msgstr "Filtre Piste" - -#: pcbnew/dialog_initpcb.cpp:146 -msgid "Include AutoRouted Tracks" -msgstr "Inclure Pistes Autoroutées" - -#: pcbnew/dialog_initpcb.cpp:150 -msgid "Include Locked Tracks" -msgstr "Inclure Pistes Verrouillées" - -#: pcbnew/pcbframe.cpp:292 -msgid "Board modified, Save before exit ?" -msgstr "Circuit Imprimé modifié, Sauver avant de quitter ?" - -#: pcbnew/pcbframe.cpp:293 -msgid "Confirmation" -msgstr "Confirmation" - -#: pcbnew/pcbframe.cpp:331 -msgid "3D Frame already opened" -msgstr "Fenêtre 3D déjà ouverte" - -#: pcbnew/pcbframe.cpp:335 -msgid "3D Viewer" -msgstr "Visu 3D" - #: pcbnew/find.cpp:117 msgid "Marker found" msgstr "Marqueur trouvé" @@ -1759,55 +1764,55 @@ msgstr "Garder" msgid "Deselect this layer to select the No Change state" msgstr "Désélectionner cette couche pour restorer l'option Pas de Changement" -#: pcbnew/class_zone.cpp:914 +#: pcbnew/class_zone.cpp:908 msgid "Zone Outline" msgstr "Contour de Zone" -#: pcbnew/class_zone.cpp:918 +#: pcbnew/class_zone.cpp:912 msgid "(Cutout)" msgstr "(Cutout)" -#: pcbnew/class_zone.cpp:920 +#: pcbnew/class_zone.cpp:914 msgid "Type" msgstr "Type" -#: pcbnew/class_zone.cpp:937 +#: pcbnew/class_zone.cpp:931 msgid "Not Found" msgstr " Non Trouvé" -#: pcbnew/class_zone.cpp:940 +#: pcbnew/class_zone.cpp:934 msgid "NetName" msgstr "NetName" -#: pcbnew/class_zone.cpp:943 +#: pcbnew/class_zone.cpp:937 msgid "Non Copper Zone" msgstr "Zone non Cuivre" -#: pcbnew/class_zone.cpp:947 +#: pcbnew/class_zone.cpp:941 msgid "NetCode" msgstr "NetCode" -#: pcbnew/class_zone.cpp:953 +#: pcbnew/class_zone.cpp:947 msgid "Corners" msgstr "Sommets" -#: pcbnew/class_zone.cpp:956 +#: pcbnew/class_zone.cpp:950 msgid "Segments" msgstr "Segments" -#: pcbnew/class_zone.cpp:958 +#: pcbnew/class_zone.cpp:952 msgid "Polygons" msgstr "Polygones" -#: pcbnew/class_zone.cpp:959 +#: pcbnew/class_zone.cpp:953 msgid "Fill mode" msgstr "Mode de remplissage" -#: pcbnew/class_zone.cpp:963 +#: pcbnew/class_zone.cpp:957 msgid "Hatch lines" msgstr "Lignes de Hachure" -#: pcbnew/class_zone.cpp:968 +#: pcbnew/class_zone.cpp:962 msgid "Corners in DrawList" msgstr "Sommets en Liste de dessin" @@ -2268,21 +2273,34 @@ msgstr "Créer Fichier " msgid " error" msgstr " erreur" -#: pcbnew/dialog_track_options.cpp:81 +#: pcbnew/pcbcfg.cpp:88 +msgid "Read Project File" +msgstr "Lire Fichier Projet" + +#: pcbnew/pcbcfg.cpp:98 +#, c-format +msgid "File %s not found" +msgstr "Fichier %s non trouvé" + +#: pcbnew/pcbcfg.cpp:233 +msgid "Save Project File" +msgstr "Sauver Fichier Projet" + +#: pcbnew/dialog_track_options.cpp:77 msgid "Enter new via diameter value:" msgstr "Entrer une nouvelle valeur du diamètre de via" -#: pcbnew/dialog_track_options.cpp:96 -#: pcbnew/dialog_track_options.cpp:151 +#: pcbnew/dialog_track_options.cpp:92 +#: pcbnew/dialog_track_options.cpp:147 msgid "Incorrect entered value. Aborted" msgstr "Valeur entrée incorrecte. Annulation" -#: pcbnew/dialog_track_options.cpp:106 -#: pcbnew/dialog_track_options.cpp:161 +#: pcbnew/dialog_track_options.cpp:102 +#: pcbnew/dialog_track_options.cpp:157 msgid "Too many values in list (max count reached). Aborted" msgstr "trop de valeurs en liste (compte maxi. atteint). Abandon" -#: pcbnew/dialog_track_options.cpp:136 +#: pcbnew/dialog_track_options.cpp:132 msgid "Enter new track size value:" msgstr "Entrer la nouvelle valeur le la largeur de piste:" @@ -2295,12 +2313,12 @@ msgid "Vias Custom Sizes List:" msgstr "Liste des Tailles de Vias Supplémentaires" #: pcbnew/dialog_track_options_base.cpp:43 -#: pcbnew/dialog_track_options_base.cpp:109 +#: pcbnew/dialog_track_options_base.cpp:85 msgid "Add" msgstr "Ajouter" #: pcbnew/dialog_track_options_base.cpp:46 -#: pcbnew/dialog_track_options_base.cpp:112 +#: pcbnew/dialog_track_options_base.cpp:88 msgid "Delete" msgstr "Supprimer" @@ -2329,58 +2347,18 @@ msgstr "" "et mettre le trou de la via à cette valeur spécifique en utilisant le menu popup." #: pcbnew/dialog_track_options_base.cpp:74 -msgid "Vias Options:" -msgstr "Options Vias:" - -#: pcbnew/dialog_track_options_base.cpp:76 -msgid "Through via" -msgstr "Via traversante" - -#: pcbnew/dialog_track_options_base.cpp:76 -msgid "Blind or buried via" -msgstr "Via enterrée ou aveugle" - -#: pcbnew/dialog_track_options_base.cpp:78 -msgid "Default Via Type" -msgstr "Via par Défaut" - -#: pcbnew/dialog_track_options_base.cpp:80 -msgid "" -"Select the current via type.\n" -"Trough via is the usual selection" -msgstr "" -"Sélection du type de via courant.\n" -"Via traversante est la sélection usuelle." - -#: pcbnew/dialog_track_options_base.cpp:87 -msgid "Do not allow micro vias" -msgstr "Ne pas autoriser les micro vias" - -#: pcbnew/dialog_track_options_base.cpp:87 -msgid "Allow micro vias" -msgstr "Autoriser les micro vias" - -#: pcbnew/dialog_track_options_base.cpp:91 -msgid "" -"Allows or do not allow use of micro vias\n" -"They are very small vias only from an external copper layer to its near neightbour" -msgstr "" -"Autorise ou non l'utilisation de micro vias\n" -"Ce sont de petites vias allant d'une couche externe à la plus proche couche interne uniquement" - -#: pcbnew/dialog_track_options_base.cpp:98 msgid "Dimensions:" msgstr "Dimensions:" -#: pcbnew/dialog_track_options_base.cpp:101 +#: pcbnew/dialog_track_options_base.cpp:77 msgid "Tracks Custom Widths List:" msgstr "Liste des Largeurs de Pistes Supplémentaires" -#: pcbnew/dialog_track_options_base.cpp:122 +#: pcbnew/dialog_track_options_base.cpp:98 msgid "Pads Mask Clearance:" msgstr "Marge Masque des Pads" -#: pcbnew/dialog_track_options_base.cpp:127 +#: pcbnew/dialog_track_options_base.cpp:103 msgid "This is the clearance between pads and the mask" msgstr "Ceci est l'espace entre pads et le masque" @@ -2516,6 +2494,59 @@ msgstr "Le caractère de délimitation de ligne doit être un seul caractère ' msgid "Un-terminated delimited string" msgstr "Ligne délimitée non terminée" +#: pcbnew/dialog_layers_setup.cpp:103 +msgid "Unknown" +msgstr "Inconnu" + +#: pcbnew/dialog_layers_setup.cpp:104 +msgid "Off-board, manufacturing" +msgstr "" + +#: pcbnew/dialog_layers_setup.cpp:105 +msgid "On-board, non-copper" +msgstr "" + +#: pcbnew/dialog_layers_setup.cpp:106 +msgid "On-board, copper" +msgstr "" + +#: pcbnew/dialog_layers_setup.cpp:107 +msgid "Board contour" +msgstr "Contour pcb" + +#: pcbnew/dialog_layers_setup.cpp:108 +#, fuzzy +msgid "Auxiliary" +msgstr "Axe Auxiliaire" + +#: pcbnew/dialog_layers_setup.cpp:116 +msgid "All Layers On" +msgstr "Toutes Couches Actives" + +#: pcbnew/dialog_layers_setup.cpp:117 +msgid "Single Side" +msgstr "Simple Face" + +#: pcbnew/dialog_layers_setup.cpp:118 +msgid "Single Side, SMD on Back" +msgstr "" + +#: pcbnew/dialog_layers_setup.cpp:119 +msgid "Two Layers, Parts on Front" +msgstr "2 couches, Composants sur le Dessus" + +#: pcbnew/dialog_layers_setup.cpp:120 +msgid "Two Layers, Parts on Both Faces" +msgstr "2 couches, Composants sur les 2 faces" + +#: pcbnew/dialog_layers_setup.cpp:121 +msgid "Four Layers, Parts on Front" +msgstr "4 couches, Composants sur le Dessus" + +#: pcbnew/dialog_layers_setup.cpp:122 +msgid "Four Layers, Parts on Both Faces" +msgstr "4 couches, Composants sur les 2 faces" + #: pcbnew/dialog_drc.cpp:136 #: pcbnew/dialog_drc.cpp:210 #, c-format @@ -2535,355 +2566,6 @@ msgstr "Fichier rapport DRC (.rpt)|*.rpt" msgid "Save DRC Report File" msgstr "Sauver Fichier Rapport DRC:" -#: pcbnew/menubarpcb.cpp:33 -msgid "&New Board" -msgstr "&Nouveau Circuit Imprimé" - -#: pcbnew/menubarpcb.cpp:34 -msgid "Clear old board and initialize a new one" -msgstr "Effacer ancien C.I. et créer un nouveau" - -#: pcbnew/menubarpcb.cpp:39 -msgid "&Load Board" -msgstr "Charger Circuit Imprimé" - -#: pcbnew/menubarpcb.cpp:40 -msgid "Delete old board and load new board" -msgstr "Effacer ancien C.I. et charger un nouveau" - -#: pcbnew/menubarpcb.cpp:45 -msgid "Append Board" -msgstr "Ajouter Circuit Imprimé" - -#: pcbnew/menubarpcb.cpp:46 -msgid "Add board to old board" -msgstr "Ajouter un C.I. au C.I. actuel" - -#: pcbnew/menubarpcb.cpp:51 -msgid "&Rescue" -msgstr "&Secours" - -#: pcbnew/menubarpcb.cpp:52 -msgid "Clear old board and get last rescue file" -msgstr "Effacer C.I. actuel et reprendre le dernier fichier secours" - -#: pcbnew/menubarpcb.cpp:57 -msgid "&Previous Version" -msgstr "&Précédente Version" - -#: pcbnew/menubarpcb.cpp:58 -msgid "Clear old board and get old version of board" -msgstr "Effacer le C.I. actuel et reprendre l'ancienne version" - -#: pcbnew/menubarpcb.cpp:65 -msgid "&Save Board\tCtrl-S" -msgstr "&Sauver Circuit Imprimé (Ctrl S)" - -#: pcbnew/menubarpcb.cpp:65 -msgid "Save current board" -msgstr "Sauver le C.I. actuel" - -#: pcbnew/menubarpcb.cpp:70 -msgid "Save Board as..." -msgstr "Sauver C.I. sous.." - -#: pcbnew/menubarpcb.cpp:71 -msgid "Save current board as.." -msgstr "Sauver le Circuit Imprimé courant sous.." - -#: pcbnew/menubarpcb.cpp:77 -msgid "P&rint" -msgstr "Imp&rimer" - -#: pcbnew/menubarpcb.cpp:78 -msgid "Print pcb board" -msgstr "Imprimer C.I." - -#: pcbnew/menubarpcb.cpp:82 -msgid "Print S&VG" -msgstr "Impression S&VG" - -#: pcbnew/menubarpcb.cpp:83 -msgid "Plot pcb board in SVG format" -msgstr "Tracer le circuit imprimé en format SVG" - -#: pcbnew/menubarpcb.cpp:88 -msgid "&Plot" -msgstr "&Tracer" - -#: pcbnew/menubarpcb.cpp:89 -msgid "Plot (HPGL, PostScript, or Gerber format)" -msgstr "Tracer ( format HPGL, POSTSCRIPT ou GERBER)" - -#: pcbnew/menubarpcb.cpp:98 -msgid "&Specctra DSN" -msgstr "&Specctra DSN" - -#: pcbnew/menubarpcb.cpp:99 -msgid "Export the current board to a \"Specctra DSN\" file" -msgstr "Exporte le CI courant dans un fichier au format \"Specctra DSN\"" - -#: pcbnew/menubarpcb.cpp:104 -msgid "&GenCAD" -msgstr "&GenCAD" - -#: pcbnew/menubarpcb.cpp:104 -msgid "Export GenCAD Format" -msgstr "Exporter en Format GenCAD" - -#: pcbnew/menubarpcb.cpp:109 -msgid "&Module Report" -msgstr "Rapport &Modules" - -#: pcbnew/menubarpcb.cpp:110 -msgid "Create a board report (footprint report)" -msgstr "Créer un fichier rapport (rapport sur modules)" - -#: pcbnew/menubarpcb.cpp:114 -msgid "&Export" -msgstr "&Exporter" - -#: pcbnew/menubarpcb.cpp:115 -msgid "Export board" -msgstr "Exporter le C.I." - -#: pcbnew/menubarpcb.cpp:123 -msgid "&Specctra Session" -msgstr "&Specctra Session" - -#: pcbnew/menubarpcb.cpp:124 -msgid "Import a routed \"Specctra Session\" (*.ses) file" -msgstr "Importer un fichier de routage \"Specctra Session\" (*.ses) " - -#: pcbnew/menubarpcb.cpp:136 -msgid "Import" -msgstr "Importer" - -#: pcbnew/menubarpcb.cpp:137 -msgid "Import files" -msgstr "Importer fichiers" - -#: pcbnew/menubarpcb.cpp:145 -msgid "Add New Footprints" -msgstr "Ajouter Nouveaux Modules" - -#: pcbnew/menubarpcb.cpp:146 -msgid "Archive new footprints only in a library (keep other footprints in this lib)" -msgstr "Archiver nouveaux modules seuls dans une librairie (garder les autres modules de cette librairie)" - -#: pcbnew/menubarpcb.cpp:150 -msgid "Create Footprint Archive" -msgstr "Créer Archive des Modules" - -#: pcbnew/menubarpcb.cpp:151 -msgid "Archive all footprints in a library(old lib will be deleted)" -msgstr "Archiver tous les modules dans une librairie (ancienne librairie supprimée)" - -#: pcbnew/menubarpcb.cpp:156 -msgid "Archive Footprints" -msgstr "Archiver Modules" - -#: pcbnew/menubarpcb.cpp:157 -msgid "Archive or add footprints in a library file" -msgstr "Archiver ou ajouter les modules dans un fichier librairie" - -#: pcbnew/menubarpcb.cpp:162 -msgid "E&xit" -msgstr "&Quitter" - -#: pcbnew/menubarpcb.cpp:163 -msgid "Quit PCBNEW" -msgstr "Quitter PCBNEW" - -#: pcbnew/menubarpcb.cpp:173 -msgid "&Library" -msgstr "&Librairie" - -#: pcbnew/menubarpcb.cpp:174 -msgid "Setting libraries, directories and others..." -msgstr "Sélectionner les librairies , répertoires et autres" - -#: pcbnew/menubarpcb.cpp:178 -msgid "&Colors and Visibility" -msgstr "&Couleurs et Visibilité" - -#: pcbnew/menubarpcb.cpp:179 -msgid "Select colors and visibilty of layers and some items" -msgstr "Sélection les couleurs et l' affichage des couches et de certains éléments du C.I." - -#: pcbnew/menubarpcb.cpp:183 -msgid "&General" -msgstr "&Général " - -#: pcbnew/menubarpcb.cpp:184 -msgid "Select general options for PCBNEW" -msgstr " Sélection options générales pour PCBNEW" - -#: pcbnew/menubarpcb.cpp:188 -msgid "&Display" -msgstr "&Affichage" - -#: pcbnew/menubarpcb.cpp:189 -msgid "Select how items (pads, tracks texts ... ) are displayed" -msgstr "Sélectionner comment les éléments (pads, pistes, textes ...) sont affichés" - -#: pcbnew/menubarpcb.cpp:196 -msgid "&Save Preferences" -msgstr "&Sauver Préférences" - -#: pcbnew/menubarpcb.cpp:197 -msgid "Save application preferences" -msgstr "Sauver les préférences de l'application" - -#: pcbnew/menubarpcb.cpp:201 -msgid "&Read Preferences" -msgstr "&Lire Préférences" - -#: pcbnew/menubarpcb.cpp:202 -msgid "Read application preferences" -msgstr "Lire les préférences de l'application" - -#: pcbnew/menubarpcb.cpp:212 -msgid "Design Rules" -msgstr "Règles de Conception" - -#: pcbnew/menubarpcb.cpp:212 -msgid "Open the design rules dialog editor" -msgstr "Ouvrir la fenêtre de dialogue de l'éditeur de règles de conception" - -#: pcbnew/menubarpcb.cpp:216 -msgid "Copper &Layers" -msgstr "Couches &Cuivre." - -#: pcbnew/menubarpcb.cpp:217 -msgid "Select copper layers count and layers names" -msgstr "Sélection du nombre de couches cuivre et du nom des couches" - -#: pcbnew/menubarpcb.cpp:227 -msgid "Tracks and Vias" -msgstr "Pistes et Vias" - -#: pcbnew/menubarpcb.cpp:228 -msgid "Adjust size and width for tracks and vias" -msgstr "Ajuster largeur des pistes et diamètre de vias" - -#: pcbnew/menubarpcb.cpp:238 -msgid "Texts and Drawings" -msgstr "Textes et Tracés" - -#: pcbnew/menubarpcb.cpp:243 -#: pcbnew/class_netinfo_item.cpp:150 -msgid "Pads" -msgstr "Pads" - -#: pcbnew/menubarpcb.cpp:244 -msgid "Adjust size,shape,layers... for pads" -msgstr "Ajuster taille, forme, couches... pour pads" - -#: pcbnew/menubarpcb.cpp:249 -msgid "&Save Setup" -msgstr "&Sauver Options" - -#: pcbnew/menubarpcb.cpp:250 -msgid "Save options in current directory" -msgstr "Sauver les options en répertoire de travail" - -#: pcbnew/menubarpcb.cpp:259 -msgid "Generate &Modules Position" -msgstr "Créer &Modules Position" - -#: pcbnew/menubarpcb.cpp:260 -msgid "Generate modules position file" -msgstr "Gen fichier Position des Modules" - -#: pcbnew/menubarpcb.cpp:265 -msgid "Create &Drill File" -msgstr "Créer &Fichier de Perçage" - -#: pcbnew/menubarpcb.cpp:266 -msgid "Generate excellon2 drill file" -msgstr "Créer Fichier de perçage Excellon2" - -#: pcbnew/menubarpcb.cpp:271 -msgid "Create &Component File" -msgstr "Créer &Fichier Cmp" - -#: pcbnew/menubarpcb.cpp:272 -msgid "Recreate .cmp file for CvPcb" -msgstr "Recréer le fichier .cmp pour CvPcb" - -#: pcbnew/menubarpcb.cpp:277 -msgid "Create &BOM File" -msgstr "Créer Fichier Liste du &Matériel" - -#: pcbnew/menubarpcb.cpp:278 -msgid "Recreate .csv file for CvPcb" -msgstr "Recréer le fichier .csv pour CvPcb" - -#: pcbnew/menubarpcb.cpp:287 -msgid "Global &Deletions" -msgstr "Effacements &Généraux" - -#: pcbnew/menubarpcb.cpp:288 -msgid "Delete tracks, modules, texts... on board" -msgstr "Effacer pistes, modules, textes... sur le C.I." - -#: pcbnew/menubarpcb.cpp:293 -msgid "&List Nets" -msgstr "Liste Equipots" - -#: pcbnew/menubarpcb.cpp:294 -msgid "List nets (names and id)" -msgstr "Lister équipotentielles (noms et numéros d'identification)" - -#: pcbnew/menubarpcb.cpp:299 -msgid "&Track Operations" -msgstr "Opéra&tions sur Pistes" - -#: pcbnew/menubarpcb.cpp:300 -msgid "Clean stubs, vias, delete break points, or connect dangling tracks to pads and vias" -msgstr "Nettoyer bouts de pistes, vias, points inutiles, ou connecter extrémités de pistes mal connectées au centre de pads ou vias" - -#: pcbnew/menubarpcb.cpp:305 -msgid "&Swap Layers" -msgstr "&Permutte Couches" - -#: pcbnew/menubarpcb.cpp:306 -msgid "Swap tracks on copper layers or drawings on others layers" -msgstr "Permutation de couches" - -#: pcbnew/menubarpcb.cpp:315 -msgid "Open the PCBNEW manual" -msgstr "Ouvrir la Documentation de PCBNEW" - -#: pcbnew/menubarpcb.cpp:319 -msgid "&About PCBNEW" -msgstr "&Au Sujet de PCBNEW" - -#: pcbnew/menubarpcb.cpp:320 -msgid "About PCBNEW printed circuit board designer" -msgstr "Au Sujet de PCBNEW outil de conception de C.I." - -#: pcbnew/menubarpcb.cpp:333 -msgid "&File" -msgstr "&Fichiers" - -#: pcbnew/menubarpcb.cpp:334 -msgid "&Preferences" -msgstr "&Préférences" - -#: pcbnew/menubarpcb.cpp:335 -msgid "&Design Rules" -msgstr "&Règles de Conception" - -#: pcbnew/menubarpcb.cpp:337 -msgid "&Miscellaneous" -msgstr "&Divers" - -#: pcbnew/menubarpcb.cpp:338 -msgid "P&ostprocess" -msgstr "P&ostprocesseurs" - #: pcbnew/moduleframe.cpp:221 msgid "Module Editor: Module modified! Continue?" msgstr "Editeur de Module: Module modifié! Continuer ?" @@ -2926,7 +2608,6 @@ msgid "Delete Pad (module %s %s) " msgstr "Effacer Pad (module %s %s) " #: pcbnew/modules.cpp:82 -#: pcbnew/librairi.cpp:523 msgid "Name:" msgstr "Nom:" @@ -2950,6 +2631,10 @@ msgstr "Nom Equipot" msgid "Net Code" msgstr "Net Code" +#: pcbnew/class_netinfo_item.cpp:150 +msgid "Pads" +msgstr "Pads" + #: pcbnew/class_netinfo_item.cpp:165 msgid "Vias" msgstr "Vias" @@ -3610,6 +3295,350 @@ msgstr "couche E.C.O.2" msgid "Draft layer" msgstr "Couche dessin" +#: pcbnew/menubarpcb.cpp:33 +msgid "&New Board" +msgstr "&Nouveau Circuit Imprimé" + +#: pcbnew/menubarpcb.cpp:34 +msgid "Clear old board and initialize a new one" +msgstr "Effacer ancien C.I. et créer un nouveau" + +#: pcbnew/menubarpcb.cpp:39 +msgid "&Load Board" +msgstr "Charger Circuit Imprimé" + +#: pcbnew/menubarpcb.cpp:40 +msgid "Delete old board and load new board" +msgstr "Effacer ancien C.I. et charger un nouveau" + +#: pcbnew/menubarpcb.cpp:45 +msgid "Append Board" +msgstr "Ajouter Circuit Imprimé" + +#: pcbnew/menubarpcb.cpp:46 +msgid "Add board to old board" +msgstr "Ajouter un C.I. au C.I. actuel" + +#: pcbnew/menubarpcb.cpp:51 +msgid "&Rescue" +msgstr "&Secours" + +#: pcbnew/menubarpcb.cpp:52 +msgid "Clear old board and get last rescue file" +msgstr "Effacer C.I. actuel et reprendre le dernier fichier secours" + +#: pcbnew/menubarpcb.cpp:57 +msgid "&Previous Version" +msgstr "&Précédente Version" + +#: pcbnew/menubarpcb.cpp:58 +msgid "Clear old board and get old version of board" +msgstr "Effacer le C.I. actuel et reprendre l'ancienne version" + +#: pcbnew/menubarpcb.cpp:65 +msgid "&Save Board\tCtrl-S" +msgstr "&Sauver Circuit Imprimé (Ctrl S)" + +#: pcbnew/menubarpcb.cpp:65 +msgid "Save current board" +msgstr "Sauver le C.I. actuel" + +#: pcbnew/menubarpcb.cpp:70 +msgid "Save Board as..." +msgstr "Sauver C.I. sous.." + +#: pcbnew/menubarpcb.cpp:71 +msgid "Save current board as.." +msgstr "Sauver le Circuit Imprimé courant sous.." + +#: pcbnew/menubarpcb.cpp:77 +msgid "P&rint" +msgstr "Imp&rimer" + +#: pcbnew/menubarpcb.cpp:78 +msgid "Print pcb board" +msgstr "Imprimer C.I." + +#: pcbnew/menubarpcb.cpp:82 +msgid "Print S&VG" +msgstr "Impression S&VG" + +#: pcbnew/menubarpcb.cpp:83 +msgid "Plot pcb board in SVG format" +msgstr "Tracer le circuit imprimé en format SVG" + +#: pcbnew/menubarpcb.cpp:88 +msgid "&Plot" +msgstr "&Tracer" + +#: pcbnew/menubarpcb.cpp:89 +msgid "Plot (HPGL, PostScript, or Gerber format)" +msgstr "Tracer ( format HPGL, POSTSCRIPT ou GERBER)" + +#: pcbnew/menubarpcb.cpp:98 +msgid "&Specctra DSN" +msgstr "&Specctra DSN" + +#: pcbnew/menubarpcb.cpp:99 +msgid "Export the current board to a \"Specctra DSN\" file" +msgstr "Exporte le CI courant dans un fichier au format \"Specctra DSN\"" + +#: pcbnew/menubarpcb.cpp:104 +msgid "&GenCAD" +msgstr "&GenCAD" + +#: pcbnew/menubarpcb.cpp:104 +msgid "Export GenCAD Format" +msgstr "Exporter en Format GenCAD" + +#: pcbnew/menubarpcb.cpp:109 +msgid "&Module Report" +msgstr "Rapport &Modules" + +#: pcbnew/menubarpcb.cpp:110 +msgid "Create a board report (footprint report)" +msgstr "Créer un fichier rapport (rapport sur modules)" + +#: pcbnew/menubarpcb.cpp:114 +msgid "&Export" +msgstr "&Exporter" + +#: pcbnew/menubarpcb.cpp:115 +msgid "Export board" +msgstr "Exporter le C.I." + +#: pcbnew/menubarpcb.cpp:123 +msgid "&Specctra Session" +msgstr "&Specctra Session" + +#: pcbnew/menubarpcb.cpp:124 +msgid "Import a routed \"Specctra Session\" (*.ses) file" +msgstr "Importer un fichier de routage \"Specctra Session\" (*.ses) " + +#: pcbnew/menubarpcb.cpp:136 +msgid "Import" +msgstr "Importer" + +#: pcbnew/menubarpcb.cpp:137 +msgid "Import files" +msgstr "Importer fichiers" + +#: pcbnew/menubarpcb.cpp:145 +msgid "Add New Footprints" +msgstr "Ajouter Nouveaux Modules" + +#: pcbnew/menubarpcb.cpp:146 +msgid "Archive new footprints only in a library (keep other footprints in this lib)" +msgstr "Archiver nouveaux modules seuls dans une librairie (garder les autres modules de cette librairie)" + +#: pcbnew/menubarpcb.cpp:150 +msgid "Create Footprint Archive" +msgstr "Créer Archive des Modules" + +#: pcbnew/menubarpcb.cpp:151 +msgid "Archive all footprints in a library(old lib will be deleted)" +msgstr "Archiver tous les modules dans une librairie (ancienne librairie supprimée)" + +#: pcbnew/menubarpcb.cpp:156 +msgid "Archive Footprints" +msgstr "Archiver Modules" + +#: pcbnew/menubarpcb.cpp:157 +msgid "Archive or add footprints in a library file" +msgstr "Archiver ou ajouter les modules dans un fichier librairie" + +#: pcbnew/menubarpcb.cpp:162 +msgid "E&xit" +msgstr "&Quitter" + +#: pcbnew/menubarpcb.cpp:163 +msgid "Quit PCBNEW" +msgstr "Quitter PCBNEW" + +#: pcbnew/menubarpcb.cpp:173 +msgid "&Library" +msgstr "&Librairie" + +#: pcbnew/menubarpcb.cpp:174 +msgid "Setting libraries, directories and others..." +msgstr "Sélectionner les librairies , répertoires et autres" + +#: pcbnew/menubarpcb.cpp:178 +msgid "&Colors and Visibility" +msgstr "&Couleurs et Visibilité" + +#: pcbnew/menubarpcb.cpp:179 +msgid "Select colors and visibilty of layers and some items" +msgstr "Sélection les couleurs et l' affichage des couches et de certains éléments du C.I." + +#: pcbnew/menubarpcb.cpp:183 +msgid "&General" +msgstr "&Général " + +#: pcbnew/menubarpcb.cpp:184 +msgid "Select general options for PCBNEW" +msgstr " Sélection options générales pour PCBNEW" + +#: pcbnew/menubarpcb.cpp:188 +msgid "&Display" +msgstr "&Affichage" + +#: pcbnew/menubarpcb.cpp:189 +msgid "Select how items (pads, tracks texts ... ) are displayed" +msgstr "Sélectionner comment les éléments (pads, pistes, textes ...) sont affichés" + +#: pcbnew/menubarpcb.cpp:196 +msgid "&Save Preferences" +msgstr "&Sauver Préférences" + +#: pcbnew/menubarpcb.cpp:197 +msgid "Save application preferences" +msgstr "Sauver les préférences de l'application" + +#: pcbnew/menubarpcb.cpp:201 +msgid "&Read Preferences" +msgstr "&Lire Préférences" + +#: pcbnew/menubarpcb.cpp:202 +msgid "Read application preferences" +msgstr "Lire les préférences de l'application" + +#: pcbnew/menubarpcb.cpp:212 +msgid "Design Rules" +msgstr "Règles de Conception" + +#: pcbnew/menubarpcb.cpp:212 +msgid "Open the design rules dialog editor" +msgstr "Ouvrir la fenêtre de dialogue de l'éditeur de règles de conception" + +#: pcbnew/menubarpcb.cpp:223 +msgid "&Layers Setup" +msgstr "&Options Couches" + +#: pcbnew/menubarpcb.cpp:224 +msgid "Enable and set properties of layers" +msgstr "" + +#: pcbnew/menubarpcb.cpp:235 +msgid "Tracks and Vias" +msgstr "Pistes et Vias" + +#: pcbnew/menubarpcb.cpp:236 +msgid "Adjust size and width for tracks and vias" +msgstr "Ajuster largeur des pistes et diamètre de vias" + +#: pcbnew/menubarpcb.cpp:246 +msgid "Texts and Drawings" +msgstr "Textes et Tracés" + +#: pcbnew/menubarpcb.cpp:252 +msgid "Adjust size,shape,layers... for pads" +msgstr "Ajuster taille, forme, couches... pour pads" + +#: pcbnew/menubarpcb.cpp:257 +msgid "&Save Setup" +msgstr "&Sauver Options" + +#: pcbnew/menubarpcb.cpp:258 +msgid "Save options in current directory" +msgstr "Sauver les options en répertoire de travail" + +#: pcbnew/menubarpcb.cpp:267 +msgid "Generate &Modules Position" +msgstr "Créer &Modules Position" + +#: pcbnew/menubarpcb.cpp:268 +msgid "Generate modules position file" +msgstr "Gen fichier Position des Modules" + +#: pcbnew/menubarpcb.cpp:273 +msgid "Create &Drill File" +msgstr "Créer &Fichier de Perçage" + +#: pcbnew/menubarpcb.cpp:274 +msgid "Generate excellon2 drill file" +msgstr "Créer Fichier de perçage Excellon2" + +#: pcbnew/menubarpcb.cpp:279 +msgid "Create &Component File" +msgstr "Créer &Fichier Cmp" + +#: pcbnew/menubarpcb.cpp:280 +msgid "Recreate .cmp file for CvPcb" +msgstr "Recréer le fichier .cmp pour CvPcb" + +#: pcbnew/menubarpcb.cpp:285 +msgid "Create &BOM File" +msgstr "Créer Fichier Liste du &Matériel" + +#: pcbnew/menubarpcb.cpp:286 +msgid "Recreate .csv file for CvPcb" +msgstr "Recréer le fichier .csv pour CvPcb" + +#: pcbnew/menubarpcb.cpp:295 +msgid "Global &Deletions" +msgstr "Effacements &Généraux" + +#: pcbnew/menubarpcb.cpp:296 +msgid "Delete tracks, modules, texts... on board" +msgstr "Effacer pistes, modules, textes... sur le C.I." + +#: pcbnew/menubarpcb.cpp:301 +msgid "&List Nets" +msgstr "Liste Equipots" + +#: pcbnew/menubarpcb.cpp:302 +msgid "List nets (names and id)" +msgstr "Lister équipotentielles (noms et numéros d'identification)" + +#: pcbnew/menubarpcb.cpp:307 +msgid "&Track Operations" +msgstr "Opéra&tions sur Pistes" + +#: pcbnew/menubarpcb.cpp:308 +msgid "Clean stubs, vias, delete break points, or connect dangling tracks to pads and vias" +msgstr "Nettoyer bouts de pistes, vias, points inutiles, ou connecter extrémités de pistes mal connectées au centre de pads ou vias" + +#: pcbnew/menubarpcb.cpp:313 +msgid "&Swap Layers" +msgstr "&Permutte Couches" + +#: pcbnew/menubarpcb.cpp:314 +msgid "Swap tracks on copper layers or drawings on others layers" +msgstr "Permutation de couches" + +#: pcbnew/menubarpcb.cpp:323 +msgid "Open the PCBNEW manual" +msgstr "Ouvrir la Documentation de PCBNEW" + +#: pcbnew/menubarpcb.cpp:327 +msgid "&About PCBNEW" +msgstr "&Au Sujet de PCBNEW" + +#: pcbnew/menubarpcb.cpp:328 +msgid "About PCBNEW printed circuit board designer" +msgstr "Au Sujet de PCBNEW outil de conception de C.I." + +#: pcbnew/menubarpcb.cpp:341 +msgid "&File" +msgstr "&Fichiers" + +#: pcbnew/menubarpcb.cpp:342 +msgid "&Preferences" +msgstr "&Préférences" + +#: pcbnew/menubarpcb.cpp:343 +msgid "&Design Rules" +msgstr "&Règles de Conception" + +#: pcbnew/menubarpcb.cpp:345 +msgid "&Miscellaneous" +msgstr "&Divers" + +#: pcbnew/menubarpcb.cpp:346 +msgid "P&ostprocess" +msgstr "P&ostprocesseurs" + #: pcbnew/dialog_SVG_print_base.cpp:25 msgid "Copper Layers:" msgstr "Couches Cuivre:" @@ -3875,23 +3904,6 @@ msgstr "Le fichier Session a une 'reference' à un composant non existant \"%s\" msgid "A wire_via references a missing padstack \"%s\"" msgstr "Une piste ou via a une référence vers un pad \"%s\" manquant" -#: pcbnew/pcbcfg.cpp:82 -msgid "Read Project File" -msgstr "Lire Fichier Projet" - -#: pcbnew/pcbcfg.cpp:92 -#, c-format -msgid "File %s not found" -msgstr "Fichier %s non trouvé" - -#: pcbnew/pcbcfg.cpp:227 -msgid "Save Project File" -msgstr "Sauver Fichier Projet" - -#: pcbnew/ioascii.cpp:175 -msgid "Error: Unexpected end of file !" -msgstr "Erreur: Fin de fichier inattendue !" - #: pcbnew/class_module.cpp:821 msgid "Last Change" msgstr "Last Change" @@ -3936,30 +3948,6 @@ msgstr "Fichier placement côté cuivre:" msgid "Module count" msgstr "Nb Modules" -#: pcbnew/class_board.cpp:45 -msgid "This is the default net class." -msgstr "Ceci est la Netclass par défaut" - -#: pcbnew/class_board.cpp:596 -msgid "Nodes" -msgstr "Nodes" - -#: pcbnew/class_board.cpp:599 -msgid "Nets" -msgstr "Nets" - -#: pcbnew/class_board.cpp:607 -msgid "Links" -msgstr "Liens" - -#: pcbnew/class_board.cpp:610 -msgid "Connect" -msgstr "Connect" - -#: pcbnew/class_board.cpp:613 -msgid "NoConn" -msgstr "Non Conn" - #: pcbnew/dialog_edit_module_text_base.cpp:19 #, c-format msgid "Module %s (%s) orient %.1f" @@ -4049,234 +4037,35 @@ msgstr "Surbrillance des équipotentielles" msgid "Local Ratsnest" msgstr "Montrer le chevelu général" -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:22 -msgid "No Display" -msgstr "Pas d'affichage" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:24 -msgid "Display Polar Coord" -msgstr "Affichage coord Polaires" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:26 -msgid "" -"Activates the display of relative coordinates from relative origin (set by the space key)\n" -"to the cursor, in polar coordinates (angle and distance)" -msgstr "" -"Active l'affichage des coordonnées relatives à l'origine relative(positionnée par la touche espace)\n" -"au curseur, en coordonnées polaires (angle et distance)" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:32 -msgid "Units" -msgstr "Unités" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:34 -msgid "Selection of units used to display dimensions and positions of items" -msgstr "Sélection des unités pour afficher les dimensions et positions des items" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:38 -msgid "Small cross" -msgstr "Petite croix" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:38 -msgid "Full screen cursor" -msgstr "Curseur plein écran" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:40 -msgid "Cursor" -msgstr "Curseur" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:42 -msgid "Main cursor shape selection (small cross or large cursor)" -msgstr "Sélection de l'aspect du curseur principal (petite croix ou grand curseur)" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "1" -msgstr "1" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "2" -msgstr "2" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "4" -msgstr "4" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "6" -msgstr "6" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "8" -msgstr "8" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "10" -msgstr "10" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "12" -msgstr "12" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "14" -msgstr "14" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:51 -msgid "16" -msgstr "16" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:55 -msgid "Active copper layers count selection" -msgstr "Sélection su nombre de couches cuivre actives" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:59 -msgid "Max Links:" -msgstr "Liens max:" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:64 -msgid "Adjust the number of ratsnets shown from cursor to closest pads" -msgstr "Ajuster le nombre de ratsnets montré du curseur aux pads les plus prêts" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:68 -msgid "Auto Save (minuts):" -msgstr "Sauveg. Auto (min)" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:73 -msgid "Delay after the first change to create a backup file of the board on disk." -msgstr "Délai après le premier changement pour créer un fichier de sauvegarde du circuit imprimé sur disque" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:82 -msgid "Drc ON" -msgstr "Drc ACTIVE" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:85 -msgid "" -"Enable/disable the DRC control.\n" -"When DRC is disable, all connections are allowed." -msgstr "" -"Active/désactive le contrôle DRC (Design Rule Check).\n" -"Lorsque de DRC est désactivé, toutes les connexions sont autorisées." - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:89 -msgid "Show Ratsnest" -msgstr "Montrer le chevelu général" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:91 -msgid "Show (or not) the full rastnest." -msgstr "Montrer(ou non) le chevelu complet" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:95 -msgid "Show Mod Ratsnest" -msgstr "Montrer le chevelu du module" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:97 -msgid "" -"Shows (or not) the local ratsnest relative to a footprint, when moving it.\n" -"This ratsnest is useful to place a footprint." -msgstr "" -"Montre (ou non) le chevelu local relatif à un module, lorsque on le déplace.\n" -"Ce chevelu est utile pour placer un module." - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:101 -msgid "Tracks Auto Del" -msgstr "Auto Supp. Pistes" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:103 -msgid "Enable/disable the automatic track deletion when recreating a track." -msgstr "Active/désactive l'effacement de piste automatique lorsque l'on recrée une piste." - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:107 -msgid "Track only 45 degrees" -msgstr "Piste à 45° seulement" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:109 -msgid "If enabled, force tracks directions to H, V or 45 degrees, when creating a track." -msgstr "Si activé, frorce la direction des pistes à H, V ou 45° en creation de piste" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:113 -msgid "Segments 45 Only" -msgstr "Segments 45 seulement" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:115 -msgid "If enabled, force segments directions to H, V or 45 degrees, when creating a segment on technical layers." -msgstr "Si activé, frorce la direction des segments à H, V ou 45° en création de segments sur couches techniques" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:119 -msgid "Auto PAN" -msgstr "Auto PAN" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:121 -msgid "Allows auto pan when creating a track, or moving an item." -msgstr "Autorise l'autopan en création de piste, ou lorsque on déplace un élément." - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:125 -msgid "Double Segm Track" -msgstr "2 segments pour piste" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:127 -msgid "If enabled, uses two track segments, with 45 degrees angle between them when creating a new track " -msgstr "Si activé, utiliser 2 segments de piste, avec un angle de 45 degrés entre eux, pour créer une nouvelle piste" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:136 -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:144 -msgid "Never" -msgstr "Jamais" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:136 -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:144 -msgid "When creating tracks" -msgstr "En création de pistes" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:136 -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:144 -msgid "Always" -msgstr "Toujours" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:138 -msgid "Magnetic Pads" -msgstr " Pads magnétiques" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:140 -msgid "control the capture of the pcb cursor when the mouse cursor enters a pad area" -msgstr "Contrôle la capture du curseur pcb quand le curseur souris est sur un pad" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:146 -msgid "Magnetic Tracks" -msgstr "Pistes Magnétiques" - -#: pcbnew/dialog_general_options_BoardEditor_base.cpp:148 -msgid "Control the capture of the pcb cursor when the mouse cursor enters a track" -msgstr "Contrôle la capture du curseur pcb quand le curseur souris passe sur une piste" - -#: pcbnew/class_track.cpp:918 +#: pcbnew/class_track.cpp:911 msgid "Track Length" msgstr "Long. Piste" -#: pcbnew/class_track.cpp:976 +#: pcbnew/class_track.cpp:969 msgid "Flags" msgstr "Flags" -#: pcbnew/class_track.cpp:988 +#: pcbnew/class_track.cpp:981 msgid "Status" msgstr "Status" -#: pcbnew/class_track.cpp:1011 +#: pcbnew/class_track.cpp:1004 msgid "Diam" msgstr "Diam" -#: pcbnew/class_track.cpp:1022 +#: pcbnew/class_track.cpp:1015 msgid "(Specific)" msgstr "(Specifique)" -#: pcbnew/class_track.cpp:1024 +#: pcbnew/class_track.cpp:1017 msgid "(Default)" msgstr "(Défaut)" -#: pcbnew/class_track.cpp:1037 +#: pcbnew/class_track.cpp:1030 msgid "Net Class" msgstr "Classe d'Equipot" -#: pcbnew/class_track.cpp:1044 +#: pcbnew/class_track.cpp:1037 msgid "Segment Length" msgstr "Long. Segment" @@ -5474,80 +5263,164 @@ msgstr "Ajout de stub (arc)" msgid "Add Polynomial Shape" msgstr "Ajout Forme polynomiale" -#: pcbnew/dialog_design_rules_base.cpp:20 +#: pcbnew/dialog_design_rules_base.cpp:25 msgid "Net Classes:" msgstr "Classes d'Equipots:" -#: pcbnew/dialog_design_rules_base.cpp:41 +#: pcbnew/dialog_design_rules_base.cpp:46 msgid "Track Width" msgstr "Epais. Piste" -#: pcbnew/dialog_design_rules_base.cpp:42 +#: pcbnew/dialog_design_rules_base.cpp:47 msgid "Via Dia" msgstr "Diamètre Via" -#: pcbnew/dialog_design_rules_base.cpp:43 +#: pcbnew/dialog_design_rules_base.cpp:48 msgid "Via Drill" msgstr "Perçage Via" -#: pcbnew/dialog_design_rules_base.cpp:44 +#: pcbnew/dialog_design_rules_base.cpp:49 msgid "uVia Dia" msgstr "Diamètre µVia" -#: pcbnew/dialog_design_rules_base.cpp:45 +#: pcbnew/dialog_design_rules_base.cpp:50 msgid "uVia Drill" msgstr " Perçage µVia" -#: pcbnew/dialog_design_rules_base.cpp:52 +#: pcbnew/dialog_design_rules_base.cpp:57 msgid "Default" msgstr "Défaut" -#: pcbnew/dialog_design_rules_base.cpp:59 +#: pcbnew/dialog_design_rules_base.cpp:64 msgid "Net Class parameters" msgstr "Paramètres de NeClass" -#: pcbnew/dialog_design_rules_base.cpp:68 +#: pcbnew/dialog_design_rules_base.cpp:73 msgid "Add another Net Class" msgstr "Ajouter une autre NetClass" -#: pcbnew/dialog_design_rules_base.cpp:73 -msgid "Remove the currently select Net Class" -msgstr "Supprimer la NetClass actuellement sélectionnée" +#: pcbnew/dialog_design_rules_base.cpp:78 +msgid "" +"Remove the currently select Net Class\n" +"The default Net Class cannot be removed" +msgstr "" +"Supprimer la NetClasse sélectionnée\n" +"La Netclasse Défaut ne peut être supprimée" -#: pcbnew/dialog_design_rules_base.cpp:77 +#: pcbnew/dialog_design_rules_base.cpp:82 msgid "Move Up" msgstr "Vers le haut ^" -#: pcbnew/dialog_design_rules_base.cpp:78 +#: pcbnew/dialog_design_rules_base.cpp:83 msgid "Move the currently selected Net Class up one row" msgstr "Déplacer la NetClassl sélectionné de une ligne vers le haut" -#: pcbnew/dialog_design_rules_base.cpp:87 +#: pcbnew/dialog_design_rules_base.cpp:92 msgid "Membership:" msgstr "Membres:" -#: pcbnew/dialog_design_rules_base.cpp:107 +#: pcbnew/dialog_design_rules_base.cpp:112 msgid "<<<" msgstr "<<<" -#: pcbnew/dialog_design_rules_base.cpp:110 +#: pcbnew/dialog_design_rules_base.cpp:113 +msgid "Move the selected nets in the right list to the left list" +msgstr "" + +#: pcbnew/dialog_design_rules_base.cpp:117 msgid ">>>" msgstr ">>>" -#: pcbnew/dialog_design_rules_base.cpp:113 +#: pcbnew/dialog_design_rules_base.cpp:118 +msgid "Move the selected nets in the left list to the right list" +msgstr "Déplacer les nets sélectionnés dans la liste de gauche vers la liste de droite" + +#: pcbnew/dialog_design_rules_base.cpp:122 msgid "<< Select All" msgstr "<< Selectionner Tout" -#: pcbnew/dialog_design_rules_base.cpp:116 +#: pcbnew/dialog_design_rules_base.cpp:123 +msgid "Select all nets in the left list" +msgstr "Sélectionner tous les nets de la liste de gauche" + +#: pcbnew/dialog_design_rules_base.cpp:127 msgid "Select All >>" msgstr "Selectionner Tout >>" +#: pcbnew/dialog_design_rules_base.cpp:128 +msgid "Select all nets in the right list" +msgstr "Sélectionner tous les nets de la liste de droite" + +#: pcbnew/dialog_design_rules_base.cpp:154 +msgid "Net Classes Editor" +msgstr "Editeur de NetClasses" + +#: pcbnew/dialog_design_rules_base.cpp:163 +msgid "Vias Options:" +msgstr "Options Vias:" + +#: pcbnew/dialog_design_rules_base.cpp:165 +msgid "Through via" +msgstr "Via traversante" + +#: pcbnew/dialog_design_rules_base.cpp:165 +msgid "Blind or buried via" +msgstr "Via enterrée ou aveugle" + +#: pcbnew/dialog_design_rules_base.cpp:167 +msgid "Default Via Type" +msgstr "Via par Défaut" + +#: pcbnew/dialog_design_rules_base.cpp:169 +msgid "" +"Select the current via type.\n" +"Trough via is the usual selection" +msgstr "" +"Sélection du type de via courant.\n" +"Via traversante est la sélection usuelle." + +#: pcbnew/dialog_design_rules_base.cpp:179 +msgid "Via Min Diameter" +msgstr "Via Taille Min" + +#: pcbnew/dialog_design_rules_base.cpp:191 +msgid "Micro Vias Options:" +msgstr "Options Micro Vias:" + +#: pcbnew/dialog_design_rules_base.cpp:193 +msgid "Do not allow micro vias" +msgstr "Ne pas autoriser les micro vias" + +#: pcbnew/dialog_design_rules_base.cpp:193 +msgid "Allow micro vias" +msgstr "Autoriser les micro vias" + +#: pcbnew/dialog_design_rules_base.cpp:197 +msgid "" +"Allows or do not allow use of micro vias\n" +"They are very small vias only from an external copper layer to its near neightbour" +msgstr "" +"Autorise ou non l'utilisation de micro vias\n" +"Ce sont de petites vias allant d'une couche externe à la plus proche couche interne uniquement" + +#: pcbnew/dialog_design_rules_base.cpp:207 +msgid "MicroVia Min Diameter" +msgstr "Diam. Mini MicroVia" + +#: pcbnew/dialog_design_rules_base.cpp:219 +msgid "Minimal Values Allowed:" +msgstr "Valeurs Minimales Autorisées:" + +#: pcbnew/dialog_design_rules_base.cpp:248 +msgid "Global Design Rules" +msgstr "Règles Générales" + #: pcbnew/zones_by_polygon_fill_functions.cpp:130 msgid "No Net" msgstr "No Net" #: pcbnew/dialog_copper_layers_setup.cpp:135 -#: pcbnew/dialog_design_rules.cpp:422 +#: pcbnew/dialog_design_rules.cpp:470 msgid "Errors detected, Abort" msgstr "Erreurs detectées, Abandont" @@ -5600,6 +5473,42 @@ msgstr "Hauteur Texte Module" msgid "Text Module Size H" msgstr "Largeur Texte Module" +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "1" +msgstr "1" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "2" +msgstr "2" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "4" +msgstr "4" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "6" +msgstr "6" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "8" +msgstr "8" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "10" +msgstr "10" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "12" +msgstr "12" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "14" +msgstr "14" + +#: pcbnew/dialog_copper_layers_setup_base.cpp:22 +msgid "16" +msgstr "16" + #: pcbnew/dialog_copper_layers_setup_base.cpp:24 msgid "Layers Count" msgstr "Nombre de Couches" @@ -5672,62 +5581,62 @@ msgstr "Interne 1" msgid "* (Any)" msgstr "* (Tout)" -#: pcbnew/dialog_design_rules.cpp:76 +#: pcbnew/dialog_design_rules.cpp:77 msgid "Class" msgstr "Classe" -#: pcbnew/dialog_design_rules.cpp:104 +#: pcbnew/dialog_design_rules.cpp:105 msgid "Current general settings:
" msgstr "Reglages généraux courants:
" -#: pcbnew/dialog_design_rules.cpp:108 +#: pcbnew/dialog_design_rules.cpp:109 #, c-format msgid "Minimum value for tracks width: %s
\n" msgstr "Valeur minimum pour la largeur de piste: %s
\n" -#: pcbnew/dialog_design_rules.cpp:112 +#: pcbnew/dialog_design_rules.cpp:113 #, c-format msgid "Minimum value for vias diameter: %s
\n" msgstr "Valeur minimum pour le diamètre de via: %s
\n" -#: pcbnew/dialog_design_rules.cpp:116 +#: pcbnew/dialog_design_rules.cpp:117 #, c-format msgid "Minimum value for microvias diameter: %s
\n" msgstr "Valeur minimum pour le diamètre de microvia: %s
\n" -#: pcbnew/dialog_design_rules.cpp:438 +#: pcbnew/dialog_design_rules.cpp:489 msgid "New Net Class Name:" msgstr "Nouveau Nom de Classe d'Equipotentielle:" -#: pcbnew/dialog_design_rules.cpp:451 +#: pcbnew/dialog_design_rules.cpp:502 msgid "This NetClass is already existing, cannot add it; Aborted" msgstr "Cette NetClass existe déjà, et ne peut être ajoutée; Abandon" -#: pcbnew/dialog_design_rules.cpp:508 +#: pcbnew/dialog_design_rules.cpp:559 msgid "The defaut Netclass cannot be removed" msgstr "" -#: pcbnew/dialog_design_rules.cpp:694 +#: pcbnew/dialog_design_rules.cpp:745 #, c-format msgid "%s: Track Size < Min Track Size
" msgstr "%s: Largeur PisteLargeur Piste Minimum
" -#: pcbnew/dialog_design_rules.cpp:708 +#: pcbnew/dialog_design_rules.cpp:759 #, c-format msgid "%s: Via Diameter < Minimun Via Diameter
" msgstr "%s: Diamètre ViaMin. Diamètre Via
" -#: pcbnew/dialog_design_rules.cpp:720 +#: pcbnew/dialog_design_rules.cpp:771 #, c-format msgid "%s: Via DrillVia Dia
" msgstr "%s: Perçage ViaDiam Via
" -#: pcbnew/dialog_design_rules.cpp:734 +#: pcbnew/dialog_design_rules.cpp:785 #, c-format msgid "%s: MicroVia Diameter < Minimun MicroVia Diameter
" msgstr "%s: Diamètre MicroViaDiamètre MicroVia Minimum
" -#: pcbnew/dialog_design_rules.cpp:746 +#: pcbnew/dialog_design_rules.cpp:797 #, c-format msgid "%s: MicroVia DrillMicroVia Dia
" msgstr "%s: Perçage MicroViaDiam MicroVia
" @@ -5744,6 +5653,13 @@ msgstr "Pistes:" msgid "Select how tracks are displayed" msgstr "Sélectionner comment les pistes sont affichées" +#: pcbnew/dialog_display_options_base.cpp:30 +#: pcbnew/dialog_display_options_base.cpp:38 +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:137 +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:145 +msgid "Never" +msgstr "Jamais" + #: pcbnew/dialog_display_options_base.cpp:30 msgid "New track" msgstr "Nouvelle piste" @@ -5752,6 +5668,13 @@ msgstr "Nouvelle piste" msgid "New track with via area" msgstr "Nouvelle piste avec via" +#: pcbnew/dialog_display_options_base.cpp:30 +#: pcbnew/dialog_display_options_base.cpp:38 +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:137 +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:145 +msgid "Always" +msgstr "Toujours" + #: pcbnew/dialog_display_options_base.cpp:32 msgid "Show Tracks Clearance:" msgstr "Montrer Isolation Piste:" @@ -5888,6 +5811,30 @@ msgstr "Designation" msgid "Supplier and ref" msgstr "Fournisseur et ref" +#: pcbnew/class_board.cpp:45 +msgid "This is the default net class." +msgstr "Ceci est la Netclass par défaut" + +#: pcbnew/class_board.cpp:654 +msgid "Nodes" +msgstr "Nodes" + +#: pcbnew/class_board.cpp:657 +msgid "Nets" +msgstr "Nets" + +#: pcbnew/class_board.cpp:665 +msgid "Links" +msgstr "Liens" + +#: pcbnew/class_board.cpp:668 +msgid "Connect" +msgstr "Connect" + +#: pcbnew/class_board.cpp:671 +msgid "NoConn" +msgstr "Non Conn" + #: pcbnew/class_edge_mod.cpp:236 msgid "Graphic Item" msgstr "Element Graphique" @@ -6071,48 +6018,193 @@ msgstr "Cacher textes invisibles" msgid "Show invisible text" msgstr "Montrer textes invisibles" +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:22 +msgid "No Display" +msgstr "Pas d'affichage" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:24 +msgid "Display Polar Coord" +msgstr "Affichage coord Polaires" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:26 +msgid "" +"Activates the display of relative coordinates from relative origin (set by the space key)\n" +"to the cursor, in polar coordinates (angle and distance)" +msgstr "" +"Active l'affichage des coordonnées relatives à l'origine relative(positionnée par la touche espace)\n" +"au curseur, en coordonnées polaires (angle et distance)" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:32 +msgid "Units" +msgstr "Unités" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:34 +msgid "Selection of units used to display dimensions and positions of items" +msgstr "Sélection des unités pour afficher les dimensions et positions des items" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:38 +msgid "Small cross" +msgstr "Petite croix" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:38 +msgid "Full screen cursor" +msgstr "Curseur plein écran" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:40 +msgid "Cursor" +msgstr "Curseur" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:42 +msgid "Main cursor shape selection (small cross or large cursor)" +msgstr "Sélection de l'aspect du curseur principal (petite croix ou grand curseur)" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:60 +msgid "Max Links:" +msgstr "Liens max:" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:65 +msgid "Adjust the number of ratsnets shown from cursor to closest pads" +msgstr "Ajuster le nombre de ratsnets montré du curseur aux pads les plus prêts" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:69 +msgid "Auto Save (minuts):" +msgstr "Sauveg. Auto (min)" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:74 +msgid "Delay after the first change to create a backup file of the board on disk." +msgstr "Délai après le premier changement pour créer un fichier de sauvegarde du circuit imprimé sur disque" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:83 +msgid "Drc ON" +msgstr "Drc ACTIVE" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:86 +msgid "" +"Enable/disable the DRC control.\n" +"When DRC is disable, all connections are allowed." +msgstr "" +"Active/désactive le contrôle DRC (Design Rule Check).\n" +"Lorsque de DRC est désactivé, toutes les connexions sont autorisées." + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:90 +msgid "Show Ratsnest" +msgstr "Montrer le chevelu général" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:92 +msgid "Show (or not) the full rastnest." +msgstr "Montrer(ou non) le chevelu complet" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:96 +msgid "Show Mod Ratsnest" +msgstr "Montrer le chevelu du module" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:98 +msgid "" +"Shows (or not) the local ratsnest relative to a footprint, when moving it.\n" +"This ratsnest is useful to place a footprint." +msgstr "" +"Montre (ou non) le chevelu local relatif à un module, lorsque on le déplace.\n" +"Ce chevelu est utile pour placer un module." + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:102 +msgid "Tracks Auto Del" +msgstr "Auto Supp. Pistes" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:104 +msgid "Enable/disable the automatic track deletion when recreating a track." +msgstr "Active/désactive l'effacement de piste automatique lorsque l'on recrée une piste." + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:108 +msgid "Track only 45 degrees" +msgstr "Piste à 45° seulement" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:110 +msgid "If enabled, force tracks directions to H, V or 45 degrees, when creating a track." +msgstr "Si activé, frorce la direction des pistes à H, V ou 45° en creation de piste" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:114 +msgid "Segments 45 Only" +msgstr "Segments 45 seulement" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:116 +msgid "If enabled, force segments directions to H, V or 45 degrees, when creating a segment on technical layers." +msgstr "Si activé, frorce la direction des segments à H, V ou 45° en création de segments sur couches techniques" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:120 +msgid "Auto PAN" +msgstr "Auto PAN" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:122 +msgid "Allows auto pan when creating a track, or moving an item." +msgstr "Autorise l'autopan en création de piste, ou lorsque on déplace un élément." + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:126 +msgid "Double Segm Track" +msgstr "2 segments pour piste" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:128 +msgid "If enabled, uses two track segments, with 45 degrees angle between them when creating a new track " +msgstr "Si activé, utiliser 2 segments de piste, avec un angle de 45 degrés entre eux, pour créer une nouvelle piste" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:137 +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:145 +msgid "When creating tracks" +msgstr "En création de pistes" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:139 +msgid "Magnetic Pads" +msgstr " Pads magnétiques" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:141 +msgid "control the capture of the pcb cursor when the mouse cursor enters a pad area" +msgstr "Contrôle la capture du curseur pcb quand le curseur souris est sur un pad" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:147 +msgid "Magnetic Tracks" +msgstr "Pistes Magnétiques" + +#: pcbnew/dialog_general_options_BoardEditor_base.cpp:149 +msgid "Control the capture of the pcb cursor when the mouse cursor enters a track" +msgstr "Contrôle la capture du curseur pcb quand le curseur souris passe sur une piste" + +#: pcbnew/copies_de_sauvegarde/dialog_design_rules_base.cpp:73 +msgid "Remove the currently select Net Class" +msgstr "Supprimer la NetClass actuellement sélectionnée" + #: eeschema/libarch.cpp:55 #, c-format msgid "An error occurrred attempting to save component library <%s>." msgstr "Une erreur s'est produite lors de la sauvegarde de la librairie de composants <%s>." #: eeschema/plotdxf.cpp:155 -#: eeschema/plotps.cpp:174 msgid "Plot Options:" msgstr "Options de Tracé:" #: eeschema/plotdxf.cpp:160 -#: eeschema/plotps.cpp:179 msgid "B/W" msgstr "N/B" #: eeschema/plotdxf.cpp:162 -#: eeschema/plotps.cpp:181 msgid "Plot Color:" msgstr "Tracé et Couleurs:" #: eeschema/plotdxf.cpp:166 -#: eeschema/plotps.cpp:185 msgid "Print Sheet Ref" msgstr "Imprimer cartouche" #: eeschema/plotdxf.cpp:175 -#: eeschema/plotps.cpp:194 msgid "&Plot Page" msgstr "&Tracer Page" #: eeschema/plotdxf.cpp:179 -#: eeschema/plotps.cpp:198 msgid "Plot A&LL" msgstr "&Tout Tracer" #: eeschema/plotdxf.cpp:185 -#: eeschema/plotps.cpp:207 msgid "Messages :" msgstr "Messages :" #: eeschema/plotdxf.cpp:371 -#: eeschema/plotps.cpp:419 #, c-format msgid "Plot: %s\n" msgstr "Trace: %s\n" @@ -6336,7 +6428,7 @@ msgstr "" #: eeschema/libedit.cpp:511 msgid "This new component has no name and cannot be created. Aborted" -msgstr "" +msgstr "Ce noveau composant n'a pas de nom et ne peut être créé, Abandon" #: eeschema/libedit.cpp:522 #, c-format @@ -6911,69 +7003,9 @@ msgid "key search criteria <" msgstr "critère de recherche par clé <" #: eeschema/database.cpp:68 -#: eeschema/selpart.cpp:75 msgid "Select Component" msgstr "Sélection Composant" -#: eeschema/symbdraw.cpp:677 -#, c-format -msgid "Arc %.1f deg" -msgstr "Arc %.1f deg" - -#: eeschema/libframe.cpp:244 -msgid "" -"Component was modified!\n" -"Discard changes?" -msgstr "" -"Le composant a été modifié\n" -"Perdre les changements" - -#: eeschema/libframe.cpp:258 -#, c-format -msgid "" -"Library \"%s\" was modified!\n" -"Discard changes?" -msgstr "" -"Librairie \"%s\" modifiée!\n" -"Perdre les changements ?" - -#: eeschema/libframe.cpp:368 -#, c-format -msgid "Part %c" -msgstr "Composant %c" - -#: eeschema/libframe.cpp:630 -msgid "Add pin" -msgstr "Addition de \"pins\"" - -#: eeschema/libframe.cpp:634 -msgid "Set pin options" -msgstr "Choix options de pin" - -#: eeschema/libframe.cpp:656 -msgid "Add rectangle" -msgstr "Ajout de rectangle" - -#: eeschema/libframe.cpp:660 -msgid "Add circle" -msgstr "Ajout de cercle" - -#: eeschema/libframe.cpp:664 -msgid "Add arc" -msgstr "Ajout d'arc" - -#: eeschema/libframe.cpp:668 -msgid "Add line" -msgstr "Addition de lignes" - -#: eeschema/libframe.cpp:672 -msgid "Set anchor position" -msgstr "Ajuster Position Ancre" - -#: eeschema/libframe.cpp:682 -msgid "Export" -msgstr "Exporter" - #: eeschema/erc.cpp:199 msgid "Duplicate Sheet name" msgstr "Nom de feuille en double" @@ -7054,63 +7086,71 @@ msgstr "" "\n" " >> Erreurs ERC: %d\n" -#: eeschema/pinedit.cpp:25 +#: eeschema/pinedit.cpp:26 msgid "line" msgstr "Ligne" -#: eeschema/pinedit.cpp:25 +#: eeschema/pinedit.cpp:26 msgid "invert" msgstr "invert" -#: eeschema/pinedit.cpp:25 +#: eeschema/pinedit.cpp:26 msgid "clock" msgstr "clock" -#: eeschema/pinedit.cpp:25 +#: eeschema/pinedit.cpp:26 msgid "clock inv" msgstr "clock inv" -#: eeschema/pinedit.cpp:26 +#: eeschema/pinedit.cpp:27 msgid "low in" msgstr "low in" -#: eeschema/pinedit.cpp:26 +#: eeschema/pinedit.cpp:27 msgid "low clock" msgstr "low clock" -#: eeschema/pinedit.cpp:26 +#: eeschema/pinedit.cpp:27 msgid "low out" msgstr "low out" -#: eeschema/pinedit.cpp:209 +#: eeschema/pinedit.cpp:211 msgid "This position is already occupied by another pin. Continue?" msgstr "Position occupée par une autre pin. Continuer ?" -#: eeschema/pinedit.cpp:344 -#: eeschema/pinedit.cpp:599 +#: eeschema/pinedit.cpp:346 +#: eeschema/pinedit.cpp:601 #, c-format msgid "Initial pin position (%d, %d)" msgstr "Position initiane de la pin (%d, %d)" -#: eeschema/pinedit.cpp:967 -#, c-format -msgid "Duplicate pin %s at location (%d, %d) conflicts with pin %s at location (%d, %d)" -msgstr "Pin dupliquée %s en position (%d, %d) en conflit avec pin %s en position (%d, %d)" +#: eeschema/pinedit.cpp:956 +msgid "No pins!" +msgstr "Pas de Pins!" -#: eeschema/pinedit.cpp:977 +#: eeschema/pinedit.cpp:967 +msgid "Marker Info" +msgstr "Info Marqueur" + +#: eeschema/pinedit.cpp:986 +#, c-format +msgid "Duplicate pin %s \"%s\" at location (%.3f, %.3f) conflicts with pin %s \"%s\" at location (%.3f, %.3f)" +msgstr "Pin dupliquée %s \"%s\" en position (%.3f, %.3f) en conflit avec pin %s \"%s\" en position (%.3f, %.3f)" + +#: eeschema/pinedit.cpp:997 #, c-format msgid " in part %c" msgstr " en composant %c" -#: eeschema/pinedit.cpp:984 +#: eeschema/pinedit.cpp:1004 msgid " of converted" msgstr " de converti" -#: eeschema/pinedit.cpp:986 +#: eeschema/pinedit.cpp:1006 msgid " of normal" msgstr " de normal" -#: eeschema/pinedit.cpp:997 +#: eeschema/pinedit.cpp:1015 msgid "No duplicate pins were found." msgstr "Pas de pins doublées trouvéées" @@ -7126,6 +7166,23 @@ msgstr "Noir" msgid "Background Color:" msgstr "Couleur du Fond:" +#: eeschema/eeschema.cpp:106 +msgid "Eeschema is already running, Continue?" +msgstr "Eeschema est en cours d'exécution. Continuer ?" + +#: eeschema/class_libentry_fields.cpp:82 +#: eeschema/class_libentry_fields.cpp:568 +msgid "Field" +msgstr "Champ" + +#: eeschema/class_libentry_fields.cpp:142 +msgid "invalid field number defined" +msgstr "numéro de champ défini invalide" + +#: eeschema/class_libentry_fields.cpp:560 +msgid "Datasheet" +msgstr "Documentation" + #: eeschema/files-io.cpp:71 msgid "Clear Schematic Hierarchy (modified!)?" msgstr "Effacer la hiérarchie schématique (modifiée!)?" @@ -7158,9 +7215,64 @@ msgstr "" msgid "File <%s> not found." msgstr "Fichier <%s> non trouvé" -#: eeschema/eeschema.cpp:117 -msgid "Eeschema is already running, Continue?" -msgstr "Eeschema est en cours d'exécution. Continuer ?" +#: eeschema/libframe.cpp:250 +msgid "" +"Component was modified!\n" +"Discard changes?" +msgstr "" +"Le composant a été modifié\n" +"Perdre les changements" + +#: eeschema/libframe.cpp:264 +#, c-format +msgid "" +"Library \"%s\" was modified!\n" +"Discard changes?" +msgstr "" +"Librairie \"%s\" modifiée!\n" +"Perdre les changements ?" + +#: eeschema/libframe.cpp:374 +#, c-format +msgid "Part %c" +msgstr "Composant %c" + +#: eeschema/libframe.cpp:636 +msgid "Add pin" +msgstr "Addition de \"pins\"" + +#: eeschema/libframe.cpp:640 +msgid "Set pin options" +msgstr "Choix options de pin" + +#: eeschema/libframe.cpp:662 +msgid "Add rectangle" +msgstr "Ajout de rectangle" + +#: eeschema/libframe.cpp:666 +msgid "Add circle" +msgstr "Ajout de cercle" + +#: eeschema/libframe.cpp:670 +msgid "Add arc" +msgstr "Ajout d'arc" + +#: eeschema/libframe.cpp:674 +msgid "Add line" +msgstr "Addition de lignes" + +#: eeschema/libframe.cpp:678 +msgid "Set anchor position" +msgstr "Ajuster Position Ancre" + +#: eeschema/libframe.cpp:688 +msgid "Export" +msgstr "Exporter" + +#: eeschema/symbdraw.cpp:646 +#, c-format +msgid "Arc %.1f deg" +msgstr "Arc %.1f deg" #: eeschema/viewlibs.cpp:108 msgid "Library Browser" @@ -7171,11 +7283,11 @@ msgstr "Visualisateur de Librairies" msgid "component selection (%d items loaded):" msgstr "Sélection Composant (%d items chargés):" -#: eeschema/getpart.cpp:185 +#: eeschema/getpart.cpp:189 msgid "Failed to find part " msgstr "Impossible de trouver le composant " -#: eeschema/getpart.cpp:185 +#: eeschema/getpart.cpp:189 msgid " in library" msgstr " en librairie" @@ -7215,10 +7327,6 @@ msgstr "Gauche" msgid "Right" msgstr "Droite" -#: eeschema/class_pin.cpp:1229 -msgid "Unknown" -msgstr "Inconnu" - #: eeschema/delsheet.cpp:44 #, c-format msgid "Sheet %s (file %s) modified. Save it?" @@ -7440,7 +7548,6 @@ msgid "Save Project Settings" msgstr "Sauver Optionsr Projet" #: eeschema/netlist.cpp:92 -#: eeschema/dialog_build_BOM_base.cpp:47 msgid "List" msgstr "Liste" @@ -7850,111 +7957,6 @@ msgstr "Emetteur ouv." msgid "Electrical Type:" msgstr "Type électrique:" -#: eeschema/classes_body_items.cpp:35 -msgid "Undefined" -msgstr "Non Défini" - -#: eeschema/classes_body_items.cpp:66 -#: eeschema/classes_body_items.cpp:72 -msgid "All" -msgstr "Tout" - -#: eeschema/classes_body_items.cpp:74 -msgid "no" -msgstr "non" - -#: eeschema/classes_body_items.cpp:76 -msgid "yes" -msgstr "oui" - -#: eeschema/classes_body_items.cpp:179 -#, c-format -msgid "arc only had %d parameters of the required 8" -msgstr "l'arc a seulement %d paramètres sur les 8 requis" - -#: eeschema/classes_body_items.cpp:527 -#: eeschema/classes_body_items.cpp:787 -#: eeschema/classes_body_items.cpp:1011 -#: eeschema/classes_body_items.cpp:1262 -#: eeschema/classes_body_items.cpp:1672 -#: eeschema/classes_body_items.cpp:2040 -msgid "Line width" -msgstr "Epaisseur ligne" - -#: eeschema/classes_body_items.cpp:532 -#: eeschema/classes_body_items.cpp:796 -#: eeschema/classes_body_items.cpp:1267 -#: eeschema/classes_body_items.cpp:1677 -#: eeschema/classes_body_items.cpp:2045 -msgid "Bounding box" -msgstr "Rectange dencadrement" - -#: eeschema/classes_body_items.cpp:577 -#, c-format -msgid "circle only had %d parameters of the required 6" -msgstr "le cercle a seulement %d paramètres sur les 6 requis" - -#: eeschema/classes_body_items.cpp:791 -msgid "Radius" -msgstr "Rayon" - -#: eeschema/classes_body_items.cpp:809 -msgid "Rectangle" -msgstr "Rectangle" - -#: eeschema/classes_body_items.cpp:844 -#, c-format -msgid "rectangle only had %d parameters of the required 7" -msgstr "le rectangle a seulement %d paramètres sur les 7 requis" - -#: eeschema/classes_body_items.cpp:1314 -msgid "PolyLine" -msgstr "PolyLigne" - -#: eeschema/classes_body_items.cpp:1360 -#, c-format -msgid "polyline only had %d parameters of the required 4" -msgstr "la polyligne a seulement %d paramètres sur les 4 requis" - -#: eeschema/classes_body_items.cpp:1365 -#, c-format -msgid "polyline count parameter %d is invalid" -msgstr "le nombre de paramètes (%d) de la polyligne est mauvais" - -#: eeschema/classes_body_items.cpp:1381 -#, c-format -msgid "polyline point %d X position not defined" -msgstr "la position X du point %d de la polyligne n'est pas définie" - -#: eeschema/classes_body_items.cpp:1388 -#, c-format -msgid "polyline point %d Y position not defined" -msgstr "la position Y du point %d de la polyligne n'est pas définie" - -#: eeschema/classes_body_items.cpp:1688 -msgid "Bezier" -msgstr "Bezier" - -#: eeschema/classes_body_items.cpp:1734 -#, c-format -msgid "Bezier only had %d parameters of the required 4" -msgstr "La courbe de Bezier a seulement %d paramètres sur les 4 requis" - -#: eeschema/classes_body_items.cpp:1740 -#, c-format -msgid "Bezier count parameter %d is invalid" -msgstr "le nombre de paramètes (%d) de la courbe de Bezier est mauvais" - -#: eeschema/classes_body_items.cpp:1756 -#, c-format -msgid "Bezier point %d X position not defined" -msgstr "la position X du point %d de la courbe de Bezier n'est pas définie" - -#: eeschema/classes_body_items.cpp:1762 -#, c-format -msgid "Bezier point %d Y position not defined" -msgstr "la position Y du point %d de la courbe de Bezier n'est pas définie" - #: eeschema/viewlib_frame.cpp:84 #: eeschema/tool_sch.cpp:51 msgid "Library browser" @@ -8472,10 +8474,6 @@ msgstr "" "\n" "#End List\n" -#: eeschema/build_BOM.cpp:620 -msgid "Field" -msgstr "Champ" - #: eeschema/build_BOM.cpp:628 msgid "" "\n" @@ -8516,6 +8514,18 @@ msgstr "> %-28.28s PinSheet %-7.7s (Feuille %s) pos: %3.3f, %3.3f\n" msgid "#End labels\n" msgstr "#End labels\n" +#: eeschema/class_libentry.cpp:70 +msgid "none" +msgstr "rien" + +#: eeschema/class_libentry.cpp:695 +msgid "file ended prematurely loading component draw element" +msgstr "" + +#: eeschema/class_libentry.cpp:750 +msgid "file ended prematurely while attempting to flush to end of drawing section." +msgstr "" + #: eeschema/edit_component_in_lib.cpp:145 #, c-format msgid "Alias <%s> not found for component <%s> in library <%s>." @@ -8833,10 +8843,12 @@ msgstr "" "Cette opération supprimera l'annotation existante et ne peut être annulée." #: eeschema/dialog_SVG_print_base.cpp:25 +#: eeschema/dialog_print_using_printer_base.cpp:25 msgid "Default Pen Size" msgstr "Dimension Plume par Défaut" #: eeschema/dialog_SVG_print_base.cpp:30 +#: eeschema/dialog_print_using_printer_base.cpp:30 msgid "Selection of the default pen thickness used to draw items, when their thickness is set to 0." msgstr "Valeur de la dimension de la plume utilisée par défaut pour tracer les éléments, lorsque leur épaisseur est à 0." @@ -8923,59 +8935,65 @@ msgstr "<%s> n'est pas un fichier documentation de composant valide." msgid "Current" msgstr "Courant" +#: eeschema/dialog_print_using_printer_base.cpp:52 +#: eeschema/classes_body_items.cpp:68 +#: eeschema/classes_body_items.cpp:74 +msgid "All" +msgstr "Tout" + #: eeschema/onrightclick.cpp:109 msgid "Leave Sheet" msgstr "Quitter sous-feuille" -#: eeschema/onrightclick.cpp:125 +#: eeschema/onrightclick.cpp:124 msgid "Delete Noconn" msgstr "Supprimer Non Connexion" -#: eeschema/onrightclick.cpp:136 +#: eeschema/onrightclick.cpp:135 msgid "Move Bus Entry" msgstr "Déplacer Entrée de Bus" -#: eeschema/onrightclick.cpp:139 +#: eeschema/onrightclick.cpp:138 msgid "Set Bus Entry /" msgstr "Entrée de Bus /" -#: eeschema/onrightclick.cpp:142 +#: eeschema/onrightclick.cpp:141 msgid "Set Bus Entry \\" msgstr "Entrée de Bus \\" -#: eeschema/onrightclick.cpp:144 +#: eeschema/onrightclick.cpp:143 msgid "Delete Bus Entry" msgstr "Supprimer Entrée de Bus" -#: eeschema/onrightclick.cpp:243 +#: eeschema/onrightclick.cpp:242 msgid "Move Field" msgstr "Déplace Champ" -#: eeschema/onrightclick.cpp:245 +#: eeschema/onrightclick.cpp:244 msgid "Rotate Field" msgstr "Rotation Champ" -#: eeschema/onrightclick.cpp:247 +#: eeschema/onrightclick.cpp:246 msgid "Edit Field" msgstr "Editer Champ" -#: eeschema/onrightclick.cpp:279 +#: eeschema/onrightclick.cpp:278 msgid "Move Component" msgstr "Déplace Composant" -#: eeschema/onrightclick.cpp:284 +#: eeschema/onrightclick.cpp:283 msgid "Drag Component" msgstr "Drag Composant" -#: eeschema/onrightclick.cpp:298 +#: eeschema/onrightclick.cpp:297 msgid "Mirror --" msgstr "Miroir--" -#: eeschema/onrightclick.cpp:301 +#: eeschema/onrightclick.cpp:300 msgid "Mirror ||" msgstr "Miroir ||" -#: eeschema/onrightclick.cpp:309 +#: eeschema/onrightclick.cpp:308 msgid "Orient Component" msgstr "Oriente Composant" @@ -8996,227 +9014,307 @@ msgstr "Edite Composant" msgid "Copy Component" msgstr "Copie Composant" -#: eeschema/onrightclick.cpp:379 +#: eeschema/onrightclick.cpp:380 msgid "Move Global Label" msgstr "Déplacer Label Global" -#: eeschema/onrightclick.cpp:381 +#: eeschema/onrightclick.cpp:385 msgid "Rotate Global Label" msgstr "Rot. Label Global" -#: eeschema/onrightclick.cpp:383 +#: eeschema/onrightclick.cpp:387 msgid "Edit Global Label" msgstr "Editer Label Global" -#: eeschema/onrightclick.cpp:385 +#: eeschema/onrightclick.cpp:389 msgid "Delete Global Label" msgstr "Supprimer Label Global" -#: eeschema/onrightclick.cpp:389 -#: eeschema/onrightclick.cpp:451 -#: eeschema/onrightclick.cpp:489 +#: eeschema/onrightclick.cpp:393 +#: eeschema/onrightclick.cpp:463 +#: eeschema/onrightclick.cpp:501 msgid "Change to Hierarchical Label" msgstr "Changer en Label Hiérarchique" -#: eeschema/onrightclick.cpp:391 -#: eeschema/onrightclick.cpp:420 -#: eeschema/onrightclick.cpp:486 +#: eeschema/onrightclick.cpp:395 +#: eeschema/onrightclick.cpp:428 +#: eeschema/onrightclick.cpp:498 msgid "Change to Label" msgstr "Change en Label" -#: eeschema/onrightclick.cpp:393 -#: eeschema/onrightclick.cpp:422 -#: eeschema/onrightclick.cpp:453 +#: eeschema/onrightclick.cpp:397 +#: eeschema/onrightclick.cpp:430 +#: eeschema/onrightclick.cpp:465 msgid "Change to Text" msgstr "Change en Texte" -#: eeschema/onrightclick.cpp:396 -#: eeschema/onrightclick.cpp:427 -#: eeschema/onrightclick.cpp:458 -#: eeschema/onrightclick.cpp:496 +#: eeschema/onrightclick.cpp:400 +#: eeschema/onrightclick.cpp:435 +#: eeschema/onrightclick.cpp:470 +#: eeschema/onrightclick.cpp:508 msgid "Change Type" msgstr "Change Type" -#: eeschema/onrightclick.cpp:410 +#: eeschema/onrightclick.cpp:415 msgid "Move Hierarchical Label" msgstr "Déplacer Label Hiérarchique" -#: eeschema/onrightclick.cpp:412 +#: eeschema/onrightclick.cpp:420 msgid "Rotate Hierarchical Label" msgstr "Rot. Label Hiérarchique" -#: eeschema/onrightclick.cpp:414 +#: eeschema/onrightclick.cpp:422 msgid "Edit Hierarchical Label" msgstr "Editer Label Hiérarchique" -#: eeschema/onrightclick.cpp:416 +#: eeschema/onrightclick.cpp:424 msgid "Delete Hierarchical label" msgstr "Supprimer Label Hiérarchique" -#: eeschema/onrightclick.cpp:424 -#: eeschema/onrightclick.cpp:455 +#: eeschema/onrightclick.cpp:432 +#: eeschema/onrightclick.cpp:467 msgid "Change to Global Label" msgstr "Change en Label Global" -#: eeschema/onrightclick.cpp:441 +#: eeschema/onrightclick.cpp:450 msgid "Move Label" msgstr "Déplace Label" -#: eeschema/onrightclick.cpp:443 +#: eeschema/onrightclick.cpp:455 msgid "Rotate Label" msgstr "Rot. Label" -#: eeschema/onrightclick.cpp:445 +#: eeschema/onrightclick.cpp:457 msgid "Edit Label" msgstr "Editer Label" -#: eeschema/onrightclick.cpp:447 +#: eeschema/onrightclick.cpp:459 msgid "Delete Label" msgstr "Supprimer Label" -#: eeschema/onrightclick.cpp:472 +#: eeschema/onrightclick.cpp:484 msgid "Move Text" msgstr "Déplacer Texte" -#: eeschema/onrightclick.cpp:475 +#: eeschema/onrightclick.cpp:487 msgid "Edit Text" msgstr "Editer Texte" -#: eeschema/onrightclick.cpp:477 +#: eeschema/onrightclick.cpp:489 msgid "Delete Text" msgstr "Effacer Texte" -#: eeschema/onrightclick.cpp:493 +#: eeschema/onrightclick.cpp:505 msgid "Change to Glabel" msgstr "Change en Label Global" -#: eeschema/onrightclick.cpp:515 -#: eeschema/onrightclick.cpp:559 +#: eeschema/onrightclick.cpp:527 +#: eeschema/onrightclick.cpp:571 msgid "Break Wire" msgstr "Briser Fil" -#: eeschema/onrightclick.cpp:518 +#: eeschema/onrightclick.cpp:530 msgid "Delete Junction" msgstr "Supprimer Jonction" -#: eeschema/onrightclick.cpp:525 -#: eeschema/onrightclick.cpp:552 +#: eeschema/onrightclick.cpp:537 +#: eeschema/onrightclick.cpp:564 msgid "Delete Node" msgstr "Supprimer Noeud" -#: eeschema/onrightclick.cpp:527 -#: eeschema/onrightclick.cpp:555 +#: eeschema/onrightclick.cpp:539 +#: eeschema/onrightclick.cpp:567 msgid "Delete Connection" msgstr "Supprimer Connexion" -#: eeschema/onrightclick.cpp:544 +#: eeschema/onrightclick.cpp:556 msgid "Wire End" msgstr "Terminer Fil" -#: eeschema/onrightclick.cpp:548 +#: eeschema/onrightclick.cpp:560 msgid "Drag Wire" msgstr "Drag Fil" -#: eeschema/onrightclick.cpp:551 +#: eeschema/onrightclick.cpp:563 msgid "Delete Wire" msgstr "Supprimer Fil" -#: eeschema/onrightclick.cpp:573 -#: eeschema/onrightclick.cpp:609 +#: eeschema/onrightclick.cpp:585 +#: eeschema/onrightclick.cpp:621 msgid "Add Global Label" msgstr "Ajout Label Global" -#: eeschema/onrightclick.cpp:589 +#: eeschema/onrightclick.cpp:601 msgid "Bus End" msgstr "Terminer Bus" -#: eeschema/onrightclick.cpp:593 +#: eeschema/onrightclick.cpp:605 msgid "Delete Bus" msgstr "Supprimer Bus" -#: eeschema/onrightclick.cpp:596 +#: eeschema/onrightclick.cpp:608 msgid "Break Bus" msgstr "Briser Bus" -#: eeschema/onrightclick.cpp:622 +#: eeschema/onrightclick.cpp:634 msgid "Enter Sheet" msgstr "Entrer dans Feuille" -#: eeschema/onrightclick.cpp:625 +#: eeschema/onrightclick.cpp:637 msgid "Move Sheet" msgstr "Déplacer Feuille" -#: eeschema/onrightclick.cpp:630 +#: eeschema/onrightclick.cpp:642 msgid "Place Sheet" msgstr "Placer Feuille" -#: eeschema/onrightclick.cpp:635 +#: eeschema/onrightclick.cpp:647 msgid "Edit Sheet" msgstr "Editer Feuille" -#: eeschema/onrightclick.cpp:637 +#: eeschema/onrightclick.cpp:649 msgid "Resize Sheet" msgstr "Redimensionner Feuille" -#: eeschema/onrightclick.cpp:640 +#: eeschema/onrightclick.cpp:652 msgid "Import PinSheets" msgstr "Importer Connecteur de Hiérarchie" -#: eeschema/onrightclick.cpp:644 +#: eeschema/onrightclick.cpp:656 msgid "Cleanup PinSheets" msgstr "Nettoyage des Pins Hiérarchiques" -#: eeschema/onrightclick.cpp:646 +#: eeschema/onrightclick.cpp:658 msgid "Delete Sheet" msgstr "Supprimer Feuille" -#: eeschema/onrightclick.cpp:661 +#: eeschema/onrightclick.cpp:673 msgid "Move PinSheet" msgstr "Déplace Connecteur de hiérarchie" -#: eeschema/onrightclick.cpp:663 +#: eeschema/onrightclick.cpp:675 msgid "Edit PinSheet" msgstr "Edit Connecteur de hiérarchie" -#: eeschema/onrightclick.cpp:667 +#: eeschema/onrightclick.cpp:679 msgid "Delete PinSheet" msgstr "Supprimer Connecteur de hiérarchie" -#: eeschema/onrightclick.cpp:684 +#: eeschema/onrightclick.cpp:696 msgid "Window Zoom" msgstr "Zoom sur Fenètre" -#: eeschema/onrightclick.cpp:691 +#: eeschema/onrightclick.cpp:703 msgid "Save Block" msgstr "Sauver Bloc" -#: eeschema/onrightclick.cpp:694 +#: eeschema/onrightclick.cpp:706 msgid "Drag Block" msgstr "Drag Bloc" -#: eeschema/onrightclick.cpp:704 +#: eeschema/onrightclick.cpp:716 msgid "Copy to Clipboard" msgstr "Copie dans Presse papier" -#: eeschema/class_libentry_fields.cpp:134 -msgid "invalid field number defined" -msgstr "numéro de champ défini invalide" +#: eeschema/classes_body_items.cpp:35 +msgid "Undefined" +msgstr "Non Défini" -#: eeschema/class_libentry_fields.cpp:552 -msgid "Datasheet" -msgstr "Documentation" +#: eeschema/classes_body_items.cpp:76 +msgid "no" +msgstr "non" -#: eeschema/class_libentry.cpp:70 -msgid "none" -msgstr "rien" +#: eeschema/classes_body_items.cpp:78 +msgid "yes" +msgstr "oui" -#: eeschema/class_libentry.cpp:695 -msgid "file ended prematurely loading component draw element" -msgstr "" +#: eeschema/classes_body_items.cpp:182 +#, c-format +msgid "arc only had %d parameters of the required 8" +msgstr "l'arc a seulement %d paramètres sur les 8 requis" -#: eeschema/class_libentry.cpp:750 -msgid "file ended prematurely while attempting to flush to end of drawing section." -msgstr "" +#: eeschema/classes_body_items.cpp:530 +#: eeschema/classes_body_items.cpp:791 +#: eeschema/classes_body_items.cpp:1016 +#: eeschema/classes_body_items.cpp:1267 +#: eeschema/classes_body_items.cpp:1678 +#: eeschema/classes_body_items.cpp:2047 +msgid "Line width" +msgstr "Epaisseur ligne" + +#: eeschema/classes_body_items.cpp:535 +#: eeschema/classes_body_items.cpp:800 +#: eeschema/classes_body_items.cpp:1272 +#: eeschema/classes_body_items.cpp:1683 +#: eeschema/classes_body_items.cpp:2052 +msgid "Bounding box" +msgstr "Rectange dencadrement" + +#: eeschema/classes_body_items.cpp:581 +#, c-format +msgid "circle only had %d parameters of the required 6" +msgstr "le cercle a seulement %d paramètres sur les 6 requis" + +#: eeschema/classes_body_items.cpp:795 +msgid "Radius" +msgstr "Rayon" + +#: eeschema/classes_body_items.cpp:814 +msgid "Rectangle" +msgstr "Rectangle" + +#: eeschema/classes_body_items.cpp:849 +#, c-format +msgid "rectangle only had %d parameters of the required 7" +msgstr "le rectangle a seulement %d paramètres sur les 7 requis" + +#: eeschema/classes_body_items.cpp:1320 +msgid "PolyLine" +msgstr "PolyLigne" + +#: eeschema/classes_body_items.cpp:1366 +#, c-format +msgid "polyline only had %d parameters of the required 4" +msgstr "la polyligne a seulement %d paramètres sur les 4 requis" + +#: eeschema/classes_body_items.cpp:1371 +#, c-format +msgid "polyline count parameter %d is invalid" +msgstr "le nombre de paramètes (%d) de la polyligne est mauvais" + +#: eeschema/classes_body_items.cpp:1387 +#, c-format +msgid "polyline point %d X position not defined" +msgstr "la position X du point %d de la polyligne n'est pas définie" + +#: eeschema/classes_body_items.cpp:1394 +#, c-format +msgid "polyline point %d Y position not defined" +msgstr "la position Y du point %d de la polyligne n'est pas définie" + +#: eeschema/classes_body_items.cpp:1695 +msgid "Bezier" +msgstr "Bezier" + +#: eeschema/classes_body_items.cpp:1741 +#, c-format +msgid "Bezier only had %d parameters of the required 4" +msgstr "La courbe de Bezier a seulement %d paramètres sur les 4 requis" + +#: eeschema/classes_body_items.cpp:1747 +#, c-format +msgid "Bezier count parameter %d is invalid" +msgstr "le nombre de paramètes (%d) de la courbe de Bezier est mauvais" + +#: eeschema/classes_body_items.cpp:1763 +#, c-format +msgid "Bezier point %d X position not defined" +msgstr "la position X du point %d de la courbe de Bezier n'est pas définie" + +#: eeschema/classes_body_items.cpp:1769 +#, c-format +msgid "Bezier point %d Y position not defined" +msgstr "la position Y du point %d de la courbe de Bezier n'est pas définie" #: eeschema/eelibs_read_libraryfiles.cpp:61 msgid "\n" @@ -9275,7 +9373,6 @@ msgid "A no connect symbol is connected to more than 1 pin" msgstr "Un symbole de non connexion est connecté à plus de une pin" #: eeschema/dialog_create_component.cpp:172 -#: eeschema/dialog_edit_component_in_lib_base.cpp:27 msgid "As Convert" msgstr "A une forme \"convertie\"" @@ -9396,17 +9493,14 @@ msgid "Show Pin Number" msgstr "Montrer Numéro de Pin" #: eeschema/dialog_create_component.cpp:241 -#: eeschema/dialog_edit_component_in_lib_base.cpp:40 msgid "Show Pin Name" msgstr "Montre Nom de Pin" #: eeschema/dialog_create_component.cpp:245 -#: eeschema/dialog_edit_component_in_lib_base.cpp:47 msgid "Pin Name Inside" msgstr "Nom de pin à l'intérieur" #: eeschema/dialog_create_component.cpp:249 -#: eeschema/dialog_edit_component_in_lib_base.cpp:77 msgid "Skew:" msgstr "Décalage:" @@ -9731,21 +9825,38 @@ msgstr " (alias de " msgid "%8.8lX/" msgstr "%8.8lX/" -#: eeschema/dialog_cmp_graphic_properties.cpp:155 -msgid "Options :" -msgstr "Options :" +#: eeschema/dialog_lib_edit_draw_item_base.cpp:22 +msgid "General" +msgstr "Général " -#: eeschema/dialog_cmp_graphic_properties.cpp:171 -msgid "Void" -msgstr "Sans" +#: eeschema/dialog_lib_edit_draw_item_base.cpp:34 +msgid "&Width:" +msgstr "&Epaisseur" -#: eeschema/dialog_cmp_graphic_properties.cpp:173 -msgid "BgFilled" -msgstr "Fond Plein" +#: eeschema/dialog_lib_edit_draw_item_base.cpp:56 +msgid "Apply changes to all &parts in component" +msgstr "" -#: eeschema/dialog_cmp_graphic_properties.cpp:174 -msgid "Fill:" -msgstr "Remplissage:" +#: eeschema/dialog_lib_edit_draw_item_base.cpp:68 +#, fuzzy +msgid "Apply changes to all body &styles (DeMorgan)" +msgstr "Créer un composant avec une forme &alternative (DeMorgan)" + +#: eeschema/dialog_lib_edit_draw_item_base.cpp:77 +msgid "Fill Style" +msgstr "Style de Remplissage" + +#: eeschema/dialog_lib_edit_draw_item_base.cpp:92 +msgid "Do ¬ fill" +msgstr "Pas de remplissage" + +#: eeschema/dialog_lib_edit_draw_item_base.cpp:96 +msgid "Fill &foreground" +msgstr "Remplissage en &arriere plan" + +#: eeschema/dialog_lib_edit_draw_item_base.cpp:99 +msgid "Fill &background" +msgstr "Remplissage en a&vant plan" #: eeschema/component_wizard/dialog_component_setup.cpp:137 msgid "Quick KICAD Library Component Builder" @@ -9874,7 +9985,6 @@ msgid " [no file]" msgstr " [pas de fichier]" #: cvpcb/menucfg.cpp:37 -#: cvpcb/tool_cvpcb.cpp:30 msgid "Open a NetList file" msgstr "Lire un Fichier Netliste" @@ -9991,8 +10101,6 @@ msgid "Delete selections" msgstr "Effacement des associations existantes" #: cvpcb/cvframe.cpp:438 -#: cvpcb/init.cpp:67 -#: cvpcb/init.cpp:119 #, c-format msgid "Components: %d (free: %d)" msgstr "Composants: %d (libres: %d)" @@ -10677,14 +10785,11 @@ msgid "%d errors while reading Gerber file [%s]" msgstr "%d erreurs pendant lecture fichier gerber [%s]" #: gerbview/readgerb.cpp:274 -#: gerbview/files.cpp:203 -#: gerbview/files.cpp:238 #, c-format msgid "Gerber DCODE files (%s)|*.%s" msgstr "Fichiers Gerber DCODE (%s)|*.%s" #: gerbview/readgerb.cpp:278 -#: gerbview/files.cpp:208 msgid "Load GERBER DCODE File" msgstr "Charger Fichier de DCodes" @@ -11453,10 +11558,6 @@ msgstr "Liste tous" msgid "Select by Browser" msgstr "Sélection par Viewer" -#: common/class_marker_base.cpp:183 -msgid "Marker Info" -msgstr "Info Marqueur" - #: common/drawframe.cpp:348 msgid "Inch" msgstr "Pouce" @@ -11838,7 +11939,7 @@ msgstr "Effacements Globaux" msgid "Footprints Orientation" msgstr "Orientation des Modules" -#: pcbnew/dialog_track_options_base.h:86 +#: pcbnew/dialog_track_options_base.h:81 msgid "Tracks and Vias Sizes" msgstr "Dims Pistes et Vias" @@ -11850,7 +11951,7 @@ msgstr "Dialogue Netliste" msgid "Create SVG file" msgstr "Créer Fichier SVG" -#: pcbnew/dialog_design_rules_base.h:81 +#: pcbnew/dialog_design_rules_base.h:100 msgid "Design Rules Editor" msgstr "Editeur de Règles de Conception" @@ -11862,10 +11963,6 @@ msgstr "Options de Remplissage de Zone" msgid "Non Copper Zones Properties" msgstr "Propriétés des Zones sur couches non cuivre" -#: pcbnew/dialog_general_options_BoardEditor_base.h:80 -msgid "General settings" -msgstr "Options Générales" - #: pcbnew/dialog_pad_properties_base.h:90 msgid "Pad Properties" msgstr "Propriétés du Pad" @@ -11874,6 +11971,10 @@ msgstr "Propriétés du Pad" msgid "Footprint text properties" msgstr "Propriétés du texte du module" +#: pcbnew/dialog_general_options_BoardEditor_base.h:80 +msgid "General settings" +msgstr "Options Générales" + #: pcbnew/set_color.h:36 msgid "Pcbnew Layer Colors:" msgstr "Pcbnew: Couleur des Couches" @@ -11947,10 +12048,6 @@ msgstr "Propriétés du Module" msgid "Copper layers setup" msgstr "Réglage des Couches Cuivre" -#: eeschema/dialog_cmp_graphic_properties.h:43 -msgid "Graphic shape properties" -msgstr "Propriétés du dessin" - #: eeschema/pinedit-dialog.h:66 msgid "Pin properties" msgstr "Propriétés des Pins" @@ -12027,10 +12124,6 @@ msgstr "ERC Warning" msgid "Erc Error" msgstr "ERC Erreur" -#: eeschema/eelayer.h:253 -msgid "General" -msgstr "Général " - #: eeschema/eelayer.h:259 msgid "Device" msgstr "Composant" @@ -12083,6 +12176,10 @@ msgstr "Propriétés des Champs" msgid "Lib Component Properties" msgstr "Propriétés du composant librairie" +#: eeschema/dialog_lib_edit_draw_item_base.h:58 +msgid "Drawing Properties" +msgstr "Propriétés de l'Elément Graphique" + #: eeschema/dialog_erc_base.h:94 msgid "EESchema Erc" msgstr "EESchema Erc" @@ -12243,6 +12340,22 @@ msgstr "DCodes id." msgid "Page Settings" msgstr "Ajustage opt Page" +#~ msgid "Copper &Layers" +#~ msgstr "Couches &Cuivre." +#~ msgid "Select copper layers count and layers names" +#~ msgstr "Sélection du nombre de couches cuivre et du nom des couches" +#~ msgid "Active copper layers count selection" +#~ msgstr "Sélection su nombre de couches cuivre actives" +#~ msgid "Options :" +#~ msgstr "Options :" +#~ msgid "Void" +#~ msgstr "Sans" +#~ msgid "BgFilled" +#~ msgstr "Fond Plein" +#~ msgid "Fill:" +#~ msgstr "Remplissage:" +#~ msgid "Graphic shape properties" +#~ msgstr "Propriétés du dessin" #~ msgid "Unable to create temporary file " #~ msgstr "Impossible de créer le fichier temporaire " #~ msgid "Create temporary file " diff --git a/pcbnew/class_board.cpp b/pcbnew/class_board.cpp index 135ee28e76..6b8de3f829 100644 --- a/pcbnew/class_board.cpp +++ b/pcbnew/class_board.cpp @@ -127,6 +127,22 @@ BOARD::~BOARD() return lists_sizes_modified; } +/** function GetBiggestClearanceValue + * @return the biggest clerance value found in NetClasses list + */ +int BOARD::GetBiggestClearanceValue() +{ + int clearance = m_NetClasses.GetDefault()->GetClearance(); + //Read list of Net Classes + for( NETCLASSES::const_iterator nc = m_NetClasses.begin(); nc != m_NetClasses.end(); nc++ ) + { + NETCLASS* netclass = nc->second; + clearance = MAX( clearance, netclass->GetClearance() ); + } + return clearance; +} + + wxString BOARD::GetLayerName( int aLayerIndex ) const { if( ! IsValidLayerIndex( aLayerIndex )) diff --git a/pcbnew/class_board.h b/pcbnew/class_board.h index 2307ff70c2..38c06604a1 100644 --- a/pcbnew/class_board.h +++ b/pcbnew/class_board.h @@ -297,7 +297,7 @@ public: bool SetLayerType( int aLayerIndex, LAYER_T aLayerType ); - /* Routines de calcul des nombres de segments pistes et zones */ + /* Functions to get some items count */ int GetNumSegmTrack(); int GetNumSegmZone(); unsigned GetNoconnectCount(); // retourne le nombre de connexions manquantes @@ -404,6 +404,7 @@ public: */ int ReturnSortedNetnamesList( wxArrayString& aNames, bool aSortbyPadsCount ); + /****** function relative to NetClasses: */ /** * Function SynchronizeNetsAndNetClasses * copies NETCLASS info to each NET, based on NET membership in a NETCLASS. @@ -425,6 +426,13 @@ public: */ bool SetCurrentNetClass( const wxString& aNetClassName ); + /** function GetBiggestClearanceValue + * @return the biggest clerance value found in NetClasses list + */ + int GetBiggestClearanceValue(); + + + /***************************************************************************/ /** * Function Save * writes the data structures for this object out to a FILE in "*.brd" format. @@ -714,6 +722,7 @@ public: * @param aNetcode = netcode to analyse. if -1, analyse all nets */ void Test_Connections_To_Copper_Areas( int aNetcode = -1 ); + }; #endif // #ifndef CLASS_BOARD_H diff --git a/pcbnew/class_board_connected_item.cpp b/pcbnew/class_board_connected_item.cpp index 8a2069f5ba..06a7aed849 100644 --- a/pcbnew/class_board_connected_item.cpp +++ b/pcbnew/class_board_connected_item.cpp @@ -111,6 +111,11 @@ int BOARD_CONNECTED_ITEM::GetClearance( BOARD_CONNECTED_ITEM* aItem ) const } +/** return a pointer to the netclass of the zone + * if the net is not found (can happen when a netlist is reread, + * and the net name is not existant, return the default net class + * So should not return a null pointer + */ NETCLASS* BOARD_CONNECTED_ITEM::GetNetClass() const { // It is important that this be implemented without any sequential searching. @@ -118,33 +123,35 @@ NETCLASS* BOARD_CONNECTED_ITEM::GetNetClass() const BOARD* board = GetBoard(); // DO NOT use wxASSERT, because GetNetClass is called inside an OnPaint event // and a call to wxASSERT can crash the application. - if( board ) - { - NETINFO_ITEM* net = board->FindNet( GetNet() ); - if( net ) - { - NETCLASS* netclass = net->GetNetClass(); -#ifdef __WXDEBUG__ - if( netclass == NULL ) - wxLogWarning(wxT("BOARD_CONNECTED_ITEM::GetNetClass(): NULL netclass") ); -#endif - return netclass; - } - else - { -#ifdef __WXDEBUG__ - wxLogWarning(wxT("BOARD_CONNECTED_ITEM::GetNetClass(): NULL net") ); -#endif - } - } - else + if( board == NULL ) // Should not occurs { #ifdef __WXDEBUG__ wxLogWarning(wxT("BOARD_CONNECTED_ITEM::GetNetClass(): NULL board, type %d"), Type() ); #endif + return NULL; } - return NULL; + NETCLASS* netclass = NULL; + NETINFO_ITEM* net = board->FindNet( GetNet() ); + if( net ) + { + netclass = net->GetNetClass(); +#ifdef __WXDEBUG__ + if( netclass == NULL ) + wxLogWarning(wxT("BOARD_CONNECTED_ITEM::GetNetClass(): NULL netclass") ); +#endif + } + else + { +#ifdef __WXDEBUG__ + wxLogWarning(wxT("BOARD_CONNECTED_ITEM::GetNetClass(): NULL net") ); +#endif + } + + if( netclass ) + return netclass; + else + return board->m_NetClasses.GetDefault(); } /** function GetNetClassName diff --git a/pcbnew/class_module.cpp b/pcbnew/class_module.cpp index f6aa8431e6..a2a9bc2d22 100644 --- a/pcbnew/class_module.cpp +++ b/pcbnew/class_module.cpp @@ -782,7 +782,8 @@ EDA_Rect MODULE::GetBoundingBox() // Add the Clearence shape size: (shape around the pads when the clearence is shown // Not optimized, but the draw cost is small (perhaps smaller than optimization) - area.Inflate(g_DesignSettings.m_TrackClearance, g_DesignSettings.m_TrackClearance); + int biggest_clearance = GetBoard()->GetBiggestClearanceValue(); + area.Inflate(biggest_clearance); return area; } diff --git a/pcbnew/class_netclass.cpp b/pcbnew/class_netclass.cpp index 4a286e0d4c..509193ab43 100644 --- a/pcbnew/class_netclass.cpp +++ b/pcbnew/class_netclass.cpp @@ -33,6 +33,10 @@ // This will get mapped to "kicad_default" in the specctra_export. const wxString NETCLASS::Default = wxT("Default"); +// Initial values for netclass initialization +int NETCLASS::DEFAULT_CLEARANCE = 100; // track to track and track to pads clearance +int NETCLASS::DEFAULT_VIA_DRILL = 250; // default via drill +int NETCLASS::DEFAULT_UVIA_DRILL = 50; // micro via drill NETCLASS::NETCLASS( BOARD* aParent, const wxString& aName, const NETCLASS* initialParameters ) : @@ -60,12 +64,13 @@ void NETCLASS::SetParams( const NETCLASS* defaults ) { const EDA_BoardDesignSettings& g = g_DesignSettings; - SetClearance( g.m_TrackClearance ); SetTrackWidth( g.m_TrackMinWidth ); SetViaDiameter( g.m_ViasMinSize ); - SetViaDrill( g.m_ViaDrill ); SetuViaDiameter(g.m_MicroViasMinSize ); - SetuViaDrill( g.m_MicroViaDrill ); + // Use default values for next parameters: + SetClearance( DEFAULT_CLEARANCE ); + SetViaDrill( DEFAULT_VIA_DRILL ); + SetuViaDrill( DEFAULT_UVIA_DRILL ); } } diff --git a/pcbnew/class_netclass.h b/pcbnew/class_netclass.h index a7570ea5ba..d7e022bb10 100644 --- a/pcbnew/class_netclass.h +++ b/pcbnew/class_netclass.h @@ -37,8 +37,15 @@ * handles a collection of nets and the parameters used to route or * test these nets. */ + class NETCLASS { +private: + // Default values used to init a NETCLASS + static int DEFAULT_CLEARANCE; + static int DEFAULT_VIA_DRILL; + static int DEFAULT_UVIA_DRILL; + protected: BOARD* m_Parent; @@ -213,7 +220,7 @@ public: /** * Class NETCLASSES - * is a containter for NETCLASS instances. It owns all its NETCLASSes + * is a container for NETCLASS instances. It owns all its NETCLASSes * (=> it will delete them at time of destruction). This container will always have * a default NETCLASS with the name given by const NETCLASS::Default. */ diff --git a/pcbnew/class_pad_draw_functions.cpp b/pcbnew/class_pad_draw_functions.cpp index 341a1a7c92..e253346eaf 100644 --- a/pcbnew/class_pad_draw_functions.cpp +++ b/pcbnew/class_pad_draw_functions.cpp @@ -14,7 +14,8 @@ /*******************************************************************************************/ -void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoint& offset ) +void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, + const wxPoint& offset ) /*******************************************************************************************/ /** Draw a pad: @@ -34,6 +35,7 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin wxPoint coord[4]; int fillpad = 0; wxPoint shape_pos; + int mask_margin = 0; // margin (clearance) used for some non copper layers if( m_Flags & DO_NOT_DRAW ) return; @@ -56,6 +58,8 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin if( color == 0 ) /* Not on copper layer */ { + // If the pad in on only one tech layer, use the layer color + // else use DARKGRAY switch( m_Masque_Layer & ~ALL_CU_LAYERS ) { case ADHESIVE_LAYER_CU: @@ -160,12 +164,26 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin } } - // if Contrast mode and a technical layer active, show pads on this layer + // if Contrast mode is ON and a technical layer active, show pads on this layer // so we can see pads on paste or solder layer if( DisplayOpt.ContrastModeDisplay && screen->m_Active_Layer > LAST_COPPER_LAYER ) { if( IsOnLayer( screen->m_Active_Layer ) ) + { color = g_DesignSettings.m_LayerColor[screen->m_Active_Layer]; + // In hight contrast mode, and if the active layer is the mask layer + // shows the pad size with the mask clearance + switch( screen->m_Active_Layer ) + { + case SOLDERMASK_N_CU: + case SOLDERMASK_N_CMP: + mask_margin = g_DesignSettings.m_MaskMargin; + break; + + default: + break; + } + } else color = DARKDARKGRAY; } @@ -191,8 +209,6 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin xc = ux0; yc = uy0; - /* le trace depend de la rotation de l'empreinte */ - dx = dx0 = m_Size.x >> 1; dy = dy0 = m_Size.y >> 1; /* demi dim dx et dy */ @@ -209,15 +225,15 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin * net classes so a call to GetClearance() is made only when needed * (never needed in Cvpcb nor in Gerbview) */ - int padClearance = DisplayIsol ? GetClearance() : 0; + int padClearance = DisplayIsol ? GetClearance() : 0; switch( GetShape() ) { case PAD_CIRCLE: if( fillpad ) - GRFilledCircle( &panel->m_ClipBox, DC, xc, yc, dx, 0, color, color ); + GRFilledCircle( &panel->m_ClipBox, DC, xc, yc, dx + mask_margin, 0, color, color ); else - GRCircle( &panel->m_ClipBox, DC, xc, yc, dx, 0, color ); + GRCircle( &panel->m_ClipBox, DC, xc, yc, dx + mask_margin, 0, color ); if( DisplayIsol ) { @@ -249,14 +265,16 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin if( fillpad ) { - GRFillCSegm( &panel->m_ClipBox, DC, ux0 + delta_cx, uy0 + delta_cy, - ux0 - delta_cx, uy0 - delta_cy, + GRFillCSegm( &panel->m_ClipBox, DC, + ux0 + delta_cx + mask_margin, uy0 + delta_cy + mask_margin, + ux0 - delta_cx - mask_margin, uy0 - delta_cy - mask_margin, rotdx, color ); } else { - GRCSegm( &panel->m_ClipBox, DC, ux0 + delta_cx, uy0 + delta_cy, - ux0 - delta_cx, uy0 - delta_cy, + GRCSegm( &panel->m_ClipBox, DC, + ux0 + delta_cx + mask_margin, uy0 + delta_cy + mask_margin, + ux0 - delta_cx - mask_margin, uy0 - delta_cy - mask_margin, rotdx, color ); } @@ -275,8 +293,8 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin case PAD_TRAPEZOID: { int ddx, ddy; - ddx = m_DeltaSize.x >> 1; - ddy = m_DeltaSize.y >> 1; /* demi dim dx et dy */ + ddx = (m_DeltaSize.x >> 1) + mask_margin; + ddy = (m_DeltaSize.y >> 1) + mask_margin; /* demi dim dx et dy */ coord[0].x = -dx - ddy; coord[0].y = +dy + ddx; @@ -301,8 +319,8 @@ void D_PAD::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin if( DisplayIsol ) { - dx += padClearance; - dy += padClearance; + dx += padClearance - mask_margin; + dy += padClearance - mask_margin; coord[0].x = -dx - ddy; coord[0].y = dy + ddx; diff --git a/pcbnew/class_track.cpp b/pcbnew/class_track.cpp index 57496eb1f1..9ba74f4865 100644 --- a/pcbnew/class_track.cpp +++ b/pcbnew/class_track.cpp @@ -108,7 +108,7 @@ TRACK* TRACK::Copy() const /** * Function GetDrillValue - * calculate the drill value for vias (m-Drill if > 0, or default drill value for the board + * calculate the drill value for vias (m_Drill if > 0, or default drill value for the Netclass * @return real drill_value */ int TRACK::GetDrillValue() const @@ -116,25 +116,18 @@ int TRACK::GetDrillValue() const if( Type() != TYPE_VIA ) return 0; - if( m_Drill >= 0 ) + if( m_Drill > 0 ) // Use the specific value. return m_Drill; + // Use the default value from the Netclass + NETCLASS* netclass = GetNetClass(); + if( m_Shape == VIA_MICROVIA ) - return g_DesignSettings.m_MicroViaDrill; + return netclass->GetuViaDrill(); - return g_DesignSettings.m_ViaDrill; + return netclass->GetViaDrill(); } -/** - * Function GetLength - * returns the position of this object. - * @return the length of the track segment (0 for a via). - */ -double TRACK::GetLength() -{ - wxPoint delta = m_End - m_Start; - return sqrt( ((double)delta.x*delta.x) + ((double)delta.y*delta.y ) ); -} /***********************/ bool TRACK::IsNull() diff --git a/pcbnew/class_track.h b/pcbnew/class_track.h index 019f9f4e26..04e2a0e15a 100644 --- a/pcbnew/class_track.h +++ b/pcbnew/class_track.h @@ -96,12 +96,6 @@ public: return m_Start; // it had to be start or end. } - /** - * Function GetLength - * returns the position of this object. - * @return the length of the track segment (0 for a via). - */ - double GetLength(); EDA_Rect GetBoundingBox(); diff --git a/pcbnew/class_zone.cpp b/pcbnew/class_zone.cpp index de8f9f9f90..b9bf8927e7 100644 --- a/pcbnew/class_zone.cpp +++ b/pcbnew/class_zone.cpp @@ -22,7 +22,7 @@ /************************/ ZONE_CONTAINER::ZONE_CONTAINER( BOARD* parent ) : - BOARD_ITEM( parent, TYPE_ZONE_CONTAINER ) + BOARD_CONNECTED_ITEM( parent, TYPE_ZONE_CONTAINER ) { m_NetCode = -1; // Net number for fast comparisons @@ -42,6 +42,7 @@ ZONE_CONTAINER::~ZONE_CONTAINER() } + /** virtual function GetPosition * @return a wxPoint, position of the first point of the outline */ @@ -71,21 +72,14 @@ void ZONE_CONTAINER::SetNet( int anet_code ) if( anet_code < 0 ) return; - if( m_Parent ) + BOARD* board = GetBoard(); + if( board ) { - BOARD* board = (BOARD*) m_Parent; NETINFO_ITEM* net = board->FindNet( anet_code ); if( net ) m_Netname = net->GetNetname(); else m_Netname.Empty(); - - // Set corresponding SEGZONE items if this zone uses fill areas by segments - for( SEGZONE* zseg = board->m_Zone; zseg; zseg = zseg->Next() ) - { - if ( zseg->m_TimeStamp == m_TimeStamp ) - zseg->SetNet(GetNet()); - } } else m_Netname.Empty(); diff --git a/pcbnew/class_zone.h b/pcbnew/class_zone.h index 1ec6edbfa6..702df763f8 100644 --- a/pcbnew/class_zone.h +++ b/pcbnew/class_zone.h @@ -33,7 +33,7 @@ public: * others polygons inside this main polygon are holes. */ -class ZONE_CONTAINER : public BOARD_ITEM +class ZONE_CONTAINER : public BOARD_CONNECTED_ITEM { public: wxString m_Netname; // Net Name @@ -60,10 +60,6 @@ public: * in this case segments have m_ZoneMinThickness width */ -private: - int m_NetCode; // Net number for fast comparisons - int m_ZoneSubnet; // variable used in rastnest computations:handle block number in zone connection calculations - public: ZONE_CONTAINER( BOARD* parent ); ~ZONE_CONTAINER(); @@ -154,21 +150,7 @@ public: return ( GetLayer() < FIRST_NO_COPPER_LAYER ) ? true : false; } - - /** - * Function GetZoneSubNet - * @return int - the sub net code in zone connections. - */ - int GetZoneSubNet() const { return m_ZoneSubnet; } - void SetZoneSubNet( int aSubNetCode ) { m_ZoneSubnet = aSubNetCode; } - - int GetNet( void ) const - { - return m_NetCode; - } - - - void SetNet( int anet_code ); + virtual void SetNet( int anet_code ); /** * Function SetNetNameFromNetCode diff --git a/pcbnew/classpcb.cpp b/pcbnew/classpcb.cpp index c6b00fa9b9..a0e917e8df 100644 --- a/pcbnew/classpcb.cpp +++ b/pcbnew/classpcb.cpp @@ -199,23 +199,22 @@ EDA_BoardDesignSettings::EDA_BoardDesignSettings() }; m_CopperLayerCount = 2; // Default design is a double sided board - m_ViaDrill = 250; // defualt via drill (for the entire board) m_ViaDrillCustomValue = 250; // via drill for vias which must have a defined drill value m_CurrentViaSize = 450; // Current via size m_CurrentViaType = VIA_THROUGH; // via type (VIA_BLIND_BURIED, VIA_THROUGH VIA_MICROVIA) m_CurrentTrackWidth = 170; // current track width m_UseConnectedTrackWidth = false; // if true, when creating a new track starting on an existing track, use this track width - m_MicroViaDrill = 50; // micro via drill (for the entire board) m_CurrentMicroViaSize = 150; // Current micro via size m_MicroViasAllowed = false; // true to allow micro vias m_DrawSegmentWidth = 100; // current graphic line width (not EDGE layer) m_EdgeSegmentWidth = 100; // current graphic line width (EDGE layer only) m_PcbTextWidth = 100; // current Pcb (not module) Text width m_PcbTextSize = wxSize( 500, 500 ); // current Pcb (not module) Text size - m_TrackClearance = 100; // track to track and track to pads clearance m_TrackMinWidth = 80; // track min value for width ((min copper size value m_ViasMinSize = 350; // vias (not micro vias) min diameter + m_ViasMinDrill = 200; // vias (not micro vias) min drill diameter m_MicroViasMinSize = 200; // micro vias (not vias) min diameter + m_MicroViasMinDrill = 80; // micro vias (not vias) min drill diameter m_MaskMargin = 150; // Solder mask margin /* Color options for screen display of the Printed Board: */ diff --git a/pcbnew/dialog_design_rules.cpp b/pcbnew/dialog_design_rules.cpp index 77dea88a20..dea2abd9db 100644 --- a/pcbnew/dialog_design_rules.cpp +++ b/pcbnew/dialog_design_rules.cpp @@ -5,7 +5,7 @@ /* * This program source code file is part of KICAD, a free EDA CAD application. * - * Copyright (C) 2004-2009 Jean-Pierre Charras, jean-pierre.charras@inpg.fr + * Copyright (C) 2004-2009 Jean-Pierre Charras, jean-pierre.charras@gpisa-lab.inpg.fr * Copyright (C) 2009 Dick Hollenbeck, dick@softplc.com * Copyright (C) 2009 Kicad Developers, see change_log.txt for contributors. * @@ -62,6 +62,7 @@ DIALOG_DESIGN_RULES::DIALOG_DESIGN_RULES( WinEDA_PcbFrame* parent ) : /***********************************************************************************/ { m_Parent = parent; + SetAutoLayout( true ); wxListItem column0; wxListItem column1; @@ -87,7 +88,7 @@ DIALOG_DESIGN_RULES::DIALOG_DESIGN_RULES( WinEDA_PcbFrame* parent ) : InitDialogRules(); - SetAutoLayout( true ); + Layout(); GetSizer()->Fit( this ); GetSizer()->SetSizeHints( this ); } @@ -161,11 +162,37 @@ void DIALOG_DESIGN_RULES::InitDialogRules() } InitializeRulesSelectionBoxes(); + InitGlobalRules(); PrintCurrentSettings( ); } -// Sort comparison function +/*******************************************/ +void DIALOG_DESIGN_RULES::InitGlobalRules() +/*******************************************/ +{ + AddUnitSymbol( *m_ViaMinTitle ); + AddUnitSymbol( *m_ViaMinDrillTitle ); + AddUnitSymbol( *m_MicroViaMinSizeTitle ); + AddUnitSymbol( *m_MicroViaMinDrillTitle ); + AddUnitSymbol( *m_TrackMinWidthTitle ); + + int Internal_Unit = m_Parent->m_InternalUnits; + PutValueInLocalUnits( *m_SetViasMinSizeCtrl, g_DesignSettings.m_ViasMinSize, Internal_Unit ); + PutValueInLocalUnits( *m_SetViasMinDrillCtrl, g_DesignSettings.m_ViasMinDrill, Internal_Unit ); + + if( g_DesignSettings.m_CurrentViaType != VIA_THROUGH ) + m_OptViaType->SetSelection( 1 ); + + m_AllowMicroViaCtrl->SetSelection( g_DesignSettings.m_MicroViasAllowed ? 1 : 0); + PutValueInLocalUnits( *m_SetMicroViasMinSizeCtrl, g_DesignSettings.m_MicroViasMinSize, Internal_Unit ); + PutValueInLocalUnits( *m_SetMicroViasMinDrillCtrl, g_DesignSettings.m_MicroViasMinDrill, Internal_Unit ); + + PutValueInLocalUnits( *m_SetTrackMinWidthCtrl, g_DesignSettings.m_TrackMinWidth, Internal_Unit ); +} + + +// Sort comparison function (helper for makePointers() ) static bool sortByClassThenName( NETCUP* a, NETCUP* b ) { // return a < b @@ -404,6 +431,35 @@ void DIALOG_DESIGN_RULES::CopyRulesListToBoard() m_Pcb->SynchronizeNetsAndNetClasses(); } +/*************************************************/ +bool DIALOG_DESIGN_RULES::CopyGlobalRulesToBoard() +/*************************************************/ +{ + g_DesignSettings.m_CurrentViaType = VIA_THROUGH; + if( m_OptViaType->GetSelection() > 0 ) + g_DesignSettings.m_CurrentViaType = VIA_BLIND_BURIED; + + // Update vias minimum values for DRC + g_DesignSettings.m_ViasMinSize = + ReturnValueFromTextCtrl( *m_SetViasMinSizeCtrl, m_Parent->m_InternalUnits ); + g_DesignSettings.m_ViasMinDrill = + ReturnValueFromTextCtrl( *m_SetViasMinDrillCtrl, m_Parent->m_InternalUnits ); + + g_DesignSettings.m_MicroViasAllowed = m_AllowMicroViaCtrl->GetSelection() == 1; + + // Update microvias minimum values for DRC + g_DesignSettings.m_MicroViasMinSize = + ReturnValueFromTextCtrl( *m_SetMicroViasMinSizeCtrl, m_Parent->m_InternalUnits ); + g_DesignSettings.m_MicroViasMinDrill = + ReturnValueFromTextCtrl( *m_SetMicroViasMinDrillCtrl, m_Parent->m_InternalUnits ); + + // Update tracks minimum values for DRC + g_DesignSettings.m_TrackMinWidth = + ReturnValueFromTextCtrl( *m_SetTrackMinWidthCtrl, m_Parent->m_InternalUnits ); + + return true; +} + /*****************************************************************/ void DIALOG_DESIGN_RULES::OnCancelButtonClick( wxCommandEvent& event ) @@ -424,8 +480,11 @@ void DIALOG_DESIGN_RULES::OnOkButtonClick( wxCommandEvent& event ) } CopyRulesListToBoard(); + CopyGlobalRulesToBoard(); EndModal( wxID_OK ); + + m_Parent->AuxiliaryToolBar_Update_UI(); } @@ -458,19 +517,19 @@ void DIALOG_DESIGN_RULES::OnAddNetclassClick( wxCommandEvent& event ) m_grid->GetNumberRows() - 1, class_name ); - // Copy values of the previous class: + // Copy values of the default class: int irow = m_grid->GetNumberRows() - 1; for( int icol = 0; icol < m_grid->GetNumberCols(); icol++ ) { wxString value; - value = m_grid->GetCellValue( irow - 1, icol ); + value = m_grid->GetCellValue( 0, icol ); m_grid->SetCellValue( irow, icol, value ); } InitializeRulesSelectionBoxes(); } -// Sort function for wxArrayInt. Itelms (ints) are sorted by decreasing value +// Sort function for wxArrayInt. Items (ints) are sorted by decreasing value // used in DIALOG_DESIGN_RULES::OnRemoveNetclassClick int sort_int(int *first, int *second) { @@ -683,12 +742,17 @@ bool DIALOG_DESIGN_RULES::TestDataValidity() wxString msg; + int minViaDrill = ReturnValueFromTextCtrl( *m_SetViasMinDrillCtrl, m_Parent->m_InternalUnits ); + int minUViaDrill = ReturnValueFromTextCtrl( *m_SetMicroViasMinDrillCtrl, m_Parent->m_InternalUnits ); + int minTrackWidth = ReturnValueFromTextCtrl( *m_SetTrackMinWidthCtrl, m_Parent->m_InternalUnits ); + + for( int row = 0; row < m_grid->GetNumberRows(); row++ ) { int tracksize = ReturnValueFromString( g_UnitMetric, m_grid->GetCellValue( row, GRID_TRACKSIZE ), m_Parent->m_InternalUnits ); - if( tracksize < g_DesignSettings.m_TrackMinWidth ) + if( tracksize < minTrackWidth ) { result = false; msg.Printf( _( "%s: Track Size < Min Track Size
" ), @@ -714,7 +778,7 @@ bool DIALOG_DESIGN_RULES::TestDataValidity() int viadrill = ReturnValueFromString( g_UnitMetric, m_grid->GetCellValue( row, GRID_VIADRILL ), m_Parent->m_InternalUnits ); - if( viadrill && viadrill >= viadia ) + if( viadrill >= viadia ) { result = false; msg.Printf( _( "%s: Via DrillVia Dia
" ), @@ -723,6 +787,15 @@ bool DIALOG_DESIGN_RULES::TestDataValidity() m_MessagesList->AppendToPage( msg ); } + if( viadrill < minViaDrill ) + { + result = false; + msg.Printf( _( "%s: Via Drill < Min Via Drill
" ), + GetChars( m_grid->GetRowLabelValue(row)) ); + + m_MessagesList->AppendToPage( msg ); + } + // Test Micro vias int muviadia = ReturnValueFromString( g_UnitMetric, m_grid->GetCellValue( row, GRID_uVIASIZE ), @@ -731,7 +804,7 @@ bool DIALOG_DESIGN_RULES::TestDataValidity() if( muviadia < g_DesignSettings.m_MicroViasMinSize ) { result = false; - msg.Printf( _( "%s: MicroVia Diameter < Minimun MicroVia Diameter
" ), + msg.Printf( _( "%s: MicroVia Diameter < MicroVia Min Diameter
" ), GetChars( m_grid->GetRowLabelValue(row)) ); m_MessagesList->AppendToPage( msg ); @@ -740,7 +813,7 @@ bool DIALOG_DESIGN_RULES::TestDataValidity() int muviadrill = ReturnValueFromString( g_UnitMetric, m_grid->GetCellValue( row, GRID_uVIADRILL ), m_Parent->m_InternalUnits ); - if( muviadrill && muviadrill >= muviadia ) + if( muviadrill >= muviadia ) { result = false; msg.Printf( _( "%s: MicroVia DrillMicroVia Dia
" ), @@ -748,6 +821,15 @@ bool DIALOG_DESIGN_RULES::TestDataValidity() m_MessagesList->AppendToPage( msg ); } + + if( muviadrill < minUViaDrill ) + { + result = false; + msg.Printf( _( "%s: MicroVia DrillMicroVia Min Drill
" ), + GetChars( m_grid->GetRowLabelValue(row)) ); + + m_MessagesList->AppendToPage( msg ); + } } return result; diff --git a/pcbnew/dialog_design_rules.h b/pcbnew/dialog_design_rules.h index 227734f06d..7c32905929 100644 --- a/pcbnew/dialog_design_rules.h +++ b/pcbnew/dialog_design_rules.h @@ -58,9 +58,11 @@ private: void OnRightSelectAllButton( wxCommandEvent& event ); bool TestDataValidity( ); void InitDialogRules(); + void InitGlobalRules(); void InitRulesList(); void InitializeRulesSelectionBoxes(); void CopyRulesListToBoard(); + bool CopyGlobalRulesToBoard(); void SetRoutableLayerStatus(); void FillListBoxWithNetNames( wxListCtrl* aListCtrl, const wxString& aNetClass ); void PrintCurrentSettings( ); diff --git a/pcbnew/dialog_design_rules_base.cpp b/pcbnew/dialog_design_rules_base.cpp index 315c6c58f2..6ea3759646 100644 --- a/pcbnew/dialog_design_rules_base.cpp +++ b/pcbnew/dialog_design_rules_base.cpp @@ -16,10 +16,15 @@ DIALOG_DESIGN_RULES_BASE::DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID wxBoxSizer* bMainSizer; bMainSizer = new wxBoxSizer( wxVERTICAL ); - wxStaticBoxSizer* sbSizer1; - sbSizer1 = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Net Classes:") ), wxVERTICAL ); + m_DRnotebook = new wxNotebook( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxNB_LEFT ); + m_panelNetClassesEditor = new wxPanel( m_DRnotebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER|wxTAB_TRAVERSAL ); + wxBoxSizer* bpanelNetClassesSizer; + bpanelNetClassesSizer = new wxBoxSizer( wxVERTICAL ); - m_grid = new wxGrid( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL ); + wxStaticBoxSizer* sbSizer1; + sbSizer1 = new wxStaticBoxSizer( new wxStaticBox( m_panelNetClassesEditor, wxID_ANY, _("Net Classes:") ), wxVERTICAL ); + + m_grid = new wxGrid( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL ); // Grid m_grid->CreateGrid( 1, 6 ); @@ -64,56 +69,64 @@ DIALOG_DESIGN_RULES_BASE::DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID wxBoxSizer* buttonBoxSizer; buttonBoxSizer = new wxBoxSizer( wxHORIZONTAL ); - m_addButton = new wxButton( this, wxID_ADD_NETCLASS, _("Add"), wxDefaultPosition, wxDefaultSize, 0 ); + m_addButton = new wxButton( m_panelNetClassesEditor, wxID_ADD_NETCLASS, _("Add"), wxDefaultPosition, wxDefaultSize, 0 ); m_addButton->SetToolTip( _("Add another Net Class") ); buttonBoxSizer->Add( m_addButton, 0, wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT, 5 ); - m_removeButton = new wxButton( this, wxID_REMOVE_NETCLASS, _("Remove"), wxDefaultPosition, wxDefaultSize, 0 ); - m_removeButton->SetToolTip( _("Remove the currently select Net Class") ); + m_removeButton = new wxButton( m_panelNetClassesEditor, wxID_REMOVE_NETCLASS, _("Remove"), wxDefaultPosition, wxDefaultSize, 0 ); + m_removeButton->SetToolTip( _("Remove the currently select Net Class\nThe default Net Class cannot be removed") ); buttonBoxSizer->Add( m_removeButton, 0, wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT, 5 ); - m_moveUpButton = new wxButton( this, wxID_ANY, _("Move Up"), wxDefaultPosition, wxDefaultSize, 0 ); + m_moveUpButton = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("Move Up"), wxDefaultPosition, wxDefaultSize, 0 ); m_moveUpButton->SetToolTip( _("Move the currently selected Net Class up one row") ); buttonBoxSizer->Add( m_moveUpButton, 0, wxRIGHT|wxLEFT, 5 ); sbSizer1->Add( buttonBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL, 5 ); - bMainSizer->Add( sbSizer1, 1, wxEXPAND|wxALL, 5 ); + bpanelNetClassesSizer->Add( sbSizer1, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 ); wxStaticBoxSizer* sbSizer4; - sbSizer4 = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Membership:") ), wxHORIZONTAL ); + sbSizer4 = new wxStaticBoxSizer( new wxStaticBox( m_panelNetClassesEditor, wxID_ANY, _("Membership:") ), wxHORIZONTAL ); wxBoxSizer* leftNetSelectBoxSizer; leftNetSelectBoxSizer = new wxBoxSizer( wxVERTICAL ); wxArrayString m_leftClassChoiceChoices; - m_leftClassChoice = new wxChoice( this, ID_LEFT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_leftClassChoiceChoices, 0 ); + m_leftClassChoice = new wxChoice( m_panelNetClassesEditor, ID_LEFT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_leftClassChoiceChoices, 0 ); m_leftClassChoice->SetSelection( 0 ); - leftNetSelectBoxSizer->Add( m_leftClassChoice, 0, wxEXPAND|wxTOP|wxBOTTOM, 5 ); + leftNetSelectBoxSizer->Add( m_leftClassChoice, 0, wxEXPAND, 5 ); - m_leftListCtrl = new wxListCtrl( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VRULES|wxSUNKEN_BORDER ); + m_leftListCtrl = new wxListCtrl( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VRULES|wxSUNKEN_BORDER ); m_leftListCtrl->SetMinSize( wxSize( 220,300 ) ); - leftNetSelectBoxSizer->Add( m_leftListCtrl, 1, wxEXPAND|wxTOP|wxBOTTOM, 5 ); + leftNetSelectBoxSizer->Add( m_leftListCtrl, 1, wxEXPAND|wxTOP, 5 ); sbSizer4->Add( leftNetSelectBoxSizer, 1, wxALL|wxEXPAND, 5 ); wxBoxSizer* bmiddleSizerNetSelect; bmiddleSizerNetSelect = new wxBoxSizer( wxVERTICAL ); - m_buttonRightToLeft = new wxButton( this, ID_LEFT_TO_RIGHT_COPY, _("<<<"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonRightToLeft = new wxButton( m_panelNetClassesEditor, ID_LEFT_TO_RIGHT_COPY, _("<<<"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonRightToLeft->SetToolTip( _("Move the selected nets in the right list to the left list") ); + bmiddleSizerNetSelect->Add( m_buttonRightToLeft, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 ); - m_buttonLeftToRight = new wxButton( this, ID_RIGHT_TO_LEFT_COPY, _(">>>"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonLeftToRight = new wxButton( m_panelNetClassesEditor, ID_RIGHT_TO_LEFT_COPY, _(">>>"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonLeftToRight->SetToolTip( _("Move the selected nets in the left list to the right list") ); + bmiddleSizerNetSelect->Add( m_buttonLeftToRight, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 ); - m_buttonLeftSelAll = new wxButton( this, wxID_ANY, _("<< Select All"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonLeftSelAll = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("<< Select All"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonLeftSelAll->SetToolTip( _("Select all nets in the left list") ); + bmiddleSizerNetSelect->Add( m_buttonLeftSelAll, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 ); - m_buttonRightSelAll = new wxButton( this, wxID_ANY, _("Select All >>"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonRightSelAll = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("Select All >>"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonRightSelAll->SetToolTip( _("Select all nets in the right list") ); + bmiddleSizerNetSelect->Add( m_buttonRightSelAll, 0, wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL, 5 ); sbSizer4->Add( bmiddleSizerNetSelect, 0, wxALIGN_CENTER_VERTICAL, 5 ); @@ -122,18 +135,133 @@ DIALOG_DESIGN_RULES_BASE::DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID rghtNetSelectBoxSizer = new wxBoxSizer( wxVERTICAL ); wxArrayString m_rightClassChoiceChoices; - m_rightClassChoice = new wxChoice( this, ID_RIGHT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_rightClassChoiceChoices, 0 ); + m_rightClassChoice = new wxChoice( m_panelNetClassesEditor, ID_RIGHT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_rightClassChoiceChoices, 0 ); m_rightClassChoice->SetSelection( 0 ); - rghtNetSelectBoxSizer->Add( m_rightClassChoice, 0, wxEXPAND|wxTOP|wxBOTTOM, 5 ); + rghtNetSelectBoxSizer->Add( m_rightClassChoice, 0, wxEXPAND, 5 ); - m_rightListCtrl = new wxListCtrl( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VRULES|wxSUNKEN_BORDER ); + m_rightListCtrl = new wxListCtrl( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VRULES|wxSUNKEN_BORDER ); m_rightListCtrl->SetMinSize( wxSize( 220,-1 ) ); - rghtNetSelectBoxSizer->Add( m_rightListCtrl, 1, wxEXPAND|wxTOP|wxBOTTOM, 5 ); + rghtNetSelectBoxSizer->Add( m_rightListCtrl, 1, wxEXPAND|wxTOP, 5 ); sbSizer4->Add( rghtNetSelectBoxSizer, 1, wxALL|wxEXPAND, 5 ); - bMainSizer->Add( sbSizer4, 2, wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT, 5 ); + bpanelNetClassesSizer->Add( sbSizer4, 2, wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT, 5 ); + + m_panelNetClassesEditor->SetSizer( bpanelNetClassesSizer ); + m_panelNetClassesEditor->Layout(); + bpanelNetClassesSizer->Fit( m_panelNetClassesEditor ); + m_DRnotebook->AddPage( m_panelNetClassesEditor, _("Net Classes Editor"), true ); + m_panelGolbalDesignRules = new wxPanel( m_DRnotebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER|wxTAB_TRAVERSAL ); + wxBoxSizer* bpanelGlobRulesSizer; + bpanelGlobRulesSizer = new wxBoxSizer( wxVERTICAL ); + + wxBoxSizer* bDesignRulesUpperSizer; + bDesignRulesUpperSizer = new wxBoxSizer( wxHORIZONTAL ); + + wxStaticBoxSizer* sbViasOptionSizer; + sbViasOptionSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Vias Options:") ), wxVERTICAL ); + + wxString m_OptViaTypeChoices[] = { _("Through via"), _("Blind or buried via") }; + int m_OptViaTypeNChoices = sizeof( m_OptViaTypeChoices ) / sizeof( wxString ); + m_OptViaType = new wxRadioBox( m_panelGolbalDesignRules, wxID_ANY, _("Default Via Type"), wxDefaultPosition, wxDefaultSize, m_OptViaTypeNChoices, m_OptViaTypeChoices, 1, wxRA_SPECIFY_COLS ); + m_OptViaType->SetSelection( 0 ); + m_OptViaType->SetToolTip( _("Select the current via type.\nTrough via is the usual selection") ); + + sbViasOptionSizer->Add( m_OptViaType, 0, wxALL|wxEXPAND, 5 ); + + wxFlexGridSizer* fgViasMinValuesSizer; + fgViasMinValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 ); + fgViasMinValuesSizer->AddGrowableCol( 1 ); + fgViasMinValuesSizer->SetFlexibleDirection( wxBOTH ); + fgViasMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED ); + + m_ViaMinTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Via Min Diameter"), wxDefaultPosition, wxDefaultSize, 0 ); + m_ViaMinTitle->Wrap( -1 ); + fgViasMinValuesSizer->Add( m_ViaMinTitle, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT, 5 ); + + m_SetViasMinSizeCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + fgViasMinValuesSizer->Add( m_SetViasMinSizeCtrl, 0, wxEXPAND|wxALL, 5 ); + + m_ViaMinDrillTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Via Min Drill"), wxDefaultPosition, wxDefaultSize, 0 ); + m_ViaMinDrillTitle->Wrap( -1 ); + fgViasMinValuesSizer->Add( m_ViaMinDrillTitle, 0, wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 ); + + m_SetViasMinDrillCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + fgViasMinValuesSizer->Add( m_SetViasMinDrillCtrl, 0, wxALL|wxEXPAND, 5 ); + + sbViasOptionSizer->Add( fgViasMinValuesSizer, 0, wxEXPAND, 5 ); + + bDesignRulesUpperSizer->Add( sbViasOptionSizer, 1, wxALIGN_CENTER_VERTICAL, 5 ); + + wxStaticBoxSizer* sbuViasSizer; + sbuViasSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Micro Vias Options:") ), wxVERTICAL ); + + wxString m_AllowMicroViaCtrlChoices[] = { _("Do not allow micro vias"), _("Allow micro vias") }; + int m_AllowMicroViaCtrlNChoices = sizeof( m_AllowMicroViaCtrlChoices ) / sizeof( wxString ); + m_AllowMicroViaCtrl = new wxRadioBox( m_panelGolbalDesignRules, wxID_ANY, _("Micro Vias:"), wxDefaultPosition, wxDefaultSize, m_AllowMicroViaCtrlNChoices, m_AllowMicroViaCtrlChoices, 1, wxRA_SPECIFY_COLS ); + m_AllowMicroViaCtrl->SetSelection( 0 ); + m_AllowMicroViaCtrl->SetToolTip( _("Allows or do not allow use of micro vias\nThey are very small vias only from an external copper layer to its near neightbour") ); + + sbuViasSizer->Add( m_AllowMicroViaCtrl, 0, wxALL|wxEXPAND, 5 ); + + wxFlexGridSizer* fgMinMicroviasValuesSizer; + fgMinMicroviasValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 ); + fgMinMicroviasValuesSizer->AddGrowableCol( 1 ); + fgMinMicroviasValuesSizer->SetFlexibleDirection( wxBOTH ); + fgMinMicroviasValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED ); + + m_MicroViaMinSizeTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("MicroVia Min Diameter"), wxDefaultPosition, wxDefaultSize, 0 ); + m_MicroViaMinSizeTitle->Wrap( -1 ); + fgMinMicroviasValuesSizer->Add( m_MicroViaMinSizeTitle, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT, 5 ); + + m_SetMicroViasMinSizeCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + fgMinMicroviasValuesSizer->Add( m_SetMicroViasMinSizeCtrl, 0, wxALL|wxEXPAND, 5 ); + + m_MicroViaMinDrillTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("MicroVia Min Drill"), wxDefaultPosition, wxDefaultSize, 0 ); + m_MicroViaMinDrillTitle->Wrap( -1 ); + fgMinMicroviasValuesSizer->Add( m_MicroViaMinDrillTitle, 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 ); + + m_SetMicroViasMinDrillCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + fgMinMicroviasValuesSizer->Add( m_SetMicroViasMinDrillCtrl, 0, wxALL|wxEXPAND, 5 ); + + sbuViasSizer->Add( fgMinMicroviasValuesSizer, 1, wxEXPAND, 5 ); + + bDesignRulesUpperSizer->Add( sbuViasSizer, 1, wxALIGN_CENTER_VERTICAL, 5 ); + + wxStaticBoxSizer* sbMinSizesSizer; + sbMinSizesSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Minimal Values Allowed:") ), wxVERTICAL ); + + wxFlexGridSizer* fgMinValuesSizer; + fgMinValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 ); + fgMinValuesSizer->AddGrowableCol( 1 ); + fgMinValuesSizer->SetFlexibleDirection( wxBOTH ); + fgMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED ); + + m_TrackMinWidthTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Track Min Width"), wxDefaultPosition, wxDefaultSize, 0 ); + m_TrackMinWidthTitle->Wrap( -1 ); + fgMinValuesSizer->Add( m_TrackMinWidthTitle, 0, wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 ); + + m_SetTrackMinWidthCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + fgMinValuesSizer->Add( m_SetTrackMinWidthCtrl, 0, wxALL, 5 ); + + sbMinSizesSizer->Add( fgMinValuesSizer, 0, 0, 5 ); + + bDesignRulesUpperSizer->Add( sbMinSizesSizer, 0, wxEXPAND, 5 ); + + bpanelGlobRulesSizer->Add( bDesignRulesUpperSizer, 0, wxEXPAND, 5 ); + + wxBoxSizer* bDesignRulesLowerSizer; + bDesignRulesLowerSizer = new wxBoxSizer( wxHORIZONTAL ); + + bpanelGlobRulesSizer->Add( bDesignRulesLowerSizer, 1, wxEXPAND, 5 ); + + m_panelGolbalDesignRules->SetSizer( bpanelGlobRulesSizer ); + m_panelGolbalDesignRules->Layout(); + bpanelGlobRulesSizer->Fit( m_panelGolbalDesignRules ); + m_DRnotebook->AddPage( m_panelGolbalDesignRules, _("Global Design Rules"), false ); + + bMainSizer->Add( m_DRnotebook, 1, wxEXPAND | wxALL, 5 ); wxStaticBoxSizer* sbSizer2; sbSizer2 = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Messages:") ), wxHORIZONTAL ); diff --git a/pcbnew/dialog_design_rules_base.fbp b/pcbnew/dialog_design_rules_base.fbp index c488581d17..f4343483fa 100644 --- a/pcbnew/dialog_design_rules_base.fbp +++ b/pcbnew/dialog_design_rules_base.fbp @@ -32,7 +32,7 @@ 600,520 DIALOG_DESIGN_RULES_BASE - 750,692 + 792,692 wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER Design Rules Editor @@ -77,105 +77,80 @@ none 5 - wxEXPAND|wxALL + wxEXPAND | wxALL 1 - + + + + + 1 + + + 0 wxID_ANY - Net Classes: + - sbSizer1 - wxVERTICAL - none + m_DRnotebook + protected + + + wxNB_LEFT + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - 5 - wxEXPAND - 1 - - 0 - 1 + + + Net Classes Editor + 1 + - - - wxALIGN_LEFT - - wxALIGN_TOP - wxALIGN_CENTRE - 40 - "Clearance" "Track Width" "Via Dia" "Via Drill" "uVia Dia" "uVia Drill" - wxALIGN_CENTRE - 6 - 100,100,100,100,100 - 0 - 1 - 0 - 1 - 1 1 - - 1 0 wxID_ANY - - - - 0 - 0 - -1,150 - m_grid + + m_panelNetClassesEditor protected - wxALIGN_LEFT - 120 - "Default" - wxALIGN_CENTRE - - 1 - Net Class parameters + - wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL + wxSUNKEN_BORDER|wxTAB_TRAVERSAL - - - - - - - - - - - - - - - - - - - - - - - - - - OnNetClassesNameLeftClick - - OnNetClassesNameRightClick - - - - @@ -196,666 +171,1607 @@ - - - - 5 - wxALIGN_CENTER_HORIZONTAL - 0 - - - buttonBoxSizer - wxHORIZONTAL - none - - 5 - wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT - 0 - - - - 0 - 1 - - - 0 - wxID_ADD_NETCLASS - Add - - - m_addButton - protected - - - - - Add another Net Class - - - - OnAddNetclassClick - - - - - - - - - - - - - - - - - - - - - - - + + + bpanelNetClassesSizer + wxVERTICAL + none + + 5 + wxEXPAND|wxRIGHT|wxLEFT + 1 + + wxID_ANY + Net Classes: + + sbSizer1 + wxVERTICAL + none + + + 5 + wxEXPAND + 1 + + 0 + 1 + + + + wxALIGN_LEFT + + wxALIGN_TOP + wxALIGN_CENTRE + 40 + "Clearance" "Track Width" "Via Dia" "Via Drill" "uVia Dia" "uVia Drill" + wxALIGN_CENTRE + 6 + 100,100,100,100,100 + + 0 + 1 + 0 + 1 + 1 + 1 + + + + 1 + 0 + wxID_ANY + + + + 0 + 0 + + -1,150 + m_grid + protected + + wxALIGN_LEFT + 120 + "Default" + wxALIGN_CENTRE + + 1 + + + Net Class parameters + + + wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL + + + + + + + + + + + + + + + + + + + + + + + + + + + + + OnNetClassesNameLeftClick + + OnNetClassesNameRightClick + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_HORIZONTAL + 0 + + + buttonBoxSizer + wxHORIZONTAL + none + + 5 + wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT + 0 + + + + 0 + 1 + + + 0 + wxID_ADD_NETCLASS + Add + + + m_addButton + protected + + + + + Add another Net Class + + + + OnAddNetclassClick + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT + 0 + + + + 0 + 1 + + + 0 + wxID_REMOVE_NETCLASS + Remove + + + m_removeButton + protected + + + + + Remove the currently select Net Class The default Net Class cannot be removed + + + + OnRemoveNetclassClick + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxRIGHT|wxLEFT + 0 + + + + 0 + 1 + + + 0 + wxID_ANY + Move Up + + + m_moveUpButton + protected + + + + + Move the currently selected Net Class up one row + + + + OnMoveUpSelectedNetClass + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - 5 - wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT - 0 - - - - 0 - 1 - - - 0 - wxID_REMOVE_NETCLASS - Remove - - - m_removeButton - protected - - - - - Remove the currently select Net Class - - - - OnRemoveNetclassClick - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxRIGHT|wxLEFT - 0 - - - - 0 - 1 - - - 0 - wxID_ANY - Move Up - - - m_moveUpButton - protected - - - - - Move the currently selected Net Class up one row - - - - OnMoveUpSelectedNetClass - - - - - - - - - - - - - - - - - - - - - - - + + 5 + wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT + 2 + + wxID_ANY + Membership: + + sbSizer4 + wxHORIZONTAL + none + + + 5 + wxALL|wxEXPAND + 1 + + + leftNetSelectBoxSizer + wxVERTICAL + none + + 5 + wxEXPAND + 0 + + + + + 1 + + + 0 + ID_LEFT_CHOICE_CLICK + + + m_leftClassChoice + protected + + 0 + + + + + + + + OnLeftCBSelection + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND|wxTOP + 1 + + + + 1 + + + 0 + wxID_ANY + + 220,300 + m_leftListCtrl + protected + + + wxLC_HRULES|wxLC_REPORT|wxLC_VRULES + + + + + wxSUNKEN_BORDER + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_VERTICAL + 0 + + + bmiddleSizerNetSelect + wxVERTICAL + none + + 5 + wxALL|wxALIGN_CENTER_HORIZONTAL + 0 + + + + 0 + 1 + + + 0 + ID_LEFT_TO_RIGHT_COPY + <<< + + + m_buttonRightToLeft + protected + + + + + Move the selected nets in the right list to the left list + + + + OnRightToLeftCopyButton + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxALIGN_CENTER_HORIZONTAL + 0 + + + + 0 + 1 + + + 0 + ID_RIGHT_TO_LEFT_COPY + >>> + + + m_buttonLeftToRight + protected + + + + + Move the selected nets in the left list to the right list + + + + OnLeftToRightCopyButton + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxALIGN_CENTER_HORIZONTAL + 0 + + + + 0 + 1 + + + 0 + wxID_ANY + << Select All + + + m_buttonLeftSelAll + protected + + + + + Select all nets in the left list + + + + OnLeftSelectAllButton + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL + 0 + + + + 0 + 1 + + + 0 + wxID_ANY + Select All >> + + + m_buttonRightSelAll + protected + + + + + Select all nets in the right list + + + + OnRightSelectAllButton + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxEXPAND + 1 + + + rghtNetSelectBoxSizer + wxVERTICAL + none + + 5 + wxEXPAND + 0 + + + + + 1 + + + 0 + ID_RIGHT_CHOICE_CLICK + + + m_rightClassChoice + protected + + 0 + + + + + + + + OnRightCBSelection + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND|wxTOP + 1 + + + + 1 + + + 0 + wxID_ANY + + 220,-1 + m_rightListCtrl + protected + + + wxLC_HRULES|wxLC_REPORT|wxLC_VRULES + + + + + wxSUNKEN_BORDER + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - 5 - wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT - 2 - - wxID_ANY - Membership: - - sbSizer4 - wxHORIZONTAL - none - - - 5 - wxALL|wxEXPAND - 1 - + + + Global Design Rules + 0 + + + + 1 + + + 0 + wxID_ANY + - leftNetSelectBoxSizer - wxVERTICAL - none - - 5 - wxEXPAND|wxTOP|wxBOTTOM - 0 - - - - - 1 - - - 0 - ID_LEFT_CHOICE_CLICK - - - m_leftClassChoice - protected - - 0 - - - - - - - - OnLeftCBSelection - - - - - - - - - - - - - - - - - - - - - - + m_panelGolbalDesignRules + protected + + + + + + + wxSUNKEN_BORDER|wxTAB_TRAVERSAL + + + + + + + + + + + + + + + + + + + + + + + + + + bpanelGlobRulesSizer + wxVERTICAL + none + + 5 + wxEXPAND + 0 + + + bDesignRulesUpperSizer + wxHORIZONTAL + none + + 5 + wxALIGN_CENTER_VERTICAL + 1 + + wxID_ANY + Vias Options: + + sbViasOptionSizer + wxVERTICAL + none + + + 5 + wxALL|wxEXPAND + 0 + + + "Through via" "Blind or buried via" + + 1 + + + 0 + wxID_ANY + Default Via Type + 1 + + + m_OptViaType + protected + + 0 + + wxRA_SPECIFY_COLS + + Select the current via type. Trough via is the usual selection + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND + 0 + + 2 + wxBOTH + 1 + + 0 + + fgViasMinValuesSizer + wxFLEX_GROWMODE_SPECIFIED + none + 1 + 0 + + 5 + wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + Via Min Diameter + + + m_ViaMinTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND|wxALL + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetViasMinSizeCtrl + protected + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT + 0 + + + + 1 + + + 0 + wxID_ANY + Via Min Drill + + + m_ViaMinDrillTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxEXPAND + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetViasMinDrillCtrl + protected + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_VERTICAL + 1 + + wxID_ANY + Micro Vias Options: + + sbuViasSizer + wxVERTICAL + none + + + 5 + wxALL|wxEXPAND + 0 + + + "Do not allow micro vias" "Allow micro vias" + + 1 + + + 0 + wxID_ANY + Micro Vias: + 1 + + + m_AllowMicroViaCtrl + protected + + 0 + + wxRA_SPECIFY_COLS + + Allows or do not allow use of micro vias They are very small vias only from an external copper layer to its near neightbour + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND + 1 + + 2 + wxBOTH + 1 + + 0 + + fgMinMicroviasValuesSizer + wxFLEX_GROWMODE_SPECIFIED + none + 1 + 0 + + 5 + wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + MicroVia Min Diameter + + + m_MicroViaMinSizeTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxEXPAND + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetMicroViasMinSizeCtrl + protected + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + MicroVia Min Drill + + + m_MicroViaMinDrillTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxEXPAND + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetMicroViasMinDrillCtrl + protected + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND + 0 + + wxID_ANY + Minimal Values Allowed: + + sbMinSizesSizer + wxVERTICAL + none + + + 5 + + 0 + + 2 + wxBOTH + 1 + + 0 + + fgMinValuesSizer + wxFLEX_GROWMODE_SPECIFIED + none + 1 + 0 + + 5 + wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + Track Min Width + + + m_TrackMinWidthTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetTrackMinWidthCtrl + protected + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - 5 - wxEXPAND|wxTOP|wxBOTTOM - 1 - - - - 1 - - - 0 - wxID_ANY - - 220,300 - m_leftListCtrl - protected - - - wxLC_HRULES|wxLC_REPORT|wxLC_VRULES - - - - - wxSUNKEN_BORDER - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_CENTER_VERTICAL - 0 - - - bmiddleSizerNetSelect - wxVERTICAL - none - - 5 - wxALL|wxALIGN_CENTER_HORIZONTAL - 0 - - - - 0 - 1 - - - 0 - ID_LEFT_TO_RIGHT_COPY - <<< - - - m_buttonRightToLeft - protected - - - - - - - - - OnRightToLeftCopyButton - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxALIGN_CENTER_HORIZONTAL - 0 - - - - 0 - 1 - - - 0 - ID_RIGHT_TO_LEFT_COPY - >>> - - - m_buttonLeftToRight - protected - - - - - - - - - OnLeftToRightCopyButton - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxALIGN_CENTER_HORIZONTAL - 0 - - - - 0 - 1 - - - 0 - wxID_ANY - << Select All - - - m_buttonLeftSelAll - protected - - - - - - - - - OnLeftSelectAllButton - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL - 0 - - - - 0 - 1 - - - 0 - wxID_ANY - Select All >> - - - m_buttonRightSelAll - protected - - - - - - - - - OnRightSelectAllButton - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxEXPAND - 1 - - - rghtNetSelectBoxSizer - wxVERTICAL - none - - 5 - wxEXPAND|wxTOP|wxBOTTOM - 0 - - - - - 1 - - - 0 - ID_RIGHT_CHOICE_CLICK - - - m_rightClassChoice - protected - - 0 - - - - - - - - OnRightCBSelection - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxEXPAND|wxTOP|wxBOTTOM - 1 - - - - 1 - - - 0 - wxID_ANY - - 220,-1 - m_rightListCtrl - protected - - - wxLC_HRULES|wxLC_REPORT|wxLC_VRULES - - - - - wxSUNKEN_BORDER - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + 5 + wxEXPAND + 1 + + + bDesignRulesLowerSizer + wxHORIZONTAL + none + diff --git a/pcbnew/dialog_design_rules_base.h b/pcbnew/dialog_design_rules_base.h index 448ead5a3a..190fd4f154 100644 --- a/pcbnew/dialog_design_rules_base.h +++ b/pcbnew/dialog_design_rules_base.h @@ -21,6 +21,14 @@ #include #include #include +#include +#include +#include +#include +#include +#include +#include +#include #include #include @@ -44,6 +52,8 @@ class DIALOG_DESIGN_RULES_BASE : public wxDialog ID_RIGHT_CHOICE_CLICK, }; + wxNotebook* m_DRnotebook; + wxPanel* m_panelNetClassesEditor; wxGrid* m_grid; wxButton* m_addButton; wxButton* m_removeButton; @@ -56,6 +66,19 @@ class DIALOG_DESIGN_RULES_BASE : public wxDialog wxButton* m_buttonRightSelAll; wxChoice* m_rightClassChoice; wxListCtrl* m_rightListCtrl; + wxPanel* m_panelGolbalDesignRules; + wxRadioBox* m_OptViaType; + wxStaticText* m_ViaMinTitle; + wxTextCtrl* m_SetViasMinSizeCtrl; + wxStaticText* m_ViaMinDrillTitle; + wxTextCtrl* m_SetViasMinDrillCtrl; + wxRadioBox* m_AllowMicroViaCtrl; + wxStaticText* m_MicroViaMinSizeTitle; + wxTextCtrl* m_SetMicroViasMinSizeCtrl; + wxStaticText* m_MicroViaMinDrillTitle; + wxTextCtrl* m_SetMicroViasMinDrillCtrl; + wxStaticText* m_TrackMinWidthTitle; + wxTextCtrl* m_SetTrackMinWidthCtrl; wxHtmlWindow* m_MessagesList; wxStdDialogButtonSizer* m_sdbButtonsSizer; wxButton* m_sdbButtonsSizerOK; @@ -78,7 +101,7 @@ class DIALOG_DESIGN_RULES_BASE : public wxDialog public: - DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Design Rules Editor"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 750,692 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); + DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Design Rules Editor"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 792,692 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); ~DIALOG_DESIGN_RULES_BASE(); }; diff --git a/pcbnew/dialog_drc.cpp b/pcbnew/dialog_drc.cpp index 6a307f0f45..fbf1b33396 100644 --- a/pcbnew/dialog_drc.cpp +++ b/pcbnew/dialog_drc.cpp @@ -22,7 +22,7 @@ DIALOG_DRC_CONTROL::DIALOG_DRC_CONTROL( DRC* aTester, WinEDA_PcbFrame* parent ) m_tester = aTester; m_Parent = parent; - Init(); + InitValues(); if( GetSizer() ) { GetSizer()->SetSizeHints( this ); @@ -30,7 +30,7 @@ DIALOG_DRC_CONTROL::DIALOG_DRC_CONTROL( DRC* aTester, WinEDA_PcbFrame* parent ) } -void DIALOG_DRC_CONTROL::Init() +void DIALOG_DRC_CONTROL::InitValues() { // Connect events and objects m_ClearanceListBox->Connect( ID_CLEARANCE_LIST, wxEVT_LEFT_DCLICK, @@ -46,10 +46,10 @@ void DIALOG_DRC_CONTROL::Init() wxMouseEventHandler( DIALOG_DRC_CONTROL::OnRightUpUnconnected ), NULL, this ); - AddUnitSymbol( *m_ClearenceTitle ); AddUnitSymbol( *m_TrackMinWidthTitle ); AddUnitSymbol( *m_ViaMinTitle ); AddUnitSymbol( *m_MicroViaMinTitle ); + m_SetClearance->SetValue( _("Use netclasses values")); Layout(); // adding the units above expanded Clearance text, now resize. @@ -69,8 +69,6 @@ void DIALOG_DRC_CONTROL::Init() */ void DIALOG_DRC_CONTROL::SetDrcParmeters( ) { - g_DesignSettings.m_TrackClearance = - ReturnValueFromTextCtrl( *m_SetClearance, m_Parent->m_InternalUnits ); g_DesignSettings.m_TrackMinWidth = ReturnValueFromTextCtrl( *m_SetTrackMinWidthCtrl, m_Parent->m_InternalUnits ); g_DesignSettings.m_ViasMinSize = diff --git a/pcbnew/dialog_drc.h b/pcbnew/dialog_drc.h index d39f519285..58250d23a0 100644 --- a/pcbnew/dialog_drc.h +++ b/pcbnew/dialog_drc.h @@ -51,7 +51,7 @@ private: */ void writeReport( FILE* fpOut ); - void Init( ); + void InitValues( ); void SetDrcParmeters( ); diff --git a/pcbnew/dialog_drc_base.cpp b/pcbnew/dialog_drc_base.cpp index ea85d4213a..4a30672b40 100644 --- a/pcbnew/dialog_drc_base.cpp +++ b/pcbnew/dialog_drc_base.cpp @@ -1,218 +1,218 @@ -/////////////////////////////////////////////////////////////////////////// -// C++ code generated with wxFormBuilder (version Sep 9 2009) -// http://www.wxformbuilder.org/ -// -// PLEASE DO "NOT" EDIT THIS FILE! -/////////////////////////////////////////////////////////////////////////// - -#include "dialog_drc.h" - -#include "dialog_drc_base.h" - -/////////////////////////////////////////////////////////////////////////// - -DIALOG_DRC_CONTROL_BASE::DIALOG_DRC_CONTROL_BASE( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style ) : wxDialog( parent, id, title, pos, size, style ) -{ - this->SetSizeHints( wxDefaultSize, wxDefaultSize ); - - wxBoxSizer* m_MainSizer; - m_MainSizer = new wxBoxSizer( wxVERTICAL ); - - wxBoxSizer* m_CommandSizer; - m_CommandSizer = new wxBoxSizer( wxHORIZONTAL ); - - wxStaticBoxSizer* sbSizerOptions; - sbSizerOptions = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Options") ), wxHORIZONTAL ); - - wxBoxSizer* bSizer7; - bSizer7 = new wxBoxSizer( wxVERTICAL ); - - wxFlexGridSizer* fgMinValuesSizer; - fgMinValuesSizer = new wxFlexGridSizer( 2, 4, 0, 0 ); - fgMinValuesSizer->SetFlexibleDirection( wxBOTH ); - fgMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED ); - - m_ClearenceTitle = new wxStaticText( this, wxID_ANY, _("Clearance"), wxDefaultPosition, wxDefaultSize, 0 ); - m_ClearenceTitle->Wrap( -1 ); - fgMinValuesSizer->Add( m_ClearenceTitle, 0, wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 ); - - m_SetClearance = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_SetClearance->SetToolTip( _("In the clearance units, enter the clearance distance") ); - - fgMinValuesSizer->Add( m_SetClearance, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); - - m_ViaMinTitle = new wxStaticText( this, wxID_ANY, _("Via Min Size"), wxDefaultPosition, wxDefaultSize, 0 ); - m_ViaMinTitle->Wrap( -1 ); - fgMinValuesSizer->Add( m_ViaMinTitle, 0, wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 ); - - m_SetViaMinSizeCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_SetViaMinSizeCtrl->SetToolTip( _("In the clearance units, enter the clearance distance") ); - - fgMinValuesSizer->Add( m_SetViaMinSizeCtrl, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); - - m_TrackMinWidthTitle - = new wxStaticText( this, wxID_ANY, _("Track Min Width"), wxDefaultPosition, wxDefaultSize, 0 ); - m_TrackMinWidthTitle - ->Wrap( -1 ); - fgMinValuesSizer->Add( m_TrackMinWidthTitle - , 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 ); - - m_SetTrackMinWidthCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_SetTrackMinWidthCtrl->SetToolTip( _("In the clearance units, enter the clearance distance") ); - - fgMinValuesSizer->Add( m_SetTrackMinWidthCtrl, 0, wxALL, 5 ); - - m_MicroViaMinTitle = new wxStaticText( this, wxID_ANY, _("MicroVia Min Size"), wxDefaultPosition, wxDefaultSize, 0 ); - m_MicroViaMinTitle->Wrap( -1 ); - fgMinValuesSizer->Add( m_MicroViaMinTitle, 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 ); - - m_SetMicroViakMinSizeCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_SetMicroViakMinSizeCtrl->SetToolTip( _("In the clearance units, enter the clearance distance") ); - - fgMinValuesSizer->Add( m_SetMicroViakMinSizeCtrl, 0, wxALL, 5 ); - - bSizer7->Add( fgMinValuesSizer, 1, wxEXPAND, 5 ); - - wxStaticBoxSizer* ReportFileSizer; - ReportFileSizer = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Create Report File") ), wxHORIZONTAL ); - - m_CreateRptCtrl = new wxCheckBox( this, ID_CHECKBOX_RPT_FILE, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_CreateRptCtrl->SetToolTip( _("Enable writing report to this file") ); - - ReportFileSizer->Add( m_CreateRptCtrl, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); - - m_RptFilenameCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_RptFilenameCtrl->SetToolTip( _("Enter the report filename") ); - m_RptFilenameCtrl->SetMinSize( wxSize( 250,-1 ) ); - - ReportFileSizer->Add( m_RptFilenameCtrl, 1, wxALL|wxEXPAND|wxALIGN_CENTER_VERTICAL, 5 ); - - m_BrowseButton = new wxButton( this, ID_BUTTON_BROWSE_RPT_FILE, _("..."), wxDefaultPosition, wxDefaultSize, 0 ); - ReportFileSizer->Add( m_BrowseButton, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); - - bSizer7->Add( ReportFileSizer, 1, wxEXPAND|wxTOP|wxBOTTOM|wxRIGHT, 5 ); - - sbSizerOptions->Add( bSizer7, 1, wxEXPAND, 5 ); - - m_CommandSizer->Add( sbSizerOptions, 0, 0, 5 ); - - wxBoxSizer* bSizerMessages; - bSizerMessages = new wxBoxSizer( wxVERTICAL ); - - m_staticText6 = new wxStaticText( this, wxID_ANY, _("Messages:"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText6->Wrap( -1 ); - bSizerMessages->Add( m_staticText6, 0, wxRIGHT|wxLEFT, 5 ); - - m_Messages = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxTE_MULTILINE|wxTE_READONLY ); - m_Messages->SetMinSize( wxSize( 160,-1 ) ); - - bSizerMessages->Add( m_Messages, 1, wxBOTTOM|wxRIGHT|wxLEFT|wxEXPAND, 5 ); - - m_CommandSizer->Add( bSizerMessages, 1, wxEXPAND, 5 ); - - wxBoxSizer* bSizer11; - bSizer11 = new wxBoxSizer( wxVERTICAL ); - - m_buttonRunDRC = new wxButton( this, ID_STARTDRC, _("Start DRC"), wxDefaultPosition, wxDefaultSize, 0 ); - m_buttonRunDRC->SetDefault(); - m_buttonRunDRC->SetToolTip( _("Start the Design Rule Checker") ); - - bSizer11->Add( m_buttonRunDRC, 0, wxTOP|wxRIGHT|wxLEFT|wxALIGN_CENTER_HORIZONTAL|wxEXPAND, 5 ); - - m_buttonListUnconnected = new wxButton( this, ID_LIST_UNCONNECTED, _("List Unconnected"), wxDefaultPosition, wxDefaultSize, 0 ); - m_buttonListUnconnected->SetToolTip( _("List unconnected pads or tracks") ); - - bSizer11->Add( m_buttonListUnconnected, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT, 5 ); - - m_DeleteAllButton = new wxButton( this, ID_DELETE_ALL, _("Delete All Markers"), wxDefaultPosition, wxDefaultSize, 0 ); - m_DeleteAllButton->SetToolTip( _("Delete every marker") ); - - bSizer11->Add( m_DeleteAllButton, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT, 5 ); - - m_DeleteCurrentMarkerButton = new wxButton( this, wxID_ANY, _("Delete Current Marker"), wxDefaultPosition, wxDefaultSize, 0 ); - m_DeleteCurrentMarkerButton->SetToolTip( _("Delete the marker selected in the listBox below") ); - - bSizer11->Add( m_DeleteCurrentMarkerButton, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxALL, 5 ); - - m_CommandSizer->Add( bSizer11, 0, wxALIGN_CENTER_VERTICAL, 5 ); - - m_MainSizer->Add( m_CommandSizer, 0, wxEXPAND|wxTOP|wxBOTTOM, 5 ); - - m_staticTextErrMsg = new wxStaticText( this, wxID_ANY, _("Error Messages:"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticTextErrMsg->Wrap( -1 ); - m_MainSizer->Add( m_staticTextErrMsg, 0, wxALL, 5 ); - - m_Notebook = new wxNotebook( this, ID_NOTEBOOK1, wxDefaultPosition, wxDefaultSize, 0 ); - m_panelClearanceListBox = new wxPanel( m_Notebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ); - wxBoxSizer* bSizeClearanceBox; - bSizeClearanceBox = new wxBoxSizer( wxVERTICAL ); - - m_ClearanceListBox = new DRCLISTBOX( m_panelClearanceListBox, ID_CLEARANCE_LIST, wxDefaultPosition, wxDefaultSize, 0, NULL, 0 ); - m_ClearanceListBox->SetToolTip( _("MARKERs, double click any to go there in PCB, right click for popup menu") ); - m_ClearanceListBox->SetMinSize( wxSize( 450,300 ) ); - - bSizeClearanceBox->Add( m_ClearanceListBox, 1, wxALL|wxEXPAND, 5 ); - - m_panelClearanceListBox->SetSizer( bSizeClearanceBox ); - m_panelClearanceListBox->Layout(); - bSizeClearanceBox->Fit( m_panelClearanceListBox ); - m_Notebook->AddPage( m_panelClearanceListBox, _("Problems / Markers"), true ); - m_panelUnconnectedBox = new wxPanel( m_Notebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ); - wxBoxSizer* bSizerUnconnectedBox; - bSizerUnconnectedBox = new wxBoxSizer( wxVERTICAL ); - - m_UnconnectedListBox = new DRCLISTBOX( m_panelUnconnectedBox, ID_UNCONNECTED_LIST, wxDefaultPosition, wxDefaultSize, 0, NULL, 0 ); - m_UnconnectedListBox->SetToolTip( _("A list of unconnected pads, right click for popup menu") ); - - bSizerUnconnectedBox->Add( m_UnconnectedListBox, 1, wxALL|wxEXPAND, 5 ); - - m_panelUnconnectedBox->SetSizer( bSizerUnconnectedBox ); - m_panelUnconnectedBox->Layout(); - bSizerUnconnectedBox->Fit( m_panelUnconnectedBox ); - m_Notebook->AddPage( m_panelUnconnectedBox, _("Unconnected"), false ); - - m_MainSizer->Add( m_Notebook, 1, wxEXPAND | wxALL, 5 ); - - m_sdbSizer1 = new wxStdDialogButtonSizer(); - m_sdbSizer1OK = new wxButton( this, wxID_OK ); - m_sdbSizer1->AddButton( m_sdbSizer1OK ); - m_sdbSizer1Cancel = new wxButton( this, wxID_CANCEL ); - m_sdbSizer1->AddButton( m_sdbSizer1Cancel ); - m_sdbSizer1->Realize(); - m_MainSizer->Add( m_sdbSizer1, 0, wxALIGN_RIGHT|wxALL, 5 ); - - this->SetSizer( m_MainSizer ); - this->Layout(); - - // Connect Events - m_CreateRptCtrl->Connect( wxEVT_COMMAND_CHECKBOX_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnReportCheckBoxClicked ), NULL, this ); - m_BrowseButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnButtonBrowseRptFileClick ), NULL, this ); - m_buttonRunDRC->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnStartdrcClick ), NULL, this ); - m_buttonListUnconnected->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnListUnconnectedClick ), NULL, this ); - m_DeleteAllButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteAllClick ), NULL, this ); - m_DeleteCurrentMarkerButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteOneClick ), NULL, this ); - m_ClearanceListBox->Connect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickClearance ), NULL, this ); - m_ClearanceListBox->Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpClearance ), NULL, this ); - m_UnconnectedListBox->Connect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickUnconnected ), NULL, this ); - m_UnconnectedListBox->Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpUnconnected ), NULL, this ); - m_sdbSizer1Cancel->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnCancelClick ), NULL, this ); - m_sdbSizer1OK->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnOkClick ), NULL, this ); -} - -DIALOG_DRC_CONTROL_BASE::~DIALOG_DRC_CONTROL_BASE() -{ - // Disconnect Events - m_CreateRptCtrl->Disconnect( wxEVT_COMMAND_CHECKBOX_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnReportCheckBoxClicked ), NULL, this ); - m_BrowseButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnButtonBrowseRptFileClick ), NULL, this ); - m_buttonRunDRC->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnStartdrcClick ), NULL, this ); - m_buttonListUnconnected->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnListUnconnectedClick ), NULL, this ); - m_DeleteAllButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteAllClick ), NULL, this ); - m_DeleteCurrentMarkerButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteOneClick ), NULL, this ); - m_ClearanceListBox->Disconnect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickClearance ), NULL, this ); - m_ClearanceListBox->Disconnect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpClearance ), NULL, this ); - m_UnconnectedListBox->Disconnect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickUnconnected ), NULL, this ); - m_UnconnectedListBox->Disconnect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpUnconnected ), NULL, this ); - m_sdbSizer1Cancel->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnCancelClick ), NULL, this ); - m_sdbSizer1OK->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnOkClick ), NULL, this ); - -} +/////////////////////////////////////////////////////////////////////////// +// C++ code generated with wxFormBuilder (version Apr 16 2008) +// http://www.wxformbuilder.org/ +// +// PLEASE DO "NOT" EDIT THIS FILE! +/////////////////////////////////////////////////////////////////////////// + +#include "dialog_drc.h" + +#include "dialog_drc_base.h" + +/////////////////////////////////////////////////////////////////////////// + +DIALOG_DRC_CONTROL_BASE::DIALOG_DRC_CONTROL_BASE( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style ) : wxDialog( parent, id, title, pos, size, style ) +{ + this->SetSizeHints( wxDefaultSize, wxDefaultSize ); + + wxBoxSizer* m_MainSizer; + m_MainSizer = new wxBoxSizer( wxVERTICAL ); + + wxBoxSizer* m_CommandSizer; + m_CommandSizer = new wxBoxSizer( wxHORIZONTAL ); + + wxStaticBoxSizer* sbSizerOptions; + sbSizerOptions = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Options") ), wxHORIZONTAL ); + + wxBoxSizer* bSizer7; + bSizer7 = new wxBoxSizer( wxVERTICAL ); + + wxFlexGridSizer* fgMinValuesSizer; + fgMinValuesSizer = new wxFlexGridSizer( 2, 4, 0, 0 ); + fgMinValuesSizer->SetFlexibleDirection( wxBOTH ); + fgMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED ); + + m_ClearanceTitle = new wxStaticText( this, wxID_ANY, _("Clearance"), wxDefaultPosition, wxDefaultSize, 0 ); + m_ClearanceTitle->Wrap( -1 ); + fgMinValuesSizer->Add( m_ClearanceTitle, 0, wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 ); + + m_SetClearance = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + m_SetClearance->Enable( false ); + m_SetClearance->SetToolTip( _("In the clearance units, enter the clearance distance") ); + + fgMinValuesSizer->Add( m_SetClearance, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); + + m_ViaMinTitle = new wxStaticText( this, wxID_ANY, _("Via Min Size"), wxDefaultPosition, wxDefaultSize, 0 ); + m_ViaMinTitle->Wrap( -1 ); + m_ViaMinTitle->Enable( false ); + + fgMinValuesSizer->Add( m_ViaMinTitle, 0, wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 ); + + m_SetViaMinSizeCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + m_SetViaMinSizeCtrl->SetToolTip( _("In the clearance units, enter the clearance distance") ); + + fgMinValuesSizer->Add( m_SetViaMinSizeCtrl, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); + + m_TrackMinWidthTitle = new wxStaticText( this, wxID_ANY, _("Track Min Width"), wxDefaultPosition, wxDefaultSize, 0 ); + m_TrackMinWidthTitle->Wrap( -1 ); + fgMinValuesSizer->Add( m_TrackMinWidthTitle, 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 ); + + m_SetTrackMinWidthCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + m_SetTrackMinWidthCtrl->SetToolTip( _("In the clearance units, enter the clearance distance") ); + + fgMinValuesSizer->Add( m_SetTrackMinWidthCtrl, 0, wxALL, 5 ); + + m_MicroViaMinTitle = new wxStaticText( this, wxID_ANY, _("MicroVia Min Size"), wxDefaultPosition, wxDefaultSize, 0 ); + m_MicroViaMinTitle->Wrap( -1 ); + fgMinValuesSizer->Add( m_MicroViaMinTitle, 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 ); + + m_SetMicroViakMinSizeCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + m_SetMicroViakMinSizeCtrl->SetToolTip( _("In the clearance units, enter the clearance distance") ); + + fgMinValuesSizer->Add( m_SetMicroViakMinSizeCtrl, 0, wxALL, 5 ); + + bSizer7->Add( fgMinValuesSizer, 1, wxEXPAND, 5 ); + + wxStaticBoxSizer* ReportFileSizer; + ReportFileSizer = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Create Report File") ), wxHORIZONTAL ); + + m_CreateRptCtrl = new wxCheckBox( this, ID_CHECKBOX_RPT_FILE, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + + m_CreateRptCtrl->SetToolTip( _("Enable writing report to this file") ); + + ReportFileSizer->Add( m_CreateRptCtrl, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); + + m_RptFilenameCtrl = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); + m_RptFilenameCtrl->SetToolTip( _("Enter the report filename") ); + m_RptFilenameCtrl->SetMinSize( wxSize( 250,-1 ) ); + + ReportFileSizer->Add( m_RptFilenameCtrl, 1, wxALL|wxEXPAND|wxALIGN_CENTER_VERTICAL, 5 ); + + m_BrowseButton = new wxButton( this, ID_BUTTON_BROWSE_RPT_FILE, _("..."), wxDefaultPosition, wxDefaultSize, 0 ); + ReportFileSizer->Add( m_BrowseButton, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 ); + + bSizer7->Add( ReportFileSizer, 1, wxEXPAND|wxTOP|wxBOTTOM|wxRIGHT, 5 ); + + sbSizerOptions->Add( bSizer7, 1, wxEXPAND, 5 ); + + m_CommandSizer->Add( sbSizerOptions, 0, 0, 5 ); + + wxBoxSizer* bSizerMessages; + bSizerMessages = new wxBoxSizer( wxVERTICAL ); + + m_staticText6 = new wxStaticText( this, wxID_ANY, _("Messages:"), wxDefaultPosition, wxDefaultSize, 0 ); + m_staticText6->Wrap( -1 ); + bSizerMessages->Add( m_staticText6, 0, wxRIGHT|wxLEFT, 5 ); + + m_Messages = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxTE_MULTILINE|wxTE_READONLY ); + m_Messages->SetMinSize( wxSize( 160,-1 ) ); + + bSizerMessages->Add( m_Messages, 1, wxBOTTOM|wxRIGHT|wxLEFT|wxEXPAND, 5 ); + + m_CommandSizer->Add( bSizerMessages, 1, wxEXPAND, 5 ); + + wxBoxSizer* bSizer11; + bSizer11 = new wxBoxSizer( wxVERTICAL ); + + m_buttonRunDRC = new wxButton( this, ID_STARTDRC, _("Start DRC"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonRunDRC->SetDefault(); + m_buttonRunDRC->SetToolTip( _("Start the Design Rule Checker") ); + + bSizer11->Add( m_buttonRunDRC, 0, wxTOP|wxRIGHT|wxLEFT|wxALIGN_CENTER_HORIZONTAL|wxEXPAND, 5 ); + + m_buttonListUnconnected = new wxButton( this, ID_LIST_UNCONNECTED, _("List Unconnected"), wxDefaultPosition, wxDefaultSize, 0 ); + m_buttonListUnconnected->SetToolTip( _("List unconnected pads or tracks") ); + + bSizer11->Add( m_buttonListUnconnected, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT, 5 ); + + m_DeleteAllButton = new wxButton( this, ID_DELETE_ALL, _("Delete All Markers"), wxDefaultPosition, wxDefaultSize, 0 ); + m_DeleteAllButton->SetToolTip( _("Delete every marker") ); + + bSizer11->Add( m_DeleteAllButton, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT, 5 ); + + m_DeleteCurrentMarkerButton = new wxButton( this, wxID_ANY, _("Delete Current Marker"), wxDefaultPosition, wxDefaultSize, 0 ); + m_DeleteCurrentMarkerButton->SetToolTip( _("Delete the marker selected in the listBox below") ); + + bSizer11->Add( m_DeleteCurrentMarkerButton, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxALL, 5 ); + + m_CommandSizer->Add( bSizer11, 0, wxALIGN_CENTER_VERTICAL, 5 ); + + m_MainSizer->Add( m_CommandSizer, 0, wxEXPAND|wxTOP|wxBOTTOM, 5 ); + + m_staticTextErrMsg = new wxStaticText( this, wxID_ANY, _("Error Messages:"), wxDefaultPosition, wxDefaultSize, 0 ); + m_staticTextErrMsg->Wrap( -1 ); + m_MainSizer->Add( m_staticTextErrMsg, 0, wxALL, 5 ); + + m_Notebook = new wxNotebook( this, ID_NOTEBOOK1, wxDefaultPosition, wxDefaultSize, 0 ); + m_panelClearanceListBox = new wxPanel( m_Notebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ); + wxBoxSizer* bSizeClearanceBox; + bSizeClearanceBox = new wxBoxSizer( wxVERTICAL ); + + m_ClearanceListBox = new DRCLISTBOX( m_panelClearanceListBox, ID_CLEARANCE_LIST, wxDefaultPosition, wxDefaultSize, 0, NULL, 0 ); + m_ClearanceListBox->SetToolTip( _("MARKERs, double click any to go there in PCB, right click for popup menu") ); + m_ClearanceListBox->SetMinSize( wxSize( 450,300 ) ); + + bSizeClearanceBox->Add( m_ClearanceListBox, 1, wxALL|wxEXPAND, 5 ); + + m_panelClearanceListBox->SetSizer( bSizeClearanceBox ); + m_panelClearanceListBox->Layout(); + bSizeClearanceBox->Fit( m_panelClearanceListBox ); + m_Notebook->AddPage( m_panelClearanceListBox, _("Problems / Markers"), true ); + m_panelUnconnectedBox = new wxPanel( m_Notebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ); + wxBoxSizer* bSizerUnconnectedBox; + bSizerUnconnectedBox = new wxBoxSizer( wxVERTICAL ); + + m_UnconnectedListBox = new DRCLISTBOX( m_panelUnconnectedBox, ID_UNCONNECTED_LIST, wxDefaultPosition, wxDefaultSize, 0, NULL, 0 ); + m_UnconnectedListBox->SetToolTip( _("A list of unconnected pads, right click for popup menu") ); + + bSizerUnconnectedBox->Add( m_UnconnectedListBox, 1, wxALL|wxEXPAND, 5 ); + + m_panelUnconnectedBox->SetSizer( bSizerUnconnectedBox ); + m_panelUnconnectedBox->Layout(); + bSizerUnconnectedBox->Fit( m_panelUnconnectedBox ); + m_Notebook->AddPage( m_panelUnconnectedBox, _("Unconnected"), false ); + + m_MainSizer->Add( m_Notebook, 1, wxEXPAND | wxALL, 5 ); + + m_sdbSizer1 = new wxStdDialogButtonSizer(); + m_sdbSizer1OK = new wxButton( this, wxID_OK ); + m_sdbSizer1->AddButton( m_sdbSizer1OK ); + m_sdbSizer1Cancel = new wxButton( this, wxID_CANCEL ); + m_sdbSizer1->AddButton( m_sdbSizer1Cancel ); + m_sdbSizer1->Realize(); + m_MainSizer->Add( m_sdbSizer1, 0, wxALIGN_RIGHT|wxALL, 5 ); + + this->SetSizer( m_MainSizer ); + this->Layout(); + + // Connect Events + m_CreateRptCtrl->Connect( wxEVT_COMMAND_CHECKBOX_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnReportCheckBoxClicked ), NULL, this ); + m_BrowseButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnButtonBrowseRptFileClick ), NULL, this ); + m_buttonRunDRC->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnStartdrcClick ), NULL, this ); + m_buttonListUnconnected->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnListUnconnectedClick ), NULL, this ); + m_DeleteAllButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteAllClick ), NULL, this ); + m_DeleteCurrentMarkerButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteOneClick ), NULL, this ); + m_ClearanceListBox->Connect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickClearance ), NULL, this ); + m_ClearanceListBox->Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpClearance ), NULL, this ); + m_UnconnectedListBox->Connect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickUnconnected ), NULL, this ); + m_UnconnectedListBox->Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpUnconnected ), NULL, this ); + m_sdbSizer1Cancel->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnCancelClick ), NULL, this ); + m_sdbSizer1OK->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnOkClick ), NULL, this ); +} + +DIALOG_DRC_CONTROL_BASE::~DIALOG_DRC_CONTROL_BASE() +{ + // Disconnect Events + m_CreateRptCtrl->Disconnect( wxEVT_COMMAND_CHECKBOX_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnReportCheckBoxClicked ), NULL, this ); + m_BrowseButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnButtonBrowseRptFileClick ), NULL, this ); + m_buttonRunDRC->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnStartdrcClick ), NULL, this ); + m_buttonListUnconnected->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnListUnconnectedClick ), NULL, this ); + m_DeleteAllButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteAllClick ), NULL, this ); + m_DeleteCurrentMarkerButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnDeleteOneClick ), NULL, this ); + m_ClearanceListBox->Disconnect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickClearance ), NULL, this ); + m_ClearanceListBox->Disconnect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpClearance ), NULL, this ); + m_UnconnectedListBox->Disconnect( wxEVT_LEFT_DCLICK, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnLeftDClickUnconnected ), NULL, this ); + m_UnconnectedListBox->Disconnect( wxEVT_RIGHT_UP, wxMouseEventHandler( DIALOG_DRC_CONTROL_BASE::OnRightUpUnconnected ), NULL, this ); + m_sdbSizer1Cancel->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnCancelClick ), NULL, this ); + m_sdbSizer1OK->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DRC_CONTROL_BASE::OnOkClick ), NULL, this ); +} diff --git a/pcbnew/dialog_drc_base.fbp b/pcbnew/dialog_drc_base.fbp index 8da4ac8963..15b762cfd4 100644 --- a/pcbnew/dialog_drc_base.fbp +++ b/pcbnew/dialog_drc_base.fbp @@ -1,1533 +1,1409 @@ - - - - - - C++ - 1 - source_name - 0 - UTF-8 - connect - dialog_drc_base - 1000 - none - 1 - dialog_drc_base - - . - - 1 - 1 - 0 - 0 - - - - - 1 - 1 - impl_virtual - - - - 0 - wxID_ANY - - - DIALOG_DRC_CONTROL_BASE - - 800,508 - wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER - - DRC Control - - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - m_MainSizer - wxVERTICAL - none - - 5 - wxEXPAND|wxTOP|wxBOTTOM - 0 - - - m_CommandSizer - wxHORIZONTAL - none - - 5 - - 0 - - wxID_ANY - Options - - sbSizerOptions - wxHORIZONTAL - none - - - 5 - wxEXPAND - 1 - - - bSizer7 - wxVERTICAL - none - - 5 - wxEXPAND - 1 - - 4 - wxBOTH - - - 0 - - fgMinValuesSizer - wxFLEX_GROWMODE_SPECIFIED - none - 2 - 0 - - 5 - wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - Clearance - - - m_ClearenceTitle - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxALIGN_CENTER_VERTICAL - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - - 0 - - m_SetClearance - public - - - - - In the clearance units, enter the clearance distance - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - Via Min Size - - - m_ViaMinTitle - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxALIGN_CENTER_VERTICAL - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - - 0 - - m_SetViaMinSizeCtrl - public - - - - - In the clearance units, enter the clearance distance - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - Track Min Width - - - m_TrackMinWidthTitle - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - - 0 - - m_SetTrackMinWidthCtrl - public - - - - - In the clearance units, enter the clearance distance - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - MicroVia Min Size - - - m_MicroViaMinTitle - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - - 0 - - m_SetMicroViakMinSizeCtrl - public - - - - - In the clearance units, enter the clearance distance - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxEXPAND|wxTOP|wxBOTTOM|wxRIGHT - 1 - - wxID_ANY - Create Report File - - ReportFileSizer - wxHORIZONTAL - none - - - 5 - wxALL|wxALIGN_CENTER_VERTICAL - 0 - - - 0 - - 1 - 1 - - - 0 - ID_CHECKBOX_RPT_FILE - - - - m_CreateRptCtrl - public - - - - - Enable writing report to this file - - wxFILTER_NONE - wxDefaultValidator - - - - - - OnReportCheckBoxClicked - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxEXPAND|wxALIGN_CENTER_VERTICAL - 1 - - - - 1 - 1 - - - 0 - wxID_ANY - - 0 - 250,-1 - m_RptFilenameCtrl - public - - - - - Enter the report filename - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL|wxALIGN_CENTER_VERTICAL - 0 - - - - 1 - 0 - 1 - - - 0 - ID_BUTTON_BROWSE_RPT_FILE - ... - - - m_BrowseButton - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - OnButtonBrowseRptFileClick - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxEXPAND - 1 - - - bSizerMessages - wxVERTICAL - none - - 5 - wxRIGHT|wxLEFT - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - Messages: - - - m_staticText6 - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxBOTTOM|wxRIGHT|wxLEFT|wxEXPAND - 1 - - - - 1 - 1 - - - 0 - wxID_ANY - - 0 - 160,-1 - m_Messages - protected - - - wxHSCROLL|wxTE_MULTILINE|wxTE_READONLY - - - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_CENTER_VERTICAL - 0 - - - bSizer11 - wxVERTICAL - none - - 5 - wxTOP|wxRIGHT|wxLEFT|wxALIGN_CENTER_HORIZONTAL|wxEXPAND - 0 - - - - 1 - 1 - 1 - - - 0 - ID_STARTDRC - Start DRC - - - m_buttonRunDRC - protected - - - - - Start the Design Rule Checker - - wxFILTER_NONE - wxDefaultValidator - - - - - OnStartdrcClick - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT - 0 - - - - 1 - 0 - 1 - - - 0 - ID_LIST_UNCONNECTED - List Unconnected - - - m_buttonListUnconnected - protected - - - - - List unconnected pads or tracks - - wxFILTER_NONE - wxDefaultValidator - - - - - OnListUnconnectedClick - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT - 0 - - - - 1 - 0 - 1 - - - 0 - ID_DELETE_ALL - Delete All Markers - - - m_DeleteAllButton - protected - - - - - Delete every marker - - wxFILTER_NONE - wxDefaultValidator - - - - - OnDeleteAllClick - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxALL - 0 - - - - 1 - 0 - 1 - - - 0 - wxID_ANY - Delete Current Marker - - - m_DeleteCurrentMarkerButton - protected - - - - - Delete the marker selected in the listBox below - - wxFILTER_NONE - wxDefaultValidator - - - - - OnDeleteOneClick - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxALL - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - Error Messages: - - - m_staticTextErrMsg - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxEXPAND | wxALL - 1 - - - - - 1 - 1 - - - 0 - ID_NOTEBOOK1 - - - m_Notebook - protected - - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Problems / Markers - 1 - - - - 1 - 1 - - - 0 - wxID_ANY - - - m_panelClearanceListBox - protected - - - ; - - - wxFILTER_NONE - wxDefaultValidator - - - - wxTAB_TRAVERSAL - - - - - - - - - - - - - - - - - - - - - - - - - - bSizeClearanceBox - wxVERTICAL - none - - 5 - wxALL|wxEXPAND - 1 - - - - - 1 - 1 - - - 0 - ID_CLEARANCE_LIST - - 450,300 - m_ClearanceListBox - public - - - - DRCLISTBOX; dialog_drc.h - MARKERs, double click any to go there in PCB, right click for popup menu - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - OnLeftDClickClearance - - - - - - - - - - - - - - OnRightUpClearance - - - - - - - - - - - Unconnected - 0 - - - - 1 - 1 - - - 0 - wxID_ANY - - - m_panelUnconnectedBox - protected - - - - - - wxFILTER_NONE - wxDefaultValidator - - - - wxTAB_TRAVERSAL - - - - - - - - - - - - - - - - - - - - - - - - - - bSizerUnconnectedBox - wxVERTICAL - none - - 5 - wxALL|wxEXPAND - 1 - - - - - 1 - 1 - - - 0 - ID_UNCONNECTED_LIST - - - m_UnconnectedListBox - public - - - - DRCLISTBOX; - A list of unconnected pads, right click for popup menu - - wxFILTER_NONE - wxDefaultValidator - - - - - - - - - - - - OnLeftDClickUnconnected - - - - - - - - - - - - - - OnRightUpUnconnected - - - - - - - - - - - - 5 - wxALIGN_RIGHT|wxALL - 0 - - 0 - 1 - 0 - 0 - 0 - 1 - 0 - 0 - - m_sdbSizer1 - protected - - OnCancelClick - - - - OnOkClick - - - - - - - - + + + + + + C++ + 1 + UTF-8 + connect + dialog_drc_base + 1000 + none + 1 + dialog_drc_base + + . + + 1 + 0 + 0 + + + + + 1 + + + + 0 + wxID_ANY + + + DIALOG_DRC_CONTROL_BASE + + 800,508 + wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER + + DRC Control + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + m_MainSizer + wxVERTICAL + none + + 5 + wxEXPAND|wxTOP|wxBOTTOM + 0 + + + m_CommandSizer + wxHORIZONTAL + none + + 5 + + 0 + + wxID_ANY + Options + + sbSizerOptions + wxHORIZONTAL + none + + + 5 + wxEXPAND + 1 + + + bSizer7 + wxVERTICAL + none + + 5 + wxEXPAND + 1 + + 4 + wxBOTH + + + 0 + + fgMinValuesSizer + wxFLEX_GROWMODE_SPECIFIED + none + 2 + 0 + + 5 + wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT + 0 + + + + 1 + + + 0 + wxID_ANY + Clearance + + + m_ClearanceTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxALIGN_CENTER_VERTICAL + 0 + + + + 0 + + + 0 + wxID_ANY + + 0 + + m_SetClearance + public + + + + + In the clearance units, enter the clearance distance + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT + 0 + + + + 0 + + + 0 + wxID_ANY + Via Min Size + + + m_ViaMinTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxALIGN_CENTER_VERTICAL + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetViaMinSizeCtrl + public + + + + + In the clearance units, enter the clearance distance + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + Track Min Width + + + m_TrackMinWidthTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetTrackMinWidthCtrl + public + + + + + In the clearance units, enter the clearance distance + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + MicroVia Min Size + + + m_MicroViaMinTitle + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL + 0 + + + + 1 + + + 0 + wxID_ANY + + 0 + + m_SetMicroViakMinSizeCtrl + public + + + + + In the clearance units, enter the clearance distance + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND|wxTOP|wxBOTTOM|wxRIGHT + 1 + + wxID_ANY + Create Report File + + ReportFileSizer + wxHORIZONTAL + none + + + 5 + wxALL|wxALIGN_CENTER_VERTICAL + 0 + + + 0 + + 1 + + + 0 + ID_CHECKBOX_RPT_FILE + + + + m_CreateRptCtrl + public + + + + + Enable writing report to this file + + + + + OnReportCheckBoxClicked + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxEXPAND|wxALIGN_CENTER_VERTICAL + 1 + + + + 1 + + + 0 + wxID_ANY + + 0 + 250,-1 + m_RptFilenameCtrl + public + + + + + Enter the report filename + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL|wxALIGN_CENTER_VERTICAL + 0 + + + + 0 + 1 + + + 0 + ID_BUTTON_BROWSE_RPT_FILE + ... + + + m_BrowseButton + protected + + + + + + + + + OnButtonBrowseRptFileClick + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND + 1 + + + bSizerMessages + wxVERTICAL + none + + 5 + wxRIGHT|wxLEFT + 0 + + + + 1 + + + 0 + wxID_ANY + Messages: + + + m_staticText6 + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxBOTTOM|wxRIGHT|wxLEFT|wxEXPAND + 1 + + + + 1 + + + 0 + wxID_ANY + + 0 + 160,-1 + m_Messages + protected + + + wxHSCROLL|wxTE_MULTILINE|wxTE_READONLY + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_VERTICAL + 0 + + + bSizer11 + wxVERTICAL + none + + 5 + wxTOP|wxRIGHT|wxLEFT|wxALIGN_CENTER_HORIZONTAL|wxEXPAND + 0 + + + + 1 + 1 + + + 0 + ID_STARTDRC + Start DRC + + + m_buttonRunDRC + protected + + + + + Start the Design Rule Checker + + + + OnStartdrcClick + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT + 0 + + + + 0 + 1 + + + 0 + ID_LIST_UNCONNECTED + List Unconnected + + + m_buttonListUnconnected + protected + + + + + List unconnected pads or tracks + + + + OnListUnconnectedClick + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxTOP|wxRIGHT|wxLEFT + 0 + + + + 0 + 1 + + + 0 + ID_DELETE_ALL + Delete All Markers + + + m_DeleteAllButton + protected + + + + + Delete every marker + + + + OnDeleteAllClick + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxALL + 0 + + + + 0 + 1 + + + 0 + wxID_ANY + Delete Current Marker + + + m_DeleteCurrentMarkerButton + protected + + + + + Delete the marker selected in the listBox below + + + + OnDeleteOneClick + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxALL + 0 + + + + 1 + + + 0 + wxID_ANY + Error Messages: + + + m_staticTextErrMsg + protected + + + + + + + + + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + 5 + wxEXPAND | wxALL + 1 + + + + + 1 + + + 0 + ID_NOTEBOOK1 + + + m_Notebook + protected + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Problems / Markers + 1 + + + + 1 + + + 0 + wxID_ANY + + + m_panelClearanceListBox + protected + + + ; + + + + wxTAB_TRAVERSAL + + + + + + + + + + + + + + + + + + + + + + + + + + bSizeClearanceBox + wxVERTICAL + none + + 5 + wxALL|wxEXPAND + 1 + + + + + 1 + + + 0 + ID_CLEARANCE_LIST + + 450,300 + m_ClearanceListBox + public + + + + DRCLISTBOX; dialog_drc.h + MARKERs, double click any to go there in PCB, right click for popup menu + + + + + + + + + + + OnLeftDClickClearance + + + + + + + + + + + + + + OnRightUpClearance + + + + + + + + + + + Unconnected + 0 + + + + 1 + + + 0 + wxID_ANY + + + m_panelUnconnectedBox + protected + + + + + + + wxTAB_TRAVERSAL + + + + + + + + + + + + + + + + + + + + + + + + + + bSizerUnconnectedBox + wxVERTICAL + none + + 5 + wxALL|wxEXPAND + 1 + + + + + 1 + + + 0 + ID_UNCONNECTED_LIST + + + m_UnconnectedListBox + public + + + + DRCLISTBOX; + A list of unconnected pads, right click for popup menu + + + + + + + + + + + OnLeftDClickUnconnected + + + + + + + + + + + + + + OnRightUpUnconnected + + + + + + + + + + + + 5 + wxALIGN_RIGHT|wxALL + 0 + + 0 + 1 + 0 + 0 + 0 + 1 + 0 + 0 + + m_sdbSizer1 + protected + + OnCancelClick + + + + OnOkClick + + + + + + + + diff --git a/pcbnew/dialog_drc_base.h b/pcbnew/dialog_drc_base.h index 9b297962c6..cdd49e53cd 100644 --- a/pcbnew/dialog_drc_base.h +++ b/pcbnew/dialog_drc_base.h @@ -1,103 +1,101 @@ -/////////////////////////////////////////////////////////////////////////// -// C++ code generated with wxFormBuilder (version Sep 9 2009) -// http://www.wxformbuilder.org/ -// -// PLEASE DO "NOT" EDIT THIS FILE! -/////////////////////////////////////////////////////////////////////////// - -#ifndef __dialog_drc_base__ -#define __dialog_drc_base__ - -#include - -class DRCLISTBOX; - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -/////////////////////////////////////////////////////////////////////////// - -#define ID_CHECKBOX_RPT_FILE 1000 -#define ID_BUTTON_BROWSE_RPT_FILE 1001 -#define ID_STARTDRC 1002 -#define ID_LIST_UNCONNECTED 1003 -#define ID_DELETE_ALL 1004 -#define ID_NOTEBOOK1 1005 -#define ID_CLEARANCE_LIST 1006 -#define ID_UNCONNECTED_LIST 1007 - -/////////////////////////////////////////////////////////////////////////////// -/// Class DIALOG_DRC_CONTROL_BASE -/////////////////////////////////////////////////////////////////////////////// -class DIALOG_DRC_CONTROL_BASE : public wxDialog -{ - private: - - protected: - wxStaticText* m_ClearenceTitle; - wxStaticText* m_ViaMinTitle; - wxStaticText* m_TrackMinWidthTitle - ; - wxStaticText* m_MicroViaMinTitle; - wxButton* m_BrowseButton; - wxStaticText* m_staticText6; - wxTextCtrl* m_Messages; - wxButton* m_buttonRunDRC; - wxButton* m_buttonListUnconnected; - wxButton* m_DeleteAllButton; - wxButton* m_DeleteCurrentMarkerButton; - wxStaticText* m_staticTextErrMsg; - wxNotebook* m_Notebook; - wxPanel* m_panelClearanceListBox; - wxPanel* m_panelUnconnectedBox; - wxStdDialogButtonSizer* m_sdbSizer1; - wxButton* m_sdbSizer1OK; - wxButton* m_sdbSizer1Cancel; - - // Virtual event handlers, overide them in your derived class - virtual void OnReportCheckBoxClicked( wxCommandEvent& event ) { event.Skip(); } - virtual void OnButtonBrowseRptFileClick( wxCommandEvent& event ) { event.Skip(); } - virtual void OnStartdrcClick( wxCommandEvent& event ) { event.Skip(); } - virtual void OnListUnconnectedClick( wxCommandEvent& event ) { event.Skip(); } - virtual void OnDeleteAllClick( wxCommandEvent& event ) { event.Skip(); } - virtual void OnDeleteOneClick( wxCommandEvent& event ) { event.Skip(); } - virtual void OnLeftDClickClearance( wxMouseEvent& event ) { event.Skip(); } - virtual void OnRightUpClearance( wxMouseEvent& event ) { event.Skip(); } - virtual void OnLeftDClickUnconnected( wxMouseEvent& event ) { event.Skip(); } - virtual void OnRightUpUnconnected( wxMouseEvent& event ) { event.Skip(); } - virtual void OnCancelClick( wxCommandEvent& event ) { event.Skip(); } - virtual void OnOkClick( wxCommandEvent& event ) { event.Skip(); } - - - public: - wxTextCtrl* m_SetClearance; - wxTextCtrl* m_SetViaMinSizeCtrl; - wxTextCtrl* m_SetTrackMinWidthCtrl; - wxTextCtrl* m_SetMicroViakMinSizeCtrl; - wxCheckBox* m_CreateRptCtrl; - wxTextCtrl* m_RptFilenameCtrl; - DRCLISTBOX* m_ClearanceListBox; - DRCLISTBOX* m_UnconnectedListBox; - - DIALOG_DRC_CONTROL_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("DRC Control"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 800,508 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); - ~DIALOG_DRC_CONTROL_BASE(); - -}; - -#endif //__dialog_drc_base__ +/////////////////////////////////////////////////////////////////////////// +// C++ code generated with wxFormBuilder (version Apr 16 2008) +// http://www.wxformbuilder.org/ +// +// PLEASE DO "NOT" EDIT THIS FILE! +/////////////////////////////////////////////////////////////////////////// + +#ifndef __dialog_drc_base__ +#define __dialog_drc_base__ + +#include + +class DRCLISTBOX; + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/////////////////////////////////////////////////////////////////////////// + +#define ID_CHECKBOX_RPT_FILE 1000 +#define ID_BUTTON_BROWSE_RPT_FILE 1001 +#define ID_STARTDRC 1002 +#define ID_LIST_UNCONNECTED 1003 +#define ID_DELETE_ALL 1004 +#define ID_NOTEBOOK1 1005 +#define ID_CLEARANCE_LIST 1006 +#define ID_UNCONNECTED_LIST 1007 + +/////////////////////////////////////////////////////////////////////////////// +/// Class DIALOG_DRC_CONTROL_BASE +/////////////////////////////////////////////////////////////////////////////// +class DIALOG_DRC_CONTROL_BASE : public wxDialog +{ + private: + + protected: + wxStaticText* m_ClearanceTitle; + wxStaticText* m_ViaMinTitle; + wxStaticText* m_TrackMinWidthTitle; + wxStaticText* m_MicroViaMinTitle; + wxButton* m_BrowseButton; + wxStaticText* m_staticText6; + wxTextCtrl* m_Messages; + wxButton* m_buttonRunDRC; + wxButton* m_buttonListUnconnected; + wxButton* m_DeleteAllButton; + wxButton* m_DeleteCurrentMarkerButton; + wxStaticText* m_staticTextErrMsg; + wxNotebook* m_Notebook; + wxPanel* m_panelClearanceListBox; + wxPanel* m_panelUnconnectedBox; + wxStdDialogButtonSizer* m_sdbSizer1; + wxButton* m_sdbSizer1OK; + wxButton* m_sdbSizer1Cancel; + + // Virtual event handlers, overide them in your derived class + virtual void OnReportCheckBoxClicked( wxCommandEvent& event ){ event.Skip(); } + virtual void OnButtonBrowseRptFileClick( wxCommandEvent& event ){ event.Skip(); } + virtual void OnStartdrcClick( wxCommandEvent& event ){ event.Skip(); } + virtual void OnListUnconnectedClick( wxCommandEvent& event ){ event.Skip(); } + virtual void OnDeleteAllClick( wxCommandEvent& event ){ event.Skip(); } + virtual void OnDeleteOneClick( wxCommandEvent& event ){ event.Skip(); } + virtual void OnLeftDClickClearance( wxMouseEvent& event ){ event.Skip(); } + virtual void OnRightUpClearance( wxMouseEvent& event ){ event.Skip(); } + virtual void OnLeftDClickUnconnected( wxMouseEvent& event ){ event.Skip(); } + virtual void OnRightUpUnconnected( wxMouseEvent& event ){ event.Skip(); } + virtual void OnCancelClick( wxCommandEvent& event ){ event.Skip(); } + virtual void OnOkClick( wxCommandEvent& event ){ event.Skip(); } + + + public: + wxTextCtrl* m_SetClearance; + wxTextCtrl* m_SetViaMinSizeCtrl; + wxTextCtrl* m_SetTrackMinWidthCtrl; + wxTextCtrl* m_SetMicroViakMinSizeCtrl; + wxCheckBox* m_CreateRptCtrl; + wxTextCtrl* m_RptFilenameCtrl; + DRCLISTBOX* m_ClearanceListBox; + DRCLISTBOX* m_UnconnectedListBox; + DIALOG_DRC_CONTROL_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("DRC Control"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 800,508 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); + ~DIALOG_DRC_CONTROL_BASE(); + +}; + +#endif //__dialog_drc_base__ diff --git a/pcbnew/dialog_track_options.cpp b/pcbnew/dialog_track_options.cpp index e3920bbf7e..33766dcbdb 100644 --- a/pcbnew/dialog_track_options.cpp +++ b/pcbnew/dialog_track_options.cpp @@ -38,15 +38,10 @@ void DIALOG_TRACKS_OPTIONS::MyInit() AddUnitSymbol( *m_MaskClearanceTitle ); int Internal_Unit = m_Parent->m_InternalUnits; - PutValueInLocalUnits( *m_OptViaDrill, g_DesignSettings.m_ViaDrill, Internal_Unit ); PutValueInLocalUnits( *m_OptCustomViaDrill, g_DesignSettings.m_ViaDrillCustomValue, Internal_Unit ); PutValueInLocalUnits( *m_OptMaskMargin, g_DesignSettings.m_MaskMargin, Internal_Unit ); - if( g_DesignSettings.m_CurrentViaType != VIA_THROUGH ) - m_OptViaType->SetSelection( 1 ); - - m_AllowMicroViaCtrl->SetSelection( g_DesignSettings.m_MicroViasAllowed ? 1 : 0); // Vias and Tracks sizes values. // note we display only extra values, never the current netclass value. @@ -200,15 +195,8 @@ void DIALOG_TRACKS_OPTIONS::InitDimensionsLists() void DIALOG_TRACKS_OPTIONS::OnButtonOkClick( wxCommandEvent& event ) /*******************************************************************/ { - g_DesignSettings.m_CurrentViaType = VIA_THROUGH; - if( m_OptViaType->GetSelection() > 0 ) - g_DesignSettings.m_CurrentViaType = VIA_BLIND_BURIED; - - g_DesignSettings.m_ViaDrill = - ReturnValueFromTextCtrl( *m_OptViaDrill, m_Parent->m_InternalUnits ); g_DesignSettings.m_ViaDrillCustomValue = ReturnValueFromTextCtrl( *m_OptCustomViaDrill, m_Parent->m_InternalUnits ); - g_DesignSettings.m_MicroViasAllowed = m_AllowMicroViaCtrl->GetSelection() == 1; g_DesignSettings.m_MaskMargin = ReturnValueFromTextCtrl( *m_OptMaskMargin, m_Parent->m_InternalUnits ); diff --git a/pcbnew/dialog_track_options_base.cpp b/pcbnew/dialog_track_options_base.cpp index fb540305b2..414e6fb3bd 100644 --- a/pcbnew/dialog_track_options_base.cpp +++ b/pcbnew/dialog_track_options_base.cpp @@ -35,7 +35,7 @@ DIALOG_TRACKS_OPTIONS_BASE::DIALOG_TRACKS_OPTIONS_BASE( wxWindow* parent, wxWind sViaSizeBox = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Vias Custom Sizes List:") ), wxHORIZONTAL ); m_ViaSizeListCtrl = new wxListBox( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0, NULL, 0 ); - sViaSizeBox->Add( m_ViaSizeListCtrl, 1, wxALL|wxEXPAND, 5 ); + sViaSizeBox->Add( m_ViaSizeListCtrl, 1, wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT, 5 ); wxBoxSizer* bSizeViasListButtons; bSizeViasListButtons = new wxBoxSizer( wxVERTICAL ); @@ -50,15 +50,6 @@ DIALOG_TRACKS_OPTIONS_BASE::DIALOG_TRACKS_OPTIONS_BASE( wxWindow* parent, wxWind sbLeftSizer->Add( sViaSizeBox, 1, wxEXPAND, 5 ); - m_ViaDefaultDrillValueTitle = new wxStaticText( this, wxID_ANY, _("Default Via Drill"), wxDefaultPosition, wxDefaultSize, 0 ); - m_ViaDefaultDrillValueTitle->Wrap( -1 ); - sbLeftSizer->Add( m_ViaDefaultDrillValueTitle, 0, wxTOP|wxRIGHT|wxLEFT, 5 ); - - m_OptViaDrill = new wxTextCtrl( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - m_OptViaDrill->SetToolTip( _("Enter the default via drill diameter\nAll vias drills not set to a specific drill value will have this drill value.") ); - - sbLeftSizer->Add( m_OptViaDrill, 0, wxBOTTOM|wxRIGHT|wxLEFT|wxEXPAND, 5 ); - m_ViaAltDrillValueTitle = new wxStaticText( this, wxID_ANY, _("Specific Via Drill"), wxDefaultPosition, wxDefaultSize, 0 ); m_ViaAltDrillValueTitle->Wrap( -1 ); sbLeftSizer->Add( m_ViaAltDrillValueTitle, 0, wxTOP|wxRIGHT|wxLEFT, 5 ); @@ -70,30 +61,6 @@ DIALOG_TRACKS_OPTIONS_BASE::DIALOG_TRACKS_OPTIONS_BASE( wxWindow* parent, wxWind bMainUpperSizer->Add( sbLeftSizer, 1, wxEXPAND, 5 ); - wxStaticBoxSizer* sbMiddleLeftSizer; - sbMiddleLeftSizer = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Vias Options:") ), wxVERTICAL ); - - wxString m_OptViaTypeChoices[] = { _("Through via"), _("Blind or buried via") }; - int m_OptViaTypeNChoices = sizeof( m_OptViaTypeChoices ) / sizeof( wxString ); - m_OptViaType = new wxRadioBox( this, wxID_ANY, _("Default Via Type"), wxDefaultPosition, wxDefaultSize, m_OptViaTypeNChoices, m_OptViaTypeChoices, 1, wxRA_SPECIFY_COLS ); - m_OptViaType->SetSelection( 0 ); - m_OptViaType->SetToolTip( _("Select the current via type.\nTrough via is the usual selection") ); - - sbMiddleLeftSizer->Add( m_OptViaType, 0, wxALL|wxEXPAND, 5 ); - - - sbMiddleLeftSizer->Add( 10, 10, 0, 0, 5 ); - - wxString m_AllowMicroViaCtrlChoices[] = { _("Do not allow micro vias"), _("Allow micro vias") }; - int m_AllowMicroViaCtrlNChoices = sizeof( m_AllowMicroViaCtrlChoices ) / sizeof( wxString ); - m_AllowMicroViaCtrl = new wxRadioBox( this, wxID_ALLOW_MICROVIA, _("Micro Vias:"), wxDefaultPosition, wxDefaultSize, m_AllowMicroViaCtrlNChoices, m_AllowMicroViaCtrlChoices, 1, wxRA_SPECIFY_COLS ); - m_AllowMicroViaCtrl->SetSelection( 0 ); - m_AllowMicroViaCtrl->SetToolTip( _("Allows or do not allow use of micro vias\nThey are very small vias only from an external copper layer to its near neightbour") ); - - sbMiddleLeftSizer->Add( m_AllowMicroViaCtrl, 0, wxALL, 5 ); - - bMainUpperSizer->Add( sbMiddleLeftSizer, 0, wxEXPAND, 5 ); - wxStaticBoxSizer* sbMiddleRightSizer; sbMiddleRightSizer = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Dimensions:") ), wxVERTICAL ); @@ -101,7 +68,7 @@ DIALOG_TRACKS_OPTIONS_BASE::DIALOG_TRACKS_OPTIONS_BASE( wxWindow* parent, wxWind sbTracksListSizer = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Tracks Custom Widths List:") ), wxHORIZONTAL ); m_TrackWidthListCtrl = new wxListBox( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0, NULL, 0 ); - sbTracksListSizer->Add( m_TrackWidthListCtrl, 1, wxALL|wxEXPAND, 5 ); + sbTracksListSizer->Add( m_TrackWidthListCtrl, 1, wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT, 5 ); wxBoxSizer* bSizerTacksButtSizer; bSizerTacksButtSizer = new wxBoxSizer( wxVERTICAL ); diff --git a/pcbnew/dialog_track_options_base.fbp b/pcbnew/dialog_track_options_base.fbp index 2b22d6bb73..0304b0fa05 100644 --- a/pcbnew/dialog_track_options_base.fbp +++ b/pcbnew/dialog_track_options_base.fbp @@ -32,7 +32,7 @@ DIALOG_TRACKS_OPTIONS_BASE - 627,351 + 500,351 wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER Tracks and Vias Sizes @@ -110,7 +110,7 @@ 5 - wxALL|wxEXPAND + wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT 1 @@ -279,108 +279,12 @@ 5 - wxTOP|wxRIGHT|wxLEFT + 0 - - - - 1 - - - 0 - wxID_ANY - Default Via Drill - - - m_ViaDefaultDrillValueTitle + + 10 protected - - - - - - - - - -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - wxBOTTOM|wxRIGHT|wxLEFT|wxEXPAND - 0 - - - - 1 - - - 0 - wxID_ANY - - 0 - - m_OptViaDrill - protected - - - - - Enter the default via drill diameter All vias drills not set to a specific drill value will have this drill value. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + 10 @@ -491,138 +395,6 @@ - - 5 - wxEXPAND - 0 - - wxID_ANY - Vias Options: - - sbMiddleLeftSizer - wxVERTICAL - none - - - 5 - wxALL|wxEXPAND - 0 - - - "Through via" "Blind or buried via" - - 1 - - - 0 - wxID_ANY - Default Via Type - 1 - - - m_OptViaType - protected - - 0 - - wxRA_SPECIFY_COLS - - Select the current via type. Trough via is the usual selection - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 - - 0 - - 10 - protected - 10 - - - - 5 - wxALL - 0 - - - "Do not allow micro vias" "Allow micro vias" - - 1 - - - 0 - wxID_ALLOW_MICROVIA - Micro Vias: - 1 - - - m_AllowMicroViaCtrl - protected - - 0 - - wxRA_SPECIFY_COLS - - Allows or do not allow use of micro vias They are very small vias only from an external copper layer to its near neightbour - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 5 wxEXPAND @@ -649,7 +421,7 @@ 5 - wxALL|wxEXPAND + wxEXPAND|wxBOTTOM|wxRIGHT|wxLEFT 1 diff --git a/pcbnew/dialog_track_options_base.h b/pcbnew/dialog_track_options_base.h index 94a17d80d8..0a95bbb1c4 100644 --- a/pcbnew/dialog_track_options_base.h +++ b/pcbnew/dialog_track_options_base.h @@ -21,7 +21,6 @@ #include #include #include -#include #include /////////////////////////////////////////////////////////////////////////// @@ -48,7 +47,6 @@ class DIALOG_TRACKS_OPTIONS_BASE : public wxDialog { wxID_ADD_VIA_SIZE = 1000, wxID_DELETED_WIA_SIEZ, - wxID_ALLOW_MICROVIA, wxID_ADD_TRACK_WIDTH, wxID_DELETED_TRACK_WIDTH, }; @@ -56,13 +54,8 @@ class DIALOG_TRACKS_OPTIONS_BASE : public wxDialog wxListBox* m_ViaSizeListCtrl; wxButton* m_buttonAddViasSize; wxButton* m_button4; - wxStaticText* m_ViaDefaultDrillValueTitle; - wxTextCtrl* m_OptViaDrill; wxStaticText* m_ViaAltDrillValueTitle; wxTextCtrl* m_OptCustomViaDrill; - wxRadioBox* m_OptViaType; - - wxRadioBox* m_AllowMicroViaCtrl; wxListBox* m_TrackWidthListCtrl; wxButton* m_buttonAddTrackSize; wxButton* m_buttonDeleteTrackWidth; @@ -83,7 +76,7 @@ class DIALOG_TRACKS_OPTIONS_BASE : public wxDialog public: - DIALOG_TRACKS_OPTIONS_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Tracks and Vias Sizes"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 627,351 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); + DIALOG_TRACKS_OPTIONS_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Tracks and Vias Sizes"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 500,351 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); ~DIALOG_TRACKS_OPTIONS_BASE(); }; diff --git a/pcbnew/drc.cpp b/pcbnew/drc.cpp index 0de02c5f95..58d2d3e11f 100644 --- a/pcbnew/drc.cpp +++ b/pcbnew/drc.cpp @@ -62,8 +62,6 @@ void DRC::ShowDialog() // copy data retained in this DRC object into the m_ui DrcPanel: - PutValueInLocalUnits( *m_ui->m_SetClearance, g_DesignSettings.m_TrackClearance, - m_mainWindow->m_InternalUnits );; PutValueInLocalUnits( *m_ui->m_SetTrackMinWidthCtrl, g_DesignSettings.m_TrackMinWidth, m_mainWindow->m_InternalUnits );; PutValueInLocalUnits( *m_ui->m_SetViaMinSizeCtrl, g_DesignSettings.m_ViasMinSize, @@ -320,7 +318,8 @@ bool DRC::doNetClass( NETCLASS* nc, wxString& msg ) #define FmtVal( x ) GetChars( ReturnStringFromValue( g_UnitMetric, x, PCB_INTERNAL_UNIT ) ) - if( nc->GetClearance() < g.m_TrackClearance ) +#if 0 // set to 1 when (if...) EDA_BoardDesignSettings has a m_MinClearance value + if( nc->GetClearance() < g.m_MinClearance ) { msg.Printf( _("NETCLASS: '%s' has Clearance:%s which is less than global:%s"), GetChars( nc->GetName() ), @@ -333,6 +332,7 @@ bool DRC::doNetClass( NETCLASS* nc, wxString& msg ) m_currentMarker = 0; ret = false; } +#endif if( nc->GetTrackWidth() < g.m_TrackMinWidth ) { @@ -362,12 +362,12 @@ bool DRC::doNetClass( NETCLASS* nc, wxString& msg ) ret = false; } - if( nc->GetViaDrill() < g.m_ViaDrill ) + if( nc->GetViaDrill() < g.m_ViasMinDrill ) { msg.Printf( _("NETCLASS: '%s' has Via Drill:%s which is less than global:%s"), GetChars( nc->GetName() ), FmtVal( nc->GetViaDrill() ), - FmtVal( g.m_ViaDrill ) + FmtVal( g.m_ViasMinDrill ) ); m_currentMarker = fillMarker( DRCE_NETCLASS_VIADRILLSIZE, msg, m_currentMarker ); @@ -390,12 +390,12 @@ bool DRC::doNetClass( NETCLASS* nc, wxString& msg ) ret = false; } - if( nc->GetuViaDrill() < g.m_MicroViaDrill ) + if( nc->GetuViaDrill() < g.m_MicroViasMinDrill ) { msg.Printf( _("NETCLASS: '%s' has uVia Drill:%s which is less than global:%s"), GetChars( nc->GetName() ), FmtVal( nc->GetuViaDrill() ), - FmtVal( g.m_MicroViaDrill ) + FmtVal( g.m_MicroViasMinDrill ) ); m_currentMarker = fillMarker( DRCE_NETCLASS_uVIADRILLSIZE, msg, m_currentMarker ); diff --git a/pcbnew/export_gencad.cpp b/pcbnew/export_gencad.cpp index bf06d9ac61..79562730e4 100644 --- a/pcbnew/export_gencad.cpp +++ b/pcbnew/export_gencad.cpp @@ -619,7 +619,7 @@ void CreateRoutesSection( FILE* file, BOARD* pcb ) fprintf( file, "VIA viapad%d %d %d ALL %d via%d\n", track->m_Width, mapXto( track->m_Start.x ), mapYto( track->m_Start.y ), - g_DesignSettings.m_ViaDrill, vianum++ ); + track->GetDrillValue(), vianum++ ); } } diff --git a/pcbnew/gendrill.cpp b/pcbnew/gendrill.cpp index e6f6cc80e3..b0893ec58b 100644 --- a/pcbnew/gendrill.cpp +++ b/pcbnew/gendrill.cpp @@ -80,27 +80,19 @@ void WinEDA_DrillFrame::InitDisplayParams( void ) { wxString msg; - if( s_Zeros_Format==DECIMAL_FORMAT ) + if( s_Zeros_Format == DECIMAL_FORMAT ) m_Choice_Precision->Enable( false ); if( DrillOriginIsAuxAxis ) m_Choice_Drill_Offset->SetSelection( 1 ); msg << s_Precision.m_lhs << wxT( ":" ) << s_Precision.m_rhs; m_Choice_Precision->SetStringSelection( msg ); - if( s_Zeros_Format==DECIMAL_FORMAT ) + if( s_Zeros_Format == DECIMAL_FORMAT ) m_Choice_Precision->Enable( false ); - msg = ReturnStringFromValue( g_UnitMetric, - g_DesignSettings.m_ViaDrill, - m_Parent->m_InternalUnits ); - msg += ReturnUnitSymbol( g_UnitMetric ); - m_ViaDrillValue->SetLabel( msg ); + m_ViaDrillValue->SetLabel( _( "Use Netclasses values" ) ); - msg = ReturnStringFromValue( g_UnitMetric, - g_DesignSettings.m_MicroViaDrill, - m_Parent->m_InternalUnits ); - msg += ReturnUnitSymbol( g_UnitMetric ); - m_MicroViaDrillValue->SetLabel( msg ); + m_MicroViaDrillValue->SetLabel( _( "Use Netclasses values" ) ); msg.Empty(); msg << g_pcb_plot_options.HPGL_Pen_Num; @@ -141,8 +133,8 @@ void WinEDA_DrillFrame::InitDisplayParams( void ) m_PadsHoleCount++; } else - if( MIN( pad->m_Drill.x, pad->m_Drill.y ) != 0 ) - m_PadsHoleCount++; + if( MIN( pad->m_Drill.x, pad->m_Drill.y ) != 0 ) + m_PadsHoleCount++; } } @@ -270,21 +262,21 @@ void WinEDA_DrillFrame::GenDrillFiles( wxCommandEvent& event ) */ { wxFileName fn; - wxString layer_extend; // added to the Board FileName to create FullFileName (= Board FileName + layer pair names) - wxString msg; - bool ExistsBuriedVias = false; // If true, drill files are created layer pair by layer pair for buried vias - int layer1 = COPPER_LAYER_N; - int layer2 = LAYER_CMP_N; - bool gen_through_holes = true; + wxString layer_extend; // added to the Board FileName to create FullFileName (= Board FileName + layer pair names) + wxString msg; + bool ExistsBuriedVias = false; // If true, drill files are created layer pair by layer pair for buried vias + int layer1 = COPPER_LAYER_N; + int layer2 = LAYER_CMP_N; + bool gen_through_holes = true; UpdateConfig(); /* set params and Save drill options */ m_Parent->MsgPanel->EraseMsgBox(); /* Set conversion scale depending on drill file units */ - s_ConversionUnits = 0.0001f; /* unites = INCHES */ + s_ConversionUnits = 0.0001f; /* unites = INCHES */ if( !s_Unit_Drill_is_Inch ) - s_ConversionUnits = 0.000254f; /* unites = mm */ + s_ConversionUnits = 0.000254f; /* unites = mm */ if( m_MicroViasCount || m_BlindOrBuriedViasCount ) ExistsBuriedVias = true; @@ -322,7 +314,7 @@ void WinEDA_DrillFrame::GenDrillFiles( wxCommandEvent& event ) if( dlg.ShowModal() == wxID_CANCEL ) break; - FILE *excellon_dest = wxFopen( dlg.GetPath(), wxT( "w" ) ); + FILE* excellon_dest = wxFopen( dlg.GetPath(), wxT( "w" ) ); if( excellon_dest == 0 ) { @@ -332,7 +324,7 @@ void WinEDA_DrillFrame::GenDrillFiles( wxCommandEvent& event ) return; } - Create_Drill_File_EXCELLON(excellon_dest, s_HoleListBuffer, s_ToolListBuffer ); + Create_Drill_File_EXCELLON( excellon_dest, s_HoleListBuffer, s_ToolListBuffer ); switch( m_Choice_Drill_Map->GetSelection() ) { @@ -393,7 +385,8 @@ void WinEDA_DrillFrame::UpdatePrecisionOptions( wxCommandEvent& event ) /********************************************************************/ { if( m_Choice_Unit->GetSelection()==1 ) - { /* inch options */ + { + /* inch options */ m_Choice_Precision->SetString( 0, _( "2:3" ) ); m_Choice_Precision->SetString( 1, _( "2:4" ) ); } @@ -411,8 +404,8 @@ void WinEDA_DrillFrame::UpdatePrecisionOptions( wxCommandEvent& event ) /**********************************************************************************/ -int WinEDA_DrillFrame::Create_Drill_File_EXCELLON(FILE *excellon_dest, - std::vector& aHoleListBuffer, +int WinEDA_DrillFrame::Create_Drill_File_EXCELLON( FILE* excellon_dest, + std::vector& aHoleListBuffer, std::vector& aToolListBuffer ) /**********************************************************************************/ @@ -440,22 +433,22 @@ int WinEDA_DrillFrame::Create_Drill_File_EXCELLON(FILE *excellon_dest, { if( s_Unit_Drill_is_Inch ) /* does it need T01, T02 or is T1,T2 ok?*/ fprintf( excellon_dest, "T%dC%.3f\n", ii + 1, - float (aToolListBuffer[ii].m_Diameter) * s_ConversionUnits ); + float (aToolListBuffer[ii].m_Diameter) * s_ConversionUnits ); else fprintf( excellon_dest, "T%dC%.3f\n", ii + 1, - float (aToolListBuffer[ii].m_Diameter) * s_ConversionUnits * 10.0 ); + float (aToolListBuffer[ii].m_Diameter) * s_ConversionUnits * 10.0 ); } fputs( "%\n", excellon_dest ); if( !Minimal ) - fputs( "M47\n", excellon_dest ); /* Operator message */ - fputs( "G05\n", excellon_dest ); /* Drill mode */ + fputs( "M47\n", excellon_dest ); /* Operator message */ + fputs( "G05\n", excellon_dest ); /* Drill mode */ /* Units : */ if( s_Unit_Drill_is_Inch && !Minimal ) - fputs( "M72\n", excellon_dest ); /* M72 = inch mode */ + fputs( "M72\n", excellon_dest ); /* M72 = inch mode */ else if( !Minimal ) - fputs( "M71\n", excellon_dest ); /* M71 = metric mode */ + fputs( "M71\n", excellon_dest ); /* M71 = metric mode */ /* Read the hole file and generate lines for normal holes (oblong holes will be created later) */ for( unsigned ii = 0; ii < aHoleListBuffer.size(); ii++ ) @@ -541,7 +534,7 @@ int WinEDA_DrillFrame::Create_Drill_File_EXCELLON(FILE *excellon_dest, fputs( line, excellon_dest ); - fputs( "G85",excellon_dest ); // add the "G85" command + fputs( "G85", excellon_dest ); // add the "G85" command xt = float (xf) * s_ConversionUnits; yt = float (yf) * s_ConversionUnits; if( s_Unit_Drill_is_Inch ) @@ -661,17 +654,19 @@ void WinEDA_DrillFrame::Write_Excellon_Header( FILE* aFile ) if( !Minimal ) { - int ii = m_Choice_Zeros_Format->GetSelection(); + int ii = m_Choice_Zeros_Format->GetSelection(); DateAndTime( Line ); + // The next 2 lines in EXCELLON files are comments: wxString msg = wxGetApp().GetTitle() + wxT( " " ) + GetBuildVersion(); fprintf( aFile, ";DRILL file {%s} date %s\n", CONV_TO_UTF8( msg ), Line ); msg = wxT( ";FORMAT={" ); + // Print precision: - if ( ii > 0 ) + if( ii > 0 ) msg << m_Choice_Precision->GetStringSelection(); else - msg << wxT("-.-"); // in decimal format the precision is irrelevant + msg << wxT( "-.-" ); // in decimal format the precision is irrelevant msg << wxT( "/ absolute / " ); msg << ( s_Unit_Drill_is_Inch ? wxT( "inch" ) : wxT( "metric" ) ); @@ -684,7 +679,7 @@ void WinEDA_DrillFrame::Write_Excellon_Header( FILE* aFile ) msg << wxT( " / " ); const wxString zero_fmt[5] = { - wxT( "decimal" ), wxT( "suppress leading zeros" ), + wxT( "decimal" ), wxT( "suppress leading zeros" ), wxT( "suppress trailing zeros" ), wxT( "keep zeros" ), wxT( "???" ) }; @@ -739,8 +734,8 @@ void WinEDA_DrillFrame::GenDrillMap( const wxString aFileName, */ { wxFileName fn; - wxString ext, wildcard; - wxString msg; + wxString ext, wildcard; + wxString msg; /* Init extension */ switch( format ) @@ -782,7 +777,7 @@ void WinEDA_DrillFrame::GenDrillMap( const wxString aFileName, if( dlg.ShowModal() == wxID_CANCEL ) return; - FILE *drillplot_dest = wxFopen( dlg.GetPath(), wxT( "wt" ) ); + FILE* drillplot_dest = wxFopen( dlg.GetPath(), wxT( "wt" ) ); if( drillplot_dest == 0 ) { @@ -812,21 +807,21 @@ void WinEDA_DrillFrame::GenDrillReport( const wxString aFileName ) */ { wxFileName fn; - wxString msg; - wxString wildcard = _( "Drill report files (.rpt)|*.rpt" ); + wxString msg; + wxString wildcard = _( "Drill report files (.rpt)|*.rpt" ); fn = aFileName; fn.SetName( fn.GetName() + wxT( "-drl" ) ); fn.SetExt( wxT( "rpt" ) ); - wxFileDialog dlg( this, _( "Save Drill Report File" ), fn.GetPath(), + wxFileDialog dlg( this, _( "Save Drill Report File" ), fn.GetPath(), fn.GetFullName(), wildcard, wxFD_SAVE | wxFD_OVERWRITE_PROMPT ); if( dlg.ShowModal() == wxID_CANCEL ) return; - FILE *report_dest = wxFopen( dlg.GetPath(), wxT( "w" ) ); + FILE* report_dest = wxFopen( dlg.GetPath(), wxT( "w" ) ); if( report_dest == 0 ) { diff --git a/pcbnew/ioascii.cpp b/pcbnew/ioascii.cpp index 99ea6529c5..92fb760e09 100644 --- a/pcbnew/ioascii.cpp +++ b/pcbnew/ioascii.cpp @@ -324,6 +324,8 @@ int WinEDA_BasePcbFrame::ReadSetup( FILE* File, int* LineNum ) char Line[1024]; char* data; + NETCLASS * netclass_default = GetBoard()->m_NetClasses.GetDefault(); + while( GetLine( File, Line, LineNum ) != NULL ) { strtok( Line, " =\n\r" ); @@ -405,7 +407,7 @@ int WinEDA_BasePcbFrame::ReadSetup( FILE* File, int* LineNum ) if( stricmp( Line, "TrackClearence" ) == 0 ) { - g_DesignSettings.m_TrackClearance = atoi( data ); + netclass_default->SetClearance( atoi( data ) ); continue; } @@ -421,12 +423,6 @@ int WinEDA_BasePcbFrame::ReadSetup( FILE* File, int* LineNum ) continue; } - if( stricmp( Line, "ZoneGridSize" ) == 0 ) - { - g_GridRoutingSize = atoi( data ); - continue; - } - if( stricmp( Line, "DrawSegmWidth" ) == 0 ) { g_DesignSettings.m_DrawSegmentWidth = atoi( data ); @@ -472,7 +468,8 @@ int WinEDA_BasePcbFrame::ReadSetup( FILE* File, int* LineNum ) if( stricmp( Line, "ViaDrill" ) == 0 ) { - g_DesignSettings.m_ViaDrill = atoi( data ); + int diameter = atoi( data ); + netclass_default->SetViaDrill( diameter ); continue; } @@ -482,9 +479,23 @@ int WinEDA_BasePcbFrame::ReadSetup( FILE* File, int* LineNum ) continue; } + if( stricmp( Line, "ViaMinDrill" ) == 0 ) + { + g_DesignSettings.m_ViasMinDrill = atoi( data ); + continue; + } + if( stricmp( Line, "MicroViaDrill" ) == 0 ) { - g_DesignSettings.m_MicroViaDrill = atoi( data ); + int diameter = atoi( data ); + netclass_default->SetuViaDrill( diameter ); + continue; + } + + if( stricmp( Line, "MicroViaMinDrill" ) == 0 ) + { + int diameter = atoi( data ); + g_DesignSettings.m_MicroViasMinDrill = diameter; continue; } @@ -582,6 +593,7 @@ int WinEDA_BasePcbFrame::ReadSetup( FILE* File, int* LineNum ) static int WriteSetup( FILE* aFile, WinEDA_BasePcbFrame* aFrame, BOARD* aBoard ) /******************************************************************************/ { + NETCLASS * netclass_default = aFrame->GetBoard()->m_NetClasses.GetDefault(); char text[1024]; fprintf( aFile, "$SETUP\n" ); @@ -610,25 +622,27 @@ static int WriteSetup( FILE* aFile, WinEDA_BasePcbFrame* aFrame, BOARD* aBoard ) fprintf( aFile, "TrackWidthList %d\n", aBoard->m_TrackWidthList[ii] ); - fprintf( aFile, "TrackClearence %d\n", g_DesignSettings.m_TrackClearance ); + fprintf( aFile, "TrackClearence %d\n", netclass_default->GetClearance() ); fprintf( aFile, "ZoneClearence %d\n", g_Zone_Default_Setting.m_ZoneClearance ); fprintf( aFile, "TrackMinWidth %d\n" , g_DesignSettings.m_TrackMinWidth ); fprintf( aFile, "DrawSegmWidth %d\n", g_DesignSettings.m_DrawSegmentWidth ); fprintf( aFile, "EdgeSegmWidth %d\n", g_DesignSettings.m_EdgeSegmentWidth ); fprintf( aFile, "ViaSize %d\n", g_DesignSettings.m_CurrentViaSize ); - fprintf( aFile, "ViaDrill %d\n", g_DesignSettings.m_ViaDrill ); + fprintf( aFile, "ViaDrill %d\n", netclass_default->GetViaDrill() ); fprintf( aFile, "ViaAltDrill %d\n", g_DesignSettings.m_ViaDrillCustomValue ); fprintf( aFile, "ViaMinSize %d\n", g_DesignSettings.m_ViasMinSize ); + fprintf( aFile, "ViaMinDrill %d\n", g_DesignSettings.m_ViasMinDrill ); // Save custom vias diameters list (the first is not saved here: this is the netclass value for( unsigned ii = 1; ii < aBoard->m_ViaSizeList.size(); ii++ ) fprintf( aFile, "ViaSizeList %d\n", aBoard->m_ViaSizeList[ii] ); fprintf( aFile, "MicroViaSize %d\n", g_DesignSettings.m_CurrentMicroViaSize); - fprintf( aFile, "MicroViaDrill %d\n", g_DesignSettings.m_MicroViaDrill); + fprintf( aFile, "MicroViaDrill %d\n", netclass_default->GetuViaDrill()); fprintf( aFile, "MicroViasAllowed %d\n", g_DesignSettings.m_MicroViasAllowed); fprintf( aFile, "MicroViaMinSize %d\n" , g_DesignSettings.m_MicroViasMinSize ); + fprintf( aFile, "MicroViaMinDrill %d\n", g_DesignSettings.m_MicroViasMinDrill ); fprintf( aFile, "TextPcbWidth %d\n", g_DesignSettings.m_PcbTextWidth ); fprintf( aFile, "TextPcbSize %d %d\n", diff --git a/pcbnew/pcbcfg.cpp b/pcbnew/pcbcfg.cpp index 79d0d81134..e3ce05fc47 100644 --- a/pcbnew/pcbcfg.cpp +++ b/pcbnew/pcbcfg.cpp @@ -49,15 +49,6 @@ void WinEDA_PcbFrame::Process_Config( wxCommandEvent& event ) DisplayColorSetupFrame( this, pos ); break; -/* - case ID_PCB_COPPER_LAYERS_SETUP: - { - DIALOG_COPPER_LAYERS_SETUP dialog( this ); - dialog.ShowModal(); - } - break; -*/ - case ID_PCB_LAYERS_SETUP: DisplayDialogLayerSetup( this ); break; @@ -163,17 +154,14 @@ bool Read_Hotkey_Config( WinEDA_DrawFrame* frame, bool verbose ) } -/**************************************************************************/ -bool Read_Config( const wxString& projectFileName ) -/*************************************************************************/ - -/* lit la configuration, si elle n'a pas deja ete lue - * 1 - lit .pro - * 2 - si non trouve lit /kicad.pro - * 3 - si non trouve: init des variables aux valeurs par defaut - * - * Retourne TRUE si lu, FALSE si config non lue ou non modifiée +/** Function Read_Config + * Read the project configuration file + * @param projectFileName = the config filename + * if not found use kicad.pro + * if not found : initialize default values + * @return true if the current config is modified, false if no change */ +bool WinEDA_PcbFrame::Read_Config( const wxString& projectFileName ) { wxFileName fn = projectFileName; int ii; @@ -192,7 +180,7 @@ bool Read_Config( const wxString& projectFileName ) /* User library path takes precedent over default library search paths. */ wxGetApp().InsertLibraryPath( g_UserLibDirBuffer, 1 ); - /* Reset the ITEM*NOT*SHOW flag when loading a new config + /* Reset the items visibility flag when loading a new config * Because it could creates SERIOUS mistakes for the user, * if some items are not visible after loading a board... */ @@ -201,10 +189,6 @@ bool Read_Config( const wxString& projectFileName ) DisplayOpt.Show_Modules_Cmp = true; DisplayOpt.Show_Modules_Cu = true; - - // These parameters could be left in their previous state, or resetted - // Comment or uncomment to keep or reset this option after loading a board - g_DesignSettings.SetElementVisibility( MODULE_TEXT_NOV_VISIBLE, true ); g_DesignSettings.SetElementVisibility( MODULE_TEXT_CMP_VISIBLE, true ); g_DesignSettings.SetElementVisibility( MODULE_TEXT_CU_VISIBLE, true ); @@ -213,6 +197,8 @@ bool Read_Config( const wxString& projectFileName ) g_DesignSettings.SetElementVisibility( VIA_THROUGH_VISIBLE, true ); g_DesignSettings.SetElementVisibility( VIA_BLIND_BURIED_VISIBLE, true ); g_DesignSettings.SetElementVisibility( VIA_MICROVIA_VISIBLE, true ); + + // Items that can remain not visible: comment them if you want. g_DesignSettings.SetElementVisibility( ANCHOR_VISIBLE, true ); DisplayOpt.DisplayPadNoConn = true; diff --git a/pcbnew/pcbcfg.h b/pcbnew/pcbcfg.h index d22ea9db0e..36327ff804 100644 --- a/pcbnew/pcbcfg.h +++ b/pcbnew/pcbcfg.h @@ -64,21 +64,6 @@ static PARAM_CFG_INT ViaDiametreCfg 0, 0xFFFF /* Min and max values*/ ); -static PARAM_CFG_INT ViaDrillCfg -( - wxT( "ViaDril" ), /* Keyword */ - &g_DesignSettings.m_ViaDrill, /* Parameter address */ - 250, /* Default value */ - 0, 0xFFFF /* Min and max values*/ -); - -static PARAM_CFG_INT ViaAltDrillCfg -( - wxT( "ViaAltD" ), /* Keyword */ - &g_DesignSettings.m_ViaDrillCustomValue, /* Parameter address */ - 250, /* Default value */ - 0, 0xFFFF /* Min and max values*/ -); static PARAM_CFG_INT LayerThicknessCfg ( wxT( "LayerThickness" ), /* Keyword */ @@ -95,14 +80,6 @@ static PARAM_CFG_INT MicroViaDiametreCfg 0, 1000 /* Min and max values*/ ); -static PARAM_CFG_INT MicroViaDrillCfg -( - wxT( "MViaDrl" ), /* Keyword */ - &g_DesignSettings.m_MicroViaDrill, /* Parameter address */ - 80, /* Default value */ - 0, 800 /* Min and max values*/ -); - static PARAM_CFG_INT ViaShowHoleCfg ( INSETUP, @@ -123,30 +100,6 @@ static PARAM_CFG_INT ShowNetNamesModeCfg 3 /* Min and max values*/ ); -static PARAM_CFG_INT TrackClearenceCfg -( - wxT( "Isol" ), /* Keyword */ - &g_DesignSettings.m_TrackClearance, /* Parameter address */ - 120, /* Default value */ - 0, 0xFFFF /* Min and max values*/ -); - -static PARAM_CFG_INT LayerCountCfg // Mask Working Layers -( - wxT( "Countlayer" ), /* Keyword */ - &g_DesignSettings.m_CopperLayerCount, /* Parameter address */ - 2, /* Default value */ - 1, NB_COPPER_LAYERS /* Min and max values*/ -); - -static PARAM_CFG_INT TrackWidthCfg -( - wxT( "Lpiste" ), /* Keyword */ - &g_DesignSettings.m_CurrentTrackWidth, /* Parameter address */ - 170, /* Default value */ - 2, 0xFFFF /* Min and max values*/ -); - static PARAM_CFG_INT RouteLayTopCfg // First current working layer ( wxT( "RouteTo" ), /* Keyword */ @@ -163,14 +116,6 @@ static PARAM_CFG_INT RouteLayBotCfg // second current working layer 0, 15 /* Min and max values*/ ); -static PARAM_CFG_INT TypeViaCfg -( - wxT( "TypeVia" ), /* Keyword */ - &g_DesignSettings.m_CurrentViaType, /* Parameter address */ - VIA_THROUGH, /* Default value */ - 0, 3 /* Min and max values*/ -); - static PARAM_CFG_BOOL Segm45Cfg // Segm Pistes a 0, 45, 90 degres uniquement ( wxT( "Segm45" ), /* Keyword */ @@ -801,26 +746,19 @@ PARAM_CFG_BASE* ParamCfgList[] = &PadDimHCfg, &PadDimVCfg, &ViaDiametreCfg, - &ViaDrillCfg, - &ViaAltDrillCfg, &MicroViaDiametreCfg, - &MicroViaDrillCfg, &ViaShowHoleCfg, &ShowNetNamesModeCfg, - &TrackClearenceCfg, &LayerThicknessCfg, - &LayerCountCfg, - &TrackWidthCfg, &RouteLayTopCfg, &RouteLayBotCfg, - &TypeViaCfg, &Segm45Cfg, &Raccord45Cfg, &UnitCfg, &SegmFillCfg, &TrackDisplayClearanceCfg, &PadFillCfg, - &ViaFillCfg, //TODO: Will adding this line break tha pcbnew file compatibility? + &ViaFillCfg, &PadAfficheGardeCfg, &PadShowNumCfg, &AfficheContourModuleCfg, diff --git a/pcbnew/pcbnew.cpp b/pcbnew/pcbnew.cpp index ca9abc4c92..36de322200 100644 --- a/pcbnew/pcbnew.cpp +++ b/pcbnew/pcbnew.cpp @@ -123,7 +123,7 @@ Changing extension to .brd." ), SetupServerFunction( RemoteCommand ); } - Read_Config( fn.GetFullPath() ); + frame->Read_Config( fn.GetFullPath() ); frame->Zoom_Automatique( true ); diff --git a/pcbnew/print_board_functions.cpp b/pcbnew/print_board_functions.cpp index e91e49cced..c19c9df3e0 100644 --- a/pcbnew/print_board_functions.cpp +++ b/pcbnew/print_board_functions.cpp @@ -147,7 +147,7 @@ void WinEDA_DrawPanel::PrintPage( wxDC* aDC, bool aPrint_Sheet_Ref, int aPrintMa continue; if( pt_piste->Type() == TYPE_VIA ) /* VIA rencontree */ { - int rayon = g_DesignSettings.m_ViaDrill / 2; + int rayon = pt_piste->GetDrillValue() / 2; GRFilledCircle( &m_ClipBox, aDC, pt_piste->m_Start.x, pt_piste->m_Start.y, rayon, 0, color, color ); } diff --git a/pcbnew/protos.h b/pcbnew/protos.h index 7d53893646..a2755e6b1d 100644 --- a/pcbnew/protos.h +++ b/pcbnew/protos.h @@ -50,7 +50,6 @@ void CreateSortedPadListByXCoord( BOARD* aBoard, std::vector* aVector ); /**************/ /* PCBCFG.CPP */ /**************/ -bool Read_Config( const wxString& project_name ); bool Read_Hotkey_Config( WinEDA_DrawFrame* frame, bool verbose ); diff --git a/pcbnew/solve.cpp b/pcbnew/solve.cpp index 7e337762ad..b0dbda6691 100644 --- a/pcbnew/solve.cpp +++ b/pcbnew/solve.cpp @@ -31,6 +31,7 @@ static int segm_oX, segm_oY; static int segm_fX, segm_fY; /* Origine et fin de la piste en cours de trace */ static RATSNEST_ITEM* pt_cur_ch; static int Ncurrent; /* measures of progress */ +static int s_Clearance; // Clerance value used in autorouter #define NOSUCCESS 0 @@ -219,6 +220,8 @@ int WinEDA_PcbFrame::Solve( wxDC* DC, int two_sides ) DrawPanel->m_AbortRequest = FALSE; DrawPanel->m_AbortEnable = TRUE; + s_Clearance = GetBoard()->m_NetClasses.GetDefault()->GetClearance(); + Ncurrent = 0; MsgPanel->EraseMsgBox(); msg.Printf( wxT( "%d " ), GetBoard()->m_NbNoconnect ); @@ -355,8 +358,8 @@ static int Autoroute_One_Track( WinEDA_PcbFrame* pcbframe, wxDC* DC, result = NOSUCCESS; - marge = g_DesignSettings.m_TrackClearance + (g_DesignSettings.m_CurrentTrackWidth / 2); - via_marge = g_DesignSettings.m_TrackClearance + (g_DesignSettings.m_CurrentViaSize / 2); + marge = s_Clearance + (g_DesignSettings.m_CurrentTrackWidth / 2); + via_marge = s_Clearance + (g_DesignSettings.m_CurrentViaSize / 2); /* clear direction flags */ i = Nrows * Ncols * sizeof(char); @@ -1048,8 +1051,8 @@ static void Place_Piste_en_Buffer( WinEDA_PcbFrame* pcbframe, wxDC* DC ) int marge, via_marge; WinEDA_DrawPanel* panel = pcbframe->DrawPanel; - marge = g_DesignSettings.m_TrackClearance + (g_DesignSettings.m_CurrentTrackWidth / 2); - via_marge = g_DesignSettings.m_TrackClearance + (g_DesignSettings.m_CurrentViaSize / 2); + marge = s_Clearance + (g_DesignSettings.m_CurrentTrackWidth / 2); + via_marge = s_Clearance + (g_DesignSettings.m_CurrentViaSize / 2); /* tst point d'arrivee : doit etre sur pad start */ diff --git a/pcbnew/specctra_export.cpp b/pcbnew/specctra_export.cpp index 4402a544a7..f9ee4db318 100644 --- a/pcbnew/specctra_export.cpp +++ b/pcbnew/specctra_export.cpp @@ -1113,10 +1113,7 @@ void SPECCTRA_DB::FromBOARD( BOARD* aBoard ) throw( IOError ) std::string componentId; // find the highest numbered netCode within the board. - int highestNetCode = -1; -// for( EQUIPOT* equipot = aBoard->m_Equipots; equipot; equipot = equipot->Next() ) -// highestNetCode = MAX( highestNetCode, equipot->GetNet() ); - highestNetCode = aBoard->m_NetInfo->GetCount() - 1; + int highestNetCode = aBoard->m_NetInfo->GetCount() - 1; deleteNETs(); // expand the net vector to highestNetCode+1, setting empty to NULL @@ -1236,12 +1233,15 @@ void SPECCTRA_DB::FromBOARD( BOARD* aBoard ) throw( IOError ) // Next we add the via's which may be used. int defaultViaSize = aBoard->m_BoardSettings->m_CurrentViaSize; -// TODO: output vias sizes in NetClasses + int defaultViaDrill = aBoard->m_NetClasses.GetDefault()->GetViaDrill(); +/** + *@todo: *** output vias sizes and drill in NetClasses *** +*/ /* I need at least one via for the (class...) scope below if( defaultViaSize ) */ { - PADSTACK* padstack = makeVia( defaultViaSize, g_DesignSettings.m_ViaDrill, + PADSTACK* padstack = makeVia( defaultViaSize, defaultViaDrill, 0, aBoard->GetCopperLayerCount()-1 ); pcb->library->AddPadstack( padstack ); @@ -1258,7 +1258,7 @@ void SPECCTRA_DB::FromBOARD( BOARD* aBoard ) throw( IOError ) if( viaSize == defaultViaSize ) continue; - PADSTACK* padstack = makeVia( viaSize, g_DesignSettings.m_ViaDrill, + PADSTACK* padstack = makeVia( viaSize, defaultViaDrill, 0, aBoard->GetCopperLayerCount()-1 ); pcb->library->AddPadstack( padstack ); } diff --git a/pcbnew/specctra_import.cpp b/pcbnew/specctra_import.cpp index d14977b1fa..fb1ec21b1c 100644 --- a/pcbnew/specctra_import.cpp +++ b/pcbnew/specctra_import.cpp @@ -242,9 +242,9 @@ SEGVIA* SPECCTRA_DB::makeVIA( PADSTACK* aPadstack, const POINT& aPoint, int aNet // drillMils is not in the session units, but actual mils so we don't use scale() drillDiam = (int) (drillMils * 10); - - if( drillDiam == g_DesignSettings.m_ViaDrill ) // default - drillDiam = -1; // import as default +/** @todo: see if we use default netclass or specific value +*/ + drillDiam = -1; // import as default: real drill is the netclass value } } diff --git a/pcbnew/zones_convert_brd_items_to_polygons.cpp b/pcbnew/zones_convert_brd_items_to_polygons.cpp index 7b8323e2f7..18cf46c3ef 100644 --- a/pcbnew/zones_convert_brd_items_to_polygons.cpp +++ b/pcbnew/zones_convert_brd_items_to_polygons.cpp @@ -193,23 +193,35 @@ void ZONE_CONTAINER::AddClearanceAreasPolygonsToPolysList( BOARD* aPcb ) */ CopyPolygonsFromFilledPolysListToBoolengine( booleng, GROUP_A ); - // Calculates the clearance value that meet DRC requirements - int clearance = max( m_ZoneClearance, g_DesignSettings.m_TrackClearance ); - clearance += m_ZoneMinThickness / 2; + /* Calculates the clearance value that meet DRC requirements + * from m_ZoneClearance and clearance from the corresponding netclass + * We have a "local" clearance in zones because most of time + * clearance between a zone and others items is bigger than the netclass clearance + * this is more true for small clearance values + * Note also the "local" clearance is used for clearance between non copper items + * or items like texts on copper layers + */ + int zone_clearance = max( m_ZoneClearance, GetClearance() ); + zone_clearance += m_ZoneMinThickness / 2; /* Add holes (i.e. tracks and pads areas as polygons outlines) * in GroupB in Bool_Engine */ - /* items ouside the zone bounding box are skipped */ + /* items ouside the zone bounding box are skipped + * the bounding box is the zone bounding box + the biigest clearance found in Netclass list + */ EDA_Rect item_boundingbox; EDA_Rect zone_boundingbox = GetBoundingBox(); - zone_boundingbox.Inflate( m_ZoneClearance, clearance ); + int biggest_clearance = aPcb->GetBiggestClearanceValue(); + biggest_clearance = MAX( biggest_clearance, zone_clearance ); + zone_boundingbox.Inflate( biggest_clearance, biggest_clearance ); /* * First : Add pads. Note: pads having the same net as zone are left in zone. * Thermal shapes will be created later if necessary */ + int item_clearance; have_poly_to_substract = false; for( MODULE* module = aPcb->m_Modules; module; module = module->Next() ) { @@ -220,18 +232,19 @@ void ZONE_CONTAINER::AddClearanceAreasPolygonsToPolysList( BOARD* aPcb ) if( pad->GetNet() != GetNet() ) { + item_clearance = pad->GetClearance() + (m_ZoneMinThickness / 2); item_boundingbox = pad->GetBoundingBox(); if( item_boundingbox.Intersects( zone_boundingbox ) ) { - AddPadWithClearancePolygon( booleng, *pad, clearance ); + AddPadWithClearancePolygon( booleng, *pad, MAX(zone_clearance,item_clearance) ); have_poly_to_substract = true; } continue; } - int gap = clearance; + int gap = zone_clearance; #ifdef USE_STUBS_FOR_THERMAL - gap = MAX( clearance, m_ThermalReliefGapValue ); + gap = MAX( zone_clearance, m_ThermalReliefGapValue ); #else if( (m_PadOption == PAD_NOT_IN_ZONE) || (GetNet() == 0) || pad->m_PadShape == PAD_TRAPEZOID ) @@ -259,10 +272,12 @@ void ZONE_CONTAINER::AddClearanceAreasPolygonsToPolysList( BOARD* aPcb ) continue; if( track->GetNet() == GetNet() && (GetNet() != 0) ) continue; + + item_clearance = track->GetClearance() + (m_ZoneMinThickness / 2); item_boundingbox = track->GetBoundingBox(); if( item_boundingbox.Intersects( zone_boundingbox ) ) { - AddTrackWithClearancePolygon( booleng, *track, clearance ); + AddTrackWithClearancePolygon( booleng, *track, MAX(zone_clearance,item_clearance) ); have_poly_to_substract = true; } } @@ -1338,13 +1353,13 @@ void AddRoundedEndsSegmentPolygon( Bool_Engine* aBooleng, int delta = 3600 / s_CircleToSegmentsCount; // rot angle in 0.1 degree - + #ifdef CREATE_KBOOL_KEY_FILES if( s_GenDataForKbool ) StartPolygon(s_CircleToSegmentsCount+4, 1); #endif - + // Compute the outlines of the segment, and creates a polygon corner = wxPoint( 0, rayon ); RotatePoint( &corner, -delta_angle ); diff --git a/pcbnew/zones_test_and_combine_areas.cpp b/pcbnew/zones_test_and_combine_areas.cpp index 994bd71efc..f9f5eead61 100644 --- a/pcbnew/zones_test_and_combine_areas.cpp +++ b/pcbnew/zones_test_and_combine_areas.cpp @@ -846,6 +846,7 @@ int BOARD::Test_Drc_Areas_Outlines_To_Areas_Outlines( ZONE_CONTAINER* aArea_To_E { wxString str; long nerrors = 0; + int zone2zoneClearance; // iterate through all areas for( int ia = 0; ia < GetAreaCount(); ia++ ) @@ -856,6 +857,7 @@ int BOARD::Test_Drc_Areas_Outlines_To_Areas_Outlines( ZONE_CONTAINER* aArea_To_E if( aArea_To_Examine && (aArea_To_Examine != Area_Ref) ) continue; + for( int ia2 = 0; ia2 < GetAreaCount(); ia2++ ) { ZONE_CONTAINER* Area_To_Test = GetArea( ia2 ); @@ -871,6 +873,14 @@ int BOARD::Test_Drc_Areas_Outlines_To_Areas_Outlines( ZONE_CONTAINER* aArea_To_E if( Area_Ref->GetNet() == Area_To_Test->GetNet() && Area_Ref->GetNet() >= 0 ) continue; + /* Examine a candidate zone: compare Area_To_Test to Area_Ref + */ + + // Calculate the clearance used in zone to zone test: + zone2zoneClearance = Area_Ref->GetClearance(Area_To_Test); + zone2zoneClearance = MAX( zone2zoneClearance, Area_Ref->m_ZoneClearance ); + zone2zoneClearance = MAX( zone2zoneClearance, Area_To_Test->m_ZoneClearance ); + // test for some corners of Area_Ref inside Area_To_Test for( int ic = 0; ic < Area_Ref->m_Poly->GetNumCorners(); ic++ ) { @@ -962,12 +972,10 @@ int BOARD::Test_Drc_Areas_Outlines_To_Areas_Outlines( ZONE_CONTAINER* aArea_To_E ax1, ay1, ax2, ay2, astyle, 0, - - // @todo: decide what to use here. - g_DesignSettings.m_TrackClearance, + zone2zoneClearance, &x, &y ); - if( d < g_DesignSettings.m_TrackClearance ) + if( d < zone2zoneClearance ) { // COPPERAREA_COPPERAREA error : intersect or too close if( aCreate_Markers )