Cloned library of VTK-5.0.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

3.3 KiB

Introduction:
-------------

This directory demonstrates how to organize a local source repository
where local VTK classes can be compiled and wrapped into
C++/Tcl/Java/Python libraries without interferring with the main VTK
source dir.

It might be good thing to sort local classes into different 'package'
directories like VTK does (Common, Rendering, Filtering, Imaging, IO,
etc.). It prevents numerous dependencies problems and provides a
better overview of the class hierarchy.

- this example enforces this 'package' organization by referring to a
vtkBar class into the Common/ directory and a vtkImageFoo class into
the Imaging/ directory (the later uses an instance of vtkBar to
"work", thus demonstrating how CMake resolves dependencies between
both directories).

Nevertheless, if you do not care about this ordering, you might just
put your classes into the Unsorted/ directory, like the vtkBar2 class
for example. By default, members of the Unsorted package will depend
on all other packages and will be linked against all VTK packages too.

What you should do:
-------------------

- Copy this vtkMy directory to a different out-of-source place, and
remove all CVS subdirs to avoid any accidental commit to the main VTK
CVS.

- Fill the subdirs with your own classes. Remove the dummy classes if
needed. For each CMakeList.txt in the package dirs, add or remove the
class(es) pertaining to this directory (SET command). Depending on
the directory, your class must #include "vtkmy*Win32Header.h"
(see dummy classes for example) and use the corresponding VTK_MY_*_EXPORT
macro after the 'class' keyword to ensure proper DLL build.

- Run CMake as usual. Use your vtkMy local dir as source dir, and
choose whatever build directory. Your VTK build- or install- directory
should be found automatically.

- Build your project.

- Add the path to your build-dir bin/ directory to your PATH
environment variable (as well as LD_LIBRARY_PATH for Unix users), so
these C++ and Tcl DLL can be found (if any).

- Add the path to your vtkMy/Wrapping/Tcl directory to your TCLLIBPATH
environment variable. TCLLIBPATH is a space separated set of paths to
Tcl libraries. Windows users should use forward slashes (/) instead of
the usual backward slashes (\), and should surround the path by quotes
(") if it contains any space.

Distribute or exchange your modules:
------------------------------------

Ideally, if you plan to exchange or distribute your modules then you
should rename the vtkmy lib prefix to something more personal or
unique. You might use your initials for example. In a nutshell, if you
were to choose vtksb, then you should take care of the following:

- Search for the vtkmy string and replace it with vtksb in all files.
- In the same way, replace VTKMY by VTKSB.
- Rename all vtkmy* files *and* directories to vtksb* (this should
only concern files like vtkmy*Win32Header.h for example).
- In all *Win32Header.h files and VTK headers, change
VTK_MY_*_EXPORT to VTK_SB_*_EXPORT. Sorry for the inconvenience, but
the wrappers expect this symbol to start with VTK_, thus
VTKMY_*_EXPORT could not be used.

Any prefix should work, but make sure that your class names start with
'vtk', otherwise the wrappers will fail (hence the vtksb or vtkmy
prefix, not sbvtk or myvtk). A safe bet is to use something starting
'vtk' in a consistent way.