This file is indexed.

/usr/share/vtk/Build/vtkMy/README is in vtk-examples 5.8.0-14.1ubuntu3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
74
75
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.