// File: ShapeProcess.cxx // Created: Mon Aug 21 19:03:02 2000 // Author: Andrey BETENEV // #include #include #include #include #include #include #include #include #include static Handle(ShapeProcess_DictionaryOfOperator) dic; //======================================================================= //function : RegisterOperator //purpose : //======================================================================= Standard_Boolean ShapeProcess::RegisterOperator (const Standard_CString name, const Handle(ShapeProcess_Operator)& op) { if ( dic.IsNull() ) dic = new ShapeProcess_DictionaryOfOperator; if ( dic->HasItem ( name, Standard_True ) ) { #ifdef DEB cout << "Warning: operator with name " << name << " is already registered!" << endl; #endif return Standard_False; } dic->SetItem ( name, op ); return Standard_True; } //======================================================================= //function : FindOperator //purpose : //======================================================================= Standard_Boolean ShapeProcess::FindOperator (const Standard_CString name, Handle(ShapeProcess_Operator)& op) { if ( dic.IsNull() ) dic = new ShapeProcess_DictionaryOfOperator; if ( ! dic->HasItem ( name, Standard_True ) ) { #ifdef DEB cout << "Error: no operator with name " << name << " registered!" << endl; #endif return Standard_False; } op = dic->Item ( name ); return !op.IsNull(); } //======================================================================= //function : Perform //purpose : //======================================================================= Standard_Boolean ShapeProcess::Perform (const Handle(ShapeProcess_Context)& context, const Standard_CString seq) { context->SetScope ( seq ); // get description of the sequence TCollection_AsciiString sequence; if ( ! context->GetString ( "exec.op", sequence ) ) { #ifdef DEB cout << "Error: ShapeProcess_Performer::Perform: sequence not defined for " << seq << endl; #endif context->UnSetScope(); return Standard_False; } TColStd_SequenceOfAsciiString sequenceOfOperators; TCollection_AsciiString oper; Standard_Integer i; for ( i=1; ; i++ ) { oper = sequence.Token ( " \t,;", i ); if ( oper.Length() <=0 ) break; sequenceOfOperators.Append(oper); } // put a message if ( context->TraceLevel() >=2 ) { Message_Msg SMSG0 ("Sequence.MSG0"); //Sequence of operators: %s TCollection_AsciiString Seq; for ( Standard_Integer i1=1; i1 <= sequenceOfOperators.Length(); i1++ ) { if (i1 > 1) Seq += ","; Seq += sequenceOfOperators.Value(i1); } SMSG0.Arg (Seq.ToCString()); context->Messenger()->Send (SMSG0, Message_Info); } // iterate on operators in the sequence for (i=1; i<=sequenceOfOperators.Length(); i++) { oper = sequenceOfOperators.Value(i); if ( context->TraceLevel() >=2 ) { Message_Msg SMSG5 ("Sequence.MSG5"); //Operator %d/%d: %s SMSG5 << i << sequenceOfOperators.Length() << oper.ToCString(); context->Messenger()->Send (SMSG5, Message_Alarm); } Handle(ShapeProcess_Operator) op; if ( ! ShapeProcess::FindOperator ( oper.ToCString(), op ) ) { if ( context->TraceLevel() >0 ) { Message_Msg SMSG1 ("Sequence.MSG1"); //Operator %s not found context->Messenger()->Send (SMSG1 << oper, Message_Alarm); } continue; } context->SetScope ( oper.ToCString() ); try { OCC_CATCH_SIGNALS op->Perform ( context ); } catch (Standard_Failure) { Message_Msg SMSG2 ("Sequence.MSG2"); //Operator %s failed with exception %s SMSG2 << oper << Standard_Failure::Caught()->GetMessageString(); context->Messenger()->Send (SMSG2, Message_Alarm); } context->UnSetScope(); } context->UnSetScope(); return Standard_True; }