/usr/include/paraview/vtkShader2.h is in paraview-dev 5.0.1+dfsg1-4.
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 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkShader2.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.
=========================================================================*/
// .NAME vtkShader2 - GLSL Shader
// .SECTION Description
// A vtkShader2 object is made of a source code encoded into a string and
// a type, identifying the hardware programmable stage it is attached to.
// Hardware programmable stages are (or will be)
// 1. vertex shader
// 2. tessellation control shader
// 3. tessellation evaluation shader
// 4. geometry shader
// 5. fragment shader
//
// Note: tessellation control shader is called hull shader in DirectX11
// Note: tessellation evaluation shader is called domain shader in DirectX11
// Ref: OpenGL spec 4.0
// http://www.opengl.org/registry/doc/glspec40.core.20100311.withchanges.pdf
// Ref: "Introducing DirectX 11"
// http://www.gamasutra.com/view/feature/3759/sponsored_feature_introducing_.php
// .SECTION See Also
// vtkShaderProgram2
#ifndef vtkShader2_h
#define vtkShader2_h
#include "vtkWeakPointer.h" // for ren context
#include "vtkRenderingOpenGLModule.h" // For export macro
#include "vtkObject.h"
// Values for GetType()/SetType()
enum vtkShader2Type
{
VTK_SHADER_TYPE_VERTEX = 0,
VTK_SHADER_TYPE_TESSELLATION_CONTROL = 3, // new, not supported yet
VTK_SHADER_TYPE_TESSELLATION_EVALUATION = 4, // new, not supported yet
VTK_SHADER_TYPE_GEOMETRY = 1,
VTK_SHADER_TYPE_FRAGMENT = 2
};
class vtkRenderWindow;
class vtkUniformVariables;
class VTKRENDERINGOPENGL_EXPORT vtkShader2 : public vtkObject
{
public:
static vtkShader2 *New();
vtkTypeMacro(vtkShader2,vtkObject);
void PrintSelf(ostream &os, vtkIndent indent);
// Description:
// Returns if the context supports the required extensions.
// Extensions are load when the context is set.
static bool IsSupported(vtkRenderWindow *context);
// Description:
// String containing the shader source code. Reminder SetString makes a copy
// of its argument.
vtkGetStringMacro(SourceCode);
vtkSetStringMacro(SourceCode);
// Description:
// Return the shader type, .
// \post valid_result: result==VTK_SHADER_TYPE_VERTEX ||
// result==VTK_SHADER_TYPE_TESSELLATION_CONTROL ||
// result==VTK_SHADER_TYPE_TESSELLATION_EVALUATION ||
// result==VTK_SHADER_TYPE_GEOMETRY ||
// result==VTK_SHADER_TYPE_FRAGMENT.
vtkGetMacro(Type,int);
// Description:
// Set the shader type, .
// \pre valid_type: type==VTK_SHADER_TYPE_VERTEX ||
// type==VTK_SHADER_TYPE_TESSELLATION_CONTROL ||
// type==VTK_SHADER_TYPE_TESSELLATION_EVALUATION ||
// type==VTK_SHADER_TYPE_GEOMETRY ||
// type==VTK_SHADER_TYPE_FRAGMENT.
// \post is_set: GetType()==type.
vtkSetMacro(Type,int);
// Description:
// Return the shader type as a string.
const char *GetTypeAsString();
// Description:
// Compile the shader code.
// The result of compilation can be query with GetLastCompileStatus()
// The log of compilation can be query with GetLastCompileLog()
// \pre SourceCode_exists: this->GetSourceCode()!=0
void Compile();
// Description:
// Tells if the last call to compile succeeded (true) or not (false).
// Initial value is false.
bool GetLastCompileStatus();
// Description:
// Return the log of the last call to compile as a string.
// Initial value is the empty string ""='\0'.
// \post result_exists: result!=0
const char *GetLastCompileLog();
// Description:
// Get/Set the context. This does not increase the reference count of the
// context to avoid reference loops.
// SetContext() may raise an error is the OpenGL context does not support the
// required OpenGL extensions.
void SetContext(vtkRenderWindow *context);
vtkRenderWindow *GetContext();
// Description:
// Release OpenGL resource (shader id).
virtual void ReleaseGraphicsResources();
// Description:
// Return the OpenGL shader object id.
vtkGetMacro(Id,unsigned int);
// Description:
// Get/Set the list of uniform variables values.
// Initial value is an empty list (not null pointer).
vtkGetObjectMacro(UniformVariables,vtkUniformVariables);
virtual void SetUniformVariables(vtkUniformVariables *variables);
protected:
// Description:
// Default constructor. SourceCode is NULL. Type is vertex.
vtkShader2();
// Description:
// Destructor. Delete SourceCode and LastCompileLog if any.
virtual ~vtkShader2();
// Description:
// Load the required OpenGL extensions.
bool LoadRequiredExtensions(vtkRenderWindow *context);
char *SourceCode;
int Type;
unsigned int Id; // actually GLuint. Initial value is 0.
bool LastCompileStatus; // Initial value is false.
char *LastCompileLog; // Initial value is the empty string ""='\0'.
size_t LastCompileLogCapacity; // Initial value is 8.
vtkTimeStamp LastCompileTime;
vtkUniformVariables *UniformVariables; // Initial values is an empty list
vtkWeakPointer<vtkRenderWindow> Context;
bool ExtensionsLoaded;
bool SupportGeometryShader;
private:
vtkShader2(const vtkShader2&); // Not implemented.
void operator=(const vtkShader2&); // Not implemented.
};
#endif
|