1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
/*
* itkStubLib.c --
*
* Stub object that will be statically linked into extensions that wish
* to access Itk.
*
* Copyright (c) 1998-1999 by XXXX
* Copyright (c) 1998 Paul Duffin.
*
* See the file "license.terms" for information on usage and redistribution
* of this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
* RCS: $Id: itkStubLib.c,v 1.7 2003/12/24 03:38:03 davygrvy Exp $
*/
/*
* We need to ensure that we use the stub macros so that this file contains
* no references to any of the stub functions. This will make it possible
* to build an extension that references Tcl_InitStubs but doesn't end up
* including the rest of the stub functions.
*/
#ifndef USE_TCL_STUBS
#define USE_TCL_STUBS
#endif
#undef USE_TCL_STUB_PROCS
#ifndef USE_ITK_STUBS
#define USE_ITK_STUBS
#endif
#undef USE_ITK_STUB_PROCS
#include "itk.h"
ItkStubs *itkStubsPtr;
/*
*----------------------------------------------------------------------
*
* Itk_InitStubs --
*
* Tries to initialise the stub table pointers and ensures that
* the correct version of Itk is loaded.
*
* Results:
* The actual version of Itk that satisfies the request, or
* NULL to indicate that an error occurred.
*
* Side effects:
* Sets the stub table pointers.
*
*----------------------------------------------------------------------
*/
CONST char *
Itk_InitStubs (interp, version, exact)
Tcl_Interp *interp;
CONST char *version;
int exact;
{
CONST char *actualVersion;
actualVersion = Tcl_PkgRequireEx(interp, "Itk", (CONST84 char *)version, exact,
(ClientData *) &itkStubsPtr);
if (actualVersion == NULL) {
itkStubsPtr = NULL;
return NULL;
}
return actualVersion;
}
|