Ok, here is a simple example. This code compiles and works for Tcl8.5 and VS2008. To start, I created a WIN32 dll project called BasicTclExtn that exported characters.
// BasicTclExtn.h #ifdef BASICTCLEXTN_EXPORTS #define BASICTCLEXTN_API __declspec(dllexport) #else #define BASICTCLEXTN_API __declspec(dllimport) #endif int BasicExtnCmd(ClientData data, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) ; extern "C" { BASICTCLEXTN_API int Basictclextn_Init(Tcl_Interp *interp) ; }
And then the .cpp file
// BasicTclExtn.cpp : Defines the exported functions for the DLL application.
You need # to include tcl.h in stdafx.h.
This example uses the Tcl stubs tool; for more information, see the Tcl_InitStubs function documentation; when using stubs, you only need to reference tclstub85.lib. To install the code correctly, you need to do the following:
- Add include directory where tcl.h is installed in Configuration Properties -> C / C ++ -> General -> Additional Include Directories
- Define the symbol
USE_TCL_STUBS , I usually do this in Properties-> C / C ++ โ Preprocessor โ Preprocessor Definitions. You may also find that then you need to define <DLLNAME>_EXPORTS ( BASICTCLEXTN_EXPORTS in my example) after that, I'm not sure why this is happening. - Add the path to the directory where the tclstub85.lib file is an additional library directory under Configuration Properties โ Linker โ General โ Additional Library Directories.
- Add tclstub85.lib to configuration properties -> Linker -> Input -> Additional Dependancies
- If the compiler throws a warning about MSVCRT, then exclude MSVCRT by adding it to ignored libraries in Configuration Properties โ Linker โ Input โ Ignore Specific Library.
All of these .lib, .dll, and .h files should be easily found in your Tcl installation. You also need to make sure that the related tclstub85.dll and tcl85.dll can be found at runtime, making sure the bin directory for Tcl is in PATH should sort it. Thus, you should be able to do the following from Tcl:
C:\Projects\BasicTclExtn\Debug>tclsh % load BasicTclExtn.dll % BasicExtnCmd 1 2 3 % BasicExtnCmd 1 2.p expected integer but got "2.p" % BasicExtnCmd 1 2 3 % BasicExtnCmd 1 wrong
This is the simplest form of Tcl exstention, you can add additional calls to Tcl_CreateObjCommand() to add more commnds to this extension. Tcl provides some features that help you process the command line options passed to the command. The sample code uses Tcl_WrongNumArgs() , but you should also look at the functions Tcl_GetIndexFromObj() .
I also suggest you get a copy of Practical Programming in Tcl and Tk from Brent Welch. You can read a few examples here http://www.beedub.com/book/ , the chapter on C programming for Tcl from the 3rd edition will help you a lot.