KiCad PCB EDA Suite
Loading...
Searching...
No Matches
trace_helpers.cpp
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2018 Wayne Stambaugh <[email protected]>
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
25
26#include <trace_helpers.h>
27
28#include <wx/tokenzr.h>
29
30const wxChar* const traceFindReplace = wxT( "KICAD_FIND_REPLACE" );
31const wxChar* const kicadTraceCoords = wxT( "KICAD_COORDS" );
32const wxChar* const kicadTraceKeyEvent = wxT( "KICAD_KEY_EVENTS" );
33const wxChar* const kicadTraceToolStack = wxT( "KICAD_TOOL_STACK" );
34const wxChar* const kicadTraceCoroutineStack = wxT( "KICAD_COROUTINE_STACK" );
35const wxChar* const traceSchLibMem = wxT( "KICAD_SCH_LIB_MEM" );
36const wxChar* const traceFindItem = wxT( "KICAD_FIND_ITEM" );
37const wxChar* const traceSchLegacyPlugin = wxT( "KICAD_SCH_LEGACY_PLUGIN" );
38const wxChar* const traceSchPlugin = wxT( "KICAD_SCH_PLUGIN" );
39const wxChar* const traceGedaPcbPlugin = wxT( "KICAD_GEDA_PLUGIN" );
40const wxChar* const traceKicadPcbPlugin = wxT( "KICAD_PCB_PLUGIN" );
41const wxChar* const tracePrinting = wxT( "KICAD_PRINT" );
42const wxChar* const traceAutoSave = wxT( "KICAD_AUTOSAVE" );
43const wxChar* const tracePathsAndFiles = wxT( "KICAD_PATHS_AND_FILES" );
44const wxChar* const traceLocale = wxT( "KICAD_LOCALE" );
45const wxChar* const traceFonts = wxT( "KICAD_FONTS" );
46const wxChar* const traceScreen = wxT( "KICAD_SCREEN" );
47const wxChar* const traceZoomScroll = wxT( "KICAD_ZOOM_SCROLL" );
48const wxChar* const traceSymbolResolver = wxT( "KICAD_SYM_RESOLVE" );
49const wxChar* const traceDisplayLocation = wxT( "KICAD_DISPLAY_LOCATION" );
50const wxChar* const traceSchSheetPaths = wxT( "KICAD_SCH_SHEET_PATHS" );
51const wxChar* const traceSchCurrentSheet = wxT( "KICAD_SCH_CURRENT_SHEET" );
52const wxChar* const traceSchFieldRendering = wxT( "KICAD_SCH_FIELD_RENDERING" );
53const wxChar* const traceSchPainter = wxT( "KICAD_SCH_PAINTER" );
54const wxChar* const traceSchSymbolRef = wxT( "KICAD_SCH_SYMBOL_REF" );
55const wxChar* const traceEnvVars = wxT( "KICAD_ENV_VARS" );
56const wxChar* const traceSchDragNetCollision = wxT( "KICAD_SCH_DRAG_NET_COLLISION" );
57const wxChar* const traceCrossProbeFlash = wxT( "CROSS_PROBE_FLASH" );
58const wxChar* const traceGalProfile = wxT( "KICAD_GAL_PROFILE" );
59const wxChar* const traceStackedPins = wxT( "KICAD_STACKED_PINS" );
60const wxChar* const traceLibWatch = wxT( "KICAD_LIB_WATCH" );
61const wxChar* const traceKiCad2Step = wxT( "KICAD2STEP" );
62const wxChar* const traceUiProfile = wxT( "KICAD_UI_PROFILE" );
63const wxChar* const traceGit = wxT( "KICAD_GIT" );
64const wxChar* const traceDiffMerge = wxT( "KICAD_DIFF_MERGE" );
65const wxChar* const traceEagleIo = wxT( "KICAD_EAGLE_IO" );
66const wxChar* const traceDiptraceIo = wxT( "KICAD_DIPTRACE_IO" );
67const wxChar* const traceDesignBlocks = wxT( "KICAD_DESIGN_BLOCK" );
68const wxChar* const traceLibFieldTable = wxT( "KICAD_LIB_FIELD_TABLE" );
69const wxChar* const tracePdfPlotter = wxT( "KICAD_PDF_PLOTTER" );
70const wxChar* const traceSnap = wxT( "KICAD_SNAP" );
71const wxChar* const traceLibraries = wxT( "KICAD_LIBRARIES" );
72const wxChar* const traceSchMove = wxT( "KICAD_SCH_MOVE" );
73const wxChar* const traceSymbolInheritance = wxT( "KICAD_SYMBOL_INHERITANCE" );
74const wxChar* const traceSchNetChain = wxT( "KICAD_SCH_NETCHAIN" );
75
76#ifdef KICAD_GAL_PROFILE
77LATENCY_PROBE latencyProbeZoomToRender( "zoom-to-render", 16 );
78LATENCY_PROBE latencyProbeRepaintToMotion( "repaint-to-motion", 16 );
79#endif
80
81wxString dump( const wxArrayString& aArray )
82{
83 wxString tmp;
84
85 for( unsigned i = 0; i < aArray.GetCount(); i++ )
86 {
87 if( aArray[i].IsEmpty() )
88 tmp << wxT( "\"\" " );
89 else
90 tmp << aArray[i] << wxT( " " );
91 }
92
93 return tmp;
94}
95
96
97// The following code was shamelessly copied from the wxWidgets keyboard sample
98// at https://github.com/wxWidgets/wxWidgets/blob/master/samples/keyboard/keyboard.cpp.
99
101// Author: Vadim Zeitlin
102// Modified by: Marcin Wojdyr
103// Created: 07.04.02
104// Copyright: (c) 2002 Vadim Zeitlin
105// Licence: wxWindows licence
107
108// helper function that returns textual description of wx virtual keycode
109const char* GetVirtualKeyCodeName(int keycode)
110{
111 switch ( keycode )
112 {
113#define WXK_(x) \
114 case WXK_##x: return #x;
115
116 WXK_(BACK)
117 WXK_(TAB)
118 WXK_(RETURN)
119 WXK_(ESCAPE)
120 WXK_(SPACE)
121 WXK_(DELETE)
122 WXK_(START)
123 WXK_(LBUTTON)
124 WXK_(RBUTTON)
125 WXK_(CANCEL)
126 WXK_(MBUTTON)
127 WXK_(CLEAR)
128 WXK_(SHIFT)
129 WXK_(ALT)
131 WXK_(MENU)
132 WXK_(PAUSE)
133 WXK_(CAPITAL)
134 WXK_(END)
135 WXK_(HOME)
136 WXK_(LEFT)
137 WXK_(UP)
138 WXK_(RIGHT)
139 WXK_(DOWN)
140 WXK_(SELECT)
141 WXK_(PRINT)
142 WXK_(EXECUTE)
143 WXK_(SNAPSHOT)
144 WXK_(INSERT)
145 WXK_(HELP)
146 WXK_(NUMPAD0)
147 WXK_(NUMPAD1)
148 WXK_(NUMPAD2)
149 WXK_(NUMPAD3)
150 WXK_(NUMPAD4)
151 WXK_(NUMPAD5)
152 WXK_(NUMPAD6)
153 WXK_(NUMPAD7)
154 WXK_(NUMPAD8)
155 WXK_(NUMPAD9)
157 WXK_(ADD)
160 WXK_(DECIMAL)
161 WXK_(DIVIDE)
162 WXK_(F1)
163 WXK_(F2)
164 WXK_(F3)
165 WXK_(F4)
166 WXK_(F5)
167 WXK_(F6)
168 WXK_(F7)
169 WXK_(F8)
170 WXK_(F9)
171 WXK_(F10)
172 WXK_(F11)
173 WXK_(F12)
174 WXK_(F13)
175 WXK_(F14)
176 WXK_(F15)
177 WXK_(F16)
178 WXK_(F17)
179 WXK_(F18)
180 WXK_(F19)
181 WXK_(F20)
182 WXK_(F21)
183 WXK_(F22)
184 WXK_(F23)
185 WXK_(F24)
186 WXK_(NUMLOCK)
187 WXK_(SCROLL)
188 WXK_(PAGEUP)
189 WXK_(PAGEDOWN)
190 WXK_(NUMPAD_SPACE)
191 WXK_(NUMPAD_TAB)
192 WXK_(NUMPAD_ENTER)
193 WXK_(NUMPAD_F1)
194 WXK_(NUMPAD_F2)
195 WXK_(NUMPAD_F3)
196 WXK_(NUMPAD_F4)
197 WXK_(NUMPAD_HOME)
198 WXK_(NUMPAD_LEFT)
199 WXK_(NUMPAD_UP)
200 WXK_(NUMPAD_RIGHT)
201 WXK_(NUMPAD_DOWN)
202 WXK_(NUMPAD_PAGEUP)
203 WXK_(NUMPAD_PAGEDOWN)
204 WXK_(NUMPAD_END)
205 WXK_(NUMPAD_BEGIN)
206 WXK_(NUMPAD_INSERT)
207 WXK_(NUMPAD_DELETE)
208 WXK_(NUMPAD_EQUAL)
209 WXK_(NUMPAD_MULTIPLY)
210 WXK_(NUMPAD_ADD)
211 WXK_(NUMPAD_SEPARATOR)
212 WXK_(NUMPAD_SUBTRACT)
213 WXK_(NUMPAD_DECIMAL)
214 WXK_(NUMPAD_DIVIDE)
215
216 WXK_(WINDOWS_LEFT)
217 WXK_(WINDOWS_RIGHT)
218#ifdef __WXOSX__
219 WXK_(RAW_CONTROL)
220#endif
221#undef WXK_
222
223 default:
224 return nullptr;
225 }
226}
227
228
229// helper function that returns textual description of key in the event
230wxString GetKeyName( const wxKeyEvent &aEvent )
231{
232 int keycode = aEvent.GetKeyCode();
233 const char* virt = GetVirtualKeyCodeName( keycode );
234
235 if( virt )
236 return virt;
237
238 if( keycode > 0 && keycode < 32 )
239 return wxString::Format( "Ctrl-%c", (unsigned char)('A' + keycode - 1) );
240
241 if( keycode >= 32 && keycode < 128 )
242 return wxString::Format( "'%c'", (unsigned char)keycode );
243
244#if wxUSE_UNICODE
245 int uc = aEvent.GetUnicodeKey();
246
247 if( uc != WXK_NONE )
248 return wxString::Format( "'%c'", uc );
249#endif
250
251 return "unknown";
252}
253
254
255wxString dump( const wxKeyEvent& aEvent )
256{
257 wxString msg;
258 wxString eventType = wxS( "unknown" );
259
260 if( aEvent.GetEventType() == wxEVT_KEY_DOWN )
261 eventType = wxS( "KeyDown" );
262 else if( aEvent.GetEventType() == wxEVT_KEY_UP )
263 eventType = wxS( "KeyUp" );
264 else if( aEvent.GetEventType() == wxEVT_CHAR )
265 eventType = wxS( "Char" );
266 else if( aEvent.GetEventType() == wxEVT_CHAR_HOOK )
267 eventType = wxS( "Hook" );
268
269 // event key_name KeyCode modifiers Unicode raw_code raw_flags pos
270 msg.Printf( "%7s %15s %5d %c%c%c%c"
271#if wxUSE_UNICODE
272 "%5d (U+%04x)"
273#else
274 " none "
275#endif
276#ifdef wxHAS_RAW_KEY_CODES
277 " %7lu 0x%08lx"
278#else
279 " not-set not-set"
280#endif
281 " (%5d,%5d)",
282 eventType,
283 GetKeyName( aEvent ),
284 aEvent.GetKeyCode(),
285 aEvent.ControlDown() ? 'C' : '-',
286 aEvent.AltDown() ? 'A' : '-',
287 aEvent.ShiftDown() ? 'S' : '-',
288 aEvent.MetaDown() ? 'M' : '-'
289#if wxUSE_UNICODE
290 , aEvent.GetUnicodeKey()
291 , aEvent.GetUnicodeKey()
292#endif
293#ifdef wxHAS_RAW_KEY_CODES
294 , (unsigned long) aEvent.GetRawKeyCode()
295 , (unsigned long) aEvent.GetRawKeyFlags()
296#endif
297 , aEvent.GetX()
298 , aEvent.GetY()
299 );
300
301 return msg;
302}
303
@ ADD
Definition am_param.h:146
@ SUBTRACT
Definition cursors.h:68
const wxChar *const traceSchPainter
Flag to enable debug output of schematic painter operations.
const wxChar *const traceSchSymbolRef
Flag to enable debug output of schematic symbol reference resolution.
const wxChar *const traceLibraries
Flag to enable library table and library manager tracing.
const wxChar *const traceSymbolResolver
Flag to enable debug output of symbol library resolver results.
const wxChar *const traceSchFieldRendering
Flag to enable debug output of schematic field rendering and positioning.
const wxChar *const traceDiffMerge
Flag to enable diff/merge engine and renderer debugging output.
const wxChar *const traceLibWatch
Flag to enable debug output for library file watch refreshes.
const wxChar *const traceSymbolInheritance
Flag to enable tracing of circular symbol inheritance detection.
const wxChar *const traceLocale
Flag to enable locale debug output.
const wxChar *const traceSchCurrentSheet
Flag to enable debug output of current sheet tracking in the schematic editor.
const wxChar *const traceKicadPcbPlugin
Flag to enable KiCad PCB plugin debug output.
const wxChar *const traceAutoSave
Flag to enable auto save feature debug tracing.
const wxChar *const kicadTraceKeyEvent
Flag to enable wxKeyEvent debug tracing.
const wxChar *const traceUiProfile
Flag to enable user interface profile tracing.
const wxChar *const traceEnvVars
Flag to enable debug output of environment variable operations.
const wxChar *const traceFindReplace
Flag to enable find and replace debug tracing.
const wxChar *const traceFindItem
Flag to enable find debug tracing.
const wxChar *const kicadTraceCoroutineStack
Flag to enable tracing of the coroutine call stack.
const wxChar *const traceSchLibMem
Flag to enable schematic library memory deletion debug output.
const wxChar *const traceEagleIo
const wxChar *const tracePathsAndFiles
Flag to enable path and file name debug output.
const wxChar *const traceKiCad2Step
Flag to enable KiCad2Step debug tracing.
const wxChar *const traceSchPlugin
Flag to enable legacy schematic plugin debug output.
const wxChar *const traceSchSheetPaths
Flag to enable debug output of schematic symbol sheet path manipulation code.
const wxChar *const traceSchNetChain
Flag to enable tracing of schematic net chain rebuild and ERC cross-chain checks.
const wxChar *const traceSchDragNetCollision
Flag to enable debug output of schematic drag net collision detection.
const wxChar *const traceCrossProbeFlash
Flag to enable debug output for cross-probe flash operations.
const wxChar *const traceSchLegacyPlugin
Flag to enable legacy schematic plugin debug output.
const wxChar *const traceSchMove
Flag to watch how schematic move tool actions are handled.
const wxChar *const tracePrinting
Flag to enable print controller debug output.
const wxChar *const kicadTraceCoords
Flag to enable draw panel coordinate debug tracing.
const wxChar *const traceZoomScroll
Flag to enable debug output of zoom-scrolling calculations in KIGFX::ZOOM_CONTROLLER and derivatives.
const wxChar *const traceGedaPcbPlugin
Flag to enable GEDA PCB plugin debug output.
const wxChar *const traceScreen
Flag to enable debug output of BASE_SCREEN and it's derivatives.
const wxChar *const traceSnap
Flag to enable snap/grid helper debug tracing.
const wxChar *const tracePdfPlotter
Flag to enable PDF plotter debug tracing.
const wxChar *const traceDesignBlocks
const wxChar *const traceStackedPins
Flag to enable debug output for stacked pins handling in symbol/pin code.
const wxChar *const traceFonts
Flag to enable locale debug output.
const wxChar *const traceDiptraceIo
const wxChar *const traceGit
Flag to enable Git debugging output.
const wxChar *const traceDisplayLocation
Flag to enable debug output of display positioning logic.
const wxChar *const traceLibFieldTable
const wxChar *const kicadTraceToolStack
Flag to enable tracing of the tool handling stack.
const wxChar *const traceGalProfile
Flag to enable debug output of GAL performance profiling.
static VECTOR2D CLEAR
wxString dump(const wxArrayString &aArray)
Debug helper for printing wxArrayString contents.
#define WXK_(x)
wxString GetKeyName(const wxKeyEvent &aEvent)
const char * GetVirtualKeyCodeName(int keycode)
wxLogTrace helper definitions.
#define SEPARATOR