26#include <wx/tokenzr.h>
57 const wxString& aSearchText )
65 if( !aSearchHierarchy )
66 sheetList.push_back(
m_frame->GetCurrentSheet() );
68 sheetList =
m_frame->Schematic().Hierarchy();
84 found = ( *aPath ==
path );
88 found = ( aReference && aReference->CmpNoCase( candidate->
GetRef( &sheet ) ) == 0 );
94 sheetWithSymbolFound = &sheet;
103 int unit =
pin->GetLibPin()->GetUnit();
105 if( unit != 0 && unit != symbol->
GetUnit() )
132 if( *sheetWithSymbolFound !=
m_frame->GetCurrentSheet() )
135 sheetWithSymbolFound );
150 m_frame->FocusOnItem( symbol );
159 displayRef = *aReference;
168 msg.Printf(
_(
"%s pin %s found" ), displayRef, aSearchText );
170 msg.Printf(
_(
"%s found but pin %s not found" ), displayRef, aSearchText );
174 msg.Printf(
_(
"%s found" ), displayRef );
179 msg.Printf(
_(
"%s not found" ), displayRef );
183 m_frame->GetCanvas()->Refresh();
208 strncpy( line, cmdline,
sizeof( line ) - 1 );
209 line[
sizeof( line ) - 1 ] =
'\0';
211 char* idcmd = strtok( line,
" \n\r" );
212 char*
text = strtok(
nullptr,
"\"\n\r" );
214 if( idcmd ==
nullptr )
219 if( strcmp( idcmd,
"$CONFIG" ) == 0 )
224 else if( strcmp( idcmd,
"$ERC" ) == 0 )
229 else if( strcmp( idcmd,
"$NET:" ) == 0 )
236 if(
auto sg =
Schematic().ConnectionGraph()->FindFirstSubgraphByName( netName ) )
254 SetStatusText(
_(
"Highlighted net:" ) + wxS(
" " ) +
UnescapeString( netName ) );
257 else if( strcmp( idcmd,
"$CLEAR:" ) == 0 )
266 if(
text ==
nullptr )
269 if( strcmp( idcmd,
"$PART:" ) != 0 )
275 idcmd = strtok(
nullptr,
" \n\r" );
277 if( idcmd ==
nullptr )
284 text = strtok(
nullptr,
"\"\n\r" );
286 if(
text ==
nullptr )
291 if( strcmp( idcmd,
"$REF:" ) == 0 )
297 else if( strcmp( idcmd,
"$VAL:" ) == 0 )
303 else if( strcmp( idcmd,
"$PAD:" ) == 0 )
316 std::vector<wxString> parts;
320 switch( item->Type() )
337 parts.push_back( wxT(
"S" ) + full_path );
360 std::string command =
"$SELECT: 0,";
362 for( wxString part : parts )
389 std::string packet = fmt::format(
"$NET: \"{}\"",
TO_UTF8( aNetName ) );
391 if( !packet.empty() )
416 if( aConnection->
IsNet() )
422 if( aConnection->
Members().empty() )
427 wxString nets = all_members[0]->Name();
429 if( all_members.size() == 1 )
439 for(
size_t i = 1; i < all_members.size(); i++ )
440 nets <<
"," << all_members[i]->Name();
442 std::string packet = fmt::format(
"$NETS: \"{}\"",
TO_UTF8( nets ) );
444 if( !packet.empty() )
461 std::string packet =
"$CLEAR\n";
479 std::unordered_map<wxString, std::vector<SCH_REFERENCE>>& aSyncSymMap,
480 std::unordered_map<wxString, std::unordered_map<wxString, SCH_PIN*>>& aSyncPinMap,
481 bool aRecursive =
false )
500 for(
unsigned ii = 0; ii < references.
GetCount(); ii++ )
509 wxString fullRef = schRef.
GetRef() + refNum;
512 if( fullRef.StartsWith( wxS(
"#" ) ) )
516 if( refNum.compare( wxS(
"?" ) ) == 0 )
520 auto symMatchIt = aSyncSymMap.find( fullRef );
522 if( symMatchIt != aSyncSymMap.end() )
524 symMatchIt->second.emplace_back( schRef );
531 auto symPinMatchIt = aSyncPinMap.find( fullRef );
533 if( symPinMatchIt != aSyncPinMap.end() )
535 std::unordered_map<wxString, SCH_PIN*>& pinMap = symPinMatchIt->second;
536 std::vector<SCH_PIN*> pinsOnSheet = symbol->
GetPins( &aSheetPath );
540 int pinUnit =
pin->GetLibPin()->GetUnit();
542 if( pinUnit > 0 && pinUnit != schRef.
GetUnit() )
545 auto pinIt = pinMap.find(
pin->GetNumber() );
547 if( pinIt != pinMap.end() )
559 std::unordered_map<wxString, std::vector<SCH_REFERENCE>>& aSyncSymMap,
560 std::unordered_map<wxString, std::unordered_map<wxString, SCH_PIN*>>& aSyncPinMap,
561 std::unordered_map<SCH_SHEET_PATH, bool>& aCache )
563 auto cacheIt = aCache.find( aSheetPath );
565 if( cacheIt != aCache.end() )
566 return cacheIt->second;
575 aSyncPinMap, aCache );
579 aCache.emplace( aSheetPath,
false );
589 aCache.emplace( aSheetPath,
false );
593 for(
unsigned ii = 0; ii < references.
GetCount(); ii++ )
601 wxString fullRef = schRef.
GetRef() + refNum;
604 if( fullRef.StartsWith( wxS(
"#" ) ) )
608 if( refNum.compare( wxS(
"?" ) ) == 0 )
611 if( aSyncSymMap.find( fullRef ) == aSyncSymMap.end() )
613 aCache.emplace( aSheetPath,
false );
617 if( aSyncPinMap.find( fullRef ) != aSyncPinMap.end() )
619 aCache.emplace( aSheetPath,
false );
624 aCache.emplace( aSheetPath,
true );
629std::optional<std::tuple<SCH_SHEET_PATH, SCH_ITEM*, std::vector<SCH_ITEM*>>>
633 wxArrayString syncArray = wxStringTokenize( aSyncStr, wxS(
"," ) );
635 std::unordered_map<wxString, std::vector<SCH_REFERENCE>> syncSymMap;
636 std::unordered_map<wxString, std::unordered_map<wxString, SCH_PIN*>> syncPinMap;
637 std::unordered_map<SCH_SHEET_PATH, double> symScores;
638 std::unordered_map<SCH_SHEET_PATH, bool> fullyWantedCache;
640 std::optional<wxString> focusSymbol;
641 std::optional<std::pair<wxString, wxString>> focusPin;
642 std::unordered_map<SCH_SHEET_PATH, std::vector<SCH_ITEM*>> focusItemResults;
647 std::vector<SCH_SHEET_PATH> orderedSheets;
648 orderedSheets.reserve( allSheetsList.size() );
654 orderedSheets.push_back( sheetPath );
658 for(
size_t i = 0; i < syncArray.size(); i++ )
660 wxString syncEntry = syncArray[i];
662 if( syncEntry.empty() )
665 wxString syncData = syncEntry.substr( 1 );
667 switch( syncEntry.GetChar( 0 ).GetValue() )
673 if( aFocusOnFirst && ( i == 0 ) )
674 focusSymbol = symRef;
676 syncSymMap[symRef] = std::vector<SCH_REFERENCE>();
685 if( aFocusOnFirst && ( i == 0 ) )
686 focusPin = std::make_pair( symRef, padNum );
688 syncPinMap[symRef][padNum] =
nullptr;
698 auto flattenSyncMaps =
699 [&syncSymMap, &syncPinMap]() -> std::vector<SCH_ITEM*>
701 std::vector<SCH_ITEM*> allVec;
703 for(
const auto& [symRef, symbols] : syncSymMap )
706 allVec.push_back( ref.GetSymbol() );
709 for(
const auto& [symRef, pinMap] : syncPinMap )
711 for(
const auto& [padNum,
pin] : pinMap )
714 allVec.push_back(
pin );
722 [&syncSymMap, &syncPinMap]()
724 for(
auto& [symRef, symbols] : syncSymMap )
727 for(
auto& [reference, pins] : syncPinMap )
729 for(
auto& [number,
pin] : pins )
734 auto syncMapsValuesEmpty =
735 [&syncSymMap, &syncPinMap]() ->
bool
737 for(
const auto& [symRef, symbols] : syncSymMap )
739 if( symbols.size() > 0 )
743 for(
const auto& [symRef, pins] : syncPinMap )
745 for(
const auto& [padNum,
pin] : pins )
755 auto checkFocusItems =
760 auto findIt = syncSymMap.find( *focusSymbol );
762 if( findIt != syncSymMap.end() )
764 if( findIt->second.size() > 0 )
765 focusItemResults[aSheet].push_back( findIt->second.front().GetSymbol() );
770 auto findIt = syncPinMap.find( focusPin->first );
772 if( findIt != syncPinMap.end() )
774 if( findIt->second[focusPin->second] )
775 focusItemResults[aSheet].push_back( findIt->second[focusPin->second] );
780 auto makeRetForSheet =
787 std::vector<SCH_ITEM*> itemsVector = flattenSyncMaps();
793 kiidPath.push_back( item->m_Uuid );
795 std::optional<SCH_SHEET_PATH> subsheetPath =
802 syncPinMap, fullyWantedCache ) )
804 itemsVector.push_back( item );
808 return std::make_tuple( aSheet, aFocusItem, itemsVector );
819 checkFocusItems( sheetPath );
822 if( focusItemResults.size() > 0 )
826 const std::vector<SCH_ITEM*>& items = focusItemResults[sheetPath];
829 return makeRetForSheet( sheetPath, items.front() );
841 if( !syncMapsValuesEmpty() )
844 return makeRetForSheet( sheetPath,
nullptr );
861 std::stringstream ss( payload );
869 wxCHECK_RET( optTable.has_value(),
"Could not load symbol lib table." );
875 std::string srcProjDir;
876 std::getline( ss, srcProjDir,
'\n' );
878 std::vector<wxString> toLoad;
880 while( std::getline( ss, file,
'\n' ) )
885 wxFileName fn( file );
889 if( type == SCH_IO_MGR::SCH_FILE_UNKNOWN )
891 wxLogTrace(
"KIWAY",
"Unknown file type: %s", fn.GetFullPath() );
895 pi.reset( SCH_IO_MGR::FindPlugin( type ) );
897 wxString libTableUri;
898 bool isProjectLocal = fn.GetFullPath().StartsWith( wxString( srcProjDir ) );
904 if( !fn.FileExists() )
907 wxFileName projectFn( projectPath, fn.GetFullName() );
909 if( fn.GetFullPath() != projectFn.GetFullPath() && !projectFn.FileExists() )
910 wxCopyFile( fn.GetFullPath(), projectFn.GetFullPath() );
912 libTableUri = wxS(
"${KIPRJMOD}/" ) + fn.GetFullName();
917 libTableUri = fn.GetFullPath();
920 if( !
table->HasRow( fn.GetName() ) )
924 row.
SetURI( libTableUri );
926 toLoad.emplace_back( fn.GetName() );
930 if( !toLoad.empty() )
934 table->Save().map_error(
937 wxLogError( wxT(
"Error saving project library table:\n\n" ) + aError.
message );
946 std::ranges::for_each( toLoad,
947 [adapter](
const wxString& aNick )
966 if( !
eeconfig()->m_CrossProbing.on_selection )
980 std::string prefix =
"$SELECT: ";
982 std::string paramStr = payload.substr( prefix.size() );
985 if( paramStr.size() < 2 )
988 std::string syncStr = paramStr.substr( 2 );
990 bool focusOnFirst = ( paramStr[0] ==
'1' );
992 std::optional<std::tuple<SCH_SHEET_PATH, SCH_ITEM*, std::vector<SCH_ITEM*>>> findRet =
997 auto& [sheetPath, focusItem, items] = *findRet;
1006 if(
eeconfig()->m_CrossProbing.flash_selection )
1008 wxLogTrace(
traceCrossProbeFlash,
"MAIL_SELECTION(_FORCE): flash enabled, items=%zu", items.size() );
1015 std::vector<SCH_ITEM*> itemPtrs;
1016 std::copy( items.begin(), items.end(), std::back_inserter( itemPtrs ) );
1032 if( !payload.empty() )
1034 wxString annotationMessage( payload );
1055 KIID uuid( payload );
1061 payload =
static_cast<SCH_SHEET*
>( item )->GetShownName(
false );
1063 payload =
static_cast<SCH_SYMBOL*
>( item )->GetRef( &
path,
true );
1065 payload = item->GetFriendlyName();
1095 std::stringstream ss( payload );
1098 std::string formatStr;
1099 wxCHECK( std::getline( ss, formatStr, delim ), );
1101 std::string fnameStr;
1102 wxCHECK( std::getline( ss, fnameStr, delim ), );
1108 importFormat = std::stoi( formatStr );
1110 catch( std::invalid_argument& )
1116 std::map<std::string, UTF8> props;
1120 std::string key, value;
1122 if( !std::getline( ss, key, delim ) )
1125 std::getline( ss, value, delim );
1127 props.emplace( key, value );
1131 if( importFormat >= 0 )
1132 importFile( fnameStr, importFormat, props.empty() ?
nullptr : &props );
1139 payload =
"success";
1161 if( !errors.IsEmpty() )
1162 statusBar->AddWarningMessages(
"load", errors );
1170 wxString targetFile( payload );
1176 if( screen && screen->
GetFileName() == targetFile )
1179 payload =
"success";
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
static TOOL_ACTION showSymbolLibTable
static TOOL_ACTION updateSchematicFromPcb
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
CROSS_PROBING_SETTINGS m_CrossProbing
Calculate the connectivity of a schematic and generates netlists.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
A base class for most all the KiCad significant classes used in schematics and boards.
EE_TYPE OfType(KICAD_T aType) const
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
wxString AsString() const
Carry a payload from one KIWAY_PLAYER to another within a PROJECT.
std::string & GetPayload()
Return the payload, which can be any text but it typically self identifying s-expression.
MAIL_T Command()
Returns the MAIL_T associated with this mail.
virtual void ExpressMail(FRAME_T aDestination, MAIL_T aCommand, std::string &aPayload, wxWindow *aSource=nullptr, bool aFromOtherThread=false)
Send aPayload to aDestination from aSource.
wxString GetLibraryLoadErrors() const
Returns all library load errors as newline-separated strings for display.
std::optional< LIBRARY_TABLE * > Table(LIBRARY_TABLE_TYPE aType, LIBRARY_TABLE_SCOPE aScope)
Retrieves a given table; creating a new empty project table if a valid project is loaded and the give...
void AbortAsyncLoads()
Abort any async library loading operations in progress.
void LoadProjectTables(std::initializer_list< LIBRARY_TABLE_TYPE > aTablesToLoad={})
(Re)loads the project library tables in the given list, or all tables if no list is given
void SetNickname(const wxString &aNickname)
void SetType(const wxString &aType)
void SetURI(const wxString &aUri)
Generate the KiCad netlist format supported by Pcbnew.
void Format(OUTPUTFORMATTER *aOutputFormatter, int aCtl)
Output this s-expression netlist into aOutputFormatter.
virtual LIBRARY_MANAGER & GetLibraryManager() const
static SYMBOL_LIBRARY_ADAPTER * SymbolLibAdapter(PROJECT *aProject)
Accessor for project symbol library manager adapter.
virtual const wxString GetProjectPath() const
Return the full path of the project.
Holds all the data relating to one schematic.
SCH_SHEET_LIST Hierarchy() const
Return the full schematic flattened hierarchical sheet list.
SCH_SHEET_PATH & CurrentSheet() const
static TOOL_ACTION runERC
Inspection and Editing.
static TOOL_ACTION changeSheet
static TOOL_ACTION updateNetHighlighting
SCH_DRAW_PANEL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
void SyncView()
Mark all items for refresh.
EESCHEMA_SETTINGS * eeconfig() const
Each graphical item can have a SCH_CONNECTION describing its logical connection (to a bus or net).
const std::vector< std::shared_ptr< SCH_CONNECTION > > AllMembers() const
wxString Name(bool aIgnoreSheet=false) const
const std::vector< std::shared_ptr< SCH_CONNECTION > > & Members() const
KIGFX::SCH_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
void AssignFootprints(const std::string &aChangedSetOfReferences)
SCH_ITEM * FindSymbolAndItem(const wxString *aPath, const wxString *aReference, bool aSearchHierarchy, SCH_SEARCH_T aSearchType, const wxString &aSearchText)
Find a symbol in the schematic and an item in this symbol and select it.
bool ReadyToNetlist(const wxString &aAnnotateMessage)
Check if we are ready to write a netlist file for the current schematic.
bool m_syncingPcbToSchSelection
friend class SCH_EDITOR_CONTROL
void SendSelectItemsToPcb(const std::vector< EDA_ITEM * > &aItems, bool aForce)
Send items to board editor for selection.
void SendCrossProbeClearHighlight()
Tell Pcbnew to clear the existing highlighted net, if one exists.
SCHEMATIC * m_schematic
The currently loaded schematic.
SCH_SHEET_PATH & GetCurrentSheet() const
void RecalculateConnections(SCH_COMMIT *aCommit, SCH_CLEANUP_FLAGS aCleanupFlags, PROGRESS_REPORTER *aProgressReporter=nullptr)
Generate the connection data for the entire schematic hierarchy.
SCHEMATIC & Schematic() const
void ExecuteRemoteCommand(const char *cmdline) override
Execute a remote command sent via a socket on port KICAD_SCH_PORT_SERVICE_NUMBER (which defaults to 4...
void RefreshNetNavigator(const NET_NAVIGATOR_ITEM_DATA *aSelection=nullptr)
SCH_DESIGN_BLOCK_PANE * m_designBlocksPane
bool importFile(const wxString &aFileName, int aFileType, const std::map< std::string, UTF8 > *aProperties=nullptr)
Load the given filename but sets the path to the current project path.
void SendCrossProbeNetName(const wxString &aNetName)
Send a net name to Pcbnew for highlighting.
void KiwayMailIn(KIWAY_MAIL_EVENT &aEvent) override
Receive #KIWAY_ROUTED_EVENT messages from other players.
void StartCrossProbeFlash(const std::vector< SCH_ITEM * > &aItems)
void SetHighlightedNetChain(const wxString &aNetChain)
wxString m_highlightedConn
The highlighted net or bus or empty string.
void SetCrossProbeConnection(const SCH_CONNECTION *aConnection)
Send a connection (net or bus) to Pcbnew for highlighting.
void TestDanglingEnds()
Test all of the connectable objects in the schematic for unused connection points.
bool SaveProject(bool aSaveAs=false)
Save the currently-open schematic (including its hierarchy) and associated project.
virtual const wxString & GetText() const override
Return the string associated with the text object.
static const wxString ShowType(SCH_FILE_T aFileType)
Return a brief name for a plugin, given aFileType enum.
static SCH_FILE_T GuessPluginTypeFromLibPath(const wxString &aLibPath, int aCtl=0)
Return a plugin type given a symbol library using the file extension of aLibPath.
Base class for any item which can be embedded within the SCHEMATIC container class,...
A net chain is a collection of nets that are connected together through passive components.
Container to create a flattened list of symbols because in a complex hierarchy, a symbol can be used ...
A helper to define a symbol's reference designator in a schematic.
void Split()
Attempt to split the reference designator into a name (U) and number (1).
bool IsSplitNeeded()
Determine if this reference needs to be split or if it likely already has been.
SCH_SYMBOL * GetSymbol() const
wxString GetRefNumber() const
EE_RTREE & Items()
Get the full RTree, usually for iterating.
const wxString & GetFileName() const
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
std::optional< SCH_SHEET_PATH > GetSheetPathByKIIDPath(const KIID_PATH &aPath, bool aIncludeLastSheet=true) const
Finds a SCH_SHEET_PATH that matches the provided KIID_PATH.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
void GetSymbols(SCH_REFERENCE_LIST &aReferences, SYMBOL_FILTER aSymbolFilter, bool aForceIncludeOrphanSymbols=false) const
Adds SCH_REFERENCE object to aReferences for each symbol in the sheet.
KIID_PATH Path() const
Get the sheet path as an KIID_PATH.
SCH_SCREEN * LastScreen()
bool IsContainedWithin(const SCH_SHEET_PATH &aSheetPathToTest) const
Check if this path is contained inside aSheetPathToTest.
wxString PathAsString() const
Return the path of time stamps which do not changes even when editing sheet parameters.
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
std::vector< const SCH_PIN * > GetPins(const SCH_SHEET_PATH *aSheet) const
Retrieve a list of the SCH_PINs for the given sheet path.
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
SCH_PIN * GetPin(const wxString &number) const
Find a symbol pin by number.
const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const override
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this symbol.
An interface to the global shared library manager that is schematic-specific and linked to one projec...
std::optional< LIB_STATUS > LoadOne(LIB_DATA *aLib) override
Loads or reloads the given library, if it exists.
A base class for LIB_SYMBOL and SCH_SYMBOL.
virtual const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const =0
bool SendCommand(int aService, const std::string &aMessage)
Used by a client to sent (by a socket connection) a data to a server.
std::optional< std::tuple< SCH_SHEET_PATH, SCH_ITEM *, std::vector< SCH_ITEM * > > > findItemsFromSyncSelection(const SCHEMATIC &aSchematic, const std::string aSyncStr, bool aFocusOnFirst)
bool findSymbolsAndPins(const SCH_SHEET_LIST &aSchematicSheetList, const SCH_SHEET_PATH &aSheetPath, std::unordered_map< wxString, std::vector< SCH_REFERENCE > > &aSyncSymMap, std::unordered_map< wxString, std::unordered_map< wxString, SCH_PIN * > > &aSyncPinMap, bool aRecursive=false)
bool sheetContainsOnlyWantedItems(const SCH_SHEET_LIST &aSchematicSheetList, const SCH_SHEET_PATH &aSheetPath, std::unordered_map< wxString, std::vector< SCH_REFERENCE > > &aSyncSymMap, std::unordered_map< wxString, std::unordered_map< wxString, SCH_PIN * > > &aSyncPinMap, std::unordered_map< SCH_SHEET_PATH, bool > &aCache)
@ FRAME_SCH_SYMBOL_EDITOR
const wxChar *const traceCrossProbeFlash
Flag to enable debug output for cross-probe flash operations.
std::unique_ptr< T > IO_RELEASER
Helper to hold and release an IO_BASE object when exceptions are thrown.
#define KI_FALLTHROUGH
The KI_FALLTHROUGH macro is to be used when switch statement cases should purposely fallthrough from ...
@ MAIL_SCH_NAVIGATE_TO_SHEET
@ ALL
All except INITIAL_ADD.
PGM_BASE & Pgm()
The global program "get" accessor.
SCH_SEARCH_T
Schematic search type used by the socket link with Pcbnew.
@ SYMBOL_FILTER_NON_POWER
KIWAY Kiway(KFCTL_STANDALONE)
wxString UnescapeString(const wxString &aSource)
wxString From_UTF8(const char *cstring)
wxString EscapeString(const wxString &aSource, ESCAPE_CONTEXT aContext)
The Escape/Unescape routines use HTML-entity-reference-style encoding to handle characters which are:...
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
bool on_selection
Synchronize the selection for multiple items too.
bool zoom_to_fit
Zoom to fit items (ignored if center_on_items is off).
bool center_on_items
Automatically pan to cross-probed items.
bool auto_highlight
Automatically turn on highlight mode in the target frame.
@ REFERENCE
Field Reference of part, i.e. "IC21".
std::vector< std::vector< std::string > > table
const SHAPE_LINE_CHAIN chain
wxLogTrace helper definitions.