Initial revision. Contributed by Bernie Bright.
This commit is contained in:
parent
e1cb71ee9b
commit
aaeb1222e5
3 changed files with 358 additions and 0 deletions
90
auto_ptr.hxx
Normal file
90
auto_ptr.hxx
Normal file
|
@ -0,0 +1,90 @@
|
|||
/**************************************************************************
|
||||
* auto_ptr.hxx -- A simple auto_ptr definition.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* $Id$
|
||||
* (Log is kept at end of this file)
|
||||
**************************************************************************/
|
||||
|
||||
#ifndef _AUTO_PTR_HXX
|
||||
#define _AUTO_PTR_HXX
|
||||
|
||||
#include "fg_stl_config.h"
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// auto_ptr is initialised with a pointer obtained via new and deletes that
|
||||
// object when it itself is destroyed (such as when leaving block scope).
|
||||
// auto_ptr can be used in any way that a normal pointer can be.
|
||||
//
|
||||
// This class is only required when the STL doesn't supply one.
|
||||
//
|
||||
template <class X> class auto_ptr {
|
||||
private:
|
||||
X* ptr;
|
||||
mutable bool owns;
|
||||
|
||||
public:
|
||||
typedef X element_type;
|
||||
|
||||
explicit auto_ptr(X* p = 0) : ptr(p), owns(p) {}
|
||||
|
||||
auto_ptr(const auto_ptr& a) : ptr(a.ptr), owns(a.owns) {
|
||||
a.owns = 0;
|
||||
}
|
||||
|
||||
template <class T> auto_ptr(const auto_ptr<T>& a)
|
||||
: ptr(a.ptr), owns(a.owns) {
|
||||
a.owns = 0;
|
||||
}
|
||||
|
||||
auto_ptr& operator = (const auto_ptr& a) {
|
||||
if (&a != this) {
|
||||
if (owns)
|
||||
delete ptr;
|
||||
owns = a.owns;
|
||||
ptr = a.ptr;
|
||||
a.owns = 0;
|
||||
}
|
||||
}
|
||||
|
||||
template <class T> auto_ptr& operator = (const auto_ptr<T>& a) {
|
||||
if (&a != this) {
|
||||
if (owns)
|
||||
delete ptr;
|
||||
owns = a.owns;
|
||||
ptr = a.ptr;
|
||||
a.owns = 0;
|
||||
}
|
||||
}
|
||||
|
||||
~auto_ptr() {
|
||||
if (owns)
|
||||
delete ptr;
|
||||
}
|
||||
|
||||
X& operator*() const { return *ptr; }
|
||||
X* operator->() const { return ptr; }
|
||||
X* get() const { return ptr; }
|
||||
X* release() const { owns = false; return ptr; }
|
||||
};
|
||||
|
||||
#endif /* _AUTO_PTR_HXX */
|
||||
|
||||
// $Log$
|
||||
// Revision 1.1 1998/08/30 14:12:45 curt
|
||||
// Initial revision. Contributed by Bernie Bright.
|
||||
//
|
178
fg_callback.hxx
Normal file
178
fg_callback.hxx
Normal file
|
@ -0,0 +1,178 @@
|
|||
/**************************************************************************
|
||||
* fg_callback.hxx -- Wrapper classes to treat function and method pointers
|
||||
* as objects.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* $Id$
|
||||
* (Log is kept at end of this file)
|
||||
**************************************************************************/
|
||||
|
||||
#ifndef _FG_CALLBACK_HXX
|
||||
#define _FG_CALLBACK_HXX
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// Abstract base class for all FlightGear callbacks.
|
||||
//
|
||||
class fgCallback
|
||||
{
|
||||
public:
|
||||
virtual ~fgCallback() {}
|
||||
|
||||
virtual fgCallback* clone() const = 0;
|
||||
virtual void* call( void** ) = 0;
|
||||
|
||||
size_t params() const { return n_params; }
|
||||
|
||||
protected:
|
||||
fgCallback( size_t params )
|
||||
: n_params(params) {}
|
||||
|
||||
protected:
|
||||
// The number of parameters to pass to the callback routine.
|
||||
size_t n_params;
|
||||
|
||||
private:
|
||||
};
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// Callback for invoking a file scope function.
|
||||
//
|
||||
class fgFunctionCallback : public fgCallback
|
||||
{
|
||||
public:
|
||||
// Pointer to function taking no arguments and returning void.
|
||||
typedef void (*Proc0v)();
|
||||
|
||||
fgFunctionCallback( Proc0v p );
|
||||
virtual fgCallback* clone() const;
|
||||
|
||||
private:
|
||||
void* call( void** in );
|
||||
void* call0v( void** );
|
||||
|
||||
private:
|
||||
// Not defined.
|
||||
fgFunctionCallback();
|
||||
|
||||
private:
|
||||
|
||||
typedef void* (fgFunctionCallback::*DoPtr)( void** );
|
||||
DoPtr doPtr;
|
||||
Proc0v proc0v;
|
||||
};
|
||||
|
||||
inline
|
||||
fgFunctionCallback::fgFunctionCallback( Proc0v p )
|
||||
: fgCallback(0),
|
||||
doPtr(&fgFunctionCallback::call0v),
|
||||
proc0v(p)
|
||||
{
|
||||
// empty
|
||||
}
|
||||
|
||||
inline fgCallback*
|
||||
fgFunctionCallback::clone() const
|
||||
{
|
||||
return new fgFunctionCallback( *this );
|
||||
}
|
||||
|
||||
inline void*
|
||||
fgFunctionCallback::call( void** in )
|
||||
{
|
||||
return (this->*doPtr)( in );
|
||||
}
|
||||
|
||||
inline void*
|
||||
fgFunctionCallback::call0v( void** )
|
||||
{
|
||||
(*proc0v)();
|
||||
return (void*) NULL;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// Callback for invoking an instance method.
|
||||
//
|
||||
template< class T >
|
||||
class fgMethodCallback : public fgCallback
|
||||
{
|
||||
public:
|
||||
// Pointer to method taking no arguments and returning void.
|
||||
typedef void (T::*Method0v)();
|
||||
|
||||
//
|
||||
fgMethodCallback( T* o, Method0v m );
|
||||
|
||||
//
|
||||
fgCallback* clone() const;
|
||||
|
||||
private:
|
||||
//
|
||||
void* call( void** in );
|
||||
|
||||
//
|
||||
void* call0v( void** );
|
||||
|
||||
private:
|
||||
// Not defined.
|
||||
fgMethodCallback();
|
||||
|
||||
private:
|
||||
T* object;
|
||||
Method0v method0v;
|
||||
|
||||
typedef void * (fgMethodCallback::*DoPtr)( void ** );
|
||||
DoPtr doPtr;
|
||||
};
|
||||
|
||||
template< class T > inline
|
||||
fgMethodCallback<T>::fgMethodCallback( T* o, Method0v m )
|
||||
: fgCallback(0),
|
||||
object(o),
|
||||
method0v(m),
|
||||
doPtr(&fgMethodCallback<T>::call0v)
|
||||
{
|
||||
}
|
||||
|
||||
template< class T > inline fgCallback*
|
||||
fgMethodCallback<T>::clone() const
|
||||
{
|
||||
return new fgMethodCallback( *this );
|
||||
}
|
||||
|
||||
template< class T > inline void*
|
||||
fgMethodCallback<T>::call( void** in )
|
||||
{
|
||||
return (this->*doPtr)( in );
|
||||
}
|
||||
|
||||
|
||||
template< class T > inline void*
|
||||
fgMethodCallback<T>::call0v( void** )
|
||||
{
|
||||
(object->*method0v)();
|
||||
return (void*) NULL;
|
||||
}
|
||||
|
||||
#endif // _FG_CALLBACK_HXX
|
||||
|
||||
// $Log$
|
||||
// Revision 1.1 1998/08/30 14:13:48 curt
|
||||
// Initial revision. Contributed by Bernie Bright.
|
||||
//
|
||||
|
90
fg_stl_config.h
Normal file
90
fg_stl_config.h
Normal file
|
@ -0,0 +1,90 @@
|
|||
/**************************************************************************
|
||||
* fg_stl_config.hxx -- STL Portability Macros
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* $Id$
|
||||
* (Log is kept at end of this file)
|
||||
**************************************************************************/
|
||||
|
||||
#ifndef _FG_STL_CONFIG_H
|
||||
#define _FG_STL_CONFIG_H
|
||||
|
||||
// What this file does.
|
||||
// (1) Defines macros for some STL includes which may be affected
|
||||
// by file name length limitations.
|
||||
// (2) Defines macros for some features not supported by all C++ compilers.
|
||||
// (3) Defines 'explicit' as a null macro if the compiler doesn't support
|
||||
// the explicit keyword.
|
||||
// (4) Defines 'typename' as a null macro if the compiler doesn't support
|
||||
// the typename keyword.
|
||||
// (5) Defines bool, true and false if the compiler doesn't do so.
|
||||
// (6) Defines _FG_EXPLICIT_FUNCTION_TMPL_ARGS if the compiler
|
||||
// supports calling a function template by providing its template
|
||||
// arguments explicitly.
|
||||
// (7) Defines _FG_NEED_AUTO_PTR if STL doesn't provide auto_ptr<>.
|
||||
|
||||
#ifdef __GNUC__
|
||||
# if __GNUC__ == 2 && __GNUC_MINOR__ >= 8
|
||||
// g++-2.8.x and egcs-1.0.x
|
||||
# define STL_ALGORITHM <algorithm>
|
||||
# define STL_FUNCTIONAL <functional>
|
||||
# define STL_IOMANIP <iomanip>
|
||||
# define STL_IOSTREAM <iostream>
|
||||
# define STL_STDEXCEPT <stdexcept>
|
||||
# define STL_STRING <string>
|
||||
# define STL_STRSTREAM <strstream>
|
||||
|
||||
# define _FG_EXPLICIT_FUNCTION_TMPL_ARGS
|
||||
# define _FG_NEED_AUTO_PTR
|
||||
|
||||
# else
|
||||
# error Old GNU compilers not yet supported
|
||||
# endif
|
||||
#endif
|
||||
|
||||
// Microsoft compilers.
|
||||
#ifdef _MSC_VER
|
||||
# if _MSC_VER < 1100
|
||||
# define _FG_NEED_EXPLICIT
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef _FG_NEED_EXPLICIT
|
||||
# define explicit
|
||||
#endif
|
||||
|
||||
#ifdef _FG_NEED_TYPENAME
|
||||
# define typename
|
||||
#endif
|
||||
|
||||
#ifdef _FG_NEED_BOOL
|
||||
typedef int bool;
|
||||
# define true 1
|
||||
# define false 0
|
||||
#endif
|
||||
|
||||
#ifdef _FG_EXPLICIT_FUNCTION_TMPL_ARGS
|
||||
# define _FG_NULL_TMPL_ARGS <>
|
||||
#else
|
||||
# define _FG_NULL_TMPL_ARGS
|
||||
#endif
|
||||
|
||||
#endif // _FG_STL_CONFIG_H
|
||||
|
||||
// $Log$
|
||||
// Revision 1.1 1998/08/30 14:13:49 curt
|
||||
// Initial revision. Contributed by Bernie Bright.
|
||||
//
|
Loading…
Reference in a new issue