1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0024644: Draw_Printer - provide the way to control messages gravity filter

Message_Printer - define GetTraceLevel()/SetTraceLevel() methods in base interface.
Implement message gravity filter in Draw_Printer.
Add new Draw Harness command dtracelevel to show/change message gravity filter.
Redirect default messenger to Draw_Printer within TKDraw instead of TKXSDRAW

Draw::Commands() - assign Draw_Printer only once
This commit is contained in:
kgv 2014-03-20 13:38:41 +04:00 committed by bugmaster
parent 0d19eb340e
commit 785a954097
14 changed files with 290 additions and 119 deletions

View File

@ -702,6 +702,99 @@ static int dmeminfo (Draw_Interpretor& theDI,
return 0; return 0;
} }
//==============================================================================
//function : dtracelevel
//purpose :
//==============================================================================
static int dtracelevel (Draw_Interpretor& theDI,
Standard_Integer theArgNb,
const char** theArgVec)
{
Message_Gravity aLevel = Message_Info;
if (theArgNb < 1 || theArgNb > 2)
{
std::cout << "Error: wrong number of arguments! See usage:\n";
theDI.PrintHelp (theArgVec[0]);
return 1;
}
else if (theArgNb == 2)
{
TCollection_AsciiString aVal (theArgVec[1]);
aVal.LowerCase();
if (aVal == "trace")
{
aLevel = Message_Trace;
}
else if (aVal == "info")
{
aLevel = Message_Info;
}
else if (aVal == "warn"
|| aVal == "warning")
{
aLevel = Message_Warning;
}
else if (aVal == "alarm")
{
aLevel = Message_Alarm;
}
else if (aVal == "fail")
{
aLevel = Message_Fail;
}
else
{
std::cout << "Error: unknown gravity '" << theArgVec[1] << "'!\n";
return 1;
}
}
Handle(Message_Messenger) aMessenger = Message::DefaultMessenger();
if (aMessenger.IsNull())
{
std::cout << "Error: default messenger is unavailable!\n";
return 1;
}
Message_SequenceOfPrinters& aPrinters = aMessenger->ChangePrinters();
if (aPrinters.Length() < 1)
{
std::cout << "Error: no printers registered in default Messenger!\n";
return 0;
}
for (Standard_Integer aPrinterIter = 1; aPrinterIter <= aPrinters.Length(); ++aPrinterIter)
{
Handle(Message_Printer)& aPrinter = aPrinters.ChangeValue (aPrinterIter);
if (theArgNb == 1)
{
if (aPrinterIter == 1)
{
aLevel = aPrinter->GetTraceLevel();
}
else if (aLevel == aPrinter->GetTraceLevel())
{
continue;
}
switch (aPrinter->GetTraceLevel())
{
case Message_Trace: theDI << "trace"; break;
case Message_Info: theDI << "info"; break;
case Message_Warning: theDI << "warn"; break;
case Message_Alarm: theDI << "alarm"; break;
case Message_Fail: theDI << "fail"; break;
}
continue;
}
aPrinter->SetTraceLevel (aLevel);
}
return 0;
}
void Draw::BasicCommands(Draw_Interpretor& theCommands) void Draw::BasicCommands(Draw_Interpretor& theCommands)
{ {
static Standard_Boolean Done = Standard_False; static Standard_Boolean Done = Standard_False;
@ -711,7 +804,7 @@ void Draw::BasicCommands(Draw_Interpretor& theCommands)
ios::sync_with_stdio(); ios::sync_with_stdio();
const char* g = "DRAW General Commands"; const char* g = "DRAW General Commands";
theCommands.Add("batch", "returns 1 in batch mode", theCommands.Add("batch", "returns 1 in batch mode",
__FILE__,ifbatch,g); __FILE__,ifbatch,g);
theCommands.Add("spy","spy [file], Save commands in file. no file close", theCommands.Add("spy","spy [file], Save commands in file. no file close",
@ -732,13 +825,15 @@ void Draw::BasicCommands(Draw_Interpretor& theCommands)
" : memory counters for this process", " : memory counters for this process",
__FILE__, dmeminfo, g); __FILE__, dmeminfo, g);
// Logging commands; note that their names are hard-coded in the code // Logging commands; note that their names are hard-coded in the code
// of Draw_Interpretor, thus should not be changed without update of that code! // of Draw_Interpretor, thus should not be changed without update of that code!
theCommands.Add("dlog", "manage logging of commands and output; run without args to get help", theCommands.Add("dlog", "manage logging of commands and output; run without args to get help",
__FILE__,dlog,g); __FILE__,dlog,g);
theCommands.Add("decho", "switch on / off echo of commands to cout; run without args to get help", theCommands.Add("decho", "switch on / off echo of commands to cout; run without args to get help",
__FILE__,decho,g); __FILE__,decho,g);
theCommands.Add("dtracelevel", "dtracelevel [trace|info|warn|alarm|fail]",
__FILE__, dtracelevel, g);
theCommands.Add("dbreak", "raises Tcl exception if user has pressed Control-Break key", theCommands.Add("dbreak", "raises Tcl exception if user has pressed Control-Break key",
__FILE__,dbreak,g); __FILE__,dbreak,g);
theCommands.Add("dversion", "provides information on OCCT build configuration (version, compiler, OS, C library, etc.)", theCommands.Add("dversion", "provides information on OCCT build configuration (version, compiler, OS, C library, etc.)",

View File

@ -16,8 +16,27 @@
#include <Draw.ixx> #include <Draw.ixx>
void Draw::Commands(Draw_Interpretor& theCommands) #include <Draw_Printer.hxx>
#include <Message.hxx>
#include <Message_Messenger.hxx>
#include <Message_PrinterOStream.hxx>
void Draw::Commands (Draw_Interpretor& theCommands)
{ {
static Standard_Boolean isFirstTime = Standard_True;
if (isFirstTime)
{
// override default std::cout printer by draw interpretor printer
const Handle(Message_Messenger)& aMsgMgr = Message::DefaultMessenger();
if (!aMsgMgr.IsNull())
{
aMsgMgr->RemovePrinters (STANDARD_TYPE (Message_PrinterOStream));
aMsgMgr->RemovePrinters (STANDARD_TYPE (Draw_Printer));
aMsgMgr->AddPrinter (new Draw_Printer (theCommands));
}
isFirstTime = Standard_False;
}
Draw::BasicCommands(theCommands); Draw::BasicCommands(theCommands);
Draw::VariableCommands(theCommands); Draw::VariableCommands(theCommands);
Draw::GraphicCommands(theCommands); Draw::GraphicCommands(theCommands);

View File

@ -576,6 +576,18 @@ Standard_Integer Draw_Interpretor::EvalFile(const Standard_CString fname)
return Tcl_EvalFile(myInterp,pfname); return Tcl_EvalFile(myInterp,pfname);
} }
//=======================================================================
//function : PrintHelp
//purpose :
//=======================================================================
Standard_Integer Draw_Interpretor::PrintHelp (const Standard_CString theCommandName)
{
TCollection_AsciiString aCmd = TCollection_AsciiString ("help ") + theCommandName;
Standard_PCharacter aLinePtr = (Standard_PCharacter )aCmd.ToCString();
return Tcl_Eval (myInterp, aLinePtr);
}
//======================================================================= //=======================================================================
//function :Complete //function :Complete
//purpose : //purpose :

View File

@ -209,6 +209,9 @@ public:
//! Eval the content on the file and returns status //! Eval the content on the file and returns status
Standard_EXPORT Standard_Integer EvalFile (const Standard_CString theFileName); Standard_EXPORT Standard_Integer EvalFile (const Standard_CString theFileName);
//! Eval the script "help command_name"
Standard_EXPORT Standard_Integer PrintHelp (const Standard_CString theCommandName);
//! Returns True if the script is complete, no pending closing braces. (}) //! Returns True if the script is complete, no pending closing braces. (})
Standard_EXPORT static Standard_Boolean Complete (const Standard_CString theScript); Standard_EXPORT static Standard_Boolean Complete (const Standard_CString theScript);

View File

@ -30,51 +30,66 @@ Draw_Printer::Draw_Printer (const Draw_Interpretor& theTcl)
//======================================================================= //=======================================================================
//function : Send //function : Send
//purpose : //purpose :
//======================================================================= //=======================================================================
void Draw_Printer::Send (const TCollection_ExtendedString& theString, void Draw_Printer::Send (const TCollection_ExtendedString& theString,
const Message_Gravity /*theGravity*/, const Message_Gravity theGravity,
const Standard_Boolean putEndl) const const Standard_Boolean theToPutEol) const
{ {
if ( ! myTcl ) if (!myTcl
|| theGravity < myTraceLevel)
{
return; return;
}
(*(Draw_Interpretor*)myTcl) << theString; (*(Draw_Interpretor*)myTcl) << theString;
if ( putEndl ){ if (theToPutEol)
{
(*(Draw_Interpretor*)myTcl) << "\n"; (*(Draw_Interpretor*)myTcl) << "\n";
} }
} }
//======================================================================= //=======================================================================
//function : Send //function : Send
//purpose : //purpose :
//======================================================================= //=======================================================================
void Draw_Printer::Send (const Standard_CString theString, void Draw_Printer::Send (const Standard_CString theString,
const Message_Gravity /*theGravity*/, const Message_Gravity theGravity,
const Standard_Boolean putEndl) const const Standard_Boolean theToPutEol) const
{ {
if ( ! myTcl ) if (!myTcl
|| theGravity < myTraceLevel)
{
return; return;
}
(*(Draw_Interpretor*)myTcl) << theString; (*(Draw_Interpretor*)myTcl) << theString;
if ( putEndl ){ if (theToPutEol)
{
(*(Draw_Interpretor*)myTcl) << "\n"; (*(Draw_Interpretor*)myTcl) << "\n";
} }
} }
//======================================================================= //=======================================================================
//function : Send //function : Send
//purpose : //purpose :
//======================================================================= //=======================================================================
void Draw_Printer::Send (const TCollection_AsciiString& theString, void Draw_Printer::Send (const TCollection_AsciiString& theString,
const Message_Gravity /*theGravity*/, const Message_Gravity theGravity,
const Standard_Boolean putEndl) const const Standard_Boolean theToPutEol) const
{ {
if ( ! myTcl ) if (!myTcl
|| theGravity < myTraceLevel)
{
return; return;
}
(*(Draw_Interpretor*)myTcl) << theString; (*(Draw_Interpretor*)myTcl) << theString;
if ( putEndl ){ if (theToPutEol)
{
(*(Draw_Interpretor*)myTcl) << "\n"; (*(Draw_Interpretor*)myTcl) << "\n";
} }
} }

View File

@ -15,42 +15,59 @@
deferred class Printer from Message inherits TShared from MMgt deferred class Printer from Message inherits TShared from MMgt
---Purpose: Abstract interface class defining printer as output context for ---Purpose: Abstract interface class defining printer as output context for text messages
-- text messages --
-- -- The message, besides being text string, has associated gravity
-- The message, besides being text string, has associated gravity -- level, which can be used by printer to decide either to process a message or ignore it.
-- level, which can be used by printer to decide either to process
-- a message or ignore it.
uses uses
Gravity from Message, Gravity from Message,
AsciiString from TCollection, AsciiString from TCollection,
ExtendedString from TCollection ExtendedString from TCollection
is is
Send (me; theString: ExtendedString from TCollection; Initialize returns Printer from Message;
theGravity: Gravity from Message; ---Purpose: Empty constructor with Message_Info trace level
putEndl: Boolean) is deferred;
---Purpose: Send a string message with specified trace level.
-- The parameter putEndl specified whether end-of-line
-- should be added to the end of the message.
-- This method must be redefined in descentant.
Send (me; theString: CString; theGravity: Gravity from Message; GetTraceLevel (me) returns Gravity from Message;
putEndl: Boolean) is virtual; ---C++: inline
---Purpose: Send a string message with specified trace level. ---Purpose: Return trace level used for filtering messages;
-- The parameter putEndl specified whether end-of-line -- messages with lover gravity will be ignored.
-- should be added to the end of the message.
-- Default implementation calls first method Send().
Send (me; theString: AsciiString from TCollection; SetTraceLevel (me : mutable;
theGravity: Gravity from Message; theTraceLevel : Gravity from Message);
putEndl: Boolean) is virtual; ---C++: inline
---Purpose: Send a string message with specified trace level. ---Purpose: Set trace level used for filtering messages.
-- The parameter putEndl specified whether end-of-line -- By default, trace level is Message_Info, so that all messages are output
-- should be added to the end of the message.
-- Default implementation calls first method Send(). Send (me;
theString : ExtendedString from TCollection;
theGravity : Gravity from Message;
theToPutEol : Boolean) is deferred;
---Purpose: Send a string message with specified trace level.
-- The parameter theToPutEol specified whether end-of-line should be added to the end of the message.
-- This method must be redefined in descentant.
Send (me;
theString : CString;
theGravity : Gravity from Message;
theToPutEol : Boolean) is virtual;
---Purpose: Send a string message with specified trace level.
-- The parameter theToPutEol specified whether end-of-line should be added to the end of the message.
-- Default implementation calls first method Send().
Send (me;
theString : AsciiString from TCollection;
theGravity : Gravity from Message;
theToPutEol : Boolean) is virtual;
---Purpose: Send a string message with specified trace level.
-- The parameter theToPutEol specified whether end-of-line should be added to the end of the message.
-- Default implementation calls first method Send().
fields
myTraceLevel : Gravity from Message is protected;
end Printer; end Printer;

View File

@ -18,26 +18,42 @@
#include <TCollection_AsciiString.hxx> #include <TCollection_AsciiString.hxx>
#include <TCollection_ExtendedString.hxx> #include <TCollection_ExtendedString.hxx>
//=======================================================================
//function : Constructor
//purpose :
//=======================================================================
Message_Printer::Message_Printer()
: myTraceLevel (Message_Info)
{
}
//======================================================================= //=======================================================================
//function : Send //function : Send
//purpose : //purpose :
//======================================================================= //=======================================================================
void Message_Printer::Send (const Standard_CString theString, void Message_Printer::Send (const Standard_CString theString,
const Message_Gravity theGravity, const Message_Gravity theGravity,
const Standard_Boolean putEndl) const const Standard_Boolean theToOutEol) const
{ {
Send ( TCollection_ExtendedString(theString), theGravity, putEndl ); if (theGravity >= myTraceLevel)
{
Send (TCollection_ExtendedString (theString), theGravity, theToOutEol);
}
} }
//======================================================================= //=======================================================================
//function : Send //function : Send
//purpose : //purpose :
//======================================================================= //=======================================================================
void Message_Printer::Send (const TCollection_AsciiString& theString, void Message_Printer::Send (const TCollection_AsciiString& theString,
const Message_Gravity theGravity, const Message_Gravity theGravity,
const Standard_Boolean putEndl) const const Standard_Boolean theToOutEol) const
{ {
Send ( TCollection_ExtendedString(theString), theGravity, putEndl ); if (theGravity >= myTraceLevel)
{
Send (TCollection_ExtendedString (theString), theGravity, theToOutEol);
}
} }

View File

@ -0,0 +1,36 @@
// Created on: 2007-06-28
// Created by: Pavel TELKOV
// Copyright (c) 2007-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <Message_Printer.hxx>
//=======================================================================
//function : GetTraceLevel
//purpose :
//=======================================================================
inline Message_Gravity Message_Printer::GetTraceLevel() const
{
return myTraceLevel;
}
//=======================================================================
//function : SetTraceLevel
//purpose :
//=======================================================================
inline void Message_Printer::SetTraceLevel (const Message_Gravity theTraceLevel)
{
myTraceLevel = theTraceLevel;
}

View File

@ -46,17 +46,6 @@ is
---Purpose: Flushes the output stream and destroys it if it has been ---Purpose: Flushes the output stream and destroys it if it has been
-- specified externally with option doFree (or if it is internal -- specified externally with option doFree (or if it is internal
-- file stream) -- file stream)
GetTraceLevel (me) returns Gravity from Message;
---C++: inline
---Purpose: Return trace level used for filtering messages;
-- messages with lover gravity will be ignored.
SetTraceLevel (me: mutable; theTraceLevel: Gravity from Message);
---C++: inline
---Purpose: Set trace level used for filtering messages.
-- By default, trace level is Message_Info, so that
-- all messages are output
GetUseUtf8 (me) returns Boolean; GetUseUtf8 (me) returns Boolean;
---Purpose: Returns option to convert non-Ascii symbols to UTF8 encoding ---Purpose: Returns option to convert non-Ascii symbols to UTF8 encoding
@ -95,7 +84,6 @@ is
fields fields
myTraceLevel: Gravity from Message;
myStream: Address from Standard; -- pointer to OStream myStream: Address from Standard; -- pointer to OStream
myIsFile: Boolean from Standard; myIsFile: Boolean from Standard;
myUseUtf8: Boolean from Standard; myUseUtf8: Boolean from Standard;

View File

@ -26,10 +26,12 @@
//purpose : Empty constructor, defaulting to cerr //purpose : Empty constructor, defaulting to cerr
//======================================================================= //=======================================================================
Message_PrinterOStream::Message_PrinterOStream (const Message_Gravity theTraceLevel) Message_PrinterOStream::Message_PrinterOStream (const Message_Gravity theTraceLevel)
: myTraceLevel(theTraceLevel), myStream(&cout), : myStream (&cout),
myIsFile(Standard_False), myUseUtf8(Standard_False) myIsFile (Standard_False),
myUseUtf8 (Standard_False)
{ {
myTraceLevel = theTraceLevel;
} }
//======================================================================= //=======================================================================
@ -38,10 +40,12 @@ Message_PrinterOStream::Message_PrinterOStream (const Message_Gravity theTraceLe
// for specific file names standard streams are created // for specific file names standard streams are created
//======================================================================= //=======================================================================
Message_PrinterOStream::Message_PrinterOStream (const Standard_CString theFileName, Message_PrinterOStream::Message_PrinterOStream (const Standard_CString theFileName,
const Standard_Boolean doAppend, const Standard_Boolean theToAppend,
const Message_Gravity theTraceLevel) const Message_Gravity theTraceLevel)
: myTraceLevel(theTraceLevel), myStream(&cout), myIsFile(Standard_False) : myStream (&cout),
myIsFile (Standard_False)
{ {
myTraceLevel = theTraceLevel;
if ( strcasecmp(theFileName, "cout") == 0 ) if ( strcasecmp(theFileName, "cout") == 0 )
myStream = &cerr; myStream = &cerr;
else if ( strcasecmp(theFileName, "cerr") == 0 ) else if ( strcasecmp(theFileName, "cerr") == 0 )
@ -49,15 +53,15 @@ Message_PrinterOStream::Message_PrinterOStream (const Standard_CString theFileNa
else else
{ {
TCollection_AsciiString aFileName (theFileName); TCollection_AsciiString aFileName (theFileName);
#ifdef WNT #ifdef _WIN32
aFileName.ChangeAll ('/', '\\'); aFileName.ChangeAll ('/', '\\');
#endif #endif
ofstream *ofile = new ofstream (aFileName.ToCString(), ofstream *ofile = new ofstream (aFileName.ToCString(),
#ifdef USE_STL_STREAMS #ifdef USE_STL_STREAMS
(doAppend ? (std::ios_base::app | std::ios_base::out) : std::ios_base::out ) ); (theToAppend ? (std::ios_base::app | std::ios_base::out) : std::ios_base::out ) );
#else #else
(doAppend ? ios::app : ios::out ) ); (theToAppend ? ios::app : ios::out ) );
#endif #endif
if ( ofile ) { if ( ofile ) {
myStream = (Standard_OStream*)ofile; myStream = (Standard_OStream*)ofile;

View File

@ -15,26 +15,6 @@
#include <Message_PrinterOStream.hxx> #include <Message_PrinterOStream.hxx>
//=======================================================================
//function : GetTraceLevel
//purpose :
//=======================================================================
inline Message_Gravity Message_PrinterOStream::GetTraceLevel() const
{
return myTraceLevel;
}
//=======================================================================
//function : SetTraceLevel
//purpose :
//=======================================================================
inline void Message_PrinterOStream::SetTraceLevel (const Message_Gravity theTraceLevel)
{
myTraceLevel = theTraceLevel;
}
//======================================================================= //=======================================================================
//function : GetUseUtf8 //function : GetUseUtf8
//purpose : //purpose :
@ -64,4 +44,3 @@ inline Standard_OStream& Message_PrinterOStream::GetStream () const
{ {
return *(Standard_OStream*)myStream; return *(Standard_OStream*)myStream;
} }

View File

@ -34,9 +34,6 @@
#include <stdio.h> #include <stdio.h>
#include <Message.hxx> #include <Message.hxx>
#include <Message_Messenger.hxx>
#include <Message_PrinterOStream.hxx>
#include <Draw_Printer.hxx>
static int deja = 0, dejald = 0; static int deja = 0, dejald = 0;
//unused variable //unused variable
@ -107,11 +104,7 @@ void XSDRAW::LoadDraw (Draw_Interpretor& theCommands)
// performed not in IFSelect_SessionPilot but in standard Tcl interpretor // performed not in IFSelect_SessionPilot but in standard Tcl interpretor
XSDRAW::RemoveCommand("x"); XSDRAW::RemoveCommand("x");
XSDRAW::RemoveCommand("exit"); XSDRAW::RemoveCommand("exit");
const Handle(Message_Messenger) &sout = Message::DefaultMessenger();
if (!sout.IsNull()){
sout->RemovePrinters(STANDARD_TYPE(Message_PrinterOStream));
sout->AddPrinter(new Draw_Printer(theCommands));
}
// if (!getenv("WBHOSTTOP")) XSDRAW::RemoveCommand("xsnew"); // if (!getenv("WBHOSTTOP")) XSDRAW::RemoveCommand("xsnew");
Handle(TColStd_HSequenceOfAsciiString) list = Handle(TColStd_HSequenceOfAsciiString) list =
IFSelect_Activator::Commands(0); IFSelect_Activator::Commands(0);

View File

@ -49,10 +49,10 @@
#include <Geom_Surface.hxx> #include <Geom_Surface.hxx>
#include <Interface_Macros.hxx> #include <Interface_Macros.hxx>
#include <Message.hxx>
#include <Message_Messenger.hxx> #include <Message_Messenger.hxx>
#include <Draw_Appli.hxx> #include <Draw_Appli.hxx>
#include <Draw_Printer.hxx>
#include <DrawTrSurf.hxx> #include <DrawTrSurf.hxx>
#include <DBRep.hxx> #include <DBRep.hxx>
//#include <GeometryTest.hxx> essai CKY 4-AUT-1998 //#include <GeometryTest.hxx> essai CKY 4-AUT-1998
@ -586,15 +586,11 @@ static Standard_Integer XSDRAWIGES_tplosttrim (Draw_Interpretor& di, Standard_In
case 3: case 3:
di << "Face: " << "\n"; break; di << "Face: " << "\n"; break;
} }
Handle(Message_Messenger) aDIMessenger =
new Message_Messenger (new Draw_Printer(di));
TColStd_MapIteratorOfMapOfTransient itmap; TColStd_MapIteratorOfMapOfTransient itmap;
for(itmap.Initialize(aMap); itmap.More(); itmap.Next()) { for(itmap.Initialize(aMap); itmap.More(); itmap.Next()) {
//XSDRAW::Model()->Print(itmap.Key(),cout); XSDRAW::Model()->Print (itmap.Key(), Message::DefaultMessenger());
Standard_SStream aSStream; di << " ";
XSDRAW::Model()->Print(itmap.Key(),aDIMessenger);
di << aSStream;
di<<" ";
} }
di << "\n"; di << "\n";
di << "\n" << "Number:"<< nbFaces << "\n"; di << "\n" << "Number:"<< nbFaces << "\n";

View File

@ -23,7 +23,7 @@
#include <Draw_Appli.hxx> #include <Draw_Appli.hxx>
#include <Draw_Interpretor.hxx> #include <Draw_Interpretor.hxx>
#include <Draw_Printer.hxx> #include <Message.hxx>
#include <Message_Messenger.hxx> #include <Message_Messenger.hxx>
#include <DBRep.hxx> #include <DBRep.hxx>
@ -165,15 +165,13 @@ static Standard_Integer stepread (Draw_Interpretor& di/*theCommands*/, Standard_
// nom = "." -> fichier deja lu // nom = "." -> fichier deja lu
Standard_Integer i, num, nbs, modepri = 1; Standard_Integer i, num, nbs, modepri = 1;
if (fromtcl) modepri = 4; if (fromtcl) modepri = 4;
Handle(Message_Messenger) aDIMessenger =
new Message_Messenger (new Draw_Printer(di));
while (modepri) { while (modepri) {
num = sr.NbRootsForTransfer(); num = sr.NbRootsForTransfer();
if (!fromtcl) { if (!fromtcl) {
di<<"NbRootsForTransfer="<<num<<" :\n"; di<<"NbRootsForTransfer="<<num<<" :\n";
for (i = 1; i <= num; i ++) { for (i = 1; i <= num; i ++) {
di<<"Root."<<i<<", Ent. "; di<<"Root."<<i<<", Ent. ";
sr.Model()->Print(sr.RootForTransfer(i),aDIMessenger); sr.Model()->Print (sr.RootForTransfer(i), Message::DefaultMessenger());
di<<" Type:"<<sr.RootForTransfer(i)->DynamicType()->Name()<<"\n"; di<<" Type:"<<sr.RootForTransfer(i)->DynamicType()->Name()<<"\n";
} }