From d9aa870e5d509cc7309ab82dd102a937ab58613a Mon Sep 17 00:00:00 2001 From: Unit 193 Date: Thu, 9 Feb 2017 04:36:04 -0500 Subject: Imported Upstream version 3.1.1+dfsg1 --- Plugins/ScriptingTcl/scriptingtcl.cpp | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'Plugins/ScriptingTcl/scriptingtcl.cpp') diff --git a/Plugins/ScriptingTcl/scriptingtcl.cpp b/Plugins/ScriptingTcl/scriptingtcl.cpp index 4390317..962c073 100644 --- a/Plugins/ScriptingTcl/scriptingtcl.cpp +++ b/Plugins/ScriptingTcl/scriptingtcl.cpp @@ -435,6 +435,28 @@ int ScriptingTcl::dbCommand(ClientData clientData, Tcl_Interp* interp, int objc, return TCL_ERROR; } +int ScriptingTcl::initTclCommand(ClientData clientData, Tcl_Interp* interp, int objc, Tcl_Obj* const objv[]) +{ + UNUSED(clientData); + UNUSED(objv); + + if (objc > 1) + { + Tcl_Obj* result = Tcl_NewStringObj(tr("Error from Tcl's' '%1' command: %2").arg("tcl_init", "invalid # args: tcl_init").toUtf8().constData(), -1); + Tcl_SetObjResult(interp, result); + return TCL_ERROR; + } + + int res = Tcl_Init(interp); + if (res != TCL_OK) + { + ScriptObject codeObj("set tcl_library $tcl_pkgPath"); + Tcl_EvalObjEx(interp, codeObj.getTclObj(), TCL_EVAL_GLOBAL); + res = Tcl_Init(interp); + } + return res; +} + int ScriptingTcl::dbEval(ContextTcl* ctx, Tcl_Interp* interp, Tcl_Obj* const objv[]) { SqlQueryPtr execResults = dbCommonEval(ctx, interp, objv); @@ -653,4 +675,5 @@ void ScriptingTcl::ContextTcl::reset() void ScriptingTcl::ContextTcl::init() { Tcl_CreateObjCommand(interp, "db", ScriptingTcl::dbCommand, reinterpret_cast(this), nullptr); + Tcl_CreateObjCommand(interp, "tcl_init", ScriptingTcl::initTclCommand, reinterpret_cast(this), nullptr); } -- cgit v1.2.3