/usr/include/vtk-7.1/vtkBoostSplitTableField.h is in libvtk7-dev 7.1.1+dfsg1-2.
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 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkBoostSplitTableField.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkBoostSplitTableField
* @brief "Splits" one-or-more table fields by duplicating rows containing delimited data.
*
*
* Assume the following table:
*
* Author Year Title
* Brian; Jeff; Tim 2007 Foo
* Tim 2003 Bar
*
* If we produce a graph relating authors to the year in which they publish, the string
* "Brian; Jeff; Tim" will be treated (incorrectly) as a single author associated with
* the year 2007. vtkBoostSplitTableField addresses this by splitting one-or-more fields into
* "subvalues" using a configurable delimiter and placing each subvalue on its own row
* (the other fields in the original row are copied). Using the above example, splitting
* the "Author" field with a ";" (semicolon) delimiter produces:
*
* Author Year Title
* Brian 2007 Foo
* Jeff 2007 Foo
* Tim 2007 Foo
* Tim 2003 Bar
*
* When this table is converted to a graph, each author (correctly) becomes a separate node.
*
* Usage:
*
* Use AddField() to specify the field(s) to be split. If no fields have been specified,
* vtkBoostSplitTableField will act as a passthrough. By default, no fields are specified.
*
* The second argument to AddField() is a string containing zero-to-many single character
* delimiters (multi-character delimiters are not supported).
*
* If the input table is missing a field specified by AddField(), it is an error.
* If no fields are specified, no splitting is performed.
* If the delimiter for a field is an empty string, no splitting is performed on that field.
*/
#ifndef vtkBoostSplitTableField_h
#define vtkBoostSplitTableField_h
#include "vtkInfovisBoostGraphAlgorithmsModule.h" // For export macro
#include "vtkTableAlgorithm.h"
class vtkStringArray;
class VTKINFOVISBOOSTGRAPHALGORITHMS_EXPORT vtkBoostSplitTableField : public vtkTableAlgorithm
{
public:
static vtkBoostSplitTableField* New();
vtkTypeMacro(vtkBoostSplitTableField, vtkTableAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
void ClearFields();
void AddField(const char* field, const char* delimiters);
protected:
vtkBoostSplitTableField();
~vtkBoostSplitTableField();
int RequestData(
vtkInformation*,
vtkInformationVector**,
vtkInformationVector*);
vtkStringArray* Fields;
vtkStringArray* Delimiters;
private:
class implementation;
vtkBoostSplitTableField(const vtkBoostSplitTableField&) VTK_DELETE_FUNCTION;
void operator=(const vtkBoostSplitTableField&) VTK_DELETE_FUNCTION;
};
#endif
|