/* this file has been autogenerated by vtkNodeJsWrap */
/* editing this might proof futile */

#ifndef NATIVE_EXTENSION_VTK_VTKSUPERQUADRICSOURCEWRAP_H
#define NATIVE_EXTENSION_VTK_VTKSUPERQUADRICSOURCEWRAP_H

#include <nan.h>

#include <vtkSmartPointer.h>
#include <vtkSuperquadricSource.h>

#include "vtkPolyDataAlgorithmWrap.h"
#include "../../plus/plus.h"

class VtkSuperquadricSourceWrap : public VtkPolyDataAlgorithmWrap
{
	public:
		using Nan::ObjectWrap::Wrap;
		static void Init(v8::Local<v8::Object> exports);
		static void InitPtpl();
		static void ConstructorGetter(
			v8::Local<v8::String> property,
			const Nan::PropertyCallbackInfo<v8::Value>& info);

		VtkSuperquadricSourceWrap(vtkSmartPointer<vtkSuperquadricSource>);
		VtkSuperquadricSourceWrap();
		~VtkSuperquadricSourceWrap( );
		static Nan::Persistent<v8::FunctionTemplate> ptpl;

	private:
		static void New(const Nan::FunctionCallbackInfo<v8::Value>& info);

		static void GetAxisOfSymmetry(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetCenter(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetClassName(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetOutputPointsPrecision(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetPhiResolution(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetPhiRoundness(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetScale(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetSize(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetThetaResolution(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetThetaRoundness(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetThickness(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetThicknessMaxValue(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetThicknessMinValue(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void GetToroidal(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void IsA(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void NewInstance(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SafeDownCast(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetAxisOfSymmetry(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetCenter(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetOutputPointsPrecision(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetPhiResolution(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetPhiRoundness(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetScale(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetSize(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetThetaResolution(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetThetaRoundness(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetThickness(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetToroidal(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetXAxisOfSymmetry(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetYAxisOfSymmetry(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void SetZAxisOfSymmetry(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void ToroidalOff(const Nan::FunctionCallbackInfo<v8::Value>& info);
		static void ToroidalOn(const Nan::FunctionCallbackInfo<v8::Value>& info);

#ifdef VTK_NODE_PLUS_VTKSUPERQUADRICSOURCEWRAP_CLASSDEF
		VTK_NODE_PLUS_VTKSUPERQUADRICSOURCEWRAP_CLASSDEF
#endif
};

#endif
