/*************************************************************************/ /* NETINFO_ITEM class, to handle info on nets (netnames, net constraints */ /*************************************************************************/ #include "fctsys.h" #include "class_drawpanel.h" #include "common.h" #include "kicad_string.h" #include "pcbnew.h" #include "class_board_design_settings.h" #include "colors_selection.h" #include "richio.h" /*********************************************************/ /* class NETINFO_ITEM: handle data relative to a given net */ /*********************************************************/ NETINFO_ITEM::NETINFO_ITEM( BOARD_ITEM* aParent ) { SetNet( 0 ); m_NbNodes = 0; m_NbLink = 0; m_NbNoconn = 0; m_Flag = 0; m_RatsnestStartIdx = 0; // Starting point of ratsnests of this net in a // general buffer of ratsnest m_RatsnestEndIdx = 0; // Ending point of ratsnests of this net m_NetClassName = NETCLASS::Default; m_NetClass = 0; } NETINFO_ITEM::~NETINFO_ITEM() { // m_NetClass is not owned by me. } /* Read NETINFO_ITEM from file. * Returns 0 if OK * 1 if incomplete reading */ int NETINFO_ITEM::ReadDescr( LINE_READER* aReader ) { char* Line; char Ltmp[1024]; int tmp; while( aReader->ReadLine() ) { Line = aReader->Line(); if( strnicmp( Line, "$End", 4 ) == 0 ) return 0; if( strncmp( Line, "Na", 2 ) == 0 ) { sscanf( Line + 2, " %d", &tmp ); SetNet( tmp ); ReadDelimitedText( Ltmp, Line + 2, sizeof(Ltmp) ); m_Netname = FROM_UTF8( Ltmp ); continue; } } return 1; } /** Note: the old name of class NETINFO_ITEM was EQUIPOT * so in Save (and read) functions, for compatibility, we use EQUIPOT as * keyword */ bool NETINFO_ITEM::Save( FILE* aFile ) const { bool success = false; fprintf( aFile, "$EQUIPOT\n" ); fprintf( aFile, "Na %d %s\n", GetNet(), EscapedUTF8( m_Netname ).c_str() ); fprintf( aFile, "St %s\n", "~" ); if( fprintf( aFile, "$EndEQUIPOT\n" ) != sizeof("$EndEQUIPOT\n") - 1 ) goto out; success = true; out: return success; } /** * Function SetNetname * @param aNetname : the new netname */ void NETINFO_ITEM::SetNetname( const wxString& aNetname ) { m_Netname = aNetname; m_ShortNetname = m_Netname.AfterLast( '/' ); } /** * Function Draw (TODO) */ void NETINFO_ITEM::Draw( EDA_DRAW_PANEL* panel, wxDC* DC, int aDrawMode, const wxPoint& aOffset ) { } /** * Function DisplayInfo * has knowledge about the frame and how and where to put status information * about this object into the frame's message panel. * Is virtual from EDA_ITEM. * @param frame A EDA_DRAW_FRAME in which to print status information. */ void NETINFO_ITEM::DisplayInfo( EDA_DRAW_FRAME* frame ) { int count; EDA_ITEM* Struct; wxString txt; MODULE* module; D_PAD* pad; double lengthnet = 0; // This is the lenght of tracks on pcb double lengthdie = 0; // this is the lenght of internal ICs connections frame->ClearMsgPanel(); frame->AppendMsgPanel( _( "Net Name" ), GetNetname(), RED ); txt.Printf( wxT( "%d" ), GetNet() ); frame->AppendMsgPanel( _( "Net Code" ), txt, RED ); count = 0; module = ( (PCB_BASE_FRAME*) frame )->GetBoard()->m_Modules; for( ; module != 0; module = module->Next() ) { for( pad = module->m_Pads; pad != 0; pad = pad->Next() ) { if( pad->GetNet() == GetNet() ) { count++; lengthdie += pad->m_LengthDie; } } } txt.Printf( wxT( "%d" ), count ); frame->AppendMsgPanel( _( "Pads" ), txt, DARKGREEN ); count = 0; Struct = ( (PCB_BASE_FRAME*) frame )->GetBoard()->m_Track; for( ; Struct != NULL; Struct = Struct->Next() ) { if( Struct->Type() == TYPE_VIA ) if( ( (SEGVIA*) Struct )->GetNet() == GetNet() ) count++; if( Struct->Type() == TYPE_TRACK ) if( ( (TRACK*) Struct )->GetNet() == GetNet() ) lengthnet += ( (TRACK*) Struct )->GetLength(); } txt.Printf( wxT( "%d" ), count ); frame->AppendMsgPanel( _( "Vias" ), txt, BLUE ); // Displays the full net lenght (tracks on pcb + internal ICs connections ): txt = frame->CoordinateToString( lengthnet + lengthdie ); frame->AppendMsgPanel( _( "Net Length:" ), txt, RED ); // Displays the net lenght of tracks only: txt = frame->CoordinateToString( lengthnet ); frame->AppendMsgPanel( _( "On Board" ), txt, RED ); // Displays the net lenght of internal ICs connections (wires inside ICs): txt = frame->CoordinateToString( lengthdie ); frame->AppendMsgPanel( _( "On Die" ), txt, RED ); } /***********************/ /* class RATSNEST_ITEM */ /***********************/ RATSNEST_ITEM::RATSNEST_ITEM() { m_NetCode = 0; // netcode ( = 1.. n , 0 is the value used for not // connected items) m_Status = 0; // state m_PadStart = NULL; // pointer to the starting pad m_PadEnd = NULL; // pointer to ending pad m_Lenght = 0; // length of the line (temporary used in some // calculations) } /** * Function Draw * Draws a line (a ratsnest) from the starting pad to the ending pad */ void RATSNEST_ITEM::Draw( EDA_DRAW_PANEL* panel, wxDC* DC, int aDrawMode, const wxPoint& aOffset ) { GRSetDrawMode( DC, aDrawMode ); int color = g_ColorsSettings.GetItemColor(RATSNEST_VISIBLE); GRLine( &panel->m_ClipBox, DC, m_PadStart->m_Pos - aOffset, m_PadEnd->m_Pos - aOffset, 0, color ); }