mirror of
https://github.com/tesseract-ocr/tesseract.git
synced 2024-12-27 10:34:12 +08:00
aba037329a
Signed-off-by: Stefan Weil <sw@weilnetz.de>
4671 lines
150 KiB
C++
4671 lines
150 KiB
C++
///////////////////////////////////////////////////////////////////////
|
|
// File: tesscallback.h
|
|
// Description: classes and functions to replace pointer-to-functions
|
|
// Author: Samuel Charron
|
|
//
|
|
// (C) Copyright 2006, Google Inc.
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
///////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef TESS_CALLBACK_SPECIALIZATIONS_H_
|
|
#define TESS_CALLBACK_SPECIALIZATIONS_H_
|
|
|
|
struct TessCallbackUtils_ {
|
|
static void FailIsRepeatable(const char* name);
|
|
};
|
|
|
|
class TessClosure {
|
|
public:
|
|
virtual ~TessClosure();
|
|
virtual void Run() = 0;
|
|
};
|
|
|
|
template <class R>
|
|
class TessResultCallback {
|
|
public:
|
|
virtual ~TessResultCallback() = default;
|
|
virtual R Run() = 0;
|
|
};
|
|
|
|
template <bool del, class R, class T>
|
|
class _ConstTessMemberResultCallback_0_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)() const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_0(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)();
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)();
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T>
|
|
class _ConstTessMemberResultCallback_0_0<del, void, T> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)() const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_0(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)();
|
|
} else {
|
|
(object_->*member_)();
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R>
|
|
inline typename _ConstTessMemberResultCallback_0_0<true, R, T1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)() const) {
|
|
return new _ConstTessMemberResultCallback_0_0<true, R, T1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R>
|
|
inline typename _ConstTessMemberResultCallback_0_0<false, R, T1>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)() const) {
|
|
return new _ConstTessMemberResultCallback_0_0<false, R, T1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T>
|
|
class _TessMemberResultCallback_0_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)();
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_0(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
R Run() override {
|
|
if (!del) {
|
|
R result = (object_->*member_)();
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)();
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T>
|
|
class _TessMemberResultCallback_0_0<del, void, T> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)();
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_0(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)();
|
|
} else {
|
|
(object_->*member_)();
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R>
|
|
inline typename _TessMemberResultCallback_0_0<true, R, T1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)()) {
|
|
return new _TessMemberResultCallback_0_0<true, R, T1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R>
|
|
inline typename _TessMemberResultCallback_0_0<false, R, T1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)()) {
|
|
return new _TessMemberResultCallback_0_0<false, R, T1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R>
|
|
class _TessFunctionResultCallback_0_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)();
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
|
|
public:
|
|
inline explicit _TessFunctionResultCallback_0_0(FunctionSignature function)
|
|
: function_(function) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)();
|
|
return result;
|
|
}
|
|
R result = (*function_)();
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del>
|
|
class _TessFunctionResultCallback_0_0<del, void> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)();
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
|
|
public:
|
|
inline explicit _TessFunctionResultCallback_0_0(FunctionSignature function)
|
|
: function_(function) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)();
|
|
} else {
|
|
(*function_)();
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R>
|
|
inline typename _TessFunctionResultCallback_0_0<true, R>::base* NewTessCallback(
|
|
R (*function)()) {
|
|
return new _TessFunctionResultCallback_0_0<true, R>(function);
|
|
}
|
|
|
|
template <class R>
|
|
inline typename _TessFunctionResultCallback_0_0<false, R>::base*
|
|
NewPermanentTessCallback(R (*function)()) {
|
|
return new _TessFunctionResultCallback_0_0<false, R>(function);
|
|
}
|
|
|
|
// Specified by TR1 [4.7.2] Reference modifications.
|
|
template <class T>
|
|
struct remove_reference;
|
|
template <typename T>
|
|
struct remove_reference {
|
|
using type = T;
|
|
};
|
|
template <typename T>
|
|
struct remove_reference<T&> {
|
|
using type = T;
|
|
};
|
|
|
|
// Identity<T>::type is a typedef of T. Useful for preventing the
|
|
// compiler from inferring the type of an argument in templates.
|
|
template <typename T>
|
|
struct Identity {
|
|
using type = T;
|
|
};
|
|
|
|
template <bool del, class R, class T, class P1>
|
|
class _ConstTessMemberResultCallback_1_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_1_0(const T* object,
|
|
MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1>
|
|
class _ConstTessMemberResultCallback_1_0<del, void, T, P1>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_1_0(const T* object,
|
|
MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_);
|
|
} else {
|
|
(object_->*member_)(p1_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1>
|
|
inline typename _ConstTessMemberResultCallback_1_0<true, R, T1, P1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1) const,
|
|
typename Identity<P1>::type p1) {
|
|
return new _ConstTessMemberResultCallback_1_0<true, R, T1, P1>(obj, member,
|
|
p1);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1>
|
|
inline typename _ConstTessMemberResultCallback_1_0<false, R, T1, P1>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1) const,
|
|
typename Identity<P1>::type p1) {
|
|
return new _ConstTessMemberResultCallback_1_0<false, R, T1, P1>(obj, member,
|
|
p1);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1>
|
|
class _TessMemberResultCallback_1_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_1_0(T* object, MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1>
|
|
class _TessMemberResultCallback_1_0<del, void, T, P1> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_1_0(T* object, MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_);
|
|
} else {
|
|
(object_->*member_)(p1_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1>
|
|
inline typename _TessMemberResultCallback_1_0<true, R, T1, P1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1), typename Identity<P1>::type p1) {
|
|
return new _TessMemberResultCallback_1_0<true, R, T1, P1>(obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1>
|
|
inline typename _TessMemberResultCallback_1_0<false, R, T1, P1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessMemberResultCallback_1_0<false, R, T1, P1>(obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1>
|
|
class _TessFunctionResultCallback_1_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)(P1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_1_0(FunctionSignature function, P1 p1)
|
|
: function_(function), p1_(p1) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)(p1_);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1>
|
|
class _TessFunctionResultCallback_1_0<del, void, P1> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)(P1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_1_0(FunctionSignature function, P1 p1)
|
|
: function_(function), p1_(p1) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)(p1_);
|
|
} else {
|
|
(*function_)(p1_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1>
|
|
inline typename _TessFunctionResultCallback_1_0<true, R, P1>::base*
|
|
NewTessCallback(R (*function)(P1), typename Identity<P1>::type p1) {
|
|
return new _TessFunctionResultCallback_1_0<true, R, P1>(function, p1);
|
|
}
|
|
|
|
template <class R, class P1>
|
|
inline typename _TessFunctionResultCallback_1_0<false, R, P1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1), typename Identity<P1>::type p1) {
|
|
return new _TessFunctionResultCallback_1_0<false, R, P1>(function, p1);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2>
|
|
class _ConstTessMemberResultCallback_2_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_2_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2>
|
|
class _ConstTessMemberResultCallback_2_0<del, void, T, P1, P2>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_2_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2>
|
|
inline typename _ConstTessMemberResultCallback_2_0<true, R, T1, P1, P2>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _ConstTessMemberResultCallback_2_0<true, R, T1, P1, P2>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2>
|
|
inline typename _ConstTessMemberResultCallback_2_0<false, R, T1, P1, P2>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, P2) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _ConstTessMemberResultCallback_2_0<false, R, T1, P1, P2>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2>
|
|
class _TessMemberResultCallback_2_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_2_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2>
|
|
class _TessMemberResultCallback_2_0<del, void, T, P1, P2> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_2_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2>
|
|
inline typename _TessMemberResultCallback_2_0<true, R, T1, P1, P2>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessMemberResultCallback_2_0<true, R, T1, P1, P2>(obj, member, p1,
|
|
p2);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2>
|
|
inline typename _TessMemberResultCallback_2_0<false, R, T1, P1, P2>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessMemberResultCallback_2_0<false, R, T1, P1, P2>(obj, member,
|
|
p1, p2);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2>
|
|
class _TessFunctionResultCallback_2_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)(P1, P2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_2_0(FunctionSignature function, P1 p1,
|
|
P2 p2)
|
|
: function_(function), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2>
|
|
class _TessFunctionResultCallback_2_0<del, void, P1, P2> : public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)(P1, P2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_2_0(FunctionSignature function, P1 p1,
|
|
P2 p2)
|
|
: function_(function), p1_(p1), p2_(p2) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_);
|
|
} else {
|
|
(*function_)(p1_, p2_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2>
|
|
inline typename _TessFunctionResultCallback_2_0<true, R, P1, P2>::base*
|
|
NewTessCallback(R (*function)(P1, P2), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessFunctionResultCallback_2_0<true, R, P1, P2>(function, p1, p2);
|
|
}
|
|
|
|
template <class R, class P1, class P2>
|
|
inline typename _TessFunctionResultCallback_2_0<false, R, P1, P2>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessFunctionResultCallback_2_0<false, R, P1, P2>(function, p1,
|
|
p2);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3>
|
|
class _ConstTessMemberResultCallback_3_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_3_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3>
|
|
class _ConstTessMemberResultCallback_3_0<del, void, T, P1, P2, P3>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_3_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_3_0<true, R, T1, P1, P2, P3>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _ConstTessMemberResultCallback_3_0<true, R, T1, P1, P2, P3>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_3_0<false, R, T1, P1, P2, P3>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _ConstTessMemberResultCallback_3_0<false, R, T1, P1, P2, P3>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3>
|
|
class _TessMemberResultCallback_3_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_3_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3>
|
|
class _TessMemberResultCallback_3_0<del, void, T, P1, P2, P3>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_3_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3>
|
|
inline typename _TessMemberResultCallback_3_0<true, R, T1, P1, P2, P3>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessMemberResultCallback_3_0<true, R, T1, P1, P2, P3>(obj, member,
|
|
p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3>
|
|
inline typename _TessMemberResultCallback_3_0<false, R, T1, P1, P2, P3>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessMemberResultCallback_3_0<false, R, T1, P1, P2, P3>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3>
|
|
class _TessFunctionResultCallback_3_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)(P1, P2, P3);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_3_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3>
|
|
class _TessFunctionResultCallback_3_0<del, void, P1, P2, P3>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)(P1, P2, P3);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_3_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3>
|
|
inline typename _TessFunctionResultCallback_3_0<true, R, P1, P2, P3>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessFunctionResultCallback_3_0<true, R, P1, P2, P3>(function, p1,
|
|
p2, p3);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3>
|
|
inline typename _TessFunctionResultCallback_3_0<false, R, P1, P2, P3>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessFunctionResultCallback_3_0<false, R, P1, P2, P3>(function, p1,
|
|
p2, p3);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4>
|
|
class _ConstTessMemberResultCallback_4_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_4_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4>
|
|
class _ConstTessMemberResultCallback_4_0<del, void, T, P1, P2, P3, P4>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_4_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4>
|
|
inline typename _ConstTessMemberResultCallback_4_0<true, R, T1, P1, P2, P3,
|
|
P4>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, P4) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _ConstTessMemberResultCallback_4_0<true, R, T1, P1, P2, P3, P4>(
|
|
obj, member, p1, p2, p3, p4);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4>
|
|
inline typename _ConstTessMemberResultCallback_4_0<false, R, T1, P1, P2, P3,
|
|
P4>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, P4) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _ConstTessMemberResultCallback_4_0<false, R, T1, P1, P2, P3, P4>(
|
|
obj, member, p1, p2, p3, p4);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4>
|
|
class _TessMemberResultCallback_4_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_4_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4>
|
|
class _TessMemberResultCallback_4_0<del, void, T, P1, P2, P3, P4>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_4_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4>
|
|
inline
|
|
typename _TessMemberResultCallback_4_0<true, R, T1, P1, P2, P3, P4>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessMemberResultCallback_4_0<true, R, T1, P1, P2, P3, P4>(
|
|
obj, member, p1, p2, p3, p4);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4>
|
|
inline
|
|
typename _TessMemberResultCallback_4_0<false, R, T1, P1, P2, P3, P4>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessMemberResultCallback_4_0<false, R, T1, P1, P2, P3, P4>(
|
|
obj, member, p1, p2, p3, p4);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class P4>
|
|
class _TessFunctionResultCallback_4_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)(P1, P2, P3, P4);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_4_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, p4_);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, p4_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class P4>
|
|
class _TessFunctionResultCallback_4_0<del, void, P1, P2, P3, P4>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)(P1, P2, P3, P4);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_4_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, p4_);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, p4_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class P4>
|
|
inline typename _TessFunctionResultCallback_4_0<true, R, P1, P2, P3, P4>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, P4), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2, typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessFunctionResultCallback_4_0<true, R, P1, P2, P3, P4>(
|
|
function, p1, p2, p3, p4);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class P4>
|
|
inline typename _TessFunctionResultCallback_4_0<false, R, P1, P2, P3, P4>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, P4),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessFunctionResultCallback_4_0<false, R, P1, P2, P3, P4>(
|
|
function, p1, p2, p3, p4);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5>
|
|
class _ConstTessMemberResultCallback_5_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_5_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
R Run() override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5>
|
|
class _ConstTessMemberResultCallback_5_0<del, void, T, P1, P2, P3, P4, P5>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_5_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5>
|
|
inline typename _ConstTessMemberResultCallback_5_0<true, R, T1, P1, P2, P3, P4,
|
|
P5>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, P4, P5) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _ConstTessMemberResultCallback_5_0<true, R, T1, P1, P2, P3, P4,
|
|
P5>(obj, member, p1, p2, p3, p4,
|
|
p5);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5>
|
|
inline typename _ConstTessMemberResultCallback_5_0<false, R, T1, P1, P2, P3, P4,
|
|
P5>::base*
|
|
NewPermanentTessCallback(const T1* obj,
|
|
R (T2::*member)(P1, P2, P3, P4, P5) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _ConstTessMemberResultCallback_5_0<false, R, T1, P1, P2, P3, P4,
|
|
P5>(obj, member, p1, p2, p3, p4,
|
|
p5);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5>
|
|
class _TessMemberResultCallback_5_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_5_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5>
|
|
class _TessMemberResultCallback_5_0<del, void, T, P1, P2, P3, P4, P5>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_5_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5>
|
|
inline typename _TessMemberResultCallback_5_0<true, R, T1, P1, P2, P3, P4,
|
|
P5>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessMemberResultCallback_5_0<true, R, T1, P1, P2, P3, P4, P5>(
|
|
obj, member, p1, p2, p3, p4, p5);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5>
|
|
inline typename _TessMemberResultCallback_5_0<false, R, T1, P1, P2, P3, P4,
|
|
P5>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessMemberResultCallback_5_0<false, R, T1, P1, P2, P3, P4, P5>(
|
|
obj, member, p1, p2, p3, p4, p5);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class P4, class P5>
|
|
class _TessFunctionResultCallback_5_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)(P1, P2, P3, P4, P5);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_5_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4), p5_(p5) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class P4, class P5>
|
|
class _TessFunctionResultCallback_5_0<del, void, P1, P2, P3, P4, P5>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)(P1, P2, P3, P4, P5);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_5_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4), p5_(p5) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5>
|
|
inline
|
|
typename _TessFunctionResultCallback_5_0<true, R, P1, P2, P3, P4, P5>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, P4, P5),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessFunctionResultCallback_5_0<true, R, P1, P2, P3, P4, P5>(
|
|
function, p1, p2, p3, p4, p5);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5>
|
|
inline typename _TessFunctionResultCallback_5_0<false, R, P1, P2, P3, P4,
|
|
P5>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, P4, P5),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessFunctionResultCallback_5_0<false, R, P1, P2, P3, P4, P5>(
|
|
function, p1, p2, p3, p4, p5);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5, class P6>
|
|
class _ConstTessMemberResultCallback_6_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5, P6) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_6_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
R Run() override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5,
|
|
class P6>
|
|
class _ConstTessMemberResultCallback_6_0<del, void, T, P1, P2, P3, P4, P5, P6>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5, P6) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_6_0(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6>
|
|
inline typename _ConstTessMemberResultCallback_6_0<true, R, T1, P1, P2, P3, P4,
|
|
P5, P6>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _ConstTessMemberResultCallback_6_0<true, R, T1, P1, P2, P3, P4, P5,
|
|
P6>(obj, member, p1, p2, p3, p4,
|
|
p5, p6);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6>
|
|
inline typename _ConstTessMemberResultCallback_6_0<false, R, T1, P1, P2, P3, P4,
|
|
P5, P6>::base*
|
|
NewPermanentTessCallback(
|
|
const T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5, typename Identity<P6>::type p6) {
|
|
return new _ConstTessMemberResultCallback_6_0<false, R, T1, P1, P2, P3, P4,
|
|
P5, P6>(obj, member, p1, p2, p3,
|
|
p4, p5, p6);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5, class P6>
|
|
class _TessMemberResultCallback_6_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5, P6);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_6_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5,
|
|
class P6>
|
|
class _TessMemberResultCallback_6_0<del, void, T, P1, P2, P3, P4, P5, P6>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5, P6);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_6_0(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6>
|
|
inline typename _TessMemberResultCallback_6_0<true, R, T1, P1, P2, P3, P4, P5,
|
|
P6>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessMemberResultCallback_6_0<true, R, T1, P1, P2, P3, P4, P5, P6>(
|
|
obj, member, p1, p2, p3, p4, p5, p6);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6>
|
|
inline typename _TessMemberResultCallback_6_0<false, R, T1, P1, P2, P3, P4, P5,
|
|
P6>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessMemberResultCallback_6_0<false, R, T1, P1, P2, P3, P4, P5,
|
|
P6>(obj, member, p1, p2, p3, p4, p5,
|
|
p6);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class P4, class P5,
|
|
class P6>
|
|
class _TessFunctionResultCallback_6_0 : public TessResultCallback<R> {
|
|
public:
|
|
using base = TessResultCallback<R>;
|
|
using FunctionSignature = R (*)(P1, P2, P3, P4, P5, P6);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_6_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: function_(function),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual R Run() {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class P4, class P5, class P6>
|
|
class _TessFunctionResultCallback_6_0<del, void, P1, P2, P3, P4, P5, P6>
|
|
: public TessClosure {
|
|
public:
|
|
using base = TessClosure;
|
|
using FunctionSignature = void (*)(P1, P2, P3, P4, P5, P6);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_6_0(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: function_(function),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
void Run() override {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_, p6_);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5, class P6>
|
|
inline typename _TessFunctionResultCallback_6_0<true, R, P1, P2, P3, P4, P5,
|
|
P6>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, P4, P5, P6),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessFunctionResultCallback_6_0<true, R, P1, P2, P3, P4, P5, P6>(
|
|
function, p1, p2, p3, p4, p5, p6);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5, class P6>
|
|
inline typename _TessFunctionResultCallback_6_0<false, R, P1, P2, P3, P4, P5,
|
|
P6>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, P4, P5, P6),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessFunctionResultCallback_6_0<false, R, P1, P2, P3, P4, P5, P6>(
|
|
function, p1, p2, p3, p4, p5, p6);
|
|
}
|
|
|
|
template <class A1>
|
|
class TessCallback1 {
|
|
public:
|
|
virtual ~TessCallback1() = default;
|
|
virtual void Run(A1) = 0;
|
|
};
|
|
|
|
template <class R, class A1>
|
|
class TessResultCallback1 {
|
|
public:
|
|
virtual ~TessResultCallback1() = default;
|
|
virtual R Run(A1) = 0;
|
|
};
|
|
|
|
template <class A1, class A2>
|
|
class TessCallback2 {
|
|
public:
|
|
virtual ~TessCallback2() = default;
|
|
virtual void Run(A1, A2) = 0;
|
|
};
|
|
|
|
template <class R, class A1, class A2>
|
|
class TessResultCallback2 {
|
|
public:
|
|
virtual ~TessResultCallback2() = default;
|
|
virtual R Run(A1, A2) = 0;
|
|
};
|
|
|
|
template <class A1, class A2, class A3>
|
|
class TessCallback3 {
|
|
public:
|
|
virtual ~TessCallback3() = default;
|
|
virtual void Run(A1, A2, A3) = 0;
|
|
};
|
|
|
|
template <class R, class A1, class A2, class A3>
|
|
class TessResultCallback3 {
|
|
public:
|
|
virtual ~TessResultCallback3() = default;
|
|
virtual R Run(A1, A2, A3) = 0;
|
|
};
|
|
|
|
template <class A1, class A2, class A3, class A4>
|
|
class TessCallback4 {
|
|
public:
|
|
virtual ~TessCallback4() = default;
|
|
virtual void Run(A1, A2, A3, A4) = 0;
|
|
};
|
|
|
|
template <class R, class A1, class A2, class A3, class A4>
|
|
class TessResultCallback4 {
|
|
public:
|
|
virtual ~TessResultCallback4() = default;
|
|
virtual R Run(A1, A2, A3, A4) = 0;
|
|
};
|
|
|
|
template <bool del, class R, class T, class A1>
|
|
class _ConstTessMemberResultCallback_0_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_1(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class A1>
|
|
class _ConstTessMemberResultCallback_0_1<del, void, T, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_1(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(a1);
|
|
} else {
|
|
(object_->*member_)(a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1>
|
|
inline typename _ConstTessMemberResultCallback_0_1<true, R, T1, A1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(A1) const) {
|
|
return new _ConstTessMemberResultCallback_0_1<true, R, T1, A1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1>
|
|
inline typename _ConstTessMemberResultCallback_0_1<false, R, T1, A1>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(A1) const) {
|
|
return new _ConstTessMemberResultCallback_0_1<false, R, T1, A1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class A1>
|
|
class _TessMemberResultCallback_0_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_1(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
R Run(A1 a1) override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class A1>
|
|
class _TessMemberResultCallback_0_1<del, void, T, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_1(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
void Run(A1 a1) override {
|
|
if (!del) {
|
|
(object_->*member_)(a1);
|
|
} else {
|
|
(object_->*member_)(a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1>
|
|
inline typename _TessMemberResultCallback_0_1<true, R, T1, A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(A1)) {
|
|
return new _TessMemberResultCallback_0_1<true, R, T1, A1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1>
|
|
inline typename _TessMemberResultCallback_0_1<false, R, T1, A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(A1)) {
|
|
return new _TessMemberResultCallback_0_1<false, R, T1, A1>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class A1>
|
|
class _TessFunctionResultCallback_0_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
|
|
public:
|
|
inline explicit _TessFunctionResultCallback_0_1(FunctionSignature function)
|
|
: function_(function) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class A1>
|
|
class _TessFunctionResultCallback_0_1<del, void, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
|
|
public:
|
|
inline explicit _TessFunctionResultCallback_0_1(FunctionSignature function)
|
|
: function_(function) {}
|
|
|
|
void Run(A1 a1) override {
|
|
if (!del) {
|
|
(*function_)(a1);
|
|
} else {
|
|
(*function_)(a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class A1>
|
|
inline typename _TessFunctionResultCallback_0_1<true, R, A1>::base*
|
|
NewTessCallback(R (*function)(A1)) {
|
|
return new _TessFunctionResultCallback_0_1<true, R, A1>(function);
|
|
}
|
|
|
|
template <class R, class A1>
|
|
inline typename _TessFunctionResultCallback_0_1<false, R, A1>::base*
|
|
NewPermanentTessCallback(R (*function)(A1)) {
|
|
return new _TessFunctionResultCallback_0_1<false, R, A1>(function);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class A1>
|
|
class _ConstTessMemberResultCallback_1_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_1_1(const T* object,
|
|
MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class A1>
|
|
class _ConstTessMemberResultCallback_1_1<del, void, T, P1, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_1_1(const T* object,
|
|
MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1>
|
|
inline typename _ConstTessMemberResultCallback_1_1<true, R, T1, P1, A1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, A1) const,
|
|
typename Identity<P1>::type p1) {
|
|
return new _ConstTessMemberResultCallback_1_1<true, R, T1, P1, A1>(
|
|
obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1>
|
|
inline typename _ConstTessMemberResultCallback_1_1<false, R, T1, P1, A1>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, A1) const,
|
|
typename Identity<P1>::type p1) {
|
|
return new _ConstTessMemberResultCallback_1_1<false, R, T1, P1, A1>(
|
|
obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class A1>
|
|
class _TessMemberResultCallback_1_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_1_1(T* object, MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class A1>
|
|
class _TessMemberResultCallback_1_1<del, void, T, P1, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_1_1(T* object, MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1>
|
|
inline typename _TessMemberResultCallback_1_1<true, R, T1, P1, A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, A1),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessMemberResultCallback_1_1<true, R, T1, P1, A1>(obj, member,
|
|
p1);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1>
|
|
inline typename _TessMemberResultCallback_1_1<false, R, T1, P1, A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, A1),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessMemberResultCallback_1_1<false, R, T1, P1, A1>(obj, member,
|
|
p1);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class A1>
|
|
class _TessFunctionResultCallback_1_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(P1, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_1_1(FunctionSignature function, P1 p1)
|
|
: function_(function), p1_(p1) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class A1>
|
|
class _TessFunctionResultCallback_1_1<del, void, P1, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(P1, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_1_1(FunctionSignature function, P1 p1)
|
|
: function_(function), p1_(p1) {}
|
|
|
|
void Run(A1 a1) override {
|
|
if (!del) {
|
|
(*function_)(p1_, a1);
|
|
} else {
|
|
(*function_)(p1_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class A1>
|
|
inline typename _TessFunctionResultCallback_1_1<true, R, P1, A1>::base*
|
|
NewTessCallback(R (*function)(P1, A1), typename Identity<P1>::type p1) {
|
|
return new _TessFunctionResultCallback_1_1<true, R, P1, A1>(function, p1);
|
|
}
|
|
|
|
template <class R, class P1, class A1>
|
|
inline typename _TessFunctionResultCallback_1_1<false, R, P1, A1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, A1),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessFunctionResultCallback_1_1<false, R, P1, A1>(function, p1);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class A1>
|
|
class _ConstTessMemberResultCallback_2_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_2_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class A1>
|
|
class _ConstTessMemberResultCallback_2_1<del, void, T, P1, P2, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_2_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_2_1<true, R, T1, P1, P2, A1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, A1) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _ConstTessMemberResultCallback_2_1<true, R, T1, P1, P2, A1>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_2_1<false, R, T1, P1, P2, A1>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, P2, A1) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _ConstTessMemberResultCallback_2_1<false, R, T1, P1, P2, A1>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class A1>
|
|
class _TessMemberResultCallback_2_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_2_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class A1>
|
|
class _TessMemberResultCallback_2_1<del, void, T, P1, P2, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_2_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1>
|
|
inline typename _TessMemberResultCallback_2_1<true, R, T1, P1, P2, A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessMemberResultCallback_2_1<true, R, T1, P1, P2, A1>(obj, member,
|
|
p1, p2);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1>
|
|
inline typename _TessMemberResultCallback_2_1<false, R, T1, P1, P2, A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessMemberResultCallback_2_1<false, R, T1, P1, P2, A1>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class A1>
|
|
class _TessFunctionResultCallback_2_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(P1, P2, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_2_1(FunctionSignature function, P1 p1,
|
|
P2 p2)
|
|
: function_(function), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class A1>
|
|
class _TessFunctionResultCallback_2_1<del, void, P1, P2, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(P1, P2, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_2_1(FunctionSignature function, P1 p1,
|
|
P2 p2)
|
|
: function_(function), p1_(p1), p2_(p2) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, a1);
|
|
} else {
|
|
(*function_)(p1_, p2_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class A1>
|
|
inline typename _TessFunctionResultCallback_2_1<true, R, P1, P2, A1>::base*
|
|
NewTessCallback(R (*function)(P1, P2, A1), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessFunctionResultCallback_2_1<true, R, P1, P2, A1>(function, p1,
|
|
p2);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class A1>
|
|
inline typename _TessFunctionResultCallback_2_1<false, R, P1, P2, A1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessFunctionResultCallback_2_1<false, R, P1, P2, A1>(function, p1,
|
|
p2);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class A1>
|
|
class _ConstTessMemberResultCallback_3_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_3_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class A1>
|
|
class _ConstTessMemberResultCallback_3_1<del, void, T, P1, P2, P3, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_3_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class A1>
|
|
inline typename _ConstTessMemberResultCallback_3_1<true, R, T1, P1, P2, P3,
|
|
A1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, A1) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _ConstTessMemberResultCallback_3_1<true, R, T1, P1, P2, P3, A1>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class A1>
|
|
inline typename _ConstTessMemberResultCallback_3_1<false, R, T1, P1, P2, P3,
|
|
A1>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, A1) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _ConstTessMemberResultCallback_3_1<false, R, T1, P1, P2, P3, A1>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class A1>
|
|
class _TessMemberResultCallback_3_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_3_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class A1>
|
|
class _TessMemberResultCallback_3_1<del, void, T, P1, P2, P3, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_3_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class A1>
|
|
inline
|
|
typename _TessMemberResultCallback_3_1<true, R, T1, P1, P2, P3, A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessMemberResultCallback_3_1<true, R, T1, P1, P2, P3, A1>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class A1>
|
|
inline
|
|
typename _TessMemberResultCallback_3_1<false, R, T1, P1, P2, P3, A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessMemberResultCallback_3_1<false, R, T1, P1, P2, P3, A1>(
|
|
obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class A1>
|
|
class _TessFunctionResultCallback_3_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(P1, P2, P3, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_3_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class A1>
|
|
class _TessFunctionResultCallback_3_1<del, void, P1, P2, P3, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(P1, P2, P3, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_3_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, a1);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class A1>
|
|
inline typename _TessFunctionResultCallback_3_1<true, R, P1, P2, P3, A1>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, A1), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessFunctionResultCallback_3_1<true, R, P1, P2, P3, A1>(
|
|
function, p1, p2, p3);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class A1>
|
|
inline typename _TessFunctionResultCallback_3_1<false, R, P1, P2, P3, A1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _TessFunctionResultCallback_3_1<false, R, P1, P2, P3, A1>(
|
|
function, p1, p2, p3);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class A1>
|
|
class _ConstTessMemberResultCallback_4_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_4_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class A1>
|
|
class _ConstTessMemberResultCallback_4_1<del, void, T, P1, P2, P3, P4, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_4_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class A1>
|
|
inline typename _ConstTessMemberResultCallback_4_1<true, R, T1, P1, P2, P3, P4,
|
|
A1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, P4, A1) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _ConstTessMemberResultCallback_4_1<true, R, T1, P1, P2, P3, P4,
|
|
A1>(obj, member, p1, p2, p3,
|
|
p4);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class A1>
|
|
inline typename _ConstTessMemberResultCallback_4_1<false, R, T1, P1, P2, P3, P4,
|
|
A1>::base*
|
|
NewPermanentTessCallback(const T1* obj,
|
|
R (T2::*member)(P1, P2, P3, P4, A1) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _ConstTessMemberResultCallback_4_1<false, R, T1, P1, P2, P3, P4,
|
|
A1>(obj, member, p1, p2, p3,
|
|
p4);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class A1>
|
|
class _TessMemberResultCallback_4_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_4_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class A1>
|
|
class _TessMemberResultCallback_4_1<del, void, T, P1, P2, P3, P4, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_4_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class A1>
|
|
inline typename _TessMemberResultCallback_4_1<true, R, T1, P1, P2, P3, P4,
|
|
A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, A1),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessMemberResultCallback_4_1<true, R, T1, P1, P2, P3, P4, A1>(
|
|
obj, member, p1, p2, p3, p4);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class A1>
|
|
inline typename _TessMemberResultCallback_4_1<false, R, T1, P1, P2, P3, P4,
|
|
A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessMemberResultCallback_4_1<false, R, T1, P1, P2, P3, P4, A1>(
|
|
obj, member, p1, p2, p3, p4);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class P4, class A1>
|
|
class _TessFunctionResultCallback_4_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(P1, P2, P3, P4, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_4_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class P4, class A1>
|
|
class _TessFunctionResultCallback_4_1<del, void, P1, P2, P3, P4, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(P1, P2, P3, P4, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_4_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, p4_, a1);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, p4_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class A1>
|
|
inline
|
|
typename _TessFunctionResultCallback_4_1<true, R, P1, P2, P3, P4, A1>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, P4, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessFunctionResultCallback_4_1<true, R, P1, P2, P3, P4, A1>(
|
|
function, p1, p2, p3, p4);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class A1>
|
|
inline typename _TessFunctionResultCallback_4_1<false, R, P1, P2, P3, P4,
|
|
A1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, P4, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4) {
|
|
return new _TessFunctionResultCallback_4_1<false, R, P1, P2, P3, P4, A1>(
|
|
function, p1, p2, p3, p4);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5, class A1>
|
|
class _ConstTessMemberResultCallback_5_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_5_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5,
|
|
class A1>
|
|
class _ConstTessMemberResultCallback_5_1<del, void, T, P1, P2, P3, P4, P5, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_5_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class A1>
|
|
inline typename _ConstTessMemberResultCallback_5_1<true, R, T1, P1, P2, P3, P4,
|
|
P5, A1>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, A1) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _ConstTessMemberResultCallback_5_1<true, R, T1, P1, P2, P3, P4, P5,
|
|
A1>(obj, member, p1, p2, p3, p4,
|
|
p5);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class A1>
|
|
inline typename _ConstTessMemberResultCallback_5_1<false, R, T1, P1, P2, P3, P4,
|
|
P5, A1>::base*
|
|
NewPermanentTessCallback(const T1* obj,
|
|
R (T2::*member)(P1, P2, P3, P4, P5, A1) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _ConstTessMemberResultCallback_5_1<false, R, T1, P1, P2, P3, P4,
|
|
P5, A1>(obj, member, p1, p2, p3,
|
|
p4, p5);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5, class A1>
|
|
class _TessMemberResultCallback_5_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_5_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5,
|
|
class A1>
|
|
class _TessMemberResultCallback_5_1<del, void, T, P1, P2, P3, P4, P5, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_5_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class A1>
|
|
inline typename _TessMemberResultCallback_5_1<true, R, T1, P1, P2, P3, P4, P5,
|
|
A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, A1),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessMemberResultCallback_5_1<true, R, T1, P1, P2, P3, P4, P5, A1>(
|
|
obj, member, p1, p2, p3, p4, p5);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class A1>
|
|
inline typename _TessMemberResultCallback_5_1<false, R, T1, P1, P2, P3, P4, P5,
|
|
A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessMemberResultCallback_5_1<false, R, T1, P1, P2, P3, P4, P5,
|
|
A1>(obj, member, p1, p2, p3, p4, p5);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class P4, class P5,
|
|
class A1>
|
|
class _TessFunctionResultCallback_5_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(P1, P2, P3, P4, P5, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_5_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4), p5_(p5) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class P4, class P5, class A1>
|
|
class _TessFunctionResultCallback_5_1<del, void, P1, P2, P3, P4, P5, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(P1, P2, P3, P4, P5, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_5_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5)
|
|
: function_(function), p1_(p1), p2_(p2), p3_(p3), p4_(p4), p5_(p5) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5, class A1>
|
|
inline typename _TessFunctionResultCallback_5_1<true, R, P1, P2, P3, P4, P5,
|
|
A1>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, P4, P5, A1),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessFunctionResultCallback_5_1<true, R, P1, P2, P3, P4, P5, A1>(
|
|
function, p1, p2, p3, p4, p5);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5, class A1>
|
|
inline typename _TessFunctionResultCallback_5_1<false, R, P1, P2, P3, P4, P5,
|
|
A1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, P4, P5, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5) {
|
|
return new _TessFunctionResultCallback_5_1<false, R, P1, P2, P3, P4, P5, A1>(
|
|
function, p1, p2, p3, p4, p5);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5, class P6, class A1>
|
|
class _ConstTessMemberResultCallback_6_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5, P6, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_6_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5,
|
|
class P6, class A1>
|
|
class _ConstTessMemberResultCallback_6_1<del, void, T, P1, P2, P3, P4, P5, P6,
|
|
A1> : public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5, P6, A1) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_6_1(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6, class A1>
|
|
inline typename _ConstTessMemberResultCallback_6_1<true, R, T1, P1, P2, P3, P4,
|
|
P5, P6, A1>::base*
|
|
NewTessCallback(const T1* obj,
|
|
R (T2::*member)(P1, P2, P3, P4, P5, P6, A1) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _ConstTessMemberResultCallback_6_1<true, R, T1, P1, P2, P3, P4, P5,
|
|
P6, A1>(obj, member, p1, p2, p3,
|
|
p4, p5, p6);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6, class A1>
|
|
inline typename _ConstTessMemberResultCallback_6_1<false, R, T1, P1, P2, P3, P4,
|
|
P5, P6, A1>::base*
|
|
NewPermanentTessCallback(
|
|
const T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6, A1) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5, typename Identity<P6>::type p6) {
|
|
return new _ConstTessMemberResultCallback_6_1<false, R, T1, P1, P2, P3, P4,
|
|
P5, P6, A1>(obj, member, p1, p2,
|
|
p3, p4, p5, p6);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class P4,
|
|
class P5, class P6, class A1>
|
|
class _TessMemberResultCallback_6_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, P4, P5, P6, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_6_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class P4, class P5,
|
|
class P6, class A1>
|
|
class _TessMemberResultCallback_6_1<del, void, T, P1, P2, P3, P4, P5, P6, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, P4, P5, P6, A1);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_6_1(T* object, MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: object_(object),
|
|
member_(member),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6, class A1>
|
|
inline typename _TessMemberResultCallback_6_1<true, R, T1, P1, P2, P3, P4, P5,
|
|
P6, A1>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6, A1),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessMemberResultCallback_6_1<true, R, T1, P1, P2, P3, P4, P5, P6,
|
|
A1>(obj, member, p1, p2, p3, p4, p5,
|
|
p6);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class P4,
|
|
class P5, class P6, class A1>
|
|
inline typename _TessMemberResultCallback_6_1<false, R, T1, P1, P2, P3, P4, P5,
|
|
P6, A1>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, P3, P4, P5, P6, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessMemberResultCallback_6_1<false, R, T1, P1, P2, P3, P4, P5, P6,
|
|
A1>(obj, member, p1, p2, p3, p4, p5,
|
|
p6);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class P3, class P4, class P5,
|
|
class P6, class A1>
|
|
class _TessFunctionResultCallback_6_1 : public TessResultCallback1<R, A1> {
|
|
public:
|
|
typedef TessResultCallback1<R, A1> base;
|
|
using FunctionSignature = R (*)(P1, P2, P3, P4, P5, P6, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_6_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: function_(function),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual R Run(A1 a1) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class P3, class P4, class P5, class P6,
|
|
class A1>
|
|
class _TessFunctionResultCallback_6_1<del, void, P1, P2, P3, P4, P5, P6, A1>
|
|
: public TessCallback1<A1> {
|
|
public:
|
|
using base = TessCallback1<A1>;
|
|
using FunctionSignature = void (*)(P1, P2, P3, P4, P5, P6, A1);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
typename remove_reference<P4>::type p4_;
|
|
typename remove_reference<P5>::type p5_;
|
|
typename remove_reference<P6>::type p6_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_6_1(FunctionSignature function, P1 p1,
|
|
P2 p2, P3 p3, P4 p4, P5 p5, P6 p6)
|
|
: function_(function),
|
|
p1_(p1),
|
|
p2_(p2),
|
|
p3_(p3),
|
|
p4_(p4),
|
|
p5_(p5),
|
|
p6_(p6) {}
|
|
|
|
virtual void Run(A1 a1) {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
} else {
|
|
(*function_)(p1_, p2_, p3_, p4_, p5_, p6_, a1);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5, class P6,
|
|
class A1>
|
|
inline typename _TessFunctionResultCallback_6_1<true, R, P1, P2, P3, P4, P5, P6,
|
|
A1>::base*
|
|
NewTessCallback(R (*function)(P1, P2, P3, P4, P5, P6, A1),
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3, typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessFunctionResultCallback_6_1<true, R, P1, P2, P3, P4, P5, P6,
|
|
A1>(function, p1, p2, p3, p4, p5,
|
|
p6);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class P3, class P4, class P5, class P6,
|
|
class A1>
|
|
inline typename _TessFunctionResultCallback_6_1<false, R, P1, P2, P3, P4, P5,
|
|
P6, A1>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, P3, P4, P5, P6, A1),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3,
|
|
typename Identity<P4>::type p4,
|
|
typename Identity<P5>::type p5,
|
|
typename Identity<P6>::type p6) {
|
|
return new _TessFunctionResultCallback_6_1<false, R, P1, P2, P3, P4, P5, P6,
|
|
A1>(function, p1, p2, p3, p4, p5,
|
|
p6);
|
|
}
|
|
|
|
template <bool del, class R, class T, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_0_2
|
|
: public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_2(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
R Run(A1 a1, A2 a2) override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_0_2<del, void, T, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_2(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(a1, a2);
|
|
} else {
|
|
(object_->*member_)(a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2>
|
|
inline typename _ConstTessMemberResultCallback_0_2<true, R, T1, A1, A2>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(A1, A2) const) {
|
|
return new _ConstTessMemberResultCallback_0_2<true, R, T1, A1, A2>(obj,
|
|
member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2>
|
|
inline typename _ConstTessMemberResultCallback_0_2<false, R, T1, A1, A2>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(A1, A2) const) {
|
|
return new _ConstTessMemberResultCallback_0_2<false, R, T1, A1, A2>(obj,
|
|
member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class A1, class A2>
|
|
class _TessMemberResultCallback_0_2 : public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(A1, A2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_2(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
R Run(A1 a1, A2 a2) override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class A1, class A2>
|
|
class _TessMemberResultCallback_0_2<del, void, T, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(A1, A2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_2(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(a1, a2);
|
|
} else {
|
|
(object_->*member_)(a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2>
|
|
inline typename _TessMemberResultCallback_0_2<true, R, T1, A1, A2>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(A1, A2)) {
|
|
return new _TessMemberResultCallback_0_2<true, R, T1, A1, A2>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2>
|
|
inline typename _TessMemberResultCallback_0_2<false, R, T1, A1, A2>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(A1, A2)) {
|
|
return new _TessMemberResultCallback_0_2<false, R, T1, A1, A2>(obj, member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class A1, class A2>
|
|
class _TessFunctionResultCallback_0_2 : public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using FunctionSignature = R (*)(A1, A2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
|
|
public:
|
|
inline explicit _TessFunctionResultCallback_0_2(FunctionSignature function)
|
|
: function_(function) {}
|
|
|
|
R Run(A1 a1, A2 a2) override {
|
|
if (!del) {
|
|
R result = (*function_)(a1, a2);
|
|
return result;
|
|
}
|
|
R result = (*function_)(a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class A1, class A2>
|
|
class _TessFunctionResultCallback_0_2<del, void, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using FunctionSignature = void (*)(A1, A2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
|
|
public:
|
|
inline explicit _TessFunctionResultCallback_0_2(FunctionSignature function)
|
|
: function_(function) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(*function_)(a1, a2);
|
|
} else {
|
|
(*function_)(a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class A1, class A2>
|
|
inline typename _TessFunctionResultCallback_0_2<true, R, A1, A2>::base*
|
|
NewTessCallback(R (*function)(A1, A2)) {
|
|
return new _TessFunctionResultCallback_0_2<true, R, A1, A2>(function);
|
|
}
|
|
|
|
template <class R, class A1, class A2>
|
|
inline typename _TessFunctionResultCallback_0_2<false, R, A1, A2>::base*
|
|
NewPermanentTessCallback(R (*function)(A1, A2)) {
|
|
return new _TessFunctionResultCallback_0_2<false, R, A1, A2>(function);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_1_2
|
|
: public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(P1, A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_1_2(const T* object,
|
|
MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_1_2<del, void, T, P1, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(P1, A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_1_2(const T* object,
|
|
MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, a1, a2);
|
|
} else {
|
|
(object_->*member_)(p1_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1, class A2>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_1_2<true, R, T1, P1, A1, A2>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, A1, A2) const,
|
|
typename Identity<P1>::type p1) {
|
|
return new _ConstTessMemberResultCallback_1_2<true, R, T1, P1, A1, A2>(
|
|
obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1, class A2>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_1_2<false, R, T1, P1, A1, A2>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, A1, A2) const,
|
|
typename Identity<P1>::type p1) {
|
|
return new _ConstTessMemberResultCallback_1_2<false, R, T1, P1, A1, A2>(
|
|
obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class A1, class A2>
|
|
class _TessMemberResultCallback_1_2 : public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(P1, A1, A2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_1_2(T* object, MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class A1, class A2>
|
|
class _TessMemberResultCallback_1_2<del, void, T, P1, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(P1, A1, A2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_1_2(T* object, MemberSignature member, P1 p1)
|
|
: object_(object), member_(member), p1_(p1) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, a1, a2);
|
|
} else {
|
|
(object_->*member_)(p1_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1, class A2>
|
|
inline typename _TessMemberResultCallback_1_2<true, R, T1, P1, A1, A2>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, A1, A2),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessMemberResultCallback_1_2<true, R, T1, P1, A1, A2>(obj, member,
|
|
p1);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class A1, class A2>
|
|
inline typename _TessMemberResultCallback_1_2<false, R, T1, P1, A1, A2>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, A1, A2),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessMemberResultCallback_1_2<false, R, T1, P1, A1, A2>(
|
|
obj, member, p1);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class A1, class A2>
|
|
class _TessFunctionResultCallback_1_2 : public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using FunctionSignature = R (*)(P1, A1, A2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_1_2(FunctionSignature function, P1 p1)
|
|
: function_(function), p1_(p1) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class A1, class A2>
|
|
class _TessFunctionResultCallback_1_2<del, void, P1, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using FunctionSignature = void (*)(P1, A1, A2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_1_2(FunctionSignature function, P1 p1)
|
|
: function_(function), p1_(p1) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(*function_)(p1_, a1, a2);
|
|
} else {
|
|
(*function_)(p1_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class A1, class A2>
|
|
inline typename _TessFunctionResultCallback_1_2<true, R, P1, A1, A2>::base*
|
|
NewTessCallback(R (*function)(P1, A1, A2), typename Identity<P1>::type p1) {
|
|
return new _TessFunctionResultCallback_1_2<true, R, P1, A1, A2>(function, p1);
|
|
}
|
|
|
|
template <class R, class P1, class A1, class A2>
|
|
inline typename _TessFunctionResultCallback_1_2<false, R, P1, A1, A2>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, A1, A2),
|
|
typename Identity<P1>::type p1) {
|
|
return new _TessFunctionResultCallback_1_2<false, R, P1, A1, A2>(function,
|
|
p1);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_2_2
|
|
: public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(P1, P2, A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_2_2(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_2_2<del, void, T, P1, P2, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(P1, P2, A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_2_2(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, a1, a2);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1, class A2>
|
|
inline typename _ConstTessMemberResultCallback_2_2<true, R, T1, P1, P2, A1,
|
|
A2>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, A1, A2) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _ConstTessMemberResultCallback_2_2<true, R, T1, P1, P2, A1, A2>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1, class A2>
|
|
inline typename _ConstTessMemberResultCallback_2_2<false, R, T1, P1, P2, A1,
|
|
A2>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(P1, P2, A1, A2) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _ConstTessMemberResultCallback_2_2<false, R, T1, P1, P2, A1, A2>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class A1, class A2>
|
|
class _TessMemberResultCallback_2_2 : public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(P1, P2, A1, A2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_2_2(T* object, MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
R Run(A1 a1, A2 a2) override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class A1, class A2>
|
|
class _TessMemberResultCallback_2_2<del, void, T, P1, P2, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(P1, P2, A1, A2);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_2_2(T* object, MemberSignature member, P1 p1,
|
|
P2 p2)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, a1, a2);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1, class A2>
|
|
inline
|
|
typename _TessMemberResultCallback_2_2<true, R, T1, P1, P2, A1, A2>::base*
|
|
NewTessCallback(T1* obj, R (T2::*member)(P1, P2, A1, A2),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessMemberResultCallback_2_2<true, R, T1, P1, P2, A1, A2>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class A1, class A2>
|
|
inline
|
|
typename _TessMemberResultCallback_2_2<false, R, T1, P1, P2, A1, A2>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(P1, P2, A1, A2),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessMemberResultCallback_2_2<false, R, T1, P1, P2, A1, A2>(
|
|
obj, member, p1, p2);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class P1, class P2, class A1, class A2>
|
|
class _TessFunctionResultCallback_2_2 : public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using FunctionSignature = R (*)(P1, P2, A1, A2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_2_2(FunctionSignature function, P1 p1,
|
|
P2 p2)
|
|
: function_(function), p1_(p1), p2_(p2) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
R result = (*function_)(p1_, p2_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (*function_)(p1_, p2_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class P1, class P2, class A1, class A2>
|
|
class _TessFunctionResultCallback_2_2<del, void, P1, P2, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using FunctionSignature = void (*)(P1, P2, A1, A2);
|
|
|
|
private:
|
|
FunctionSignature function_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
|
|
public:
|
|
inline _TessFunctionResultCallback_2_2(FunctionSignature function, P1 p1,
|
|
P2 p2)
|
|
: function_(function), p1_(p1), p2_(p2) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(*function_)(p1_, p2_, a1, a2);
|
|
} else {
|
|
(*function_)(p1_, p2_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
function_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
template <class R, class P1, class P2, class A1, class A2>
|
|
inline typename _TessFunctionResultCallback_2_2<true, R, P1, P2, A1, A2>::base*
|
|
NewTessCallback(R (*function)(P1, P2, A1, A2), typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessFunctionResultCallback_2_2<true, R, P1, P2, A1, A2>(function,
|
|
p1, p2);
|
|
}
|
|
|
|
template <class R, class P1, class P2, class A1, class A2>
|
|
inline typename _TessFunctionResultCallback_2_2<false, R, P1, P2, A1, A2>::base*
|
|
NewPermanentTessCallback(R (*function)(P1, P2, A1, A2),
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2) {
|
|
return new _TessFunctionResultCallback_2_2<false, R, P1, P2, A1, A2>(function,
|
|
p1, p2);
|
|
}
|
|
|
|
template <bool del, class R, class T, class P1, class P2, class P3, class A1,
|
|
class A2>
|
|
class _ConstTessMemberResultCallback_3_2
|
|
: public TessResultCallback2<R, A1, A2> {
|
|
public:
|
|
typedef TessResultCallback2<R, A1, A2> base;
|
|
using MemberSignature = R (T::*)(P1, P2, P3, A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_3_2(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(p1_, p2_, p3_, a1, a2);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(p1_, p2_, p3_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
template <bool del, class T, class P1, class P2, class P3, class A1, class A2>
|
|
class _ConstTessMemberResultCallback_3_2<del, void, T, P1, P2, P3, A1, A2>
|
|
: public TessCallback2<A1, A2> {
|
|
public:
|
|
typedef TessCallback2<A1, A2> base;
|
|
using MemberSignature = void (T::*)(P1, P2, P3, A1, A2) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
typename remove_reference<P1>::type p1_;
|
|
typename remove_reference<P2>::type p2_;
|
|
typename remove_reference<P3>::type p3_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_3_2(const T* object,
|
|
MemberSignature member, P1 p1,
|
|
P2 p2, P3 p3)
|
|
: object_(object), member_(member), p1_(p1), p2_(p2), p3_(p3) {}
|
|
|
|
virtual void Run(A1 a1, A2 a2) {
|
|
if (!del) {
|
|
(object_->*member_)(p1_, p2_, p3_, a1, a2);
|
|
} else {
|
|
(object_->*member_)(p1_, p2_, p3_, a1, a2);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
}
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class A1,
|
|
class A2>
|
|
inline typename _ConstTessMemberResultCallback_3_2<true, R, T1, P1, P2, P3, A1,
|
|
A2>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(P1, P2, P3, A1, A2) const,
|
|
typename Identity<P1>::type p1, typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _ConstTessMemberResultCallback_3_2<true, R, T1, P1, P2, P3, A1,
|
|
A2>(obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class P1, class P2, class P3, class A1,
|
|
class A2>
|
|
inline typename _ConstTessMemberResultCallback_3_2<false, R, T1, P1, P2, P3, A1,
|
|
A2>::base*
|
|
NewPermanentTessCallback(const T1* obj,
|
|
R (T2::*member)(P1, P2, P3, A1, A2) const,
|
|
typename Identity<P1>::type p1,
|
|
typename Identity<P2>::type p2,
|
|
typename Identity<P3>::type p3) {
|
|
return new _ConstTessMemberResultCallback_3_2<false, R, T1, P1, P2, P3, A1,
|
|
A2>(obj, member, p1, p2, p3);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class A1, class A2, class A3>
|
|
class _ConstTessMemberResultCallback_0_3
|
|
: public TessResultCallback3<R, A1, A2, A3> {
|
|
public:
|
|
typedef TessResultCallback3<R, A1, A2, A3> base;
|
|
using MemberSignature = R (T::*)(A1, A2, A3) const;
|
|
|
|
private:
|
|
const T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _ConstTessMemberResultCallback_0_3(const T* object,
|
|
MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
R Run(A1 a1, A2 a2, A3 a3) override {
|
|
if (!del) {
|
|
R result = (object_->*member_)(a1, a2, a3);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(a1, a2, a3);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2, class A3>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_0_3<true, R, T1, A1, A2, A3>::base*
|
|
NewTessCallback(const T1* obj, R (T2::*member)(A1, A2, A3) const) {
|
|
return new _ConstTessMemberResultCallback_0_3<true, R, T1, A1, A2, A3>(
|
|
obj, member);
|
|
}
|
|
#endif
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2, class A3>
|
|
inline
|
|
typename _ConstTessMemberResultCallback_0_3<false, R, T1, A1, A2, A3>::base*
|
|
NewPermanentTessCallback(const T1* obj, R (T2::*member)(A1, A2, A3) const) {
|
|
return new _ConstTessMemberResultCallback_0_3<false, R, T1, A1, A2, A3>(
|
|
obj, member);
|
|
}
|
|
#endif
|
|
|
|
template <bool del, class R, class T, class A1, class A2, class A3, class A4>
|
|
class _TessMemberResultCallback_0_4
|
|
: public TessResultCallback4<R, A1, A2, A3, A4> {
|
|
public:
|
|
typedef TessResultCallback4<R, A1, A2, A3, A4> base;
|
|
using MemberSignature = R (T::*)(A1, A2, A3, A4);
|
|
|
|
private:
|
|
T* object_;
|
|
MemberSignature member_;
|
|
|
|
public:
|
|
inline _TessMemberResultCallback_0_4(T* object, MemberSignature member)
|
|
: object_(object), member_(member) {}
|
|
|
|
virtual R Run(A1 a1, A2 a2, A3 a3, A4 a4) {
|
|
if (!del) {
|
|
R result = (object_->*member_)(a1, a2, a3, a4);
|
|
return result;
|
|
}
|
|
R result = (object_->*member_)(a1, a2, a3, a4);
|
|
// zero out the pointer to ensure segfault if used again
|
|
member_ = nullptr;
|
|
delete this;
|
|
return result;
|
|
}
|
|
};
|
|
|
|
#ifndef SWIG
|
|
template <class T1, class T2, class R, class A1, class A2, class A3, class A4>
|
|
inline
|
|
typename _TessMemberResultCallback_0_4<false, R, T1, A1, A2, A3, A4>::base*
|
|
NewPermanentTessCallback(T1* obj, R (T2::*member)(A1, A2, A3, A4)) {
|
|
return new _TessMemberResultCallback_0_4<false, R, T1, A1, A2, A3, A4>(
|
|
obj, member);
|
|
}
|
|
#endif
|
|
|
|
#endif // TESS_CALLBACK_SPECIALIZATIONS_H_
|