mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0024202: Support class methods as callbacks for Draw Harness commands
This commit is contained in:
parent
eddb9c7c00
commit
dda67c1ca2
@ -110,9 +110,9 @@ is
|
|||||||
primitive CommandFunction;
|
primitive CommandFunction;
|
||||||
---Purpose: typedef Standard_Integer (*Draw_CommandFunction)
|
---Purpose: typedef Standard_Integer (*Draw_CommandFunction)
|
||||||
-- (Draw_Interpretor&, Standard_Integer, char**)
|
-- (Draw_Interpretor&, Standard_Integer, char**)
|
||||||
|
|
||||||
class Interpretor;
|
imported Interpretor;
|
||||||
---Purpose: Encapsulate the Tcl interpretor to add commands.
|
---Purpose: Encapsulate the Tcl interpretor to add commands.
|
||||||
|
|
||||||
class Printer;
|
class Printer;
|
||||||
---Purpose: Implements a printer class to connect Message_Messenger
|
---Purpose: Implements a printer class to connect Message_Messenger
|
||||||
|
@ -1,24 +0,0 @@
|
|||||||
// Created on: 1995-02-23
|
|
||||||
// Created by: Remi LEQUETTE
|
|
||||||
// Copyright (c) 1995-1999 Matra Datavision
|
|
||||||
// Copyright (c) 1999-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.
|
|
||||||
|
|
||||||
#ifndef _Draw_CommandFunction_HeaderFile
|
|
||||||
#define _Draw_CommandFunction_HeaderFile
|
|
||||||
|
|
||||||
class Draw_Interpretor;
|
|
||||||
|
|
||||||
typedef Standard_Integer (*Draw_CommandFunction)(Draw_Interpretor&, Standard_Integer, const char**);
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,174 +0,0 @@
|
|||||||
-- Created on: 1995-02-23
|
|
||||||
-- Created by: Remi LEQUETTE
|
|
||||||
-- Copyright (c) 1995-1999 Matra Datavision
|
|
||||||
-- Copyright (c) 1999-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.
|
|
||||||
|
|
||||||
class Interpretor from Draw
|
|
||||||
|
|
||||||
---Purpose: Provides an encapsulation of the TCL interpretor
|
|
||||||
-- to define Draw commands.
|
|
||||||
|
|
||||||
uses
|
|
||||||
|
|
||||||
SStream from Standard,
|
|
||||||
PInterp from Draw,
|
|
||||||
CommandFunction from Draw,
|
|
||||||
AsciiString from TCollection,
|
|
||||||
ExtendedString from TCollection
|
|
||||||
|
|
||||||
is
|
|
||||||
|
|
||||||
Create returns Interpretor from Draw;
|
|
||||||
|
|
||||||
Init(me : in out);
|
|
||||||
|
|
||||||
Add(me : in out; Command : CString;
|
|
||||||
Help : CString;
|
|
||||||
Function : CommandFunction from Draw;
|
|
||||||
Group : CString = "User Commands");
|
|
||||||
---Purpose: Creates a new command with name <Command>, help
|
|
||||||
-- string <Help> in group <Group>.
|
|
||||||
-- <Function> implement the function.
|
|
||||||
|
|
||||||
Add(me : in out; Command : CString;
|
|
||||||
Help : CString;
|
|
||||||
FileName : CString ;
|
|
||||||
Function : CommandFunction from Draw;
|
|
||||||
Group : CString = "User Commands");
|
|
||||||
---Purpose: Creates a new command with name <Command>, help
|
|
||||||
-- string <Help> in group <Group>. <Function>
|
|
||||||
-- implement the function.
|
|
||||||
-- <FileName> is the name of the file that contains
|
|
||||||
-- the implementation of the command
|
|
||||||
--
|
|
||||||
|
|
||||||
Remove(me : in out; Command : CString)
|
|
||||||
returns Boolean;
|
|
||||||
---Purpose: Removes <Command>, returns true if success (the
|
|
||||||
-- command existed).
|
|
||||||
|
|
||||||
--
|
|
||||||
-- The result
|
|
||||||
--
|
|
||||||
|
|
||||||
Result(me) returns CString;
|
|
||||||
|
|
||||||
Reset(me : in out);
|
|
||||||
---Purpose: Resets the result to empty string
|
|
||||||
|
|
||||||
Append(me : in out; Result : CString) returns Interpretor from Draw;
|
|
||||||
---Purpose: Appends to the result
|
|
||||||
---C++: return &
|
|
||||||
---C++: alias operator<<
|
|
||||||
|
|
||||||
Append(me : in out; Result : AsciiString from TCollection)
|
|
||||||
returns Interpretor from Draw;
|
|
||||||
---Purpose: Appends to the result
|
|
||||||
---C++: return &
|
|
||||||
---C++: alias operator<<
|
|
||||||
|
|
||||||
Append(me : in out; Result : ExtendedString from TCollection)
|
|
||||||
returns Interpretor from Draw;
|
|
||||||
---Purpose: Appends to the result
|
|
||||||
---C++: return &
|
|
||||||
---C++: alias operator<<
|
|
||||||
|
|
||||||
Append(me : in out; Result : Integer) returns Interpretor from Draw;
|
|
||||||
---Purpose: Appends to the result
|
|
||||||
---C++: return &
|
|
||||||
---C++: alias operator<<
|
|
||||||
|
|
||||||
Append(me : in out; Result : Real) returns Interpretor from Draw;
|
|
||||||
---Purpose: Appends to the result
|
|
||||||
---C++: return &
|
|
||||||
---C++: alias operator<<
|
|
||||||
|
|
||||||
Append(me : in out; Result : SStream) returns Interpretor from Draw;
|
|
||||||
---Purpose: Appends to the result
|
|
||||||
---C++: return &
|
|
||||||
---C++: alias operator<<
|
|
||||||
|
|
||||||
AppendElement(me : in out; Result : CString);
|
|
||||||
---Purpose: Appends to the result the string as a list element
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Interpetation
|
|
||||||
--
|
|
||||||
|
|
||||||
Eval(me : in out; Script : CString)
|
|
||||||
returns Integer;
|
|
||||||
---Purpose: Eval the script and returns OK = 0, ERROR = 1
|
|
||||||
|
|
||||||
RecordAndEval(me : in out; Script : CString; Flags : Integer = 0)
|
|
||||||
returns Integer;
|
|
||||||
---Purpose: Eval the script and returns OK = 0, ERROR = 1
|
|
||||||
-- Store the script in the history record.
|
|
||||||
|
|
||||||
EvalFile(me : in out; FileName : CString)
|
|
||||||
returns Integer;
|
|
||||||
---Purpose: Eval the content on the file and returns status
|
|
||||||
|
|
||||||
Complete(myclass; Script : CString) returns Boolean;
|
|
||||||
---Purpose: Returns True if the script is complete, no pending
|
|
||||||
-- closing braces. (})
|
|
||||||
|
|
||||||
Destroy(me : in out);
|
|
||||||
---C++: alias ~
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Access to Tcl_Interp
|
|
||||||
--
|
|
||||||
|
|
||||||
Create(anInterp : PInterp from Draw)
|
|
||||||
returns Interpretor from Draw;
|
|
||||||
|
|
||||||
Set(me : in out; anInterp : PInterp from Draw);
|
|
||||||
|
|
||||||
Interp (me) returns PInterp from Draw;
|
|
||||||
|
|
||||||
SetDoLog (me: in out; doLog: Boolean);
|
|
||||||
---Purpose: Enables or disables logging of all commands and their
|
|
||||||
-- results
|
|
||||||
---Level: Advanced
|
|
||||||
|
|
||||||
SetDoEcho (me: in out; doEcho: Boolean);
|
|
||||||
---Purpose: Enables or disables eachoing of all commands and their
|
|
||||||
-- results to cout
|
|
||||||
---Level: Advanced
|
|
||||||
|
|
||||||
GetDoLog (me) returns Boolean;
|
|
||||||
---Purpose: Returns true if logging of commands is enabled
|
|
||||||
---Level: Advanced
|
|
||||||
|
|
||||||
GetDoEcho (me) returns Boolean;
|
|
||||||
---Purpose: Returns true if echoing of commands is enabled
|
|
||||||
---Level: Advanced
|
|
||||||
|
|
||||||
Log (me: in out) returns SStream;
|
|
||||||
---Purpose: Returns log stream
|
|
||||||
---Level: Advanced
|
|
||||||
---C++: return &
|
|
||||||
|
|
||||||
fields
|
|
||||||
|
|
||||||
isAllocated : Boolean from Standard;
|
|
||||||
myInterp : PInterp from Draw;
|
|
||||||
|
|
||||||
myDoLog: Boolean;
|
|
||||||
myDoEcho: Boolean;
|
|
||||||
myLog: SStream from Standard;
|
|
||||||
|
|
||||||
end Interpretor;
|
|
@ -14,7 +14,7 @@
|
|||||||
// Alternatively, this file may be used under the terms of Open CASCADE
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
||||||
// commercial license or contractual agreement.
|
// commercial license or contractual agreement.
|
||||||
|
|
||||||
#include <Draw_Interpretor.ixx>
|
#include <Draw_Interpretor.hxx>
|
||||||
#include <Draw_Appli.hxx>
|
#include <Draw_Appli.hxx>
|
||||||
#include <Standard_SStream.hxx>
|
#include <Standard_SStream.hxx>
|
||||||
#include <Standard_RangeError.hxx>
|
#include <Standard_RangeError.hxx>
|
||||||
@ -91,17 +91,6 @@ class TclUTFToLocalStringSentry {
|
|||||||
char **Argv;
|
char **Argv;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// Call backs for TCL
|
|
||||||
//
|
|
||||||
|
|
||||||
struct CData {
|
|
||||||
CData(Draw_CommandFunction ff, Draw_Interpretor* ii) : f(ff), i(ii) {}
|
|
||||||
Draw_CommandFunction f;
|
|
||||||
Draw_Interpretor* i;
|
|
||||||
};
|
|
||||||
|
|
||||||
// logging helpers
|
// logging helpers
|
||||||
namespace {
|
namespace {
|
||||||
void dumpArgs (Standard_OStream& os, int argc, const char *argv[])
|
void dumpArgs (Standard_OStream& os, int argc, const char *argv[])
|
||||||
@ -183,18 +172,18 @@ namespace {
|
|||||||
// MKV 29.03.05
|
// MKV 29.03.05
|
||||||
#if ((TCL_MAJOR_VERSION > 8) || ((TCL_MAJOR_VERSION == 8) && (TCL_MINOR_VERSION >= 4))) && !defined(USE_NON_CONST)
|
#if ((TCL_MAJOR_VERSION > 8) || ((TCL_MAJOR_VERSION == 8) && (TCL_MINOR_VERSION >= 4))) && !defined(USE_NON_CONST)
|
||||||
static Standard_Integer CommandCmd
|
static Standard_Integer CommandCmd
|
||||||
(ClientData clientData, Tcl_Interp *interp,
|
(ClientData theClientData, Tcl_Interp *interp,
|
||||||
Standard_Integer argc, const char* argv[])
|
Standard_Integer argc, const char* argv[])
|
||||||
#else
|
#else
|
||||||
static Standard_Integer CommandCmd
|
static Standard_Integer CommandCmd
|
||||||
(ClientData clientData, Tcl_Interp *interp,
|
(ClientData theClientData, Tcl_Interp *interp,
|
||||||
Standard_Integer argc, char* argv[])
|
Standard_Integer argc, char* argv[])
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
static Standard_Integer code;
|
static Standard_Integer code;
|
||||||
code = TCL_OK;
|
code = TCL_OK;
|
||||||
CData* C = (CData*) clientData;
|
Draw_Interpretor::CallBackData* aCallback = (Draw_Interpretor::CallBackData* )theClientData;
|
||||||
Draw_Interpretor& di = *(C->i);
|
Draw_Interpretor& di = *(aCallback->myDI);
|
||||||
|
|
||||||
// log command execution, except commands manipulating log itself and echo
|
// log command execution, except commands manipulating log itself and echo
|
||||||
Standard_Boolean isLogManipulation = (strcmp (argv[0], "dlog") == 0 ||
|
Standard_Boolean isLogManipulation = (strcmp (argv[0], "dlog") == 0 ||
|
||||||
@ -231,7 +220,7 @@ static Standard_Integer CommandCmd
|
|||||||
// OCC63: Convert strings from UTF-8 to local encoding, normally expected by OCC commands
|
// OCC63: Convert strings from UTF-8 to local encoding, normally expected by OCC commands
|
||||||
TclUTFToLocalStringSentry anArgs ( argc, (const char**)argv );
|
TclUTFToLocalStringSentry anArgs ( argc, (const char**)argv );
|
||||||
|
|
||||||
Standard_Integer fres = C->f ( di, argc, anArgs.GetArgv() );
|
Standard_Integer fres = aCallback->Invoke ( di, argc, anArgs.GetArgv() );
|
||||||
if (fres != 0)
|
if (fres != 0)
|
||||||
code = TCL_ERROR;
|
code = TCL_ERROR;
|
||||||
}
|
}
|
||||||
@ -299,11 +288,10 @@ static Standard_Integer CommandCmd
|
|||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void CommandDelete (ClientData theClientData)
|
||||||
static void CommandDelete (ClientData clientData)
|
|
||||||
{
|
{
|
||||||
CData *C = (CData*) clientData;
|
Draw_Interpretor::CallBackData* aCallback = (Draw_Interpretor::CallBackData* )theClientData;
|
||||||
delete C;
|
delete aCallback;
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
@ -346,78 +334,50 @@ Draw_Interpretor::Draw_Interpretor(const Draw_PInterp& p) :
|
|||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : Add
|
//function : add
|
||||||
//purpose :
|
//purpose :
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//#ifdef WNT
|
void Draw_Interpretor::add (const Standard_CString theCommandName,
|
||||||
void Draw_Interpretor::Add(const Standard_CString n,
|
const Standard_CString theHelp,
|
||||||
const Standard_CString help,
|
const Standard_CString theFileName,
|
||||||
const Draw_CommandFunction f,
|
Draw_Interpretor::CallBackData* theCallback,
|
||||||
const Standard_CString group)
|
const Standard_CString theGroup)
|
||||||
//#else
|
|
||||||
//void Draw_Interpretor::Add(const Standard_CString n,
|
|
||||||
// const Standard_CString help,
|
|
||||||
// const Draw_CommandFunction& f,
|
|
||||||
// const Standard_CString group)
|
|
||||||
//#endif
|
|
||||||
{
|
{
|
||||||
Standard_PCharacter pN, pHelp, pGroup;
|
if (myInterp == NULL)
|
||||||
//
|
{
|
||||||
pN=(Standard_PCharacter)n;
|
Init();
|
||||||
pHelp=(Standard_PCharacter)help;
|
}
|
||||||
pGroup=(Standard_PCharacter)group;
|
|
||||||
//
|
|
||||||
if (myInterp==NULL) Init();
|
|
||||||
|
|
||||||
CData* C = new CData(f,this);
|
Standard_PCharacter aName = (Standard_PCharacter )theCommandName;
|
||||||
|
Standard_PCharacter aHelp = (Standard_PCharacter )theHelp;
|
||||||
Tcl_CreateCommand(myInterp, pN ,CommandCmd, (ClientData) C, CommandDelete);
|
Standard_PCharacter aGroup = (Standard_PCharacter )theGroup;
|
||||||
|
Tcl_CreateCommand (myInterp, aName, CommandCmd, (ClientData )theCallback, CommandDelete);
|
||||||
|
|
||||||
// add the help
|
// add the help
|
||||||
Tcl_SetVar2(myInterp,"Draw_Helps", pN, pHelp, TCL_GLOBAL_ONLY);
|
Tcl_SetVar2 (myInterp, "Draw_Helps", aName, aHelp, TCL_GLOBAL_ONLY);
|
||||||
Tcl_SetVar2(myInterp,"Draw_Groups",pGroup,pN,
|
Tcl_SetVar2 (myInterp, "Draw_Groups", aGroup, aName,
|
||||||
TCL_GLOBAL_ONLY|TCL_APPEND_VALUE|TCL_LIST_ELEMENT);
|
TCL_GLOBAL_ONLY | TCL_APPEND_VALUE | TCL_LIST_ELEMENT);
|
||||||
}
|
|
||||||
//=======================================================================
|
|
||||||
//function : Add
|
|
||||||
//purpose :
|
|
||||||
//=======================================================================
|
|
||||||
void Draw_Interpretor::Add(const Standard_CString n,
|
|
||||||
const Standard_CString help,
|
|
||||||
const Standard_CString file_name,
|
|
||||||
const Draw_CommandFunction f,
|
|
||||||
const Standard_CString group)
|
|
||||||
{
|
|
||||||
Standard_PCharacter pN, pHelp, pGroup, pFileName;
|
|
||||||
//
|
|
||||||
pN=(Standard_PCharacter)n;
|
|
||||||
pHelp=(Standard_PCharacter)help;
|
|
||||||
pGroup=(Standard_PCharacter)group;
|
|
||||||
pFileName=(Standard_PCharacter)file_name;
|
|
||||||
//
|
|
||||||
if (myInterp==NULL) Init();
|
|
||||||
|
|
||||||
CData* C = new CData(f,this);
|
|
||||||
Tcl_CreateCommand(myInterp,pN,CommandCmd, (ClientData) C, CommandDelete);
|
|
||||||
|
|
||||||
// add the help
|
|
||||||
Tcl_SetVar2(myInterp,"Draw_Helps",pN,pHelp,TCL_GLOBAL_ONLY);
|
|
||||||
Tcl_SetVar2(myInterp,"Draw_Groups",pGroup,pN,
|
|
||||||
TCL_GLOBAL_ONLY|TCL_APPEND_VALUE|TCL_LIST_ELEMENT);
|
|
||||||
|
|
||||||
// add path to source file (keep not more than two last subdirectories)
|
// add path to source file (keep not more than two last subdirectories)
|
||||||
OSD_Path aPath (pFileName);
|
if (theFileName == NULL
|
||||||
|
|| *theFileName == '\0')
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
OSD_Path aPath (theFileName);
|
||||||
Standard_Integer nbTrek = aPath.TrekLength();
|
Standard_Integer nbTrek = aPath.TrekLength();
|
||||||
for (Standard_Integer i = 2; i < nbTrek; i++)
|
for (Standard_Integer i = 2; i < nbTrek; ++i)
|
||||||
|
{
|
||||||
aPath.RemoveATrek (1);
|
aPath.RemoveATrek (1);
|
||||||
aPath.SetDisk("");
|
}
|
||||||
aPath.SetNode("");
|
aPath.SetDisk ("");
|
||||||
|
aPath.SetNode ("");
|
||||||
TCollection_AsciiString aSrcPath;
|
TCollection_AsciiString aSrcPath;
|
||||||
aPath.SystemName (aSrcPath);
|
aPath.SystemName (aSrcPath);
|
||||||
Tcl_SetVar2(myInterp,"Draw_Files",pN,aSrcPath.ToCString(),TCL_GLOBAL_ONLY);
|
Tcl_SetVar2 (myInterp, "Draw_Files", aName, aSrcPath.ToCString(), TCL_GLOBAL_ONLY);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : Remove
|
//function : Remove
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -634,7 +594,7 @@ Standard_Boolean Draw_Interpretor::Complete(const Standard_CString line)
|
|||||||
//purpose :
|
//purpose :
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
|
||||||
void Draw_Interpretor::Destroy()
|
Draw_Interpretor::~Draw_Interpretor()
|
||||||
{
|
{
|
||||||
// MKV 01.02.05
|
// MKV 01.02.05
|
||||||
#if ((TCL_MAJOR_VERSION > 8) || ((TCL_MAJOR_VERSION == 8) && (TCL_MINOR_VERSION >= 4)))
|
#if ((TCL_MAJOR_VERSION > 8) || ((TCL_MAJOR_VERSION == 8) && (TCL_MINOR_VERSION >= 4)))
|
||||||
|
263
src/Draw/Draw_Interpretor.hxx
Normal file
263
src/Draw/Draw_Interpretor.hxx
Normal file
@ -0,0 +1,263 @@
|
|||||||
|
// Created on: 1995-02-23
|
||||||
|
// Created by: Remi LEQUETTE
|
||||||
|
// Copyright (c) 1995-1999 Matra Datavision
|
||||||
|
// Copyright (c) 1999-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.
|
||||||
|
|
||||||
|
#ifndef _Draw_Interpretor_HeaderFile
|
||||||
|
#define _Draw_Interpretor_HeaderFile
|
||||||
|
|
||||||
|
#include <Standard.hxx>
|
||||||
|
#include <Standard_DefineAlloc.hxx>
|
||||||
|
#include <Standard_Macro.hxx>
|
||||||
|
#include <Standard_Boolean.hxx>
|
||||||
|
#include <Draw_PInterp.hxx>
|
||||||
|
#include <Standard_SStream.hxx>
|
||||||
|
#include <Standard_CString.hxx>
|
||||||
|
#include <Standard_Integer.hxx>
|
||||||
|
#include <Standard_Real.hxx>
|
||||||
|
|
||||||
|
class TCollection_AsciiString;
|
||||||
|
class TCollection_ExtendedString;
|
||||||
|
|
||||||
|
//! Provides an encapsulation of the TCL interpretor to define Draw commands.
|
||||||
|
class Draw_Interpretor
|
||||||
|
{
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
//! Global callback function definition
|
||||||
|
typedef Standard_Integer (*CommandFunction )(Draw_Interpretor& theDI,
|
||||||
|
Standard_Integer theArgNb,
|
||||||
|
const char** theArgVec);
|
||||||
|
|
||||||
|
//! Callback for TCL (interface)
|
||||||
|
struct CallBackData
|
||||||
|
{
|
||||||
|
|
||||||
|
//! Main constructor
|
||||||
|
CallBackData (Draw_Interpretor* theDI) : myDI (theDI) {}
|
||||||
|
|
||||||
|
//! Destructor
|
||||||
|
virtual ~CallBackData() {}
|
||||||
|
|
||||||
|
//! Invoke function
|
||||||
|
virtual Standard_Integer Invoke (Draw_Interpretor& theDI,
|
||||||
|
Standard_Integer theArgNb,
|
||||||
|
const char** theArgVec) = 0;
|
||||||
|
|
||||||
|
Draw_Interpretor* myDI; //!< pointer to Draw Interpretor
|
||||||
|
|
||||||
|
// make sure allocation and de-allocation is done by the same memory allocator
|
||||||
|
DEFINE_STANDARD_ALLOC
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
//! Callback implementation for global function definition
|
||||||
|
struct CallBackDataFunc : public CallBackData
|
||||||
|
{
|
||||||
|
|
||||||
|
CallBackDataFunc (Draw_Interpretor* theDI,
|
||||||
|
CommandFunction theFunc)
|
||||||
|
: CallBackData (theDI),
|
||||||
|
myFunc (theFunc) {}
|
||||||
|
|
||||||
|
virtual Standard_Integer Invoke (Draw_Interpretor& theDI,
|
||||||
|
Standard_Integer theArgNb,
|
||||||
|
const char** theArgVec)
|
||||||
|
{
|
||||||
|
return myFunc != NULL ? myFunc (theDI, theArgNb, theArgVec) : 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
Draw_Interpretor::CommandFunction myFunc;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
//! Callback implementation for class's method definition
|
||||||
|
template<typename theObjHandle>
|
||||||
|
struct CallBackDataMethod : public CallBackData
|
||||||
|
{
|
||||||
|
typedef typename theObjHandle::element_type element_type;
|
||||||
|
typedef Standard_Integer (element_type::*methodType)(Draw_Interpretor& , Standard_Integer , const char** );
|
||||||
|
|
||||||
|
CallBackDataMethod (Draw_Interpretor* theDI,
|
||||||
|
const theObjHandle& theObjPtr,
|
||||||
|
methodType theMethod)
|
||||||
|
: CallBackData (theDI),
|
||||||
|
myObjPtr (theObjPtr),
|
||||||
|
myMethod (theMethod) {}
|
||||||
|
|
||||||
|
virtual Standard_Integer Invoke (Draw_Interpretor& theDI,
|
||||||
|
Standard_Integer theArgNb,
|
||||||
|
const char** theArgVec)
|
||||||
|
{
|
||||||
|
return myMethod != NULL && !myObjPtr.IsNull()
|
||||||
|
? (myObjPtr.operator->()->*myMethod) (theDI, theArgNb, theArgVec)
|
||||||
|
: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
theObjHandle myObjPtr;
|
||||||
|
methodType myMethod;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
//! Empty constructor
|
||||||
|
Standard_EXPORT Draw_Interpretor();
|
||||||
|
|
||||||
|
//! Initialize TCL interpretor
|
||||||
|
Standard_EXPORT void Init();
|
||||||
|
|
||||||
|
//! Creates a new command with name <theCommandName>, help string <theHelp> in group <theGroup>.
|
||||||
|
//! @param theFunction callback implementation
|
||||||
|
inline void Add (Standard_CString theCommandName,
|
||||||
|
Standard_CString theHelp,
|
||||||
|
CommandFunction theFunction,
|
||||||
|
Standard_CString theGroup = "User Commands")
|
||||||
|
{
|
||||||
|
Add (theCommandName, theHelp, "", theFunction, theGroup);
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Creates a new command with name <theCommandName>, help string <theHelp> in group <theGroup>.
|
||||||
|
//! @theFunction callback implementation
|
||||||
|
//! @theFileName the name of the file that contains the implementation of the command
|
||||||
|
inline void Add (Standard_CString theCommandName,
|
||||||
|
Standard_CString theHelp,
|
||||||
|
Standard_CString theFileName,
|
||||||
|
CommandFunction theFunction,
|
||||||
|
Standard_CString theGroup = "User Commands")
|
||||||
|
{
|
||||||
|
CallBackDataFunc* aCallback = new CallBackDataFunc (this, theFunction);
|
||||||
|
add (theCommandName, theHelp, theFileName, aCallback, theGroup);
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Creates a new command with name <theCommandName>, help string <theHelp> in group <theGroup>.
|
||||||
|
//! @param theObjPtr callback class instance
|
||||||
|
//! @param theMethod callback implementation
|
||||||
|
//! @param theFileName the name of the file that contains the implementation of the command
|
||||||
|
template<typename theHandleType>
|
||||||
|
inline void Add (Standard_CString theCommandName,
|
||||||
|
Standard_CString theHelp,
|
||||||
|
Standard_CString theFileName,
|
||||||
|
const theHandleType& theObjPtr,
|
||||||
|
typename Draw_Interpretor::CallBackDataMethod<theHandleType>::methodType theMethod,
|
||||||
|
Standard_CString theGroup)
|
||||||
|
{
|
||||||
|
Draw_Interpretor::CallBackDataMethod<theHandleType>* aCallback =
|
||||||
|
new Draw_Interpretor::CallBackDataMethod<theHandleType> (this, theObjPtr, theMethod);
|
||||||
|
add (theCommandName, theHelp, theFileName, aCallback, theGroup);
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Removes <theCommandName>, returns true if success (the command existed).
|
||||||
|
Standard_EXPORT Standard_Boolean Remove (const Standard_CString theCommandName);
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
Standard_EXPORT Standard_CString Result() const;
|
||||||
|
|
||||||
|
//! Resets the result to empty string
|
||||||
|
Standard_EXPORT void Reset();
|
||||||
|
|
||||||
|
//! Appends to the result
|
||||||
|
Standard_EXPORT Draw_Interpretor& Append (const Standard_CString theResult);
|
||||||
|
inline Draw_Interpretor& operator<< (const Standard_CString theResult) { return Append (theResult); }
|
||||||
|
|
||||||
|
//! Appends to the result
|
||||||
|
Standard_EXPORT Draw_Interpretor& Append (const TCollection_AsciiString& theResult);
|
||||||
|
inline Draw_Interpretor& operator<< (const TCollection_AsciiString& theResult) { return Append (theResult); }
|
||||||
|
|
||||||
|
//! Appends to the result
|
||||||
|
Standard_EXPORT Draw_Interpretor& Append (const TCollection_ExtendedString& theResult);
|
||||||
|
inline Draw_Interpretor& operator<< (const TCollection_ExtendedString& theResult) { return Append (theResult); }
|
||||||
|
|
||||||
|
//! Appends to the result
|
||||||
|
Standard_EXPORT Draw_Interpretor& Append (const Standard_Integer theResult);
|
||||||
|
inline Draw_Interpretor& operator<< (const Standard_Integer theResult) { return Append (theResult); }
|
||||||
|
|
||||||
|
//! Appends to the result
|
||||||
|
Standard_EXPORT Draw_Interpretor& Append (const Standard_Real theResult);
|
||||||
|
inline Draw_Interpretor& operator<< (const Standard_Real theResult) { return Append (theResult); }
|
||||||
|
|
||||||
|
//! Appends to the result
|
||||||
|
Standard_EXPORT Draw_Interpretor& Append (const Standard_SStream& theResult);
|
||||||
|
inline Draw_Interpretor& operator<< (const Standard_SStream& theResult) { return Append (theResult); }
|
||||||
|
|
||||||
|
//! Appends to the result the string as a list element
|
||||||
|
Standard_EXPORT void AppendElement (const Standard_CString theResult);
|
||||||
|
|
||||||
|
//! Eval the script and returns OK = 0, ERROR = 1
|
||||||
|
Standard_EXPORT Standard_Integer Eval (const Standard_CString theScript);
|
||||||
|
|
||||||
|
//! Eval the script and returns OK = 0, ERROR = 1
|
||||||
|
//! Store the script in the history record.
|
||||||
|
Standard_EXPORT Standard_Integer RecordAndEval (const Standard_CString theScript,
|
||||||
|
const Standard_Integer theFlags = 0);
|
||||||
|
|
||||||
|
//! Eval the content on the file and returns status
|
||||||
|
Standard_EXPORT Standard_Integer EvalFile (const Standard_CString theFileName);
|
||||||
|
|
||||||
|
//! Returns True if the script is complete, no pending closing braces. (})
|
||||||
|
Standard_EXPORT static Standard_Boolean Complete (const Standard_CString theScript);
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
//! Destructor
|
||||||
|
Standard_EXPORT ~Draw_Interpretor();
|
||||||
|
|
||||||
|
Standard_EXPORT Draw_Interpretor (const Draw_PInterp& theInterp);
|
||||||
|
|
||||||
|
Standard_EXPORT void Set (const Draw_PInterp& theInterp);
|
||||||
|
|
||||||
|
Standard_EXPORT Draw_PInterp Interp() const;
|
||||||
|
|
||||||
|
//! Enables or disables logging of all commands and their results
|
||||||
|
Standard_EXPORT void SetDoLog (const Standard_Boolean theDoLog);
|
||||||
|
|
||||||
|
//! Enables or disables eachoing of all commands and their results to cout
|
||||||
|
Standard_EXPORT void SetDoEcho (const Standard_Boolean theDoEcho);
|
||||||
|
|
||||||
|
//! Returns true if logging of commands is enabled
|
||||||
|
Standard_EXPORT Standard_Boolean GetDoLog() const;
|
||||||
|
|
||||||
|
//! Returns true if echoing of commands is enabled
|
||||||
|
Standard_EXPORT Standard_Boolean GetDoEcho() const;
|
||||||
|
|
||||||
|
//! Returns log stream
|
||||||
|
Standard_EXPORT Standard_SStream& Log();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
Standard_EXPORT void add (Standard_CString theCommandName,
|
||||||
|
Standard_CString theHelp,
|
||||||
|
Standard_CString theFileName,
|
||||||
|
CallBackData* theCallback,
|
||||||
|
Standard_CString theGroup);
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
Standard_Boolean isAllocated;
|
||||||
|
Draw_PInterp myInterp;
|
||||||
|
Standard_Boolean myDoLog;
|
||||||
|
Standard_Boolean myDoEcho;
|
||||||
|
Standard_SStream myLog;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
DEFINE_STANDARD_ALLOC
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // _Draw_Interpretor_HeaderFile
|
@ -8,13 +8,14 @@ Draw_VariableCommands.cxx
|
|||||||
Draw_GraphicCommands.cxx
|
Draw_GraphicCommands.cxx
|
||||||
Draw_UnitCommands.cxx
|
Draw_UnitCommands.cxx
|
||||||
Draw_Appli.hxx
|
Draw_Appli.hxx
|
||||||
|
Draw_Interpretor.hxx
|
||||||
|
Draw_Interpretor.cxx
|
||||||
Draw_Viewer.cxx
|
Draw_Viewer.cxx
|
||||||
Draw_Viewer.hxx
|
Draw_Viewer.hxx
|
||||||
Draw_Viewer.hxx
|
Draw_Viewer.hxx
|
||||||
Draw_Window.cxx
|
Draw_Window.cxx
|
||||||
Draw_Window.hxx
|
Draw_Window.hxx
|
||||||
Draw_PInterp.hxx
|
Draw_PInterp.hxx
|
||||||
Draw_CommandFunction.hxx
|
|
||||||
DrawRessource.h
|
DrawRessource.h
|
||||||
init.h
|
init.h
|
||||||
MAINWINDOW.h
|
MAINWINDOW.h
|
||||||
|
@ -76,7 +76,9 @@ class NCollection_Handle : public Handle_Standard_Transient
|
|||||||
: Handle_Standard_Transient (thePtr) {}
|
: Handle_Standard_Transient (thePtr) {}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
typedef T element_type;
|
||||||
|
|
||||||
//! Default constructor; creates null handle
|
//! Default constructor; creates null handle
|
||||||
NCollection_Handle () {}
|
NCollection_Handle () {}
|
||||||
|
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
#include <BRepPrimAPI_MakeSphere.hxx>
|
#include <BRepPrimAPI_MakeSphere.hxx>
|
||||||
#include <BRepAlgo_Cut.hxx>
|
#include <BRepAlgo_Cut.hxx>
|
||||||
#include <NCollection_Map.hxx>
|
#include <NCollection_Map.hxx>
|
||||||
|
#include <NCollection_Handle.hxx>
|
||||||
#include <TCollection_HAsciiString.hxx>
|
#include <TCollection_HAsciiString.hxx>
|
||||||
|
|
||||||
#include <Standard_Version.hxx>
|
#include <Standard_Version.hxx>
|
||||||
@ -1532,9 +1533,41 @@ static Standard_Integer OCC24533 (Draw_Interpretor& di, Standard_Integer n, cons
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Dummy class to test interface for compilation issues
|
||||||
|
class QABugs_HandleClass : public Standard_Transient
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Standard_Integer HandleProc (Draw_Interpretor& , Standard_Integer , const char** theArgVec)
|
||||||
|
{
|
||||||
|
std::cerr << "QABugs_HandleClass[" << this << "] " << theArgVec[0] << "\n";
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
DEFINE_STANDARD_RTTI(QABugs_HandleClass) // Type definition
|
||||||
|
};
|
||||||
|
DEFINE_STANDARD_HANDLE (QABugs_HandleClass, Standard_Transient)
|
||||||
|
IMPLEMENT_STANDARD_HANDLE (QABugs_HandleClass, Standard_Transient)
|
||||||
|
IMPLEMENT_STANDARD_RTTIEXT(QABugs_HandleClass, Standard_Transient)
|
||||||
|
|
||||||
|
// Dummy class to test interface for compilation issues
|
||||||
|
struct QABugs_NHandleClass
|
||||||
|
{
|
||||||
|
Standard_Integer NHandleProc (Draw_Interpretor& , Standard_Integer , const char** theArgVec)
|
||||||
|
{
|
||||||
|
std::cerr << "QABugs_NHandleClass[" << this << "] " << "" << theArgVec[0] << "\n";
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
void QABugs::Commands_19(Draw_Interpretor& theCommands) {
|
void QABugs::Commands_19(Draw_Interpretor& theCommands) {
|
||||||
const char *group = "QABugs";
|
const char *group = "QABugs";
|
||||||
|
|
||||||
|
Handle(QABugs_HandleClass) aClassPtr = new QABugs_HandleClass();
|
||||||
|
theCommands.Add ("OCC24202_1", "Test Handle-based procedure",
|
||||||
|
__FILE__, aClassPtr, &QABugs_HandleClass::HandleProc, group);
|
||||||
|
NCollection_Handle<QABugs_NHandleClass> aNClassPtr = new QABugs_NHandleClass();
|
||||||
|
theCommands.Add ("OCC24202_2", "Test NCollection_Handle-based procedure",
|
||||||
|
__FILE__, aNClassPtr, &QABugs_NHandleClass::NHandleProc, group);
|
||||||
|
|
||||||
theCommands.Add ("OCC230", "OCC230 TrimmedCurve Pnt2d Pnt2d", __FILE__, OCC230, group);
|
theCommands.Add ("OCC230", "OCC230 TrimmedCurve Pnt2d Pnt2d", __FILE__, OCC230, group);
|
||||||
theCommands.Add ("OCC142", "OCC142", __FILE__, OCC142, group);
|
theCommands.Add ("OCC142", "OCC142", __FILE__, OCC142, group);
|
||||||
theCommands.Add ("OCC23361", "OCC23361", __FILE__, OCC23361, group);
|
theCommands.Add ("OCC23361", "OCC23361", __FILE__, OCC23361, group);
|
||||||
|
@ -45,6 +45,8 @@ Standard_EXPORT const Handle(Standard_Type)& STANDARD_TYPE(C1); \
|
|||||||
\
|
\
|
||||||
class Handle(C1) : public Handle(C2) { \
|
class Handle(C1) : public Handle(C2) { \
|
||||||
public: \
|
public: \
|
||||||
|
typedef C1 element_type;\
|
||||||
|
\
|
||||||
Handle(C1)():Handle(C2)() {} \
|
Handle(C1)():Handle(C2)() {} \
|
||||||
\
|
\
|
||||||
Handle(C1)(const Handle(C1)& aHandle) : Handle(C2)(aHandle) {} \
|
Handle(C1)(const Handle(C1)& aHandle) : Handle(C2)(aHandle) {} \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user