public inbox for gcc-prs@sourceware.org
help / color / mirror / Atom feed
* Re: c++/6396: 3.1 flow.c 583 ICE with -frename-registers
@ 2002-04-25  9:35 jakub
  0 siblings, 0 replies; 4+ messages in thread
From: jakub @ 2002-04-25  9:35 UTC (permalink / raw)
  To: gcc-bugs, gcc-prs, nobody, tmwg

Synopsis: 3.1 flow.c 583 ICE with -frename-registers

State-Changed-From-To: open->analyzed
State-Changed-By: jakub
State-Changed-When: Thu Apr 25 09:35:06 2002
State-Changed-Why:
    Using -frename-registers at -O0 is a bad idea.
    I've just submitted a patch which does register renaming
    only when optimizing.

http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=6396


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: c++/6396: 3.1 flow.c 583 ICE with -frename-registers
@ 2002-10-28  4:14 reichelt
  0 siblings, 0 replies; 4+ messages in thread
From: reichelt @ 2002-10-28  4:14 UTC (permalink / raw)
  To: gcc-bugs, gcc-prs, nobody, tmwg

Synopsis: 3.1 flow.c 583 ICE with -frename-registers

State-Changed-From-To: analyzed->closed
State-Changed-By: reichelt
State-Changed-When: Mon Oct 28 04:14:35 2002
State-Changed-Why:
    I cannot reproduce the problem.
    Apparaently fixed.

http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=6396


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: c++/6396: 3.1 flow.c 583 ICE with -frename-registers
@ 2002-04-25 10:36 George Garvey
  0 siblings, 0 replies; 4+ messages in thread
From: George Garvey @ 2002-04-25 10:36 UTC (permalink / raw)
  To: nobody; +Cc: gcc-prs

The following reply was made to PR c++/6396; it has been noted by GNATS.

From: George Garvey <tmwg@inxservices.com>
To: jakub@gcc.gnu.org, gcc-bugs@gcc.gnu.org, gcc-prs@gcc.gnu.org,
  nobody@gcc.gnu.org, gcc-gnats@gcc.gnu.org
Cc:  
Subject: Re: c++/6396: 3.1 flow.c 583 ICE with -frename-registers
Date: Thu, 25 Apr 2002 10:26:15 -0700

    You are right. I messed something up in the makefile, and added -O0
 by mistake after -O2 et al. I just verified that removing the -O0 and only
 using -O2 and the other options does not get an ICE, the file compiles
 successfully.
 
 On Thu, Apr 25, 2002 at 04:35:08PM -0000, jakub@gcc.gnu.org wrote:
 > Synopsis: 3.1 flow.c 583 ICE with -frename-registers
 > 
 > State-Changed-From-To: open->analyzed
 > State-Changed-By: jakub
 > State-Changed-When: Thu Apr 25 09:35:06 2002
 > State-Changed-Why:
 >     Using -frename-registers at -O0 is a bad idea.
 >     I've just submitted a patch which does register renaming
 >     only when optimizing.
 > 
 > http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=6396


^ permalink raw reply	[flat|nested] 4+ messages in thread

* c++/6396: 3.1 flow.c:583 ICE with -frename-registers
@ 2002-04-21 11:56 tmwg-gcc
  0 siblings, 0 replies; 4+ messages in thread
From: tmwg-gcc @ 2002-04-21 11:56 UTC (permalink / raw)
  To: gcc-gnats


>Number:         6396
>Category:       c++
>Synopsis:       3.1 flow.c 583 ICE with -frename-registers
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    unassigned
>State:          open
>Class:          ice-on-legal-code
>Submitter-Id:   net
>Arrival-Date:   Sun Apr 21 11:56:01 PDT 2002
>Closed-Date:
>Last-Modified:
>Originator:     George Garvey
>Release:        3.0.99.10 20020420 (prerelease)
>Organization:
inX Services
>Environment:
System: Linux mwg 2.4.19-pre5-ac1 #1 Thu Apr 4 10:43:33 PST 2002 i686 unknown
Architecture: i686

I renamed the version from 3.1 to 3.0.99.10
host: i686-inX-linux
build: i686-inX-linux
target: i686-inX-linux
configured with: ../configure --prefix=/usr --exec-prefix=/usr --datadir=/usr/lib --includedir=/usr/local/include --with-gnu-ld --with-gnu-as --with-local-prefix=/usr/local --with-gxx-include-dir=/usr/include/c++3.1 --with-cpp-install-dir=/lib --disable-c-mbchar --enable-threads=posix --with-dwarf2 --enable-shared --disable-nls --with-system-zlib --enable-version-specific-runtime-libs --with-slibdir=/lib --enable-fast-character --enable-interpreter --with-x --enable-clocale=gnu --disable-c-mbchar --enable-c99 --enable-long-long --enable-cheaders=c_std --enable-cxx-flags="-march=i686 -pipe -O2 -fomit-frame-pointer -momit-leaf-frame-pointer -frename-registers -fexpensive-optimizations -fschedule-insns -fschedule-insns2 -malign-stringops -fno-keep-static-consts -fno-keep-inline-functions -fdata-sections -ffunction-sections" --enable-languages=c,c++,gcov,proto --verbose --host=i686-inX-linux --build=i686-inX-linux --target=i686-inX-linux
>Description:
	
>How-To-Repeat:
g++ -pipe -O2 -fomit-frame-pointer -momit-leaf-frame-pointer -frename-registers -fexpensive-optimizations -fschedule-insns -fschedule-insns2  -Wall -W -Wformat -Wformat-security -Wformat-extra-args -Wno-format-y2k -Wdisabled-optimization -Wno-system-headers -Wunused-function -Wunused-label -Wunused-parameter -Winline -Wsynth -Wsign-promo -Wold-style-cast  -fno-keep-static-consts -fno-keep-inline-functions -malign-stringops -fdata-sections -D_GNU_SOURCE -DATTRIB_FMT_BUG=1 -DARGS_FMT_BUG=1    -DRKeditor=1 -DREAD_SYLK=1 -DVAN_DIRECTORY="\"/usr/inXDB/van\"" -DinX_DEBUG -DUSE_MMAP=1 -I../array -I../object -I../avl -I../julian -I../inXDB -I../inXDB/DB -I../modem -I../money -I../inXDB/test -I../edi -I../webapp -I../iconn -I../van -I../van/cs -I../blowfish -I../van -I../van/maint -I../van/vansh -I../van/ivansh -I../van/with -isystem /usr/include/X11 -O0 -ffunction-sections  -march=i686 -c -MD -g ../inXDB/DB/TypeGen.cc -o ../i686_unix/o/inXDB/dbGen/TypeGen.o

# 1 "../inXDB/DB/TypeGen.cc"
# 1 "<built-in>"
# 1 "<command line>"
# 1 "../inXDB/DB/TypeGen.cc"

#ident "@(#)$Id: TypeGen.cc 1.5.1.96 Mon, 08 Apr 2002 04:34:36 -0700 tmwg $ -- Copyright (c) 1997-2002 inX Services"
# 11 "../inXDB/DB/TypeGen.cc"
# 1 "../array/inX.h" 1



#ident "@(#)$Id: inX.h 1.6 Thu, 24 Jan 2002 17:40:44 -0800 tmwg $ -- Copyright (c) 1997-2000 inX Services"
# 25 "../array/inX.h"
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 1 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/features.h" 1 3
# 283 "/usr/lib/gcc/../../i686-inX-linux/include/features.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/cdefs.h" 1 3
# 284 "/usr/lib/gcc/../../i686-inX-linux/include/features.h" 2 3
# 312 "/usr/lib/gcc/../../i686-inX-linux/include/features.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/gnu/stubs.h" 1 3
# 313 "/usr/lib/gcc/../../i686-inX-linux/include/features.h" 2 3
# 27 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3

extern "C" {

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/types.h" 1 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/bits/types.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 201 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 3
typedef unsigned int size_t;
# 30 "/usr/lib/gcc/../../i686-inX-linux/include/bits/types.h" 2 3


typedef unsigned char __u_char;
typedef unsigned short __u_short;
typedef unsigned int __u_int;
typedef unsigned long __u_long;

__extension__ typedef unsigned long long int __u_quad_t;
__extension__ typedef long long int __quad_t;
# 49 "/usr/lib/gcc/../../i686-inX-linux/include/bits/types.h" 3
typedef signed char __int8_t;
typedef unsigned char __uint8_t;
typedef signed short int __int16_t;
typedef unsigned short int __uint16_t;
typedef signed int __int32_t;
typedef unsigned int __uint32_t;

__extension__ typedef signed long long int __int64_t;
__extension__ typedef unsigned long long int __uint64_t;

typedef __quad_t *__qaddr_t;

typedef __u_quad_t __dev_t;
typedef __u_int __uid_t;
typedef __u_int __gid_t;
typedef __u_long __ino_t;
typedef __u_int __mode_t;
typedef __u_int __nlink_t;
typedef long int __off_t;
typedef __quad_t __loff_t;
typedef int __pid_t;
typedef int __ssize_t;
typedef __u_long __rlim_t;
typedef __u_quad_t __rlim64_t;
typedef __u_int __id_t;

typedef struct
  {
    int __val[2];
  } __fsid_t;


typedef int __daddr_t;
typedef char *__caddr_t;
typedef long int __time_t;
typedef unsigned int __useconds_t;
typedef long int __suseconds_t;
typedef long int __swblk_t;

typedef long int __clock_t;


typedef int __clockid_t;


typedef int __timer_t;






typedef int __key_t;


typedef unsigned short int __ipc_pid_t;



typedef long int __blksize_t;




typedef long int __blkcnt_t;
typedef __quad_t __blkcnt64_t;


typedef __u_long __fsblkcnt_t;
typedef __u_quad_t __fsblkcnt64_t;


typedef __u_long __fsfilcnt_t;
typedef __u_quad_t __fsfilcnt64_t;


typedef __u_quad_t __ino64_t;


typedef __loff_t __off64_t;


typedef long int __t_scalar_t;
typedef unsigned long int __t_uscalar_t;


typedef int __intptr_t;


typedef unsigned int __socklen_t;




# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/pthreadtypes.h" 1 3
# 23 "/usr/lib/gcc/../../i686-inX-linux/include/bits/pthreadtypes.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sched.h" 1 3
# 68 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sched.h" 3
struct __sched_param
  {
    int __sched_priority;
  };
# 24 "/usr/lib/gcc/../../i686-inX-linux/include/bits/pthreadtypes.h" 2 3


struct _pthread_fastlock
{
  long int __status;
  int __spinlock;

};



typedef struct _pthread_descr_struct *_pthread_descr;





typedef struct __pthread_attr_s
{
  int __detachstate;
  int __schedpolicy;
  struct __sched_param __schedparam;
  int __inheritsched;
  int __scope;
  size_t __guardsize;
  int __stackaddr_set;
  void *__stackaddr;
  size_t __stacksize;
} pthread_attr_t;



typedef struct
{
  struct _pthread_fastlock __c_lock;
  _pthread_descr __c_waiting;
} pthread_cond_t;



typedef struct
{
  int __dummy;
} pthread_condattr_t;


typedef unsigned int pthread_key_t;





typedef struct
{
  int __m_reserved;
  int __m_count;
  _pthread_descr __m_owner;
  int __m_kind;
  struct _pthread_fastlock __m_lock;
} pthread_mutex_t;



typedef struct
{
  int __mutexkind;
} pthread_mutexattr_t;



typedef int pthread_once_t;




typedef struct _pthread_rwlock_t
{
  struct _pthread_fastlock __rw_lock;
  int __rw_readers;
  _pthread_descr __rw_writer;
  _pthread_descr __rw_read_waiting;
  _pthread_descr __rw_write_waiting;
  int __rw_kind;
  int __rw_pshared;
} pthread_rwlock_t;



typedef struct
{
  int __lockkind;
  int __pshared;
} pthread_rwlockattr_t;




typedef volatile int pthread_spinlock_t;


typedef struct {
  struct _pthread_fastlock __ba_lock;
  int __ba_required;
  int __ba_present;
  _pthread_descr __ba_waiting;
} pthread_barrier_t;


typedef struct {
  int __pshared;
} pthread_barrierattr_t;





typedef unsigned long int pthread_t;
# 144 "/usr/lib/gcc/../../i686-inX-linux/include/bits/types.h" 2 3
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3



typedef __u_char u_char;
typedef __u_short u_short;
typedef __u_int u_int;
typedef __u_long u_long;
typedef __quad_t quad_t;
typedef __u_quad_t u_quad_t;
typedef __fsid_t fsid_t;




typedef __loff_t loff_t;



typedef __ino_t ino_t;






typedef __ino64_t ino64_t;




typedef __dev_t dev_t;




typedef __gid_t gid_t;




typedef __mode_t mode_t;




typedef __nlink_t nlink_t;




typedef __uid_t uid_t;





typedef __off_t off_t;






typedef __off64_t off64_t;




typedef __pid_t pid_t;




typedef __id_t id_t;




typedef __ssize_t ssize_t;





typedef __daddr_t daddr_t;
typedef __caddr_t caddr_t;





typedef __key_t key_t;
# 132 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 1 3
# 59 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
typedef __clock_t clock_t;
# 70 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
typedef __time_t time_t;
# 82 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
typedef __clockid_t clockid_t;
# 94 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
typedef __timer_t timer_t;
# 133 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3



typedef __useconds_t useconds_t;



typedef __suseconds_t suseconds_t;





# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 147 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3



typedef unsigned long int ulong;
typedef unsigned short int ushort;
typedef unsigned int uint;
# 190 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 3
typedef int int8_t __attribute__ ((__mode__ (__QI__)));
typedef int int16_t __attribute__ ((__mode__ (__HI__)));
typedef int int32_t __attribute__ ((__mode__ (__SI__)));
typedef int int64_t __attribute__ ((__mode__ (__DI__)));


typedef unsigned int u_int8_t __attribute__ ((__mode__ (__QI__)));
typedef unsigned int u_int16_t __attribute__ ((__mode__ (__HI__)));
typedef unsigned int u_int32_t __attribute__ ((__mode__ (__SI__)));
typedef unsigned int u_int64_t __attribute__ ((__mode__ (__DI__)));

typedef int register_t __attribute__ ((__mode__ (__word__)));
# 212 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/endian.h" 1 3
# 37 "/usr/lib/gcc/../../i686-inX-linux/include/endian.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/endian.h" 1 3
# 38 "/usr/lib/gcc/../../i686-inX-linux/include/endian.h" 2 3
# 213 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3


# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 1 3
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/select.h" 1 3
# 32 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 2 3


# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigset.h" 1 3
# 23 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigset.h" 3
typedef int __sig_atomic_t;




typedef struct
  {
    unsigned long int __val[(1024 / (8 * sizeof (unsigned long int)))];
  } __sigset_t;
# 35 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 2 3



typedef __sigset_t sigset_t;





# 1 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 1 3
# 106 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
struct timespec
  {
    __time_t tv_sec;
    long int tv_nsec;
  };
# 45 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 2 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/time.h" 1 3
# 67 "/usr/lib/gcc/../../i686-inX-linux/include/bits/time.h" 3
struct timeval
  {
    __time_t tv_sec;
    __suseconds_t tv_usec;
  };
# 47 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 2 3
# 55 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 3
typedef long int __fd_mask;







typedef struct
  {



    __fd_mask fds_bits[1024 / (8 * sizeof (__fd_mask))];





  } fd_set;






typedef __fd_mask fd_mask;
# 95 "/usr/lib/gcc/../../i686-inX-linux/include/sys/select.h" 3
extern "C" {






extern int select (int __nfds, fd_set *__restrict __readfds,
                   fd_set *__restrict __writefds,
                   fd_set *__restrict __exceptfds,
                   struct timeval *__restrict __timeout) throw ();





extern int pselect (int __nfds, fd_set *__restrict __readfds,
                    fd_set *__restrict __writefds,
                    fd_set *__restrict __exceptfds,
                    const struct timespec *__restrict __timeout,
                    const __sigset_t *__restrict __sigmask) throw ();


}
# 216 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3


# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/sysmacros.h" 1 3
# 219 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 2 3




typedef __blksize_t blksize_t;






typedef __blkcnt_t blkcnt_t;



typedef __fsblkcnt_t fsblkcnt_t;



typedef __fsfilcnt_t fsfilcnt_t;
# 257 "/usr/lib/gcc/../../i686-inX-linux/include/sys/types.h" 3
typedef __blkcnt64_t blkcnt64_t;
typedef __fsblkcnt64_t fsblkcnt64_t;
typedef __fsfilcnt64_t fsfilcnt64_t;


}
# 26 "../array/inX.h" 2
                typedef unsigned char uchar;
# 44 "../array/inX.h"
# 1 "/usr/include/c++3.1/ctime" 1 3
# 48 "/usr/include/c++3.1/ctime" 3

# 1 "/usr/include/c++3.1/cstddef" 1 3
# 47 "/usr/include/c++3.1/cstddef" 3

# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 147 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 3
typedef int ptrdiff_t;
# 49 "/usr/include/c++3.1/cstddef" 2 3

namespace std
{
  using ::ptrdiff_t;
  using ::size_t;
}
# 50 "/usr/include/c++3.1/ctime" 2 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 1 3
# 30 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
extern "C" {







# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 39 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 2 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/time.h" 1 3
# 43 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 2 3
# 118 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
struct tm
{
  int tm_sec;
  int tm_min;
  int tm_hour;
  int tm_mday;
  int tm_mon;
  int tm_year;
  int tm_wday;
  int tm_yday;
  int tm_isdst;


  long int tm_gmtoff;
  __const char *tm_zone;




};




struct itimerspec
  {
    struct timespec it_interval;
    struct timespec it_value;
  };


struct sigevent;
# 163 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
extern clock_t clock (void) throw ();


extern time_t time (time_t *__timer) throw ();


extern double difftime (time_t __time1, time_t __time0)
     throw () __attribute__ ((__const__));


extern time_t mktime (struct tm *__tp) throw ();





extern size_t strftime (char *__restrict __s, size_t __maxsize,
                        __const char *__restrict __format,
                        __const struct tm *__restrict __tp) throw ();




extern char *strptime (__const char *__restrict __s,
                       __const char *__restrict __fmt, struct tm *__tp)
     throw ();





extern struct tm *gmtime (__const time_t *__timer) throw ();



extern struct tm *localtime (__const time_t *__timer) throw ();




extern struct tm *gmtime_r (__const time_t *__restrict __timer,
                            struct tm *__restrict __tp) throw ();



extern struct tm *localtime_r (__const time_t *__restrict __timer,
                               struct tm *__restrict __tp) throw ();




extern char *asctime (__const struct tm *__tp) throw ();


extern char *ctime (__const time_t *__timer) throw ();






extern char *asctime_r (__const struct tm *__restrict __tp,
                        char *__restrict __buf) throw ();


extern char *ctime_r (__const time_t *__restrict __timer,
                      char *__restrict __buf) throw ();




extern char *__tzname[2];
extern int __daylight;
extern long int __timezone;




extern char *tzname[2];



extern void tzset (void) throw ();



extern int daylight;
extern long int timezone;





extern int stime (__const time_t *__when) throw ();
# 271 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
extern time_t timegm (struct tm *__tp) throw ();


extern time_t timelocal (struct tm *__tp) throw ();


extern int dysize (int __year) throw () __attribute__ ((__const__));





extern int nanosleep (__const struct timespec *__requested_time,
                      struct timespec *__remaining) throw ();



extern int clock_getres (clockid_t __clock_id, struct timespec *__res) throw ();


extern int clock_gettime (clockid_t __clock_id, struct timespec *__tp) throw ();


extern int clock_settime (clockid_t __clock_id, __const struct timespec *__tp)
     throw ();



extern int clock_nanosleep (clockid_t __clock_id, int __flags,
                            __const struct timespec *__req,
                            struct timespec *__rem) throw ();


extern int clock_getcpuclockid (pid_t __pid, clockid_t *__clock_id) throw ();




extern int timer_create (clockid_t __clock_id,
                         struct sigevent *__restrict __evp,
                         timer_t *__restrict __timerid) throw ();


extern int timer_delete (timer_t __timerid) throw ();


extern int timer_settime (timer_t __timerid, int __flags,
                          __const struct itimerspec *__restrict __value,
                          struct itimerspec *__restrict __ovalue) throw ();


extern int timer_gettime (timer_t __timerid, struct itimerspec *__value)
     throw ();


extern int timer_getoverrun (timer_t __timerid) throw ();
# 342 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
extern int getdate_err;





extern struct tm *getdate (__const char *__string) throw ();
# 357 "/usr/lib/gcc/../../i686-inX-linux/include/time.h" 3
extern int getdate_r (__const char *__restrict __string,
                      struct tm *__restrict __resbufp) throw ();



}
# 52 "/usr/include/c++3.1/ctime" 2 3
# 64 "/usr/include/c++3.1/ctime" 3
namespace std
{
  using ::clock_t;
  using ::time_t;
  using ::tm;

  using ::clock;
  using ::difftime;
  using ::mktime;
  using ::time;
  using ::asctime;
  using ::ctime;
  using ::gmtime;
  using ::localtime;
  using ::strftime;
}
# 45 "../array/inX.h" 2
# 53 "../array/inX.h"
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/time.h" 1 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 2 3
# 38 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 3
extern "C" {
# 56 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 3
struct timezone
  {
    int tz_minuteswest;
    int tz_dsttime;
  };

typedef struct timezone *__restrict __timezone_ptr_t;
# 72 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 3
extern int gettimeofday (struct timeval *__restrict __tv,
                         __timezone_ptr_t __tz) throw ();




extern int settimeofday (__const struct timeval *__tv,
                         __const struct timezone *__tz) throw ();





extern int adjtime (__const struct timeval *__delta,
                    struct timeval *__olddelta) throw ();




enum __itimer_which
  {

    ITIMER_REAL = 0,


    ITIMER_VIRTUAL = 1,



    ITIMER_PROF = 2

  };



struct itimerval
  {

    struct timeval it_interval;

    struct timeval it_value;
  };






typedef int __itimer_which_t;




extern int getitimer (__itimer_which_t __which,
                      struct itimerval *__value) throw ();




extern int setitimer (__itimer_which_t __which,
                      __const struct itimerval *__restrict __new,
                      struct itimerval *__restrict __old) throw ();



extern int utimes (__const char *__file, __const struct timeval __tvp[2])
     throw ();
# 171 "/usr/lib/gcc/../../i686-inX-linux/include/sys/time.h" 3
}
# 54 "../array/inX.h" 2




inline tm *
localtime(const timeval &t) {
        return ::localtime(&t.tv_sec);
}

inline time_t
sec(const timeval &t) {
        return t.tv_sec;
}

inline time_t
sec(timeval &t, const long s) {
        return t.tv_sec = s;
}

inline time_t
usec(const timeval &t) {
        return t.tv_usec;
}

inline time_t
usec(timeval &t, const long u) {
        return t.tv_usec = u;
}
# 127 "../array/inX.h"
                const int Success(0);
                const int File_Closed(-1);

# 1 "/usr/include/c++3.1/cstring" 1 3
# 48 "/usr/include/c++3.1/cstring" 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/string.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/string.h" 3
extern "C" {




# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 34 "/usr/lib/gcc/../../i686-inX-linux/include/string.h" 2 3



extern void *memcpy (void *__restrict __dest,
                     __const void *__restrict __src, size_t __n) throw ();


extern void *memmove (void *__dest, __const void *__src, size_t __n)
     throw ();





extern void *memccpy (void *__restrict __dest, __const void *__restrict __src,
                      int __c, size_t __n)
     throw ();




extern void *memset (void *__s, int __c, size_t __n) throw ();


extern int memcmp (__const void *__s1, __const void *__s2, size_t __n)
     throw () __attribute__ ((__pure__));


extern void *memchr (__const void *__s, int __c, size_t __n)
      throw () __attribute__ ((__pure__));




extern void *rawmemchr (__const void *__s, int __c) throw () __attribute__ ((__pure__));


extern void *memrchr (__const void *__s, int __c, size_t __n)
      throw () __attribute__ ((__pure__));




extern char *strcpy (char *__restrict __dest, __const char *__restrict __src)
     throw ();

extern char *strncpy (char *__restrict __dest,
                      __const char *__restrict __src, size_t __n) throw ();

extern size_t strlcpy (char *__restrict __dest,
                      __const char *__restrict __src, size_t __n) throw ();


extern char *strcat (char *__restrict __dest, __const char *__restrict __src)
     throw ();

extern char *strncat (char *__restrict __dest, __const char *__restrict __src,
                      size_t __n) throw ();

extern size_t strlcat (char *__restrict __dest, __const char *__restrict __src,
                      size_t __n) throw ();


extern int strcmp (__const char *__s1, __const char *__s2)
     throw () __attribute__ ((__pure__));

extern int strncmp (__const char *__s1, __const char *__s2, size_t __n)
     throw () __attribute__ ((__pure__));


extern int strcoll (__const char *__s1, __const char *__s2)
     throw () __attribute__ ((__pure__));

extern size_t strxfrm (char *__restrict __dest,
                       __const char *__restrict __src, size_t __n) throw ();





# 1 "/usr/lib/gcc/../../i686-inX-linux/include/xlocale.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/xlocale.h" 3
typedef struct __locale_struct
{

  struct locale_data *__locales[13];


  const unsigned short int *__ctype_b;
  const int *__ctype_tolower;
  const int *__ctype_toupper;
} *__locale_t;
# 115 "/usr/lib/gcc/../../i686-inX-linux/include/string.h" 2 3


extern int __strcoll_l (__const char *__s1, __const char *__s2, __locale_t __l)
     throw () __attribute__ ((__pure__));

extern size_t __strxfrm_l (char *__dest, __const char *__src, size_t __n,
                           __locale_t __l) throw ();




extern char *strdup (__const char *__s) throw () __attribute__ ((__malloc__));






extern char *strndup (__const char *__string, size_t __n)
     throw () __attribute__ ((__malloc__));
# 161 "/usr/lib/gcc/../../i686-inX-linux/include/string.h" 3
extern char *strchr (__const char *__s, int __c) throw () __attribute__ ((__pure__));

extern char *strrchr (__const char *__s, int __c) throw () __attribute__ ((__pure__));




extern char *strchrnul (__const char *__s, int __c) throw () __attribute__ ((__pure__));




extern size_t strcspn (__const char *__s, __const char *__reject)
     throw () __attribute__ ((__pure__));


extern size_t strspn (__const char *__s, __const char *__accept)
     throw () __attribute__ ((__pure__));

extern char *strpbrk (__const char *__s, __const char *__accept)
     throw () __attribute__ ((__pure__));

extern char *strstr (__const char *__haystack, __const char *__needle)
     throw () __attribute__ ((__pure__));



extern char *strcasestr (__const char *__haystack, __const char *__needle)
     throw () __attribute__ ((__pure__));



extern char *strtok (char *__restrict __s, __const char *__restrict __delim)
     throw ();



extern char *__strtok_r (char *__restrict __s,
                         __const char *__restrict __delim,
                         char **__restrict __save_ptr) throw ();

extern char *strtok_r (char *__restrict __s, __const char *__restrict __delim,
                       char **__restrict __save_ptr) throw ();






extern void *memmem (__const void *__haystack, size_t __haystacklen,
                     __const void *__needle, size_t __needlelen)
     throw () __attribute__ ((__pure__));



extern void *__mempcpy (void *__restrict __dest,
                        __const void *__restrict __src, size_t __n) throw ();
extern void *mempcpy (void *__restrict __dest,
                      __const void *__restrict __src, size_t __n) throw ();




extern size_t strlen (__const char *__s) throw () __attribute__ ((__pure__));




extern size_t strnlen (__const char *__string, size_t __maxlen)
     throw () __attribute__ ((__pure__));




extern char *strerror (int __errnum) throw ();



extern char *strerror_r (int __errnum, char *__buf, size_t __buflen) throw ();




extern void __bzero (void *__s, size_t __n) throw ();



extern void bcopy (__const void *__src, void *__dest, size_t __n) throw ();


extern void bzero (void *__s, size_t __n) throw ();


extern int bcmp (__const void *__s1, __const void *__s2, size_t __n)
     throw () __attribute__ ((__pure__));


extern char *index (__const char *__s, int __c) throw () __attribute__ ((__pure__));


extern char *rindex (__const char *__s, int __c) throw () __attribute__ ((__pure__));



extern int ffs (int __i) throw () __attribute__ ((__const__));




extern int ffsl (long int __l) throw () __attribute__ ((__const__));

__extension__ extern int ffsll (long long int __ll)
     throw () __attribute__ ((__const__));




extern int strcasecmp (__const char *__s1, __const char *__s2)
     throw () __attribute__ ((__pure__));


extern int strncasecmp (__const char *__s1, __const char *__s2, size_t __n)
     throw () __attribute__ ((__pure__));





extern int __strcasecmp_l (__const char *__s1, __const char *__s2,
                           __locale_t __loc) throw () __attribute__ ((__pure__));

extern int __strncasecmp_l (__const char *__s1, __const char *__s2,
                            size_t __n, __locale_t __loc)
     throw () __attribute__ ((__pure__));





extern char *strsep (char **__restrict __stringp,
                     __const char *__restrict __delim) throw ();




extern int strverscmp (__const char *__s1, __const char *__s2)
     throw () __attribute__ ((__pure__));


extern char *strsignal (int __sig) throw ();


extern char *__stpcpy (char *__restrict __dest, __const char *__restrict __src)
     throw ();
extern char *stpcpy (char *__restrict __dest, __const char *__restrict __src)
     throw ();



extern char *__stpncpy (char *__restrict __dest,
                        __const char *__restrict __src, size_t __n) throw ();
extern char *stpncpy (char *__restrict __dest,
                      __const char *__restrict __src, size_t __n) throw ();


extern char *strfry (char *__string) throw ();


extern void *memfrob (void *__s, size_t __n) throw ();






extern char *basename (__const char *__filename) throw ();
# 370 "/usr/lib/gcc/../../i686-inX-linux/include/string.h" 3
}
# 52 "/usr/include/c++3.1/cstring" 2 3
# 77 "/usr/include/c++3.1/cstring" 3
namespace std
{
  using ::memcpy;
  using ::memmove;
  using ::strcpy;
  using ::strncpy;
  using ::strcat;
  using ::strncat;
  using ::memcmp;
  using ::strcmp;
  using ::strcoll;
  using ::strncmp;
  using ::strxfrm;
  using ::strcspn;
  using ::strspn;
  using ::strtok;
  using ::memset;
  using ::strerror;
  using ::strlen;

  using ::memchr;

  inline void*
  memchr(void* __p, int __c, size_t __n)
  { return memchr(const_cast<const void*>(__p), __c, __n); }

  using ::strchr;

  inline char*
  strchr(char* __s1, int __n)
  { return __builtin_strchr(const_cast<const char*>(__s1), __n); }

  using ::strpbrk;

  inline char*
  strpbrk(char* __s1, const char* __s2)
  { return __builtin_strpbrk(const_cast<const char*>(__s1), __s2); }

  using ::strrchr;

  inline char*
  strrchr(char* __s1, int __n)
  { return __builtin_strrchr(const_cast<const char*>(__s1), __n); }

  using ::strstr;

  inline char*
  strstr(char* __s1, const char* __s2)
  { return __builtin_strstr(const_cast<const char*>(__s1), __s2); }
}
# 131 "../array/inX.h" 2
# 141 "../array/inX.h"
inline int
strsame(const char *str1, const char *str2) {
        return strcmp(str1, str2) == Success;
}

inline int
strnsame(const char *str1, const char *str2, const size_t bytes) {
        return strncmp(str1, str2, bytes) == Success;
}

inline char *
safe_strcpy(char *buffer,
                                const char *string, const size_t buffer_bytes
                          ) {
        strlcpy(buffer, string, buffer_bytes);

        return buffer;
}

inline char *
safe_strcat(char *buffer,
                                const char *string, const size_t buffer_bytes
                          ) {
        strlcat(buffer, string, buffer_bytes);

        return buffer;
}



# 1 "../array/inXdebug.h" 1



#ident "@(#)$Id: inXdebug.h 1.1 Wed, 05 Apr 2000 07:55:06 -0700 tmwg $ -- Copyright (c) 1997-2000 inX Services"
# 26 "../array/inXdebug.h"
                extern uint inX_Verbose;
# 172 "../array/inX.h" 2
# 12 "../inXDB/DB/TypeGen.cc" 2
# 1 "/usr/include/c++3.1/cstdio" 1 3
# 48 "/usr/include/c++3.1/cstdio" 3

# 1 "/usr/include/c++3.1/i686-inX-linux/bits/c++config.h" 1 3
# 34 "/usr/include/c++3.1/i686-inX-linux/bits/c++config.h" 3
# 1 "/usr/include/c++3.1/i686-inX-linux/bits/os_defines.h" 1 3
# 35 "/usr/include/c++3.1/i686-inX-linux/bits/c++config.h" 2 3
# 50 "/usr/include/c++3.1/cstdio" 2 3


# 1 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 1 3
# 30 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern "C" {



# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 35 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 2 3
# 45 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
typedef struct _IO_FILE FILE;
# 55 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
typedef struct _IO_FILE __FILE;
# 65 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 1 3
# 32 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 1 3
# 14 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 321 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 3
typedef unsigned int wint_t;
# 15 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 2 3
# 24 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 1 3
# 48 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 49 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 2 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/wchar.h" 1 3
# 51 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 2 3
# 67 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
typedef struct
{
  int __count;
  union
  {
    wint_t __wch;
    char __wchb[4];
  } __value;
} __mbstate_t;
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 2 3

typedef struct
{
  __off_t __pos;
  __mbstate_t __state;
} _G_fpos_t;
typedef struct
{
  __off64_t __pos;
  __mbstate_t __state;
} _G_fpos64_t;
# 44 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/gconv.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/gconv.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 1 3
# 48 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 49 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 2 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/gconv.h" 2 3


# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 32 "/usr/lib/gcc/../../i686-inX-linux/include/gconv.h" 2 3





enum
{
  __GCONV_OK = 0,
  __GCONV_NOCONV,
  __GCONV_NODB,
  __GCONV_NOMEM,

  __GCONV_EMPTY_INPUT,
  __GCONV_FULL_OUTPUT,
  __GCONV_ILLEGAL_INPUT,
  __GCONV_INCOMPLETE_INPUT,

  __GCONV_ILLEGAL_DESCRIPTOR,
  __GCONV_INTERNAL_ERROR
};



enum
{
  __GCONV_IS_LAST = 0x0001,
  __GCONV_IGNORE_ERRORS = 0x0002
};



struct __gconv_step;
struct __gconv_step_data;
struct __gconv_loaded_object;
struct __gconv_trans_data;



typedef int (*__gconv_fct) (struct __gconv_step *, struct __gconv_step_data *,
                            __const unsigned char **, __const unsigned char *,
                            unsigned char **, size_t *, int, int);


typedef int (*__gconv_init_fct) (struct __gconv_step *);
typedef void (*__gconv_end_fct) (struct __gconv_step *);



typedef int (*__gconv_trans_fct) (struct __gconv_step *,
                                  struct __gconv_step_data *, void *,
                                  __const unsigned char *,
                                  __const unsigned char **,
                                  __const unsigned char *, unsigned char **,
                                  size_t *);


typedef int (*__gconv_trans_context_fct) (void *, __const unsigned char *,
                                          __const unsigned char *,
                                          unsigned char *, unsigned char *);


typedef int (*__gconv_trans_query_fct) (__const char *, __const char ***,
                                        size_t *);


typedef int (*__gconv_trans_init_fct) (void **, const char *);
typedef void (*__gconv_trans_end_fct) (void *);

struct __gconv_trans_data
{

  __gconv_trans_fct __trans_fct;
  __gconv_trans_context_fct __trans_context_fct;
  __gconv_trans_end_fct __trans_end_fct;
  void *__data;
  struct __gconv_trans_data *__next;
};



struct __gconv_step
{
  struct __gconv_loaded_object *__shlib_handle;
  __const char *__modname;

  int __counter;

  char *__from_name;
  char *__to_name;

  __gconv_fct __fct;
  __gconv_init_fct __init_fct;
  __gconv_end_fct __end_fct;



  int __min_needed_from;
  int __max_needed_from;
  int __min_needed_to;
  int __max_needed_to;


  int __stateful;

  void *__data;
};



struct __gconv_step_data
{
  unsigned char *__outbuf;
  unsigned char *__outbufend;



  int __flags;



  int __invocation_counter;



  int __internal_use;

  __mbstate_t *__statep;
  __mbstate_t __state;



  struct __gconv_trans_data *__trans;
};



typedef struct __gconv_info
{
  size_t __nsteps;
  struct __gconv_step *__steps;
  __extension__ struct __gconv_step_data __data [];
} *__gconv_t;
# 45 "/usr/lib/gcc/../../i686-inX-linux/include/_G_config.h" 2 3
typedef union
{
  struct __gconv_info __cd;
  struct
  {
    struct __gconv_info __cd;
    struct __gconv_step_data __data;
  } __combined;
} _G_iconv_t;

typedef int _G_int16_t __attribute__ ((__mode__ (__HI__)));
typedef int _G_int32_t __attribute__ ((__mode__ (__SI__)));
typedef unsigned int _G_uint16_t __attribute__ ((__mode__ (__HI__)));
typedef unsigned int _G_uint32_t __attribute__ ((__mode__ (__SI__)));
# 33 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 2 3
# 53 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stdarg.h" 1 3
# 43 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stdarg.h" 3
typedef __builtin_va_list __gnuc_va_list;
# 54 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 2 3
# 160 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
struct _IO_jump_t; struct _IO_FILE;
# 170 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
typedef void _IO_lock_t;





struct _IO_marker {
  struct _IO_marker *_next;
  struct _IO_FILE *_sbuf;



  int _pos;
# 193 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
};


enum __codecvt_result
{
  __codecvt_ok,
  __codecvt_partial,
  __codecvt_error,
  __codecvt_noconv
};
# 261 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
struct _IO_FILE {
  int _flags;




  char* _IO_read_ptr;
  char* _IO_read_end;
  char* _IO_read_base;
  char* _IO_write_base;
  char* _IO_write_ptr;
  char* _IO_write_end;
  char* _IO_buf_base;
  char* _IO_buf_end;

  char *_IO_save_base;
  char *_IO_backup_base;
  char *_IO_save_end;

  struct _IO_marker *_markers;

  struct _IO_FILE *_chain;

  int _fileno;
  int _blksize;
  __off_t _old_offset;



  unsigned short _cur_column;
  signed char _vtable_offset;
  char _shortbuf[1];



  _IO_lock_t *_lock;
# 305 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
  __off64_t _offset;





  void *__pad1;
  void *__pad2;

  int _mode;

  char _unused2[15 * sizeof (int) - 2 * sizeof (void *)];

};





struct _IO_FILE_plus;

extern struct _IO_FILE_plus _IO_2_1_stdin_;
extern struct _IO_FILE_plus _IO_2_1_stdout_;
extern struct _IO_FILE_plus _IO_2_1_stderr_;
# 344 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
typedef __ssize_t __io_read_fn (void *__cookie, char *__buf, size_t __nbytes);







typedef __ssize_t __io_write_fn (void *__cookie, __const char *__buf,
                                 size_t __n);







typedef int __io_seek_fn (void *__cookie, __off64_t *__pos, int __w);


typedef int __io_close_fn (void *__cookie);




typedef __io_read_fn cookie_read_function_t;
typedef __io_write_fn cookie_write_function_t;
typedef __io_seek_fn cookie_seek_function_t;
typedef __io_close_fn cookie_close_function_t;


typedef struct
{
  __io_read_fn *read;
  __io_write_fn *write;
  __io_seek_fn *seek;
  __io_close_fn *close;
} _IO_cookie_io_functions_t;
typedef _IO_cookie_io_functions_t cookie_io_functions_t;

struct _IO_cookie_file;


extern void _IO_cookie_init (struct _IO_cookie_file *__cfile, int __read_write,
                             void *__cookie, _IO_cookie_io_functions_t __fns);




extern "C" {


extern int __underflow (_IO_FILE *) throw ();
extern int __uflow (_IO_FILE *) throw ();
extern int __overflow (_IO_FILE *, int) throw ();
extern wint_t __wunderflow (_IO_FILE *) throw ();
extern wint_t __wuflow (_IO_FILE *) throw ();
extern wint_t __woverflow (_IO_FILE *, wint_t) throw ();
# 426 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
extern int _IO_getc (_IO_FILE *__fp) throw ();
extern int _IO_putc (int __c, _IO_FILE *__fp) throw ();
extern int _IO_feof (_IO_FILE *__fp) throw ();
extern int _IO_ferror (_IO_FILE *__fp) throw ();

extern int _IO_peekc_locked (_IO_FILE *__fp) throw ();





extern void _IO_flockfile (_IO_FILE *) throw ();
extern void _IO_funlockfile (_IO_FILE *) throw ();
extern int _IO_ftrylockfile (_IO_FILE *) throw ();
# 456 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
extern int _IO_vfscanf (_IO_FILE * __restrict, const char * __restrict,
                        __gnuc_va_list, int *__restrict) throw ();
extern int _IO_vfprintf (_IO_FILE *__restrict, const char *__restrict,
                         __gnuc_va_list) throw ();
extern __ssize_t _IO_padn (_IO_FILE *, int, __ssize_t) throw ();
extern size_t _IO_sgetn (_IO_FILE *, void *, size_t) throw ();

extern __off64_t _IO_seekoff (_IO_FILE *, __off64_t, int, int) throw ();
extern __off64_t _IO_seekpos (_IO_FILE *, __off64_t, int) throw ();

extern void _IO_free_backup_area (_IO_FILE *) throw ();
# 514 "/usr/lib/gcc/../../i686-inX-linux/include/libio.h" 3
}
# 66 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 2 3




typedef __gnuc_va_list va_list;
# 80 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
typedef _G_fpos_t fpos_t;




typedef _G_fpos64_t fpos64_t;
# 129 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/stdio_lim.h" 1 3
# 130 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 2 3



extern FILE *stdin;
extern FILE *stdout;
extern FILE *stderr;






extern int remove (__const char *__filename) throw ();

extern int rename (__const char *__old, __const char *__new) throw ();




extern FILE *tmpfile (void) throw ();
# 158 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern FILE *tmpfile64 (void) throw ();


extern char *tmpnam (char *__s) throw ();




extern char *tmpnam_r (char *__s) throw ();
# 178 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern char *tempnam (__const char *__dir, __const char *__pfx)
     throw () __attribute__ ((__malloc__));




extern int fclose (FILE *__stream) throw ();

extern int fflush (FILE *__stream) throw ();



extern int fflush_unlocked (FILE *__stream) throw ();




extern int fcloseall (void) throw ();





extern FILE *fopen (__const char *__restrict __filename,
                    __const char *__restrict __modes) throw ();

extern FILE *freopen (__const char *__restrict __filename,
                      __const char *__restrict __modes,
                      FILE *__restrict __stream) throw ();
# 222 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern FILE *fopen64 (__const char *__restrict __filename,
                      __const char *__restrict __modes) throw ();
extern FILE *freopen64 (__const char *__restrict __filename,
                        __const char *__restrict __modes,
                        FILE *__restrict __stream) throw ();




extern FILE *fdopen (int __fd, __const char *__modes) throw ();





extern FILE *fopencookie (void *__restrict __magic_cookie,
                          __const char *__restrict __modes,
                          _IO_cookie_io_functions_t __io_funcs) throw ();


extern FILE *fmemopen (void *__s, size_t __len, __const char *__modes) throw ();




extern FILE *open_memstream (char **__restrict __bufloc,
                             size_t *__restrict __sizeloc) throw ();





extern void setbuf (FILE *__restrict __stream, char *__restrict __buf) throw ();



extern int setvbuf (FILE *__restrict __stream, char *__restrict __buf,
                    int __modes, size_t __n) throw ();




extern void setbuffer (FILE *__restrict __stream, char *__restrict __buf,
                       size_t __size) throw ();


extern void setlinebuf (FILE *__stream) throw ();




extern int fprintf (FILE *__restrict __stream,
                    __const char *__restrict __format, ...) throw ();

extern int printf (__const char *__restrict __format, ...) throw ();

extern int sprintf (char *__restrict __s,
                    __const char *__restrict __format, ...) throw ();


extern int vfprintf (FILE *__restrict __s, __const char *__restrict __format,
                     __gnuc_va_list __arg) throw ();

extern int vprintf (__const char *__restrict __format, __gnuc_va_list __arg)
     throw ();

extern int vsprintf (char *__restrict __s, __const char *__restrict __format,
                     __gnuc_va_list __arg) throw ();



extern int snprintf (char *__restrict __s, size_t __maxlen,
                     __const char *__restrict __format, ...)
     throw () __attribute__ ((__format__ (__printf__, 3, 4)));

extern int vsnprintf (char *__restrict __s, size_t __maxlen,
                      __const char *__restrict __format, __gnuc_va_list __arg)
     throw () __attribute__ ((__format__ (__printf__, 3, 0)));





extern int vasprintf (char **__restrict __ptr, __const char *__restrict __f,
                      __gnuc_va_list __arg)
     throw () __attribute__ ((__format__ (__printf__, 2, 0)));
extern int __asprintf (char **__restrict __ptr,
                       __const char *__restrict __fmt, ...)
     throw () __attribute__ ((__format__ (__printf__, 2, 3)));
extern int asprintf (char **__restrict __ptr,
                     __const char *__restrict __fmt, ...)
     throw () __attribute__ ((__format__ (__printf__, 2, 3)));


extern int vdprintf (int __fd, __const char *__restrict __fmt,
                     __gnuc_va_list __arg)
     throw () __attribute__ ((__format__ (__printf__, 2, 0)));
extern int dprintf (int __fd, __const char *__restrict __fmt, ...)
     throw () __attribute__ ((__format__ (__printf__, 2, 3)));




extern int fscanf (FILE *__restrict __stream,
                   __const char *__restrict __format, ...) throw ();

extern int scanf (__const char *__restrict __format, ...) throw ();

extern int sscanf (__const char *__restrict __s,
                   __const char *__restrict __format, ...) throw ();



extern int vfscanf (FILE *__restrict __s, __const char *__restrict __format,
                    __gnuc_va_list __arg)
     throw () __attribute__ ((__format__ (__scanf__, 2, 0)));


extern int vscanf (__const char *__restrict __format, __gnuc_va_list __arg)
     throw () __attribute__ ((__format__ (__scanf__, 1, 0)));


extern int vsscanf (__const char *__restrict __s,
                    __const char *__restrict __format, __gnuc_va_list __arg)
     throw () __attribute__ ((__format__ (__scanf__, 2, 0)));




extern int fgetc (FILE *__stream) throw ();
extern int getc (FILE *__stream) throw ();


extern int getchar (void) throw ();
# 365 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern int getc_unlocked (FILE *__stream) throw ();
extern int getchar_unlocked (void) throw ();




extern int fgetc_unlocked (FILE *__stream) throw ();




extern int fputc (int __c, FILE *__stream) throw ();
extern int putc (int __c, FILE *__stream) throw ();


extern int putchar (int __c) throw ();
# 390 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern int fputc_unlocked (int __c, FILE *__stream) throw ();




extern int putc_unlocked (int __c, FILE *__stream) throw ();
extern int putchar_unlocked (int __c) throw ();





extern int getw (FILE *__stream) throw ();


extern int putw (int __w, FILE *__stream) throw ();




extern char *fgets (char *__restrict __s, int __n, FILE *__restrict __stream)
     throw ();



extern char *fgets_unlocked (char *__restrict __s, int __n,
                             FILE *__restrict __stream) throw ();




extern char *gets (char *__s) throw ();
# 430 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern __ssize_t __getdelim (char **__restrict __lineptr,
                               size_t *__restrict __n, int __delimiter,
                               FILE *__restrict __stream) throw ();
extern __ssize_t getdelim (char **__restrict __lineptr,
                             size_t *__restrict __n, int __delimiter,
                             FILE *__restrict __stream) throw ();


extern __ssize_t getline (char **__restrict __lineptr,
                            size_t *__restrict __n,
                            FILE *__restrict __stream) throw ();




extern int fputs (__const char *__restrict __s, FILE *__restrict __stream)
     throw ();



extern int fputs_unlocked (__const char *__restrict __s,
                           FILE *__restrict __stream) throw ();



extern int puts (__const char *__s) throw ();



extern int ungetc (int __c, FILE *__stream) throw ();



extern size_t fread (void *__restrict __ptr, size_t __size,
                     size_t __n, FILE *__restrict __stream) throw ();

extern size_t fwrite (__const void *__restrict __ptr, size_t __size,
                      size_t __n, FILE *__restrict __s) throw ();



extern size_t fread_unlocked (void *__restrict __ptr, size_t __size,
                              size_t __n, FILE *__restrict __stream) throw ();
extern size_t fwrite_unlocked (__const void *__restrict __ptr, size_t __size,
                               size_t __n, FILE *__restrict __stream) throw ();




extern int fseek (FILE *__stream, long int __off, int __whence) throw ();

extern long int ftell (FILE *__stream) throw ();

extern void rewind (FILE *__stream) throw ();
# 493 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern int fseeko (FILE *__stream, __off_t __off, int __whence) throw ();

extern __off_t ftello (FILE *__stream) throw ();



extern int fgetpos (FILE *__restrict __stream, fpos_t *__restrict __pos)
     throw ();

extern int fsetpos (FILE *__stream, __const fpos_t *__pos) throw ();
# 527 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
extern int fseeko64 (FILE *__stream, __off64_t __off, int __whence) throw ();
extern __off64_t ftello64 (FILE *__stream) throw ();
extern int fgetpos64 (FILE *__restrict __stream, fpos64_t *__restrict __pos)
     throw ();
extern int fsetpos64 (FILE *__stream, __const fpos64_t *__pos) throw ();



extern void clearerr (FILE *__stream) throw ();

extern int feof (FILE *__stream) throw ();

extern int ferror (FILE *__stream) throw ();



extern void clearerr_unlocked (FILE *__stream) throw ();
extern int feof_unlocked (FILE *__stream) throw ();
extern int ferror_unlocked (FILE *__stream) throw ();




extern void perror (__const char *__s) throw ();




extern int sys_nerr;
extern __const char *__const sys_errlist[];


extern int _sys_nerr;
extern __const char *__const _sys_errlist[];





extern int fileno (FILE *__stream) throw ();




extern int fileno_unlocked (FILE *__stream) throw ();






extern FILE *popen (__const char *__command, __const char *__modes) throw ();


extern int pclose (FILE *__stream) throw ();





extern char *ctermid (char *__s) throw ();





extern char *cuserid (char *__s) throw ();




struct obstack;


extern int obstack_printf (struct obstack *__restrict __obstack,
                           __const char *__restrict __format, ...) throw ();
extern int obstack_vprintf (struct obstack *__restrict __obstack,
                            __const char *__restrict __format,
                            __gnuc_va_list __args) throw ();







extern void flockfile (FILE *__stream) throw ();



extern int ftrylockfile (FILE *__stream) throw ();


extern void funlockfile (FILE *__stream) throw ();
# 644 "/usr/lib/gcc/../../i686-inX-linux/include/stdio.h" 3
inline int
fflush (FILE *__stream) throw () {
        return fflush_unlocked(__stream);
}



inline int
getc(FILE *__stream) throw () {



        return getc_unlocked(__stream);

}
inline int
getchar(void) throw () {



        return getchar_unlocked();

}


inline int
fgetc(FILE *__stream) throw () {
        return fgetc_unlocked(__stream);
}
inline int
fputc(int __c, FILE *__stream) throw () {



        return fputc_unlocked(__c, __stream);

}


inline int
putc(int __c, FILE *__stream) throw () {



        return putc_unlocked(__c, __stream);

}
inline int
putchar(int __c) throw () {



        return putchar_unlocked(__c);

}


inline char *
fgets(char *__restrict __s, int __n, FILE *__restrict __stream) throw () {
        return fgets_unlocked(__s, __n, __stream);
}
inline int
fputs(__const char *__restrict __s, FILE *__restrict __stream) throw () {
        return fputs_unlocked(__s, __stream);
}






inline void
clearerr(FILE *__stream) throw () {
        clearerr_unlocked(__stream);
}
inline int
feof(FILE *__stream) throw () {



        return feof_unlocked(__stream);

}
inline int
ferror(FILE *__stream) throw () {



        return ferror_unlocked(__stream);

}
inline int
fileno(FILE *__stream) throw () {
        return fileno_unlocked(__stream);
}




}
# 53 "/usr/include/c++3.1/cstdio" 2 3
# 97 "/usr/include/c++3.1/cstdio" 3
namespace std
{
  using ::FILE;
  using ::fpos_t;

  using ::clearerr;
  using ::fclose;
  using ::feof;
  using ::ferror;
  using ::fflush;
  using ::fgetc;
  using ::fgetpos;
  using ::fgets;
  using ::fopen;
  using ::fprintf;
  using ::fputc;
  using ::fputs;
  using ::fread;
  using ::freopen;
  using ::fscanf;
  using ::fseek;
  using ::fsetpos;
  using ::ftell;
  using ::fwrite;
  using ::getc;
  using ::getchar;
  using ::gets;
  using ::perror;
  using ::printf;
  using ::putc;
  using ::putchar;
  using ::puts;
  using ::remove;
  using ::rename;
  using ::rewind;
  using ::scanf;
  using ::setbuf;
  using ::setvbuf;
  using ::sprintf;
  using ::sscanf;
  using ::tmpfile;
  using ::tmpnam;
  using ::ungetc;
  using ::vfprintf;
  using ::vprintf;
  using ::vsprintf;
}
# 153 "/usr/include/c++3.1/cstdio" 3
namespace __gnu_cxx
{
  using ::snprintf;
  using ::vfscanf;
  using ::vscanf;
  using ::vsnprintf;
  using ::vsscanf;
}

namespace std
{
  using __gnu_cxx::snprintf;
  using __gnu_cxx::vfscanf;
  using __gnu_cxx::vscanf;
  using __gnu_cxx::vsnprintf;
  using __gnu_cxx::vsscanf;
}
# 13 "../inXDB/DB/TypeGen.cc" 2
# 1 "/usr/include/c++3.1/cctype" 1 3
# 47 "/usr/include/c++3.1/cctype" 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 1 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 3
extern "C" {
# 47 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 3
enum
{
  _ISupper = ((0) < 8 ? ((1 << (0)) << 8) : ((1 << (0)) >> 8)),
  _ISlower = ((1) < 8 ? ((1 << (1)) << 8) : ((1 << (1)) >> 8)),
  _ISalpha = ((2) < 8 ? ((1 << (2)) << 8) : ((1 << (2)) >> 8)),
  _ISdigit = ((3) < 8 ? ((1 << (3)) << 8) : ((1 << (3)) >> 8)),
  _ISxdigit = ((4) < 8 ? ((1 << (4)) << 8) : ((1 << (4)) >> 8)),
  _ISspace = ((5) < 8 ? ((1 << (5)) << 8) : ((1 << (5)) >> 8)),
  _ISprint = ((6) < 8 ? ((1 << (6)) << 8) : ((1 << (6)) >> 8)),
  _ISgraph = ((7) < 8 ? ((1 << (7)) << 8) : ((1 << (7)) >> 8)),
  _ISblank = ((8) < 8 ? ((1 << (8)) << 8) : ((1 << (8)) >> 8)),
  _IScntrl = ((9) < 8 ? ((1 << (9)) << 8) : ((1 << (9)) >> 8)),
  _ISpunct = ((10) < 8 ? ((1 << (10)) << 8) : ((1 << (10)) >> 8)),
  _ISalnum = ((11) < 8 ? ((1 << (11)) << 8) : ((1 << (11)) >> 8))
};
# 75 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 3
extern __const unsigned short int *__ctype_b;
extern __const __int32_t *__ctype_tolower;
extern __const __int32_t *__ctype_toupper;
# 91 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 3
extern int isalnum (int) throw ();
extern int isalpha (int) throw ();
extern int iscntrl (int) throw ();
extern int isdigit (int) throw ();
extern int islower (int) throw ();
extern int isgraph (int) throw ();
extern int isprint (int) throw ();
extern int ispunct (int) throw ();
extern int isspace (int) throw ();
extern int isupper (int) throw ();
extern int isxdigit (int) throw ();


extern int isblank (int) throw ();




extern int tolower (int __c) throw ();


extern int toupper (int __c) throw ();






extern int isascii (int __c) throw ();



extern int toascii (int __c) throw ();



extern int _toupper (int) throw ();
extern int _tolower (int) throw ();
# 223 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 3
extern int __isalnum_l (int, __locale_t) throw ();
extern int __isalpha_l (int, __locale_t) throw ();
extern int __iscntrl_l (int, __locale_t) throw ();
extern int __isdigit_l (int, __locale_t) throw ();
extern int __islower_l (int, __locale_t) throw ();
extern int __isgraph_l (int, __locale_t) throw ();
extern int __isprint_l (int, __locale_t) throw ();
extern int __ispunct_l (int, __locale_t) throw ();
extern int __isspace_l (int, __locale_t) throw ();
extern int __isupper_l (int, __locale_t) throw ();
extern int __isxdigit_l (int, __locale_t) throw ();

extern int __isblank_l (int, __locale_t) throw ();



extern int __tolower_l (int __c, __locale_t __l) throw ();


extern int __toupper_l (int __c, __locale_t __l) throw ();
# 276 "/usr/lib/gcc/../../i686-inX-linux/include/ctype.h" 3
}
# 49 "/usr/include/c++3.1/cctype" 2 3
# 65 "/usr/include/c++3.1/cctype" 3
namespace std
{
  using ::isalnum;
  using ::isalpha;
  using ::iscntrl;
  using ::isdigit;
  using ::isgraph;
  using ::islower;
  using ::isprint;
  using ::ispunct;
  using ::isspace;
  using ::isupper;
  using ::isxdigit;
  using ::tolower;
  using ::toupper;
}
# 14 "../inXDB/DB/TypeGen.cc" 2

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/alloca.h" 1 3
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/alloca.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/alloca.h" 2 3

extern "C" {





extern void *alloca (size_t __size) throw ();





}
# 16 "../inXDB/DB/TypeGen.cc" 2

# 1 "/usr/include/c++3.1/algorithm" 1 3
# 65 "/usr/include/c++3.1/algorithm" 3

# 1 "/usr/include/c++3.1/bits/stl_algobase.h" 1 3
# 66 "/usr/include/c++3.1/bits/stl_algobase.h" 3
# 1 "/usr/include/c++3.1/climits" 1 3
# 48 "/usr/include/c++3.1/climits" 3

# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/limits.h" 1 3
# 11 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/limits.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/syslimits.h" 1 3






# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/limits.h" 1 3
# 132 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/limits.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/limits.h" 1 3
# 144 "/usr/lib/gcc/../../i686-inX-linux/include/limits.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/posix1_lim.h" 1 3
# 126 "/usr/lib/gcc/../../i686-inX-linux/include/bits/posix1_lim.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/local_lim.h" 1 3
# 36 "/usr/lib/gcc/../../i686-inX-linux/include/bits/local_lim.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/linux/limits.h" 1 3
# 37 "/usr/lib/gcc/../../i686-inX-linux/include/bits/local_lim.h" 2 3
# 127 "/usr/lib/gcc/../../i686-inX-linux/include/bits/posix1_lim.h" 2 3
# 145 "/usr/lib/gcc/../../i686-inX-linux/include/limits.h" 2 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/posix2_lim.h" 1 3
# 149 "/usr/lib/gcc/../../i686-inX-linux/include/limits.h" 2 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/xopen_lim.h" 1 3
# 34 "/usr/lib/gcc/../../i686-inX-linux/include/bits/xopen_lim.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/stdio_lim.h" 1 3
# 35 "/usr/lib/gcc/../../i686-inX-linux/include/bits/xopen_lim.h" 2 3
# 136 "/usr/lib/gcc/../../i686-inX-linux/include/bits/xopen_lim.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/wordsize.h" 1 3
# 137 "/usr/lib/gcc/../../i686-inX-linux/include/bits/xopen_lim.h" 2 3
# 153 "/usr/lib/gcc/../../i686-inX-linux/include/limits.h" 2 3
# 133 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/limits.h" 2 3
# 8 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/syslimits.h" 2 3
# 12 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/limits.h" 2 3
# 50 "/usr/include/c++3.1/climits" 2 3
# 67 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/cstdlib" 1 3
# 48 "/usr/include/c++3.1/cstdlib" 3




# 1 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 1 3
# 33 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 34 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 2 3

extern "C" {






# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/waitflags.h" 1 3
# 43 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/waitstatus.h" 1 3
# 65 "/usr/lib/gcc/../../i686-inX-linux/include/bits/waitstatus.h" 3
union wait
  {
    int w_status;
    struct
      {

        unsigned int __w_termsig:7;
        unsigned int __w_coredump:1;
        unsigned int __w_retcode:8;
        unsigned int:16;







      } __wait_terminated;
    struct
      {

        unsigned int __w_stopval:8;
        unsigned int __w_stopsig:8;
        unsigned int:16;






      } __wait_stopped;
  };
# 44 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 2 3
# 94 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
typedef struct
  {
    int quot;
    int rem;
  } div_t;



typedef struct
  {
    long int quot;
    long int rem;
  } ldiv_t;





__extension__ typedef struct
  {
    long long int quot;
    long long int rem;
  } lldiv_t;
# 133 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern size_t __ctype_get_mb_cur_max (void) throw ();



extern double atof (__const char *__nptr) throw () __attribute__ ((__pure__));

extern int atoi (__const char *__nptr) throw () __attribute__ ((__pure__));

extern long int atol (__const char *__nptr) throw () __attribute__ ((__pure__));



__extension__ extern long long int atoll (__const char *__nptr)
     throw () __attribute__ ((__pure__));



extern double strtod (__const char *__restrict __nptr,
                      char **__restrict __endptr) throw ();



extern float strtof (__const char *__restrict __nptr,
                     char **__restrict __endptr) throw ();

extern long double strtold (__const char *__restrict __nptr,
                            char **__restrict __endptr) throw ();



extern long int strtol (__const char *__restrict __nptr,
                        char **__restrict __endptr, int __base) throw ();

extern unsigned long int strtoul (__const char *__restrict __nptr,
                                  char **__restrict __endptr, int __base)
     throw ();



__extension__
extern long long int strtoq (__const char *__restrict __nptr,
                             char **__restrict __endptr, int __base) throw ();

__extension__
extern unsigned long long int strtouq (__const char *__restrict __nptr,
                                       char **__restrict __endptr, int __base)
     throw ();






__extension__
extern long long int strtoll (__const char *__restrict __nptr,
                              char **__restrict __endptr, int __base) throw ();

__extension__
extern unsigned long long int strtoull (__const char *__restrict __nptr,
                                        char **__restrict __endptr, int __base)
     throw ();
# 215 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern long int __strtol_l (__const char *__restrict __nptr,
                            char **__restrict __endptr, int __base,
                            __locale_t __loc) throw ();

extern unsigned long int __strtoul_l (__const char *__restrict __nptr,
                                      char **__restrict __endptr,
                                      int __base, __locale_t __loc) throw ();

__extension__
extern long long int __strtoll_l (__const char *__restrict __nptr,
                                  char **__restrict __endptr, int __base,
                                  __locale_t __loc) throw ();

__extension__
extern unsigned long long int __strtoull_l (__const char *__restrict __nptr,
                                            char **__restrict __endptr,
                                            int __base, __locale_t __loc)
     throw ();

extern double __strtod_l (__const char *__restrict __nptr,
                          char **__restrict __endptr, __locale_t __loc)
     throw ();

extern float __strtof_l (__const char *__restrict __nptr,
                         char **__restrict __endptr, __locale_t __loc) throw ();

extern long double __strtold_l (__const char *__restrict __nptr,
                                char **__restrict __endptr,
                                __locale_t __loc) throw ();






extern double __strtod_internal (__const char *__restrict __nptr,
                                 char **__restrict __endptr, int __group)
     throw ();
extern float __strtof_internal (__const char *__restrict __nptr,
                                char **__restrict __endptr, int __group)
     throw ();
extern long double __strtold_internal (__const char *__restrict __nptr,
                                       char **__restrict __endptr,
                                       int __group) throw ();

extern long int __strtol_internal (__const char *__restrict __nptr,
                                   char **__restrict __endptr,
                                   int __base, int __group) throw ();



extern unsigned long int __strtoul_internal (__const char *__restrict __nptr,
                                             char **__restrict __endptr,
                                             int __base, int __group) throw ();




__extension__
extern long long int __strtoll_internal (__const char *__restrict __nptr,
                                         char **__restrict __endptr,
                                         int __base, int __group) throw ();



__extension__
extern unsigned long long int __strtoull_internal (__const char *
                                                   __restrict __nptr,
                                                   char **__restrict __endptr,
                                                   int __base, int __group)
     throw ();
# 384 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern char *l64a (long int __n) throw ();


extern long int a64l (__const char *__s) throw () __attribute__ ((__pure__));
# 397 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern long int random (void) throw ();


extern void srandom (unsigned int __seed) throw ();





extern char *initstate (unsigned int __seed, char *__statebuf,
                        size_t __statelen) throw ();



extern char *setstate (char *__statebuf) throw ();







struct random_data
  {
    int32_t *fptr;
    int32_t *rptr;
    int32_t *state;
    int rand_type;
    int rand_deg;
    int rand_sep;
    int32_t *end_ptr;
  };

extern int random_r (struct random_data *__restrict __buf,
                     int32_t *__restrict __result) throw ();

extern int srandom_r (unsigned int __seed, struct random_data *__buf) throw ();

extern int initstate_r (unsigned int __seed, char *__restrict __statebuf,
                        size_t __statelen,
                        struct random_data *__restrict __buf) throw ();

extern int setstate_r (char *__restrict __statebuf,
                       struct random_data *__restrict __buf) throw ();





extern int rand (void) throw ();

extern void srand (unsigned int __seed) throw ();



extern int rand_r (unsigned int *__seed) throw ();







extern double drand48 (void) throw ();
extern double erand48 (unsigned short int __xsubi[3]) throw ();


extern long int lrand48 (void) throw ();
extern long int nrand48 (unsigned short int __xsubi[3]) throw ();


extern long int mrand48 (void) throw ();
extern long int jrand48 (unsigned short int __xsubi[3]) throw ();


extern void srand48 (long int __seedval) throw ();
extern unsigned short int *seed48 (unsigned short int __seed16v[3]) throw ();
extern void lcong48 (unsigned short int __param[7]) throw ();





struct drand48_data
  {
    unsigned short int __x[3];
    unsigned short int __old_x[3];
    unsigned short int __c;
    unsigned short int __init;
    unsigned long long int __a;
  };


extern int drand48_r (struct drand48_data *__restrict __buffer,
                      double *__restrict __result) throw ();
extern int erand48_r (unsigned short int __xsubi[3],
                      struct drand48_data *__restrict __buffer,
                      double *__restrict __result) throw ();


extern int lrand48_r (struct drand48_data *__restrict __buffer,
                      long int *__restrict __result) throw ();
extern int nrand48_r (unsigned short int __xsubi[3],
                      struct drand48_data *__restrict __buffer,
                      long int *__restrict __result) throw ();


extern int mrand48_r (struct drand48_data *__restrict __buffer,
                      long int *__restrict __result) throw ();
extern int jrand48_r (unsigned short int __xsubi[3],
                      struct drand48_data *__restrict __buffer,
                      long int *__restrict __result) throw ();


extern int srand48_r (long int __seedval, struct drand48_data *__buffer)
     throw ();

extern int seed48_r (unsigned short int __seed16v[3],
                     struct drand48_data *__buffer) throw ();

extern int lcong48_r (unsigned short int __param[7],
                      struct drand48_data *__buffer) throw ();
# 527 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern void *malloc (size_t __size) throw () __attribute__ ((__malloc__));

extern void *calloc (size_t __nmemb, size_t __size)
     throw () __attribute__ ((__malloc__));





extern void *realloc (void *__ptr, size_t __size) throw () __attribute__ ((__malloc__));

extern void free (void *__ptr) throw ();



extern void cfree (void *__ptr) throw ();
# 551 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern void *valloc (size_t __size) throw () __attribute__ ((__malloc__));




extern int posix_memalign (void **__memptr, size_t __alignment, size_t __size)
     throw () __attribute__ ((__malloc__));



extern void abort (void) throw () __attribute__ ((__noreturn__));



extern int atexit (void (*__func) (void)) throw ();




extern int on_exit (void (*__func) (int __status, void *__arg), void *__arg)
     throw ();





extern void exit (int __status) throw () __attribute__ ((__noreturn__));




extern void _Exit (int __status) throw () __attribute__ ((__noreturn__));




extern char *getenv (__const char *__name) throw ();



extern char *__secure_getenv (__const char *__name) throw ();





extern int putenv (char *__string) throw ();





extern int setenv (__const char *__name, __const char *__value, int __replace)
     throw ();


extern int unsetenv (__const char *__name) throw ();






extern int clearenv (void) throw ();
# 623 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern char *mktemp (char *__template) throw ();







extern int mkstemp (char *__template) throw ();
# 640 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern int mkstemp64 (char *__template) throw ();
# 650 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern char *mkdtemp (char *__template) throw ();




extern int system (__const char *__command) throw ();






extern char *canonicalize_file_name (__const char *__name) throw ();
# 672 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern char *realpath (__const char *__restrict __name,
                       char *__restrict __resolved) throw ();






typedef int (*__compar_fn_t) (__const void *, __const void *);


typedef __compar_fn_t comparison_fn_t;





extern void *bsearch (__const void *__key, __const void *__base,
                      size_t __nmemb, size_t __size, __compar_fn_t __compar);



extern void qsort (void *__base, size_t __nmemb, size_t __size,
                   __compar_fn_t __compar);



extern int abs (int __x) throw () __attribute__ ((__const__));
extern long int labs (long int __x) throw () __attribute__ ((__const__));

__extension__ extern long long int llabs (long long int __x)
     throw () __attribute__ ((__const__));






extern div_t div (int __numer, int __denom)
     throw () __attribute__ ((__const__));
extern ldiv_t ldiv (long int __numer, long int __denom)
     throw () __attribute__ ((__const__));

__extension__ extern lldiv_t lldiv (long long int __numer,
                                    long long int __denom)
     throw () __attribute__ ((__const__));
# 728 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern char *ecvt (double __value, int __ndigit, int *__restrict __decpt,
                   int *__restrict __sign) throw ();




extern char *fcvt (double __value, int __ndigit, int *__restrict __decpt,
                   int *__restrict __sign) throw ();




extern char *gcvt (double __value, int __ndigit, char *__buf) throw ();




extern char *qecvt (long double __value, int __ndigit,
                    int *__restrict __decpt, int *__restrict __sign) throw ();
extern char *qfcvt (long double __value, int __ndigit,
                    int *__restrict __decpt, int *__restrict __sign) throw ();
extern char *qgcvt (long double __value, int __ndigit, char *__buf) throw ();




extern int ecvt_r (double __value, int __ndigit, int *__restrict __decpt,
                   int *__restrict __sign, char *__restrict __buf,
                   size_t __len) throw ();
extern int fcvt_r (double __value, int __ndigit, int *__restrict __decpt,
                   int *__restrict __sign, char *__restrict __buf,
                   size_t __len) throw ();

extern int qecvt_r (long double __value, int __ndigit,
                    int *__restrict __decpt, int *__restrict __sign,
                    char *__restrict __buf, size_t __len) throw ();
extern int qfcvt_r (long double __value, int __ndigit,
                    int *__restrict __decpt, int *__restrict __sign,
                    char *__restrict __buf, size_t __len) throw ();






extern int mblen (__const char *__s, size_t __n) throw ();


extern int mbtowc (wchar_t *__restrict __pwc,
                   __const char *__restrict __s, size_t __n) throw ();


extern int wctomb (char *__s, wchar_t __wchar) throw ();



extern size_t mbstowcs (wchar_t *__restrict __pwcs,
                        __const char *__restrict __s, size_t __n) throw ();

extern size_t wcstombs (char *__restrict __s,
                        __const wchar_t *__restrict __pwcs, size_t __n)
     throw ();







extern int rpmatch (__const char *__response) throw ();
# 808 "/usr/lib/gcc/../../i686-inX-linux/include/stdlib.h" 3
extern int getsubopt (char **__restrict __optionp,
                      char *__const *__restrict __tokens,
                      char **__restrict __valuep) throw ();





extern void setkey (__const char *__key) throw ();







extern int posix_openpt (int __oflag) throw ();







extern int grantpt (int __fd) throw ();



extern int unlockpt (int __fd) throw ();




extern char *ptsname (int __fd) throw ();






extern int ptsname_r (int __fd, char *__buf, size_t __buflen) throw ();


extern int getpt (void) throw ();






extern int getloadavg (double __loadavg[], int __nelem) throw ();





}
# 53 "/usr/include/c++3.1/cstdlib" 2 3
# 84 "/usr/include/c++3.1/cstdlib" 3
namespace std
{
  using ::div_t;
  using ::ldiv_t;

  using ::abort;
  using ::abs;
  using ::atexit;
  using ::atof;
  using ::atoi;
  using ::atol;
  using ::bsearch;
  using ::calloc;
  using ::div;
  using ::exit;
  using ::free;
  using ::getenv;
  using ::labs;
  using ::ldiv;
  using ::malloc;
  using ::mblen;
  using ::mbstowcs;
  using ::mbtowc;
  using ::qsort;
  using ::rand;
  using ::realloc;
  using ::srand;
  using ::strtod;
  using ::strtol;
  using ::strtoul;
  using ::system;
  using ::wcstombs;
  using ::wctomb;

  inline long
  abs(long __i) { return labs(__i); }

  inline ldiv_t
  div(long __i, long __j) { return ldiv(__i, __j); }
}
# 136 "/usr/include/c++3.1/cstdlib" 3
namespace __gnu_cxx
{
  using ::lldiv_t;
  using ::_Exit;

  inline long long
  abs(long long __x) { return __x >= 0 ? __x : -__x; }

  inline long long
  llabs(long long __x) { return __x >= 0 ? __x : -__x; }

  inline lldiv_t
  div(long long __n, long long __d)
  { lldiv_t __q; __q.quot = __n / __d; __q.rem = __n % __d; return __q; }

  inline lldiv_t
  lldiv(long long __n, long long __d)
  { lldiv_t __q; __q.quot = __n / __d; __q.rem = __n % __d; return __q; }

  using ::atoll;
  using ::strtof;
  using ::strtoll;
  using ::strtoull;
  using ::strtold;
}

namespace std
{
  using __gnu_cxx::lldiv_t;
  using __gnu_cxx::_Exit;
  using __gnu_cxx::abs;
  using __gnu_cxx::llabs;
  using __gnu_cxx::div;
  using __gnu_cxx::lldiv;
  using __gnu_cxx::atoll;
  using __gnu_cxx::strtof;
  using __gnu_cxx::strtoll;
  using __gnu_cxx::strtoull;
  using __gnu_cxx::strtold;
}
# 68 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3

# 1 "/usr/include/c++3.1/new" 1 3
# 42 "/usr/include/c++3.1/new" 3
# 1 "/usr/include/c++3.1/exception" 1 3
# 40 "/usr/include/c++3.1/exception" 3
extern "C++" {

namespace std
{






  class exception
  {
  public:
    exception() throw() { }
    virtual ~exception() throw();


    virtual const char* what() const throw();
  };



  class bad_exception : public exception
  {
  public:
    bad_exception() throw() { }


    virtual ~bad_exception() throw();
  };


  typedef void (*terminate_handler) ();

  typedef void (*unexpected_handler) ();


  terminate_handler set_terminate(terminate_handler) throw();


  void terminate() __attribute__ ((__noreturn__));


  unexpected_handler set_unexpected(unexpected_handler) throw();


  void unexpected() __attribute__ ((__noreturn__));
# 98 "/usr/include/c++3.1/exception" 3
  bool uncaught_exception() throw();
}

namespace __gnu_cxx
{
# 111 "/usr/include/c++3.1/exception" 3
  void __verbose_terminate_handler ();
}

}
# 43 "/usr/include/c++3.1/new" 2 3

extern "C++" {

namespace std
{


  class bad_alloc : public exception
  {
  public:
    bad_alloc() throw() { }


    virtual ~bad_alloc() throw();
  };

  struct nothrow_t { };
  extern const nothrow_t nothrow;


  typedef void (*new_handler)();

  new_handler set_new_handler(new_handler);
}
# 79 "/usr/include/c++3.1/new" 3
void* operator new(std::size_t) throw (std::bad_alloc);
void* operator new[](std::size_t) throw (std::bad_alloc);
void operator delete(void*) throw();
void operator delete[](void*) throw();
void* operator new(std::size_t, const std::nothrow_t&) throw();
void* operator new[](std::size_t, const std::nothrow_t&) throw();
void operator delete(void*, const std::nothrow_t&) throw();
void operator delete[](void*, const std::nothrow_t&) throw();


inline void* operator new(std::size_t, void* __p) throw() { return __p; }
inline void* operator new[](std::size_t, void* __p) throw() { return __p; }

}
# 70 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/iosfwd" 1 3
# 43 "/usr/include/c++3.1/iosfwd" 3


# 1 "/usr/include/c++3.1/bits/stringfwd.h" 1 3
# 43 "/usr/include/c++3.1/bits/stringfwd.h" 3



namespace std
{
  template<class _CharT>
    struct char_traits;

  template<> struct char_traits<char>;




  template<typename _Alloc>
    class allocator;

  template<typename _CharT, typename _Traits = char_traits<_CharT>,
           typename _Alloc = allocator<_CharT> >
    class basic_string;

  typedef basic_string<char> string;
  typedef basic_string<wchar_t> wstring;
}
# 46 "/usr/include/c++3.1/iosfwd" 2 3
# 1 "/usr/include/c++3.1/bits/fpos.h" 1 3
# 43 "/usr/include/c++3.1/bits/fpos.h" 3

# 1 "/usr/include/c++3.1/i686-inX-linux/bits/c++io.h" 1 3
# 37 "/usr/include/c++3.1/i686-inX-linux/bits/c++io.h" 3
# 1 "/usr/include/c++3.1/i686-inX-linux/bits/gthr.h" 1 3
# 98 "/usr/include/c++3.1/i686-inX-linux/bits/gthr.h" 3
# 1 "/usr/include/c++3.1/i686-inX-linux/bits/gthr-default.h" 1 3
# 37 "/usr/include/c++3.1/i686-inX-linux/bits/gthr-default.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 1 3
# 20 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sched.h" 1 3
# 32 "/usr/lib/gcc/../../i686-inX-linux/include/sched.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sched.h" 1 3
# 47 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sched.h" 3
struct sched_param
  {
    int __sched_priority;
  };

extern "C" {



extern int clone (int (*__fn) (void *__arg), void *__child_stack,
                  int __flags, void *__arg) throw ();


}
# 33 "/usr/lib/gcc/../../i686-inX-linux/include/sched.h" 2 3




extern "C" {


extern int sched_setparam (__pid_t __pid, __const struct sched_param *__param)
     throw ();


extern int sched_getparam (__pid_t __pid, struct sched_param *__param) throw ();


extern int sched_setscheduler (__pid_t __pid, int __policy,
                               __const struct sched_param *__param) throw ();


extern int sched_getscheduler (__pid_t __pid) throw ();


extern int sched_yield (void) throw ();


extern int sched_get_priority_max (int __algorithm) throw ();


extern int sched_get_priority_min (int __algorithm) throw ();


extern int sched_rr_get_interval (__pid_t __pid, struct timespec *__t) throw ();

}
# 21 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 2 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 1 3
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern "C" {

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigset.h" 1 3
# 34 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3
# 371 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
}
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/pthreadtypes.h" 1 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/initspin.h" 1 3
# 27 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 2 3


extern "C" {
# 59 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
enum
{
  PTHREAD_CREATE_JOINABLE,

  PTHREAD_CREATE_DETACHED

};

enum
{
  PTHREAD_INHERIT_SCHED,

  PTHREAD_EXPLICIT_SCHED

};

enum
{
  PTHREAD_SCOPE_SYSTEM,

  PTHREAD_SCOPE_PROCESS

};

enum
{
  PTHREAD_MUTEX_TIMED_NP,
  PTHREAD_MUTEX_RECURSIVE_NP,
  PTHREAD_MUTEX_ERRORCHECK_NP,
  PTHREAD_MUTEX_ADAPTIVE_NP

  ,
  PTHREAD_MUTEX_NORMAL = PTHREAD_MUTEX_TIMED_NP,
  PTHREAD_MUTEX_RECURSIVE = PTHREAD_MUTEX_RECURSIVE_NP,
  PTHREAD_MUTEX_ERRORCHECK = PTHREAD_MUTEX_ERRORCHECK_NP,
  PTHREAD_MUTEX_DEFAULT = PTHREAD_MUTEX_NORMAL



  , PTHREAD_MUTEX_FAST_NP = PTHREAD_MUTEX_ADAPTIVE_NP

};

enum
{
  PTHREAD_PROCESS_PRIVATE,

  PTHREAD_PROCESS_SHARED

};


enum
{
  PTHREAD_RWLOCK_PREFER_READER_NP,
  PTHREAD_RWLOCK_PREFER_WRITER_NP,
  PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP,
  PTHREAD_RWLOCK_DEFAULT_NP = PTHREAD_RWLOCK_PREFER_WRITER_NP
};
# 131 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
struct _pthread_cleanup_buffer
{
  void (*__routine) (void *);
  void *__arg;
  int __canceltype;
  struct _pthread_cleanup_buffer *__prev;
};



enum
{
  PTHREAD_CANCEL_ENABLE,

  PTHREAD_CANCEL_DISABLE

};
enum
{
  PTHREAD_CANCEL_DEFERRED,

  PTHREAD_CANCEL_ASYNCHRONOUS

};
# 163 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern int pthread_create (pthread_t *__restrict __thread,
                           __const pthread_attr_t *__restrict __attr,
                           void *(*__start_routine) (void *),
                           void *__restrict __arg) throw ();


extern pthread_t pthread_self (void) throw ();


extern int pthread_equal (pthread_t __thread1, pthread_t __thread2) throw ();


extern void pthread_exit (void *__retval)
     throw () __attribute__ ((__noreturn__));




extern int pthread_join (pthread_t __th, void **__thread_return) throw ();





extern int pthread_detach (pthread_t __th) throw ();







extern int pthread_attr_init (pthread_attr_t *__attr) throw ();


extern int pthread_attr_destroy (pthread_attr_t *__attr) throw ();


extern int pthread_attr_setdetachstate (pthread_attr_t *__attr,
                                        int __detachstate) throw ();


extern int pthread_attr_getdetachstate (__const pthread_attr_t *__attr,
                                        int *__detachstate) throw ();


extern int pthread_attr_setschedparam (pthread_attr_t *__restrict __attr,
                                       __const struct sched_param *__restrict
                                       __param) throw ();


extern int pthread_attr_getschedparam (__const pthread_attr_t *__restrict
                                       __attr,
                                       struct sched_param *__restrict __param)
     throw ();


extern int pthread_attr_setschedpolicy (pthread_attr_t *__attr, int __policy)
     throw ();


extern int pthread_attr_getschedpolicy (__const pthread_attr_t *__restrict
                                        __attr, int *__restrict __policy)
     throw ();


extern int pthread_attr_setinheritsched (pthread_attr_t *__attr,
                                         int __inherit) throw ();


extern int pthread_attr_getinheritsched (__const pthread_attr_t *__restrict
                                         __attr, int *__restrict __inherit)
     throw ();


extern int pthread_attr_setscope (pthread_attr_t *__attr, int __scope)
     throw ();


extern int pthread_attr_getscope (__const pthread_attr_t *__restrict __attr,
                                  int *__restrict __scope) throw ();



extern int pthread_attr_setguardsize (pthread_attr_t *__attr,
                                      size_t __guardsize) throw ();


extern int pthread_attr_getguardsize (__const pthread_attr_t *__restrict
                                      __attr, size_t *__restrict __guardsize)
     throw ();






extern int pthread_attr_setstackaddr (pthread_attr_t *__attr,
                                      void *__stackaddr) throw ();


extern int pthread_attr_getstackaddr (__const pthread_attr_t *__restrict
                                      __attr, void **__restrict __stackaddr)
     throw ();





extern int pthread_attr_setstack (pthread_attr_t *__attr, void *__stackaddr,
                                  size_t __stacksize) throw ();


extern int pthread_attr_getstack (__const pthread_attr_t *__restrict __attr,
                                  void **__restrict __stackaddr,
                                  size_t *__restrict __stacksize) throw ();





extern int pthread_attr_setstacksize (pthread_attr_t *__attr,
                                      size_t __stacksize) throw ();


extern int pthread_attr_getstacksize (__const pthread_attr_t *__restrict
                                      __attr, size_t *__restrict __stacksize)
     throw ();



extern int pthread_getattr_np (pthread_t __th, pthread_attr_t *__attr) throw ();






extern int pthread_setschedparam (pthread_t __target_thread, int __policy,
                                  __const struct sched_param *__param)
     throw ();


extern int pthread_getschedparam (pthread_t __target_thread,
                                  int *__restrict __policy,
                                  struct sched_param *__restrict __param)
     throw ();



extern int pthread_getconcurrency (void) throw ();


extern int pthread_setconcurrency (int __level) throw ();







extern int pthread_yield (void) throw ();






extern int pthread_mutex_init (pthread_mutex_t *__restrict __mutex,
                               __const pthread_mutexattr_t *__restrict
                               __mutex_attr) throw ();


extern int pthread_mutex_destroy (pthread_mutex_t *__mutex) throw ();


extern int pthread_mutex_trylock (pthread_mutex_t *__mutex) throw ();


extern int pthread_mutex_lock (pthread_mutex_t *__mutex) throw ();



extern int pthread_mutex_timedlock (pthread_mutex_t *__restrict __mutex,
                                    __const struct timespec *__restrict
                                    __abstime) throw ();



extern int pthread_mutex_unlock (pthread_mutex_t *__mutex) throw ();






extern int pthread_mutexattr_init (pthread_mutexattr_t *__attr) throw ();


extern int pthread_mutexattr_destroy (pthread_mutexattr_t *__attr) throw ();


extern int pthread_mutexattr_getpshared (__const pthread_mutexattr_t *
                                         __restrict __attr,
                                         int *__restrict __pshared) throw ();


extern int pthread_mutexattr_setpshared (pthread_mutexattr_t *__attr,
                                         int __pshared) throw ();





extern int pthread_mutexattr_settype (pthread_mutexattr_t *__attr, int __kind)
     throw ();


extern int pthread_mutexattr_gettype (__const pthread_mutexattr_t *__restrict
                                      __attr, int *__restrict __kind) throw ();







extern int pthread_cond_init (pthread_cond_t *__restrict __cond,
                              __const pthread_condattr_t *__restrict
                              __cond_attr) throw ();


extern int pthread_cond_destroy (pthread_cond_t *__cond) throw ();


extern int pthread_cond_signal (pthread_cond_t *__cond) throw ();


extern int pthread_cond_broadcast (pthread_cond_t *__cond) throw ();



extern int pthread_cond_wait (pthread_cond_t *__restrict __cond,
                              pthread_mutex_t *__restrict __mutex) throw ();





extern int pthread_cond_timedwait (pthread_cond_t *__restrict __cond,
                                   pthread_mutex_t *__restrict __mutex,
                                   __const struct timespec *__restrict
                                   __abstime) throw ();




extern int pthread_condattr_init (pthread_condattr_t *__attr) throw ();


extern int pthread_condattr_destroy (pthread_condattr_t *__attr) throw ();


extern int pthread_condattr_getpshared (__const pthread_condattr_t *
                                        __restrict __attr,
                                        int *__restrict __pshared) throw ();


extern int pthread_condattr_setpshared (pthread_condattr_t *__attr,
                                        int __pshared) throw ();







extern int pthread_rwlock_init (pthread_rwlock_t *__restrict __rwlock,
                                __const pthread_rwlockattr_t *__restrict
                                __attr) throw ();


extern int pthread_rwlock_destroy (pthread_rwlock_t *__rwlock) throw ();


extern int pthread_rwlock_rdlock (pthread_rwlock_t *__rwlock) throw ();


extern int pthread_rwlock_tryrdlock (pthread_rwlock_t *__rwlock) throw ();



extern int pthread_rwlock_timedrdlock (pthread_rwlock_t *__restrict __rwlock,
                                       __const struct timespec *__restrict
                                       __abstime) throw ();



extern int pthread_rwlock_wrlock (pthread_rwlock_t *__rwlock) throw ();


extern int pthread_rwlock_trywrlock (pthread_rwlock_t *__rwlock) throw ();



extern int pthread_rwlock_timedwrlock (pthread_rwlock_t *__restrict __rwlock,
                                       __const struct timespec *__restrict
                                       __abstime) throw ();



extern int pthread_rwlock_unlock (pthread_rwlock_t *__rwlock) throw ();





extern int pthread_rwlockattr_init (pthread_rwlockattr_t *__attr) throw ();


extern int pthread_rwlockattr_destroy (pthread_rwlockattr_t *__attr) throw ();


extern int pthread_rwlockattr_getpshared (__const pthread_rwlockattr_t *
                                          __restrict __attr,
                                          int *__restrict __pshared) throw ();


extern int pthread_rwlockattr_setpshared (pthread_rwlockattr_t *__attr,
                                          int __pshared) throw ();


extern int pthread_rwlockattr_getkind_np (__const pthread_rwlockattr_t *__attr,
                                          int *__pref) throw ();


extern int pthread_rwlockattr_setkind_np (pthread_rwlockattr_t *__attr,
                                          int __pref) throw ();
# 509 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern int pthread_spin_init (pthread_spinlock_t *__lock, int __pshared)
     throw ();


extern int pthread_spin_destroy (pthread_spinlock_t *__lock) throw ();


extern int pthread_spin_lock (pthread_spinlock_t *__lock) throw ();


extern int pthread_spin_trylock (pthread_spinlock_t *__lock) throw ();


extern int pthread_spin_unlock (pthread_spinlock_t *__lock) throw ();




extern int pthread_barrier_init (pthread_barrier_t *__restrict __barrier,
                                 __const pthread_barrierattr_t *__restrict
                                 __attr, unsigned int __count) throw ();

extern int pthread_barrier_destroy (pthread_barrier_t *__barrier) throw ();

extern int pthread_barrierattr_init (pthread_barrierattr_t *__attr) throw ();

extern int pthread_barrierattr_destroy (pthread_barrierattr_t *__attr) throw ();

extern int pthread_barrierattr_getpshared (__const pthread_barrierattr_t *
                                           __restrict __attr,
                                           int *__restrict __pshared) throw ();

extern int pthread_barrierattr_setpshared (pthread_barrierattr_t *__attr,
                                           int __pshared) throw ();

extern int pthread_barrier_wait (pthread_barrier_t *__barrier) throw ();
# 556 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern int pthread_key_create (pthread_key_t *__key,
                               void (*__destr_function) (void *)) throw ();


extern int pthread_key_delete (pthread_key_t __key) throw ();


extern int pthread_setspecific (pthread_key_t __key,
                                __const void *__pointer) throw ();


extern void *pthread_getspecific (pthread_key_t __key) throw ();
# 576 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern int pthread_once (pthread_once_t *__once_control,
                         void (*__init_routine) (void)) throw ();






extern int pthread_setcancelstate (int __state, int *__oldstate) throw ();



extern int pthread_setcanceltype (int __type, int *__oldtype) throw ();


extern int pthread_cancel (pthread_t __thread) throw ();




extern void pthread_testcancel (void) throw ();
# 610 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern void _pthread_cleanup_push (struct _pthread_cleanup_buffer *__buffer,
                                   void (*__routine) (void *),
                                   void *__arg) throw ();







extern void _pthread_cleanup_pop (struct _pthread_cleanup_buffer *__buffer,
                                  int __execute) throw ();
# 631 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern void _pthread_cleanup_push_defer (struct _pthread_cleanup_buffer *__buffer,
                                         void (*__routine) (void *),
                                         void *__arg) throw ();
# 642 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern void _pthread_cleanup_pop_restore (struct _pthread_cleanup_buffer *__buffer,
                                          int __execute) throw ();





extern int pthread_getcpuclockid (pthread_t __thread_id,
                                  clockid_t *__clock_id) throw ();




# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigthread.h" 1 3
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigthread.h" 3
extern int pthread_sigmask (int __how,
                            __const __sigset_t *__restrict __newmask,
                            __sigset_t *__restrict __oldmask)throw ();


extern int pthread_kill (pthread_t __thread, int __signo) throw ();
# 656 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 2 3
# 671 "/usr/lib/gcc/../../i686-inX-linux/include/pthread.h" 3
extern int pthread_atfork (void (*__prepare) (void),
                           void (*__parent) (void),
                           void (*__child) (void)) throw ();




extern void pthread_kill_other_threads_np (void) throw ();

}
# 38 "/usr/include/c++3.1/i686-inX-linux/bits/gthr-default.h" 2 3

typedef pthread_key_t __gthread_key_t;
typedef pthread_once_t __gthread_once_t;
typedef pthread_mutex_t __gthread_mutex_t;






#pragma weak pthread_once
#pragma weak pthread_key_create
#pragma weak pthread_key_delete
#pragma weak pthread_getspecific
#pragma weak pthread_setspecific
#pragma weak pthread_create

#pragma weak pthread_mutex_lock 
#pragma weak pthread_mutex_trylock 
#pragma weak pthread_mutex_unlock 
# 80 "/usr/include/c++3.1/i686-inX-linux/bits/gthr-default.h" 3
static inline int
__gthread_active_p (void)
{
  static void *const __gthread_active_ptr = (void *) &pthread_create;
  return __gthread_active_ptr != 0;
}
# 437 "/usr/include/c++3.1/i686-inX-linux/bits/gthr-default.h" 3
static inline int
__gthread_once (__gthread_once_t *once, void (*func) (void))
{
  if (__gthread_active_p ())
    return pthread_once (once, func);
  else
    return -1;
}

static inline int
__gthread_key_create (__gthread_key_t *key, void (*dtor) (void *))
{
  return pthread_key_create (key, dtor);
}

static inline int
__gthread_key_dtor (__gthread_key_t key, void *ptr)
{

  if (ptr)
    return pthread_setspecific (key, 0);
  else
    return 0;
}

static inline int
__gthread_key_delete (__gthread_key_t key)
{
  return pthread_key_delete (key);
}

static inline void *
__gthread_getspecific (__gthread_key_t key)
{
  return pthread_getspecific (key);
}

static inline int
__gthread_setspecific (__gthread_key_t key, const void *ptr)
{
  return pthread_setspecific (key, ptr);
}

static inline int
__gthread_mutex_lock (__gthread_mutex_t *mutex)
{
  if (__gthread_active_p ())
    return pthread_mutex_lock (mutex);
  else
    return 0;
}

static inline int
__gthread_mutex_trylock (__gthread_mutex_t *mutex)
{
  if (__gthread_active_p ())
    return pthread_mutex_trylock (mutex);
  else
    return 0;
}

static inline int
__gthread_mutex_unlock (__gthread_mutex_t *mutex)
{
  if (__gthread_active_p ())
    return pthread_mutex_unlock (mutex);
  else
    return 0;
}
# 99 "/usr/include/c++3.1/i686-inX-linux/bits/gthr.h" 2 3
# 38 "/usr/include/c++3.1/i686-inX-linux/bits/c++io.h" 2 3

namespace std
{

  typedef long streamoff;
  typedef ptrdiff_t streamsize;



  typedef fpos_t __c_streampos;

  typedef __gthread_mutex_t __c_lock;


  typedef FILE __c_file;


  struct __ios_flags
  {
    typedef short __int_type;

    static const __int_type _S_boolalpha = 0x0001;
    static const __int_type _S_dec = 0x0002;
    static const __int_type _S_fixed = 0x0004;
    static const __int_type _S_hex = 0x0008;
    static const __int_type _S_internal = 0x0010;
    static const __int_type _S_left = 0x0020;
    static const __int_type _S_oct = 0x0040;
    static const __int_type _S_right = 0x0080;
    static const __int_type _S_scientific = 0x0100;
    static const __int_type _S_showbase = 0x0200;
    static const __int_type _S_showpoint = 0x0400;
    static const __int_type _S_showpos = 0x0800;
    static const __int_type _S_skipws = 0x1000;
    static const __int_type _S_unitbuf = 0x2000;
    static const __int_type _S_uppercase = 0x4000;
    static const __int_type _S_adjustfield = 0x0020 | 0x0080 | 0x0010;
    static const __int_type _S_basefield = 0x0002 | 0x0040 | 0x0008;
    static const __int_type _S_floatfield = 0x0100 | 0x0004;


    static const __int_type _S_badbit = 0x01;
    static const __int_type _S_eofbit = 0x02;
    static const __int_type _S_failbit = 0x04;


    static const __int_type _S_app = 0x01;
    static const __int_type _S_ate = 0x02;
    static const __int_type _S_bin = 0x04;
    static const __int_type _S_in = 0x08;
    static const __int_type _S_out = 0x10;
    static const __int_type _S_trunc = 0x20;
  };
}
# 45 "/usr/include/c++3.1/bits/fpos.h" 2 3
# 1 "/usr/include/c++3.1/cwchar" 1 3
# 48 "/usr/include/c++3.1/cwchar" 3






# 1 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 1 3
# 40 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stdarg.h" 1 3
# 41 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 2 3







# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 49 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 2 3
# 85 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
typedef __mbstate_t mbstate_t;
# 105 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
struct tm;


extern "C" {


extern wchar_t *wcscpy (wchar_t *__restrict __dest,
                        __const wchar_t *__restrict __src) throw ();

extern wchar_t *wcsncpy (wchar_t *__restrict __dest,
                         __const wchar_t *__restrict __src, size_t __n)
     throw ();


extern wchar_t *wcscat (wchar_t *__restrict __dest,
                        __const wchar_t *__restrict __src) throw ();

extern wchar_t *wcsncat (wchar_t *__restrict __dest,
                         __const wchar_t *__restrict __src, size_t __n)
     throw ();


extern int wcscmp (__const wchar_t *__s1, __const wchar_t *__s2)
     throw () __attribute__ ((__pure__));

extern int wcsncmp (__const wchar_t *__s1, __const wchar_t *__s2, size_t __n)
     throw () __attribute__ ((__pure__));



extern int wcscasecmp (__const wchar_t *__s1, __const wchar_t *__s2) throw ();


extern int wcsncasecmp (__const wchar_t *__s1, __const wchar_t *__s2,
                        size_t __n) throw ();





extern int __wcscasecmp_l (__const wchar_t *__s1, __const wchar_t *__s2,
                           __locale_t __loc) throw ();

extern int __wcsncasecmp_l (__const wchar_t *__s1, __const wchar_t *__s2,
                            size_t __n, __locale_t __loc) throw ();




extern int wcscoll (__const wchar_t *__s1, __const wchar_t *__s2) throw ();



extern size_t wcsxfrm (wchar_t *__restrict __s1,
                       __const wchar_t *__restrict __s2, size_t __n) throw ();







extern int __wcscoll_l (__const wchar_t *__s1, __const wchar_t *__s2,
                        __locale_t __loc) throw ();



extern size_t __wcsxfrm_l (wchar_t *__s1, __const wchar_t *__s2,
                           size_t __n, __locale_t __loc) throw ();


extern wchar_t *wcsdup (__const wchar_t *__s) throw () __attribute__ ((__malloc__));



extern wchar_t *wcschr (__const wchar_t *__wcs, wchar_t __wc)
     throw () __attribute__ ((__pure__));

extern wchar_t *wcsrchr (__const wchar_t *__wcs, wchar_t __wc)
     throw () __attribute__ ((__pure__));




extern wchar_t *wcschrnul (__const wchar_t *__s, wchar_t __wc)
     throw () __attribute__ ((__pure__));




extern size_t wcscspn (__const wchar_t *__wcs, __const wchar_t *__reject)
     throw () __attribute__ ((__pure__));


extern size_t wcsspn (__const wchar_t *__wcs, __const wchar_t *__accept)
     throw () __attribute__ ((__pure__));

extern wchar_t *wcspbrk (__const wchar_t *__wcs, __const wchar_t *__accept)
     throw () __attribute__ ((__pure__));

extern wchar_t *wcsstr (__const wchar_t *__haystack, __const wchar_t *__needle)
     throw () __attribute__ ((__pure__));



extern wchar_t *wcswcs (__const wchar_t *__haystack, __const wchar_t *__needle)
     throw () __attribute__ ((__pure__));



extern wchar_t *wcstok (wchar_t *__restrict __s,
                        __const wchar_t *__restrict __delim,
                        wchar_t **__restrict __ptr) throw ();


extern size_t wcslen (__const wchar_t *__s) throw () __attribute__ ((__pure__));



extern size_t wcsnlen (__const wchar_t *__s, size_t __maxlen)
     throw () __attribute__ ((__pure__));




extern wchar_t *wmemchr (__const wchar_t *__s, wchar_t __c, size_t __n)
     throw () __attribute__ ((__pure__));


extern int wmemcmp (__const wchar_t *__restrict __s1,
                    __const wchar_t *__restrict __s2, size_t __n)
     throw () __attribute__ ((__pure__));


extern wchar_t *wmemcpy (wchar_t *__restrict __s1,
                         __const wchar_t *__restrict __s2, size_t __n) throw ();



extern wchar_t *wmemmove (wchar_t *__s1, __const wchar_t *__s2, size_t __n)
     throw ();


extern wchar_t *wmemset (wchar_t *__s, wchar_t __c, size_t __n) throw ();




extern wchar_t *wmempcpy (wchar_t *__restrict __s1,
                          __const wchar_t *__restrict __s2, size_t __n)
     throw ();





extern wint_t btowc (int __c) throw ();



extern int wctob (wint_t __c) throw ();



extern int mbsinit (__const mbstate_t *__ps) throw () __attribute__ ((__pure__));



extern size_t mbrtowc (wchar_t *__restrict __pwc,
                       __const char *__restrict __s, size_t __n,
                       mbstate_t *__p) throw ();


extern size_t wcrtomb (char *__restrict __s, wchar_t __wc,
                       mbstate_t *__restrict __ps) throw ();


extern size_t __mbrlen (__const char *__restrict __s, size_t __n,
                        mbstate_t *__restrict __ps) throw ();
extern size_t mbrlen (__const char *__restrict __s, size_t __n,
                      mbstate_t *__restrict __ps) throw ();
# 297 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
extern size_t mbsrtowcs (wchar_t *__restrict __dst,
                         __const char **__restrict __src, size_t __len,
                         mbstate_t *__restrict __ps) throw ();



extern size_t wcsrtombs (char *__restrict __dst,
                         __const wchar_t **__restrict __src, size_t __len,
                         mbstate_t *__restrict __ps) throw ();





extern size_t mbsnrtowcs (wchar_t *__restrict __dst,
                          __const char **__restrict __src, size_t __nmc,
                          size_t __len, mbstate_t *__restrict __ps) throw ();



extern size_t wcsnrtombs (char *__restrict __dst,
                          __const wchar_t **__restrict __src,
                          size_t __nwc, size_t __len,
                          mbstate_t *__restrict __ps) throw ();






extern int wcwidth (wchar_t __c) throw ();



extern int wcswidth (__const wchar_t *__s, size_t __n) throw ();





extern double wcstod (__const wchar_t *__restrict __nptr,
                      wchar_t **__restrict __endptr) throw ();



extern float wcstof (__const wchar_t *__restrict __nptr,
                     wchar_t **__restrict __endptr) throw ();
extern long double wcstold (__const wchar_t *__restrict __nptr,
                            wchar_t **__restrict __endptr) throw ();





extern long int wcstol (__const wchar_t *__restrict __nptr,
                        wchar_t **__restrict __endptr, int __base) throw ();



extern unsigned long int wcstoul (__const wchar_t *__restrict __nptr,
                                  wchar_t **__restrict __endptr, int __base)
     throw ();




__extension__
extern long long int wcstoq (__const wchar_t *__restrict __nptr,
                             wchar_t **__restrict __endptr, int __base)
     throw ();



__extension__
extern unsigned long long int wcstouq (__const wchar_t *__restrict __nptr,
                                       wchar_t **__restrict __endptr,
                                       int __base) throw ();





__extension__
extern long long int wcstoll (__const wchar_t *__restrict __nptr,
                              wchar_t **__restrict __endptr, int __base)
     throw ();



__extension__
extern unsigned long long int wcstoull (__const wchar_t *__restrict __nptr,
                                        wchar_t **__restrict __endptr,
                                        int __base) throw ();
# 410 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
extern long int __wcstol_l (__const wchar_t *__restrict __nptr,
                            wchar_t **__restrict __endptr, int __base,
                            __locale_t __loc) throw ();

extern unsigned long int __wcstoul_l (__const wchar_t *__restrict __nptr,
                                      wchar_t **__restrict __endptr,
                                      int __base, __locale_t __loc) throw ();

__extension__
extern long long int __wcstoll_l (__const wchar_t *__restrict __nptr,
                                  wchar_t **__restrict __endptr,
                                  int __base, __locale_t __loc) throw ();

__extension__
extern unsigned long long int __wcstoull_l (__const wchar_t *__restrict __nptr,
                                            wchar_t **__restrict __endptr,
                                            int __base, __locale_t __loc)
     throw ();

extern double __wcstod_l (__const wchar_t *__restrict __nptr,
                          wchar_t **__restrict __endptr, __locale_t __loc)
     throw ();

extern float __wcstof_l (__const wchar_t *__restrict __nptr,
                         wchar_t **__restrict __endptr, __locale_t __loc)
     throw ();

extern long double __wcstold_l (__const wchar_t *__restrict __nptr,
                                wchar_t **__restrict __endptr,
                                __locale_t __loc) throw ();





extern double __wcstod_internal (__const wchar_t *__restrict __nptr,
                                 wchar_t **__restrict __endptr, int __group)
     throw ();
extern float __wcstof_internal (__const wchar_t *__restrict __nptr,
                                wchar_t **__restrict __endptr, int __group)
     throw ();
extern long double __wcstold_internal (__const wchar_t *__restrict __nptr,
                                       wchar_t **__restrict __endptr,
                                       int __group) throw ();


extern long int __wcstol_internal (__const wchar_t *__restrict __nptr,
                                   wchar_t **__restrict __endptr,
                                   int __base, int __group) throw ();



extern unsigned long int __wcstoul_internal (__const wchar_t *__restrict __npt,
                                             wchar_t **__restrict __endptr,
                                             int __base, int __group) throw ();



__extension__
extern long long int __wcstoll_internal (__const wchar_t *__restrict __nptr,
                                         wchar_t **__restrict __endptr,
                                         int __base, int __group) throw ();



__extension__
extern unsigned long long int __wcstoull_internal (__const wchar_t *
                                                   __restrict __nptr,
                                                   wchar_t **
                                                   __restrict __endptr,
                                                   int __base,
                                                   int __group) throw ();
# 528 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
extern wchar_t *wcpcpy (wchar_t *__dest, __const wchar_t *__src) throw ();



extern wchar_t *wcpncpy (wchar_t *__dest, __const wchar_t *__src, size_t __n)
     throw ();







extern int fwide (__FILE *__fp, int __mode) throw ();



extern int fwprintf (__FILE *__restrict __stream,
                     __const wchar_t *__restrict __format, ...)
     throw () ;

extern int wprintf (__const wchar_t *__restrict __format, ...)
     throw () ;

extern int swprintf (wchar_t *__restrict __s, size_t __n,
                     __const wchar_t *__restrict __format, ...)
     throw () ;


extern int vfwprintf (__FILE *__restrict __s,
                      __const wchar_t *__restrict __format,
                      __gnuc_va_list __arg)
     throw () ;

extern int vwprintf (__const wchar_t *__restrict __format,
                     __gnuc_va_list __arg)
     throw () ;


extern int vswprintf (wchar_t *__restrict __s, size_t __n,
                      __const wchar_t *__restrict __format,
                      __gnuc_va_list __arg)
     throw () ;



extern int fwscanf (__FILE *__restrict __stream,
                    __const wchar_t *__restrict __format, ...)
     throw () ;

extern int wscanf (__const wchar_t *__restrict __format, ...)
     throw () ;

extern int swscanf (__const wchar_t *__restrict __s,
                    __const wchar_t *__restrict __format, ...)
     throw () ;




extern int vfwscanf (__FILE *__restrict __s,
                     __const wchar_t *__restrict __format,
                     __gnuc_va_list __arg)
     throw () ;

extern int vwscanf (__const wchar_t *__restrict __format,
                    __gnuc_va_list __arg)
     throw () ;

extern int vswscanf (__const wchar_t *__restrict __s,
                     __const wchar_t *__restrict __format,
                     __gnuc_va_list __arg)
     throw () ;




extern wint_t fgetwc (__FILE *__stream) throw ();
extern wint_t getwc (__FILE *__stream) throw ();


extern wint_t getwchar (void) throw ();



extern wint_t fputwc (wchar_t __wc, __FILE *__stream) throw ();
extern wint_t putwc (wchar_t __wc, __FILE *__stream) throw ();


extern wint_t putwchar (wchar_t __wc) throw ();




extern wchar_t *fgetws (wchar_t *__restrict __ws, int __n,
                        __FILE *__restrict __stream) throw ();


extern int fputws (__const wchar_t *__restrict __ws,
                   __FILE *__restrict __stream) throw ();



extern wint_t ungetwc (wint_t __wc, __FILE *__stream) throw ();





extern wint_t getwc_unlocked (__FILE *__stream) throw ();
extern wint_t getwchar_unlocked (void) throw ();


extern wint_t fgetwc_unlocked (__FILE *__stream) throw ();


extern wint_t fputwc_unlocked (wchar_t __wc, __FILE *__stream) throw ();



extern wint_t putwc_unlocked (wchar_t __wc, __FILE *__stream) throw ();
extern wint_t putwchar_unlocked (wchar_t __wc) throw ();



extern wchar_t *fgetws_unlocked (wchar_t *__restrict __ws, int __n,
                                 __FILE *__restrict __stream) throw ();


extern int fputws_unlocked (__const wchar_t *__restrict __ws,
                            __FILE *__restrict __stream) throw ();






extern size_t wcsftime (wchar_t *__restrict __s, size_t __maxsize,
                        __const wchar_t *__restrict __format,
                        __const struct tm *__restrict __tp) throw ();
# 680 "/usr/lib/gcc/../../i686-inX-linux/include/wchar.h" 3
}
# 55 "/usr/include/c++3.1/cwchar" 2 3
# 69 "/usr/include/c++3.1/cwchar" 3
namespace std
{
  using ::mbstate_t;
}
# 46 "/usr/include/c++3.1/bits/fpos.h" 2 3

namespace std
{



  template<typename _StateT>
    class fpos
    {
    public:

      typedef _StateT __state_type;

    private:
      streamoff _M_off;
      __state_type _M_st;

    public:
      __state_type
      state() const { return _M_st; }

      void
      state(__state_type __st) { _M_st = __st; }



      fpos(): _M_off(streamoff()), _M_st(__state_type()) { }

      fpos(streamoff __off, __state_type __st = __state_type())
      : _M_off(__off), _M_st(__st) { }

      operator streamoff() const { return _M_off; }

      fpos&
      operator+=(streamoff __off) { _M_off += __off; return *this; }

      fpos&
      operator-=(streamoff __off) { _M_off -= __off; return *this; }

      fpos
      operator+(streamoff __off)
      {
        fpos __t(*this);
        __t += __off;
        return __t;
      }

      fpos
      operator-(streamoff __off)
      {
        fpos __t(*this);
        __t -= __off;
        return __t;
      }

      bool
      operator==(const fpos& __pos) const
      { return _M_off == __pos._M_off; }

      bool
      operator!=(const fpos& __pos) const
      { return _M_off != __pos._M_off; }

      streamoff
      _M_position() const { return _M_off; }

      void
      _M_position(streamoff __off) { _M_off = __off; }
    };


  typedef fpos<mbstate_t> streampos;



}
# 47 "/usr/include/c++3.1/iosfwd" 2 3
# 1 "/usr/include/c++3.1/bits/functexcept.h" 1 3
# 34 "/usr/include/c++3.1/bits/functexcept.h" 3
# 1 "/usr/include/c++3.1/exception_defines.h" 1 3
# 35 "/usr/include/c++3.1/bits/functexcept.h" 2 3

namespace std
{

  void
  __throw_bad_exception(void);


  void
  __throw_bad_alloc(void);


  void
  __throw_bad_cast(void);

  void
  __throw_bad_typeid(void);


  void
  __throw_logic_error(const char* __s);

  void
  __throw_domain_error(const char* __s);

  void
  __throw_invalid_argument(const char* __s);

  void
  __throw_length_error(const char* __s);

  void
  __throw_out_of_range(const char* __s);

  void
  __throw_runtime_error(const char* __s);

  void
  __throw_range_error(const char* __s);

  void
  __throw_overflow_error(const char* __s);

  void
  __throw_underflow_error(const char* __s);


  void
  __throw_ios_failure(const char* __s);
}
# 48 "/usr/include/c++3.1/iosfwd" 2 3

namespace std
{
  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_ios;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_streambuf;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_istream;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_ostream;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_iostream;

  template<typename _CharT, typename _Traits = char_traits<_CharT>,
            typename _Alloc = allocator<_CharT> >
    class basic_stringbuf;

  template<typename _CharT, typename _Traits = char_traits<_CharT>,
           typename _Alloc = allocator<_CharT> >
    class basic_istringstream;

  template<typename _CharT, typename _Traits = char_traits<_CharT>,
           typename _Alloc = allocator<_CharT> >
    class basic_ostringstream;

  template<typename _CharT, typename _Traits = char_traits<_CharT>,
           typename _Alloc = allocator<_CharT> >
    class basic_stringstream;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_filebuf;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_ifstream;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_ofstream;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class basic_fstream;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class istreambuf_iterator;

  template<typename _CharT, typename _Traits = char_traits<_CharT> >
    class ostreambuf_iterator;



  class ios_base;


  typedef basic_ios<char> ios;
  typedef basic_streambuf<char> streambuf;
  typedef basic_istream<char> istream;
  typedef basic_ostream<char> ostream;
  typedef basic_iostream<char> iostream;
  typedef basic_stringbuf<char> stringbuf;
  typedef basic_istringstream<char> istringstream;
  typedef basic_ostringstream<char> ostringstream;
  typedef basic_stringstream<char> stringstream;
  typedef basic_filebuf<char> filebuf;
  typedef basic_ifstream<char> ifstream;
  typedef basic_ofstream<char> ofstream;
  typedef basic_fstream<char> fstream;

  typedef basic_ios<wchar_t> wios;
  typedef basic_streambuf<wchar_t> wstreambuf;
  typedef basic_istream<wchar_t> wistream;
  typedef basic_ostream<wchar_t> wostream;
  typedef basic_iostream<wchar_t> wiostream;
  typedef basic_stringbuf<wchar_t> wstringbuf;
  typedef basic_istringstream<wchar_t> wistringstream;
  typedef basic_ostringstream<wchar_t> wostringstream;
  typedef basic_stringstream<wchar_t> wstringstream;
  typedef basic_filebuf<wchar_t> wfilebuf;
  typedef basic_ifstream<wchar_t> wifstream;
  typedef basic_ofstream<wchar_t> wofstream;
  typedef basic_fstream<wchar_t> wfstream;
}
# 71 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/bits/stl_pair.h" 1 3
# 64 "/usr/include/c++3.1/bits/stl_pair.h" 3
namespace std
{


template <class _T1, class _T2>
struct pair {
  typedef _T1 first_type;
  typedef _T2 second_type;

  _T1 first;
  _T2 second;




  pair() : first(), second() {}




  pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) {}


  template <class _U1, class _U2>
  pair(const pair<_U1, _U2>& __p) : first(__p.first), second(__p.second) {}
};


template <class _T1, class _T2>
inline bool operator==(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y)
{
  return __x.first == __y.first && __x.second == __y.second;
}


template <class _T1, class _T2>
inline bool operator<(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y)
{
  return __x.first < __y.first ||
         (!(__y.first < __x.first) && __x.second < __y.second);
}


template <class _T1, class _T2>
inline bool operator!=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) {
  return !(__x == __y);
}


template <class _T1, class _T2>
inline bool operator>(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) {
  return __y < __x;
}


template <class _T1, class _T2>
inline bool operator<=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) {
  return !(__y < __x);
}


template <class _T1, class _T2>
inline bool operator>=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) {
  return !(__x < __y);
}
# 140 "/usr/include/c++3.1/bits/stl_pair.h" 3
template <class _T1, class _T2>


inline pair<_T1, _T2> make_pair(_T1 __x, _T2 __y)



{
  return pair<_T1, _T2>(__x, __y);
}

}
# 72 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/bits/type_traits.h" 1 3
# 53 "/usr/include/c++3.1/bits/type_traits.h" 3
# 90 "/usr/include/c++3.1/bits/type_traits.h" 3
struct __true_type {};
struct __false_type {};

template <class _Tp>
struct __type_traits {
   typedef __true_type this_dummy_member_must_be_first;
# 113 "/usr/include/c++3.1/bits/type_traits.h" 3
   typedef __false_type has_trivial_default_constructor;
   typedef __false_type has_trivial_copy_constructor;
   typedef __false_type has_trivial_assignment_operator;
   typedef __false_type has_trivial_destructor;
   typedef __false_type is_POD_type;
};




template<> struct __type_traits<bool> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<char> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<signed char> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<unsigned char> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<wchar_t> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<short> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<unsigned short> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<int> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<unsigned int> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<long> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<unsigned long> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<long long> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<unsigned long long> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<float> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<double> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template<> struct __type_traits<long double> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};

template <class _Tp>
struct __type_traits<_Tp*> {
   typedef __true_type has_trivial_default_constructor;
   typedef __true_type has_trivial_copy_constructor;
   typedef __true_type has_trivial_assignment_operator;
   typedef __true_type has_trivial_destructor;
   typedef __true_type is_POD_type;
};





template <class _Tp> struct _Is_integer {
  typedef __false_type _Integral;
};

template<> struct _Is_integer<bool> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<char> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<signed char> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<unsigned char> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<wchar_t> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<short> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<unsigned short> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<int> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<unsigned int> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<long> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<unsigned long> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<long long> {
  typedef __true_type _Integral;
};

template<> struct _Is_integer<unsigned long long> {
  typedef __true_type _Integral;
};

template<typename _Tp> struct _Is_normal_iterator {
   typedef __false_type _Normal;
};


namespace __gnu_cxx
{
  template<typename _Iterator, typename _Container> class __normal_iterator;
}

template<typename _Iterator, typename _Container>
struct _Is_normal_iterator< __gnu_cxx::__normal_iterator<_Iterator, _Container> > {
   typedef __true_type _Normal;
};
# 73 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/bits/stl_iterator_base_types.h" 1 3
# 68 "/usr/include/c++3.1/bits/stl_iterator_base_types.h" 3

namespace std
{
# 80 "/usr/include/c++3.1/bits/stl_iterator_base_types.h" 3
  struct input_iterator_tag {};

  struct output_iterator_tag {};

  struct forward_iterator_tag : public input_iterator_tag {};

  struct bidirectional_iterator_tag : public forward_iterator_tag {};

  struct random_access_iterator_tag : public bidirectional_iterator_tag {};
# 100 "/usr/include/c++3.1/bits/stl_iterator_base_types.h" 3
  template<typename _Category, typename _Tp, typename _Distance = ptrdiff_t,
           typename _Pointer = _Tp*, typename _Reference = _Tp&>
    struct iterator {

      typedef _Category iterator_category;

      typedef _Tp value_type;

      typedef _Distance difference_type;

      typedef _Pointer pointer;

      typedef _Reference reference;
    };







  template<typename _Iterator>
    struct iterator_traits {
      typedef typename _Iterator::iterator_category iterator_category;
      typedef typename _Iterator::value_type value_type;
      typedef typename _Iterator::difference_type difference_type;
      typedef typename _Iterator::pointer pointer;
      typedef typename _Iterator::reference reference;
    };

  template<typename _Tp>
    struct iterator_traits<_Tp*> {
      typedef random_access_iterator_tag iterator_category;
      typedef _Tp value_type;
      typedef ptrdiff_t difference_type;
      typedef _Tp* pointer;
      typedef _Tp& reference;
    };

  template<typename _Tp>
    struct iterator_traits<const _Tp*> {
      typedef random_access_iterator_tag iterator_category;
      typedef _Tp value_type;
      typedef ptrdiff_t difference_type;
      typedef const _Tp* pointer;
      typedef const _Tp& reference;
    };







  template<typename _Iter>
    inline typename iterator_traits<_Iter>::iterator_category
    __iterator_category(const _Iter&)
    { return typename iterator_traits<_Iter>::iterator_category(); }

}
# 74 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/bits/stl_iterator_base_funcs.h" 1 3
# 68 "/usr/include/c++3.1/bits/stl_iterator_base_funcs.h" 3
# 1 "/usr/include/c++3.1/bits/concept_check.h" 1 3
# 39 "/usr/include/c++3.1/bits/concept_check.h" 3
# 69 "/usr/include/c++3.1/bits/stl_iterator_base_funcs.h" 2 3




namespace std
{
template<typename _InputIterator>
  inline typename iterator_traits<_InputIterator>::difference_type
  __distance(_InputIterator __first, _InputIterator __last, input_iterator_tag)
  {

   

    typename iterator_traits<_InputIterator>::difference_type __n = 0;
    while (__first != __last) {
      ++__first; ++__n;
    }
    return __n;
  }

template<typename _RandomAccessIterator>
  inline typename iterator_traits<_RandomAccessIterator>::difference_type
  __distance(_RandomAccessIterator __first, _RandomAccessIterator __last,
             random_access_iterator_tag)
  {

   
    return __last - __first;
  }
# 111 "/usr/include/c++3.1/bits/stl_iterator_base_funcs.h" 3
template<typename _InputIterator>
  inline typename iterator_traits<_InputIterator>::difference_type
  distance(_InputIterator __first, _InputIterator __last)
  {

    return __distance(__first, __last, __iterator_category(__first));
  }

template<typename _InputIter, typename _Distance>
  inline void
  __advance(_InputIter& __i, _Distance __n, input_iterator_tag)
  {

   
    while (__n--) ++__i;
  }

template<typename _BidirectionalIterator, typename _Distance>
  inline void
  __advance(_BidirectionalIterator& __i, _Distance __n,
            bidirectional_iterator_tag)
  {

   

    if (__n > 0)
      while (__n--) ++__i;
    else
      while (__n++) --__i;
  }

template<typename _RandomAccessIterator, typename _Distance>
  inline void
  __advance(_RandomAccessIterator& __i, _Distance __n,
            random_access_iterator_tag)
  {

   
    __i += __n;
  }
# 164 "/usr/include/c++3.1/bits/stl_iterator_base_funcs.h" 3
template<typename _InputIterator, typename _Distance>
  inline void
  advance(_InputIterator& __i, _Distance __n)
  {

    __advance(__i, __n, __iterator_category(__i));
  }

}
# 75 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3
# 1 "/usr/include/c++3.1/bits/stl_iterator.h" 1 3
# 68 "/usr/include/c++3.1/bits/stl_iterator.h" 3
namespace std
{
# 89 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Iterator>
    class reverse_iterator
    : public iterator<typename iterator_traits<_Iterator>::iterator_category,
                      typename iterator_traits<_Iterator>::value_type,
                      typename iterator_traits<_Iterator>::difference_type,
                      typename iterator_traits<_Iterator>::pointer,
                      typename iterator_traits<_Iterator>::reference>
    {
    protected:
      _Iterator current;

    public:
      typedef _Iterator iterator_type;
      typedef typename iterator_traits<_Iterator>::difference_type
                                                               difference_type;
      typedef typename iterator_traits<_Iterator>::reference reference;
      typedef typename iterator_traits<_Iterator>::pointer pointer;

    public:



      reverse_iterator() { }




      explicit
      reverse_iterator(iterator_type __x) : current(__x) { }




      reverse_iterator(const reverse_iterator& __x)
      : current(__x.current) { }





      template<typename _Iter>
        reverse_iterator(const reverse_iterator<_Iter>& __x)
        : current(__x.base()) { }




      iterator_type
      base() const { return current; }






      reference
      operator*() const
      {
        _Iterator __tmp = current;
        return *--__tmp;
      }






      pointer
      operator->() const { return &(operator*()); }






      reverse_iterator&
      operator++()
      {
        --current;
        return *this;
      }






      reverse_iterator
      operator++(int)
      {
        reverse_iterator __tmp = *this;
        --current;
        return __tmp;
      }






      reverse_iterator&
      operator--()
      {
        ++current;
        return *this;
      }






      reverse_iterator operator--(int)
      {
        reverse_iterator __tmp = *this;
        ++current;
        return __tmp;
      }






      reverse_iterator
      operator+(difference_type __n) const
      { return reverse_iterator(current - __n); }






      reverse_iterator&
      operator+=(difference_type __n)
      {
        current -= __n;
        return *this;
      }






      reverse_iterator
      operator-(difference_type __n) const
      { return reverse_iterator(current + __n); }






      reverse_iterator&
      operator-=(difference_type __n)
      {
        current += __n;
        return *this;
      }






      reference
      operator[](difference_type __n) const { return *(*this + __n); }
    };
# 269 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Iterator>
    inline bool
    operator==(const reverse_iterator<_Iterator>& __x,
               const reverse_iterator<_Iterator>& __y)
    { return __x.base() == __y.base(); }

  template<typename _Iterator>
    inline bool
    operator<(const reverse_iterator<_Iterator>& __x,
              const reverse_iterator<_Iterator>& __y)
    { return __y.base() < __x.base(); }

  template<typename _Iterator>
    inline bool
    operator!=(const reverse_iterator<_Iterator>& __x,
               const reverse_iterator<_Iterator>& __y)
    { return !(__x == __y); }

  template<typename _Iterator>
    inline bool
    operator>(const reverse_iterator<_Iterator>& __x,
              const reverse_iterator<_Iterator>& __y)
    { return __y < __x; }

  template<typename _Iterator>
    inline bool
    operator<=(const reverse_iterator<_Iterator>& __x,
                const reverse_iterator<_Iterator>& __y)
    { return !(__y < __x); }

  template<typename _Iterator>
    inline bool
    operator>=(const reverse_iterator<_Iterator>& __x,
               const reverse_iterator<_Iterator>& __y)
    { return !(__x < __y); }

  template<typename _Iterator>
    inline typename reverse_iterator<_Iterator>::difference_type
    operator-(const reverse_iterator<_Iterator>& __x,
              const reverse_iterator<_Iterator>& __y)
    { return __y.base() - __x.base(); }

  template<typename _Iterator>
    inline reverse_iterator<_Iterator>
    operator+(typename reverse_iterator<_Iterator>::difference_type __n,
              const reverse_iterator<_Iterator>& __x)
    { return reverse_iterator<_Iterator>(__x.base() - __n); }
# 327 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Container>
    class back_insert_iterator
    : public iterator<output_iterator_tag, void, void, void, void>
    {
    protected:
      _Container* container;

    public:

      typedef _Container container_type;


      explicit
      back_insert_iterator(_Container& __x) : container(&__x) { }
# 353 "/usr/include/c++3.1/bits/stl_iterator.h" 3
      back_insert_iterator&
      operator=(typename _Container::const_reference __value)
      {
        container->push_back(__value);
        return *this;
      }


      back_insert_iterator&
      operator*() { return *this; }


      back_insert_iterator&
      operator++() { return *this; }


      back_insert_iterator
      operator++(int) { return *this; }
    };
# 384 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Container>
    inline back_insert_iterator<_Container>
    back_inserter(_Container& __x)
    { return back_insert_iterator<_Container>(__x); }
# 397 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Container>
    class front_insert_iterator
    : public iterator<output_iterator_tag, void, void, void, void>
    {
    protected:
      _Container* container;

    public:

      typedef _Container container_type;


      explicit front_insert_iterator(_Container& __x) : container(&__x) { }
# 422 "/usr/include/c++3.1/bits/stl_iterator.h" 3
      front_insert_iterator&
      operator=(typename _Container::const_reference __value)
      {
        container->push_front(__value);
        return *this;
      }


      front_insert_iterator&
      operator*() { return *this; }


      front_insert_iterator&
      operator++() { return *this; }


      front_insert_iterator
      operator++(int) { return *this; }
    };
# 453 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Container>
    inline front_insert_iterator<_Container>
    front_inserter(_Container& __x)
    { return front_insert_iterator<_Container>(__x); }
# 470 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Container>
    class insert_iterator
    : public iterator<output_iterator_tag, void, void, void, void>
    {
    protected:
      _Container* container;
      typename _Container::iterator iter;

    public:

      typedef _Container container_type;





      insert_iterator(_Container& __x, typename _Container::iterator __i)
      : container(&__x), iter(__i) {}
# 512 "/usr/include/c++3.1/bits/stl_iterator.h" 3
      insert_iterator&
      operator=(const typename _Container::const_reference __value)
      {
        iter = container->insert(iter, __value);
        ++iter;
        return *this;
      }


      insert_iterator&
      operator*() { return *this; }


      insert_iterator&
      operator++() { return *this; }


      insert_iterator&
      operator++(int) { return *this; }
    };
# 544 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _Container, typename _Iterator>
    inline insert_iterator<_Container>
    inserter(_Container& __x, _Iterator __i)
    {
      return insert_iterator<_Container>(__x,
                                         typename _Container::iterator(__i));
    }
}

namespace __gnu_cxx
{







  using std::iterator_traits;
  using std::iterator;
  template<typename _Iterator, typename _Container>
    class __normal_iterator
      : public iterator<typename iterator_traits<_Iterator>::iterator_category,
                        typename iterator_traits<_Iterator>::value_type,
                        typename iterator_traits<_Iterator>::difference_type,
                        typename iterator_traits<_Iterator>::pointer,
                        typename iterator_traits<_Iterator>::reference>
    {
    protected:
      _Iterator _M_current;

    public:
      typedef typename iterator_traits<_Iterator>::difference_type
                                                               difference_type;
      typedef typename iterator_traits<_Iterator>::reference reference;
      typedef typename iterator_traits<_Iterator>::pointer pointer;

      __normal_iterator() : _M_current(_Iterator()) { }

      explicit
      __normal_iterator(const _Iterator& __i) : _M_current(__i) { }


      template<typename _Iter>
      inline __normal_iterator(const __normal_iterator<_Iter, _Container>& __i)
        : _M_current(__i.base()) { }


      reference
      operator*() const { return *_M_current; }

      pointer
      operator->() const { return _M_current; }

      __normal_iterator&
      operator++() { ++_M_current; return *this; }

      __normal_iterator
      operator++(int) { return __normal_iterator(_M_current++); }


      __normal_iterator&
      operator--() { --_M_current; return *this; }

      __normal_iterator
      operator--(int) { return __normal_iterator(_M_current--); }


      reference
      operator[](const difference_type& __n) const
      { return _M_current[__n]; }

      __normal_iterator&
      operator+=(const difference_type& __n)
      { _M_current += __n; return *this; }

      __normal_iterator
      operator+(const difference_type& __n) const
      { return __normal_iterator(_M_current + __n); }

      __normal_iterator&
      operator-=(const difference_type& __n)
      { _M_current -= __n; return *this; }

      __normal_iterator
      operator-(const difference_type& __n) const
      { return __normal_iterator(_M_current - __n); }

      difference_type
      operator-(const __normal_iterator& __i) const
      { return _M_current - __i._M_current; }

      const _Iterator&
      base() const { return _M_current; }
    };
# 649 "/usr/include/c++3.1/bits/stl_iterator.h" 3
  template<typename _IteratorL, typename _IteratorR, typename _Container>
  inline bool
  operator==(const __normal_iterator<_IteratorL, _Container>& __lhs,
             const __normal_iterator<_IteratorR, _Container>& __rhs)
  { return __lhs.base() == __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline bool
  operator==(const __normal_iterator<_Iterator, _Container>& __lhs,
             const __normal_iterator<_Iterator, _Container>& __rhs)
  { return __lhs.base() == __rhs.base(); }

  template<typename _IteratorL, typename _IteratorR, typename _Container>
  inline bool
  operator!=(const __normal_iterator<_IteratorL, _Container>& __lhs,
             const __normal_iterator<_IteratorR, _Container>& __rhs)
  { return __lhs.base() != __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline bool
  operator!=(const __normal_iterator<_Iterator, _Container>& __lhs,
             const __normal_iterator<_Iterator, _Container>& __rhs)
  { return __lhs.base() != __rhs.base(); }


  template<typename _IteratorL, typename _IteratorR, typename _Container>
  inline bool
  operator<(const __normal_iterator<_IteratorL, _Container>& __lhs,
            const __normal_iterator<_IteratorR, _Container>& __rhs)
  { return __lhs.base() < __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline bool
  operator<(const __normal_iterator<_Iterator, _Container>& __lhs,
             const __normal_iterator<_Iterator, _Container>& __rhs)
  { return __lhs.base() < __rhs.base(); }

  template<typename _IteratorL, typename _IteratorR, typename _Container>
  inline bool
  operator>(const __normal_iterator<_IteratorL, _Container>& __lhs,
            const __normal_iterator<_IteratorR, _Container>& __rhs)
  { return __lhs.base() > __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline bool
  operator>(const __normal_iterator<_Iterator, _Container>& __lhs,
            const __normal_iterator<_Iterator, _Container>& __rhs)
  { return __lhs.base() > __rhs.base(); }

  template<typename _IteratorL, typename _IteratorR, typename _Container>
  inline bool
  operator<=(const __normal_iterator<_IteratorL, _Container>& __lhs,
             const __normal_iterator<_IteratorR, _Container>& __rhs)
  { return __lhs.base() <= __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline bool
  operator<=(const __normal_iterator<_Iterator, _Container>& __lhs,
             const __normal_iterator<_Iterator, _Container>& __rhs)
  { return __lhs.base() <= __rhs.base(); }

  template<typename _IteratorL, typename _IteratorR, typename _Container>
  inline bool
  operator>=(const __normal_iterator<_IteratorL, _Container>& __lhs,
             const __normal_iterator<_IteratorR, _Container>& __rhs)
  { return __lhs.base() >= __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline bool
  operator>=(const __normal_iterator<_Iterator, _Container>& __lhs,
             const __normal_iterator<_Iterator, _Container>& __rhs)
  { return __lhs.base() >= __rhs.base(); }

  template<typename _Iterator, typename _Container>
  inline __normal_iterator<_Iterator, _Container>
  operator+(typename __normal_iterator<_Iterator, _Container>::difference_type __n,
            const __normal_iterator<_Iterator, _Container>& __i)
  { return __normal_iterator<_Iterator, _Container>(__i.base() + __n); }
}
# 76 "/usr/include/c++3.1/bits/stl_algobase.h" 2 3


namespace std
{
# 91 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _ForwardIter1, typename _ForwardIter2>
    inline void
    iter_swap(_ForwardIter1 __a, _ForwardIter2 __b)
    {
      typedef typename iterator_traits<_ForwardIter1>::value_type _ValueType1;
      typedef typename iterator_traits<_ForwardIter2>::value_type _ValueType2;


     
     
     
     

      _ValueType1 __tmp = *__a;
      *__a = *__b;
      *__b = __tmp;
    }
# 118 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _Tp>
    inline void
    swap(_Tp& __a, _Tp& __b)
    {

     

      _Tp __tmp = __a;
      __a = __b;
      __b = __tmp;
    }
# 146 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _Tp>
    inline const _Tp&
    min(const _Tp& __a, const _Tp& __b)
    {

     

      if (__b < __a) return __b; return __a;
    }
# 166 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _Tp>
    inline const _Tp&
    max(const _Tp& __a, const _Tp& __b)
    {

     

      if (__a < __b) return __b; return __a;
    }
# 186 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _Tp, typename _Compare>
    inline const _Tp&
    min(const _Tp& __a, const _Tp& __b, _Compare __comp)
    {

      if (__comp(__b, __a)) return __b; return __a;
    }
# 204 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _Tp, typename _Compare>
    inline const _Tp&
    max(const _Tp& __a, const _Tp& __b, _Compare __comp)
    {

      if (__comp(__a, __b)) return __b; return __a;
    }
# 221 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy(_InputIter __first, _InputIter __last,
           _OutputIter __result,
           input_iterator_tag)
    {
      for ( ; __first != __last; ++__result, ++__first)
        *__result = *__first;
      return __result;
    }

  template<typename _RandomAccessIter, typename _OutputIter>
    inline _OutputIter
    __copy(_RandomAccessIter __first, _RandomAccessIter __last,
           _OutputIter __result,
           random_access_iterator_tag)
    {
      typedef typename iterator_traits<_RandomAccessIter>::difference_type
          _Distance;
      for (_Distance __n = __last - __first; __n > 0; --__n) {
        *__result = *__first;
        ++__first;
        ++__result;
      }
      return __result;
    }

  template<typename _Tp>
    inline _Tp*
    __copy_trivial(const _Tp* __first, const _Tp* __last, _Tp* __result)
    {
      memmove(__result, __first, sizeof(_Tp) * (__last - __first));
      return __result + (__last - __first);
    }

  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy_aux2(_InputIter __first, _InputIter __last,
                _OutputIter __result, __false_type)
    { return __copy(__first, __last, __result, __iterator_category(__first)); }

  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy_aux2(_InputIter __first, _InputIter __last,
                _OutputIter __result, __true_type)
    { return __copy(__first, __last, __result, __iterator_category(__first)); }

  template<typename _Tp>
    inline _Tp*
    __copy_aux2(_Tp* __first, _Tp* __last,
                _Tp* __result, __true_type)
    { return __copy_trivial(__first, __last, __result); }

  template<typename _Tp>
    inline _Tp*
    __copy_aux2(const _Tp* __first, const _Tp* __last,
                _Tp* __result, __true_type)
    { return __copy_trivial(__first, __last, __result); }

  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy_ni2(_InputIter __first, _InputIter __last,
               _OutputIter __result, __true_type)
    {
      typedef typename iterator_traits<_InputIter>::value_type
          _ValueType;
      typedef typename __type_traits<_ValueType>::has_trivial_assignment_operator
          _Trivial;
      return _OutputIter(__copy_aux2(__first, __last,
                                     __result.base(),
                                     _Trivial()));
    }

  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy_ni2(_InputIter __first, _InputIter __last,
               _OutputIter __result, __false_type)
    {
      typedef typename iterator_traits<_InputIter>::value_type
          _ValueType;
      typedef typename __type_traits<_ValueType>::has_trivial_assignment_operator
          _Trivial;
      return __copy_aux2(__first, __last,
                         __result,
                         _Trivial());
    }

  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy_ni1(_InputIter __first, _InputIter __last,
               _OutputIter __result, __true_type)
    {
      typedef typename _Is_normal_iterator<_OutputIter>::_Normal __Normal;
      return __copy_ni2(__first.base(), __last.base(), __result, __Normal());
    }

  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    __copy_ni1(_InputIter __first, _InputIter __last,
               _OutputIter __result, __false_type)
    {
      typedef typename _Is_normal_iterator<_OutputIter>::_Normal __Normal;
      return __copy_ni2(__first, __last, __result, __Normal());
    }
# 339 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    copy(_InputIter __first, _InputIter __last, _OutputIter __result)
    {

     
     


       typedef typename _Is_normal_iterator<_InputIter>::_Normal __Normal;
       return __copy_ni1(__first, __last, __result, __Normal());
    }




  template<typename _BidirectionalIter1, typename _BidirectionalIter2>
    inline _BidirectionalIter2
    __copy_backward(_BidirectionalIter1 __first, _BidirectionalIter1 __last,
                    _BidirectionalIter2 __result,
                    bidirectional_iterator_tag)
    {
      while (__first != __last)
        *--__result = *--__last;
      return __result;
    }

  template<typename _RandomAccessIter, typename _BidirectionalIter>
    inline _BidirectionalIter
    __copy_backward(_RandomAccessIter __first, _RandomAccessIter __last,
                    _BidirectionalIter __result,
                    random_access_iterator_tag)
    {
      typename iterator_traits<_RandomAccessIter>::difference_type __n;
      for (__n = __last - __first; __n > 0; --__n)
        *--__result = *--__last;
      return __result;
    }







  template<typename _BidirectionalIter1, typename _BidirectionalIter2,
           typename _BoolType>
    struct __copy_backward_dispatch
    {
      static _BidirectionalIter2
      copy(_BidirectionalIter1 __first, _BidirectionalIter1 __last,
           _BidirectionalIter2 __result)
      {
        return __copy_backward(__first, __last,
                               __result,
                               __iterator_category(__first));
      }
    };

  template<typename _Tp>
    struct __copy_backward_dispatch<_Tp*, _Tp*, __true_type>
    {
      static _Tp*
      copy(const _Tp* __first, const _Tp* __last, _Tp* __result)
      {
        const ptrdiff_t _Num = __last - __first;
        memmove(__result - _Num, __first, sizeof(_Tp) * _Num);
        return __result - _Num;
      }
    };

  template<typename _Tp>
    struct __copy_backward_dispatch<const _Tp*, _Tp*, __true_type>
    {
      static _Tp*
      copy(const _Tp* __first, const _Tp* __last, _Tp* __result)
      {
        return __copy_backward_dispatch<_Tp*, _Tp*, __true_type>
          ::copy(__first, __last, __result);
      }
    };

  template<typename _BI1, typename _BI2>
    inline _BI2
    __copy_backward_aux(_BI1 __first, _BI1 __last, _BI2 __result)
    {
      typedef typename __type_traits<typename iterator_traits<_BI2>::value_type>
                            ::has_trivial_assignment_operator _Trivial;
      return __copy_backward_dispatch<_BI1, _BI2, _Trivial>
                  ::copy(__first, __last, __result);
    }

  template <typename _BI1, typename _BI2>
    inline _BI2
    __copy_backward_output_normal_iterator(_BI1 __first, _BI1 __last,
                                           _BI2 __result, __true_type)
    { return _BI2(__copy_backward_aux(__first, __last, __result.base())); }

  template <typename _BI1, typename _BI2>
    inline _BI2
    __copy_backward_output_normal_iterator(_BI1 __first, _BI1 __last,
                                           _BI2 __result, __false_type)
    { return __copy_backward_aux(__first, __last, __result); }

  template <typename _BI1, typename _BI2>
    inline _BI2
    __copy_backward_input_normal_iterator(_BI1 __first, _BI1 __last,
                                          _BI2 __result, __true_type)
    {
      typedef typename _Is_normal_iterator<_BI2>::_Normal __Normal;
      return __copy_backward_output_normal_iterator(__first.base(), __last.base(),
                                                    __result, __Normal());
    }

  template <typename _BI1, typename _BI2>
    inline _BI2
    __copy_backward_input_normal_iterator(_BI1 __first, _BI1 __last,
                                          _BI2 __result, __false_type)
    {
      typedef typename _Is_normal_iterator<_BI2>::_Normal __Normal;
      return __copy_backward_output_normal_iterator(__first, __last, __result,
                                                    __Normal());
    }
# 477 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template <typename _BI1, typename _BI2>
    inline _BI2
    copy_backward(_BI1 __first, _BI1 __last, _BI2 __result)
    {

     
     
     



      typedef typename _Is_normal_iterator<_BI1>::_Normal __Normal;
      return __copy_backward_input_normal_iterator(__first, __last, __result,
                                                   __Normal());
    }
# 509 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _ForwardIter, typename _Tp>
    void
    fill(_ForwardIter __first, _ForwardIter __last, const _Tp& __value)
    {

     

      for ( ; __first != __last; ++__first)
        *__first = __value;
    }
# 531 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _OutputIter, typename _Size, typename _Tp>
    _OutputIter
    fill_n(_OutputIter __first, _Size __n, const _Tp& __value)
    {

     

      for ( ; __n > 0; --__n, ++__first)
        *__first = __value;
      return __first;
    }



  inline void
  fill(unsigned char* __first, unsigned char* __last, const unsigned char& __c)
  {
    unsigned char __tmp = __c;
    memset(__first, __tmp, __last - __first);
  }

  inline void
  fill(signed char* __first, signed char* __last, const signed char& __c)
  {
    signed char __tmp = __c;
    memset(__first, static_cast<unsigned char>(__tmp), __last - __first);
  }

  inline void
  fill(char* __first, char* __last, const char& __c)
  {
    char __tmp = __c;
    memset(__first, static_cast<unsigned char>(__tmp), __last - __first);
  }

  template<typename _Size>
    inline unsigned char*
    fill_n(unsigned char* __first, _Size __n, const unsigned char& __c)
    {
      fill(__first, __first + __n, __c);
      return __first + __n;
    }

  template<typename _Size>
    inline signed char*
    fill_n(char* __first, _Size __n, const signed char& __c)
    {
      fill(__first, __first + __n, __c);
      return __first + __n;
    }

  template<typename _Size>
    inline char*
    fill_n(char* __first, _Size __n, const char& __c)
    {
      fill(__first, __first + __n, __c);
      return __first + __n;
    }
# 606 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter1, typename _InputIter2>
    pair<_InputIter1, _InputIter2>
    mismatch(_InputIter1 __first1, _InputIter1 __last1,
             _InputIter2 __first2)
    {

     
     
     

     


      while (__first1 != __last1 && *__first1 == *__first2) {
        ++__first1;
        ++__first2;
      }
      return pair<_InputIter1, _InputIter2>(__first1, __first2);
    }
# 640 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _BinaryPredicate>
    pair<_InputIter1, _InputIter2>
    mismatch(_InputIter1 __first1, _InputIter1 __last1,
             _InputIter2 __first2,
             _BinaryPredicate __binary_pred)
    {

     
     

      while (__first1 != __last1 && __binary_pred(*__first1, *__first2)) {
        ++__first1;
        ++__first2;
      }
      return pair<_InputIter1, _InputIter2>(__first1, __first2);
    }
# 668 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter1, typename _InputIter2>
    inline bool
    equal(_InputIter1 __first1, _InputIter1 __last1,
          _InputIter2 __first2)
    {

     
     
     



      for ( ; __first1 != __last1; ++__first1, ++__first2)
        if (!(*__first1 == *__first2))
          return false;
      return true;
    }
# 699 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _BinaryPredicate>
    inline bool
    equal(_InputIter1 __first1, _InputIter1 __last1,
          _InputIter2 __first2,
          _BinaryPredicate __binary_pred)
    {

     
     

      for ( ; __first1 != __last1; ++__first1, ++__first2)
        if (!__binary_pred(*__first1, *__first2))
          return false;
      return true;
    }
# 732 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter1, typename _InputIter2>
    bool
    lexicographical_compare(_InputIter1 __first1, _InputIter1 __last1,
                            _InputIter2 __first2, _InputIter2 __last2)
    {

     
     
     

     


      for ( ; __first1 != __last1 && __first2 != __last2
            ; ++__first1, ++__first2) {
        if (*__first1 < *__first2)
          return true;
        if (*__first2 < *__first1)
          return false;
      }
      return __first1 == __last1 && __first2 != __last2;
    }
# 767 "/usr/include/c++3.1/bits/stl_algobase.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _Compare>
    bool
    lexicographical_compare(_InputIter1 __first1, _InputIter1 __last1,
                            _InputIter2 __first2, _InputIter2 __last2,
                            _Compare __comp)
    {

     
     

      for ( ; __first1 != __last1 && __first2 != __last2
            ; ++__first1, ++__first2) {
        if (__comp(*__first1, *__first2))
          return true;
        if (__comp(*__first2, *__first1))
          return false;
      }
      return __first1 == __last1 && __first2 != __last2;
    }

  inline bool
  lexicographical_compare(const unsigned char* __first1, const unsigned char* __last1,
                          const unsigned char* __first2, const unsigned char* __last2)
  {
    const size_t __len1 = __last1 - __first1;
    const size_t __len2 = __last2 - __first2;
    const int __result = memcmp(__first1, __first2, min(__len1, __len2));
    return __result != 0 ? __result < 0 : __len1 < __len2;
  }

  inline bool
  lexicographical_compare(const char* __first1, const char* __last1,
                          const char* __first2, const char* __last2)
  {

    return lexicographical_compare((const signed char*) __first1,
                                   (const signed char*) __last1,
                                   (const signed char*) __first2,
                                   (const signed char*) __last2);






  }

}
# 67 "/usr/include/c++3.1/algorithm" 2 3
# 1 "/usr/include/c++3.1/bits/stl_construct.h" 1 3
# 67 "/usr/include/c++3.1/bits/stl_construct.h" 3
namespace std
{






  template <class _T1, class _T2>
    inline void
    _Construct(_T1* __p, const _T2& __value)
    { new (static_cast<void*>(__p)) _T1(__value); }







  template <class _T1>
    inline void
    _Construct(_T1* __p)
    { new (static_cast<void*>(__p)) _T1(); }
# 98 "/usr/include/c++3.1/bits/stl_construct.h" 3
  template <class _ForwardIterator>
    inline void
    __destroy_aux(_ForwardIterator __first, _ForwardIterator __last, __false_type)
    { for ( ; __first != __last; ++__first) _Destroy(&*__first); }
# 112 "/usr/include/c++3.1/bits/stl_construct.h" 3
  template <class _ForwardIterator>
    inline void
    __destroy_aux(_ForwardIterator, _ForwardIterator, __true_type)
    { }






  template <class _Tp>
    inline void
    _Destroy(_Tp* __pointer)
    { __pointer->~_Tp(); }
# 134 "/usr/include/c++3.1/bits/stl_construct.h" 3
  template <class _ForwardIterator>
    inline void
    _Destroy(_ForwardIterator __first, _ForwardIterator __last)
    {
      typedef typename iterator_traits<_ForwardIterator>::value_type
                       _Value_type;
      typedef typename __type_traits<_Value_type>::has_trivial_destructor
                       _Has_trivial_destructor;

      __destroy_aux(__first, __last, _Has_trivial_destructor());
    }
}
# 68 "/usr/include/c++3.1/algorithm" 2 3
# 1 "/usr/include/c++3.1/bits/stl_uninitialized.h" 1 3
# 66 "/usr/include/c++3.1/bits/stl_uninitialized.h" 3
namespace std
{



  template<typename _InputIter, typename _ForwardIter>
    inline _ForwardIter
    __uninitialized_copy_aux(_InputIter __first, _InputIter __last,
                             _ForwardIter __result,
                             __true_type)
    { return copy(__first, __last, __result); }

  template<typename _InputIter, typename _ForwardIter>
    _ForwardIter
    __uninitialized_copy_aux(_InputIter __first, _InputIter __last,
                             _ForwardIter __result,
                             __false_type)
    {
      _ForwardIter __cur = __result;
      try {
        for ( ; __first != __last; ++__first, ++__cur)
          _Construct(&*__cur, *__first);
        return __cur;
      }
      catch(...)
        {
          _Destroy(__result, __cur);
          throw;
        }
    }
# 106 "/usr/include/c++3.1/bits/stl_uninitialized.h" 3
  template<typename _InputIter, typename _ForwardIter>
    inline _ForwardIter
    uninitialized_copy(_InputIter __first, _InputIter __last, _ForwardIter __result)
    {
      typedef typename iterator_traits<_InputIter>::value_type _ValueType;
      typedef typename __type_traits<_ValueType>::is_POD_type _Is_POD;
      return __uninitialized_copy_aux(__first, __last, __result, _Is_POD());
    }

  inline char*
  uninitialized_copy(const char* __first, const char* __last, char* __result)
  {
    memmove(__result, __first, __last - __first);
    return __result + (__last - __first);
  }

  inline wchar_t*
  uninitialized_copy(const wchar_t* __first, const wchar_t* __last,
                     wchar_t* __result)
  {
    memmove(__result, __first, sizeof(wchar_t) * (__last - __first));
    return __result + (__last - __first);
  }



  template<typename _ForwardIter, typename _Tp>
    inline void
    __uninitialized_fill_aux(_ForwardIter __first, _ForwardIter __last,
                             const _Tp& __x, __true_type)
    { fill(__first, __last, __x); }

  template<typename _ForwardIter, typename _Tp>
    void
    __uninitialized_fill_aux(_ForwardIter __first, _ForwardIter __last,
                             const _Tp& __x, __false_type)
    {
      _ForwardIter __cur = __first;
      try {
        for ( ; __cur != __last; ++__cur)
          _Construct(&*__cur, __x);
      }
      catch(...)
        {
          _Destroy(__first, __cur);
          throw;
        }
    }
# 164 "/usr/include/c++3.1/bits/stl_uninitialized.h" 3
  template<typename _ForwardIter, typename _Tp>
    inline void
    uninitialized_fill(_ForwardIter __first, _ForwardIter __last, const _Tp& __x)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename __type_traits<_ValueType>::is_POD_type _Is_POD;
      __uninitialized_fill_aux(__first, __last, __x, _Is_POD());
    }



  template<typename _ForwardIter, typename _Size, typename _Tp>
    inline _ForwardIter
    __uninitialized_fill_n_aux(_ForwardIter __first, _Size __n,
                               const _Tp& __x, __true_type)
    {
      return fill_n(__first, __n, __x);
    }

  template<typename _ForwardIter, typename _Size, typename _Tp>
    _ForwardIter
    __uninitialized_fill_n_aux(_ForwardIter __first, _Size __n,
                               const _Tp& __x, __false_type)
    {
      _ForwardIter __cur = __first;
      try {
        for ( ; __n > 0; --__n, ++__cur)
          _Construct(&*__cur, __x);
        return __cur;
      }
      catch(...)
        {
          _Destroy(__first, __cur);
          throw;
        }
    }
# 210 "/usr/include/c++3.1/bits/stl_uninitialized.h" 3
  template<typename _ForwardIter, typename _Size, typename _Tp>
    inline _ForwardIter
    uninitialized_fill_n(_ForwardIter __first, _Size __n, const _Tp& __x)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename __type_traits<_ValueType>::is_POD_type _Is_POD;
      return __uninitialized_fill_n_aux(__first, __n, __x, _Is_POD());
    }
# 227 "/usr/include/c++3.1/bits/stl_uninitialized.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _ForwardIter>
    inline _ForwardIter
    __uninitialized_copy_copy(_InputIter1 __first1, _InputIter1 __last1,
                              _InputIter2 __first2, _InputIter2 __last2,
                              _ForwardIter __result)
    {
      _ForwardIter __mid = uninitialized_copy(__first1, __last1, __result);
      try {
        return uninitialized_copy(__first2, __last2, __mid);
      }
      catch(...)
        {
          _Destroy(__result, __mid);
          throw;
        }
    }




  template<typename _ForwardIter, typename _Tp, typename _InputIter>
    inline _ForwardIter
    __uninitialized_fill_copy(_ForwardIter __result, _ForwardIter __mid,
                              const _Tp& __x,
                              _InputIter __first, _InputIter __last)
    {
      uninitialized_fill(__result, __mid, __x);
      try {
        return uninitialized_copy(__first, __last, __mid);
      }
      catch(...)
        {
          _Destroy(__result, __mid);
          throw;
        }
    }




  template<typename _InputIter, typename _ForwardIter, typename _Tp>
    inline void
    __uninitialized_copy_fill(_InputIter __first1, _InputIter __last1,
                              _ForwardIter __first2, _ForwardIter __last2,
                              const _Tp& __x)
    {
      _ForwardIter __mid2 = uninitialized_copy(__first1, __last1, __first2);
      try {
        uninitialized_fill(__mid2, __last2, __x);
      }
      catch(...)
        {
          _Destroy(__first2, __mid2);
          throw;
        }
    }

}
# 69 "/usr/include/c++3.1/algorithm" 2 3
# 1 "/usr/include/c++3.1/bits/stl_algo.h" 1 3
# 64 "/usr/include/c++3.1/bits/stl_algo.h" 3
# 1 "/usr/include/c++3.1/bits/stl_heap.h" 1 3
# 63 "/usr/include/c++3.1/bits/stl_heap.h" 3
namespace std
{



  template<typename _RandomAccessIterator, typename _Distance, typename _Tp>
    void
    __push_heap(_RandomAccessIterator __first,
                _Distance __holeIndex, _Distance __topIndex, _Tp __value)
    {
      _Distance __parent = (__holeIndex - 1) / 2;
      while (__holeIndex > __topIndex && *(__first + __parent) < __value) {
        *(__first + __holeIndex) = *(__first + __parent);
        __holeIndex = __parent;
        __parent = (__holeIndex - 1) / 2;
      }
      *(__first + __holeIndex) = __value;
    }

  template<typename _RandomAccessIterator>
    inline void
    push_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::value_type
          _ValueType;
      typedef typename iterator_traits<_RandomAccessIterator>::difference_type
          _DistanceType;


     

     

      __push_heap(__first, _DistanceType((__last - __first) - 1), _DistanceType(0),
                  _ValueType(*(__last - 1)));
    }

  template<typename _RandomAccessIterator, typename _Distance, typename _Tp,
            typename _Compare>
    void
    __push_heap(_RandomAccessIterator __first, _Distance __holeIndex,
                _Distance __topIndex, _Tp __value, _Compare __comp)
    {
      _Distance __parent = (__holeIndex - 1) / 2;
      while (__holeIndex > __topIndex && __comp(*(__first + __parent), __value)) {
        *(__first + __holeIndex) = *(__first + __parent);
        __holeIndex = __parent;
        __parent = (__holeIndex - 1) / 2;
      }
      *(__first + __holeIndex) = __value;
    }

  template<typename _RandomAccessIterator, typename _Compare>
    inline void
    push_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
              _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::value_type
          _ValueType;
      typedef typename iterator_traits<_RandomAccessIterator>::difference_type
          _DistanceType;


     


      __push_heap(__first, _DistanceType((__last - __first) - 1), _DistanceType(0),
                  _ValueType(*(__last - 1)), __comp);
    }

  template<typename _RandomAccessIterator, typename _Distance, typename _Tp>
    void
    __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex,
                  _Distance __len, _Tp __value)
    {
      _Distance __topIndex = __holeIndex;
      _Distance __secondChild = 2 * __holeIndex + 2;
      while (__secondChild < __len) {
        if (*(__first + __secondChild) < *(__first + (__secondChild - 1)))
          __secondChild--;
        *(__first + __holeIndex) = *(__first + __secondChild);
        __holeIndex = __secondChild;
        __secondChild = 2 * (__secondChild + 1);
      }
      if (__secondChild == __len) {
        *(__first + __holeIndex) = *(__first + (__secondChild - 1));
        __holeIndex = __secondChild - 1;
      }
      __push_heap(__first, __holeIndex, __topIndex, __value);
    }

  template<typename _RandomAccessIterator, typename _Tp>
    inline void
    __pop_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
               _RandomAccessIterator __result, _Tp __value)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::difference_type _Distance;
      *__result = *__first;
      __adjust_heap(__first, _Distance(0), _Distance(__last - __first), __value);
    }

  template<typename _RandomAccessIterator>
    inline void
    pop_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::value_type _ValueType;


     

     

      __pop_heap(__first, __last - 1, __last - 1, _ValueType(*(__last - 1)));
    }

  template<typename _RandomAccessIterator, typename _Distance,
           typename _Tp, typename _Compare>
    void
    __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex,
                  _Distance __len, _Tp __value, _Compare __comp)
    {
      _Distance __topIndex = __holeIndex;
      _Distance __secondChild = 2 * __holeIndex + 2;
      while (__secondChild < __len) {
        if (__comp(*(__first + __secondChild), *(__first + (__secondChild - 1))))
          __secondChild--;
        *(__first + __holeIndex) = *(__first + __secondChild);
        __holeIndex = __secondChild;
        __secondChild = 2 * (__secondChild + 1);
      }
      if (__secondChild == __len) {
        *(__first + __holeIndex) = *(__first + (__secondChild - 1));
        __holeIndex = __secondChild - 1;
      }
      __push_heap(__first, __holeIndex, __topIndex, __value, __comp);
    }

  template<typename _RandomAccessIterator, typename _Tp, typename _Compare>
    inline void
    __pop_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
               _RandomAccessIterator __result, _Tp __value, _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::difference_type _Distance;
      *__result = *__first;
      __adjust_heap(__first, _Distance(0), _Distance(__last - __first),
                    __value, __comp);
    }

  template<typename _RandomAccessIterator, typename _Compare>
    inline void
    pop_heap(_RandomAccessIterator __first,
             _RandomAccessIterator __last, _Compare __comp)
    {

     


      typedef typename iterator_traits<_RandomAccessIterator>::value_type _ValueType;
      __pop_heap(__first, __last - 1, __last - 1, _ValueType(*(__last - 1)), __comp);
    }

  template<typename _RandomAccessIterator>
    void
    make_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::value_type
          _ValueType;
      typedef typename iterator_traits<_RandomAccessIterator>::difference_type
          _DistanceType;


     

     

      if (__last - __first < 2) return;
      _DistanceType __len = __last - __first;
      _DistanceType __parent = (__len - 2)/2;

      while (true) {
        __adjust_heap(__first, __parent, __len, _ValueType(*(__first + __parent)));
        if (__parent == 0) return;
        __parent--;
      }
    }

  template<typename _RandomAccessIterator, typename _Compare>
    inline void
    make_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
              _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIterator>::value_type
          _ValueType;
      typedef typename iterator_traits<_RandomAccessIterator>::difference_type
          _DistanceType;


     


      if (__last - __first < 2) return;
      _DistanceType __len = __last - __first;
      _DistanceType __parent = (__len - 2)/2;

      while (true) {
        __adjust_heap(__first, __parent, __len,
                      _ValueType(*(__first + __parent)), __comp);
        if (__parent == 0) return;
        __parent--;
      }
    }

  template<typename _RandomAccessIterator>
    void
    sort_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)
    {

     

     


      while (__last - __first > 1)
        pop_heap(__first, __last--);
    }

  template<typename _RandomAccessIterator, typename _Compare>
    void
    sort_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
              _Compare __comp)
    {

     


      while (__last - __first > 1)
        pop_heap(__first, __last--, __comp);
    }

}
# 65 "/usr/include/c++3.1/bits/stl_algo.h" 2 3
# 1 "/usr/include/c++3.1/bits/stl_tempbuf.h" 1 3
# 64 "/usr/include/c++3.1/bits/stl_tempbuf.h" 3
namespace std
{
# 74 "/usr/include/c++3.1/bits/stl_tempbuf.h" 3
template <class _ForwardIterator, class _Tp>
  class _Temporary_buffer
{

 

  ptrdiff_t _M_original_len;
  ptrdiff_t _M_len;
  _Tp* _M_buffer;


  void _M_allocate_buffer() {
    _M_original_len = _M_len;
    _M_buffer = 0;

    if (_M_len > (ptrdiff_t)(2147483647 / sizeof(_Tp)))
      _M_len = 2147483647 / sizeof(_Tp);

    while (_M_len > 0) {
      _M_buffer = (_Tp*) malloc(_M_len * sizeof(_Tp));
      if (_M_buffer)
        break;
      _M_len /= 2;
    }
  }

  void _M_initialize_buffer(const _Tp&, __true_type) {}
  void _M_initialize_buffer(const _Tp& val, __false_type) {
    uninitialized_fill_n(_M_buffer, _M_len, val);
  }

public:

  ptrdiff_t size() const { return _M_len; }

  ptrdiff_t requested_size() const { return _M_original_len; }

  _Tp* begin() { return _M_buffer; }

  _Tp* end() { return _M_buffer + _M_len; }

  _Temporary_buffer(_ForwardIterator __first, _ForwardIterator __last) {

    typedef typename __type_traits<_Tp>::has_trivial_default_constructor
            _Trivial;

    try {
      _M_len = distance(__first, __last);
      _M_allocate_buffer();
      if (_M_len > 0)
        _M_initialize_buffer(*__first, _Trivial());
    }
    catch(...)
      {
        free(_M_buffer);
        _M_buffer = 0;
        _M_len = 0;
        throw;
      }
  }

  ~_Temporary_buffer() {
    _Destroy(_M_buffer, _M_buffer + _M_len);
    free(_M_buffer);
  }

private:

  _Temporary_buffer(const _Temporary_buffer&) {}
  void operator=(const _Temporary_buffer&) {}
};

}
# 66 "/usr/include/c++3.1/bits/stl_algo.h" 2 3



namespace std
{
# 84 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _Tp>
  inline const _Tp&
    __median(const _Tp& __a, const _Tp& __b, const _Tp& __c)
    {

     
      if (__a < __b)
        if (__b < __c)
          return __b;
        else if (__a < __c)
          return __c;
        else
          return __a;
      else if (__a < __c)
        return __a;
      else if (__b < __c)
        return __c;
      else
        return __b;
    }
# 118 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _Tp, typename _Compare>
    inline const _Tp&
    __median(const _Tp& __a, const _Tp& __b, const _Tp& __c, _Compare __comp)
    {

     
      if (__comp(__a, __b))
        if (__comp(__b, __c))
          return __b;
        else if (__comp(__a, __c))
          return __c;
        else
          return __a;
      else if (__comp(__a, __c))
        return __a;
      else if (__comp(__b, __c))
        return __c;
      else
        return __b;
    }
# 150 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _Function>
    _Function
    for_each(_InputIter __first, _InputIter __last, _Function __f)
    {

     
      for ( ; __first != __last; ++__first)
        __f(*__first);
      return __f;
    }






  template<typename _InputIter, typename _Tp>
    inline _InputIter
    find(_InputIter __first, _InputIter __last,
         const _Tp& __val,
         input_iterator_tag)
    {
      while (__first != __last && !(*__first == __val))
        ++__first;
      return __first;
    }






  template<typename _InputIter, typename _Predicate>
    inline _InputIter
    find_if(_InputIter __first, _InputIter __last,
            _Predicate __pred,
            input_iterator_tag)
    {
      while (__first != __last && !__pred(*__first))
        ++__first;
      return __first;
    }






  template<typename _RandomAccessIter, typename _Tp>
    _RandomAccessIter
    find(_RandomAccessIter __first, _RandomAccessIter __last,
         const _Tp& __val,
         random_access_iterator_tag)
    {
      typename iterator_traits<_RandomAccessIter>::difference_type __trip_count
        = (__last - __first) >> 2;

      for ( ; __trip_count > 0 ; --__trip_count) {
        if (*__first == __val) return __first;
        ++__first;

        if (*__first == __val) return __first;
        ++__first;

        if (*__first == __val) return __first;
        ++__first;

        if (*__first == __val) return __first;
        ++__first;
      }

      switch(__last - __first) {
      case 3:
        if (*__first == __val) return __first;
        ++__first;
      case 2:
        if (*__first == __val) return __first;
        ++__first;
      case 1:
        if (*__first == __val) return __first;
        ++__first;
      case 0:
      default:
        return __last;
      }
    }






  template<typename _RandomAccessIter, typename _Predicate>
    _RandomAccessIter
    find_if(_RandomAccessIter __first, _RandomAccessIter __last,
            _Predicate __pred,
            random_access_iterator_tag)
    {
      typename iterator_traits<_RandomAccessIter>::difference_type __trip_count
        = (__last - __first) >> 2;

      for ( ; __trip_count > 0 ; --__trip_count) {
        if (__pred(*__first)) return __first;
        ++__first;

        if (__pred(*__first)) return __first;
        ++__first;

        if (__pred(*__first)) return __first;
        ++__first;

        if (__pred(*__first)) return __first;
        ++__first;
      }

      switch(__last - __first) {
      case 3:
        if (__pred(*__first)) return __first;
        ++__first;
      case 2:
        if (__pred(*__first)) return __first;
        ++__first;
      case 1:
        if (__pred(*__first)) return __first;
        ++__first;
      case 0:
      default:
        return __last;
      }
    }
# 289 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _Tp>
    inline _InputIter
    find(_InputIter __first, _InputIter __last,
         const _Tp& __val)
    {

     
     

      return find(__first, __last, __val, __iterator_category(__first));
    }
# 309 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _Predicate>
    inline _InputIter
    find_if(_InputIter __first, _InputIter __last,
            _Predicate __pred)
    {

     
     

      return find_if(__first, __last, __pred, __iterator_category(__first));
    }
# 329 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter>
    _ForwardIter
    adjacent_find(_ForwardIter __first, _ForwardIter __last)
    {

     
     

      if (__first == __last)
        return __last;
      _ForwardIter __next = __first;
      while(++__next != __last) {
        if (*__first == *__next)
          return __first;
        __first = __next;
      }
      return __last;
    }
# 358 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _BinaryPredicate>
    _ForwardIter
    adjacent_find(_ForwardIter __first, _ForwardIter __last,
                  _BinaryPredicate __binary_pred)
    {

     
     


      if (__first == __last)
        return __last;
      _ForwardIter __next = __first;
      while(++__next != __last) {
        if (__binary_pred(*__first, *__next))
          return __first;
        __first = __next;
      }
      return __last;
    }
# 387 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _Tp>
    typename iterator_traits<_InputIter>::difference_type
    count(_InputIter __first, _InputIter __last, const _Tp& __value)
    {

     
     

     
      typename iterator_traits<_InputIter>::difference_type __n = 0;
      for ( ; __first != __last; ++__first)
        if (*__first == __value)
          ++__n;
      return __n;
    }
# 411 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _Predicate>
    typename iterator_traits<_InputIter>::difference_type
    count_if(_InputIter __first, _InputIter __last, _Predicate __pred)
    {

     
     

      typename iterator_traits<_InputIter>::difference_type __n = 0;
      for ( ; __first != __last; ++__first)
        if (__pred(*__first))
          ++__n;
      return __n;
    }
# 450 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter1, typename _ForwardIter2>
    _ForwardIter1
    search(_ForwardIter1 __first1, _ForwardIter1 __last1,
           _ForwardIter2 __first2, _ForwardIter2 __last2)
    {

     
     
     




      if (__first1 == __last1 || __first2 == __last2)
        return __first1;


      _ForwardIter2 __tmp(__first2);
      ++__tmp;
      if (__tmp == __last2)
        return find(__first1, __last1, *__first2);



      _ForwardIter2 __p1, __p;

      __p1 = __first2; ++__p1;

      _ForwardIter1 __current = __first1;

      while (__first1 != __last1) {
        __first1 = find(__first1, __last1, *__first2);
        if (__first1 == __last1)
          return __last1;

        __p = __p1;
        __current = __first1;
        if (++__current == __last1)
          return __last1;

        while (*__current == *__p) {
          if (++__p == __last2)
            return __first1;
          if (++__current == __last1)
            return __last1;
        }

        ++__first1;
      }
      return __first1;
    }
# 522 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter1, typename _ForwardIter2, typename _BinaryPred>
    _ForwardIter1
    search(_ForwardIter1 __first1, _ForwardIter1 __last1,
           _ForwardIter2 __first2, _ForwardIter2 __last2,
           _BinaryPred __predicate)
    {

     
     
     




      if (__first1 == __last1 || __first2 == __last2)
        return __first1;


      _ForwardIter2 __tmp(__first2);
      ++__tmp;
      if (__tmp == __last2) {
        while (__first1 != __last1 && !__predicate(*__first1, *__first2))
          ++__first1;
        return __first1;
      }



      _ForwardIter2 __p1, __p;

      __p1 = __first2; ++__p1;

      _ForwardIter1 __current = __first1;

      while (__first1 != __last1) {
        while (__first1 != __last1) {
          if (__predicate(*__first1, *__first2))
            break;
          ++__first1;
        }
        while (__first1 != __last1 && !__predicate(*__first1, *__first2))
          ++__first1;
        if (__first1 == __last1)
          return __last1;

        __p = __p1;
        __current = __first1;
        if (++__current == __last1) return __last1;

        while (__predicate(*__current, *__p)) {
          if (++__p == __last2)
            return __first1;
          if (++__current == __last1)
            return __last1;
        }

        ++__first1;
      }
      return __first1;
    }
# 596 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Integer, typename _Tp>
    _ForwardIter
    search_n(_ForwardIter __first, _ForwardIter __last,
             _Integer __count, const _Tp& __val)
    {

     
     

     

      if (__count <= 0)
        return __first;
      else {
        __first = find(__first, __last, __val);
        while (__first != __last) {
          _Integer __n = __count - 1;
          _ForwardIter __i = __first;
          ++__i;
          while (__i != __last && __n != 0 && *__i == __val) {
            ++__i;
            --__n;
          }
          if (__n == 0)
            return __first;
          else
            __first = find(__i, __last, __val);
        }
        return __last;
      }
    }
# 643 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Integer, typename _Tp,
           typename _BinaryPred>
    _ForwardIter
    search_n(_ForwardIter __first, _ForwardIter __last,
             _Integer __count, const _Tp& __val,
             _BinaryPred __binary_pred)
    {

     
     


      if (__count <= 0)
        return __first;
      else {
        while (__first != __last) {
          if (__binary_pred(*__first, __val))
            break;
          ++__first;
        }
        while (__first != __last) {
          _Integer __n = __count - 1;
          _ForwardIter __i = __first;
          ++__i;
          while (__i != __last && __n != 0 && __binary_pred(*__i, __val)) {
            ++__i;
            --__n;
          }
          if (__n == 0)
            return __first;
          else {
            while (__i != __last) {
              if (__binary_pred(*__i, __val))
                break;
              ++__i;
            }
            __first = __i;
          }
        }
        return __last;
      }
    }
# 697 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter1, typename _ForwardIter2>
    _ForwardIter2
    swap_ranges(_ForwardIter1 __first1, _ForwardIter1 __last1,
                _ForwardIter2 __first2)
    {

     
     
     


     



      for ( ; __first1 != __last1; ++__first1, ++__first2)
        iter_swap(__first1, __first2);
      return __first2;
    }
# 732 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _UnaryOperation>
    _OutputIter
    transform(_InputIter __first, _InputIter __last,
              _OutputIter __result, _UnaryOperation __unary_op)
    {

     
     



      for ( ; __first != __last; ++__first, ++__result)
        *__result = __unary_op(*__first);
      return __result;
    }
# 765 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _OutputIter,
           typename _BinaryOperation>
    _OutputIter
    transform(_InputIter1 __first1, _InputIter1 __last1,
              _InputIter2 __first2, _OutputIter __result,
              _BinaryOperation __binary_op)
    {

     
     
     



      for ( ; __first1 != __last1; ++__first1, ++__first2, ++__result)
        *__result = __binary_op(*__first1, *__first2);
      return __result;
    }
# 796 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp>
    void
    replace(_ForwardIter __first, _ForwardIter __last,
            const _Tp& __old_value, const _Tp& __new_value)
    {

     
     

     


      for ( ; __first != __last; ++__first)
        if (*__first == __old_value)
          *__first = __new_value;
    }
# 825 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Predicate, typename _Tp>
    void
    replace_if(_ForwardIter __first, _ForwardIter __last,
               _Predicate __pred, const _Tp& __new_value)
    {

     
     

     


      for ( ; __first != __last; ++__first)
        if (__pred(*__first))
          *__first = __new_value;
    }
# 856 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _Tp>
    _OutputIter
    replace_copy(_InputIter __first, _InputIter __last,
                 _OutputIter __result,
                 const _Tp& __old_value, const _Tp& __new_value)
    {

     
     

     


      for ( ; __first != __last; ++__first, ++__result)
        *__result = *__first == __old_value ? __new_value : *__first;
      return __result;
    }
# 888 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _Predicate,
           typename _Tp>
    _OutputIter
    replace_copy_if(_InputIter __first, _InputIter __last,
                    _OutputIter __result,
                    _Predicate __pred, const _Tp& __new_value)
    {

     
     

     


      for ( ; __first != __last; ++__first, ++__result)
        *__result = __pred(*__first) ? __new_value : *__first;
      return __result;
    }
# 918 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Generator>
    void
    generate(_ForwardIter __first, _ForwardIter __last, _Generator __gen)
    {

     
     


      for ( ; __first != __last; ++__first)
        *__first = __gen();
    }
# 942 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _OutputIter, typename _Size, typename _Generator>
    _OutputIter
    generate_n(_OutputIter __first, _Size __n, _Generator __gen)
    {

     



      for ( ; __n > 0; --__n, ++__first)
        *__first = __gen();
      return __first;
    }
# 969 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _Tp>
    _OutputIter
    remove_copy(_InputIter __first, _InputIter __last,
                _OutputIter __result, const _Tp& __value)
    {

     
     

     


      for ( ; __first != __last; ++__first)
        if (!(*__first == __value)) {
          *__result = *__first;
          ++__result;
        }
      return __result;
    }
# 1003 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _Predicate>
    _OutputIter
    remove_copy_if(_InputIter __first, _InputIter __last,
                   _OutputIter __result, _Predicate __pred)
    {

     
     

     


      for ( ; __first != __last; ++__first)
        if (!__pred(*__first)) {
          *__result = *__first;
          ++__result;
        }
      return __result;
    }
# 1039 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp>
    _ForwardIter
    remove(_ForwardIter __first, _ForwardIter __last,
           const _Tp& __value)
    {

     
     

     


      __first = find(__first, __last, __value);
      _ForwardIter __i = __first;
      return __first == __last ? __first
                               : remove_copy(++__i, __last, __first, __value);
    }
# 1073 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Predicate>
    _ForwardIter
    remove_if(_ForwardIter __first, _ForwardIter __last,
              _Predicate __pred)
    {

     
     


      __first = find_if(__first, __last, __pred);
      _ForwardIter __i = __first;
      return __first == __last ? __first
                               : remove_copy_if(++__i, __last, __first, __pred);
    }







  template<typename _InputIter, typename _OutputIter>
    _OutputIter
    __unique_copy(_InputIter __first, _InputIter __last,
                  _OutputIter __result,
                  output_iterator_tag)
    {

      typename iterator_traits<_InputIter>::value_type __value = *__first;
      *__result = __value;
      while (++__first != __last)
        if (!(__value == *__first)) {
          __value = *__first;
          *++__result = __value;
        }
      return ++__result;
    }







  template<typename _InputIter, typename _ForwardIter>
    _ForwardIter
    __unique_copy(_InputIter __first, _InputIter __last,
                  _ForwardIter __result,
                  forward_iterator_tag)
    {

      *__result = *__first;
      while (++__first != __last)
        if (!(*__result == *__first))
          *++__result = *__first;
      return ++__result;
    }
# 1145 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter>
    inline _OutputIter
    unique_copy(_InputIter __first, _InputIter __last,
                _OutputIter __result)
    {

     
     

     


      typedef typename iterator_traits<_OutputIter>::iterator_category _IterType;

      if (__first == __last) return __result;
      return __unique_copy(__first, __last, __result, _IterType());
    }
# 1170 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _BinaryPredicate>
    _OutputIter
    __unique_copy(_InputIter __first, _InputIter __last,
                  _OutputIter __result,
                  _BinaryPredicate __binary_pred,
                  output_iterator_tag)
    {

     



      typename iterator_traits<_InputIter>::value_type __value = *__first;
      *__result = __value;
      while (++__first != __last)
        if (!__binary_pred(__value, *__first)) {
          __value = *__first;
          *++__result = __value;
        }
      return ++__result;
    }
# 1199 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _ForwardIter, typename _BinaryPredicate>
    _ForwardIter
    __unique_copy(_InputIter __first, _InputIter __last,
                  _ForwardIter __result,
                  _BinaryPredicate __binary_pred,
                  forward_iterator_tag)
    {

     



      *__result = *__first;
      while (++__first != __last)
        if (!__binary_pred(*__result, *__first)) *++__result = *__first;
      return ++__result;
    }
# 1232 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _OutputIter, typename _BinaryPredicate>
    inline _OutputIter
    unique_copy(_InputIter __first, _InputIter __last,
                _OutputIter __result,
                _BinaryPredicate __binary_pred)
    {

     
     


      typedef typename iterator_traits<_OutputIter>::iterator_category _IterType;

      if (__first == __last) return __result;
      return __unique_copy(__first, __last,
__result, __binary_pred, _IterType());
    }
# 1263 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter>
    _ForwardIter
    unique(_ForwardIter __first, _ForwardIter __last)
    {

         
         


          __first = adjacent_find(__first, __last);
          return unique_copy(__first, __last, __first);
    }
# 1290 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _BinaryPredicate>
    _ForwardIter
    unique(_ForwardIter __first, _ForwardIter __last,
           _BinaryPredicate __binary_pred)
    {

     
     



      __first = adjacent_find(__first, __last, __binary_pred);
      return unique_copy(__first, __last, __first, __binary_pred);
    }







  template<typename _BidirectionalIter>
    void
    __reverse(_BidirectionalIter __first, _BidirectionalIter __last,
                          bidirectional_iterator_tag)
    {
          while (true)
            if (__first == __last || __first == --__last)
                  return;
            else
                  iter_swap(__first++, __last);
    }







  template<typename _RandomAccessIter>
    void
    __reverse(_RandomAccessIter __first, _RandomAccessIter __last,
                          random_access_iterator_tag)
    {
          while (__first < __last)
            iter_swap(__first++, --__last);
    }
# 1349 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _BidirectionalIter>
    inline void
    reverse(_BidirectionalIter __first, _BidirectionalIter __last)
    {

         

          __reverse(__first, __last, __iterator_category(__first));
    }
# 1374 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _BidirectionalIter, typename _OutputIter>
    _OutputIter
    reverse_copy(_BidirectionalIter __first, _BidirectionalIter __last,
                             _OutputIter __result)
    {

     
     


      while (__first != __last) {
        --__last;
        *__result = *__last;
        ++__result;
      }
      return __result;
    }
# 1399 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _EuclideanRingElement>
    _EuclideanRingElement
    __gcd(_EuclideanRingElement __m, _EuclideanRingElement __n)
    {
      while (__n != 0) {
        _EuclideanRingElement __t = __m % __n;
        __m = __n;
        __n = __t;
      }
      return __m;
    }






  template<typename _ForwardIter>
    void
    __rotate(_ForwardIter __first,
             _ForwardIter __middle,
             _ForwardIter __last,
              forward_iterator_tag)
    {
      if ((__first == __middle) || (__last == __middle))
        return;

      _ForwardIter __first2 = __middle;
      do {
        swap(*__first++, *__first2++);
        if (__first == __middle)
          __middle = __first2;
      } while (__first2 != __last);

      __first2 = __middle;

      while (__first2 != __last) {
        swap(*__first++, *__first2++);
        if (__first == __middle)
          __middle = __first2;
        else if (__first2 == __last)
          __first2 = __middle;
      }
    }






  template<typename _BidirectionalIter>
    void
    __rotate(_BidirectionalIter __first,
             _BidirectionalIter __middle,
             _BidirectionalIter __last,
              bidirectional_iterator_tag)
    {

     


      if ((__first == __middle) || (__last == __middle))
        return;

      __reverse(__first, __middle, bidirectional_iterator_tag());
      __reverse(__middle, __last, bidirectional_iterator_tag());

      while (__first != __middle && __middle != __last)
        swap (*__first++, *--__last);

      if (__first == __middle) {
        __reverse(__middle, __last, bidirectional_iterator_tag());
      }
      else {
        __reverse(__first, __middle, bidirectional_iterator_tag());
      }
    }






  template<typename _RandomAccessIter>
    void
    __rotate(_RandomAccessIter __first,
             _RandomAccessIter __middle,
             _RandomAccessIter __last,
             random_access_iterator_tag)
    {

     


      if ((__first == __middle) || (__last == __middle))
        return;

      typedef typename iterator_traits<_RandomAccessIter>::difference_type _Distance;
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;

      _Distance __n = __last - __first;
      _Distance __k = __middle - __first;
      _Distance __l = __n - __k;

      if (__k == __l) {
        swap_ranges(__first, __middle, __middle);
        return;
      }

      _Distance __d = __gcd(__n, __k);

      for (_Distance __i = 0; __i < __d; __i++) {
        _ValueType __tmp = *__first;
        _RandomAccessIter __p = __first;

        if (__k < __l) {
          for (_Distance __j = 0; __j < __l/__d; __j++) {
            if (__p > __first + __l) {
              *__p = *(__p - __l);
              __p -= __l;
            }

            *__p = *(__p + __k);
            __p += __k;
          }
        }

        else {
          for (_Distance __j = 0; __j < __k/__d - 1; __j ++) {
            if (__p < __last - __k) {
              *__p = *(__p + __k);
              __p += __k;
            }

            *__p = * (__p - __l);
            __p -= __l;
          }
        }

        *__p = __tmp;
        ++__first;
      }
    }
# 1561 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter>
    inline void
    rotate(_ForwardIter __first, _ForwardIter __middle, _ForwardIter __last)
    {

     

      typedef typename iterator_traits<_ForwardIter>::iterator_category _IterType;
      __rotate(__first, __middle, __last, _IterType());
    }
# 1589 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _OutputIter>
    _OutputIter
    rotate_copy(_ForwardIter __first, _ForwardIter __middle,
                _ForwardIter __last, _OutputIter __result)
    {

     
     


      return copy(__first, __middle, copy(__middle, __last, __result));
    }
# 1612 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _Distance>
    inline _Distance
    __random_number(_Distance __n)
    {

      return lrand48() % __n;



    }
# 1634 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter>
    inline void
    random_shuffle(_RandomAccessIter __first, _RandomAccessIter __last)
    {

     


      if (__first == __last) return;
      for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
        iter_swap(__i, __first + __random_number((__i - __first) + 1));
    }
# 1660 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter, typename _RandomNumberGenerator>
    void
    random_shuffle(_RandomAccessIter __first, _RandomAccessIter __last,
                   _RandomNumberGenerator& __rand)
    {

     


      if (__first == __last) return;
      for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
        iter_swap(__i, __first + __rand((__i - __first) + 1));
    }







  template<typename _ForwardIter, typename _Predicate>
    _ForwardIter
    __partition(_ForwardIter __first, _ForwardIter __last,
                _Predicate __pred,
                forward_iterator_tag)
    {
      if (__first == __last) return __first;

      while (__pred(*__first))
        if (++__first == __last) return __first;

      _ForwardIter __next = __first;

      while (++__next != __last)
        if (__pred(*__next)) {
          swap(*__first, *__next);
          ++__first;
        }

      return __first;
    }






  template<typename _BidirectionalIter, typename _Predicate>
    _BidirectionalIter
    __partition(_BidirectionalIter __first, _BidirectionalIter __last,
                _Predicate __pred,
                bidirectional_iterator_tag)
    {
      while (true) {
        while (true)
          if (__first == __last)
            return __first;
          else if (__pred(*__first))
            ++__first;
          else
            break;
        --__last;
        while (true)
          if (__first == __last)
            return __first;
          else if (!__pred(*__last))
            --__last;
          else
            break;
        iter_swap(__first, __last);
        ++__first;
      }
    }
# 1748 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Predicate>
    inline _ForwardIter
    partition(_ForwardIter __first, _ForwardIter __last,
              _Predicate __pred)
    {

     
     


      return __partition(__first, __last, __pred, __iterator_category(__first));
    }







  template<typename _ForwardIter, typename _Predicate, typename _Distance>
    _ForwardIter
    __inplace_stable_partition(_ForwardIter __first, _ForwardIter __last,
                               _Predicate __pred, _Distance __len)
    {
      if (__len == 1)
        return __pred(*__first) ? __last : __first;
      _ForwardIter __middle = __first;
      advance(__middle, __len / 2);
      _ForwardIter __begin = __inplace_stable_partition(__first, __middle,
                                                        __pred,
                                                        __len / 2);
      _ForwardIter __end = __inplace_stable_partition(__middle, __last,
                                                      __pred,
                                                      __len - __len / 2);
      rotate(__begin, __middle, __end);
      advance(__begin, distance(__middle, __end));
      return __begin;
    }






  template<typename _ForwardIter, typename _Pointer, typename _Predicate,
           typename _Distance>
    _ForwardIter
    __stable_partition_adaptive(_ForwardIter __first, _ForwardIter __last,
                                _Predicate __pred, _Distance __len,
                                _Pointer __buffer,
                                _Distance __buffer_size)
    {
      if (__len <= __buffer_size) {
        _ForwardIter __result1 = __first;
        _Pointer __result2 = __buffer;
        for ( ; __first != __last ; ++__first)
          if (__pred(*__first)) {
            *__result1 = *__first;
            ++__result1;
          }
          else {
            *__result2 = *__first;
            ++__result2;
          }
        copy(__buffer, __result2, __result1);
        return __result1;
      }
      else {
        _ForwardIter __middle = __first;
        advance(__middle, __len / 2);
        _ForwardIter __begin = __stable_partition_adaptive(__first, __middle,
                                                           __pred,
                                                           __len / 2,
                                                           __buffer, __buffer_size);
        _ForwardIter __end = __stable_partition_adaptive( __middle, __last,
                                                          __pred,
                                                          __len - __len / 2,
                                                          __buffer, __buffer_size);
        rotate(__begin, __middle, __end);
        advance(__begin, distance(__middle, __end));
        return __begin;
      }
    }
# 1848 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Predicate>
    _ForwardIter
    stable_partition(_ForwardIter __first, _ForwardIter __last,
                     _Predicate __pred)
    {

     
     


      if (__first == __last)
        return __first;
      else
      {
        typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
        typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;

        _Temporary_buffer<_ForwardIter, _ValueType> __buf(__first, __last);
        if (__buf.size() > 0)
          return __stable_partition_adaptive(__first, __last, __pred,
                                             _DistanceType(__buf.requested_size()),
                                             __buf.begin(), __buf.size());
        else
          return __inplace_stable_partition(__first, __last, __pred,
                                            _DistanceType(__buf.requested_size()));
      }
    }






  template<typename _RandomAccessIter, typename _Tp>
    _RandomAccessIter
    __unguarded_partition(_RandomAccessIter __first, _RandomAccessIter __last,
                          _Tp __pivot)
    {
      while (true) {
        while (*__first < __pivot)
          ++__first;
        --__last;
        while (__pivot < *__last)
          --__last;
        if (!(__first < __last))
          return __first;
        iter_swap(__first, __last);
        ++__first;
      }
    }






  template<typename _RandomAccessIter, typename _Tp, typename _Compare>
    _RandomAccessIter
    __unguarded_partition(_RandomAccessIter __first, _RandomAccessIter __last,
                          _Tp __pivot, _Compare __comp)
    {
      while (true) {
        while (__comp(*__first, __pivot))
          ++__first;
        --__last;
        while (__comp(__pivot, *__last))
          --__last;
        if (!(__first < __last))
          return __first;
        iter_swap(__first, __last);
        ++__first;
      }
    }
# 1929 "/usr/include/c++3.1/bits/stl_algo.h" 3
  enum { _M_threshold = 16 };






  template<typename _RandomAccessIter, typename _Tp>
    void
    __unguarded_linear_insert(_RandomAccessIter __last, _Tp __val)
    {
      _RandomAccessIter __next = __last;
      --__next;
      while (__val < *__next) {
        *__last = *__next;
        __last = __next;
        --__next;
      }
      *__last = __val;
    }






  template<typename _RandomAccessIter, typename _Tp, typename _Compare>
    void
    __unguarded_linear_insert(_RandomAccessIter __last, _Tp __val, _Compare __comp)
    {
      _RandomAccessIter __next = __last;
      --__next;
      while (__comp(__val, *__next)) {
        *__last = *__next;
        __last = __next;
        --__next;
      }
      *__last = __val;
    }






  template<typename _RandomAccessIter>
    void
    __insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last)
    {
      if (__first == __last) return;

      for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
      {
        typename iterator_traits<_RandomAccessIter>::value_type __val = *__i;
        if (__val < *__first) {
          copy_backward(__first, __i, __i + 1);
          *__first = __val;
        }
        else
          __unguarded_linear_insert(__i, __val);
      }
    }






  template<typename _RandomAccessIter, typename _Compare>
    void
    __insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last,
                     _Compare __comp)
    {
      if (__first == __last) return;

      for (_RandomAccessIter __i = __first + 1; __i != __last; ++__i)
      {
        typename iterator_traits<_RandomAccessIter>::value_type __val = *__i;
        if (__comp(__val, *__first)) {
          copy_backward(__first, __i, __i + 1);
          *__first = __val;
        }
        else
          __unguarded_linear_insert(__i, __val, __comp);
      }
    }






  template<typename _RandomAccessIter>
    inline void
    __unguarded_insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;

      for (_RandomAccessIter __i = __first; __i != __last; ++__i)
        __unguarded_linear_insert(__i, _ValueType(*__i));
    }






  template<typename _RandomAccessIter, typename _Compare>
    inline void
    __unguarded_insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last,
                               _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;

      for (_RandomAccessIter __i = __first; __i != __last; ++__i)
        __unguarded_linear_insert(__i, _ValueType(*__i), __comp);
    }






  template<typename _RandomAccessIter>
    void
    __final_insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last)
    {
      if (__last - __first > _M_threshold) {
        __insertion_sort(__first, __first + _M_threshold);
        __unguarded_insertion_sort(__first + _M_threshold, __last);
      }
      else
        __insertion_sort(__first, __last);
    }






  template<typename _RandomAccessIter, typename _Compare>
    void
    __final_insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last,
                           _Compare __comp)
    {
      if (__last - __first > _M_threshold) {
        __insertion_sort(__first, __first + _M_threshold, __comp);
        __unguarded_insertion_sort(__first + _M_threshold, __last, __comp);
      }
      else
        __insertion_sort(__first, __last, __comp);
    }






  template<typename _Size>
    inline _Size
    __lg(_Size __n)
    {
      _Size __k;
      for (__k = 0; __n != 1; __n >>= 1) ++__k;
      return __k;
    }






  template<typename _RandomAccessIter, typename _Size>
    void
    __introsort_loop(_RandomAccessIter __first, _RandomAccessIter __last,
                     _Size __depth_limit)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;

      while (__last - __first > _M_threshold) {
        if (__depth_limit == 0) {
          partial_sort(__first, __last, __last);
          return;
        }
        --__depth_limit;
        _RandomAccessIter __cut =
          __unguarded_partition(__first, __last,
                                _ValueType(__median(*__first,
                                                    *(__first + (__last - __first)/2),
                                                    *(__last - 1))));
        __introsort_loop(__cut, __last, __depth_limit);
        __last = __cut;
      }
    }






  template<typename _RandomAccessIter, typename _Size, typename _Compare>
    void
    __introsort_loop(_RandomAccessIter __first, _RandomAccessIter __last,
                     _Size __depth_limit, _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;

      while (__last - __first > _M_threshold) {
        if (__depth_limit == 0) {
          partial_sort(__first, __last, __last, __comp);
          return;
        }
        --__depth_limit;
        _RandomAccessIter __cut =
          __unguarded_partition(__first, __last,
                                _ValueType(__median(*__first,
                                                    *(__first + (__last - __first)/2),
                                                    *(__last - 1), __comp)),
           __comp);
        __introsort_loop(__cut, __last, __depth_limit, __comp);
        __last = __cut;
      }
    }
# 2166 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter>
    inline void
    sort(_RandomAccessIter __first, _RandomAccessIter __last)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;


     

     

      if (__first != __last) {
        __introsort_loop(__first, __last, __lg(__last - __first) * 2);
        __final_insertion_sort(__first, __last);
      }
    }
# 2197 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter, typename _Compare>
    inline void
    sort(_RandomAccessIter __first, _RandomAccessIter __last, _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;


     

     

      if (__first != __last) {
        __introsort_loop(__first, __last, __lg(__last - __first) * 2, __comp);
        __final_insertion_sort(__first, __last, __comp);
      }
    }







  template<typename _RandomAccessIter>
    void
    __inplace_stable_sort(_RandomAccessIter __first, _RandomAccessIter __last)
    {
      if (__last - __first < 15) {
        __insertion_sort(__first, __last);
        return;
      }
      _RandomAccessIter __middle = __first + (__last - __first) / 2;
      __inplace_stable_sort(__first, __middle);
      __inplace_stable_sort(__middle, __last);
      __merge_without_buffer(__first, __middle, __last,
                             __middle - __first,
                             __last - __middle);
    }






  template<typename _RandomAccessIter, typename _Compare>
    void
    __inplace_stable_sort(_RandomAccessIter __first, _RandomAccessIter __last,
                          _Compare __comp)
    {
      if (__last - __first < 15) {
        __insertion_sort(__first, __last, __comp);
        return;
      }
      _RandomAccessIter __middle = __first + (__last - __first) / 2;
      __inplace_stable_sort(__first, __middle, __comp);
      __inplace_stable_sort(__middle, __last, __comp);
      __merge_without_buffer(__first, __middle, __last,
                             __middle - __first,
                             __last - __middle,
                             __comp);
    }

  template<typename _RandomAccessIter1, typename _RandomAccessIter2,
           typename _Distance>
    void
    __merge_sort_loop(_RandomAccessIter1 __first, _RandomAccessIter1 __last,
                      _RandomAccessIter2 __result, _Distance __step_size)
    {
      _Distance __two_step = 2 * __step_size;

      while (__last - __first >= __two_step) {
        __result = merge(__first, __first + __step_size,
                         __first + __step_size, __first + __two_step,
                         __result);
        __first += __two_step;
      }

      __step_size = min(_Distance(__last - __first), __step_size);
      merge(__first, __first + __step_size, __first + __step_size, __last,
            __result);
    }

  template<typename _RandomAccessIter1, typename _RandomAccessIter2,
           typename _Distance, typename _Compare>
    void
    __merge_sort_loop(_RandomAccessIter1 __first, _RandomAccessIter1 __last,
                      _RandomAccessIter2 __result, _Distance __step_size,
                      _Compare __comp)
    {
      _Distance __two_step = 2 * __step_size;

      while (__last - __first >= __two_step) {
        __result = merge(__first, __first + __step_size,
                         __first + __step_size, __first + __two_step,
                         __result,
                         __comp);
        __first += __two_step;
      }
      __step_size = min(_Distance(__last - __first), __step_size);

      merge(__first, __first + __step_size,
            __first + __step_size, __last,
            __result,
            __comp);
    }

  enum { _M_chunk_size = 7 };

  template<typename _RandomAccessIter, typename _Distance>
    void
    __chunk_insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last,
                           _Distance __chunk_size)
    {
      while (__last - __first >= __chunk_size) {
        __insertion_sort(__first, __first + __chunk_size);
        __first += __chunk_size;
      }
      __insertion_sort(__first, __last);
    }

  template<typename _RandomAccessIter, typename _Distance, typename _Compare>
    void
    __chunk_insertion_sort(_RandomAccessIter __first, _RandomAccessIter __last,
                           _Distance __chunk_size, _Compare __comp)
    {
      while (__last - __first >= __chunk_size) {
        __insertion_sort(__first, __first + __chunk_size, __comp);
        __first += __chunk_size;
      }
      __insertion_sort(__first, __last, __comp);
    }

  template<typename _RandomAccessIter, typename _Pointer>
    void
    __merge_sort_with_buffer(_RandomAccessIter __first, _RandomAccessIter __last,
                             _Pointer __buffer)
    {
      typedef typename iterator_traits<_RandomAccessIter>::difference_type _Distance;

      _Distance __len = __last - __first;
      _Pointer __buffer_last = __buffer + __len;

      _Distance __step_size = _M_chunk_size;
      __chunk_insertion_sort(__first, __last, __step_size);

      while (__step_size < __len) {
        __merge_sort_loop(__first, __last, __buffer, __step_size);
        __step_size *= 2;
        __merge_sort_loop(__buffer, __buffer_last, __first, __step_size);
        __step_size *= 2;
      }
    }

  template<typename _RandomAccessIter, typename _Pointer, typename _Compare>
    void
    __merge_sort_with_buffer(_RandomAccessIter __first, _RandomAccessIter __last,
                             _Pointer __buffer, _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::difference_type _Distance;

      _Distance __len = __last - __first;
      _Pointer __buffer_last = __buffer + __len;

      _Distance __step_size = _M_chunk_size;
      __chunk_insertion_sort(__first, __last, __step_size, __comp);

      while (__step_size < __len) {
        __merge_sort_loop(__first, __last, __buffer, __step_size, __comp);
        __step_size *= 2;
        __merge_sort_loop(__buffer, __buffer_last, __first, __step_size, __comp);
        __step_size *= 2;
      }
    }

  template<typename _RandomAccessIter, typename _Pointer, typename _Distance>
    void
    __stable_sort_adaptive(_RandomAccessIter __first, _RandomAccessIter __last,
                           _Pointer __buffer, _Distance __buffer_size)
    {
      _Distance __len = (__last - __first + 1) / 2;
      _RandomAccessIter __middle = __first + __len;
      if (__len > __buffer_size) {
        __stable_sort_adaptive(__first, __middle, __buffer, __buffer_size);
        __stable_sort_adaptive(__middle, __last, __buffer, __buffer_size);
      }
      else {
        __merge_sort_with_buffer(__first, __middle, __buffer);
        __merge_sort_with_buffer(__middle, __last, __buffer);
      }
      __merge_adaptive(__first, __middle, __last, _Distance(__middle - __first),
                       _Distance(__last - __middle), __buffer, __buffer_size);
    }

  template<typename _RandomAccessIter, typename _Pointer, typename _Distance,
           typename _Compare>
    void
    __stable_sort_adaptive(_RandomAccessIter __first, _RandomAccessIter __last,
                           _Pointer __buffer, _Distance __buffer_size,
                           _Compare __comp)
    {
      _Distance __len = (__last - __first + 1) / 2;
      _RandomAccessIter __middle = __first + __len;
      if (__len > __buffer_size) {
        __stable_sort_adaptive(__first, __middle, __buffer, __buffer_size,
                               __comp);
        __stable_sort_adaptive(__middle, __last, __buffer, __buffer_size,
                               __comp);
      }
      else {
        __merge_sort_with_buffer(__first, __middle, __buffer, __comp);
        __merge_sort_with_buffer(__middle, __last, __buffer, __comp);
      }
      __merge_adaptive(__first, __middle, __last, _Distance(__middle - __first),
                       _Distance(__last - __middle), __buffer, __buffer_size,
                       __comp);
    }
# 2430 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter>
    inline void
    stable_sort(_RandomAccessIter __first, _RandomAccessIter __last)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;
      typedef typename iterator_traits<_RandomAccessIter>::difference_type _DistanceType;


     

     

      _Temporary_buffer<_RandomAccessIter, _ValueType> buf(__first, __last);
      if (buf.begin() == 0)
        __inplace_stable_sort(__first, __last);
      else
        __stable_sort_adaptive(__first, __last, buf.begin(), _DistanceType(buf.size()));
    }
# 2466 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter, typename _Compare>
    inline void
    stable_sort(_RandomAccessIter __first, _RandomAccessIter __last, _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;
      typedef typename iterator_traits<_RandomAccessIter>::difference_type _DistanceType;


     

     


      _Temporary_buffer<_RandomAccessIter, _ValueType> buf(__first, __last);
      if (buf.begin() == 0)
        __inplace_stable_sort(__first, __last, __comp);
      else
        __stable_sort_adaptive(__first, __last, buf.begin(), _DistanceType(buf.size()),
                               __comp);
    }
# 2502 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter>
    void
    partial_sort(_RandomAccessIter __first,
                 _RandomAccessIter __middle,
                 _RandomAccessIter __last)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;


     

     

      make_heap(__first, __middle);
      for (_RandomAccessIter __i = __middle; __i < __last; ++__i)
        if (*__i < *__first)
          __pop_heap(__first, __middle, __i, _ValueType(*__i));
      sort_heap(__first, __middle);
    }
# 2540 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter, typename _Compare>
    void
    partial_sort(_RandomAccessIter __first,
                 _RandomAccessIter __middle,
                 _RandomAccessIter __last,
                 _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;


     

     


      make_heap(__first, __middle, __comp);
      for (_RandomAccessIter __i = __middle; __i < __last; ++__i)
        if (__comp(*__i, *__first))
          __pop_heap(__first, __middle, __i, _ValueType(*__i), __comp);
      sort_heap(__first, __middle, __comp);
    }
# 2579 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _RandomAccessIter>
    _RandomAccessIter
    partial_sort_copy(_InputIter __first, _InputIter __last,
                      _RandomAccessIter __result_first,
                      _RandomAccessIter __result_last)
    {
      typedef typename iterator_traits<_InputIter>::value_type _InputValueType;
      typedef typename iterator_traits<_RandomAccessIter>::value_type _OutputValueType;
      typedef typename iterator_traits<_RandomAccessIter>::difference_type _DistanceType;


     
     
     
     

      if (__result_first == __result_last) return __result_last;
      _RandomAccessIter __result_real_last = __result_first;
      while(__first != __last && __result_real_last != __result_last) {
        *__result_real_last = *__first;
        ++__result_real_last;
        ++__first;
      }
      make_heap(__result_first, __result_real_last);
      while (__first != __last) {
        if (*__first < *__result_first)
          __adjust_heap(__result_first, _DistanceType(0),
                        _DistanceType(__result_real_last - __result_first),
                        _InputValueType(*__first));
        ++__first;
      }
      sort_heap(__result_first, __result_real_last);
      return __result_real_last;
    }
# 2633 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter, typename _RandomAccessIter, typename _Compare>
    _RandomAccessIter
    partial_sort_copy(_InputIter __first, _InputIter __last,
                      _RandomAccessIter __result_first,
                      _RandomAccessIter __result_last,
                      _Compare __comp)
    {
      typedef typename iterator_traits<_InputIter>::value_type _InputValueType;
      typedef typename iterator_traits<_RandomAccessIter>::value_type _OutputValueType;
      typedef typename iterator_traits<_RandomAccessIter>::difference_type _DistanceType;


     
     
     
     


      if (__result_first == __result_last) return __result_last;
      _RandomAccessIter __result_real_last = __result_first;
      while(__first != __last && __result_real_last != __result_last) {
        *__result_real_last = *__first;
        ++__result_real_last;
        ++__first;
      }
      make_heap(__result_first, __result_real_last, __comp);
      while (__first != __last) {
        if (__comp(*__first, *__result_first))
          __adjust_heap(__result_first, _DistanceType(0),
                        _DistanceType(__result_real_last - __result_first),
                        _InputValueType(*__first),
                        __comp);
        ++__first;
      }
      sort_heap(__result_first, __result_real_last, __comp);
      return __result_real_last;
    }
# 2686 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter>
    void
    nth_element(_RandomAccessIter __first,
                _RandomAccessIter __nth,
                _RandomAccessIter __last)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;


     
     

      while (__last - __first > 3) {
        _RandomAccessIter __cut =
          __unguarded_partition(__first, __last,
                                _ValueType(__median(*__first,
                                                    *(__first + (__last - __first)/2),
                                                    *(__last - 1))));
        if (__cut <= __nth)
          __first = __cut;
        else
          __last = __cut;
      }
      __insertion_sort(__first, __last);
    }
# 2728 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _RandomAccessIter, typename _Compare>
    void
    nth_element(_RandomAccessIter __first,
                _RandomAccessIter __nth,
                _RandomAccessIter __last,
                            _Compare __comp)
    {
      typedef typename iterator_traits<_RandomAccessIter>::value_type _ValueType;


     
     


      while (__last - __first > 3) {
        _RandomAccessIter __cut =
          __unguarded_partition(__first, __last,
                                _ValueType(__median(*__first,
                                                    *(__first + (__last - __first)/2),
                                                    *(__last - 1),
                                                    __comp)),
                                __comp);
        if (__cut <= __nth)
          __first = __cut;
        else
          __last = __cut;
      }
      __insertion_sort(__first, __last, __comp);
    }
# 2768 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp>
    _ForwardIter
    lower_bound(_ForwardIter __first, _ForwardIter __last, const _Tp& __val)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;






     
     
     

      _DistanceType __len = distance(__first, __last);
      _DistanceType __half;
      _ForwardIter __middle;

      while (__len > 0) {
        __half = __len >> 1;
        __middle = __first;
        advance(__middle, __half);
        if (*__middle < __val) {
          __first = __middle;
          ++__first;
          __len = __len - __half - 1;
        }
        else
          __len = __half;
      }
      return __first;
    }
# 2816 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp, typename _Compare>
    _ForwardIter
    lower_bound(_ForwardIter __first, _ForwardIter __last,
                const _Tp& __val, _Compare __comp)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;


     
     

      _DistanceType __len = distance(__first, __last);
      _DistanceType __half;
      _ForwardIter __middle;

      while (__len > 0) {
        __half = __len >> 1;
        __middle = __first;
        advance(__middle, __half);
        if (__comp(*__middle, __val)) {
          __first = __middle;
          ++__first;
          __len = __len - __half - 1;
        }
        else
          __len = __half;
      }
      return __first;
    }
# 2856 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp>
    _ForwardIter
    upper_bound(_ForwardIter __first, _ForwardIter __last, const _Tp& __val)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;



     
     
     

      _DistanceType __len = distance(__first, __last);
      _DistanceType __half;
      _ForwardIter __middle;

      while (__len > 0) {
        __half = __len >> 1;
        __middle = __first;
        advance(__middle, __half);
        if (__val < *__middle)
          __len = __half;
        else {
          __first = __middle;
          ++__first;
          __len = __len - __half - 1;
        }
      }
      return __first;
    }
# 2901 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp, typename _Compare>
    _ForwardIter
    upper_bound(_ForwardIter __first, _ForwardIter __last,
                const _Tp& __val, _Compare __comp)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;


     
     

      _DistanceType __len = distance(__first, __last);
      _DistanceType __half;
      _ForwardIter __middle;

      while (__len > 0) {
        __half = __len >> 1;
        __middle = __first;
        advance(__middle, __half);
        if (__comp(__val, *__middle))
          __len = __half;
        else {
          __first = __middle;
          ++__first;
          __len = __len - __half - 1;
        }
      }
      return __first;
    }
# 2948 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp>
    pair<_ForwardIter, _ForwardIter>
    equal_range(_ForwardIter __first, _ForwardIter __last, const _Tp& __val)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;



     
     
     

      _DistanceType __len = distance(__first, __last);
      _DistanceType __half;
      _ForwardIter __middle, __left, __right;

      while (__len > 0) {
        __half = __len >> 1;
        __middle = __first;
        advance(__middle, __half);
        if (*__middle < __val) {
          __first = __middle;
          ++__first;
          __len = __len - __half - 1;
        }
        else if (__val < *__middle)
          __len = __half;
        else {
          __left = lower_bound(__first, __middle, __val);
          advance(__first, __len);
          __right = upper_bound(++__middle, __first, __val);
          return pair<_ForwardIter, _ForwardIter>(__left, __right);
        }
      }
      return pair<_ForwardIter, _ForwardIter>(__first, __first);
    }
# 3003 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp, typename _Compare>
    pair<_ForwardIter, _ForwardIter>
    equal_range(_ForwardIter __first, _ForwardIter __last, const _Tp& __val,
                _Compare __comp)
    {
      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
      typedef typename iterator_traits<_ForwardIter>::difference_type _DistanceType;


     
     
     

      _DistanceType __len = distance(__first, __last);
      _DistanceType __half;
      _ForwardIter __middle, __left, __right;

      while (__len > 0) {
        __half = __len >> 1;
        __middle = __first;
        advance(__middle, __half);
        if (__comp(*__middle, __val)) {
          __first = __middle;
          ++__first;
          __len = __len - __half - 1;
        }
        else if (__comp(__val, *__middle))
          __len = __half;
        else {
          __left = lower_bound(__first, __middle, __val, __comp);
          advance(__first, __len);
          __right = upper_bound(++__middle, __first, __val, __comp);
          return pair<_ForwardIter, _ForwardIter>(__left, __right);
        }
      }
      return pair<_ForwardIter, _ForwardIter>(__first, __first);
    }
# 3052 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp>
    bool
    binary_search(_ForwardIter __first, _ForwardIter __last,
                  const _Tp& __val)
    {


     
     

     

      _ForwardIter __i = lower_bound(__first, __last, __val);
      return __i != __last && !(__val < *__i);
    }
# 3083 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter, typename _Tp, typename _Compare>
    bool
    binary_search(_ForwardIter __first, _ForwardIter __last,
                  const _Tp& __val, _Compare __comp)
    {

     
     

     


      _ForwardIter __i = lower_bound(__first, __last, __val, __comp);
      return __i != __last && !__comp(__val, *__i);
    }
# 3115 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _OutputIter>
    _OutputIter
    merge(_InputIter1 __first1, _InputIter1 __last1,
          _InputIter2 __first2, _InputIter2 __last2,
          _OutputIter __result)
    {

     
     
     

     


     


      while (__first1 != __last1 && __first2 != __last2) {
        if (*__first2 < *__first1) {
          *__result = *__first2;
          ++__first2;
        }
        else {
          *__result = *__first1;
          ++__first1;
        }
        ++__result;
      }
      return copy(__first2, __last2, copy(__first1, __last1, __result));
    }
# 3166 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _InputIter1, typename _InputIter2, typename _OutputIter,
           typename _Compare>
    _OutputIter
    merge(_InputIter1 __first1, _InputIter1 __last1,
          _InputIter2 __first2, _InputIter2 __last2,
          _OutputIter __result, _Compare __comp)
    {

     
     
     


     

     



      while (__first1 != __last1 && __first2 != __last2) {
        if (__comp(*__first2, *__first1)) {
          *__result = *__first2;
          ++__first2;
        }
        else {
          *__result = *__first1;
          ++__first1;
        }
        ++__result;
      }
      return copy(__first2, __last2, copy(__first1, __last1, __result));
    }






  template<typename _BidirectionalIter, typename _Distance>
    void
    __merge_without_buffer(_BidirectionalIter __first,
                           _BidirectionalIter __middle,
                           _BidirectionalIter __last,
                           _Distance __len1, _Distance __len2)
    {
      if (__len1 == 0 || __len2 == 0)
        return;
      if (__len1 + __len2 == 2) {
        if (*__middle < *__first)
              iter_swap(__first, __middle);
        return;
      }
      _BidirectionalIter __first_cut = __first;
      _BidirectionalIter __second_cut = __middle;
      _Distance __len11 = 0;
      _Distance __len22 = 0;
      if (__len1 > __len2) {
        __len11 = __len1 / 2;
        advance(__first_cut, __len11);
        __second_cut = lower_bound(__middle, __last, *__first_cut);
        __len22 = distance(__middle, __second_cut);
      }
      else {
        __len22 = __len2 / 2;
        advance(__second_cut, __len22);
        __first_cut = upper_bound(__first, __middle, *__second_cut);
        __len11 = distance(__first, __first_cut);
      }
      rotate(__first_cut, __middle, __second_cut);
      _BidirectionalIter __new_middle = __first_cut;
      advance(__new_middle, distance(__middle, __second_cut));
      __merge_without_buffer(__first, __first_cut, __new_middle,
                             __len11, __len22);
      __merge_without_buffer(__new_middle, __second_cut, __last,
                             __len1 - __len11, __len2 - __len22);
    }






  template<typename _BidirectionalIter, typename _Distance, typename _Compare>
    void
    __merge_without_buffer(_BidirectionalIter __first,
                           _BidirectionalIter __middle,
                           _BidirectionalIter __last,
                           _Distance __len1, _Distance __len2,
                           _Compare __comp)
    {
      if (__len1 == 0 || __len2 == 0)
        return;
      if (__len1 + __len2 == 2) {
        if (__comp(*__middle, *__first))
              iter_swap(__first, __middle);
        return;
      }
      _BidirectionalIter __first_cut = __first;
      _BidirectionalIter __second_cut = __middle;
      _Distance __len11 = 0;
      _Distance __len22 = 0;
      if (__len1 > __len2) {
        __len11 = __len1 / 2;
        advance(__first_cut, __len11);
        __second_cut = lower_bound(__middle, __last, *__first_cut, __comp);
        __len22 = distance(__middle, __second_cut);
      }
      else {
        __len22 = __len2 / 2;
        advance(__second_cut, __len22);
        __first_cut = upper_bound(__first, __middle, *__second_cut, __comp);
        __len11 = distance(__first, __first_cut);
      }
      rotate(__first_cut, __middle, __second_cut);
      _BidirectionalIter __new_middle = __first_cut;
      advance(__new_middle, distance(__middle, __second_cut));
      __merge_without_buffer(__first, __first_cut, __new_middle,
                             __len11, __len22, __comp);
      __merge_without_buffer(__new_middle, __second_cut, __last,
                             __len1 - __len11, __len2 - __len22, __comp);
    }






  template<typename _BidirectionalIter1, typename _BidirectionalIter2,
           typename _Distance>
    _BidirectionalIter1
    __rotate_adaptive(_BidirectionalIter1 __first,
                      _BidirectionalIter1 __middle,
                      _BidirectionalIter1 __last,
                      _Distance __len1, _Distance __len2,
                      _BidirectionalIter2 __buffer,
                      _Distance __buffer_size)
    {
      _BidirectionalIter2 __buffer_end;
      if (__len1 > __len2 && __len2 <= __buffer_size) {
        __buffer_end = copy(__middle, __last, __buffer);
        copy_backward(__first, __middle, __last);
        return copy(__buffer, __buffer_end, __first);
      }
      else if (__len1 <= __buffer_size) {
        __buffer_end = copy(__first, __middle, __buffer);
        copy(__middle, __last, __first);
        return copy_backward(__buffer, __buffer_end, __last);
      }
      else {
        rotate(__first, __middle, __last);
        advance(__first, distance(__middle, __last));
        return __first;
      }
    }






  template<typename _BidirectionalIter1, typename _BidirectionalIter2,
           typename _BidirectionalIter3>
    _BidirectionalIter3
    __merge_backward(_BidirectionalIter1 __first1, _BidirectionalIter1 __last1,
                     _BidirectionalIter2 __first2, _BidirectionalIter2 __last2,
                     _BidirectionalIter3 __result)
    {
      if (__first1 == __last1)
        return copy_backward(__first2, __last2, __result);
      if (__first2 == __last2)
        return copy_backward(__first1, __last1, __result);
      --__last1;
      --__last2;
      while (true) {
        if (*__last2 < *__last1) {
          *--__result = *__last1;
          if (__first1 == __last1)
            return copy_backward(__first2, ++__last2, __result);
          --__last1;
        }
        else {
          *--__result = *__last2;
          if (__first2 == __last2)
            return copy_backward(__first1, ++__last1, __result);
          --__last2;
        }
      }
    }






  template<typename _BidirectionalIter1, typename _BidirectionalIter2,
           typename _BidirectionalIter3, typename _Compare>
    _BidirectionalIter3
    __merge_backward(_BidirectionalIter1 __first1, _BidirectionalIter1 __last1,
                     _BidirectionalIter2 __first2, _BidirectionalIter2 __last2,
                     _BidirectionalIter3 __result,
                     _Compare __comp)
    {
      if (__first1 == __last1)
        return copy_backward(__first2, __last2, __result);
      if (__first2 == __last2)
        return copy_backward(__first1, __last1, __result);
      --__last1;
      --__last2;
      while (true) {
        if (__comp(*__last2, *__last1)) {
          *--__result = *__last1;
          if (__first1 == __last1)
            return copy_backward(__first2, ++__last2, __result);
          --__last1;
        }
        else {
          *--__result = *__last2;
          if (__first2 == __last2)
            return copy_backward(__first1, ++__last1, __result);
          --__last2;
        }
      }
    }






  template<typename _BidirectionalIter, typename _Distance, typename _Pointer>
    void
    __merge_adaptive(_BidirectionalIter __first,
                     _BidirectionalIter __middle,
                     _BidirectionalIter __last,
                     _Distance __len1, _Distance __len2,
                     _Pointer __buffer, _Distance __buffer_size)
    {
          if (__len1 <= __len2 && __len1 <= __buffer_size) {
            _Pointer __buffer_end = copy(__first, __middle, __buffer);
            merge(__buffer, __buffer_end, __middle, __last, __first);
          }
          else if (__len2 <= __buffer_size) {
            _Pointer __buffer_end = copy(__middle, __last, __buffer);
            __merge_backward(__first, __middle, __buffer, __buffer_end, __last);
          }
          else {
            _BidirectionalIter __first_cut = __first;
            _BidirectionalIter __second_cut = __middle;
            _Distance __len11 = 0;
            _Distance __len22 = 0;
            if (__len1 > __len2) {
                  __len11 = __len1 / 2;
                  advance(__first_cut, __len11);
                  __second_cut = lower_bound(__middle, __last, *__first_cut);
                  __len22 = distance(__middle, __second_cut);
            }
            else {
                  __len22 = __len2 / 2;
                  advance(__second_cut, __len22);
                  __first_cut = upper_bound(__first, __middle, *__second_cut);
                  __len11 = distance(__first, __first_cut);
            }
            _BidirectionalIter __new_middle =
                  __rotate_adaptive(__first_cut, __middle, __second_cut,
                                    __len1 - __len11, __len22, __buffer,
                                    __buffer_size);
            __merge_adaptive(__first, __first_cut, __new_middle, __len11,
                             __len22, __buffer, __buffer_size);
            __merge_adaptive(__new_middle, __second_cut, __last, __len1 - __len11,
                             __len2 - __len22, __buffer, __buffer_size);
          }
    }






  template<typename _BidirectionalIter, typename _Distance, typename _Pointer,
           typename _Compare>
    void
    __merge_adaptive(_BidirectionalIter __first,
                     _BidirectionalIter __middle,
                     _BidirectionalIter __last,
                     _Distance __len1, _Distance __len2,
                     _Pointer __buffer, _Distance __buffer_size,
                     _Compare __comp)
    {
          if (__len1 <= __len2 && __len1 <= __buffer_size) {
            _Pointer __buffer_end = copy(__first, __middle, __buffer);
            merge(__buffer, __buffer_end, __middle, __last, __first, __comp);
          }
          else if (__len2 <= __buffer_size) {
            _Pointer __buffer_end = copy(__middle, __last, __buffer);
            __merge_backward(__first, __middle, __buffer, __buffer_end, __last,
                                             __comp);
          }
          else {
            _BidirectionalIter __first_cut = __first;
            _BidirectionalIter __second_cut = __middle;
            _Distance __len11 = 0;
            _Distance __len22 = 0;
            if (__len1 > __len2) {
                  __len11 = __len1 / 2;
                  advance(__first_cut, __len11);
                  __second_cut = lower_bound(__middle, __last, *__first_cut, __comp);
                  __len22 = distance(__middle, __second_cut);
            }
            else {
                  __len22 = __len2 / 2;
                  advance(__second_cut, __len22);
                  __first_cut = upper_bound(__first, __middle, *__second_cut, __comp);
                  __len11 = distance(__first, __first_cut);
            }
            _BidirectionalIter __new_middle =
                  __rotate_adaptive(__first_cut, __middle, __second_cut,
                                    __len1 - __len11, __len22, __buffer,
                                    __buffer_size);
            __merge_adaptive(__first, __first_cut, __new_middle, __len11,
                             __len22, __buffer, __buffer_size, __comp);
            __merge_adaptive(__new_middle, __second_cut, __last, __len1 - __len11,
                             __len2 - __len22, __buffer, __buffer_size, __comp);
          }
    }
# 3508 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _BidirectionalIter>
    void
    inplace_merge(_BidirectionalIter __first,
                  _BidirectionalIter __middle,
                  _BidirectionalIter __last)
    {
      typedef typename iterator_traits<_BidirectionalIter>::value_type
          _ValueType;
      typedef typename iterator_traits<_BidirectionalIter>::difference_type
          _DistanceType;


     

     

      if (__first == __middle || __middle == __last)
        return;

      _DistanceType __len1 = distance(__first, __middle);
      _DistanceType __len2 = distance(__middle, __last);

      _Temporary_buffer<_BidirectionalIter, _ValueType> __buf(__first, __last);
      if (__buf.begin() == 0)
        __merge_without_buffer(__first, __middle, __last, __len1, __len2);
      else
        __merge_adaptive(__first, __middle, __last, __len1, __len2,
                         __buf.begin(), _DistanceType(__buf.size()));
    }
# 3559 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _BidirectionalIter, typename _Compare>
    void
    inplace_merge(_BidirectionalIter __first,
                  _BidirectionalIter __middle,
                  _BidirectionalIter __last,
                  _Compare __comp)
    {
      typedef typename iterator_traits<_BidirectionalIter>::value_type
          _ValueType;
      typedef typename iterator_traits<_BidirectionalIter>::difference_type
          _DistanceType;


     

     


      if (__first == __middle || __middle == __last)
        return;

      _DistanceType __len1 = distance(__first, __middle);
      _DistanceType __len2 = distance(__middle, __last);

      _Temporary_buffer<_BidirectionalIter, _ValueType> __buf(__first, __last);
      if (__buf.begin() == 0)
        __merge_without_buffer(__first, __middle, __last, __len1, __len2, __comp);
      else
        __merge_adaptive(__first, __middle, __last, __len1, __len2,
                         __buf.begin(), _DistanceType(__buf.size()),
                         __comp);
    }






  template<typename _InputIter1, typename _InputIter2>
    bool
    includes(_InputIter1 __first1, _InputIter1 __last1,
             _InputIter2 __first2, _InputIter2 __last2)
    {

     
     
     


     


      while (__first1 != __last1 && __first2 != __last2)
        if (*__first2 < *__first1)
          return false;
        else if(*__first1 < *__first2)
          ++__first1;
        else
          ++__first1, ++__first2;

      return __first2 == __last2;
    }

  template<typename _InputIter1, typename _InputIter2, typename _Compare>
    bool
    includes(_InputIter1 __first1, _InputIter1 __last1,
             _InputIter2 __first2, _InputIter2 __last2, _Compare __comp)
    {

     
     
     


     



      while (__first1 != __last1 && __first2 != __last2)
        if (__comp(*__first2, *__first1))
          return false;
        else if(__comp(*__first1, *__first2))
          ++__first1;
        else
          ++__first1, ++__first2;

      return __first2 == __last2;
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter>
    _OutputIter
    set_union(_InputIter1 __first1, _InputIter1 __last1,
              _InputIter2 __first2, _InputIter2 __last2,
              _OutputIter __result)
    {

     
     
     

     


     


      while (__first1 != __last1 && __first2 != __last2) {
        if (*__first1 < *__first2) {
          *__result = *__first1;
          ++__first1;
        }
        else if (*__first2 < *__first1) {
          *__result = *__first2;
          ++__first2;
        }
        else {
          *__result = *__first1;
          ++__first1;
          ++__first2;
        }
        ++__result;
      }
      return copy(__first2, __last2, copy(__first1, __last1, __result));
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter,
           typename _Compare>
    _OutputIter
    set_union(_InputIter1 __first1, _InputIter1 __last1,
              _InputIter2 __first2, _InputIter2 __last2,
              _OutputIter __result, _Compare __comp)
    {

     
     
     


     

     



      while (__first1 != __last1 && __first2 != __last2) {
        if (__comp(*__first1, *__first2)) {
          *__result = *__first1;
          ++__first1;
        }
        else if (__comp(*__first2, *__first1)) {
          *__result = *__first2;
          ++__first2;
        }
        else {
          *__result = *__first1;
          ++__first1;
          ++__first2;
        }
        ++__result;
      }
      return copy(__first2, __last2, copy(__first1, __last1, __result));
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter>
    _OutputIter
    set_intersection(_InputIter1 __first1, _InputIter1 __last1,
                     _InputIter2 __first2, _InputIter2 __last2,
                     _OutputIter __result)
    {

     
     
     

     


     


      while (__first1 != __last1 && __first2 != __last2)
        if (*__first1 < *__first2)
          ++__first1;
        else if (*__first2 < *__first1)
          ++__first2;
        else {
          *__result = *__first1;
          ++__first1;
          ++__first2;
          ++__result;
        }
      return __result;
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter,
           typename _Compare>
    _OutputIter
    set_intersection(_InputIter1 __first1, _InputIter1 __last1,
                     _InputIter2 __first2, _InputIter2 __last2,
                     _OutputIter __result, _Compare __comp)
    {

     
     
     


     

     



      while (__first1 != __last1 && __first2 != __last2)
        if (__comp(*__first1, *__first2))
          ++__first1;
        else if (__comp(*__first2, *__first1))
          ++__first2;
        else {
          *__result = *__first1;
          ++__first1;
          ++__first2;
          ++__result;
        }
      return __result;
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter>
    _OutputIter
    set_difference(_InputIter1 __first1, _InputIter1 __last1,
                   _InputIter2 __first2, _InputIter2 __last2,
                   _OutputIter __result)
    {

     
     
     

     


     


      while (__first1 != __last1 && __first2 != __last2)
        if (*__first1 < *__first2) {
          *__result = *__first1;
          ++__first1;
          ++__result;
        }
        else if (*__first2 < *__first1)
          ++__first2;
        else {
          ++__first1;
          ++__first2;
        }
      return copy(__first1, __last1, __result);
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter,
           typename _Compare>
    _OutputIter
    set_difference(_InputIter1 __first1, _InputIter1 __last1,
                   _InputIter2 __first2, _InputIter2 __last2,
                   _OutputIter __result, _Compare __comp)
    {

     
     
     


     

     



      while (__first1 != __last1 && __first2 != __last2)
        if (__comp(*__first1, *__first2)) {
          *__result = *__first1;
          ++__first1;
          ++__result;
        }
        else if (__comp(*__first2, *__first1))
          ++__first2;
        else {
          ++__first1;
          ++__first2;
        }
      return copy(__first1, __last1, __result);
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter>
    _OutputIter
    set_symmetric_difference(_InputIter1 __first1, _InputIter1 __last1,
                             _InputIter2 __first2, _InputIter2 __last2,
                             _OutputIter __result)
    {

     
     
     

     


     


      while (__first1 != __last1 && __first2 != __last2)
        if (*__first1 < *__first2) {
          *__result = *__first1;
          ++__first1;
          ++__result;
        }
        else if (*__first2 < *__first1) {
          *__result = *__first2;
          ++__first2;
          ++__result;
        }
        else {
          ++__first1;
          ++__first2;
        }
      return copy(__first2, __last2, copy(__first1, __last1, __result));
    }

  template<typename _InputIter1, typename _InputIter2, typename _OutputIter,
           typename _Compare>
    _OutputIter
    set_symmetric_difference(_InputIter1 __first1, _InputIter1 __last1,
                             _InputIter2 __first2, _InputIter2 __last2,
                             _OutputIter __result,
                             _Compare __comp)
    {

     
     
     


     

     



      while (__first1 != __last1 && __first2 != __last2)
        if (__comp(*__first1, *__first2)) {
          *__result = *__first1;
          ++__first1;
          ++__result;
        }
        else if (__comp(*__first2, *__first1)) {
          *__result = *__first2;
          ++__first2;
          ++__result;
        }
        else {
          ++__first1;
          ++__first2;
        }
      return copy(__first2, __last2, copy(__first1, __last1, __result));
    }




  template<typename _ForwardIter>
    _ForwardIter
    max_element(_ForwardIter __first, _ForwardIter __last)
    {

     
     


      if (__first == __last) return __first;
      _ForwardIter __result = __first;
      while (++__first != __last)
        if (*__result < *__first)
          __result = __first;
      return __result;
    }

  template<typename _ForwardIter, typename _Compare>
    _ForwardIter
    max_element(_ForwardIter __first, _ForwardIter __last,
                _Compare __comp)
    {

     
     



      if (__first == __last) return __first;
      _ForwardIter __result = __first;
      while (++__first != __last)
        if (__comp(*__result, *__first)) __result = __first;
      return __result;
    }

  template<typename _ForwardIter>
    _ForwardIter
    min_element(_ForwardIter __first, _ForwardIter __last)
    {

     
     


      if (__first == __last) return __first;
      _ForwardIter __result = __first;
      while (++__first != __last)
        if (*__first < *__result)
          __result = __first;
      return __result;
    }

  template<typename _ForwardIter, typename _Compare>
    _ForwardIter
    min_element(_ForwardIter __first, _ForwardIter __last,
                _Compare __comp)
    {

     
     



      if (__first == __last) return __first;
      _ForwardIter __result = __first;
      while (++__first != __last)
        if (__comp(*__first, *__result))
          __result = __first;
      return __result;
    }




  template<typename _BidirectionalIter>
    bool
    next_permutation(_BidirectionalIter __first, _BidirectionalIter __last)
    {

     
     


      if (__first == __last)
        return false;
      _BidirectionalIter __i = __first;
      ++__i;
      if (__i == __last)
        return false;
      __i = __last;
      --__i;

      for(;;) {
        _BidirectionalIter __ii = __i;
        --__i;
        if (*__i < *__ii) {
          _BidirectionalIter __j = __last;
          while (!(*__i < *--__j))
            {}
          iter_swap(__i, __j);
          reverse(__ii, __last);
          return true;
        }
        if (__i == __first) {
          reverse(__first, __last);
          return false;
        }
      }
    }

  template<typename _BidirectionalIter, typename _Compare>
    bool
    next_permutation(_BidirectionalIter __first, _BidirectionalIter __last,
                     _Compare __comp)
    {

     
     



      if (__first == __last)
        return false;
      _BidirectionalIter __i = __first;
      ++__i;
      if (__i == __last)
        return false;
      __i = __last;
      --__i;

      for(;;) {
        _BidirectionalIter __ii = __i;
        --__i;
        if (__comp(*__i, *__ii)) {
          _BidirectionalIter __j = __last;
          while (!__comp(*__i, *--__j))
            {}
          iter_swap(__i, __j);
          reverse(__ii, __last);
          return true;
        }
        if (__i == __first) {
          reverse(__first, __last);
          return false;
        }
      }
    }

  template<typename _BidirectionalIter>
    bool
    prev_permutation(_BidirectionalIter __first, _BidirectionalIter __last)
    {

     
     


      if (__first == __last)
        return false;
      _BidirectionalIter __i = __first;
      ++__i;
      if (__i == __last)
        return false;
      __i = __last;
      --__i;

      for(;;) {
        _BidirectionalIter __ii = __i;
        --__i;
        if (*__ii < *__i) {
          _BidirectionalIter __j = __last;
          while (!(*--__j < *__i))
            {}
          iter_swap(__i, __j);
          reverse(__ii, __last);
          return true;
        }
        if (__i == __first) {
          reverse(__first, __last);
          return false;
        }
      }
    }

  template<typename _BidirectionalIter, typename _Compare>
    bool
    prev_permutation(_BidirectionalIter __first, _BidirectionalIter __last,
                     _Compare __comp)
    {

     
     



      if (__first == __last)
        return false;
      _BidirectionalIter __i = __first;
      ++__i;
      if (__i == __last)
        return false;
      __i = __last;
      --__i;

      for(;;) {
        _BidirectionalIter __ii = __i;
        --__i;
        if (__comp(*__ii, *__i)) {
          _BidirectionalIter __j = __last;
          while (!__comp(*--__j, *__i))
            {}
          iter_swap(__i, __j);
          reverse(__ii, __last);
          return true;
        }
        if (__i == __first) {
          reverse(__first, __last);
          return false;
        }
      }
    }



  template<typename _InputIter, typename _ForwardIter>
    _InputIter
    find_first_of(_InputIter __first1, _InputIter __last1,
                  _ForwardIter __first2, _ForwardIter __last2)
    {

     
     
     



      for ( ; __first1 != __last1; ++__first1)
        for (_ForwardIter __iter = __first2; __iter != __last2; ++__iter)
          if (*__first1 == *__iter)
            return __first1;
      return __last1;
    }

  template<typename _InputIter, typename _ForwardIter, typename _BinaryPredicate>
    _InputIter
    find_first_of(_InputIter __first1, _InputIter __last1,
                  _ForwardIter __first2, _ForwardIter __last2,
                  _BinaryPredicate __comp)
    {

     
     
     


     



      for ( ; __first1 != __last1; ++__first1)
        for (_ForwardIter __iter = __first2; __iter != __last2; ++__iter)
          if (__comp(*__first1, *__iter))
            return __first1;
      return __last1;
    }
# 4201 "/usr/include/c++3.1/bits/stl_algo.h" 3
  template<typename _ForwardIter1, typename _ForwardIter2>
    _ForwardIter1
    __find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
               _ForwardIter2 __first2, _ForwardIter2 __last2,
               forward_iterator_tag, forward_iterator_tag)
    {
      if (__first2 == __last2)
        return __last1;
      else {
        _ForwardIter1 __result = __last1;
        while (1) {
          _ForwardIter1 __new_result
            = search(__first1, __last1, __first2, __last2);
          if (__new_result == __last1)
            return __result;
          else {
            __result = __new_result;
            __first1 = __new_result;
            ++__first1;
          }
        }
      }
    }

  template<typename _ForwardIter1, typename _ForwardIter2,
           typename _BinaryPredicate>
    _ForwardIter1
    __find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
               _ForwardIter2 __first2, _ForwardIter2 __last2,
               forward_iterator_tag, forward_iterator_tag,
               _BinaryPredicate __comp)
    {
      if (__first2 == __last2)
        return __last1;
      else {
        _ForwardIter1 __result = __last1;
        while (1) {
          _ForwardIter1 __new_result
            = search(__first1, __last1, __first2, __last2, __comp);
          if (__new_result == __last1)
            return __result;
          else {
            __result = __new_result;
            __first1 = __new_result;
            ++__first1;
          }
        }
      }
    }


  template<typename _BidirectionalIter1, typename _BidirectionalIter2>
    _BidirectionalIter1
    __find_end(_BidirectionalIter1 __first1, _BidirectionalIter1 __last1,
               _BidirectionalIter2 __first2, _BidirectionalIter2 __last2,
               bidirectional_iterator_tag, bidirectional_iterator_tag)
    {

     
     

      typedef reverse_iterator<_BidirectionalIter1> _RevIter1;
      typedef reverse_iterator<_BidirectionalIter2> _RevIter2;

      _RevIter1 __rlast1(__first1);
      _RevIter2 __rlast2(__first2);
      _RevIter1 __rresult = search(_RevIter1(__last1), __rlast1,
                                   _RevIter2(__last2), __rlast2);

      if (__rresult == __rlast1)
        return __last1;
      else {
        _BidirectionalIter1 __result = __rresult.base();
        advance(__result, -distance(__first2, __last2));
        return __result;
      }
    }

  template<typename _BidirectionalIter1, typename _BidirectionalIter2,
           typename _BinaryPredicate>
    _BidirectionalIter1
    __find_end(_BidirectionalIter1 __first1, _BidirectionalIter1 __last1,
               _BidirectionalIter2 __first2, _BidirectionalIter2 __last2,
               bidirectional_iterator_tag, bidirectional_iterator_tag,
               _BinaryPredicate __comp)
    {

     
     

      typedef reverse_iterator<_BidirectionalIter1> _RevIter1;
      typedef reverse_iterator<_BidirectionalIter2> _RevIter2;

      _RevIter1 __rlast1(__first1);
      _RevIter2 __rlast2(__first2);
      _RevIter1 __rresult = search(_RevIter1(__last1), __rlast1,
                                   _RevIter2(__last2), __rlast2,
                                   __comp);

      if (__rresult == __rlast1)
        return __last1;
      else {
        _BidirectionalIter1 __result = __rresult.base();
        advance(__result, -distance(__first2, __last2));
        return __result;
      }
    }



  template<typename _ForwardIter1, typename _ForwardIter2>
    inline _ForwardIter1
    find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
             _ForwardIter2 __first2, _ForwardIter2 __last2)
    {

     
     
     



      return __find_end(__first1, __last1, __first2, __last2,
                        __iterator_category(__first1),
                        __iterator_category(__first2));
    }

  template<typename _ForwardIter1, typename _ForwardIter2,
           typename _BinaryPredicate>
    inline _ForwardIter1
    find_end(_ForwardIter1 __first1, _ForwardIter1 __last1,
             _ForwardIter2 __first2, _ForwardIter2 __last2,
             _BinaryPredicate __comp)
    {

     
     
     



      return __find_end(__first1, __last1, __first2, __last2,
                        __iterator_category(__first1),
                        __iterator_category(__first2),
                        __comp);
    }

}
# 70 "/usr/include/c++3.1/algorithm" 2 3
# 18 "../inXDB/DB/TypeGen.cc" 2
# 1 "/usr/include/c++3.1/iostream" 1 3
# 43 "/usr/include/c++3.1/iostream" 3


# 1 "/usr/include/c++3.1/ostream" 1 3
# 44 "/usr/include/c++3.1/ostream" 3

# 1 "/usr/include/c++3.1/ios" 1 3
# 43 "/usr/include/c++3.1/ios" 3



# 1 "/usr/include/c++3.1/bits/char_traits.h" 1 3
# 43 "/usr/include/c++3.1/bits/char_traits.h" 3




namespace std
{



  template<class _CharT>
    struct char_traits
    {
      typedef _CharT char_type;

      typedef unsigned long int_type;
      typedef streampos pos_type;
      typedef streamoff off_type;
      typedef mbstate_t state_type;

      static void
      assign(char_type& __c1, const char_type& __c2)
      { __c1 = __c2; }

      static bool
      eq(const char_type& __c1, const char_type& __c2)
      { return __c1 == __c2; }

      static bool
      lt(const char_type& __c1, const char_type& __c2)
      { return __c1 < __c2; }

      static int
      compare(const char_type* __s1, const char_type* __s2, size_t __n)
      {
        for (size_t __i = 0; __i < __n; ++__i)
          if (!eq(__s1[__i], __s2[__i]))
            return lt(__s1[__i], __s2[__i]) ? -1 : 1;
        return 0;
      }

      static size_t
      length(const char_type* __s)
      {
        const char_type* __p = __s;
        while (*__p) ++__p;
        return (__p - __s);
      }

      static const char_type*
      find(const char_type* __s, size_t __n, const char_type& __a)
      {
        for (const char_type* __p = __s; size_t(__p - __s) < __n; ++__p)
          if (*__p == __a) return __p;
        return 0;
      }

      static char_type*
      move(char_type* __s1, const char_type* __s2, size_t __n)
      { return (char_type*) memmove(__s1, __s2, __n * sizeof(char_type)); }

      static char_type*
      copy(char_type* __s1, const char_type* __s2, size_t __n)
      { return (char_type*) memcpy(__s1, __s2, __n * sizeof(char_type)); }

      static char_type*
      assign(char_type* __s, size_t __n, char_type __a)
      {
        for (char_type* __p = __s; __p < __s + __n; ++__p)
          assign(*__p, __a);
        return __s;
      }

      static char_type
      to_char_type(const int_type& __c)
      { return char_type(__c); }

      static int_type
      to_int_type(const char_type& __c) { return int_type(__c); }

      static bool
      eq_int_type(const int_type& __c1, const int_type& __c2)
      { return __c1 == __c2; }

      static int_type
      eof() { return static_cast<int_type>(-1); }

      static int_type
      not_eof(const int_type& __c)
      { return eq_int_type(__c, eof()) ? int_type(0) : __c; }
    };



  template<>
    struct char_traits<char>
    {
      typedef char char_type;
      typedef int int_type;
      typedef streampos pos_type;
      typedef streamoff off_type;
      typedef mbstate_t state_type;

      static void
      assign(char_type& __c1, const char_type& __c2)
      { __c1 = __c2; }

      static bool
      eq(const char_type& __c1, const char_type& __c2)
      { return __c1 == __c2; }

      static bool
      lt(const char_type& __c1, const char_type& __c2)
      { return __c1 < __c2; }

      static int
      compare(const char_type* __s1, const char_type* __s2, size_t __n)
      { return memcmp(__s1, __s2, __n); }

      static size_t
      length(const char_type* __s)
      { return strlen(__s); }

      static const char_type*
      find(const char_type* __s, size_t __n, const char_type& __a)
      { return static_cast<const char_type*>(memchr(__s, __a, __n)); }

      static char_type*
      move(char_type* __s1, const char_type* __s2, size_t __n)
      { return static_cast<char_type*>(memmove(__s1, __s2, __n)); }

      static char_type*
      copy(char_type* __s1, const char_type* __s2, size_t __n)
      { return static_cast<char_type*>(memcpy(__s1, __s2, __n)); }

      static char_type*
      assign(char_type* __s, size_t __n, char_type __a)
      { return static_cast<char_type*>(memset(__s, __a, __n)); }

      static char_type
      to_char_type(const int_type& __c)
      { return static_cast<char_type>(__c); }



      static int_type
      to_int_type(const char_type& __c)
      { return static_cast<int_type>(static_cast<unsigned char>(__c)); }

      static bool
      eq_int_type(const int_type& __c1, const int_type& __c2)
      { return __c1 == __c2; }

      static int_type
      eof() { return static_cast<int_type>((-1)); }

      static int_type
      not_eof(const int_type& __c)
      { return (__c == eof()) ? 0 : __c; }
  };
# 269 "/usr/include/c++3.1/bits/char_traits.h" 3
  template<typename _CharT, typename _Traits>
    struct _Char_traits_match
    {
      _CharT _M_c;
      _Char_traits_match(_CharT const& __c) : _M_c(__c) { }

      bool
      operator()(_CharT const& __a) { return _Traits::eq(_M_c, __a); }
    };
}
# 47 "/usr/include/c++3.1/ios" 2 3

# 1 "/usr/include/c++3.1/bits/localefwd.h" 1 3
# 44 "/usr/include/c++3.1/bits/localefwd.h" 3


# 1 "/usr/include/c++3.1/i686-inX-linux/bits/c++locale.h" 1 3
# 36 "/usr/include/c++3.1/i686-inX-linux/bits/c++locale.h" 3
# 1 "/usr/include/c++3.1/clocale" 1 3
# 48 "/usr/include/c++3.1/clocale" 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 1 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 30 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/locale.h" 1 3
# 27 "/usr/lib/gcc/../../i686-inX-linux/include/bits/locale.h" 3
enum
{
  __LC_CTYPE = 0,
  __LC_NUMERIC = 1,
  __LC_TIME = 2,
  __LC_COLLATE = 3,
  __LC_MONETARY = 4,
  __LC_MESSAGES = 5,
  __LC_ALL = 6,
  __LC_PAPER = 7,
  __LC_NAME = 8,
  __LC_ADDRESS = 9,
  __LC_TELEPHONE = 10,
  __LC_MEASUREMENT = 11,
  __LC_IDENTIFICATION = 12
};
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 2 3

extern "C" {
# 52 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 3
struct lconv
{


  char *decimal_point;
  char *thousands_sep;





  char *grouping;





  char *int_curr_symbol;
  char *currency_symbol;
  char *mon_decimal_point;
  char *mon_thousands_sep;
  char *mon_grouping;
  char *positive_sign;
  char *negative_sign;
  char int_frac_digits;
  char frac_digits;

  char p_cs_precedes;

  char p_sep_by_space;

  char n_cs_precedes;

  char n_sep_by_space;






  char p_sign_posn;
  char n_sign_posn;


  char int_p_cs_precedes;

  char int_p_sep_by_space;

  char int_n_cs_precedes;

  char int_n_sep_by_space;






  char int_p_sign_posn;
  char int_n_sign_posn;
# 119 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 3
};



extern char *setlocale (int __category, __const char *__locale) throw ();


extern struct lconv *localeconv (void) throw ();
# 149 "/usr/lib/gcc/../../i686-inX-linux/include/locale.h" 3
extern __locale_t __newlocale (int __category_mask, __const char *__locale,
                               __locale_t __base) throw ();



extern __locale_t __duplocale (__locale_t __dataset) throw ();



extern void __freelocale (__locale_t __dataset) throw ();


}
# 50 "/usr/include/c++3.1/clocale" 2 3





namespace std
{
  using ::lconv;
  using ::setlocale;
  using ::localeconv;
}
# 37 "/usr/include/c++3.1/i686-inX-linux/bits/c++locale.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 1 3
# 24 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/nl_types.h" 1 3
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/nl_types.h" 3
extern "C" {


typedef void *nl_catd;


typedef int nl_item;


extern nl_catd catopen (__const char *__cat_name, int __flag) throw ();



extern char *catgets (nl_catd __catalog, int __set, int __number,
                      __const char *__string) throw ();


extern int catclose (nl_catd __catalog) throw ();

}
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 2 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/locale.h" 1 3
# 27 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 2 3


extern "C" {
# 43 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 3
enum
{



  ABDAY_1 = (((__LC_TIME) << 16) | (0)),

  ABDAY_2,

  ABDAY_3,

  ABDAY_4,

  ABDAY_5,

  ABDAY_6,

  ABDAY_7,



  DAY_1,

  DAY_2,

  DAY_3,

  DAY_4,

  DAY_5,

  DAY_6,

  DAY_7,



  ABMON_1,

  ABMON_2,

  ABMON_3,

  ABMON_4,

  ABMON_5,

  ABMON_6,

  ABMON_7,

  ABMON_8,

  ABMON_9,

  ABMON_10,

  ABMON_11,

  ABMON_12,



  MON_1,

  MON_2,

  MON_3,

  MON_4,

  MON_5,

  MON_6,

  MON_7,

  MON_8,

  MON_9,

  MON_10,

  MON_11,

  MON_12,


  AM_STR,

  PM_STR,


  D_T_FMT,

  D_FMT,

  T_FMT,

  T_FMT_AMPM,


  ERA,

  __ERA_YEAR,



  ERA_D_FMT,

  ALT_DIGITS,

  ERA_D_T_FMT,

  ERA_T_FMT,


  _NL_TIME_ERA_NUM_ENTRIES,
  _NL_TIME_ERA_ENTRIES,

  _NL_WABDAY_1,
  _NL_WABDAY_2,
  _NL_WABDAY_3,
  _NL_WABDAY_4,
  _NL_WABDAY_5,
  _NL_WABDAY_6,
  _NL_WABDAY_7,


  _NL_WDAY_1,
  _NL_WDAY_2,
  _NL_WDAY_3,
  _NL_WDAY_4,
  _NL_WDAY_5,
  _NL_WDAY_6,
  _NL_WDAY_7,


  _NL_WABMON_1,
  _NL_WABMON_2,
  _NL_WABMON_3,
  _NL_WABMON_4,
  _NL_WABMON_5,
  _NL_WABMON_6,
  _NL_WABMON_7,
  _NL_WABMON_8,
  _NL_WABMON_9,
  _NL_WABMON_10,
  _NL_WABMON_11,
  _NL_WABMON_12,


  _NL_WMON_1,
  _NL_WMON_2,
  _NL_WMON_3,
  _NL_WMON_4,
  _NL_WMON_5,
  _NL_WMON_6,
  _NL_WMON_7,
  _NL_WMON_8,
  _NL_WMON_9,
  _NL_WMON_10,
  _NL_WMON_11,
  _NL_WMON_12,

  _NL_WAM_STR,
  _NL_WPM_STR,

  _NL_WD_T_FMT,
  _NL_WD_FMT,
  _NL_WT_FMT,
  _NL_WT_FMT_AMPM,

  _NL_WERA_YEAR,
  _NL_WERA_D_FMT,
  _NL_WALT_DIGITS,
  _NL_WERA_D_T_FMT,
  _NL_WERA_T_FMT,

  _NL_TIME_WEEK_NDAYS,
  _NL_TIME_WEEK_1STDAY,
  _NL_TIME_WEEK_1STWEEK,
  _NL_TIME_FIRST_WEEKDAY,
  _NL_TIME_FIRST_WORKDAY,
  _NL_TIME_CAL_DIRECTION,
  _NL_TIME_TIMEZONE,

  _DATE_FMT,

  _NL_W_DATE_FMT,

  _NL_TIME_CODESET,

  _NL_NUM_LC_TIME,




  _NL_COLLATE_NRULES = (((__LC_COLLATE) << 16) | (0)),
  _NL_COLLATE_RULESETS,
  _NL_COLLATE_TABLEMB,
  _NL_COLLATE_WEIGHTMB,
  _NL_COLLATE_EXTRAMB,
  _NL_COLLATE_INDIRECTMB,
  _NL_COLLATE_GAP1,
  _NL_COLLATE_GAP2,
  _NL_COLLATE_GAP3,
  _NL_COLLATE_TABLEWC,
  _NL_COLLATE_WEIGHTWC,
  _NL_COLLATE_EXTRAWC,
  _NL_COLLATE_INDIRECTWC,
  _NL_COLLATE_SYMB_HASH_SIZEMB,
  _NL_COLLATE_SYMB_TABLEMB,
  _NL_COLLATE_SYMB_EXTRAMB,
  _NL_COLLATE_COLLSEQMB,
  _NL_COLLATE_COLLSEQWC,
  _NL_COLLATE_CODESET,
  _NL_NUM_LC_COLLATE,




  _NL_CTYPE_CLASS = (((__LC_CTYPE) << 16) | (0)),
  _NL_CTYPE_TOUPPER,
  _NL_CTYPE_GAP1,
  _NL_CTYPE_TOLOWER,
  _NL_CTYPE_GAP2,
  _NL_CTYPE_CLASS32,
  _NL_CTYPE_GAP3,
  _NL_CTYPE_GAP4,
  _NL_CTYPE_GAP5,
  _NL_CTYPE_GAP6,
  _NL_CTYPE_CLASS_NAMES,
  _NL_CTYPE_MAP_NAMES,
  _NL_CTYPE_WIDTH,
  _NL_CTYPE_MB_CUR_MAX,
  _NL_CTYPE_CODESET_NAME,
  CODESET = _NL_CTYPE_CODESET_NAME,

  _NL_CTYPE_TOUPPER32,
  _NL_CTYPE_TOLOWER32,
  _NL_CTYPE_CLASS_OFFSET,
  _NL_CTYPE_MAP_OFFSET,
  _NL_CTYPE_INDIGITS_MB_LEN,
  _NL_CTYPE_INDIGITS0_MB,
  _NL_CTYPE_INDIGITS1_MB,
  _NL_CTYPE_INDIGITS2_MB,
  _NL_CTYPE_INDIGITS3_MB,
  _NL_CTYPE_INDIGITS4_MB,
  _NL_CTYPE_INDIGITS5_MB,
  _NL_CTYPE_INDIGITS6_MB,
  _NL_CTYPE_INDIGITS7_MB,
  _NL_CTYPE_INDIGITS8_MB,
  _NL_CTYPE_INDIGITS9_MB,
  _NL_CTYPE_INDIGITS_WC_LEN,
  _NL_CTYPE_INDIGITS0_WC,
  _NL_CTYPE_INDIGITS1_WC,
  _NL_CTYPE_INDIGITS2_WC,
  _NL_CTYPE_INDIGITS3_WC,
  _NL_CTYPE_INDIGITS4_WC,
  _NL_CTYPE_INDIGITS5_WC,
  _NL_CTYPE_INDIGITS6_WC,
  _NL_CTYPE_INDIGITS7_WC,
  _NL_CTYPE_INDIGITS8_WC,
  _NL_CTYPE_INDIGITS9_WC,
  _NL_CTYPE_OUTDIGIT0_MB,
  _NL_CTYPE_OUTDIGIT1_MB,
  _NL_CTYPE_OUTDIGIT2_MB,
  _NL_CTYPE_OUTDIGIT3_MB,
  _NL_CTYPE_OUTDIGIT4_MB,
  _NL_CTYPE_OUTDIGIT5_MB,
  _NL_CTYPE_OUTDIGIT6_MB,
  _NL_CTYPE_OUTDIGIT7_MB,
  _NL_CTYPE_OUTDIGIT8_MB,
  _NL_CTYPE_OUTDIGIT9_MB,
  _NL_CTYPE_OUTDIGIT0_WC,
  _NL_CTYPE_OUTDIGIT1_WC,
  _NL_CTYPE_OUTDIGIT2_WC,
  _NL_CTYPE_OUTDIGIT3_WC,
  _NL_CTYPE_OUTDIGIT4_WC,
  _NL_CTYPE_OUTDIGIT5_WC,
  _NL_CTYPE_OUTDIGIT6_WC,
  _NL_CTYPE_OUTDIGIT7_WC,
  _NL_CTYPE_OUTDIGIT8_WC,
  _NL_CTYPE_OUTDIGIT9_WC,
  _NL_CTYPE_TRANSLIT_TAB_SIZE,
  _NL_CTYPE_TRANSLIT_FROM_IDX,
  _NL_CTYPE_TRANSLIT_FROM_TBL,
  _NL_CTYPE_TRANSLIT_TO_IDX,
  _NL_CTYPE_TRANSLIT_TO_TBL,
  _NL_CTYPE_TRANSLIT_DEFAULT_MISSING_LEN,
  _NL_CTYPE_TRANSLIT_DEFAULT_MISSING,
  _NL_CTYPE_TRANSLIT_IGNORE_LEN,
  _NL_CTYPE_TRANSLIT_IGNORE,
  _NL_CTYPE_EXTRA_MAP_1,
  _NL_CTYPE_EXTRA_MAP_2,
  _NL_CTYPE_EXTRA_MAP_3,
  _NL_CTYPE_EXTRA_MAP_4,
  _NL_CTYPE_EXTRA_MAP_5,
  _NL_CTYPE_EXTRA_MAP_6,
  _NL_CTYPE_EXTRA_MAP_7,
  _NL_CTYPE_EXTRA_MAP_8,
  _NL_CTYPE_EXTRA_MAP_9,
  _NL_CTYPE_EXTRA_MAP_10,
  _NL_CTYPE_EXTRA_MAP_11,
  _NL_CTYPE_EXTRA_MAP_12,
  _NL_CTYPE_EXTRA_MAP_13,
  _NL_CTYPE_EXTRA_MAP_14,
  _NL_NUM_LC_CTYPE,




  __INT_CURR_SYMBOL = (((__LC_MONETARY) << 16) | (0)),



  __CURRENCY_SYMBOL,



  __MON_DECIMAL_POINT,



  __MON_THOUSANDS_SEP,



  __MON_GROUPING,



  __POSITIVE_SIGN,



  __NEGATIVE_SIGN,



  __INT_FRAC_DIGITS,



  __FRAC_DIGITS,



  __P_CS_PRECEDES,



  __P_SEP_BY_SPACE,



  __N_CS_PRECEDES,



  __N_SEP_BY_SPACE,



  __P_SIGN_POSN,



  __N_SIGN_POSN,



  _NL_MONETARY_CRNCYSTR,

  __INT_P_CS_PRECEDES,



  __INT_P_SEP_BY_SPACE,



  __INT_N_CS_PRECEDES,



  __INT_N_SEP_BY_SPACE,



  __INT_P_SIGN_POSN,



  __INT_N_SIGN_POSN,



  _NL_MONETARY_DUO_INT_CURR_SYMBOL,
  _NL_MONETARY_DUO_CURRENCY_SYMBOL,
  _NL_MONETARY_DUO_INT_FRAC_DIGITS,
  _NL_MONETARY_DUO_FRAC_DIGITS,
  _NL_MONETARY_DUO_P_CS_PRECEDES,
  _NL_MONETARY_DUO_P_SEP_BY_SPACE,
  _NL_MONETARY_DUO_N_CS_PRECEDES,
  _NL_MONETARY_DUO_N_SEP_BY_SPACE,
  _NL_MONETARY_DUO_INT_P_CS_PRECEDES,
  _NL_MONETARY_DUO_INT_P_SEP_BY_SPACE,
  _NL_MONETARY_DUO_INT_N_CS_PRECEDES,
  _NL_MONETARY_DUO_INT_N_SEP_BY_SPACE,
  _NL_MONETARY_DUO_P_SIGN_POSN,
  _NL_MONETARY_DUO_N_SIGN_POSN,
  _NL_MONETARY_DUO_INT_P_SIGN_POSN,
  _NL_MONETARY_DUO_INT_N_SIGN_POSN,
  _NL_MONETARY_UNO_VALID_FROM,
  _NL_MONETARY_UNO_VALID_TO,
  _NL_MONETARY_DUO_VALID_FROM,
  _NL_MONETARY_DUO_VALID_TO,
  _NL_MONETARY_CONVERSION_RATE,
  _NL_MONETARY_DECIMAL_POINT_WC,
  _NL_MONETARY_THOUSANDS_SEP_WC,
  _NL_MONETARY_CODESET,
  _NL_NUM_LC_MONETARY,



  __DECIMAL_POINT = (((__LC_NUMERIC) << 16) | (0)),



  RADIXCHAR = __DECIMAL_POINT,

  __THOUSANDS_SEP,



  THOUSEP = __THOUSANDS_SEP,

  __GROUPING,



  _NL_NUMERIC_DECIMAL_POINT_WC,
  _NL_NUMERIC_THOUSANDS_SEP_WC,
  _NL_NUMERIC_CODESET,
  _NL_NUM_LC_NUMERIC,

  __YESEXPR = (((__LC_MESSAGES) << 16) | (0)),

  __NOEXPR,

  __YESSTR,



  __NOSTR,



  _NL_MESSAGES_CODESET,
  _NL_NUM_LC_MESSAGES,

  _NL_PAPER_HEIGHT = (((__LC_PAPER) << 16) | (0)),
  _NL_PAPER_WIDTH,
  _NL_PAPER_CODESET,
  _NL_NUM_LC_PAPER,

  _NL_NAME_NAME_FMT = (((__LC_NAME) << 16) | (0)),
  _NL_NAME_NAME_GEN,
  _NL_NAME_NAME_MR,
  _NL_NAME_NAME_MRS,
  _NL_NAME_NAME_MISS,
  _NL_NAME_NAME_MS,
  _NL_NAME_CODESET,
  _NL_NUM_LC_NAME,

  _NL_ADDRESS_POSTAL_FMT = (((__LC_ADDRESS) << 16) | (0)),
  _NL_ADDRESS_COUNTRY_NAME,
  _NL_ADDRESS_COUNTRY_POST,
  _NL_ADDRESS_COUNTRY_AB2,
  _NL_ADDRESS_COUNTRY_AB3,
  _NL_ADDRESS_COUNTRY_CAR,
  _NL_ADDRESS_COUNTRY_NUM,
  _NL_ADDRESS_COUNTRY_ISBN,
  _NL_ADDRESS_LANG_NAME,
  _NL_ADDRESS_LANG_AB,
  _NL_ADDRESS_LANG_TERM,
  _NL_ADDRESS_LANG_LIB,
  _NL_ADDRESS_CODESET,
  _NL_NUM_LC_ADDRESS,

  _NL_TELEPHONE_TEL_INT_FMT = (((__LC_TELEPHONE) << 16) | (0)),
  _NL_TELEPHONE_TEL_DOM_FMT,
  _NL_TELEPHONE_INT_SELECT,
  _NL_TELEPHONE_INT_PREFIX,
  _NL_TELEPHONE_CODESET,
  _NL_NUM_LC_TELEPHONE,

  _NL_MEASUREMENT_MEASUREMENT = (((__LC_MEASUREMENT) << 16) | (0)),
  _NL_MEASUREMENT_CODESET,
  _NL_NUM_LC_MEASUREMENT,

  _NL_IDENTIFICATION_TITLE = (((__LC_IDENTIFICATION) << 16) | (0)),
  _NL_IDENTIFICATION_SOURCE,
  _NL_IDENTIFICATION_ADDRESS,
  _NL_IDENTIFICATION_CONTACT,
  _NL_IDENTIFICATION_EMAIL,
  _NL_IDENTIFICATION_TEL,
  _NL_IDENTIFICATION_FAX,
  _NL_IDENTIFICATION_LANGUAGE,
  _NL_IDENTIFICATION_TERRITORY,
  _NL_IDENTIFICATION_AUDIENCE,
  _NL_IDENTIFICATION_APPLICATION,
  _NL_IDENTIFICATION_ABBREVIATION,
  _NL_IDENTIFICATION_REVISION,
  _NL_IDENTIFICATION_DATE,
  _NL_IDENTIFICATION_CATEGORY,
  _NL_IDENTIFICATION_CODESET,
  _NL_NUM_LC_IDENTIFICATION,


  _NL_NUM
};
# 575 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 3
extern char *nl_langinfo (nl_item __item) throw ();
# 586 "/usr/lib/gcc/../../i686-inX-linux/include/langinfo.h" 3
extern char *__nl_langinfo_l (nl_item __item, __locale_t l);


}
# 38 "/usr/include/c++3.1/i686-inX-linux/bits/c++locale.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/iconv.h" 1 3
# 24 "/usr/lib/gcc/../../i686-inX-linux/include/iconv.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/iconv.h" 2 3


extern "C" {


typedef void *iconv_t;




extern iconv_t iconv_open (__const char *__tocode, __const char *__fromcode)
     throw ();




extern size_t iconv (iconv_t __cd, char **__restrict __inbuf,
                     size_t *__restrict __inbytesleft,
                     char **__restrict __outbuf,
                     size_t *__restrict __outbytesleft);


extern int iconv_close (iconv_t __cd) throw ();

}
# 39 "/usr/include/c++3.1/i686-inX-linux/bits/c++locale.h" 2 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/libintl.h" 1 3
# 30 "/usr/lib/gcc/../../i686-inX-linux/include/libintl.h" 3
extern "C" {




extern char *gettext (__const char *__msgid) throw ();



extern char *dgettext (__const char *__domainname, __const char *__msgid)
     throw ();
extern char *__dgettext (__const char *__domainname, __const char *__msgid)
     throw () __attribute__ ((__format_arg__ (2)));



extern char *dcgettext (__const char *__domainname,
                        __const char *__msgid, int __category) throw ();
extern char *__dcgettext (__const char *__domainname,
                          __const char *__msgid, int __category)
     throw () __attribute__ ((__format_arg__ (2)));




extern char *ngettext (__const char *__msgid1, __const char *__msgid2,
                       unsigned long int __n)
     throw () __attribute__ ((__format_arg__ (1))) __attribute__ ((__format_arg__ (2)));



extern char *dngettext (__const char *__domainname, __const char *__msgid1,
                        __const char *__msgid2, unsigned long int __n)
     throw () __attribute__ ((__format_arg__ (2))) __attribute__ ((__format_arg__ (3)));



extern char *dcngettext (__const char *__domainname, __const char *__msgid1,
                         __const char *__msgid2, unsigned long int __n,
                         int __category)
     throw () __attribute__ ((__format_arg__ (2))) __attribute__ ((__format_arg__ (3)));





extern char *textdomain (__const char *__domainname) throw ();



extern char *bindtextdomain (__const char *__domainname,
                             __const char *__dirname) throw ();



extern char *bind_textdomain_codeset (__const char *__domainname,
                                      __const char *__codeset) throw ();
# 115 "/usr/lib/gcc/../../i686-inX-linux/include/libintl.h" 3
}
# 40 "/usr/include/c++3.1/i686-inX-linux/bits/c++locale.h" 2 3



namespace std
{
  typedef __locale_t __c_locale;
}
# 47 "/usr/include/c++3.1/bits/localefwd.h" 2 3


# 1 "/usr/include/c++3.1/string" 1 3
# 44 "/usr/include/c++3.1/string" 3




# 1 "/usr/include/c++3.1/memory" 1 3
# 53 "/usr/include/c++3.1/memory" 3


# 1 "/usr/include/c++3.1/bits/stl_alloc.h" 1 3
# 84 "/usr/include/c++3.1/bits/stl_alloc.h" 3
# 1 "/usr/include/c++3.1/cassert" 1 3
# 47 "/usr/include/c++3.1/cassert" 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/assert.h" 1 3
# 65 "/usr/lib/gcc/../../i686-inX-linux/include/assert.h" 3
extern "C" {


extern void __assert_fail (__const char *__assertion, __const char *__file,
                           unsigned int __line, __const char *__function)
     throw () __attribute__ ((__noreturn__));


extern void __assert_perror_fail (int __errnum, __const char *__file,
                                  unsigned int __line,
                                  __const char *__function)
     throw () __attribute__ ((__noreturn__));




extern void __assert (const char *__assertion, const char *__file, int __line)
     throw () __attribute__ ((__noreturn__));


}
# 49 "/usr/include/c++3.1/cassert" 2 3
# 85 "/usr/include/c++3.1/bits/stl_alloc.h" 2 3
# 1 "/usr/include/c++3.1/bits/functexcept.h" 1 3
# 34 "/usr/include/c++3.1/bits/functexcept.h" 3
# 1 "/usr/include/c++3.1/exception_defines.h" 1 3
# 35 "/usr/include/c++3.1/bits/functexcept.h" 2 3

namespace std
{

  void
  __throw_bad_exception(void);


  void
  __throw_bad_alloc(void);


  void
  __throw_bad_cast(void);

  void
  __throw_bad_typeid(void);


  void
  __throw_logic_error(const char* __s);

  void
  __throw_domain_error(const char* __s);

  void
  __throw_invalid_argument(const char* __s);

  void
  __throw_length_error(const char* __s);

  void
  __throw_out_of_range(const char* __s);

  void
  __throw_runtime_error(const char* __s);

  void
  __throw_range_error(const char* __s);

  void
  __throw_overflow_error(const char* __s);

  void
  __throw_underflow_error(const char* __s);


  void
  __throw_ios_failure(const char* __s);
}
# 86 "/usr/include/c++3.1/bits/stl_alloc.h" 2 3
# 1 "/usr/include/c++3.1/bits/stl_threads.h" 1 3
# 54 "/usr/include/c++3.1/bits/stl_threads.h" 3
namespace std
{




  struct _Refcount_Base
  {

    typedef size_t _RC_t;


    volatile _RC_t _M_ref_count;


    __gthread_mutex_t _M_ref_count_lock;

    _Refcount_Base(_RC_t __n) : _M_ref_count(__n)
    {

      __gthread_mutex_t __tmp = {0, 0, 0, PTHREAD_MUTEX_TIMED_NP, { 0, 0 }};
      _M_ref_count_lock = __tmp;





    }

    void
    _M_incr()
    {
      __gthread_mutex_lock(&_M_ref_count_lock);
      ++_M_ref_count;
      __gthread_mutex_unlock(&_M_ref_count_lock);
    }

    _RC_t
    _M_decr()
    {
      __gthread_mutex_lock(&_M_ref_count_lock);
      volatile _RC_t __tmp = --_M_ref_count;
      __gthread_mutex_unlock(&_M_ref_count_lock);
      return __tmp;
    }
  };
# 109 "/usr/include/c++3.1/bits/stl_threads.h" 3
  template<int __dummy>
    struct _Swap_lock_struct
    { static __gthread_mutex_t _S_swap_lock; };

  template<int __dummy>
    __gthread_mutex_t
    _Swap_lock_struct<__dummy>::_S_swap_lock = {0, 0, 0, PTHREAD_MUTEX_TIMED_NP, { 0, 0 }};



  inline unsigned long
  _Atomic_swap(unsigned long * __p, unsigned long __q)
  {
    __gthread_mutex_lock(&_Swap_lock_struct<0>::_S_swap_lock);
    unsigned long __result = *__p;
    *__p = __q;
    __gthread_mutex_unlock(&_Swap_lock_struct<0>::_S_swap_lock);
    return __result;
  }
# 151 "/usr/include/c++3.1/bits/stl_threads.h" 3
  struct _STL_mutex_lock
  {





    __gthread_mutex_t _M_lock;

    void
    _M_initialize()
    {
# 184 "/usr/include/c++3.1/bits/stl_threads.h" 3
    }

    void
    _M_acquire_lock()
    {



      __gthread_mutex_lock(&_M_lock);
    }

    void
    _M_release_lock()
    {



      __gthread_mutex_unlock(&_M_lock);
    }
  };
# 220 "/usr/include/c++3.1/bits/stl_threads.h" 3
  struct _STL_auto_lock
  {
    _STL_mutex_lock& _M_lock;

    _STL_auto_lock(_STL_mutex_lock& __lock) : _M_lock(__lock)
    { _M_lock._M_acquire_lock(); }

    ~_STL_auto_lock() { _M_lock._M_release_lock(); }

  private:
    void operator=(const _STL_auto_lock&);
    _STL_auto_lock(const _STL_auto_lock&);
  };

}
# 87 "/usr/include/c++3.1/bits/stl_alloc.h" 2 3

namespace std
{
# 98 "/usr/include/c++3.1/bits/stl_alloc.h" 3
  class __new_alloc
  {
  public:
    static void*
    allocate(size_t __n)
    { return ::operator new(__n); }

    static void
    deallocate(void* __p, size_t)
    { ::operator delete(__p); }
  };
# 121 "/usr/include/c++3.1/bits/stl_alloc.h" 3
  template <int __inst>
    class __malloc_alloc_template
    {
    private:
      static void* _S_oom_malloc(size_t);
      static void* _S_oom_realloc(void*, size_t);
      static void (* __malloc_alloc_oom_handler)();

    public:
      static void*
      allocate(size_t __n)
      {
        void* __result = malloc(__n);
        if (0 == __result) __result = _S_oom_malloc(__n);
        return __result;
      }

      static void
      deallocate(void* __p, size_t )
      { free(__p); }

      static void*
      reallocate(void* __p, size_t , size_t __new_sz)
      {
        void* __result = realloc(__p, __new_sz);
        if (0 == __result) __result = _S_oom_realloc(__p, __new_sz);
        return __result;
      }

      static void (* __set_malloc_handler(void (*__f)()))()
      {
        void (* __old)() = __malloc_alloc_oom_handler;
        __malloc_alloc_oom_handler = __f;
        return(__old);
      }
    };


  template <int __inst>
    void (* __malloc_alloc_template<__inst>::__malloc_alloc_oom_handler)() = 0;

  template <int __inst>
    void*
    __malloc_alloc_template<__inst>::_S_oom_malloc(size_t __n)
    {
      void (* __my_malloc_handler)();
      void* __result;

      for (;;)
        {
          __my_malloc_handler = __malloc_alloc_oom_handler;
          if (0 == __my_malloc_handler)
            std::__throw_bad_alloc();
          (*__my_malloc_handler)();
          __result = malloc(__n);
          if (__result)
            return(__result);
        }
    }

  template <int __inst>
    void*
    __malloc_alloc_template<__inst>::_S_oom_realloc(void* __p, size_t __n)
    {
      void (* __my_malloc_handler)();
      void* __result;

      for (;;)
        {
          __my_malloc_handler = __malloc_alloc_oom_handler;
          if (0 == __my_malloc_handler)
            std::__throw_bad_alloc();
          (*__my_malloc_handler)();
          __result = realloc(__p, __n);
          if (__result)
            return(__result);
        }
    }






  typedef __new_alloc __mem_interface;
# 219 "/usr/include/c++3.1/bits/stl_alloc.h" 3
  template<class _Tp, class _Alloc>
  class __simple_alloc
  {
  public:
    static _Tp* allocate(size_t __n)
    { return 0 == __n ? 0 : (_Tp*) _Alloc::allocate(__n * sizeof (_Tp)); }

    static _Tp* allocate()
    { return (_Tp*) _Alloc::allocate(sizeof (_Tp)); }

    static void deallocate(_Tp* __p, size_t __n)
    { if (0 != __n) _Alloc::deallocate(__p, __n * sizeof (_Tp)); }

    static void deallocate(_Tp* __p)
    { _Alloc::deallocate(__p, sizeof (_Tp)); }
  };
# 251 "/usr/include/c++3.1/bits/stl_alloc.h" 3
  template <class _Alloc>
  class __debug_alloc
  {
  private:
    enum {_S_extra = 8};


  public:

    static void* allocate(size_t __n)
    {
      char* __result = (char*)_Alloc::allocate(__n + (int) _S_extra);
      *(size_t*)__result = __n;
      return __result + (int) _S_extra;
    }

    static void deallocate(void* __p, size_t __n)
    {
      char* __real_p = (char*)__p - (int) _S_extra;
      (static_cast<void> ((*(size_t*)__real_p == __n) ? 0 : (__assert_fail ("*(size_t*)__real_p == __n", "/usr/include/c++3.1/bits/stl_alloc.h", 270, __PRETTY_FUNCTION__), 0)));
      _Alloc::deallocate(__real_p, __n + (int) _S_extra);
    }

    static void* reallocate(void* __p, size_t __old_sz, size_t __new_sz)
    {
      char* __real_p = (char*)__p - (int) _S_extra;
      (static_cast<void> ((*(size_t*)__real_p == __old_sz) ? 0 : (__assert_fail ("*(size_t*)__real_p == __old_sz", "/usr/include/c++3.1/bits/stl_alloc.h", 277, __PRETTY_FUNCTION__), 0)));
      char* __result = (char*)
        _Alloc::reallocate(__real_p, __old_sz + (int) _S_extra,
                                     __new_sz + (int) _S_extra);
      *(size_t*)__result = __new_sz;
      return __result + (int) _S_extra;
    }
  };
# 324 "/usr/include/c++3.1/bits/stl_alloc.h" 3
template<bool __threads, int __inst>
  class __default_alloc_template
  {
  private:
    enum {_ALIGN = 8};
    enum {_MAX_BYTES = 128};
    enum {_NFREELISTS = _MAX_BYTES / _ALIGN};

    union _Obj
    {
      union _Obj* _M_free_list_link;
      char _M_client_data[1];
    };

    static _Obj* volatile _S_free_list[_NFREELISTS];


    static char* _S_start_free;
    static char* _S_end_free;
    static size_t _S_heap_size;

    static _STL_mutex_lock _S_node_allocator_lock;

    static size_t
    _S_round_up(size_t __bytes)
    { return (((__bytes) + (size_t) _ALIGN-1) & ~((size_t) _ALIGN - 1)); }

    static size_t
    _S_freelist_index(size_t __bytes)
    { return (((__bytes) + (size_t)_ALIGN-1)/(size_t)_ALIGN - 1); }



    static void*
    _S_refill(size_t __n);



    static char*
    _S_chunk_alloc(size_t __size, int& __nobjs);



    class _Lock
    {
    public:
      _Lock() { if (__threads) _S_node_allocator_lock._M_acquire_lock(); }
      ~_Lock() { if (__threads) _S_node_allocator_lock._M_release_lock(); }
    } __attribute__ ((__unused__));
    friend class _Lock;

  public:

    static void*
    allocate(size_t __n)
    {
      void* __ret = 0;

      if (__n > (size_t) _MAX_BYTES)
        __ret = __mem_interface::allocate(__n);
      else
        {
          _Obj* volatile* __my_free_list = _S_free_list
            + _S_freelist_index(__n);



          _Lock __lock_instance;
          _Obj* __restrict__ __result = *__my_free_list;
          if (__result == 0)
            __ret = _S_refill(_S_round_up(__n));
          else
            {
              *__my_free_list = __result -> _M_free_list_link;
              __ret = __result;
            }
        }
      return __ret;
    };


    static void
    deallocate(void* __p, size_t __n)
    {
      if (__n > (size_t) _MAX_BYTES)
        __mem_interface::deallocate(__p, __n);
      else
        {
          _Obj* volatile* __my_free_list
            = _S_free_list + _S_freelist_index(__n);
          _Obj* __q = (_Obj*)__p;



          _Lock __lock_instance;
          __q -> _M_free_list_link = *__my_free_list;
          *__my_free_list = __q;
        }
    }

    static void*
    reallocate(void* __p, size_t __old_sz, size_t __new_sz);
  };


  template<bool __threads, int __inst>
    inline bool
    operator==(const __default_alloc_template<__threads, __inst>&,
               const __default_alloc_template<__threads, __inst>&)
    { return true; }

  template<bool __threads, int __inst>
    inline bool
    operator!=(const __default_alloc_template<__threads, __inst>&,
               const __default_alloc_template<__threads, __inst>&)
    { return false; }





  template<bool __threads, int __inst>
    char*
    __default_alloc_template<__threads, __inst>::_S_chunk_alloc(size_t __size,
                                                                int& __nobjs)
    {
      char* __result;
      size_t __total_bytes = __size * __nobjs;
      size_t __bytes_left = _S_end_free - _S_start_free;

      if (__bytes_left >= __total_bytes)
      {
        __result = _S_start_free;
        _S_start_free += __total_bytes;
        return(__result);
      }
      else if (__bytes_left >= __size)
        {
          __nobjs = (int)(__bytes_left/__size);
          __total_bytes = __size * __nobjs;
          __result = _S_start_free;
          _S_start_free += __total_bytes;
          return(__result);
        }
      else
        {
          size_t __bytes_to_get =
            2 * __total_bytes + _S_round_up(_S_heap_size >> 4);

          if (__bytes_left > 0)
            {
              _Obj* volatile* __my_free_list =
                _S_free_list + _S_freelist_index(__bytes_left);

              ((_Obj*)_S_start_free) -> _M_free_list_link = *__my_free_list;
              *__my_free_list = (_Obj*)_S_start_free;
            }
          _S_start_free = (char*) __mem_interface::allocate(__bytes_to_get);
          if (0 == _S_start_free)
            {
              size_t __i;
              _Obj* volatile* __my_free_list;
              _Obj* __p;



              __i = __size;
              for (; __i <= (size_t) _MAX_BYTES; __i += (size_t) _ALIGN)
                {
                  __my_free_list = _S_free_list + _S_freelist_index(__i);
                  __p = *__my_free_list;
                  if (0 != __p)
                    {
                      *__my_free_list = __p -> _M_free_list_link;
                      _S_start_free = (char*)__p;
                      _S_end_free = _S_start_free + __i;
                      return(_S_chunk_alloc(__size, __nobjs));


                    }
                }
              _S_end_free = 0;
              _S_start_free = (char*)__mem_interface::allocate(__bytes_to_get);


            }
          _S_heap_size += __bytes_to_get;
          _S_end_free = _S_start_free + __bytes_to_get;
          return(_S_chunk_alloc(__size, __nobjs));
        }
    }





  template<bool __threads, int __inst>
    void*
    __default_alloc_template<__threads, __inst>::_S_refill(size_t __n)
    {
      int __nobjs = 20;
      char* __chunk = _S_chunk_alloc(__n, __nobjs);
      _Obj* volatile* __my_free_list;
      _Obj* __result;
      _Obj* __current_obj;
      _Obj* __next_obj;
      int __i;

      if (1 == __nobjs) return(__chunk);
      __my_free_list = _S_free_list + _S_freelist_index(__n);


      __result = (_Obj*)__chunk;
      *__my_free_list = __next_obj = (_Obj*)(__chunk + __n);
      for (__i = 1; ; __i++) {
        __current_obj = __next_obj;
        __next_obj = (_Obj*)((char*)__next_obj + __n);
        if (__nobjs - 1 == __i) {
          __current_obj -> _M_free_list_link = 0;
          break;
        } else {
          __current_obj -> _M_free_list_link = __next_obj;
        }
      }
      return(__result);
    }


  template<bool threads, int inst>
    void*
    __default_alloc_template<threads, inst>::reallocate(void* __p,
                                                        size_t __old_sz,
                                                        size_t __new_sz)
    {
      void* __result;
      size_t __copy_sz;

      if (__old_sz > (size_t) _MAX_BYTES && __new_sz > (size_t) _MAX_BYTES) {
        return(realloc(__p, __new_sz));
      }
      if (_S_round_up(__old_sz) == _S_round_up(__new_sz)) return(__p);
      __result = allocate(__new_sz);
      __copy_sz = __new_sz > __old_sz? __old_sz : __new_sz;
      memcpy(__result, __p, __copy_sz);
      deallocate(__p, __old_sz);
      return(__result);
    }

  template<bool __threads, int __inst>
  _STL_mutex_lock
  __default_alloc_template<__threads, __inst>::_S_node_allocator_lock
  = { {0, 0, 0, PTHREAD_MUTEX_TIMED_NP, { 0, 0 }} };

  template<bool __threads, int __inst>
  char* __default_alloc_template<__threads, __inst>::_S_start_free = 0;

  template<bool __threads, int __inst>
  char* __default_alloc_template<__threads, __inst>::_S_end_free = 0;

  template<bool __threads, int __inst>
  size_t __default_alloc_template<__threads, __inst>::_S_heap_size = 0;

  template<bool __threads, int __inst>
  typename __default_alloc_template<__threads, __inst>::_Obj* volatile
  __default_alloc_template<__threads, __inst>::_S_free_list[_NFREELISTS];

  typedef __default_alloc_template<true, 0> __alloc;
  typedef __default_alloc_template<false, 0> __single_client_alloc;
# 613 "/usr/include/c++3.1/bits/stl_alloc.h" 3
template <class _Tp>
class allocator
{
  typedef __alloc _Alloc;
public:
  typedef size_t size_type;
  typedef ptrdiff_t difference_type;
  typedef _Tp* pointer;
  typedef const _Tp* const_pointer;
  typedef _Tp& reference;
  typedef const _Tp& const_reference;
  typedef _Tp value_type;

  template <class _Tp1> struct rebind {
    typedef allocator<_Tp1> other;
  };

  allocator() throw() {}
  allocator(const allocator&) throw() {}
  template <class _Tp1> allocator(const allocator<_Tp1>&) throw() {}
  ~allocator() throw() {}

  pointer address(reference __x) const { return &__x; }
  const_pointer address(const_reference __x) const { return &__x; }



  _Tp* allocate(size_type __n, const void* = 0) {
    return __n != 0 ? static_cast<_Tp*>(_Alloc::allocate(__n * sizeof(_Tp)))
                    : 0;
  }


  void deallocate(pointer __p, size_type __n)
    { _Alloc::deallocate(__p, __n * sizeof(_Tp)); }

  size_type max_size() const throw()
    { return size_t(-1) / sizeof(_Tp); }

  void construct(pointer __p, const _Tp& __val) { new(__p) _Tp(__val); }
  void destroy(pointer __p) { __p->~_Tp(); }
};

template<>
class allocator<void> {
public:
  typedef size_t size_type;
  typedef ptrdiff_t difference_type;
  typedef void* pointer;
  typedef const void* const_pointer;
  typedef void value_type;

  template <class _Tp1> struct rebind {
    typedef allocator<_Tp1> other;
  };
};


template <class _T1, class _T2>
inline bool operator==(const allocator<_T1>&, const allocator<_T2>&)
{
  return true;
}

template <class _T1, class _T2>
inline bool operator!=(const allocator<_T1>&, const allocator<_T2>&)
{
  return false;
}
# 695 "/usr/include/c++3.1/bits/stl_alloc.h" 3
template <class _Tp, class _Alloc>
struct __allocator
{
  _Alloc __underlying_alloc;

  typedef size_t size_type;
  typedef ptrdiff_t difference_type;
  typedef _Tp* pointer;
  typedef const _Tp* const_pointer;
  typedef _Tp& reference;
  typedef const _Tp& const_reference;
  typedef _Tp value_type;

  template <class _Tp1> struct rebind {
    typedef __allocator<_Tp1, _Alloc> other;
  };

  __allocator() throw() {}
  __allocator(const __allocator& __a) throw()
    : __underlying_alloc(__a.__underlying_alloc) {}
  template <class _Tp1>
  __allocator(const __allocator<_Tp1, _Alloc>& __a) throw()
    : __underlying_alloc(__a.__underlying_alloc) {}
  ~__allocator() throw() {}

  pointer address(reference __x) const { return &__x; }
  const_pointer address(const_reference __x) const { return &__x; }


  _Tp* allocate(size_type __n, const void* = 0) {
    return __n != 0
        ? static_cast<_Tp*>(__underlying_alloc.allocate(__n * sizeof(_Tp)))
        : 0;
  }


  void deallocate(pointer __p, size_type __n)
    { __underlying_alloc.deallocate(__p, __n * sizeof(_Tp)); }

  size_type max_size() const throw()
    { return size_t(-1) / sizeof(_Tp); }

  void construct(pointer __p, const _Tp& __val) { new(__p) _Tp(__val); }
  void destroy(pointer __p) { __p->~_Tp(); }
};

template <class _Alloc>
class __allocator<void, _Alloc> {
  typedef size_t size_type;
  typedef ptrdiff_t difference_type;
  typedef void* pointer;
  typedef const void* const_pointer;
  typedef void value_type;

  template <class _Tp1> struct rebind {
    typedef __allocator<_Tp1, _Alloc> other;
  };
};

template <class _Tp, class _Alloc>
inline bool operator==(const __allocator<_Tp, _Alloc>& __a1,
                       const __allocator<_Tp, _Alloc>& __a2)
{
  return __a1.__underlying_alloc == __a2.__underlying_alloc;
}

template <class _Tp, class _Alloc>
inline bool operator!=(const __allocator<_Tp, _Alloc>& __a1,
                       const __allocator<_Tp, _Alloc>& __a2)
{
  return __a1.__underlying_alloc != __a2.__underlying_alloc;
}







template <int inst>
inline bool operator==(const __malloc_alloc_template<inst>&,
                       const __malloc_alloc_template<inst>&)
{
  return true;
}

template <int __inst>
inline bool operator!=(const __malloc_alloc_template<__inst>&,
                       const __malloc_alloc_template<__inst>&)
{
  return false;
}

template <class _Alloc>
inline bool operator==(const __debug_alloc<_Alloc>&,
                       const __debug_alloc<_Alloc>&) {
  return true;
}

template <class _Alloc>
inline bool operator!=(const __debug_alloc<_Alloc>&,
                       const __debug_alloc<_Alloc>&) {
  return false;
}
# 840 "/usr/include/c++3.1/bits/stl_alloc.h" 3
template <class _Tp, class _Allocator>
struct _Alloc_traits
{
  static const bool _S_instanceless = false;
  typedef typename _Allocator::template rebind<_Tp>::other allocator_type;
};

template <class _Tp, class _Allocator>
const bool _Alloc_traits<_Tp, _Allocator>::_S_instanceless;


template <class _Tp, class _Tp1>
struct _Alloc_traits<_Tp, allocator<_Tp1> >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __alloc> _Alloc_type;
  typedef allocator<_Tp> allocator_type;
};




template <class _Tp, int __inst>
struct _Alloc_traits<_Tp, __malloc_alloc_template<__inst> >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __malloc_alloc_template<__inst> > _Alloc_type;
  typedef __allocator<_Tp, __malloc_alloc_template<__inst> > allocator_type;
};


template <class _Tp, bool __threads, int __inst>
struct _Alloc_traits<_Tp, __default_alloc_template<__threads, __inst> >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __default_alloc_template<__threads, __inst> >
          _Alloc_type;
  typedef __allocator<_Tp, __default_alloc_template<__threads, __inst> >
          allocator_type;
};


template <class _Tp, class _Alloc>
struct _Alloc_traits<_Tp, __debug_alloc<_Alloc> >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __debug_alloc<_Alloc> > _Alloc_type;
  typedef __allocator<_Tp, __debug_alloc<_Alloc> > allocator_type;
};




template <class _Tp, class _Tp1, int __inst>
struct _Alloc_traits<_Tp,
                     __allocator<_Tp1, __malloc_alloc_template<__inst> > >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __malloc_alloc_template<__inst> > _Alloc_type;
  typedef __allocator<_Tp, __malloc_alloc_template<__inst> > allocator_type;
};


template <class _Tp, class _Tp1, bool __thr, int __inst>
struct _Alloc_traits<_Tp,
                      __allocator<_Tp1,
                                  __default_alloc_template<__thr, __inst> > >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __default_alloc_template<__thr,__inst> >
          _Alloc_type;
  typedef __allocator<_Tp, __default_alloc_template<__thr,__inst> >
          allocator_type;
};


template <class _Tp, class _Tp1, class _Alloc>
struct _Alloc_traits<_Tp, __allocator<_Tp1, __debug_alloc<_Alloc> > >
{
  static const bool _S_instanceless = true;
  typedef __simple_alloc<_Tp, __debug_alloc<_Alloc> > _Alloc_type;
  typedef __allocator<_Tp, __debug_alloc<_Alloc> > allocator_type;
};





  extern template class allocator<char>;
  extern template class allocator<wchar_t>;



  extern template class __default_alloc_template<true, 0>;

}
# 56 "/usr/include/c++3.1/memory" 2 3



# 1 "/usr/include/c++3.1/bits/stl_raw_storage_iter.h" 1 3
# 64 "/usr/include/c++3.1/bits/stl_raw_storage_iter.h" 3
namespace std
{




  template <class _ForwardIterator, class _Tp>
  class raw_storage_iterator
    : public iterator<output_iterator_tag, void, void, void, void>
    {
    protected:
      _ForwardIterator _M_iter;

    public:
      explicit
      raw_storage_iterator(_ForwardIterator __x) : _M_iter(__x) {}

      raw_storage_iterator&
      operator*() { return *this; }

      raw_storage_iterator&
      operator=(const _Tp& __element)
      {
        _Construct(&*_M_iter, __element);
        return *this;
      }

      raw_storage_iterator<_ForwardIterator, _Tp>&
      operator++()
      {
        ++_M_iter;
        return *this;
      }

      raw_storage_iterator<_ForwardIterator, _Tp>
      operator++(int)
      {
        raw_storage_iterator<_ForwardIterator, _Tp> __tmp = *this;
        ++_M_iter;
        return __tmp;
      }
    };
}
# 60 "/usr/include/c++3.1/memory" 2 3

namespace std
{







  template <class _Tp>
  pair<_Tp*, ptrdiff_t>
  __get_temporary_buffer(ptrdiff_t __len, _Tp*)
  {
    if (__len > ptrdiff_t(2147483647 / sizeof(_Tp)))
      __len = 2147483647 / sizeof(_Tp);

    while (__len > 0) {
      _Tp* __tmp = (_Tp*) std::malloc((std::size_t)__len * sizeof(_Tp));
      if (__tmp != 0)
        return pair<_Tp*, ptrdiff_t>(__tmp, __len);
      __len /= 2;
    }

    return pair<_Tp*, ptrdiff_t>((_Tp*)0, 0);
  }
# 102 "/usr/include/c++3.1/memory" 3
  template <class _Tp>
  inline pair<_Tp*, ptrdiff_t> get_temporary_buffer(ptrdiff_t __len) {
    return __get_temporary_buffer(__len, (_Tp*) 0);
  }
# 114 "/usr/include/c++3.1/memory" 3
  template <class _Tp>
  void return_temporary_buffer(_Tp* __p) {
    std::free(__p);
  }


template <class _Tp1>
  struct auto_ptr_ref
{
   _Tp1* _M_ptr;
   auto_ptr_ref(_Tp1* __p) : _M_ptr(__p) {}
};




template <class _Tp>
  class auto_ptr
{
private:
  _Tp* _M_ptr;

public:
  typedef _Tp element_type;

  explicit auto_ptr(_Tp* __p = 0) throw() : _M_ptr(__p) {}
  auto_ptr(auto_ptr& __a) throw() : _M_ptr(__a.release()) {}

  template <class _Tp1> auto_ptr(auto_ptr<_Tp1>& __a) throw()
    : _M_ptr(__a.release()) {}

  auto_ptr& operator=(auto_ptr& __a) throw() {
    reset(__a.release());
    return *this;
  }

  template <class _Tp1>
  auto_ptr& operator=(auto_ptr<_Tp1>& __a) throw() {
    reset(__a.release());
    return *this;
  }





  ~auto_ptr() { delete _M_ptr; }

  _Tp& operator*() const throw() {
    return *_M_ptr;
  }
  _Tp* operator->() const throw() {
    return _M_ptr;
  }
  _Tp* get() const throw() {
    return _M_ptr;
  }
  _Tp* release() throw() {
    _Tp* __tmp = _M_ptr;
    _M_ptr = 0;
    return __tmp;
  }
  void reset(_Tp* __p = 0) throw() {
    if (__p != _M_ptr) {
      delete _M_ptr;
      _M_ptr = __p;
    }
  }

public:
  auto_ptr(auto_ptr_ref<_Tp> __ref) throw()
    : _M_ptr(__ref._M_ptr) {}

  auto_ptr& operator=(auto_ptr_ref<_Tp> __ref) throw() {
    if (__ref._M_ptr != this->get()) {
      delete _M_ptr;
      _M_ptr = __ref._M_ptr;
    }
    return *this;
  }

  template <class _Tp1> operator auto_ptr_ref<_Tp1>() throw()
    { return auto_ptr_ref<_Tp>(this->release()); }
  template <class _Tp1> operator auto_ptr<_Tp1>() throw()
    { return auto_ptr<_Tp1>(this->release()); }
};

}
# 49 "/usr/include/c++3.1/string" 2 3



# 1 "/usr/include/c++3.1/bits/stl_function.h" 1 3
# 64 "/usr/include/c++3.1/bits/stl_function.h" 3
namespace std
{
# 101 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Arg, class _Result>
struct unary_function {
  typedef _Arg argument_type;
  typedef _Result result_type;
};




template <class _Arg1, class _Arg2, class _Result>
struct binary_function {
  typedef _Arg1 first_argument_type;
  typedef _Arg2 second_argument_type;
  typedef _Result result_type;
};
# 127 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Tp>
struct plus : public binary_function<_Tp,_Tp,_Tp> {
  _Tp operator()(const _Tp& __x, const _Tp& __y) const { return __x + __y; }
};


template <class _Tp>
struct minus : public binary_function<_Tp,_Tp,_Tp> {
  _Tp operator()(const _Tp& __x, const _Tp& __y) const { return __x - __y; }
};


template <class _Tp>
struct multiplies : public binary_function<_Tp,_Tp,_Tp> {
  _Tp operator()(const _Tp& __x, const _Tp& __y) const { return __x * __y; }
};


template <class _Tp>
struct divides : public binary_function<_Tp,_Tp,_Tp> {
  _Tp operator()(const _Tp& __x, const _Tp& __y) const { return __x / __y; }
};


template <class _Tp>
struct modulus : public binary_function<_Tp,_Tp,_Tp>
{
  _Tp operator()(const _Tp& __x, const _Tp& __y) const { return __x % __y; }
};


template <class _Tp>
struct negate : public unary_function<_Tp,_Tp>
{
  _Tp operator()(const _Tp& __x) const { return -__x; }
};
# 173 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Tp>
struct equal_to : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x == __y; }
};


template <class _Tp>
struct not_equal_to : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x != __y; }
};


template <class _Tp>
struct greater : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x > __y; }
};


template <class _Tp>
struct less : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x < __y; }
};


template <class _Tp>
struct greater_equal : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x >= __y; }
};


template <class _Tp>
struct less_equal : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x <= __y; }
};
# 222 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Tp>
struct logical_and : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x && __y; }
};


template <class _Tp>
struct logical_or : public binary_function<_Tp,_Tp,bool>
{
  bool operator()(const _Tp& __x, const _Tp& __y) const { return __x || __y; }
};


template <class _Tp>
struct logical_not : public unary_function<_Tp,bool>
{
  bool operator()(const _Tp& __x) const { return !__x; }
};
# 271 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Predicate>
class unary_negate
  : public unary_function<typename _Predicate::argument_type, bool> {
protected:
  _Predicate _M_pred;
public:
  explicit unary_negate(const _Predicate& __x) : _M_pred(__x) {}
  bool operator()(const typename _Predicate::argument_type& __x) const {
    return !_M_pred(__x);
  }
};


template <class _Predicate>
inline unary_negate<_Predicate>
not1(const _Predicate& __pred)
{
  return unary_negate<_Predicate>(__pred);
}


template <class _Predicate>
class binary_negate
  : public binary_function<typename _Predicate::first_argument_type,
                           typename _Predicate::second_argument_type,
                           bool> {
protected:
  _Predicate _M_pred;
public:
  explicit binary_negate(const _Predicate& __x) : _M_pred(__x) {}
  bool operator()(const typename _Predicate::first_argument_type& __x,
                  const typename _Predicate::second_argument_type& __y) const
  {
    return !_M_pred(__x, __y);
  }
};


template <class _Predicate>
inline binary_negate<_Predicate>
not2(const _Predicate& __pred)
{
  return binary_negate<_Predicate>(__pred);
}
# 349 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Operation>
class binder1st
  : public unary_function<typename _Operation::second_argument_type,
                          typename _Operation::result_type> {
protected:
  _Operation op;
  typename _Operation::first_argument_type value;
public:
  binder1st(const _Operation& __x,
            const typename _Operation::first_argument_type& __y)
      : op(__x), value(__y) {}
  typename _Operation::result_type
  operator()(const typename _Operation::second_argument_type& __x) const {
    return op(value, __x);
  }


  typename _Operation::result_type
  operator()(typename _Operation::second_argument_type& __x) const {
    return op(value, __x);
  }

};


template <class _Operation, class _Tp>
inline binder1st<_Operation>
bind1st(const _Operation& __fn, const _Tp& __x)
{
  typedef typename _Operation::first_argument_type _Arg1_type;
  return binder1st<_Operation>(__fn, _Arg1_type(__x));
}


template <class _Operation>
class binder2nd
  : public unary_function<typename _Operation::first_argument_type,
                          typename _Operation::result_type> {
protected:
  _Operation op;
  typename _Operation::second_argument_type value;
public:
  binder2nd(const _Operation& __x,
            const typename _Operation::second_argument_type& __y)
      : op(__x), value(__y) {}
  typename _Operation::result_type
  operator()(const typename _Operation::first_argument_type& __x) const {
    return op(__x, value);
  }


  typename _Operation::result_type
  operator()(typename _Operation::first_argument_type& __x) const {
    return op(__x, value);
  }

};


template <class _Operation, class _Tp>
inline binder2nd<_Operation>
bind2nd(const _Operation& __fn, const _Tp& __x)
{
  typedef typename _Operation::second_argument_type _Arg2_type;
  return binder2nd<_Operation>(__fn, _Arg2_type(__x));
}
# 438 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Arg, class _Result>
class pointer_to_unary_function : public unary_function<_Arg, _Result> {
protected:
  _Result (*_M_ptr)(_Arg);
public:
  pointer_to_unary_function() {}
  explicit pointer_to_unary_function(_Result (*__x)(_Arg)) : _M_ptr(__x) {}
  _Result operator()(_Arg __x) const { return _M_ptr(__x); }
};


template <class _Arg, class _Result>
inline pointer_to_unary_function<_Arg, _Result> ptr_fun(_Result (*__x)(_Arg))
{
  return pointer_to_unary_function<_Arg, _Result>(__x);
}


template <class _Arg1, class _Arg2, class _Result>
class pointer_to_binary_function :
  public binary_function<_Arg1,_Arg2,_Result> {
protected:
    _Result (*_M_ptr)(_Arg1, _Arg2);
public:
    pointer_to_binary_function() {}
    explicit pointer_to_binary_function(_Result (*__x)(_Arg1, _Arg2))
      : _M_ptr(__x) {}
    _Result operator()(_Arg1 __x, _Arg2 __y) const {
      return _M_ptr(__x, __y);
    }
};


template <class _Arg1, class _Arg2, class _Result>
inline pointer_to_binary_function<_Arg1,_Arg2,_Result>
ptr_fun(_Result (*__x)(_Arg1, _Arg2)) {
  return pointer_to_binary_function<_Arg1,_Arg2,_Result>(__x);
}


template <class _Tp>
struct _Identity : public unary_function<_Tp,_Tp> {
  _Tp& operator()(_Tp& __x) const { return __x; }
  const _Tp& operator()(const _Tp& __x) const { return __x; }
};

template <class _Pair>
struct _Select1st : public unary_function<_Pair, typename _Pair::first_type> {
  typename _Pair::first_type& operator()(_Pair& __x) const {
    return __x.first;
  }
  const typename _Pair::first_type& operator()(const _Pair& __x) const {
    return __x.first;
  }
};

template <class _Pair>
struct _Select2nd : public unary_function<_Pair, typename _Pair::second_type>
{
  typename _Pair::second_type& operator()(_Pair& __x) const {
    return __x.second;
  }
  const typename _Pair::second_type& operator()(const _Pair& __x) const {
    return __x.second;
  }
};
# 528 "/usr/include/c++3.1/bits/stl_function.h" 3
template <class _Ret, class _Tp>
class mem_fun_t : public unary_function<_Tp*,_Ret> {
public:
  explicit mem_fun_t(_Ret (_Tp::*__pf)()) : _M_f(__pf) {}
  _Ret operator()(_Tp* __p) const { return (__p->*_M_f)(); }
private:
  _Ret (_Tp::*_M_f)();
};


template <class _Ret, class _Tp>
class const_mem_fun_t : public unary_function<const _Tp*,_Ret> {
public:
  explicit const_mem_fun_t(_Ret (_Tp::*__pf)() const) : _M_f(__pf) {}
  _Ret operator()(const _Tp* __p) const { return (__p->*_M_f)(); }
private:
  _Ret (_Tp::*_M_f)() const;
};


template <class _Ret, class _Tp>
class mem_fun_ref_t : public unary_function<_Tp,_Ret> {
public:
  explicit mem_fun_ref_t(_Ret (_Tp::*__pf)()) : _M_f(__pf) {}
  _Ret operator()(_Tp& __r) const { return (__r.*_M_f)(); }
private:
  _Ret (_Tp::*_M_f)();
};


template <class _Ret, class _Tp>
class const_mem_fun_ref_t : public unary_function<_Tp,_Ret> {
public:
  explicit const_mem_fun_ref_t(_Ret (_Tp::*__pf)() const) : _M_f(__pf) {}
  _Ret operator()(const _Tp& __r) const { return (__r.*_M_f)(); }
private:
  _Ret (_Tp::*_M_f)() const;
};


template <class _Ret, class _Tp, class _Arg>
class mem_fun1_t : public binary_function<_Tp*,_Arg,_Ret> {
public:
  explicit mem_fun1_t(_Ret (_Tp::*__pf)(_Arg)) : _M_f(__pf) {}
  _Ret operator()(_Tp* __p, _Arg __x) const { return (__p->*_M_f)(__x); }
private:
  _Ret (_Tp::*_M_f)(_Arg);
};


template <class _Ret, class _Tp, class _Arg>
class const_mem_fun1_t : public binary_function<const _Tp*,_Arg,_Ret> {
public:
  explicit const_mem_fun1_t(_Ret (_Tp::*__pf)(_Arg) const) : _M_f(__pf) {}
  _Ret operator()(const _Tp* __p, _Arg __x) const
    { return (__p->*_M_f)(__x); }
private:
  _Ret (_Tp::*_M_f)(_Arg) const;
};


template <class _Ret, class _Tp, class _Arg>
class mem_fun1_ref_t : public binary_function<_Tp,_Arg,_Ret> {
public:
  explicit mem_fun1_ref_t(_Ret (_Tp::*__pf)(_Arg)) : _M_f(__pf) {}
  _Ret operator()(_Tp& __r, _Arg __x) const { return (__r.*_M_f)(__x); }
private:
  _Ret (_Tp::*_M_f)(_Arg);
};


template <class _Ret, class _Tp, class _Arg>
class const_mem_fun1_ref_t : public binary_function<_Tp,_Arg,_Ret> {
public:
  explicit const_mem_fun1_ref_t(_Ret (_Tp::*__pf)(_Arg) const) : _M_f(__pf) {}
  _Ret operator()(const _Tp& __r, _Arg __x) const { return (__r.*_M_f)(__x); }
private:
  _Ret (_Tp::*_M_f)(_Arg) const;
};


template <class _Tp>
class mem_fun_t<void, _Tp> : public unary_function<_Tp*,void> {
public:
  explicit mem_fun_t(void (_Tp::*__pf)()) : _M_f(__pf) {}
  void operator()(_Tp* __p) const { (__p->*_M_f)(); }
private:
  void (_Tp::*_M_f)();
};


template <class _Tp>
class const_mem_fun_t<void, _Tp> : public unary_function<const _Tp*,void> {
public:
  explicit const_mem_fun_t(void (_Tp::*__pf)() const) : _M_f(__pf) {}
  void operator()(const _Tp* __p) const { (__p->*_M_f)(); }
private:
  void (_Tp::*_M_f)() const;
};


template <class _Tp>
class mem_fun_ref_t<void, _Tp> : public unary_function<_Tp,void> {
public:
  explicit mem_fun_ref_t(void (_Tp::*__pf)()) : _M_f(__pf) {}
  void operator()(_Tp& __r) const { (__r.*_M_f)(); }
private:
  void (_Tp::*_M_f)();
};


template <class _Tp>
class const_mem_fun_ref_t<void, _Tp> : public unary_function<_Tp,void> {
public:
  explicit const_mem_fun_ref_t(void (_Tp::*__pf)() const) : _M_f(__pf) {}
  void operator()(const _Tp& __r) const { (__r.*_M_f)(); }
private:
  void (_Tp::*_M_f)() const;
};


template <class _Tp, class _Arg>
class mem_fun1_t<void, _Tp, _Arg> : public binary_function<_Tp*,_Arg,void> {
public:
  explicit mem_fun1_t(void (_Tp::*__pf)(_Arg)) : _M_f(__pf) {}
  void operator()(_Tp* __p, _Arg __x) const { (__p->*_M_f)(__x); }
private:
  void (_Tp::*_M_f)(_Arg);
};


template <class _Tp, class _Arg>
class const_mem_fun1_t<void, _Tp, _Arg>
  : public binary_function<const _Tp*,_Arg,void> {
public:
  explicit const_mem_fun1_t(void (_Tp::*__pf)(_Arg) const) : _M_f(__pf) {}
  void operator()(const _Tp* __p, _Arg __x) const { (__p->*_M_f)(__x); }
private:
  void (_Tp::*_M_f)(_Arg) const;
};


template <class _Tp, class _Arg>
class mem_fun1_ref_t<void, _Tp, _Arg>
  : public binary_function<_Tp,_Arg,void> {
public:
  explicit mem_fun1_ref_t(void (_Tp::*__pf)(_Arg)) : _M_f(__pf) {}
  void operator()(_Tp& __r, _Arg __x) const { (__r.*_M_f)(__x); }
private:
  void (_Tp::*_M_f)(_Arg);
};


template <class _Tp, class _Arg>
class const_mem_fun1_ref_t<void, _Tp, _Arg>
  : public binary_function<_Tp,_Arg,void> {
public:
  explicit const_mem_fun1_ref_t(void (_Tp::*__pf)(_Arg) const) : _M_f(__pf) {}
  void operator()(const _Tp& __r, _Arg __x) const { (__r.*_M_f)(__x); }
private:
  void (_Tp::*_M_f)(_Arg) const;
};





template <class _Ret, class _Tp>
inline mem_fun_t<_Ret,_Tp> mem_fun(_Ret (_Tp::*__f)())
  { return mem_fun_t<_Ret,_Tp>(__f); }

template <class _Ret, class _Tp>
inline const_mem_fun_t<_Ret,_Tp> mem_fun(_Ret (_Tp::*__f)() const)
  { return const_mem_fun_t<_Ret,_Tp>(__f); }

template <class _Ret, class _Tp>
inline mem_fun_ref_t<_Ret,_Tp> mem_fun_ref(_Ret (_Tp::*__f)())
  { return mem_fun_ref_t<_Ret,_Tp>(__f); }

template <class _Ret, class _Tp>
inline const_mem_fun_ref_t<_Ret,_Tp> mem_fun_ref(_Ret (_Tp::*__f)() const)
  { return const_mem_fun_ref_t<_Ret,_Tp>(__f); }

template <class _Ret, class _Tp, class _Arg>
inline mem_fun1_t<_Ret,_Tp,_Arg> mem_fun(_Ret (_Tp::*__f)(_Arg))
  { return mem_fun1_t<_Ret,_Tp,_Arg>(__f); }

template <class _Ret, class _Tp, class _Arg>
inline const_mem_fun1_t<_Ret,_Tp,_Arg> mem_fun(_Ret (_Tp::*__f)(_Arg) const)
  { return const_mem_fun1_t<_Ret,_Tp,_Arg>(__f); }

template <class _Ret, class _Tp, class _Arg>
inline mem_fun1_ref_t<_Ret,_Tp,_Arg> mem_fun_ref(_Ret (_Tp::*__f)(_Arg))
  { return mem_fun1_ref_t<_Ret,_Tp,_Arg>(__f); }

template <class _Ret, class _Tp, class _Arg>
inline const_mem_fun1_ref_t<_Ret,_Tp,_Arg>
mem_fun_ref(_Ret (_Tp::*__f)(_Arg) const)
  { return const_mem_fun1_ref_t<_Ret,_Tp,_Arg>(__f); }



}
# 53 "/usr/include/c++3.1/string" 2 3
# 1 "/usr/include/c++3.1/bits/basic_string.h" 1 3
# 44 "/usr/include/c++3.1/bits/basic_string.h" 3

# 1 "/usr/include/c++3.1/i686-inX-linux/bits/atomicity.h" 1 3
# 33 "/usr/include/c++3.1/i686-inX-linux/bits/atomicity.h" 3
typedef int _Atomic_word;

static inline _Atomic_word
__attribute__ ((__unused__))
__exchange_and_add (volatile _Atomic_word *__mem, int __val)
{
  register _Atomic_word __result;
  __asm__ __volatile__ ("lock; xaddl %0,%2"
                        : "=r" (__result)
                        : "0" (__val), "m" (*__mem)
                        : "memory");
  return __result;
}

static inline void
__attribute__ ((__unused__))
__atomic_add (volatile _Atomic_word* __mem, int __val)
{
  __asm__ __volatile__ ("lock; addl %0,%1"
                        : : "ir" (__val), "m" (*__mem) : "memory");
}
# 46 "/usr/include/c++3.1/bits/basic_string.h" 2 3

namespace std
{
# 88 "/usr/include/c++3.1/bits/basic_string.h" 3
  template<typename _CharT, typename _Traits, typename _Alloc>
    class basic_string
    {

    public:
      typedef _Traits traits_type;
      typedef typename _Traits::char_type value_type;
      typedef _Alloc allocator_type;
      typedef typename _Alloc::size_type size_type;
      typedef typename _Alloc::difference_type difference_type;
      typedef typename _Alloc::reference reference;
      typedef typename _Alloc::const_reference const_reference;
      typedef typename _Alloc::pointer pointer;
      typedef typename _Alloc::const_pointer const_pointer;
      typedef __gnu_cxx::__normal_iterator<pointer, basic_string> iterator;
      typedef __gnu_cxx::__normal_iterator<const_pointer, basic_string>
                                                            const_iterator;
      typedef reverse_iterator<const_iterator> const_reverse_iterator;
      typedef reverse_iterator<iterator> reverse_iterator;

    private:
# 123 "/usr/include/c++3.1/bits/basic_string.h" 3
      struct _Rep
      {

        typedef typename _Alloc::template rebind<char>::other _Raw_bytes_alloc;
# 141 "/usr/include/c++3.1/bits/basic_string.h" 3
        static const size_type _S_max_size;
        static const _CharT _S_terminal;

        size_type _M_length;
        size_type _M_capacity;
        _Atomic_word _M_references;

        bool
        _M_is_leaked() const
        { return _M_references < 0; }

        bool
        _M_is_shared() const
        { return _M_references > 0; }

        void
        _M_set_leaked()
        { _M_references = -1; }

        void
        _M_set_sharable()
        { _M_references = 0; }

        _CharT*
        _M_refdata() throw()
        { return reinterpret_cast<_CharT*>(this + 1); }

        _CharT&
        operator[](size_t __s) throw()
        { return _M_refdata() [__s]; }

        _CharT*
        _M_grab(const _Alloc& __alloc1, const _Alloc& __alloc2)
        {
          return (!_M_is_leaked() && __alloc1 == __alloc2)
                  ? _M_refcopy() : _M_clone(__alloc1);
        }


        static _Rep*
        _S_create(size_t, const _Alloc&);

        void
        _M_dispose(const _Alloc& __a)
        {
          if (__exchange_and_add(&_M_references, -1) <= 0)
            _M_destroy(__a);
        }

        void
        _M_destroy(const _Alloc&) throw();

        _CharT*
        _M_refcopy() throw()
        {
          __atomic_add(&_M_references, 1);
          return _M_refdata();
        }

        _CharT*
        _M_clone(const _Alloc&, size_type __res = 0);
      };


      struct _Alloc_hider : _Alloc
      {
        _Alloc_hider(_CharT* __dat, const _Alloc& __a)
        : _Alloc(__a), _M_p(__dat) { }

        _CharT* _M_p;
      };

    public:



      static const size_type npos = static_cast<size_type>(-1);

    private:

      mutable _Alloc_hider _M_dataplus;



      static size_type _S_empty_rep_storage[(sizeof(_Rep) + sizeof(_CharT) + sizeof(size_type) - 1)/sizeof(size_type)];

      _CharT*
      _M_data() const
      { return _M_dataplus._M_p; }

      _CharT*
      _M_data(_CharT* __p)
      { return (_M_dataplus._M_p = __p); }

      _Rep*
      _M_rep() const
      { return &((reinterpret_cast<_Rep*> (_M_data()))[-1]); }



      iterator
      _M_ibegin() const { return iterator(_M_data()); }

      iterator
      _M_iend() const { return iterator(_M_data() + this->size()); }

      void
      _M_leak()
      {
        if (!_M_rep()->_M_is_leaked())
          _M_leak_hard();
      }

      iterator
      _M_check(size_type __pos) const
      {
        if (__pos > this->size())
          __throw_out_of_range("basic_string::_M_check");
        return _M_ibegin() + __pos;
      }


      iterator
      _M_fold(size_type __pos, size_type __off) const
      {
        bool __testoff = __off < this->size() - __pos;
        size_type __newoff = __testoff ? __off : this->size() - __pos;
        return (_M_ibegin() + __pos + __newoff);
      }



      template<class _Iterator>
        static void
        _S_copy_chars(_CharT* __p, _Iterator __k1, _Iterator __k2)
        {
          for (; __k1 != __k2; ++__k1, ++__p)
            traits_type::assign(*__p, *__k1);
        }

      static void
      _S_copy_chars(_CharT* __p, iterator __k1, iterator __k2)
      { _S_copy_chars(__p, __k1.base(), __k2.base()); }

      static void
      _S_copy_chars(_CharT* __p, const_iterator __k1, const_iterator __k2)
      { _S_copy_chars(__p, __k1.base(), __k2.base()); }

      static void
      _S_copy_chars(_CharT* __p, _CharT* __k1, _CharT* __k2)
      { traits_type::copy(__p, __k1, __k2 - __k1); }

      static void
      _S_copy_chars(_CharT* __p, const _CharT* __k1, const _CharT* __k2)
      { traits_type::copy(__p, __k1, __k2 - __k1); }

      void
      _M_mutate(size_type __pos, size_type __len1, size_type __len2);

      void
      _M_leak_hard();

      static _Rep&
      _S_empty_rep()
      { return *reinterpret_cast<_Rep*>(&_S_empty_rep_storage); }

    public:




      inline
      basic_string();

      explicit
      basic_string(const _Alloc& __a);


      basic_string(const basic_string& __str);
      basic_string(const basic_string& __str, size_type __pos,
                   size_type __n = npos);
      basic_string(const basic_string& __str, size_type __pos,
                   size_type __n, const _Alloc& __a);

      basic_string(const _CharT* __s, size_type __n,
                   const _Alloc& __a = _Alloc());
      basic_string(const _CharT* __s, const _Alloc& __a = _Alloc());
      basic_string(size_type __n, _CharT __c, const _Alloc& __a = _Alloc());

      template<class _InputIterator>
        basic_string(_InputIterator __beg, _InputIterator __end,
                     const _Alloc& __a = _Alloc());

      ~basic_string()
      { _M_rep()->_M_dispose(this->get_allocator()); }

      basic_string&
      operator=(const basic_string& __str) { return this->assign(__str); }

      basic_string&
      operator=(const _CharT* __s) { return this->assign(__s); }

      basic_string&
      operator=(_CharT __c) { return this->assign(1, __c); }


      iterator
      begin()
      {
        _M_leak();
        return iterator(_M_data());
      }

      const_iterator
      begin() const
      { return const_iterator(_M_data()); }

      iterator
      end()
      {
         _M_leak();
         return iterator(_M_data() + this->size());
      }

      const_iterator
      end() const
      { return const_iterator(_M_data() + this->size()); }

      reverse_iterator
      rbegin()
      { return reverse_iterator(this->end()); }

      const_reverse_iterator
      rbegin() const
      { return const_reverse_iterator(this->end()); }

      reverse_iterator
      rend()
      { return reverse_iterator(this->begin()); }

      const_reverse_iterator
      rend() const
      { return const_reverse_iterator(this->begin()); }

    public:

      size_type
      size() const { return _M_rep()->_M_length; }

      size_type
      length() const { return _M_rep()->_M_length; }

      size_type
      max_size() const { return _Rep::_S_max_size; }

      void
      resize(size_type __n, _CharT __c);

      void
      resize(size_type __n) { this->resize(__n, _CharT()); }

      size_type
      capacity() const { return _M_rep()->_M_capacity; }

      void
      reserve(size_type __res_arg = 0);

      void
      clear() { _M_mutate(0, this->size(), 0); }

      bool
      empty() const { return this->size() == 0; }


      const_reference
      operator[] (size_type __pos) const
      { return _M_data()[__pos]; }

      reference
      operator[](size_type __pos)
      {
        _M_leak();
        return _M_data()[__pos];
      }

      const_reference
      at(size_type __n) const
      {
        if (__n >= this->size())
          __throw_out_of_range("basic_string::at");
        return _M_data()[__n];
      }

      reference
      at(size_type __n)
      {
        if (__n >= size())
          __throw_out_of_range("basic_string::at");
        _M_leak();
        return _M_data()[__n];
      }


      basic_string&
      operator+=(const basic_string& __str) { return this->append(__str); }

      basic_string&
      operator+=(const _CharT* __s) { return this->append(__s); }

      basic_string&
      operator+=(_CharT __c) { return this->append(size_type(1), __c); }

      basic_string&
      append(const basic_string& __str);

      basic_string&
      append(const basic_string& __str, size_type __pos, size_type __n);

      basic_string&
      append(const _CharT* __s, size_type __n);

      basic_string&
      append(const _CharT* __s)
      { return this->append(__s, traits_type::length(__s)); }

      basic_string&
      append(size_type __n, _CharT __c);

      template<class _InputIterator>
        basic_string&
        append(_InputIterator __first, _InputIterator __last)
        { return this->replace(_M_iend(), _M_iend(), __first, __last); }

      void
      push_back(_CharT __c)
      { this->replace(_M_iend(), _M_iend(), 1, __c); }

      basic_string&
      assign(const basic_string& __str);

      basic_string&
      assign(const basic_string& __str, size_type __pos, size_type __n)
      {
        const size_type __strsize = __str.size();
        if (__pos > __strsize)
          __throw_out_of_range("basic_string::assign");
        const bool __testn = __n < __strsize - __pos;
        const size_type __newsize = __testn ? __n : __strsize - __pos;
        return this->assign(__str._M_data() + __pos, __newsize);
      }

      basic_string&
      assign(const _CharT* __s, size_type __n)
      {
        if (__n > this->max_size())
          __throw_length_error("basic_string::assign");
        if (_M_rep()->_M_is_shared() || less<const _CharT*>()(__s, _M_data())
            || less<const _CharT*>()(_M_data() + this->size(), __s))
          return _M_replace_safe(_M_ibegin(), _M_iend(), __s, __s + __n);
        else
          {

            const size_type __pos = __s - _M_data();
            if (__pos >= __n)
              traits_type::copy(_M_data(), __s, __n);
            else if (__pos)
              traits_type::move(_M_data(), __s, __n);
            _M_rep()->_M_length = __n;
            _M_data()[__n] = _Rep::_S_terminal;
            return *this;
          }
      }

      basic_string&
      assign(const _CharT* __s)
      { return this->assign(__s, traits_type::length(__s)); }

      basic_string&
      assign(size_type __n, _CharT __c)
      { return this->replace(_M_ibegin(), _M_iend(), __n, __c); }

      template<class _InputIterator>
        basic_string&
        assign(_InputIterator __first, _InputIterator __last)
        { return this->replace(_M_ibegin(), _M_iend(), __first, __last); }

      void
      insert(iterator __p, size_type __n, _CharT __c)
      { this->replace(__p, __p, __n, __c); }

      template<class _InputIterator>
        void insert(iterator __p, _InputIterator __beg, _InputIterator __end)
        { this->replace(__p, __p, __beg, __end); }

      basic_string&
      insert(size_type __pos1, const basic_string& __str)
      { return this->insert(__pos1, __str, 0, __str.size()); }

      basic_string&
      insert(size_type __pos1, const basic_string& __str,
             size_type __pos2, size_type __n)
      {
        const size_type __strsize = __str.size();
        if (__pos2 > __strsize)
          __throw_out_of_range("basic_string::insert");
        const bool __testn = __n < __strsize - __pos2;
        const size_type __newsize = __testn ? __n : __strsize - __pos2;
        return this->insert(__pos1, __str._M_data() + __pos2, __newsize);
      }

      basic_string&
      insert(size_type __pos, const _CharT* __s, size_type __n)
      {
        const size_type __size = this->size();
        if (__pos > __size)
          __throw_out_of_range("basic_string::insert");
        if (__size > this->max_size() - __n)
          __throw_length_error("basic_string::insert");
        if (_M_rep()->_M_is_shared() || less<const _CharT*>()(__s, _M_data())
            || less<const _CharT*>()(_M_data() + __size, __s))
          return _M_replace_safe(_M_ibegin() + __pos, _M_ibegin() + __pos,
                                 __s, __s + __n);
        else
          {



            const size_type __off = __s - _M_data();
            _M_mutate(__pos, 0, __n);
            __s = _M_data() + __off;
            _CharT* __p = _M_data() + __pos;
            if (__s + __n <= __p)
              traits_type::copy(__p, __s, __n);
            else if (__s >= __p)
              traits_type::copy(__p, __s + __n, __n);
            else
              {
                traits_type::copy(__p, __s, __p - __s);
                traits_type::copy(__p + (__p - __s), __p + __n, __n - (__p - __s));
              }
            return *this;
          }
       }

      basic_string&
      insert(size_type __pos, const _CharT* __s)
      { return this->insert(__pos, __s, traits_type::length(__s)); }

      basic_string&
      insert(size_type __pos, size_type __n, _CharT __c)
      {
        this->insert(_M_check(__pos), __n, __c);
        return *this;
      }

      iterator
      insert(iterator __p, _CharT __c = _CharT())
      {
        size_type __pos = __p - _M_ibegin();
        this->insert(_M_check(__pos), size_type(1), __c);
        _M_rep()->_M_set_leaked();
        return this->_M_ibegin() + __pos;
      }

      basic_string&
      erase(size_type __pos = 0, size_type __n = npos)
      {
        return this->replace(_M_check(__pos), _M_fold(__pos, __n),
                             _M_data(), _M_data());
      }

      iterator
      erase(iterator __position)
      {
        size_type __i = __position - _M_ibegin();
        this->replace(__position, __position + 1, _M_data(), _M_data());
        _M_rep()->_M_set_leaked();
        return _M_ibegin() + __i;
      }

      iterator
      erase(iterator __first, iterator __last)
      {
        size_type __i = __first - _M_ibegin();
        this->replace(__first, __last, _M_data(), _M_data());
        _M_rep()->_M_set_leaked();
       return _M_ibegin() + __i;
      }

      basic_string&
      replace(size_type __pos, size_type __n, const basic_string& __str)
      { return this->replace(__pos, __n, __str._M_data(), __str.size()); }

      basic_string&
      replace(size_type __pos1, size_type __n1, const basic_string& __str,
              size_type __pos2, size_type __n2);

      basic_string&
      replace(size_type __pos, size_type __n1, const _CharT* __s,
              size_type __n2)
      {
        const size_type __size = this->size();
        if (__pos > __size)
          __throw_out_of_range("basic_string::replace");
        if (__size - __n1 > this->max_size() - __n2)
          __throw_length_error("basic_string::replace");
        const bool __testn1 = __n1 < __size - __pos;
        const size_type __foldn1 = __testn1 ? __n1 : __size - __pos;
        if (_M_rep()->_M_is_shared() || less<const _CharT*>()(__s, _M_data())
            || less<const _CharT*>()(_M_data() + __size, __s))
          return _M_replace_safe(_M_ibegin() + __pos,
                                 _M_ibegin() + __pos + __foldn1, __s, __s + __n2);
        else return this->replace(_M_check(__pos), _M_fold(__pos, __n1),
                                  __s, __s + __n2);
      }

      basic_string&
      replace(size_type __pos, size_type __n1, const _CharT* __s)
      { return this->replace(__pos, __n1, __s, traits_type::length(__s)); }

      basic_string&
      replace(size_type __pos, size_type __n1, size_type __n2, _CharT __c)
      { return this->replace(_M_check(__pos), _M_fold(__pos, __n1), __n2, __c); }

      basic_string&
      replace(iterator __i1, iterator __i2, const basic_string& __str)
      { return this->replace(__i1, __i2, __str._M_data(), __str.size()); }

      basic_string&
      replace(iterator __i1, iterator __i2,
                           const _CharT* __s, size_type __n)
      { return this->replace(__i1 - _M_ibegin(), __i2 - __i1, __s, __n); }

      basic_string&
      replace(iterator __i1, iterator __i2, const _CharT* __s)
      { return this->replace(__i1, __i2, __s, traits_type::length(__s)); }

      basic_string&
      replace(iterator __i1, iterator __i2, size_type __n, _CharT __c);

      template<class _InputIterator>
        basic_string&
        replace(iterator __i1, iterator __i2,
                _InputIterator __k1, _InputIterator __k2)
        { return _M_replace(__i1, __i2, __k1, __k2,
             typename iterator_traits<_InputIterator>::iterator_category()); }

    private:
      template<class _InputIterator>
        basic_string&
        _M_replace(iterator __i1, iterator __i2, _InputIterator __k1,
                   _InputIterator __k2, input_iterator_tag);

      template<class _ForwardIterator>
        basic_string&
        _M_replace_safe(iterator __i1, iterator __i2, _ForwardIterator __k1,
                   _ForwardIterator __k2);



      template<class _InIter>
        static _CharT*
        _S_construct_aux(_InIter __beg, _InIter __end, const _Alloc& __a,
                         __false_type)
        {
          typedef typename iterator_traits<_InIter>::iterator_category _Tag;
          return _S_construct(__beg, __end, __a, _Tag());
        }

      template<class _InIter>
        static _CharT*
        _S_construct_aux(_InIter __beg, _InIter __end, const _Alloc& __a,
                         __true_type)
        {
          return _S_construct(static_cast<size_type>(__beg),
                              static_cast<value_type>(__end), __a);
        }

      template<class _InIter>
        static _CharT*
        _S_construct(_InIter __beg, _InIter __end, const _Alloc& __a)
        {
          typedef typename _Is_integer<_InIter>::_Integral _Integral;
          return _S_construct_aux(__beg, __end, __a, _Integral());
        }


      template<class _InIter>
        static _CharT*
         _S_construct(_InIter __beg, _InIter __end, const _Alloc& __a,
                      input_iterator_tag);



      template<class _FwdIter>
        static _CharT*
        _S_construct(_FwdIter __beg, _FwdIter __end, const _Alloc& __a,
                     forward_iterator_tag);

      static _CharT*
      _S_construct(size_type __req, _CharT __c, const _Alloc& __a);

    public:

      size_type
      copy(_CharT* __s, size_type __n, size_type __pos = 0) const;

      void
      swap(basic_string<_CharT, _Traits, _Alloc>& __s);


      const _CharT*
      c_str() const
      {

        size_type __n = this->size();
        traits_type::assign(_M_data()[__n], _Rep::_S_terminal);
        return _M_data();
      }

      const _CharT*
      data() const { return _M_data(); }

      allocator_type
      get_allocator() const { return _M_dataplus; }

      size_type
      find(const _CharT* __s, size_type __pos, size_type __n) const;

      size_type
      find(const basic_string& __str, size_type __pos = 0) const
      { return this->find(__str.data(), __pos, __str.size()); }

      size_type
      find(const _CharT* __s, size_type __pos = 0) const
      { return this->find(__s, __pos, traits_type::length(__s)); }

      size_type
      find(_CharT __c, size_type __pos = 0) const;

      size_type
      rfind(const basic_string& __str, size_type __pos = npos) const
      { return this->rfind(__str.data(), __pos, __str.size()); }

      size_type
      rfind(const _CharT* __s, size_type __pos, size_type __n) const;

      size_type
      rfind(const _CharT* __s, size_type __pos = npos) const
      { return this->rfind(__s, __pos, traits_type::length(__s)); }

      size_type
      rfind(_CharT __c, size_type __pos = npos) const;

      size_type
      find_first_of(const basic_string& __str, size_type __pos = 0) const
      { return this->find_first_of(__str.data(), __pos, __str.size()); }

      size_type
      find_first_of(const _CharT* __s, size_type __pos, size_type __n) const;

      size_type
      find_first_of(const _CharT* __s, size_type __pos = 0) const
      { return this->find_first_of(__s, __pos, traits_type::length(__s)); }

      size_type
      find_first_of(_CharT __c, size_type __pos = 0) const
      { return this->find(__c, __pos); }

      size_type
      find_last_of(const basic_string& __str, size_type __pos = npos) const
      { return this->find_last_of(__str.data(), __pos, __str.size()); }

      size_type
      find_last_of(const _CharT* __s, size_type __pos, size_type __n) const;

      size_type
      find_last_of(const _CharT* __s, size_type __pos = npos) const
      { return this->find_last_of(__s, __pos, traits_type::length(__s)); }

      size_type
      find_last_of(_CharT __c, size_type __pos = npos) const
      { return this->rfind(__c, __pos); }

      size_type
      find_first_not_of(const basic_string& __str, size_type __pos = 0) const
      { return this->find_first_not_of(__str.data(), __pos, __str.size()); }

      size_type
      find_first_not_of(const _CharT* __s, size_type __pos,
                        size_type __n) const;

      size_type
      find_first_not_of(const _CharT* __s, size_type __pos = 0) const
      { return this->find_first_not_of(__s, __pos, traits_type::length(__s)); }

      size_type
      find_first_not_of(_CharT __c, size_type __pos = 0) const;

      size_type
      find_last_not_of(const basic_string& __str, size_type __pos = npos) const
      { return this->find_last_not_of(__str.data(), __pos, __str.size()); }

      size_type
      find_last_not_of(const _CharT* __s, size_type __pos,
                       size_type __n) const;
      size_type
      find_last_not_of(const _CharT* __s, size_type __pos = npos) const
      { return this->find_last_not_of(__s, __pos, traits_type::length(__s)); }

      size_type
      find_last_not_of(_CharT __c, size_type __pos = npos) const;

      basic_string
      substr(size_type __pos = 0, size_type __n = npos) const
      {
        if (__pos > this->size())
          __throw_out_of_range("basic_string::substr");
        return basic_string(*this, __pos, __n);
      }

      int
      compare(const basic_string& __str) const
      {
        size_type __size = this->size();
        size_type __osize = __str.size();
        size_type __len = min(__size, __osize);

        int __r = traits_type::compare(_M_data(), __str.data(), __len);
        if (!__r)
          __r = __size - __osize;
        return __r;
      }

      int
      compare(size_type __pos, size_type __n, const basic_string& __str) const;

      int
      compare(size_type __pos1, size_type __n1, const basic_string& __str,
              size_type __pos2, size_type __n2) const;

      int
      compare(const _CharT* __s) const;



      int
      compare(size_type __pos, size_type __n1, const _CharT* __s) const;

      int
      compare(size_type __pos, size_type __n1, const _CharT* __s,
              size_type __n2) const;
  };


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline basic_string<_CharT, _Traits, _Alloc>::
    basic_string()
    : _M_dataplus(_S_empty_rep()._M_refcopy(), _Alloc()) { }


  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>
    operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
              const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    {
      basic_string<_CharT, _Traits, _Alloc> __str(__lhs);
      __str.append(__rhs);
      return __str;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT,_Traits,_Alloc>
    operator+(const _CharT* __lhs,
              const basic_string<_CharT,_Traits,_Alloc>& __rhs);

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT,_Traits,_Alloc>
    operator+(_CharT __lhs, const basic_string<_CharT,_Traits,_Alloc>& __rhs);

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline basic_string<_CharT, _Traits, _Alloc>
    operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
             const _CharT* __rhs)
    {
      basic_string<_CharT, _Traits, _Alloc> __str(__lhs);
      __str.append(__rhs);
      return __str;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline basic_string<_CharT, _Traits, _Alloc>
    operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, _CharT __rhs)
    {
      typedef basic_string<_CharT, _Traits, _Alloc> __string_type;
      typedef typename __string_type::size_type __size_type;
      __string_type __str(__lhs);
      __str.append(__size_type(1), __rhs);
      return __str;
    }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator==(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __lhs.compare(__rhs) == 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator==(const _CharT* __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __rhs.compare(__lhs) == 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator==(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const _CharT* __rhs)
    { return __lhs.compare(__rhs) == 0; }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __rhs.compare(__lhs) != 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator!=(const _CharT* __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __rhs.compare(__lhs) != 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const _CharT* __rhs)
    { return __lhs.compare(__rhs) != 0; }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator<(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
              const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __lhs.compare(__rhs) < 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator<(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
              const _CharT* __rhs)
    { return __lhs.compare(__rhs) < 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator<(const _CharT* __lhs,
              const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __rhs.compare(__lhs) > 0; }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator>(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
              const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __lhs.compare(__rhs) > 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator>(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
              const _CharT* __rhs)
    { return __lhs.compare(__rhs) > 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator>(const _CharT* __lhs,
              const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __rhs.compare(__lhs) < 0; }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator<=(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __lhs.compare(__rhs) <= 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator<=(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const _CharT* __rhs)
    { return __lhs.compare(__rhs) <= 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator<=(const _CharT* __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
  { return __rhs.compare(__lhs) >= 0; }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator>=(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __lhs.compare(__rhs) >= 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator>=(const basic_string<_CharT, _Traits, _Alloc>& __lhs,
               const _CharT* __rhs)
    { return __lhs.compare(__rhs) >= 0; }

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline bool
    operator>=(const _CharT* __lhs,
             const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { return __rhs.compare(__lhs) <= 0; }


  template<typename _CharT, typename _Traits, typename _Alloc>
    inline void
    swap(basic_string<_CharT, _Traits, _Alloc>& __lhs,
         basic_string<_CharT, _Traits, _Alloc>& __rhs)
    { __lhs.swap(__rhs); }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_istream<_CharT, _Traits>&
    operator>>(basic_istream<_CharT, _Traits>& __is,
               basic_string<_CharT, _Traits, _Alloc>& __str);

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __os,
               const basic_string<_CharT, _Traits, _Alloc>& __str);

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_istream<_CharT,_Traits>&
    getline(basic_istream<_CharT, _Traits>& __is,
            basic_string<_CharT, _Traits, _Alloc>& __str, _CharT __delim);

  template<typename _CharT, typename _Traits, typename _Alloc>
    inline basic_istream<_CharT,_Traits>&
    getline(basic_istream<_CharT, _Traits>& __is,
            basic_string<_CharT, _Traits, _Alloc>& __str);
}
# 54 "/usr/include/c++3.1/string" 2 3



# 1 "/usr/include/c++3.1/bits/basic_string.tcc" 1 3
# 45 "/usr/include/c++3.1/bits/basic_string.tcc" 3

namespace std
{
  template<typename _CharT, typename _Traits, typename _Alloc>
    const typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    _Rep::_S_max_size = (((npos - sizeof(_Rep))/sizeof(_CharT)) - 1) / 4;

  template<typename _CharT, typename _Traits, typename _Alloc>
    const _CharT
    basic_string<_CharT, _Traits, _Alloc>::
    _Rep::_S_terminal = _CharT();

  template<typename _CharT, typename _Traits, typename _Alloc>
    const typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::npos;



  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::_S_empty_rep_storage[
    (sizeof(_Rep) + sizeof(_CharT) + sizeof(size_type) - 1)/sizeof(size_type)];





  template<typename _CharT, typename _Traits, typename _Alloc>
    template<typename _InIter>
      _CharT*
      basic_string<_CharT, _Traits, _Alloc>::
      _S_construct(_InIter __beg, _InIter __end, const _Alloc& __a,
                   input_iterator_tag)
      {
        if (__beg == __end && __a == _Alloc())
          return _S_empty_rep()._M_refcopy();

        _CharT __buf[100];
        size_type __i = 0;
        while (__beg != __end && __i < sizeof(__buf) / sizeof(_CharT))
          {
            __buf[__i++] = *__beg;
            ++__beg;
          }
        _Rep* __r = _Rep::_S_create(__i, __a);
        traits_type::copy(__r->_M_refdata(), __buf, __i);
        __r->_M_length = __i;
        try
          {



            for (;;)
              {
                _CharT* __p = __r->_M_refdata() + __r->_M_length;
                _CharT* __last = __r->_M_refdata() + __r->_M_capacity;
                for (;;)
                  {
                    if (__beg == __end)
                      {
                        __r->_M_length = __p - __r->_M_refdata();
                        *__p = _Rep::_S_terminal;
                        return __r->_M_refdata();
                      }
                    if (__p == __last)
                      break;
                    *__p++ = *__beg;
                    ++__beg;
                  }

                size_type __len = __p - __r->_M_refdata();
                _Rep* __another = _Rep::_S_create(__len + 1, __a);
                traits_type::copy(__another->_M_refdata(),
                                  __r->_M_refdata(), __len);
                __r->_M_destroy(__a);
                __r = __another;
                __r->_M_length = __len;
              }
          }
        catch(...)
          {
            __r->_M_destroy(__a);
            throw;
          }
        return 0;
      }

  template<typename _CharT, typename _Traits, typename _Alloc>
    template <class _InIter>
      _CharT*
      basic_string<_CharT, _Traits, _Alloc>::
      _S_construct(_InIter __beg, _InIter __end, const _Alloc& __a,
                   forward_iterator_tag)
      {
        size_type __dnew = static_cast<size_type>(distance(__beg, __end));


        if (__builtin_expect(__beg == _InIter(0), 0))
          __throw_logic_error("attempt to create string with null pointer");

        if (__beg == __end && __a == _Alloc())
          return _S_empty_rep()._M_refcopy();


        _Rep* __r = _Rep::_S_create(__dnew, __a);
        try
          { _S_copy_chars(__r->_M_refdata(), __beg, __end); }
        catch(...)
          {
            __r->_M_destroy(__a);
            throw;
          }
        __r->_M_length = __dnew;

        __r->_M_refdata()[__dnew] = _Rep::_S_terminal;
        return __r->_M_refdata();
      }

  template<typename _CharT, typename _Traits, typename _Alloc>
    _CharT*
    basic_string<_CharT, _Traits, _Alloc>::
    _S_construct(size_type __n, _CharT __c, const _Alloc& __a)
    {
      if (__n == 0 && __a == _Alloc())
        return _S_empty_rep()._M_refcopy();


      _Rep* __r = _Rep::_S_create(__n, __a);
      try
        {
          if (__n)
            traits_type::assign(__r->_M_refdata(), __n, __c);
        }
      catch(...)
        {
          __r->_M_destroy(__a);
          throw;
        }
      __r->_M_length = __n;
      __r->_M_refdata()[__n] = _Rep::_S_terminal;
      return __r->_M_refdata();
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(const basic_string& __str)
    : _M_dataplus(__str._M_rep()->_M_grab(_Alloc(), __str.get_allocator()),
                 __str.get_allocator())
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(const _Alloc& __a)
    : _M_dataplus(_S_construct(size_type(), _CharT(), __a), __a)
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(const basic_string& __str, size_type __pos, size_type __n)
    : _M_dataplus(_S_construct(__str._M_check(__pos),
                               __str._M_fold(__pos, __n), _Alloc()), _Alloc())
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(const basic_string& __str, size_type __pos,
                 size_type __n, const _Alloc& __a)
    : _M_dataplus(_S_construct(__str._M_check(__pos),
                               __str._M_fold(__pos, __n), __a), __a)
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(const _CharT* __s, size_type __n, const _Alloc& __a)
    : _M_dataplus(_S_construct(__s, __s + __n, __a), __a)
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(const _CharT* __s, const _Alloc& __a)
    : _M_dataplus(_S_construct(__s, __s ? __s + traits_type::length(__s) : 0,
                               __a), __a)
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(size_type __n, _CharT __c, const _Alloc& __a)
    : _M_dataplus(_S_construct(__n, __c, __a), __a)
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    template<typename _InputIter>
    basic_string<_CharT, _Traits, _Alloc>::
    basic_string(_InputIter __beg, _InputIter __end, const _Alloc& __a)
    : _M_dataplus(_S_construct(__beg, __end, __a), __a)
    { }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::assign(const basic_string& __str)
    {
      if (_M_rep() != __str._M_rep())
        {

          allocator_type __a = this->get_allocator();
          _CharT* __tmp = __str._M_rep()->_M_grab(__a, __str.get_allocator());
          _M_rep()->_M_dispose(__a);
          _M_data(__tmp);
        }
      return *this;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    void
    basic_string<_CharT, _Traits, _Alloc>::_Rep::
    _M_destroy(const _Alloc& __a) throw ()
    {
      size_type __size = sizeof(_Rep) + (_M_capacity + 1) * sizeof(_CharT);
      _Raw_bytes_alloc(__a).deallocate(reinterpret_cast<char*>(this), __size);
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    void
    basic_string<_CharT, _Traits, _Alloc>::_M_leak_hard()
    {
      if (_M_rep()->_M_is_shared())
        _M_mutate(0, 0, 0);
      _M_rep()->_M_set_leaked();
    }







  template<typename _CharT, typename _Traits, typename _Alloc>
    void
    basic_string<_CharT, _Traits, _Alloc>::
    _M_mutate(size_type __pos, size_type __len1, size_type __len2)
    {
      size_type __old_size = this->size();
      const size_type __new_size = __old_size + __len2 - __len1;
      const _CharT* __src = _M_data() + __pos + __len1;
      const size_type __how_much = __old_size - __pos - __len1;

      if (_M_rep()->_M_is_shared() || __new_size > capacity())
        {

          allocator_type __a = get_allocator();


          const size_type __pagesize = 4096;
          const size_type __malloc_header_size = 4 * sizeof (void*);

          const size_type __page_capacity = (__pagesize - __malloc_header_size
                                             - sizeof(_Rep) - sizeof(_CharT))
                                             / sizeof(_CharT);
          _Rep* __r;
          if (__new_size > capacity() && __new_size > __page_capacity)

            __r = _Rep::_S_create(__new_size > 2*capacity() ?
                                  __new_size : 2*capacity(), __a);
          else
            __r = _Rep::_S_create(__new_size, __a);
          try
            {
              if (__pos)
                traits_type::copy(__r->_M_refdata(), _M_data(), __pos);
              if (__how_much)
                traits_type::copy(__r->_M_refdata() + __pos + __len2,
                                  __src, __how_much);
            }
          catch(...)
            {
              __r->_M_dispose(get_allocator());
              throw;
            }
          _M_rep()->_M_dispose(__a);
          _M_data(__r->_M_refdata());
      }
      else if (__how_much && __len1 != __len2)
        {

          traits_type::move(_M_data() + __pos + __len2, __src, __how_much);
        }
      _M_rep()->_M_set_sharable();
      _M_rep()->_M_length = __new_size;
      _M_data()[__new_size] = _Rep::_S_terminal;

    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    void
    basic_string<_CharT, _Traits, _Alloc>::reserve(size_type __res)
    {
      if (__res > this->capacity() || _M_rep()->_M_is_shared())
        {
          if (__res > this->max_size())
            __throw_length_error("basic_string::reserve");

          if (__res < this->size())
            __res = this->size();
          allocator_type __a = get_allocator();
          _CharT* __tmp = _M_rep()->_M_clone(__a, __res - this->size());
          _M_rep()->_M_dispose(__a);
          _M_data(__tmp);
        }
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    void basic_string<_CharT, _Traits, _Alloc>::swap(basic_string& __s)
    {
      if (_M_rep()->_M_is_leaked())
        _M_rep()->_M_set_sharable();
      if (__s._M_rep()->_M_is_leaked())
        __s._M_rep()->_M_set_sharable();
      if (this->get_allocator() == __s.get_allocator())
        {
          _CharT* __tmp = _M_data();
          _M_data(__s._M_data());
          __s._M_data(__tmp);
        }

      else
        {
          basic_string __tmp1(_M_ibegin(), _M_iend(), __s.get_allocator());
          basic_string __tmp2(__s._M_ibegin(), __s._M_iend(),
                              this->get_allocator());
          *this = __tmp2;
          __s = __tmp1;
        }
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::_Rep*
    basic_string<_CharT, _Traits, _Alloc>::_Rep::
    _S_create(size_t __capacity, const _Alloc& __alloc)
    {
      typedef basic_string<_CharT, _Traits, _Alloc> __string_type;


      if (__capacity > _S_max_size)



        __throw_length_error("basic_string::_S_create");




      size_t __size = (__capacity + 1) * sizeof(_CharT) + sizeof(_Rep);
# 421 "/usr/include/c++3.1/bits/basic_string.tcc" 3
      const size_t __pagesize = 4096;
      const size_t __subpagesize = 128;
      const size_t __malloc_header_size = 4 * sizeof (void*);
      if ((__size + __malloc_header_size) > __pagesize)
        {
          size_t __extra =
            (__pagesize - ((__size + __malloc_header_size) % __pagesize))
            % __pagesize;
          __capacity += __extra / sizeof(_CharT);
          __size = (__capacity + 1) * sizeof(_CharT) + sizeof(_Rep);
        }
      else if (__size > __subpagesize)
        {
          size_t __extra =
            (__subpagesize - ((__size + __malloc_header_size) % __subpagesize))
            % __subpagesize;
          __capacity += __extra / sizeof(_CharT);
          __size = (__capacity + 1) * sizeof(_CharT) + sizeof(_Rep);
        }



      void* __place = _Raw_bytes_alloc(__alloc).allocate(__size);
      _Rep *__p = new (__place) _Rep;
      __p->_M_capacity = __capacity;
      __p->_M_set_sharable();
      __p->_M_length = 0;
      return __p;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    _CharT*
    basic_string<_CharT, _Traits, _Alloc>::_Rep::
    _M_clone(const _Alloc& __alloc, size_type __res)
    {

      const size_type __requested_cap = _M_length + __res;

      const size_type __pagesize = 4096;
      const size_type __malloc_header_size = 4 * sizeof (void*);

      const size_type __page_capacity =
        (__pagesize - __malloc_header_size - sizeof(_Rep) - sizeof(_CharT))
        / sizeof(_CharT);
      _Rep* __r;
      if (__requested_cap > _M_capacity && __requested_cap > __page_capacity)

        __r = _Rep::_S_create(__requested_cap > 2*_M_capacity ?
                              __requested_cap : 2*_M_capacity, __alloc);
      else
        __r = _Rep::_S_create(__requested_cap, __alloc);

      if (_M_length)
        {
          try
            { traits_type::copy(__r->_M_refdata(), _M_refdata(), _M_length); }
          catch(...)
            {
              __r->_M_destroy(__alloc);
              throw;
            }
        }
      __r->_M_length = _M_length;
      return __r->_M_refdata();
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    void
    basic_string<_CharT, _Traits, _Alloc>::resize(size_type __n, _CharT __c)
    {
      if (__n > max_size())
        __throw_length_error("basic_string::resize");
      size_type __size = this->size();
      if (__size < __n)
        this->append(__n - __size, __c);
      else if (__n < __size)
        this->erase(__n);

    }
# 508 "/usr/include/c++3.1/bits/basic_string.tcc" 3
  template<typename _CharT, typename _Traits, typename _Alloc>
    template<typename _InputIter>
      basic_string<_CharT, _Traits, _Alloc>&
      basic_string<_CharT, _Traits, _Alloc>::
      _M_replace(iterator __i1, iterator __i2, _InputIter __k1,
                 _InputIter __k2, input_iterator_tag)
      {

        basic_string __s(__k1, __k2);
        return _M_replace_safe(__i1, __i2, __s._M_ibegin(), __s._M_iend());
      }






  template<typename _CharT, typename _Traits, typename _Alloc>
    template<typename _ForwardIter>
      basic_string<_CharT, _Traits, _Alloc>&
      basic_string<_CharT, _Traits, _Alloc>::
      _M_replace_safe(iterator __i1, iterator __i2, _ForwardIter __k1,
                      _ForwardIter __k2)
      {
        size_type __dnew = static_cast<size_type>(distance(__k1, __k2));
        size_type __dold = __i2 - __i1;
        size_type __dmax = this->max_size();

        if (__dmax <= __dnew)
          __throw_length_error("basic_string::_M_replace");
        size_type __off = __i1 - _M_ibegin();
        _M_mutate(__off, __dold, __dnew);


        if (__dnew)
          _S_copy_chars(_M_data() + __off, __k1, __k2);

        return *this;
      }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::
    replace(size_type __pos1, size_type __n1, const basic_string& __str,
            size_type __pos2, size_type __n2)
    {
      const size_type __strsize = __str.size();
      if (__pos2 > __strsize)
        __throw_out_of_range("basic_string::replace");
      const bool __testn2 = __n2 < __strsize - __pos2;
      const size_type __foldn2 = __testn2 ? __n2 : __strsize - __pos2;
      return this->replace(__pos1, __n1,
                           __str._M_data() + __pos2, __foldn2);
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::
    append(const basic_string& __str)
    {



      size_type __size = __str.size();
      size_type __len = __size + this->size();
      if (__len > this->capacity())
        this->reserve(__len);
      return _M_replace_safe(_M_iend(), _M_iend(), __str._M_ibegin(),
                             __str._M_iend());
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::
    append(const basic_string& __str, size_type __pos, size_type __n)
    {



      size_type __len = min(__str.size() - __pos, __n) + this->size();
      if (__len > this->capacity())
        this->reserve(__len);
      return _M_replace_safe(_M_iend(), _M_iend(), __str._M_check(__pos),
                             __str._M_fold(__pos, __n));
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::
    append(const _CharT* __s, size_type __n)
    {
      size_type __len = __n + this->size();
      if (__len > this->capacity())
        this->reserve(__len);
      return _M_replace_safe(_M_iend(), _M_iend(), __s, __s + __n);
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::
    append(size_type __n, _CharT __c)
    {
      size_type __len = __n + this->size();
      if (__len > this->capacity())
        this->reserve(__len);
       return this->replace(_M_iend(), _M_iend(), __n, __c);
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>
    operator+(const _CharT* __lhs,
              const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    {
      typedef basic_string<_CharT, _Traits, _Alloc> __string_type;
      typedef typename __string_type::size_type __size_type;
      __size_type __len = _Traits::length(__lhs);
      __string_type __str;
      __str.reserve(__len + __rhs.size());
      __str.append(__lhs, __lhs + __len);
      __str.append(__rhs);
      return __str;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>
    operator+(_CharT __lhs, const basic_string<_CharT, _Traits, _Alloc>& __rhs)
    {
      typedef basic_string<_CharT, _Traits, _Alloc> __string_type;
      typedef typename __string_type::size_type __size_type;
      __string_type __str;
      __size_type __len = __rhs.size();
      __str.reserve(__len + 1);
      __str.append(__size_type(1), __lhs);
      __str.append(__rhs);
      return __str;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_string<_CharT, _Traits, _Alloc>&
    basic_string<_CharT, _Traits, _Alloc>::
    replace(iterator __i1, iterator __i2, size_type __n2, _CharT __c)
    {
      size_type __n1 = __i2 - __i1;
      size_type __off1 = __i1 - _M_ibegin();
      if (max_size() - (this->size() - __n1) <= __n2)
        __throw_length_error("basic_string::replace");
      _M_mutate (__off1, __n1, __n2);

      if (__n2)
        traits_type::assign(_M_data() + __off1, __n2, __c);
      return *this;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    copy(_CharT* __s, size_type __n, size_type __pos) const
    {
      if (__pos > this->size())
        __throw_out_of_range("basic_string::copy");

      if (__n > this->size() - __pos)
        __n = this->size() - __pos;

      traits_type::copy(__s, _M_data() + __pos, __n);

      return __n;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find(const _CharT* __s, size_type __pos, size_type __n) const
    {
      size_type __size = this->size();
      size_t __xpos = __pos;
      const _CharT* __data = _M_data();
      for (; __xpos + __n <= __size; ++__xpos)
        if (traits_type::compare(__data + __xpos, __s, __n) == 0)
          return __xpos;
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find(_CharT __c, size_type __pos) const
    {
      size_type __size = this->size();
      size_type __ret = npos;
      if (__pos < __size)
        {
          const _CharT* __data = _M_data();
          size_type __n = __size - __pos;
          const _CharT* __p = traits_type::find(__data + __pos, __n, __c);
          if (__p)
            __ret = __p - __data;
        }
      return __ret;
    }


  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    rfind(const _CharT* __s, size_type __pos, size_type __n) const
    {
      size_type __size = this->size();
      if (__n <= __size)
        {
          __pos = std::min(__size - __n, __pos);
          const _CharT* __data = _M_data();
          do
            {
              if (traits_type::compare(__data + __pos, __s, __n) == 0)
                return __pos;
            }
          while (__pos-- > 0);
        }
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    rfind(_CharT __c, size_type __pos) const
    {
      size_type __size = this->size();
      if (__size)
        {
          size_t __xpos = __size - 1;
          if (__xpos > __pos)
            __xpos = __pos;

          for (++__xpos; __xpos-- > 0; )
            if (traits_type::eq(_M_data()[__xpos], __c))
              return __xpos;
        }
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find_first_of(const _CharT* __s, size_type __pos, size_type __n) const
    {
      for (; __n && __pos < this->size(); ++__pos)
        {
          const _CharT* __p = traits_type::find(__s, __n, _M_data()[__pos]);
          if (__p)
            return __pos;
        }
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find_last_of(const _CharT* __s, size_type __pos, size_type __n) const
    {
      size_type __size = this->size();
      if (__size && __n)
        {
          if (--__size > __pos)
            __size = __pos;
          do
            {
              if (traits_type::find(__s, __n, _M_data()[__size]))
                return __size;
            }
          while (__size-- != 0);
        }
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find_first_not_of(const _CharT* __s, size_type __pos, size_type __n) const
    {
      size_t __xpos = __pos;
      for (; __xpos < this->size(); ++__xpos)
        if (!traits_type::find(__s, __n, _M_data()[__xpos]))
          return __xpos;
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find_first_not_of(_CharT __c, size_type __pos) const
    {
      size_t __xpos = __pos;
      for (; __xpos < this->size(); ++__xpos)
        if (!traits_type::eq(_M_data()[__xpos], __c))
          return __xpos;
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find_last_not_of(const _CharT* __s, size_type __pos, size_type __n) const
    {
      size_type __size = this->size();
      if (__size)
        {
          if (--__size > __pos)
            __size = __pos;
          do
            {
              if (!traits_type::find(__s, __n, _M_data()[__size]))
                return __size;
            }
          while (__size--);
        }
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    typename basic_string<_CharT, _Traits, _Alloc>::size_type
    basic_string<_CharT, _Traits, _Alloc>::
    find_last_not_of(_CharT __c, size_type __pos) const
    {
      size_type __size = this->size();
      if (__size)
        {
          if (--__size > __pos)
            __size = __pos;
          do
            {
              if (!traits_type::eq(_M_data()[__size], __c))
                return __size;
            }
          while (__size--);
        }
      return npos;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    int
    basic_string<_CharT, _Traits, _Alloc>::
    compare(size_type __pos, size_type __n, const basic_string& __str) const
    {
      size_type __size = this->size();
      size_type __osize = __str.size();
      if (__pos > __size)
        __throw_out_of_range("basic_string::compare");

      size_type __rsize= min(__size - __pos, __n);
      size_type __len = min(__rsize, __osize);
      int __r = traits_type::compare(_M_data() + __pos, __str.data(), __len);
      if (!__r)
        __r = __rsize - __osize;
      return __r;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    int
    basic_string<_CharT, _Traits, _Alloc>::
    compare(size_type __pos1, size_type __n1, const basic_string& __str,
            size_type __pos2, size_type __n2) const
    {
      size_type __size = this->size();
      size_type __osize = __str.size();
      if (__pos1 > __size || __pos2 > __osize)
        __throw_out_of_range("basic_string::compare");

      size_type __rsize = min(__size - __pos1, __n1);
      size_type __rosize = min(__osize - __pos2, __n2);
      size_type __len = min(__rsize, __rosize);
      int __r = traits_type::compare(_M_data() + __pos1,
                                     __str.data() + __pos2, __len);
      if (!__r)
        __r = __rsize - __rosize;
      return __r;
    }


  template<typename _CharT, typename _Traits, typename _Alloc>
    int
    basic_string<_CharT, _Traits, _Alloc>::
    compare(const _CharT* __s) const
    {
      size_type __size = this->size();
      int __r = traits_type::compare(_M_data(), __s, __size);
      if (!__r)
        __r = __size - traits_type::length(__s);
      return __r;
    }


  template<typename _CharT, typename _Traits, typename _Alloc>
    int
    basic_string <_CharT, _Traits, _Alloc>::
    compare(size_type __pos, size_type __n1, const _CharT* __s) const
    {
      size_type __size = this->size();
      if (__pos > __size)
        __throw_out_of_range("basic_string::compare");

      size_type __osize = traits_type::length(__s);
      size_type __rsize = min(__size - __pos, __n1);
      size_type __len = min(__rsize, __osize);
      int __r = traits_type::compare(_M_data() + __pos, __s, __len);
      if (!__r)
        __r = __rsize - __osize;
      return __r;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    int
    basic_string <_CharT, _Traits, _Alloc>::
    compare(size_type __pos, size_type __n1, const _CharT* __s,
            size_type __n2) const
    {
      size_type __size = this->size();
      if (__pos > __size)
        __throw_out_of_range("basic_string::compare");

      size_type __osize = min(traits_type::length(__s), __n2);
      size_type __rsize = min(__size - __pos, __n1);
      size_type __len = min(__rsize, __osize);
      int __r = traits_type::compare(_M_data() + __pos, __s, __len);
      if (!__r)
        __r = __rsize - __osize;
      return __r;
    }

  template <class _CharT, class _Traits, class _Alloc>
    void
    _S_string_copy(const basic_string<_CharT, _Traits, _Alloc>& __str,
                   _CharT* __buf, typename _Alloc::size_type __bufsiz)
    {
      typedef typename _Alloc::size_type size_type;
      size_type __strsize = __str.size();
      size_type __bytes = min(__strsize, __bufsiz - 1);
      _Traits::copy(__buf, __str.data(), __bytes);
      __buf[__bytes] = _CharT();
    }




  extern template class basic_string<char>;
  extern template
    basic_istream<char>&
    operator>>(basic_istream<char>&, string&);
  extern template
    basic_ostream<char>&
    operator<<(basic_ostream<char>&, const string&);
  extern template
    basic_istream<char>&
    getline(basic_istream<char>&, string&, char);
  extern template
    basic_istream<char>&
    getline(basic_istream<char>&, string&);

  extern template class basic_string<wchar_t>;
  extern template
    basic_istream<wchar_t>&
    operator>>(basic_istream<wchar_t>&, wstring&);
  extern template
    basic_ostream<wchar_t>&
    operator<<(basic_ostream<wchar_t>&, const wstring&);
  extern template
    basic_istream<wchar_t>&
    getline(basic_istream<wchar_t>&, wstring&, wchar_t);
  extern template
    basic_istream<wchar_t>&
    getline(basic_istream<wchar_t>&, wstring&);
}
# 58 "/usr/include/c++3.1/string" 2 3
# 50 "/usr/include/c++3.1/bits/localefwd.h" 2 3
# 1 "/usr/include/c++3.1/bits/functexcept.h" 1 3
# 34 "/usr/include/c++3.1/bits/functexcept.h" 3
# 1 "/usr/include/c++3.1/exception_defines.h" 1 3
# 35 "/usr/include/c++3.1/bits/functexcept.h" 2 3

namespace std
{

  void
  __throw_bad_exception(void);


  void
  __throw_bad_alloc(void);


  void
  __throw_bad_cast(void);

  void
  __throw_bad_typeid(void);


  void
  __throw_logic_error(const char* __s);

  void
  __throw_domain_error(const char* __s);

  void
  __throw_invalid_argument(const char* __s);

  void
  __throw_length_error(const char* __s);

  void
  __throw_out_of_range(const char* __s);

  void
  __throw_runtime_error(const char* __s);

  void
  __throw_range_error(const char* __s);

  void
  __throw_overflow_error(const char* __s);

  void
  __throw_underflow_error(const char* __s);


  void
  __throw_ios_failure(const char* __s);
}
# 51 "/usr/include/c++3.1/bits/localefwd.h" 2 3


namespace std
{

  class locale;


  template<typename _CharT>
    inline bool
    isspace(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isprint(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    iscntrl(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isupper(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    islower(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isalpha(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isdigit(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    ispunct(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isxdigit(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isalnum(_CharT, const locale&);

  template<typename _CharT>
    inline bool
    isgraph(_CharT, const locale&);

  template<typename _CharT>
    inline _CharT
    toupper(_CharT, const locale&);

  template<typename _CharT>
    inline _CharT
    tolower(_CharT, const locale&);



  class ctype_base;
  template<typename _CharT>
    class ctype;
  template<> class ctype<char>;



  template<typename _CharT>
    class ctype_byname;


  class codecvt_base;
  class __enc_traits;
  template<typename _InternT, typename _ExternT, typename _StateT>
    class codecvt;
  template<> class codecvt<char, char, mbstate_t>;



  template<typename _InternT, typename _ExternT, typename _StateT>
    class codecvt_byname;


  template<typename _CharT, typename _InIter = istreambuf_iterator<_CharT> >
    class num_get;
  template<typename _CharT, typename _OutIter = ostreambuf_iterator<_CharT> >
    class num_put;
  template<typename _CharT> class numpunct;
  template<typename _CharT> class numpunct_byname;


  template<typename _CharT>
    class collate;
  template<typename _CharT> class
    collate_byname;


  class time_base;
  template<typename _CharT, typename _InIter = istreambuf_iterator<_CharT> >
    class time_get;
  template<typename _CharT, typename _InIter = istreambuf_iterator<_CharT> >
    class time_get_byname;
  template<typename _CharT, typename _OutIter = ostreambuf_iterator<_CharT> >
    class time_put;
  template<typename _CharT, typename _OutIter = ostreambuf_iterator<_CharT> >
    class time_put_byname;


  class money_base;
  template<typename _CharT, typename _InIter = istreambuf_iterator<_CharT> >
    class money_get;
  template<typename _CharT, typename _OutIter = ostreambuf_iterator<_CharT> >
    class money_put;
  template<typename _CharT, bool _Intl = false>
    class moneypunct;
  template<typename _CharT, bool _Intl = false>
    class moneypunct_byname;


  class messages_base;
  template<typename _CharT>
    class messages;
  template<typename _CharT>
    class messages_byname;


  class locale
  {
  public:

    typedef unsigned int category;


    class facet;
    class id;
    class _Impl;

    friend class facet;
    friend class _Impl;

    template<typename _Facet>
      friend const _Facet&
      use_facet(const locale&);

    template<typename _Facet>
      friend bool
      has_facet(const locale&) throw();



    static const category none = 0;
    static const category ctype = 1L << 0;
    static const category numeric = 1L << 1;
    static const category collate = 1L << 2;
    static const category time = 1L << 3;
    static const category monetary = 1L << 4;
    static const category messages = 1L << 5;
    static const category all = (collate | ctype | monetary |
                                           numeric | time | messages);


    locale() throw();

    locale(const locale& __other) throw();

    explicit
    locale(const char* __s);

    locale(const locale& __base, const char* __s, category __cat);

    locale(const locale& __base, const locale& __add, category __cat);

    template<typename _Facet>
      locale(const locale& __other, _Facet* __f);

    ~locale() throw();

    const locale&
    operator=(const locale& __other) throw();

    template<typename _Facet>
      locale
      combine(const locale& __other) const;


    string
    name() const;

    bool
    operator==(const locale& __other) const throw ();

    inline bool
    operator!=(const locale& __other) const throw ()
    { return !(this->operator==(__other)); }

    template<typename _Char, typename _Traits, typename _Alloc>
      bool
      operator()(const basic_string<_Char, _Traits, _Alloc>& __s1,
                 const basic_string<_Char, _Traits, _Alloc>& __s2) const;


    static locale
    global(const locale&);

    static const locale&
    classic();

  private:

    _Impl* _M_impl;


    static _Impl* _S_classic;


    static _Impl* _S_global;

    static const size_t _S_num_categories = 6;

    explicit
    locale(_Impl*) throw();

    static inline void
    _S_initialize()
    {
      if (!_S_classic)
        classic();
    }

    static category
    _S_normalize_category(category);

    void
    _M_coalesce(const locale& __base, const locale& __add, category __cat);
  };



  class locale::_Impl
  {
  public:

    friend class locale;
    friend class locale::facet;

    template<typename _Facet>
      friend const _Facet&
      use_facet(const locale&);

    template<typename _Facet>
      friend bool
      has_facet(const locale&) throw();

  private:

    _Atomic_word _M_references;
    facet** _M_facets;
    size_t _M_facets_size;
    const char* _M_names[_S_num_categories];
    static const locale::id* const _S_id_ctype[];
    static const locale::id* const _S_id_numeric[];
    static const locale::id* const _S_id_collate[];
    static const locale::id* const _S_id_time[];
    static const locale::id* const _S_id_monetary[];
    static const locale::id* const _S_id_messages[];
    static const locale::id* const* const _S_facet_categories[];

    inline void
    _M_add_reference() throw()
    { __atomic_add(&_M_references, 1); }

    inline void
    _M_remove_reference() throw()
    {
      if (__exchange_and_add(&_M_references, -1) == 1)
        {
          try
            { delete this; }
          catch(...)
            { }
        }
    }

    _Impl(const _Impl&, size_t);
    _Impl(const char*, size_t);
    _Impl(facet**, size_t, bool);

   ~_Impl() throw();

    _Impl(const _Impl&);

    void
    operator=(const _Impl&);

    inline bool
    _M_check_same_name()
    {
      bool __ret = true;
      for (size_t i = 0; __ret && i < _S_num_categories - 1; ++i)
        __ret &= (strcmp(_M_names[i], _M_names[i + 1]) == 0);
      return __ret;
    }

    void
    _M_replace_categories(const _Impl*, category);

    void
    _M_replace_category(const _Impl*, const locale::id* const*);

    void
    _M_replace_facet(const _Impl*, const locale::id*);

    void
    _M_install_facet(const locale::id*, facet*);

    template<typename _Facet>
      inline void
      _M_init_facet(_Facet* __facet)
      { _M_install_facet(&_Facet::id, __facet); }
  };

  template<typename _Facet>
    locale::locale(const locale& __other, _Facet* __f)
    {
      _M_impl = new _Impl(*__other._M_impl, 1);
      _M_impl->_M_install_facet(&_Facet::id, __f);
      for (size_t __i = 0; __i < _S_num_categories; ++__i)
        _M_impl->_M_names[__i] = "*";
    }


  class locale::facet
  {
  private:
    friend class locale;
    friend class locale::_Impl;

    _Atomic_word _M_references;

  protected:


    static __c_locale _S_c_locale;

    explicit
    facet(size_t __refs = 0) throw();

    virtual
    ~facet();

    static void
    _S_create_c_locale(__c_locale& __cloc, const char* __s,
                       __c_locale __old = 0);

    static __c_locale
    _S_clone_c_locale(__c_locale& __cloc);

    static void
    _S_destroy_c_locale(__c_locale& __cloc);

  private:
    void
    _M_add_reference() throw();

    void
    _M_remove_reference() throw();

    facet(const facet&);

    void
    operator=(const facet&);
  };



  class locale::id
  {
  private:
    friend class locale;
    friend class locale::_Impl;
    template<typename _Facet>
      friend const _Facet&
      use_facet(const locale&);
    template<typename _Facet>
      friend bool
      has_facet(const locale&) throw ();




    mutable size_t _M_index;


    static _Atomic_word _S_highwater;

    void
    operator=(const id&);

    id(const id&);

  public:


    id();

    inline size_t
    _M_id() const
    {
      if (!_M_index)
        _M_index = 1 + __exchange_and_add(&_S_highwater, 1);
      return _M_index - 1;
    }
  };

  template<typename _Facet>
    const _Facet&
    use_facet(const locale& __loc);

  template<typename _Facet>
    bool
    has_facet(const locale& __loc) throw();
}
# 49 "/usr/include/c++3.1/ios" 2 3
# 1 "/usr/include/c++3.1/bits/ios_base.h" 1 3
# 44 "/usr/include/c++3.1/bits/ios_base.h" 3



namespace std
{




  enum _Ios_Fmtflags { _M_ios_fmtflags_end = 1L << 16 };

  inline _Ios_Fmtflags
  operator&(_Ios_Fmtflags __a, _Ios_Fmtflags __b)
  { return _Ios_Fmtflags(static_cast<int>(__a) & static_cast<int>(__b)); }

  inline _Ios_Fmtflags
  operator|(_Ios_Fmtflags __a, _Ios_Fmtflags __b)
  { return _Ios_Fmtflags(static_cast<int>(__a) | static_cast<int>(__b)); }

  inline _Ios_Fmtflags
  operator^(_Ios_Fmtflags __a, _Ios_Fmtflags __b)
  { return _Ios_Fmtflags(static_cast<int>(__a) ^ static_cast<int>(__b)); }

  inline _Ios_Fmtflags
  operator|=(_Ios_Fmtflags& __a, _Ios_Fmtflags __b)
  { return __a = __a | __b; }

  inline _Ios_Fmtflags
  operator&=(_Ios_Fmtflags& __a, _Ios_Fmtflags __b)
  { return __a = __a & __b; }

  inline _Ios_Fmtflags
  operator^=(_Ios_Fmtflags& __a, _Ios_Fmtflags __b)
  { return __a = __a ^ __b; }

  inline _Ios_Fmtflags
  operator~(_Ios_Fmtflags __a)
  { return _Ios_Fmtflags(~static_cast<int>(__a)); }


  enum _Ios_Openmode { _M_ios_openmode_end = 1L << 16 };

  inline _Ios_Openmode
  operator&(_Ios_Openmode __a, _Ios_Openmode __b)
  { return _Ios_Openmode(static_cast<int>(__a) & static_cast<int>(__b)); }

  inline _Ios_Openmode
  operator|(_Ios_Openmode __a, _Ios_Openmode __b)
  { return _Ios_Openmode(static_cast<int>(__a) | static_cast<int>(__b)); }

  inline _Ios_Openmode
  operator^(_Ios_Openmode __a, _Ios_Openmode __b)
  { return _Ios_Openmode(static_cast<int>(__a) ^ static_cast<int>(__b)); }

  inline _Ios_Openmode
  operator|=(_Ios_Openmode& __a, _Ios_Openmode __b)
  { return __a = __a | __b; }

  inline _Ios_Openmode
  operator&=(_Ios_Openmode& __a, _Ios_Openmode __b)
  { return __a = __a & __b; }

  inline _Ios_Openmode
  operator^=(_Ios_Openmode& __a, _Ios_Openmode __b)
  { return __a = __a ^ __b; }

  inline _Ios_Openmode
  operator~(_Ios_Openmode __a)
  { return _Ios_Openmode(~static_cast<int>(__a)); }


  enum _Ios_Iostate { _M_ios_iostate_end = 1L << 16 };

  inline _Ios_Iostate
  operator&(_Ios_Iostate __a, _Ios_Iostate __b)
  { return _Ios_Iostate(static_cast<int>(__a) & static_cast<int>(__b)); }

  inline _Ios_Iostate
  operator|(_Ios_Iostate __a, _Ios_Iostate __b)
  { return _Ios_Iostate(static_cast<int>(__a) | static_cast<int>(__b)); }

  inline _Ios_Iostate
  operator^(_Ios_Iostate __a, _Ios_Iostate __b)
  { return _Ios_Iostate(static_cast<int>(__a) ^ static_cast<int>(__b)); }

  inline _Ios_Iostate
  operator|=(_Ios_Iostate& __a, _Ios_Iostate __b)
  { return __a = __a | __b; }

  inline _Ios_Iostate
  operator&=(_Ios_Iostate& __a, _Ios_Iostate __b)
  { return __a = __a & __b; }

  inline _Ios_Iostate
  operator^=(_Ios_Iostate& __a, _Ios_Iostate __b)
  { return __a = __a ^ __b; }

  inline _Ios_Iostate
  operator~(_Ios_Iostate __a)
  { return _Ios_Iostate(~static_cast<int>(__a)); }

  enum _Ios_Seekdir { _M_ios_seekdir_end = 1L << 16 };


  class ios_base
  {
  public:


    class failure : public exception
    {
    public:


      explicit
      failure(const string& __str) throw();



      virtual
      ~failure() throw();

      virtual const char*
      what() const throw();

    private:
      enum { _M_bufsize = 256 };
      char _M_name[_M_bufsize];

    };


    typedef _Ios_Fmtflags fmtflags;

    static const fmtflags boolalpha = fmtflags(__ios_flags::_S_boolalpha);
    static const fmtflags dec = fmtflags(__ios_flags::_S_dec);
    static const fmtflags fixed = fmtflags(__ios_flags::_S_fixed);
    static const fmtflags hex = fmtflags(__ios_flags::_S_hex);
    static const fmtflags internal = fmtflags(__ios_flags::_S_internal);
    static const fmtflags left = fmtflags(__ios_flags::_S_left);
    static const fmtflags oct = fmtflags(__ios_flags::_S_oct);
    static const fmtflags right = fmtflags(__ios_flags::_S_right);
    static const fmtflags scientific = fmtflags(__ios_flags::_S_scientific);
    static const fmtflags showbase = fmtflags(__ios_flags::_S_showbase);
    static const fmtflags showpoint = fmtflags(__ios_flags::_S_showpoint);
    static const fmtflags showpos = fmtflags(__ios_flags::_S_showpos);
    static const fmtflags skipws = fmtflags(__ios_flags::_S_skipws);
    static const fmtflags unitbuf = fmtflags(__ios_flags::_S_unitbuf);
    static const fmtflags uppercase = fmtflags(__ios_flags::_S_uppercase);
    static const fmtflags adjustfield = fmtflags(__ios_flags::_S_adjustfield);
    static const fmtflags basefield = fmtflags(__ios_flags::_S_basefield);
    static const fmtflags floatfield = fmtflags(__ios_flags::_S_floatfield);


    typedef _Ios_Iostate iostate;
    static const iostate badbit = iostate(__ios_flags::_S_badbit);
    static const iostate eofbit = iostate(__ios_flags::_S_eofbit);
    static const iostate failbit = iostate(__ios_flags::_S_failbit);
    static const iostate goodbit = iostate(0);


    typedef _Ios_Openmode openmode;
    static const openmode app = openmode(__ios_flags::_S_app);
    static const openmode ate = openmode(__ios_flags::_S_ate);
    static const openmode binary = openmode(__ios_flags::_S_bin);
    static const openmode in = openmode(__ios_flags::_S_in);
    static const openmode out = openmode(__ios_flags::_S_out);
    static const openmode trunc = openmode(__ios_flags::_S_trunc);


    typedef _Ios_Seekdir seekdir;
    static const seekdir beg = seekdir(0);
    static const seekdir cur = seekdir(1);
    static const seekdir end = seekdir(2);
# 226 "/usr/include/c++3.1/bits/ios_base.h" 3
    enum event
    {
      erase_event,
      imbue_event,
      copyfmt_event
    };

    typedef void (*event_callback) (event, ios_base&, int);

    void
    register_callback(event_callback __fn, int __index);

  protected:

    streamsize _M_precision;
    streamsize _M_width;
    fmtflags _M_flags;
    iostate _M_exception;
    iostate _M_streambuf_state;



    struct _Callback_list
    {

      _Callback_list* _M_next;
      ios_base::event_callback _M_fn;
      int _M_index;
      _Atomic_word _M_refcount;

      _Callback_list(ios_base::event_callback __fn, int __index,
                     _Callback_list* __cb)
      : _M_next(__cb), _M_fn(__fn), _M_index(__index), _M_refcount(0) { }

      void
      _M_add_reference() { __atomic_add(&_M_refcount, 1); }


      int
      _M_remove_reference() { return __exchange_and_add(&_M_refcount, -1); }
    };

     _Callback_list* _M_callbacks;

    void
    _M_call_callbacks(event __ev) throw();

    void
    _M_dispose_callbacks(void);


    struct _Words
    {
      void* _M_pword;
      long _M_iword;
      _Words() : _M_pword(0), _M_iword(0) { }
    };


    _Words _M_word_zero;


    static const int _S_local_word_size = 8;
    _Words _M_local_word[_S_local_word_size];


    int _M_word_size;
    _Words* _M_word;

    _Words&
    _M_grow_words(int __index);


    locale _M_ios_locale;

    void
    _M_init();

  public:





    class Init
    {
      friend class ios_base;
    public:
      Init();
      ~Init();

      static void
      _S_ios_create(bool __sync);

      static void
      _S_ios_destroy();

    private:
      static int _S_ios_base_init;
      static bool _S_synced_with_stdio;
    };


    inline fmtflags
    flags() const { return _M_flags; }

    inline fmtflags
    flags(fmtflags __fmtfl)
    {
      fmtflags __old = _M_flags;
      _M_flags = __fmtfl;
      return __old;
    }

    inline fmtflags
    setf(fmtflags __fmtfl)
    {
      fmtflags __old = _M_flags;
      _M_flags |= __fmtfl;
      return __old;
    }

    inline fmtflags
    setf(fmtflags __fmtfl, fmtflags __mask)
    {
      fmtflags __old = _M_flags;
      _M_flags &= ~__mask;
      _M_flags |= (__fmtfl & __mask);
      return __old;
    }

    inline void
    unsetf(fmtflags __mask) { _M_flags &= ~__mask; }

    inline streamsize
    precision() const { return _M_precision; }

    inline streamsize
    precision(streamsize __prec)
    {
      streamsize __old = _M_precision;
      _M_precision = __prec;
      return __old;
    }

    inline streamsize
    width() const { return _M_width; }

    inline streamsize
    width(streamsize __wide)
    {
      streamsize __old = _M_width;
      _M_width = __wide;
      return __old;
    }

    static bool
    sync_with_stdio(bool __sync = true);


    locale
    imbue(const locale& __loc);

    inline locale
    getloc() const { return _M_ios_locale; }


    static int
    xalloc() throw();

    inline long&
    iword(int __ix)
    {
      _Words& __word = (__ix < _M_word_size)
                        ? _M_word[__ix] : _M_grow_words(__ix);
      return __word._M_iword;
    }

    inline void*&
    pword(int __ix)
    {
      _Words& __word = (__ix < _M_word_size)
                        ? _M_word[__ix] : _M_grow_words(__ix);
      return __word._M_pword;
    }


    ~ios_base();

  protected:
    ios_base();



  private:
    ios_base(const ios_base&);

    ios_base&
    operator=(const ios_base&);

  };


  inline ios_base&
  boolalpha(ios_base& __base)
  {
    __base.setf(ios_base::boolalpha);
    return __base;
  }

  inline ios_base&
  noboolalpha(ios_base& __base)
  {
    __base.unsetf(ios_base::boolalpha);
    return __base;
  }

  inline ios_base&
  showbase(ios_base& __base)
  {
    __base.setf(ios_base::showbase);
    return __base;
  }

  inline ios_base&
  noshowbase(ios_base& __base)
  {
    __base.unsetf(ios_base::showbase);
    return __base;
  }

  inline ios_base&
  showpoint(ios_base& __base)
  {
    __base.setf(ios_base::showpoint);
    return __base;
  }

  inline ios_base&
  noshowpoint(ios_base& __base)
  {
    __base.unsetf(ios_base::showpoint);
    return __base;
  }

  inline ios_base&
  showpos(ios_base& __base)
  {
    __base.setf(ios_base::showpos);
    return __base;
  }

  inline ios_base&
  noshowpos(ios_base& __base)
  {
    __base.unsetf(ios_base::showpos);
    return __base;
  }

  inline ios_base&
  skipws(ios_base& __base)
  {
    __base.setf(ios_base::skipws);
    return __base;
  }

  inline ios_base&
  noskipws(ios_base& __base)
  {
    __base.unsetf(ios_base::skipws);
    return __base;
  }

  inline ios_base&
  uppercase(ios_base& __base)
  {
    __base.setf(ios_base::uppercase);
    return __base;
  }

  inline ios_base&
  nouppercase(ios_base& __base)
  {
    __base.unsetf(ios_base::uppercase);
    return __base;
  }

  inline ios_base&
  unitbuf(ios_base& __base)
  {
     __base.setf(ios_base::unitbuf);
     return __base;
  }

  inline ios_base&
  nounitbuf(ios_base& __base)
  {
     __base.unsetf(ios_base::unitbuf);
     return __base;
  }


  inline ios_base&
  internal(ios_base& __base)
  {
     __base.setf(ios_base::internal, ios_base::adjustfield);
     return __base;
  }

  inline ios_base&
  left(ios_base& __base)
  {
    __base.setf(ios_base::left, ios_base::adjustfield);
    return __base;
  }

  inline ios_base&
  right(ios_base& __base)
  {
    __base.setf(ios_base::right, ios_base::adjustfield);
    return __base;
  }


  inline ios_base&
  dec(ios_base& __base)
  {
    __base.setf(ios_base::dec, ios_base::basefield);
    return __base;
  }

  inline ios_base&
  hex(ios_base& __base)
  {
    __base.setf(ios_base::hex, ios_base::basefield);
    return __base;
  }

  inline ios_base&
  oct(ios_base& __base)
  {
    __base.setf(ios_base::oct, ios_base::basefield);
    return __base;
  }


  inline ios_base&
  fixed(ios_base& __base)
  {
    __base.setf(ios_base::fixed, ios_base::floatfield);
    return __base;
  }

  inline ios_base&
  scientific(ios_base& __base)
  {
    __base.setf(ios_base::scientific, ios_base::floatfield);
    return __base;
  }

}
# 50 "/usr/include/c++3.1/ios" 2 3
# 1 "/usr/include/c++3.1/streambuf" 1 3
# 44 "/usr/include/c++3.1/streambuf" 3







namespace std
{
  template<typename _CharT, typename _Traits>
    streamsize
    __copy_streambufs(basic_ios<_CharT, _Traits>& _ios,
                      basic_streambuf<_CharT, _Traits>* __sbin,
                      basic_streambuf<_CharT, _Traits>* __sbout);


  template<typename _CharT, typename _Traits>
    class basic_streambuf
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename traits_type::int_type int_type;
      typedef typename traits_type::pos_type pos_type;
      typedef typename traits_type::off_type off_type;


      typedef ctype<char_type> __ctype_type;
      typedef basic_streambuf<char_type, traits_type> __streambuf_type;

      friend class basic_ios<char_type, traits_type>;
      friend class basic_istream<char_type, traits_type>;
      friend class basic_ostream<char_type, traits_type>;
      friend class istreambuf_iterator<char_type, traits_type>;
      friend class ostreambuf_iterator<char_type, traits_type>;

      friend streamsize
      __copy_streambufs<>(basic_ios<char_type, traits_type>& __ios,
                          __streambuf_type* __sbin,__streambuf_type* __sbout);

    protected:





      char_type* _M_buf;


      int_type _M_buf_size;


      int_type _M_buf_size_opt;



      bool _M_buf_unified;






      char_type* _M_in_beg;
      char_type* _M_in_cur;
      char_type* _M_in_end;
      char_type* _M_out_beg;
      char_type* _M_out_cur;
      char_type* _M_out_end;


      ios_base::openmode _M_mode;


      locale _M_buf_locale;


      bool _M_buf_locale_init;






      static const int_type _S_pback_size = 1;
      char_type _M_pback[_S_pback_size];
      char_type* _M_pback_cur_save;
      char_type* _M_pback_end_save;
      bool _M_pback_init;




      void
      _M_pback_create()
      {
        if (!_M_pback_init)
          {
            int_type __dist = _M_in_end - _M_in_cur;
            int_type __len = min(_S_pback_size, __dist);
            traits_type::copy(_M_pback, _M_in_cur, __len);
            _M_pback_cur_save = _M_in_cur;
            _M_pback_end_save = _M_in_end;
            this->setg(_M_pback, _M_pback, _M_pback + __len);
            _M_pback_init = true;
          }
      }




      void
      _M_pback_destroy()
      {
        if (_M_pback_init)
          {

            int_type __off_cur = _M_in_cur - _M_pback;


            int_type __off_end = 0;
            int_type __pback_len = _M_in_end - _M_pback;
            int_type __save_len = _M_pback_end_save - _M_buf;
            if (__pback_len > __save_len)
              __off_end = __pback_len - __save_len;

            this->setg(_M_buf, _M_pback_cur_save + __off_cur,
                       _M_pback_end_save + __off_end);
            _M_pback_cur_save = __null;
            _M_pback_end_save = __null;
            _M_pback_init = false;
          }
      }



      void
      _M_in_cur_move(off_type __n)
      {
        bool __testout = _M_out_cur;
        _M_in_cur += __n;
        if (__testout && _M_buf_unified)
          _M_out_cur += __n;
      }
# 198 "/usr/include/c++3.1/streambuf" 3
      void
      _M_out_cur_move(off_type __n)
      {
        bool __testin = _M_in_cur;

        _M_out_cur += __n;
        if (__testin && _M_buf_unified)
          _M_in_cur += __n;
        if (_M_out_cur > _M_out_end)
          {
            _M_out_end = _M_out_cur;

            if (__testin)
              _M_in_end += __n;
          }
      }




      off_type
      _M_out_buf_size()
      {
        off_type __ret = 0;
        if (_M_out_cur)
          {

            if (_M_out_beg == _M_buf)
              __ret = _M_out_beg + _M_buf_size - _M_out_cur;

            else
              __ret = _M_out_end - _M_out_cur;
          }
        return __ret;
      }
# 241 "/usr/include/c++3.1/streambuf" 3
      void
      _M_set_indeterminate(void)
      {
        if (_M_mode & ios_base::in)
          this->setg(_M_buf, _M_buf, _M_buf);
        if (_M_mode & ios_base::out)
          this->setp(_M_buf, _M_buf);
      }

      void
      _M_set_determinate(off_type __off)
      {
        bool __testin = _M_mode & ios_base::in;
        bool __testout = _M_mode & ios_base::out;
        if (__testin)
          this->setg(_M_buf, _M_buf, _M_buf + __off);
        if (__testout)
          this->setp(_M_buf, _M_buf + __off);
      }

      bool
      _M_is_indeterminate(void)
      {
        bool __ret = false;

        if (_M_buf)
          {
            if (_M_mode & ios_base::in)
              __ret = _M_in_beg == _M_in_cur && _M_in_cur == _M_in_end;
            if (_M_mode & ios_base::out)
              __ret = _M_out_beg == _M_out_cur && _M_out_cur == _M_out_end;
          }
        return __ret;
      }

  public:
      virtual
      ~basic_streambuf()
      {
        _M_buf_unified = false;
        _M_buf_size = 0;
        _M_buf_size_opt = 0;
        _M_mode = ios_base::openmode(0);
        _M_buf_locale_init = false;
      }


      locale
      pubimbue(const locale &__loc)
      {
        locale __tmp(this->getloc());
        this->imbue(__loc);
        return __tmp;
      }

      locale
      getloc() const
      {
        if (_M_buf_locale_init)
          return _M_buf_locale;
        else
          return locale();
      }


      __streambuf_type*
      pubsetbuf(char_type* __s, streamsize __n)
      { return this->setbuf(__s, __n); }

      pos_type
      pubseekoff(off_type __off, ios_base::seekdir __way,
                 ios_base::openmode __mode = ios_base::in | ios_base::out)
      { return this->seekoff(__off, __way, __mode); }

      pos_type
      pubseekpos(pos_type __sp,
                 ios_base::openmode __mode = ios_base::in | ios_base::out)
      { return this->seekpos(__sp, __mode); }

      int
      pubsync() { return this->sync(); }



      streamsize
      in_avail()
      {
        streamsize __ret;
        if (_M_in_cur && _M_in_cur < _M_in_end)
          {
            if (_M_pback_init)
              {
                int_type __save_len = _M_pback_end_save - _M_pback_cur_save;
                int_type __pback_len = _M_in_cur - _M_pback;
                __ret = __save_len - __pback_len;
              }
            else
              __ret = this->egptr() - this->gptr();
          }
        else
          __ret = this->showmanyc();
        return __ret;
      }

      int_type
      snextc()
      {
        int_type __eof = traits_type::eof();
        return (this->sbumpc() == __eof ? __eof : this->sgetc());
      }

      int_type
      sbumpc();

      int_type
      sgetc()
      {
        int_type __ret;
        if (_M_in_cur && _M_in_cur < _M_in_end)
          __ret = traits_type::to_int_type(*(this->gptr()));
        else
          __ret = this->underflow();
        return __ret;
      }

      streamsize
      sgetn(char_type* __s, streamsize __n)
      { return this->xsgetn(__s, __n); }


      int_type
      sputbackc(char_type __c);

      int_type
      sungetc();


      int_type
      sputc(char_type __c);

      streamsize
      sputn(const char_type* __s, streamsize __n)
      { return this->xsputn(__s, __n); }

    protected:
      basic_streambuf()
      : _M_buf(__null), _M_buf_size(0),
      _M_buf_size_opt(static_cast<int_type>(8192)), _M_buf_unified(false),
      _M_in_beg(0), _M_in_cur(0), _M_in_end(0), _M_out_beg(0), _M_out_cur(0),
      _M_out_end(0), _M_mode(ios_base::openmode(0)), _M_buf_locale(locale()),
      _M_buf_locale_init(false), _M_pback_cur_save(0), _M_pback_end_save(0),
      _M_pback_init(false)
      { }


      char_type*
      eback() const { return _M_in_beg; }

      char_type*
      gptr() const { return _M_in_cur; }

      char_type*
      egptr() const { return _M_in_end; }

      void
      gbump(int __n) { _M_in_cur += __n; }

      void
      setg(char_type* __gbeg, char_type* __gnext, char_type* __gend)
      {
        _M_in_beg = __gbeg;
        _M_in_cur = __gnext;
        _M_in_end = __gend;
        if (!(_M_mode & ios_base::in) && __gbeg && __gnext && __gend)
          _M_mode = _M_mode | ios_base::in;
      }


      char_type*
      pbase() const { return _M_out_beg; }

      char_type*
      pptr() const { return _M_out_cur; }

      char_type*
      epptr() const { return _M_out_end; }

      void
      pbump(int __n) { _M_out_cur += __n; }

      void
      setp(char_type* __pbeg, char_type* __pend)
      {
        _M_out_beg = _M_out_cur = __pbeg;
        _M_out_end = __pend;
        if (!(_M_mode & ios_base::out) && __pbeg && __pend)
          _M_mode = _M_mode | ios_base::out;
      }



      virtual void
      imbue(const locale& __loc)
      {
        _M_buf_locale_init = true;
        if (_M_buf_locale != __loc)
          _M_buf_locale = __loc;
      }


      virtual basic_streambuf<char_type,_Traits>*
      setbuf(char_type*, streamsize)
      { return this; }

      virtual pos_type
      seekoff(off_type, ios_base::seekdir,
              ios_base::openmode = ios_base::in | ios_base::out)
      { return pos_type(off_type(-1)); }

      virtual pos_type
      seekpos(pos_type,
              ios_base::openmode = ios_base::in | ios_base::out)
      { return pos_type(off_type(-1)); }

      virtual int
      sync() { return 0; }


      virtual streamsize
      showmanyc() { return 0; }

      virtual streamsize
      xsgetn(char_type* __s, streamsize __n);

      virtual int_type
      underflow()
      { return traits_type::eof(); }

      virtual int_type
      uflow()
      {
        int_type __ret = traits_type::eof();
        bool __testeof = this->underflow() == __ret;
        bool __testpending = _M_in_cur && _M_in_cur < _M_in_end;
        if (!__testeof && __testpending)
          {
            __ret = traits_type::to_int_type(*_M_in_cur);
            ++_M_in_cur;
            if (_M_buf_unified && _M_mode & ios_base::out)
              ++_M_out_cur;
          }
        return __ret;
      }


      virtual int_type
      pbackfail(int_type = traits_type::eof())
      { return traits_type::eof(); }


      virtual streamsize
      xsputn(const char_type* __s, streamsize __n);

      virtual int_type
      overflow(int_type = traits_type::eof())
      { return traits_type::eof(); }
# 522 "/usr/include/c++3.1/streambuf" 3
    private:
      basic_streambuf(const __streambuf_type&) { };

      __streambuf_type&
      operator=(const __streambuf_type&) { return *this; };

    };
}





# 1 "/usr/include/c++3.1/bits/streambuf.tcc" 1 3
# 39 "/usr/include/c++3.1/bits/streambuf.tcc" 3

namespace std
{
  template<typename _CharT, typename _Traits>
    const typename basic_streambuf<_CharT, _Traits>::int_type
    basic_streambuf<_CharT, _Traits>::_S_pback_size;

  template<typename _CharT, typename _Traits>
    typename basic_streambuf<_CharT, _Traits>::int_type
    basic_streambuf<_CharT, _Traits>::
    sbumpc()
    {
      int_type __ret;
      if (_M_in_cur && _M_in_cur < _M_in_end)
        {
          char_type __c = *gptr();
          _M_in_cur_move(1);
          __ret = traits_type::to_int_type(__c);
        }
      else
        __ret = this->uflow();
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_streambuf<_CharT, _Traits>::int_type
    basic_streambuf<_CharT, _Traits>::
    sputbackc(char_type __c)
    {
      int_type __ret;
      bool __testpos = _M_in_cur && _M_in_beg < _M_in_cur;
      bool __testne = _M_in_cur && !traits_type::eq(__c, this->gptr()[-1]);
      if (!__testpos || __testne)
        __ret = pbackfail(traits_type::to_int_type(__c));
      else
        {
          _M_in_cur_move(-1);
          __ret = traits_type::to_int_type(*this->gptr());
        }
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_streambuf<_CharT, _Traits>::int_type
    basic_streambuf<_CharT, _Traits>::
    sungetc()
    {
      int_type __ret;
      if (_M_in_cur && _M_in_beg < _M_in_cur)
        {
          _M_in_cur_move(-1);
          __ret = traits_type::to_int_type(*_M_in_cur);
        }
      else
        __ret = this->pbackfail();
      return __ret;
    }






  template<typename _CharT, typename _Traits>
    typename basic_streambuf<_CharT, _Traits>::int_type
    basic_streambuf<_CharT, _Traits>::
    sputc(char_type __c)
    {
      int_type __ret;
      if (_M_out_buf_size())
        {
          *_M_out_cur = __c;
          _M_out_cur_move(1);
          __ret = traits_type::to_int_type(__c);
        }
      else
        __ret = this->overflow(traits_type::to_int_type(__c));
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    streamsize
    basic_streambuf<_CharT, _Traits>::
    xsgetn(char_type* __s, streamsize __n)
    {
      streamsize __ret = 0;
      while (__ret < __n)
        {
          size_t __buf_len = _M_in_end - _M_in_cur;
          if (__buf_len > 0)
            {
              size_t __remaining = __n - __ret;
              size_t __len = min(__buf_len, __remaining);
              traits_type::copy(__s, _M_in_cur, __len);
              __ret += __len;
              __s += __len;
              _M_in_cur_move(__len);
            }

          if (__ret < __n)
            {
              int_type __c = this->uflow();
              if (__c != traits_type::eof())
                {
                  traits_type::assign(*__s++, traits_type::to_char_type(__c));
                  ++__ret;
                }
              else
                break;
            }
        }
      return __ret;
    }






  template<typename _CharT, typename _Traits>
    streamsize
    basic_streambuf<_CharT, _Traits>::
    xsputn(const char_type* __s, streamsize __n)
    {
      streamsize __ret = 0;
      while (__ret < __n)
        {
          off_type __buf_len = _M_out_buf_size();
          if (__buf_len > 0)
            {
              off_type __remaining = __n - __ret;
              off_type __len = min(__buf_len, __remaining);
              traits_type::copy(_M_out_cur, __s, __len);
              __ret += __len;
              __s += __len;
              _M_out_cur_move(__len);
            }

          if (__ret < __n)
            {
              int_type __c = this->overflow(traits_type::to_int_type(*__s));
              if (__c != traits_type::eof())
                {
                  ++__ret;
                  ++__s;
                }
              else
                break;
            }
        }
      return __ret;
    }





  template<typename _CharT, typename _Traits>
    streamsize
    __copy_streambufs(basic_ios<_CharT, _Traits>& __ios,
                      basic_streambuf<_CharT, _Traits>* __sbin,
                      basic_streambuf<_CharT, _Traits>* __sbout)
  {
      typedef typename _Traits::int_type int_type;

      streamsize __ret = 0;
      streamsize __bufsize = __sbin->in_avail();
      streamsize __xtrct;
      bool __testput = __sbout->_M_mode & ios_base::out;
      try
        {
          while (__testput && __bufsize != -1)
            {
              __xtrct = __sbout->sputn(__sbin->gptr(), __bufsize);
              __ret += __xtrct;
              __sbin->_M_in_cur_move(__xtrct);
              if (__xtrct == __bufsize)
                {
                  if (__sbin->sgetc() == _Traits::eof())
                    break;
                  __bufsize = __sbin->in_avail();
                }
              else
                break;
            }
        }
      catch(exception& __fail)
        {
          __ios.setstate(ios_base::failbit);
          if ((__ios.exceptions() & ios_base::failbit) != 0)
            throw;
        }
      return __ret;
    }




  extern template class basic_streambuf<char>;
  extern template
    streamsize
    __copy_streambufs(basic_ios<char>&, basic_streambuf<char>*,
                      basic_streambuf<char>*);

  extern template class basic_streambuf<wchar_t>;
  extern template
    streamsize
    __copy_streambufs(basic_ios<wchar_t>&, basic_streambuf<wchar_t>*,
                      basic_streambuf<wchar_t>*);
}
# 536 "/usr/include/c++3.1/streambuf" 2 3
# 51 "/usr/include/c++3.1/ios" 2 3
# 1 "/usr/include/c++3.1/bits/basic_ios.h" 1 3
# 39 "/usr/include/c++3.1/bits/basic_ios.h" 3

# 1 "/usr/include/c++3.1/bits/streambuf_iterator.h" 1 3
# 41 "/usr/include/c++3.1/bits/streambuf_iterator.h" 3

namespace std
{
  template<typename _CharT, typename _Traits>
    class ostreambuf_iterator
    : public iterator<output_iterator_tag, void, void, void, void>
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef basic_streambuf<_CharT, _Traits> streambuf_type;
      typedef basic_ostream<_CharT, _Traits> ostream_type;

    private:
      streambuf_type* _M_sbuf;
      bool _M_failed;

    public:
      inline
      ostreambuf_iterator(ostream_type& __s) throw ()
      : _M_sbuf(__s.rdbuf()), _M_failed(!_M_sbuf) { }

      ostreambuf_iterator(streambuf_type* __s) throw ()
      : _M_sbuf(__s), _M_failed(!_M_sbuf) { }

      ostreambuf_iterator&
      operator=(_CharT __c);

      ostreambuf_iterator&
      operator*() throw()
      { return *this; }

      ostreambuf_iterator&
      operator++(int) throw()
      { return *this; }

      ostreambuf_iterator&
      operator++() throw()
      { return *this; }

      bool
      failed() const throw()
      { return _M_failed; }
    };

  template<typename _CharT, typename _Traits>
    inline ostreambuf_iterator<_CharT, _Traits>&
    ostreambuf_iterator<_CharT, _Traits>::operator=(_CharT __c)
    {
      if (!_M_failed &&
          _Traits::eq_int_type(_M_sbuf->sputc(__c),_Traits::eof()))
      _M_failed = true;
      return *this;
    }



  template<typename _CharT, typename _Traits>
    class istreambuf_iterator
    : public iterator<input_iterator_tag, _CharT, typename _Traits::off_type,
                      _CharT*, _CharT&>
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename _Traits::int_type int_type;
      typedef basic_streambuf<_CharT, _Traits> streambuf_type;
      typedef basic_istream<_CharT, _Traits> istream_type;

    private:







      streambuf_type* _M_sbuf;
      int_type _M_c;

    public:
      istreambuf_iterator() throw()
      : _M_sbuf(__null), _M_c(-2) { }

      istreambuf_iterator(istream_type& __s) throw()
      : _M_sbuf(__s.rdbuf()), _M_c(-2) { }

      istreambuf_iterator(streambuf_type* __s) throw()
      : _M_sbuf(__s), _M_c(-2) { }




      char_type
      operator*() const
      {

        char_type __ret;
        if (_M_sbuf && _M_c != static_cast<int_type>(-2))
          __ret = _M_c;
        else if (_M_sbuf)
          __ret = traits_type::to_char_type(_M_sbuf->sgetc());
        else
          __ret = static_cast<char_type>(traits_type::eof());
        return __ret;
      }

      istreambuf_iterator&
      operator++()
      {
        if (_M_sbuf)
          _M_sbuf->sbumpc();
        _M_c = -2;
        return *this;
      }

      istreambuf_iterator
      operator++(int)
      {
        istreambuf_iterator __old = *this;
        if (_M_sbuf)
          __old._M_c = _M_sbuf->sbumpc();
        _M_c = -2;
        return __old;
      }

      bool
      equal(const istreambuf_iterator& __b)
      {
        int_type __eof = traits_type::eof();
        bool __thiseof = !_M_sbuf || _M_sbuf->sgetc() == __eof;
        bool __beof = !__b._M_sbuf || __b._M_sbuf->sgetc() == __eof;
        return (__thiseof && __beof || (!__thiseof && !__beof));
      }




      bool
      equal(const istreambuf_iterator& __b) const
      {
        int_type __eof = traits_type::eof();
        bool __thiseof = !_M_sbuf || _M_sbuf->sgetc() == __eof;
        bool __beof = !__b._M_sbuf || __b._M_sbuf->sgetc() == __eof;
        return (__thiseof && __beof || (!__thiseof && !__beof));
      }

    };

  template<typename _CharT, typename _Traits>
    inline bool
    operator==(const istreambuf_iterator<_CharT, _Traits>& __a,
               const istreambuf_iterator<_CharT, _Traits>& __b)
    { return __a.equal(__b); }

  template<typename _CharT, typename _Traits>
    inline bool
    operator!=(const istreambuf_iterator<_CharT, _Traits>& __a,
               const istreambuf_iterator<_CharT, _Traits>& __b)
    { return !__a.equal(__b); }
}
# 41 "/usr/include/c++3.1/bits/basic_ios.h" 2 3
# 1 "/usr/include/c++3.1/bits/locale_facets.h" 1 3
# 44 "/usr/include/c++3.1/bits/locale_facets.h" 3


# 1 "/usr/include/c++3.1/cwctype" 1 3
# 48 "/usr/include/c++3.1/cwctype" 3




# 1 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 1 3
# 35 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 36 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 2 3
# 61 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
typedef unsigned long int wctype_t;
# 79 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
enum
{
  __ISwupper = 0,
  __ISwlower = 1,
  __ISwalpha = 2,
  __ISwdigit = 3,
  __ISwxdigit = 4,
  __ISwspace = 5,
  __ISwprint = 6,
  __ISwgraph = 7,
  __ISwblank = 8,
  __ISwcntrl = 9,
  __ISwpunct = 10,
  __ISwalnum = 11,

  _ISwupper = ((__ISwupper) < 8 ? (int) ((1UL << (__ISwupper)) << 24) : ((__ISwupper) < 16 ? (int) ((1UL << (__ISwupper)) << 8) : ((__ISwupper) < 24 ? (int) ((1UL << (__ISwupper)) >> 8) : (int) ((1UL << (__ISwupper)) >> 24)))),
  _ISwlower = ((__ISwlower) < 8 ? (int) ((1UL << (__ISwlower)) << 24) : ((__ISwlower) < 16 ? (int) ((1UL << (__ISwlower)) << 8) : ((__ISwlower) < 24 ? (int) ((1UL << (__ISwlower)) >> 8) : (int) ((1UL << (__ISwlower)) >> 24)))),
  _ISwalpha = ((__ISwalpha) < 8 ? (int) ((1UL << (__ISwalpha)) << 24) : ((__ISwalpha) < 16 ? (int) ((1UL << (__ISwalpha)) << 8) : ((__ISwalpha) < 24 ? (int) ((1UL << (__ISwalpha)) >> 8) : (int) ((1UL << (__ISwalpha)) >> 24)))),
  _ISwdigit = ((__ISwdigit) < 8 ? (int) ((1UL << (__ISwdigit)) << 24) : ((__ISwdigit) < 16 ? (int) ((1UL << (__ISwdigit)) << 8) : ((__ISwdigit) < 24 ? (int) ((1UL << (__ISwdigit)) >> 8) : (int) ((1UL << (__ISwdigit)) >> 24)))),
  _ISwxdigit = ((__ISwxdigit) < 8 ? (int) ((1UL << (__ISwxdigit)) << 24) : ((__ISwxdigit) < 16 ? (int) ((1UL << (__ISwxdigit)) << 8) : ((__ISwxdigit) < 24 ? (int) ((1UL << (__ISwxdigit)) >> 8) : (int) ((1UL << (__ISwxdigit)) >> 24)))),
  _ISwspace = ((__ISwspace) < 8 ? (int) ((1UL << (__ISwspace)) << 24) : ((__ISwspace) < 16 ? (int) ((1UL << (__ISwspace)) << 8) : ((__ISwspace) < 24 ? (int) ((1UL << (__ISwspace)) >> 8) : (int) ((1UL << (__ISwspace)) >> 24)))),
  _ISwprint = ((__ISwprint) < 8 ? (int) ((1UL << (__ISwprint)) << 24) : ((__ISwprint) < 16 ? (int) ((1UL << (__ISwprint)) << 8) : ((__ISwprint) < 24 ? (int) ((1UL << (__ISwprint)) >> 8) : (int) ((1UL << (__ISwprint)) >> 24)))),
  _ISwgraph = ((__ISwgraph) < 8 ? (int) ((1UL << (__ISwgraph)) << 24) : ((__ISwgraph) < 16 ? (int) ((1UL << (__ISwgraph)) << 8) : ((__ISwgraph) < 24 ? (int) ((1UL << (__ISwgraph)) >> 8) : (int) ((1UL << (__ISwgraph)) >> 24)))),
  _ISwblank = ((__ISwblank) < 8 ? (int) ((1UL << (__ISwblank)) << 24) : ((__ISwblank) < 16 ? (int) ((1UL << (__ISwblank)) << 8) : ((__ISwblank) < 24 ? (int) ((1UL << (__ISwblank)) >> 8) : (int) ((1UL << (__ISwblank)) >> 24)))),
  _ISwcntrl = ((__ISwcntrl) < 8 ? (int) ((1UL << (__ISwcntrl)) << 24) : ((__ISwcntrl) < 16 ? (int) ((1UL << (__ISwcntrl)) << 8) : ((__ISwcntrl) < 24 ? (int) ((1UL << (__ISwcntrl)) >> 8) : (int) ((1UL << (__ISwcntrl)) >> 24)))),
  _ISwpunct = ((__ISwpunct) < 8 ? (int) ((1UL << (__ISwpunct)) << 24) : ((__ISwpunct) < 16 ? (int) ((1UL << (__ISwpunct)) << 8) : ((__ISwpunct) < 24 ? (int) ((1UL << (__ISwpunct)) >> 8) : (int) ((1UL << (__ISwpunct)) >> 24)))),
  _ISwalnum = ((__ISwalnum) < 8 ? (int) ((1UL << (__ISwalnum)) << 24) : ((__ISwalnum) < 16 ? (int) ((1UL << (__ISwalnum)) << 8) : ((__ISwalnum) < 24 ? (int) ((1UL << (__ISwalnum)) >> 8) : (int) ((1UL << (__ISwalnum)) >> 24))))
};



extern "C" {







extern int iswalnum (wint_t __wc) throw ();





extern int iswalpha (wint_t __wc) throw ();


extern int iswcntrl (wint_t __wc) throw ();



extern int iswdigit (wint_t __wc) throw ();



extern int iswgraph (wint_t __wc) throw ();




extern int iswlower (wint_t __wc) throw ();


extern int iswprint (wint_t __wc) throw ();




extern int iswpunct (wint_t __wc) throw ();




extern int iswspace (wint_t __wc) throw ();




extern int iswupper (wint_t __wc) throw ();




extern int iswxdigit (wint_t __wc) throw ();





extern int iswblank (wint_t __wc) throw ();
# 178 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
extern wctype_t wctype (__const char *__property) throw ();



extern int iswctype (wint_t __wc, wctype_t __desc) throw ();
# 249 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
typedef __const __int32_t *wctrans_t;


extern wint_t towlower (wint_t __wc) throw ();


extern wint_t towupper (wint_t __wc) throw ();
# 275 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
}
# 288 "/usr/lib/gcc/../../i686-inX-linux/include/wctype.h" 3
extern "C" {



extern wctrans_t wctrans (__const char *__property) throw ();


extern wint_t towctrans (wint_t __wc, wctrans_t __desc) throw ();







extern int __iswalnum_l (wint_t __wc, __locale_t __locale) throw ();





extern int __iswalpha_l (wint_t __wc, __locale_t __locale) throw ();


extern int __iswcntrl_l (wint_t __wc, __locale_t __locale) throw ();



extern int __iswdigit_l (wint_t __wc, __locale_t __locale) throw ();



extern int __iswgraph_l (wint_t __wc, __locale_t __locale) throw ();




extern int __iswlower_l (wint_t __wc, __locale_t __locale) throw ();


extern int __iswprint_l (wint_t __wc, __locale_t __locale) throw ();




extern int __iswpunct_l (wint_t __wc, __locale_t __locale) throw ();




extern int __iswspace_l (wint_t __wc, __locale_t __locale) throw ();




extern int __iswupper_l (wint_t __wc, __locale_t __locale) throw ();




extern int __iswxdigit_l (wint_t __wc, __locale_t __locale) throw ();




extern int __iswblank_l (wint_t __wc, __locale_t __locale) throw ();



extern wctype_t __wctype_l (__const char *__property, __locale_t __locale)
     throw ();



extern int __iswctype_l (wint_t __wc, wctype_t __desc, __locale_t __locale)
     throw ();







extern wint_t __towlower_l (wint_t __wc, __locale_t __locale) throw ();


extern wint_t __towupper_l (wint_t __wc, __locale_t __locale) throw ();



extern wctrans_t __wctrans_l (__const char *__property, __locale_t __locale)
     throw ();


extern wint_t __towctrans_l (wint_t __wc, wctrans_t __desc,
                             __locale_t __locale) throw ();



}
# 53 "/usr/include/c++3.1/cwctype" 2 3
# 47 "/usr/include/c++3.1/bits/locale_facets.h" 2 3
# 1 "/usr/include/c++3.1/ios" 1 3
# 48 "/usr/include/c++3.1/bits/locale_facets.h" 2 3

namespace std
{
# 60 "/usr/include/c++3.1/bits/locale_facets.h" 3
# 1 "/usr/include/c++3.1/i686-inX-linux/bits/ctype_base.h" 1 3
# 50 "/usr/include/c++3.1/i686-inX-linux/bits/ctype_base.h" 3
  struct ctype_base
  {

    typedef const int* __to_type;



    typedef unsigned short mask;
    static const mask upper = _ISupper;
    static const mask lower = _ISlower;
    static const mask alpha = _ISalpha;
    static const mask digit = _ISdigit;
    static const mask xdigit = _ISxdigit;
    static const mask space = _ISspace;
    static const mask print = _ISprint;
    static const mask graph = _ISgraph;
    static const mask cntrl = _IScntrl;
    static const mask punct = _ISpunct;
    static const mask alnum = _ISalnum;
  };
# 61 "/usr/include/c++3.1/bits/locale_facets.h" 2 3


  template<typename _CharT>
    class __ctype_abstract_base : public locale::facet, public ctype_base
    {
    public:

      typedef _CharT char_type;

      bool
      is(mask __m, char_type __c) const
      { return this->do_is(__m, __c); }

      const char_type*
      is(const char_type *__lo, const char_type *__hi, mask *__vec) const
      { return this->do_is(__lo, __hi, __vec); }

      const char_type*
      scan_is(mask __m, const char_type* __lo, const char_type* __hi) const
      { return this->do_scan_is(__m, __lo, __hi); }

      const char_type*
      scan_not(mask __m, const char_type* __lo, const char_type* __hi) const
      { return this->do_scan_not(__m, __lo, __hi); }

      char_type
      toupper(char_type __c) const
      { return this->do_toupper(__c); }

      const char_type*
      toupper(char_type *__lo, const char_type* __hi) const
      { return this->do_toupper(__lo, __hi); }

      char_type
      tolower(char_type __c) const
      { return this->do_tolower(__c); }

      const char_type*
      tolower(char_type* __lo, const char_type* __hi) const
      { return this->do_tolower(__lo, __hi); }

      char_type
      widen(char __c) const
      { return this->do_widen(__c); }

      const char*
      widen(const char* __lo, const char* __hi, char_type* __to) const
      { return this->do_widen(__lo, __hi, __to); }

      char
      narrow(char_type __c, char __dfault) const
      { return this->do_narrow(__c, __dfault); }

      const char_type*
      narrow(const char_type* __lo, const char_type* __hi,
              char __dfault, char *__to) const
      { return this->do_narrow(__lo, __hi, __dfault, __to); }

    protected:
      explicit
      __ctype_abstract_base(size_t __refs = 0): locale::facet(__refs) { }

      virtual
      ~__ctype_abstract_base() { }

      virtual bool
      do_is(mask __m, char_type __c) const = 0;

      virtual const char_type*
      do_is(const char_type* __lo, const char_type* __hi,
            mask* __vec) const = 0;

      virtual const char_type*
      do_scan_is(mask __m, const char_type* __lo,
                 const char_type* __hi) const = 0;

      virtual const char_type*
      do_scan_not(mask __m, const char_type* __lo,
                  const char_type* __hi) const = 0;

      virtual char_type
      do_toupper(char_type) const = 0;

      virtual const char_type*
      do_toupper(char_type* __lo, const char_type* __hi) const = 0;

      virtual char_type
      do_tolower(char_type) const = 0;

      virtual const char_type*
      do_tolower(char_type* __lo, const char_type* __hi) const = 0;

      virtual char_type
      do_widen(char) const = 0;

      virtual const char*
      do_widen(const char* __lo, const char* __hi,
               char_type* __dest) const = 0;

      virtual char
      do_narrow(char_type, char __dfault) const = 0;

      virtual const char_type*
      do_narrow(const char_type* __lo, const char_type* __hi,
                 char __dfault, char* __dest) const = 0;
    };


  template<typename _CharT>
    class ctype : public __ctype_abstract_base<_CharT>
    {
    public:

      typedef _CharT char_type;
      typedef typename ctype::mask mask;

      static locale::id id;

      explicit
      ctype(size_t __refs = 0) : __ctype_abstract_base<_CharT>(__refs) { }

   protected:
      virtual
      ~ctype();

      virtual bool
      do_is(mask __m, char_type __c) const;

      virtual const char_type*
      do_is(const char_type* __lo, const char_type* __hi, mask* __vec) const;

      virtual const char_type*
      do_scan_is(mask __m, const char_type* __lo, const char_type* __hi) const;

      virtual const char_type*
      do_scan_not(mask __m, const char_type* __lo,
                  const char_type* __hi) const;

      virtual char_type
      do_toupper(char_type __c) const;

      virtual const char_type*
      do_toupper(char_type* __lo, const char_type* __hi) const;

      virtual char_type
      do_tolower(char_type __c) const;

      virtual const char_type*
      do_tolower(char_type* __lo, const char_type* __hi) const;

      virtual char_type
      do_widen(char __c) const;

      virtual const char*
      do_widen(const char* __lo, const char* __hi, char_type* __dest) const;

      virtual char
      do_narrow(char_type, char __dfault) const;

      virtual const char_type*
      do_narrow(const char_type* __lo, const char_type* __hi,
                char __dfault, char* __dest) const;
    };

  template<typename _CharT>
    locale::id ctype<_CharT>::id;


  template<>
    class ctype<char> : public __ctype_abstract_base<char>
    {
    public:

      typedef char char_type;

    protected:

      __c_locale _M_c_locale_ctype;
      bool _M_del;
      __to_type _M_toupper;
      __to_type _M_tolower;
      const mask* _M_table;

    public:
      static locale::id id;
      static const size_t table_size = 1 + static_cast<unsigned char>(-1);

      explicit
      ctype(const mask* __table = 0, bool __del = false, size_t __refs = 0);

      explicit
      ctype(__c_locale __cloc, const mask* __table = 0, bool __del = false,
            size_t __refs = 0);

      inline bool
      is(mask __m, char __c) const;

      inline const char*
      is(const char* __lo, const char* __hi, mask* __vec) const;

      inline const char*
      scan_is(mask __m, const char* __lo, const char* __hi) const;

      inline const char*
      scan_not(mask __m, const char* __lo, const char* __hi) const;

    protected:
      const mask*
      table() const throw()
      { return _M_table; }

      static const mask*
      classic_table() throw();

      virtual
      ~ctype();

      virtual bool
      do_is(mask __m, char_type __c) const;

      virtual const char_type*
      do_is(const char_type* __lo, const char_type* __hi, mask* __vec) const;

      virtual const char_type*
      do_scan_is(mask __m, const char_type* __lo, const char_type* __hi) const;

      virtual const char_type*
      do_scan_not(mask __m, const char_type* __lo,
                  const char_type* __hi) const;

      virtual char_type
      do_toupper(char_type) const;

      virtual const char_type*
      do_toupper(char_type* __lo, const char_type* __hi) const;

      virtual char_type
      do_tolower(char_type) const;

      virtual const char_type*
      do_tolower(char_type* __lo, const char_type* __hi) const;

      virtual char_type
      do_widen(char) const;

      virtual const char*
      do_widen(const char* __lo, const char* __hi, char_type* __dest) const;

      virtual char
      do_narrow(char_type, char __dfault) const;

      virtual const char_type*
      do_narrow(const char_type* __lo, const char_type* __hi,
                char __dfault, char* __dest) const;
    };

  template<>
    const ctype<char>&
    use_facet<ctype<char> >(const locale& __loc);
# 397 "/usr/include/c++3.1/bits/locale_facets.h" 3
# 1 "/usr/include/c++3.1/i686-inX-linux/bits/ctype_inline.h" 1 3
# 37 "/usr/include/c++3.1/i686-inX-linux/bits/ctype_inline.h" 3
  bool
  ctype<char>::
  is(mask __m, char __c) const
  { return _M_table[static_cast<unsigned char>(__c)] & __m; }

  const char*
  ctype<char>::
  is(const char* __low, const char* __high, mask* __vec) const
  {
    while (__low < __high)
      *__vec++ = _M_table[static_cast<unsigned char>(*__low++)];
    return __high;
  }

  const char*
  ctype<char>::
  scan_is(mask __m, const char* __low, const char* __high) const
  {
    while (__low < __high
           && !(_M_table[static_cast<unsigned char>(*__low)] & __m))
      ++__low;
    return __low;
  }

  const char*
  ctype<char>::
  scan_not(mask __m, const char* __low, const char* __high) const
  {
    while (__low < __high
           && (_M_table[static_cast<unsigned char>(*__low)] & __m) != 0)
      ++__low;
    return __low;
  }
# 398 "/usr/include/c++3.1/bits/locale_facets.h" 2 3


  template<typename _CharT>
    class ctype_byname : public ctype<_CharT>
    {
    public:
      typedef _CharT char_type;

      explicit
      ctype_byname(const char* __s, size_t __refs = 0);

    protected:
      virtual
      ~ctype_byname() { };
    };


  template<>
    ctype_byname<char>::ctype_byname(const char*, size_t refs);

  template<>
    ctype_byname<wchar_t>::ctype_byname(const char*, size_t refs);


# 1 "/usr/include/c++3.1/bits/codecvt.h" 1 3
# 45 "/usr/include/c++3.1/bits/codecvt.h" 3


  class codecvt_base
  {
  public:
    enum result
    {
      ok,
      partial,
      error,
      noconv
    };
  };





  template<typename _InternT, typename _ExternT, typename _StateT>
    class __codecvt_abstract_base
    : public locale::facet, public codecvt_base
    {
    public:

      typedef codecvt_base::result result;
      typedef _InternT intern_type;
      typedef _ExternT extern_type;
      typedef _StateT state_type;


      result
      out(state_type& __state, const intern_type* __from,
          const intern_type* __from_end, const intern_type*& __from_next,
          extern_type* __to, extern_type* __to_end,
          extern_type*& __to_next) const
      {
        return this->do_out(__state, __from, __from_end, __from_next,
                            __to, __to_end, __to_next);
      }

      result
      unshift(state_type& __state, extern_type* __to, extern_type* __to_end,
              extern_type*& __to_next) const
      { return this->do_unshift(__state, __to,__to_end,__to_next); }

      result
      in(state_type& __state, const extern_type* __from,
         const extern_type* __from_end, const extern_type*& __from_next,
         intern_type* __to, intern_type* __to_end,
         intern_type*& __to_next) const
      {
        return this->do_in(__state, __from, __from_end, __from_next,
                           __to, __to_end, __to_next);
      }

      int
      encoding() const throw()
      { return this->do_encoding(); }

      bool
      always_noconv() const throw()
      { return this->do_always_noconv(); }

      int
      length(const state_type& __state, const extern_type* __from,
             const extern_type* __end, size_t __max) const
      { return this->do_length(__state, __from, __end, __max); }

      int
      max_length() const throw()
      { return this->do_max_length(); }

    protected:
      explicit
      __codecvt_abstract_base(size_t __refs = 0) : locale::facet(__refs) { }

      virtual
      ~__codecvt_abstract_base() { }

      virtual result
      do_out(state_type& __state, const intern_type* __from,
             const intern_type* __from_end, const intern_type*& __from_next,
             extern_type* __to, extern_type* __to_end,
             extern_type*& __to_next) const = 0;

      virtual result
      do_unshift(state_type& __state, extern_type* __to,
                 extern_type* __to_end, extern_type*& __to_next) const = 0;

      virtual result
      do_in(state_type& __state, const extern_type* __from,
            const extern_type* __from_end, const extern_type*& __from_next,
            intern_type* __to, intern_type* __to_end,
            intern_type*& __to_next) const = 0;

      virtual int
      do_encoding() const throw() = 0;

      virtual bool
      do_always_noconv() const throw() = 0;

      virtual int
      do_length(const state_type&, const extern_type* __from,
                const extern_type* __end, size_t __max) const = 0;

      virtual int
      do_max_length() const throw() = 0;
    };



  template<typename _InternT, typename _ExternT, typename _StateT>
    class codecvt
    : public __codecvt_abstract_base<_InternT, _ExternT, _StateT>
    {
    public:

      typedef codecvt_base::result result;
      typedef _InternT intern_type;
      typedef _ExternT extern_type;
      typedef _StateT state_type;


      static locale::id id;

      explicit
      codecvt(size_t __refs = 0)
      : __codecvt_abstract_base<_InternT,_ExternT,_StateT> (__refs) { }

    protected:
      virtual
      ~codecvt() { }

      virtual result
      do_out(state_type& __state, const intern_type* __from,
             const intern_type* __from_end, const intern_type*& __from_next,
             extern_type* __to, extern_type* __to_end,
             extern_type*& __to_next) const;

      virtual result
      do_unshift(state_type& __state, extern_type* __to,
                 extern_type* __to_end, extern_type*& __to_next) const;

      virtual result
      do_in(state_type& __state, const extern_type* __from,
            const extern_type* __from_end, const extern_type*& __from_next,
            intern_type* __to, intern_type* __to_end,
            intern_type*& __to_next) const;

      virtual int
      do_encoding() const throw();

      virtual bool
      do_always_noconv() const throw();

      virtual int
      do_length(const state_type&, const extern_type* __from,
                const extern_type* __end, size_t __max) const;

      virtual int
      do_max_length() const throw();
    };

  template<typename _InternT, typename _ExternT, typename _StateT>
    locale::id codecvt<_InternT, _ExternT, _StateT>::id;


  template<>
    class codecvt<char, char, mbstate_t>
    : public __codecvt_abstract_base<char, char, mbstate_t>
    {
    public:

      typedef char intern_type;
      typedef char extern_type;
      typedef mbstate_t state_type;


      static locale::id id;

      explicit
      codecvt(size_t __refs = 0);

    protected:
      virtual
      ~codecvt();

      virtual result
      do_out(state_type& __state, const intern_type* __from,
             const intern_type* __from_end, const intern_type*& __from_next,
             extern_type* __to, extern_type* __to_end,
             extern_type*& __to_next) const;

      virtual result
      do_unshift(state_type& __state, extern_type* __to,
                 extern_type* __to_end, extern_type*& __to_next) const;

      virtual result
      do_in(state_type& __state, const extern_type* __from,
            const extern_type* __from_end, const extern_type*& __from_next,
            intern_type* __to, intern_type* __to_end,
            intern_type*& __to_next) const;

      virtual int
      do_encoding() const throw();

      virtual bool
      do_always_noconv() const throw();

      virtual int
      do_length(const state_type&, const extern_type* __from,
                const extern_type* __end, size_t __max) const;

      virtual int
      do_max_length() const throw();
  };
# 318 "/usr/include/c++3.1/bits/codecvt.h" 3
  template<typename _InternT, typename _ExternT, typename _StateT>
    class codecvt_byname : public codecvt<_InternT, _ExternT, _StateT>
    {
    public:
      explicit
      codecvt_byname(const char*, size_t __refs = 0)
      : codecvt<_InternT, _ExternT, _StateT>(__refs) { }
    protected:
      virtual
      ~codecvt_byname() { }
    };
# 423 "/usr/include/c++3.1/bits/locale_facets.h" 2 3



  class __num_base
  {
  protected:


    static const char _S_atoms[];

    enum
    {
      _M_zero,
      _M_e = _M_zero + 10,
      _M_E = _M_zero + 11,
      _M_size = 21 + 1
    };



    static bool
    _S_format_float(const ios_base& __io, char* __fptr, char __mod,
                    streamsize __prec);


    static void
    _S_format_int(const ios_base& __io, char* __fptr, char __mod, char __modl);
  };


  template<typename _CharT>
    class numpunct : public locale::facet
    {
    public:

      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

      static locale::id id;

    private:
      char_type _M_decimal_point;
      char_type _M_thousands_sep;
      const char* _M_grouping;
      const char_type* _M_truename;
      const char_type* _M_falsename;

    public:
      explicit
      numpunct(size_t __refs = 0) : locale::facet(__refs)
      { _M_initialize_numpunct(); }

      explicit
      numpunct(__c_locale __cloc, size_t __refs = 0) : locale::facet(__refs)
      { _M_initialize_numpunct(__cloc); }

      char_type
      decimal_point() const
      { return this->do_decimal_point(); }

      char_type
      thousands_sep() const
      { return this->do_thousands_sep(); }

      string
      grouping() const
      { return this->do_grouping(); }

      string_type
      truename() const
      { return this->do_truename(); }

      string_type
      falsename() const
      { return this->do_falsename(); }

    protected:
      virtual
      ~numpunct();

      virtual char_type
      do_decimal_point() const
      { return _M_decimal_point; }

      virtual char_type
      do_thousands_sep() const
      { return _M_thousands_sep; }

      virtual string
      do_grouping() const
      { return _M_grouping; }

      virtual string_type
      do_truename() const
      { return _M_truename; }

      virtual string_type
      do_falsename() const
      { return _M_falsename; }


      void
      _M_initialize_numpunct(__c_locale __cloc = _S_c_locale);
    };

  template<typename _CharT>
    locale::id numpunct<_CharT>::id;

  template<>
    numpunct<char>::~numpunct();

  template<>
    void
    numpunct<char>::_M_initialize_numpunct(__c_locale __cloc);
# 547 "/usr/include/c++3.1/bits/locale_facets.h" 3
  template<typename _CharT>
    class numpunct_byname : public numpunct<_CharT>
    {

      __c_locale _M_c_locale_numpunct;

    public:
      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

      explicit
      numpunct_byname(const char* __s, size_t __refs = 0)
      : numpunct<_CharT>(__refs)
      {
        _S_create_c_locale(_M_c_locale_numpunct, __s);
        _M_initialize_numpunct(_M_c_locale_numpunct);
      }

    protected:
      virtual
      ~numpunct_byname()
      { _S_destroy_c_locale(_M_c_locale_numpunct); }
    };

  template<typename _CharT, typename _InIter>
    class num_get : public locale::facet, public __num_base
    {
    public:

      typedef _CharT char_type;
      typedef _InIter iter_type;

      static locale::id id;

      explicit
      num_get(size_t __refs = 0) : locale::facet(__refs) { }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, bool& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, long& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, unsigned short& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, unsigned int& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, unsigned long& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }


      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, long long& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, unsigned long long& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }


      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, float& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, double& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, long double& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

      iter_type
      get(iter_type __in, iter_type __end, ios_base& __io,
          ios_base::iostate& __err, void*& __v) const
      { return this->do_get(__in, __end, __io, __err, __v); }

    protected:
      virtual ~num_get() { }

      iter_type
      _M_extract_float(iter_type, iter_type, ios_base&, ios_base::iostate&,
                       string& __xtrc) const;

      iter_type
      _M_extract_int(iter_type, iter_type, ios_base&, ios_base::iostate&,
                     string& __xtrc, int& __base) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate&, bool&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate&, long&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
              unsigned short&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             unsigned int&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             unsigned long&) const;


      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             long long&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             unsigned long long&) const;


      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             float&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             double&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             long double&) const;

      virtual iter_type
      do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err,
             void*&) const;
    };

  template<typename _CharT, typename _InIter>
    locale::id num_get<_CharT, _InIter>::id;

  template<typename _CharT, typename _OutIter>
    class num_put : public locale::facet, public __num_base
    {
    public:

      typedef _CharT char_type;
      typedef _OutIter iter_type;

      static locale::id id;

      explicit
      num_put(size_t __refs = 0) : locale::facet(__refs) { }

      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill, bool __v) const
      { return this->do_put(__s, __f, __fill, __v); }

      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill, long __v) const
      { return this->do_put(__s, __f, __fill, __v); }

      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill,
          unsigned long __v) const
      { return this->do_put(__s, __f, __fill, __v); }


      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill, long long __v) const
      { return this->do_put(__s, __f, __fill, __v); }

      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill,
          unsigned long long __v) const
      { return this->do_put(__s, __f, __fill, __v); }


      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill, double __v) const
      { return this->do_put(__s, __f, __fill, __v); }

      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill,
          long double __v) const
      { return this->do_put(__s, __f, __fill, __v); }

      iter_type
      put(iter_type __s, ios_base& __f, char_type __fill,
          const void* __v) const
      { return this->do_put(__s, __f, __fill, __v); }

    protected:
      template<typename _ValueT>
        iter_type
        _M_convert_float(iter_type, ios_base& __io, char_type __fill,
                         char __mod, _ValueT __v) const;

      template<typename _ValueT>
        iter_type
        _M_convert_int(iter_type, ios_base& __io, char_type __fill,
                       char __mod, char __modl, _ValueT __v) const;

      iter_type
      _M_widen_float(iter_type, ios_base& __io, char_type __fill, char* __cs,
                     int __len) const;

      iter_type
      _M_widen_int(iter_type, ios_base& __io, char_type __fill, char* __cs,
                   int __len) const;

      iter_type
      _M_insert(iter_type, ios_base& __io, char_type __fill,
                const char_type* __ws, int __len) const;

      virtual
      ~num_put() { };

      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, bool __v) const;

      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, long __v) const;

      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, unsigned long) const;


      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, long long __v) const;

      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, unsigned long long) const;


      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, double __v) const;

      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, long double __v) const;

      virtual iter_type
      do_put(iter_type, ios_base&, char_type __fill, const void* __v) const;
    };

  template <typename _CharT, typename _OutIter>
    locale::id num_put<_CharT, _OutIter>::id;


  template<typename _CharT>
    class collate : public locale::facet
    {
    public:

      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

    protected:


      __c_locale _M_c_locale_collate;

    public:
      static locale::id id;

      explicit
      collate(size_t __refs = 0)
      : locale::facet(__refs)
      { _M_c_locale_collate = _S_c_locale; }


      explicit
      collate(__c_locale __cloc, size_t __refs = 0)
      : locale::facet(__refs)
      { _M_c_locale_collate = _S_clone_c_locale(__cloc); }

      int
      compare(const _CharT* __lo1, const _CharT* __hi1,
              const _CharT* __lo2, const _CharT* __hi2) const
      { return this->do_compare(__lo1, __hi1, __lo2, __hi2); }

      string_type
      transform(const _CharT* __lo, const _CharT* __hi) const
      { return this->do_transform(__lo, __hi); }

      long
      hash(const _CharT* __lo, const _CharT* __hi) const
      { return this->do_hash(__lo, __hi); }


      int
      _M_compare(const _CharT*, const _CharT*) const;

      size_t
      _M_transform(_CharT*, const _CharT*, size_t) const;

  protected:
      virtual
      ~collate()
      {
        if (_M_c_locale_collate != _S_c_locale)
          _S_destroy_c_locale(_M_c_locale_collate);
      }

      virtual int
      do_compare(const _CharT* __lo1, const _CharT* __hi1,
                 const _CharT* __lo2, const _CharT* __hi2) const;

      virtual string_type
      do_transform(const _CharT* __lo, const _CharT* __hi) const;

      virtual long
      do_hash(const _CharT* __lo, const _CharT* __hi) const;
    };

  template<typename _CharT>
    locale::id collate<_CharT>::id;


  template<>
    int
    collate<char>::_M_compare(const char*, const char*) const;

  template<>
    size_t
    collate<char>::_M_transform(char*, const char*, size_t) const;
# 896 "/usr/include/c++3.1/bits/locale_facets.h" 3
  template<typename _CharT>
    class collate_byname : public collate<_CharT>
    {
    public:
      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

      explicit
      collate_byname(const char* __s, size_t __refs = 0)
      : collate<_CharT>(__refs)
      {
        if (_M_c_locale_collate != _S_c_locale)
          _S_destroy_c_locale(_M_c_locale_collate);
        _S_create_c_locale(_M_c_locale_collate, __s);
      }

    protected:
      virtual
      ~collate_byname() { }
    };


  class time_base
  {
  public:
    enum dateorder { no_order, dmy, mdy, ymd, ydm };
  };

  template<typename _CharT>
    class __timepunct : public locale::facet
    {
    public:

      typedef _CharT __char_type;
      typedef basic_string<_CharT> __string_type;

      static locale::id id;


      static const _CharT* _S_timezones[14];

    protected:
      __c_locale _M_c_locale_timepunct;
      const char* _M_name_timepunct;
      const _CharT* _M_date_format;
      const _CharT* _M_date_era_format;
      const _CharT* _M_time_format;
      const _CharT* _M_time_era_format;
      const _CharT* _M_date_time_format;
      const _CharT* _M_date_time_era_format;
      const _CharT* _M_am;
      const _CharT* _M_pm;
      const _CharT* _M_am_pm_format;


      const _CharT* _M_day1;
      const _CharT* _M_day2;
      const _CharT* _M_day3;
      const _CharT* _M_day4;
      const _CharT* _M_day5;
      const _CharT* _M_day6;
      const _CharT* _M_day7;


      const _CharT* _M_day_a1;
      const _CharT* _M_day_a2;
      const _CharT* _M_day_a3;
      const _CharT* _M_day_a4;
      const _CharT* _M_day_a5;
      const _CharT* _M_day_a6;
      const _CharT* _M_day_a7;


      const _CharT* _M_month01;
      const _CharT* _M_month02;
      const _CharT* _M_month03;
      const _CharT* _M_month04;
      const _CharT* _M_month05;
      const _CharT* _M_month06;
      const _CharT* _M_month07;
      const _CharT* _M_month08;
      const _CharT* _M_month09;
      const _CharT* _M_month10;
      const _CharT* _M_month11;
      const _CharT* _M_month12;


      const _CharT* _M_month_a01;
      const _CharT* _M_month_a02;
      const _CharT* _M_month_a03;
      const _CharT* _M_month_a04;
      const _CharT* _M_month_a05;
      const _CharT* _M_month_a06;
      const _CharT* _M_month_a07;
      const _CharT* _M_month_a08;
      const _CharT* _M_month_a09;
      const _CharT* _M_month_a10;
      const _CharT* _M_month_a11;
      const _CharT* _M_month_a12;

    public:
      explicit
      __timepunct(size_t __refs = 0)
      : locale::facet(__refs), _M_name_timepunct("C")
      { _M_initialize_timepunct(); }

      explicit
      __timepunct(__c_locale __cloc, const char* __s, size_t __refs = 0)
      : locale::facet(__refs), _M_name_timepunct(__s)
      { _M_initialize_timepunct(__cloc); }

      void
      _M_put(_CharT* __s, size_t __maxlen, const _CharT* __format,
             const tm* __tm) const;

      void
      _M_date_formats(const _CharT** __date) const
      {

        __date[0] = _M_date_format;
        __date[1] = _M_date_era_format;
      }

      void
      _M_time_formats(const _CharT** __time) const
      {

        __time[0] = _M_time_format;
        __time[1] = _M_time_era_format;
      }

      void
      _M_ampm(const _CharT** __ampm) const
      {
        __ampm[0] = _M_am;
        __ampm[1] = _M_pm;
      }

      void
      _M_date_time_formats(const _CharT** __dt) const
      {

        __dt[0] = _M_date_time_format;
        __dt[1] = _M_date_time_era_format;
      }

      void
      _M_days(const _CharT** __days) const
      {
        __days[0] = _M_day1;
        __days[1] = _M_day2;
        __days[2] = _M_day3;
        __days[3] = _M_day4;
        __days[4] = _M_day5;
        __days[5] = _M_day6;
        __days[6] = _M_day7;
      }

      void
      _M_days_abbreviated(const _CharT** __days) const
      {
        __days[0] = _M_day_a1;
        __days[1] = _M_day_a2;
        __days[2] = _M_day_a3;
        __days[3] = _M_day_a4;
        __days[4] = _M_day_a5;
        __days[5] = _M_day_a6;
        __days[6] = _M_day_a7;
      }

      void
      _M_months(const _CharT** __months) const
      {
        __months[0] = _M_month01;
        __months[1] = _M_month02;
        __months[2] = _M_month03;
        __months[3] = _M_month04;
        __months[4] = _M_month05;
        __months[5] = _M_month06;
        __months[6] = _M_month07;
        __months[7] = _M_month08;
        __months[8] = _M_month09;
        __months[9] = _M_month10;
        __months[10] = _M_month11;
        __months[11] = _M_month12;
      }

      void
      _M_months_abbreviated(const _CharT** __months) const
      {
        __months[0] = _M_month_a01;
        __months[1] = _M_month_a02;
        __months[2] = _M_month_a03;
        __months[3] = _M_month_a04;
        __months[4] = _M_month_a05;
        __months[5] = _M_month_a06;
        __months[6] = _M_month_a07;
        __months[7] = _M_month_a08;
        __months[8] = _M_month_a09;
        __months[9] = _M_month_a10;
        __months[10] = _M_month_a11;
        __months[11] = _M_month_a12;
      }

    protected:
      virtual
      ~__timepunct();


      void
      _M_initialize_timepunct(__c_locale __cloc = _S_c_locale);
    };

  template<typename _CharT>
    locale::id __timepunct<_CharT>::id;


  template<>
    __timepunct<char>::~__timepunct();

  template<>
    const char*
    __timepunct<char>::_S_timezones[14];

  template<>
    void
    __timepunct<char>::_M_initialize_timepunct(__c_locale __cloc);

  template<>
    void
    __timepunct<char>::_M_put(char*, size_t, const char*, const tm*) const;
# 1147 "/usr/include/c++3.1/bits/locale_facets.h" 3
  template<typename _CharT>
    const _CharT* __timepunct<_CharT>::_S_timezones[14];


  template<typename _CharT, typename _InIter>
    class time_get : public locale::facet, public time_base
    {
    public:

      typedef _CharT char_type;
      typedef _InIter iter_type;
      typedef basic_string<_CharT> __string_type;

      static locale::id id;

      explicit
      time_get(size_t __refs = 0)
      : locale::facet (__refs) { }

      dateorder
      date_order() const
      { return this->do_date_order(); }

      iter_type
      get_time(iter_type __beg, iter_type __end, ios_base& __io,
               ios_base::iostate& __err, tm* __tm) const
      { return this->do_get_time(__beg, __end, __io, __err, __tm); }

      iter_type
      get_date(iter_type __beg, iter_type __end, ios_base& __io,
               ios_base::iostate& __err, tm* __tm) const
      { return this->do_get_date(__beg, __end, __io, __err, __tm); }

      iter_type
      get_weekday(iter_type __beg, iter_type __end, ios_base& __io,
                  ios_base::iostate& __err, tm* __tm) const
      { return this->do_get_weekday(__beg, __end, __io, __err, __tm); }

      iter_type
      get_monthname(iter_type __beg, iter_type __end, ios_base& __io,
                    ios_base::iostate& __err, tm* __tm) const
      { return this->do_get_monthname(__beg, __end, __io, __err, __tm); }

      iter_type
      get_year(iter_type __beg, iter_type __end, ios_base& __io,
               ios_base::iostate& __err, tm* __tm) const
      { return this->do_get_year(__beg, __end, __io, __err, __tm); }

    protected:
      virtual
      ~time_get() { }

      virtual dateorder
      do_date_order() const;

      virtual iter_type
      do_get_time(iter_type __beg, iter_type __end, ios_base& __io,
                  ios_base::iostate& __err, tm* __tm) const;

      virtual iter_type
      do_get_date(iter_type __beg, iter_type __end, ios_base& __io,
                  ios_base::iostate& __err, tm* __tm) const;

      virtual iter_type
      do_get_weekday(iter_type __beg, iter_type __end, ios_base&,
                     ios_base::iostate& __err, tm* __tm) const;

      virtual iter_type
      do_get_monthname(iter_type __beg, iter_type __end, ios_base&,
                       ios_base::iostate& __err, tm* __tm) const;

      virtual iter_type
      do_get_year(iter_type __beg, iter_type __end, ios_base& __io,
                  ios_base::iostate& __err, tm* __tm) const;


      void
      _M_extract_num(iter_type& __beg, iter_type& __end, int& __member,
                     int __min, int __max, size_t __len,
                     const ctype<_CharT>& __ctype,
                     ios_base::iostate& __err) const;



      void
      _M_extract_name(iter_type& __beg, iter_type& __end, int& __member,
                      const _CharT** __names, size_t __indexlen,
                      ios_base::iostate& __err) const;


      void
      _M_extract_via_format(iter_type& __beg, iter_type& __end, ios_base& __io,
                            ios_base::iostate& __err, tm* __tm,
                            const _CharT* __format) const;
    };

  template<typename _CharT, typename _InIter>
    locale::id time_get<_CharT, _InIter>::id;

  template<typename _CharT, typename _InIter>
    class time_get_byname : public time_get<_CharT, _InIter>
    {
    public:

      typedef _CharT char_type;
      typedef _InIter iter_type;

      explicit
      time_get_byname(const char*, size_t __refs = 0)
      : time_get<_CharT, _InIter>(__refs) { }

    protected:
      virtual
      ~time_get_byname() { }
    };

  template<typename _CharT, typename _OutIter>
    class time_put : public locale::facet, public time_base
    {
    public:

      typedef _CharT char_type;
      typedef _OutIter iter_type;

      static locale::id id;

      explicit
      time_put(size_t __refs = 0)
      : locale::facet(__refs) { }

      iter_type
      put(iter_type __s, ios_base& __io, char_type __fill, const tm* __tm,
          const _CharT* __beg, const _CharT* __end) const;

      iter_type
      put(iter_type __s, ios_base& __io, char_type __fill,
          const tm* __tm, char __format, char __mod = 0) const
      { return this->do_put(__s, __io, __fill, __tm, __format, __mod); }

    protected:
      virtual
      ~time_put()
      { }

      virtual iter_type
      do_put(iter_type __s, ios_base& __io, char_type __fill, const tm* __tm,
             char __format, char __mod) const;
    };

  template<typename _CharT, typename _OutIter>
    locale::id time_put<_CharT, _OutIter>::id;

  template<typename _CharT, typename _OutIter>
    class time_put_byname : public time_put<_CharT, _OutIter>
    {
    public:

      typedef _CharT char_type;
      typedef _OutIter iter_type;

      explicit
      time_put_byname(const char* , size_t __refs = 0)
      : time_put<_CharT, _OutIter>(__refs)
      { };

    protected:
      virtual
      ~time_put_byname() { }
    };


  class money_base
  {
  public:
    enum part { none, space, symbol, sign, value };
    struct pattern { char field[4]; };

    static const pattern _S_default_pattern;



    static pattern
    _S_construct_pattern(char __precedes, char __space, char __posn);
  };

  template<typename _CharT, bool _Intl>
    class moneypunct : public locale::facet, public money_base
    {
    public:

      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

      static const bool intl = _Intl;
      static locale::id id;

    private:
      const char* _M_grouping;
      char_type _M_decimal_point;
      char_type _M_thousands_sep;
      const char_type* _M_curr_symbol;
      const char_type* _M_positive_sign;
      const char_type* _M_negative_sign;
      int _M_frac_digits;
      pattern _M_pos_format;
      pattern _M_neg_format;

    public:
      explicit
      moneypunct(size_t __refs = 0) : locale::facet(__refs)
      { _M_initialize_moneypunct(); }

      explicit
      moneypunct(__c_locale __cloc, size_t __refs = 0) : locale::facet(__refs)
      { _M_initialize_moneypunct(__cloc); }

      char_type
      decimal_point() const
      { return this->do_decimal_point(); }

      char_type
      thousands_sep() const
      { return this->do_thousands_sep(); }

      string
      grouping() const
      { return this->do_grouping(); }

      string_type
      curr_symbol() const
      { return this->do_curr_symbol(); }

      string_type
      positive_sign() const
      { return this->do_positive_sign(); }

      string_type
      negative_sign() const
      { return this->do_negative_sign(); }

      int
      frac_digits() const
      { return this->do_frac_digits(); }

      pattern
      pos_format() const
      { return this->do_pos_format(); }

      pattern
      neg_format() const
      { return this->do_neg_format(); }

    protected:
      virtual
      ~moneypunct();

      virtual char_type
      do_decimal_point() const
      { return _M_decimal_point; }

      virtual char_type
      do_thousands_sep() const
      { return _M_thousands_sep; }

      virtual string
      do_grouping() const
      { return _M_grouping; }

      virtual string_type
      do_curr_symbol() const
      { return _M_curr_symbol; }

      virtual string_type
      do_positive_sign() const
      { return _M_positive_sign; }

      virtual string_type
      do_negative_sign() const
      { return _M_negative_sign; }

      virtual int
      do_frac_digits() const
      { return _M_frac_digits; }

      virtual pattern
      do_pos_format() const
      { return _M_pos_format; }

      virtual pattern
      do_neg_format() const
      { return _M_neg_format; }


       void
       _M_initialize_moneypunct(__c_locale __cloc = _S_c_locale);
    };

  template<typename _CharT, bool _Intl>
    locale::id moneypunct<_CharT, _Intl>::id;

  template<typename _CharT, bool _Intl>
    const bool moneypunct<_CharT, _Intl>::intl;

  template<>
    moneypunct<char, true>::~moneypunct();

  template<>
    moneypunct<char, false>::~moneypunct();

  template<>
    void
    moneypunct<char, true>::_M_initialize_moneypunct(__c_locale __cloc);

  template<>
    void
    moneypunct<char, false>::_M_initialize_moneypunct(__c_locale __cloc);
# 1480 "/usr/include/c++3.1/bits/locale_facets.h" 3
  template<typename _CharT, bool _Intl>
    class moneypunct_byname : public moneypunct<_CharT, _Intl>
    {
      __c_locale _M_c_locale_moneypunct;

    public:
      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

      static const bool intl = _Intl;

      explicit
      moneypunct_byname(const char* __s, size_t __refs = 0)
      : moneypunct<_CharT, _Intl>(__refs)
      {
        _S_create_c_locale(_M_c_locale_moneypunct, __s);
        _M_initialize_moneypunct(_M_c_locale_moneypunct);
      }

    protected:
      virtual
      ~moneypunct_byname()
      { _S_destroy_c_locale(_M_c_locale_moneypunct); }
    };

  template<typename _CharT, bool _Intl>
    const bool moneypunct_byname<_CharT, _Intl>::intl;

  template<typename _CharT, typename _InIter>
    class money_get : public locale::facet
    {
    public:

      typedef _CharT char_type;
      typedef _InIter iter_type;
      typedef basic_string<_CharT> string_type;

      static locale::id id;

      explicit
      money_get(size_t __refs = 0) : locale::facet(__refs) { }

      iter_type
      get(iter_type __s, iter_type __end, bool __intl, ios_base& __io,
          ios_base::iostate& __err, long double& __units) const
      { return this->do_get(__s, __end, __intl, __io, __err, __units); }

      iter_type
      get(iter_type __s, iter_type __end, bool __intl, ios_base& __io,
          ios_base::iostate& __err, string_type& __digits) const
      { return this->do_get(__s, __end, __intl, __io, __err, __digits); }

    protected:
      virtual
      ~money_get() { }

      virtual iter_type
      do_get(iter_type __s, iter_type __end, bool __intl, ios_base& __io,
             ios_base::iostate& __err, long double& __units) const;

      virtual iter_type
      do_get(iter_type __s, iter_type __end, bool __intl, ios_base& __io,
             ios_base::iostate& __err, string_type& __digits) const;
    };

  template<typename _CharT, typename _InIter>
    locale::id money_get<_CharT, _InIter>::id;

  template<typename _CharT, typename _OutIter>
    class money_put : public locale::facet
    {
    public:
      typedef _CharT char_type;
      typedef _OutIter iter_type;
      typedef basic_string<_CharT> string_type;

      static locale::id id;

      explicit
      money_put(size_t __refs = 0) : locale::facet(__refs) { }

      iter_type
      put(iter_type __s, bool __intl, ios_base& __io,
          char_type __fill, long double __units) const
      { return this->do_put(__s, __intl, __io, __fill, __units); }

      iter_type
      put(iter_type __s, bool __intl, ios_base& __io,
          char_type __fill, const string_type& __digits) const
      { return this->do_put(__s, __intl, __io, __fill, __digits); }

    protected:
      virtual
      ~money_put() { }

      virtual iter_type
      do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill,
             long double __units) const;

      virtual iter_type
      do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill,
             const string_type& __digits) const;
    };

  template<typename _CharT, typename _OutIter>
    locale::id money_put<_CharT, _OutIter>::id;


  struct messages_base
  {
    typedef int catalog;
  };

  template<typename _CharT>
    class messages : public locale::facet, public messages_base
    {
    public:

      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

    protected:


      __c_locale _M_c_locale_messages;


      const char* _M_name_messages;


    public:
      static locale::id id;

      explicit
      messages(size_t __refs = 0)
      : locale::facet(__refs), _M_name_messages("C")
      { _M_c_locale_messages = _S_c_locale; }


      explicit
      messages(__c_locale __cloc, const char* __name, size_t __refs = 0)
      : locale::facet(__refs)
      {
        _M_name_messages = __name;
        _M_c_locale_messages = _S_clone_c_locale(__cloc);
      }

      catalog
      open(const basic_string<char>& __s, const locale& __loc) const
      { return this->do_open(__s, __loc); }


      catalog
      open(const basic_string<char>&, const locale&, const char*) const;

      string_type
      get(catalog __c, int __set, int __msgid, const string_type& __s) const
      { return this->do_get(__c, __set, __msgid, __s); }

      void
      close(catalog __c) const
      { return this->do_close(__c); }

    protected:
      virtual
      ~messages()
       {
         if (_M_c_locale_messages != _S_c_locale)
           _S_destroy_c_locale(_M_c_locale_messages);
       }

      virtual catalog
      do_open(const basic_string<char>&, const locale&) const;

      virtual string_type
      do_get(catalog, int, int, const string_type& __dfault) const;

      virtual void
      do_close(catalog) const;


      char*
      _M_convert_to_char(const string_type& __msg) const
      {

        return reinterpret_cast<char*>(const_cast<_CharT*>(__msg.c_str()));
      }


      string_type
      _M_convert_from_char(char* __msg) const
      {

        size_t __len = char_traits<char>::length(__msg) - 1;
# 1705 "/usr/include/c++3.1/bits/locale_facets.h" 3
        return string_type();
      }
     };

  template<typename _CharT>
    locale::id messages<_CharT>::id;


  template<>
    string
    messages<char>::do_get(catalog, int, int, const string&) const;


# 1 "/usr/include/c++3.1/i686-inX-linux/bits/messages_members.h" 1 3
# 37 "/usr/include/c++3.1/i686-inX-linux/bits/messages_members.h" 3
  template<typename _CharT>
    typename messages<_CharT>::catalog
    messages<_CharT>::open(const basic_string<char>& __s, const locale& __loc,
                           const char* __dir) const
    {
      bindtextdomain(__s.c_str(), __dir);
      return this->do_open(__s, __loc);
    }

  template<typename _CharT>
    typename messages<_CharT>::catalog
    messages<_CharT>::do_open(const basic_string<char>& __s,
                              const locale&) const
    {


      textdomain(__s.c_str());
      return 0;
    }

  template<typename _CharT>
    typename messages<_CharT>::string_type
    messages<_CharT>::do_get(catalog, int, int,
                             const string_type& __dfault) const
    {






      const char* __old = setlocale(__LC_ALL, _M_name_messages);
      char* __msg = gettext(_M_convert_to_char(__dfault));
      setlocale(__LC_ALL, __old);
      return _M_convert_from_char(__msg);

    }

  template<typename _CharT>
    void
    messages<_CharT>::do_close(catalog) const
    { }
# 1719 "/usr/include/c++3.1/bits/locale_facets.h" 2 3

  template<typename _CharT>
    class messages_byname : public messages<_CharT>
    {
    public:
      typedef _CharT char_type;
      typedef basic_string<_CharT> string_type;

      explicit
      messages_byname(const char* __s, size_t __refs = 0)
      : messages<_CharT>(__refs)
      {
        _M_name_messages = __s;
        if (_M_c_locale_messages != _S_c_locale)
          _S_destroy_c_locale(_M_c_locale_messages);
        _S_create_c_locale(_M_c_locale_messages, __s);
      }

    protected:
      virtual
      ~messages_byname()
      { }
    };






  template<typename _CharT>
    inline bool
    isspace(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::space, __c); }

  template<typename _CharT>
    inline bool
    isprint(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::print, __c); }

  template<typename _CharT>
    inline bool
    iscntrl(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::cntrl, __c); }

  template<typename _CharT>
    inline bool
    isupper(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::upper, __c); }

  template<typename _CharT>
    inline bool islower(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::lower, __c); }

  template<typename _CharT>
    inline bool
    isalpha(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::alpha, __c); }

  template<typename _CharT>
    inline bool
    isdigit(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::digit, __c); }

  template<typename _CharT>
    inline bool
    ispunct(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::punct, __c); }

  template<typename _CharT>
    inline bool
    isxdigit(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::xdigit, __c); }

  template<typename _CharT>
    inline bool
    isalnum(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::alnum, __c); }

  template<typename _CharT>
    inline bool
    isgraph(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::graph, __c); }

  template<typename _CharT>
    inline _CharT
    toupper(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).toupper(__c); }

  template<typename _CharT>
    inline _CharT
    tolower(_CharT __c, const locale& __loc)
    { return use_facet<ctype<_CharT> >(__loc).tolower(__c); }
}
# 42 "/usr/include/c++3.1/bits/basic_ios.h" 2 3

namespace std
{

  template<typename _CharT, typename _Traits>
    class basic_ios : public ios_base
    {
    public:

      typedef _CharT char_type;
      typedef typename _Traits::int_type int_type;
      typedef typename _Traits::pos_type pos_type;
      typedef typename _Traits::off_type off_type;
      typedef _Traits traits_type;


      typedef ctype<_CharT> __ctype_type;
      typedef ostreambuf_iterator<_CharT, _Traits> __ostreambuf_iter;
      typedef num_put<_CharT, __ostreambuf_iter> __numput_type;
      typedef istreambuf_iterator<_CharT, _Traits> __istreambuf_iter;
      typedef num_get<_CharT, __istreambuf_iter> __numget_type;


    protected:
      basic_ostream<_CharT, _Traits>* _M_tie;
      mutable char_type _M_fill;
      mutable bool _M_fill_init;
      basic_streambuf<_CharT, _Traits>* _M_streambuf;


      const __ctype_type* _M_fctype;

      const __numput_type* _M_fnumput;

      const __numget_type* _M_fnumget;

    public:
      operator void*() const
      { return this->fail() ? 0 : const_cast<basic_ios*>(this); }

      bool
      operator!() const
      { return this->fail(); }

      iostate
      rdstate() const
      { return _M_streambuf_state; }

      void
      clear(iostate __state = goodbit);

      void
      setstate(iostate __state)
      { this->clear(this->rdstate() | __state); }

      bool
      good() const
      { return this->rdstate() == 0; }

      bool
      eof() const
      { return (this->rdstate() & eofbit) != 0; }

      bool
      fail() const
      { return (this->rdstate() & (badbit | failbit)) != 0; }

      bool
      bad() const
      { return (this->rdstate() & badbit) != 0; }

      iostate
      exceptions() const
      { return _M_exception; }

      void
      exceptions(iostate __except)
      {
        _M_exception = __except;
        this->clear(_M_streambuf_state);
      }


      explicit
      basic_ios(basic_streambuf<_CharT, _Traits>* __sb) : ios_base()
      { this->init(__sb); }

      virtual
      ~basic_ios() { }


      basic_ostream<_CharT, _Traits>*
      tie() const
      { return _M_tie; }

      basic_ostream<_CharT, _Traits>*
      tie(basic_ostream<_CharT, _Traits>* __tiestr)
      {
        basic_ostream<_CharT, _Traits>* __old = _M_tie;
        _M_tie = __tiestr;
        return __old;
      }

      basic_streambuf<_CharT, _Traits>*
      rdbuf() const
      { return _M_streambuf; }

      basic_streambuf<_CharT, _Traits>*
      rdbuf(basic_streambuf<_CharT, _Traits>* __sb);

      basic_ios&
      copyfmt(const basic_ios& __rhs);

      char_type
      fill() const
      {
        if (!_M_fill_init)
          {
            _M_fill = this->widen(' ');
            _M_fill_init = true;
          }
        return _M_fill;
      }

      char_type
      fill(char_type __ch)
      {
        char_type __old = this->fill();
        _M_fill = __ch;
        return __old;
      }


      locale
      imbue(const locale& __loc);

      char
      narrow(char_type __c, char __dfault) const;

      char_type
      widen(char __c) const;

    protected:

      basic_ios() : ios_base()
      { }

      void
      init(basic_streambuf<_CharT, _Traits>* __sb);

      bool
      _M_check_facet(const locale::facet* __f) const
      {
        if (!__f)
          __throw_bad_cast();
        return true;
      }

      void
      _M_cache_facets(const locale& __loc);
    };
}



# 1 "/usr/include/c++3.1/bits/basic_ios.tcc" 1 3
# 34 "/usr/include/c++3.1/bits/basic_ios.tcc" 3

namespace std
{
  template<typename _CharT, typename _Traits>
    void
    basic_ios<_CharT, _Traits>::clear(iostate __state)
    {
      if (this->rdbuf())
        _M_streambuf_state = __state;
      else
          _M_streambuf_state = __state | badbit;
      if ((this->rdstate() & this->exceptions()))
        __throw_ios_failure("basic_ios::clear(iostate) caused exception");
    }

  template<typename _CharT, typename _Traits>
    basic_streambuf<_CharT, _Traits>*
    basic_ios<_CharT, _Traits>::rdbuf(basic_streambuf<_CharT, _Traits>* __sb)
    {
      basic_streambuf<_CharT, _Traits>* __old = _M_streambuf;
      _M_streambuf = __sb;
      this->clear();
      return __old;
    }

  template<typename _CharT, typename _Traits>
    basic_ios<_CharT, _Traits>&
    basic_ios<_CharT, _Traits>::copyfmt(const basic_ios& __rhs)
    {




      _Words* __words = (__rhs._M_word_size <= _S_local_word_size) ?
        _M_local_word : new _Words[__rhs._M_word_size];


      _Callback_list* __cb = __rhs._M_callbacks;
      if (__cb)
        __cb->_M_add_reference();
      _M_call_callbacks(erase_event);
      if (_M_word != _M_local_word)
        {
          delete [] _M_word;
          _M_word = 0;
        }
      _M_dispose_callbacks();

      _M_callbacks = __cb;
      for (int __i = 0; __i < __rhs._M_word_size; ++__i)
        __words[__i] = __rhs._M_word[__i];
      if (_M_word != _M_local_word)
        {
          delete [] _M_word;
          _M_word = 0;
        }
      _M_word = __words;
      _M_word_size = __rhs._M_word_size;

      this->flags(__rhs.flags());
      this->width(__rhs.width());
      this->precision(__rhs.precision());
      this->tie(__rhs.tie());
      this->fill(__rhs.fill());

      this->exceptions(__rhs.exceptions());

      _M_call_callbacks(copyfmt_event);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    char
    basic_ios<_CharT, _Traits>::narrow(char_type __c, char __dfault) const
    {
      char __ret = __dfault;
      if (_M_check_facet(_M_fctype))
        __ret = _M_fctype->narrow(__c, __dfault);
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    _CharT
    basic_ios<_CharT, _Traits>::widen(char __c) const
    {
      char_type __ret = char_type();
      if (_M_check_facet(_M_fctype))
        __ret = _M_fctype->widen(__c);
      return __ret;
    }


  template<typename _CharT, typename _Traits>
    locale
    basic_ios<_CharT, _Traits>::imbue(const locale& __loc)
    {
      locale __old(this->getloc());
      ios_base::imbue(__loc);
      _M_cache_facets(__loc);
      if (this->rdbuf() != 0)
        this->rdbuf()->pubimbue(__loc);
      return __old;
    }

  template<typename _CharT, typename _Traits>
    void
    basic_ios<_CharT, _Traits>::init(basic_streambuf<_CharT, _Traits>* __sb)
    {

      ios_base::_M_init();
      _M_cache_facets(_M_ios_locale);
      _M_tie = 0;
# 159 "/usr/include/c++3.1/bits/basic_ios.tcc" 3
      _M_fill = 0;
      _M_fill_init = false;

      _M_exception = goodbit;
      _M_streambuf = __sb;
      _M_streambuf_state = __sb ? goodbit : badbit;
    }

  template<typename _CharT, typename _Traits>
    void
    basic_ios<_CharT, _Traits>::_M_cache_facets(const locale& __loc)
    {
      if (has_facet<__ctype_type>(__loc))
        _M_fctype = &use_facet<__ctype_type>(__loc);
      else
        _M_fctype = 0;

      if (has_facet<__numput_type>(__loc))
        _M_fnumput = &use_facet<__numput_type>(__loc);
      else
        _M_fnumput = 0;
      if (has_facet<__numget_type>(__loc))
        _M_fnumget = &use_facet<__numget_type>(__loc);
      else
        _M_fnumget = 0;
    }




  extern template class basic_ios<char>;
  extern template class basic_ios<wchar_t>;
}
# 208 "/usr/include/c++3.1/bits/basic_ios.h" 2 3
# 52 "/usr/include/c++3.1/ios" 2 3
# 46 "/usr/include/c++3.1/ostream" 2 3

namespace std
{

  template<typename _CharT, typename _Traits>
    class basic_ostream : virtual public basic_ios<_CharT, _Traits>
    {
    public:

      typedef _CharT char_type;
      typedef typename _Traits::int_type int_type;
      typedef typename _Traits::pos_type pos_type;
      typedef typename _Traits::off_type off_type;
      typedef _Traits traits_type;


      typedef basic_streambuf<_CharT, _Traits> __streambuf_type;
      typedef basic_ios<_CharT, _Traits> __ios_type;
      typedef basic_ostream<_CharT, _Traits> __ostream_type;
      typedef ostreambuf_iterator<_CharT, _Traits> __ostreambuf_iter;
      typedef num_put<_CharT, __ostreambuf_iter> __numput_type;
      typedef ctype<_CharT> __ctype_type;


      explicit
      basic_ostream(__streambuf_type* __sb)
      { this->init(__sb); }

      virtual
      ~basic_ostream() { }


      class sentry;
      friend class sentry;



      __ostream_type&
      operator<<(__ostream_type& (*__pf)(__ostream_type&));

      __ostream_type&
      operator<<(__ios_type& (*__pf)(__ios_type&));

      __ostream_type&
      operator<<(ios_base& (*__pf) (ios_base&));


      __ostream_type&
      operator<<(long __n);

      __ostream_type&
      operator<<(unsigned long __n);

      __ostream_type&
      operator<<(bool __n);

      __ostream_type&
      operator<<(short __n)
      {
        ios_base::fmtflags __fmt = this->flags() & ios_base::basefield;
        if (__fmt & ios_base::oct || __fmt & ios_base::hex)
          return this->operator<<(static_cast<unsigned long>
                                  (static_cast<unsigned short>(__n)));
        else
          return this->operator<<(static_cast<long>(__n));
      }

      __ostream_type&
      operator<<(unsigned short __n)
      { return this->operator<<(static_cast<unsigned long>(__n)); }

      __ostream_type&
      operator<<(int __n)
      {
        ios_base::fmtflags __fmt = this->flags() & ios_base::basefield;
        if (__fmt & ios_base::oct || __fmt & ios_base::hex)
          return this->operator<<(static_cast<unsigned long>
                                  (static_cast<unsigned int>(__n)));
        else
          return this->operator<<(static_cast<long>(__n));
      }

      __ostream_type&
      operator<<(unsigned int __n)
      { return this->operator<<(static_cast<unsigned long>(__n)); }


      __ostream_type&
      operator<<(long long __n);

      __ostream_type&
      operator<<(unsigned long long __n);


      __ostream_type&
      operator<<(double __f);

      __ostream_type&
      operator<<(float __f)
      { return this->operator<<(static_cast<double>(__f)); }

      __ostream_type&
      operator<<(long double __f);

      __ostream_type&
      operator<<(const void* __p);

      __ostream_type&
      operator<<(__streambuf_type* __sb);


      __ostream_type&
      put(char_type __c);

      __ostream_type&
      write(const char_type* __s, streamsize __n);

      __ostream_type&
      flush();


      pos_type
      tellp();

      __ostream_type&
      seekp(pos_type);

      __ostream_type&
      seekp(off_type, ios_base::seekdir);
    };


  template <typename _CharT, typename _Traits>
    class basic_ostream<_CharT, _Traits>::sentry
    {

      bool _M_ok;
      basic_ostream<_CharT,_Traits>& _M_os;

    public:
      explicit
      sentry(basic_ostream<_CharT,_Traits>& __os);

      ~sentry()
      {

        if (_M_os.flags() & ios_base::unitbuf && !uncaught_exception())
          {

            if (_M_os.rdbuf() && _M_os.rdbuf()->pubsync() == -1)
              _M_os.setstate(ios_base::badbit);
          }
      }

      operator bool()
      { return _M_ok; }
    };

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out, _CharT __c);

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out, char __c)
    { return (__out << __out.widen(__c)); }


  template <class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, char __c);


  template<class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, signed char __c)
    { return (__out << static_cast<char>(__c)); }

  template<class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, unsigned char __c)
    { return (__out << static_cast<char>(__c)); }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out, const _CharT* __s);

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits> &
    operator<<(basic_ostream<_CharT, _Traits>& __out, const char* __s);


  template<class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, const char* __s);


  template<class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, const signed char* __s)
    { return (__out << reinterpret_cast<const char*>(__s)); }

  template<class _Traits>
    basic_ostream<char, _Traits> &
    operator<<(basic_ostream<char, _Traits>& __out, const unsigned char* __s)
    { return (__out << reinterpret_cast<const char*>(__s)); }


  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    endl(basic_ostream<_CharT, _Traits>& __os)
    { return flush(__os.put(__os.widen('\n'))); }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    ends(basic_ostream<_CharT, _Traits>& __os)
    { return __os.put(_CharT()); }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    flush(basic_ostream<_CharT, _Traits>& __os)
    { return __os.flush(); }

}





# 1 "/usr/include/c++3.1/bits/ostream.tcc" 1 3
# 36 "/usr/include/c++3.1/bits/ostream.tcc" 3

# 1 "/usr/include/c++3.1/locale" 1 3
# 43 "/usr/include/c++3.1/locale" 3



# 1 "/usr/include/c++3.1/bits/locale_facets.tcc" 1 3
# 37 "/usr/include/c++3.1/bits/locale_facets.tcc" 3

# 1 "/usr/include/c++3.1/cerrno" 1 3
# 47 "/usr/include/c++3.1/cerrno" 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/errno.h" 1 3
# 32 "/usr/lib/gcc/../../i686-inX-linux/include/errno.h" 3
extern "C" {



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/errno.h" 1 3
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/bits/errno.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/linux/errno.h" 1 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/asm/errno.h" 1 3
# 5 "/usr/lib/gcc/../../i686-inX-linux/include/linux/errno.h" 2 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/bits/errno.h" 2 3
# 36 "/usr/lib/gcc/../../i686-inX-linux/include/bits/errno.h" 3
extern int errno;


extern int *__errno_location (void) throw () __attribute__ ((__const__));
# 37 "/usr/lib/gcc/../../i686-inX-linux/include/errno.h" 2 3
# 55 "/usr/lib/gcc/../../i686-inX-linux/include/errno.h" 3
extern char *program_invocation_name, *program_invocation_short_name;



}
# 69 "/usr/lib/gcc/../../i686-inX-linux/include/errno.h" 3
typedef int error_t;
# 49 "/usr/include/c++3.1/cerrno" 2 3
# 39 "/usr/include/c++3.1/bits/locale_facets.tcc" 2 3


# 1 "/usr/include/c++3.1/cmath" 1 3
# 48 "/usr/include/c++3.1/cmath" 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 1 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
extern "C" {



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/huge_val.h" 1 3
# 34 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 2 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/nan.h" 1 3
# 38 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 2 3


# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathdef.h" 1 3
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathdef.h" 3
typedef long double float_t;

typedef long double double_t;
# 41 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 2 3
# 63 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathcalls.h" 1 3
# 54 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathcalls.h" 3
extern double acos (double __x) throw (); extern double __acos (double __x) throw ();

extern double asin (double __x) throw (); extern double __asin (double __x) throw ();

extern double atan (double __x) throw (); extern double __atan (double __x) throw ();

extern double atan2 (double __y, double __x) throw (); extern double __atan2 (double __y, double __x) throw ();


extern double cos (double __x) throw (); extern double __cos (double __x) throw ();

extern double sin (double __x) throw (); extern double __sin (double __x) throw ();

extern double tan (double __x) throw (); extern double __tan (double __x) throw ();



extern void sincos (double __x, double *__sinx, double *__cosx) throw (); extern void __sincos (double __x, double *__sinx, double *__cosx) throw ();






extern double cosh (double __x) throw (); extern double __cosh (double __x) throw ();

extern double sinh (double __x) throw (); extern double __sinh (double __x) throw ();

extern double tanh (double __x) throw (); extern double __tanh (double __x) throw ();



extern double acosh (double __x) throw (); extern double __acosh (double __x) throw ();

extern double asinh (double __x) throw (); extern double __asinh (double __x) throw ();

extern double atanh (double __x) throw (); extern double __atanh (double __x) throw ();





extern double exp (double __x) throw (); extern double __exp (double __x) throw ();



extern double exp10 (double __x) throw (); extern double __exp10 (double __x) throw ();

extern double pow10 (double __x) throw (); extern double __pow10 (double __x) throw ();



extern double frexp (double __x, int *__exponent) throw (); extern double __frexp (double __x, int *__exponent) throw ();


extern double ldexp (double __x, int __exponent) throw (); extern double __ldexp (double __x, int __exponent) throw ();


extern double log (double __x) throw (); extern double __log (double __x) throw ();


extern double log10 (double __x) throw (); extern double __log10 (double __x) throw ();


extern double modf (double __x, double *__iptr) throw (); extern double __modf (double __x, double *__iptr) throw ();



extern double expm1 (double __x) throw (); extern double __expm1 (double __x) throw ();


extern double log1p (double __x) throw (); extern double __log1p (double __x) throw ();


extern double logb (double __x) throw (); extern double __logb (double __x) throw ();




extern double exp2 (double __x) throw (); extern double __exp2 (double __x) throw ();


extern double log2 (double __x) throw (); extern double __log2 (double __x) throw ();






extern double pow (double __x, double __y) throw (); extern double __pow (double __x, double __y) throw ();


extern double sqrt (double __x) throw (); extern double __sqrt (double __x) throw ();



extern double hypot (double __x, double __y) throw (); extern double __hypot (double __x, double __y) throw ();




extern double cbrt (double __x) throw (); extern double __cbrt (double __x) throw ();






extern double ceil (double __x) throw (); extern double __ceil (double __x) throw ();


extern double fabs (double __x) throw () __attribute__ ((__const__)); extern double __fabs (double __x) throw () __attribute__ ((__const__));


extern double floor (double __x) throw (); extern double __floor (double __x) throw ();


extern double fmod (double __x, double __y) throw (); extern double __fmod (double __x, double __y) throw ();




extern int __isinf (double __value) throw () __attribute__ ((__const__));


extern int __finite (double __value) throw () __attribute__ ((__const__));




extern int isinf (double __value) throw () __attribute__ ((__const__));


extern int finite (double __value) throw () __attribute__ ((__const__));


extern double drem (double __x, double __y) throw (); extern double __drem (double __x, double __y) throw ();



extern double significand (double __x) throw (); extern double __significand (double __x) throw ();




extern double copysign (double __x, double __y) throw () __attribute__ ((__const__)); extern double __copysign (double __x, double __y) throw () __attribute__ ((__const__));




extern double nan (__const char *__tagb) throw () __attribute__ ((__const__)); extern double __nan (__const char *__tagb) throw () __attribute__ ((__const__));




extern int __isnan (double __value) throw () __attribute__ ((__const__));



extern int isnan (double __value) throw () __attribute__ ((__const__));


extern double j0 (double) throw (); extern double __j0 (double) throw ();
extern double j1 (double) throw (); extern double __j1 (double) throw ();
extern double jn (int, double) throw (); extern double __jn (int, double) throw ();
extern double y0 (double) throw (); extern double __y0 (double) throw ();
extern double y1 (double) throw (); extern double __y1 (double) throw ();
extern double yn (int, double) throw (); extern double __yn (int, double) throw ();





extern double erf (double) throw (); extern double __erf (double) throw ();
extern double erfc (double) throw (); extern double __erfc (double) throw ();
extern double lgamma (double) throw (); extern double __lgamma (double) throw ();



extern double tgamma (double) throw (); extern double __tgamma (double) throw ();




extern double gamma (double) throw (); extern double __gamma (double) throw ();






extern double lgamma_r (double, int *__signgamp) throw (); extern double __lgamma_r (double, int *__signgamp) throw ();






extern double rint (double __x) throw (); extern double __rint (double __x) throw ();


extern double nextafter (double __x, double __y) throw () __attribute__ ((__const__)); extern double __nextafter (double __x, double __y) throw () __attribute__ ((__const__));

extern double nexttoward (double __x, long double __y) throw () __attribute__ ((__const__)); extern double __nexttoward (double __x, long double __y) throw () __attribute__ ((__const__));



extern double remainder (double __x, double __y) throw (); extern double __remainder (double __x, double __y) throw ();



extern double scalb (double __x, double __n) throw (); extern double __scalb (double __x, double __n) throw ();




extern double scalbn (double __x, int __n) throw (); extern double __scalbn (double __x, int __n) throw ();



extern int ilogb (double __x) throw (); extern int __ilogb (double __x) throw ();




extern double scalbln (double __x, long int __n) throw (); extern double __scalbln (double __x, long int __n) throw ();



extern double nearbyint (double __x) throw (); extern double __nearbyint (double __x) throw ();



extern double round (double __x) throw (); extern double __round (double __x) throw ();



extern double trunc (double __x) throw () __attribute__ ((__const__)); extern double __trunc (double __x) throw () __attribute__ ((__const__));




extern double remquo (double __x, double __y, int *__quo) throw (); extern double __remquo (double __x, double __y, int *__quo) throw ();






extern long int lrint (double __x) throw (); extern long int __lrint (double __x) throw ();
extern long long int llrint (double __x) throw (); extern long long int __llrint (double __x) throw ();



extern long int lround (double __x) throw (); extern long int __lround (double __x) throw ();
extern long long int llround (double __x) throw (); extern long long int __llround (double __x) throw ();



extern double fdim (double __x, double __y) throw (); extern double __fdim (double __x, double __y) throw ();


extern double fmax (double __x, double __y) throw (); extern double __fmax (double __x, double __y) throw ();


extern double fmin (double __x, double __y) throw (); extern double __fmin (double __x, double __y) throw ();



extern int __fpclassify (double __value) throw ()
     __attribute__ ((__const__));


extern int __signbit (double __value) throw ()
     __attribute__ ((__const__));



extern double fma (double __x, double __y, double __z) throw (); extern double __fma (double __x, double __y, double __z) throw ();
# 64 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 2 3
# 82 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathcalls.h" 1 3
# 54 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathcalls.h" 3
extern float acosf (float __x) throw (); extern float __acosf (float __x) throw ();

extern float asinf (float __x) throw (); extern float __asinf (float __x) throw ();

extern float atanf (float __x) throw (); extern float __atanf (float __x) throw ();

extern float atan2f (float __y, float __x) throw (); extern float __atan2f (float __y, float __x) throw ();


extern float cosf (float __x) throw (); extern float __cosf (float __x) throw ();

extern float sinf (float __x) throw (); extern float __sinf (float __x) throw ();

extern float tanf (float __x) throw (); extern float __tanf (float __x) throw ();



extern void sincosf (float __x, float *__sinx, float *__cosx) throw (); extern void __sincosf (float __x, float *__sinx, float *__cosx) throw ();






extern float coshf (float __x) throw (); extern float __coshf (float __x) throw ();

extern float sinhf (float __x) throw (); extern float __sinhf (float __x) throw ();

extern float tanhf (float __x) throw (); extern float __tanhf (float __x) throw ();



extern float acoshf (float __x) throw (); extern float __acoshf (float __x) throw ();

extern float asinhf (float __x) throw (); extern float __asinhf (float __x) throw ();

extern float atanhf (float __x) throw (); extern float __atanhf (float __x) throw ();





extern float expf (float __x) throw (); extern float __expf (float __x) throw ();



extern float exp10f (float __x) throw (); extern float __exp10f (float __x) throw ();

extern float pow10f (float __x) throw (); extern float __pow10f (float __x) throw ();



extern float frexpf (float __x, int *__exponent) throw (); extern float __frexpf (float __x, int *__exponent) throw ();


extern float ldexpf (float __x, int __exponent) throw (); extern float __ldexpf (float __x, int __exponent) throw ();


extern float logf (float __x) throw (); extern float __logf (float __x) throw ();


extern float log10f (float __x) throw (); extern float __log10f (float __x) throw ();


extern float modff (float __x, float *__iptr) throw (); extern float __modff (float __x, float *__iptr) throw ();



extern float expm1f (float __x) throw (); extern float __expm1f (float __x) throw ();


extern float log1pf (float __x) throw (); extern float __log1pf (float __x) throw ();


extern float logbf (float __x) throw (); extern float __logbf (float __x) throw ();




extern float exp2f (float __x) throw (); extern float __exp2f (float __x) throw ();


extern float log2f (float __x) throw (); extern float __log2f (float __x) throw ();






extern float powf (float __x, float __y) throw (); extern float __powf (float __x, float __y) throw ();


extern float sqrtf (float __x) throw (); extern float __sqrtf (float __x) throw ();



extern float hypotf (float __x, float __y) throw (); extern float __hypotf (float __x, float __y) throw ();




extern float cbrtf (float __x) throw (); extern float __cbrtf (float __x) throw ();






extern float ceilf (float __x) throw (); extern float __ceilf (float __x) throw ();


extern float fabsf (float __x) throw () __attribute__ ((__const__)); extern float __fabsf (float __x) throw () __attribute__ ((__const__));


extern float floorf (float __x) throw (); extern float __floorf (float __x) throw ();


extern float fmodf (float __x, float __y) throw (); extern float __fmodf (float __x, float __y) throw ();




extern int __isinff (float __value) throw () __attribute__ ((__const__));


extern int __finitef (float __value) throw () __attribute__ ((__const__));




extern int isinff (float __value) throw () __attribute__ ((__const__));


extern int finitef (float __value) throw () __attribute__ ((__const__));


extern float dremf (float __x, float __y) throw (); extern float __dremf (float __x, float __y) throw ();



extern float significandf (float __x) throw (); extern float __significandf (float __x) throw ();




extern float copysignf (float __x, float __y) throw () __attribute__ ((__const__)); extern float __copysignf (float __x, float __y) throw () __attribute__ ((__const__));




extern float nanf (__const char *__tagb) throw () __attribute__ ((__const__)); extern float __nanf (__const char *__tagb) throw () __attribute__ ((__const__));




extern int __isnanf (float __value) throw () __attribute__ ((__const__));



extern int isnanf (float __value) throw () __attribute__ ((__const__));


extern float j0f (float) throw (); extern float __j0f (float) throw ();
extern float j1f (float) throw (); extern float __j1f (float) throw ();
extern float jnf (int, float) throw (); extern float __jnf (int, float) throw ();
extern float y0f (float) throw (); extern float __y0f (float) throw ();
extern float y1f (float) throw (); extern float __y1f (float) throw ();
extern float ynf (int, float) throw (); extern float __ynf (int, float) throw ();





extern float erff (float) throw (); extern float __erff (float) throw ();
extern float erfcf (float) throw (); extern float __erfcf (float) throw ();
extern float lgammaf (float) throw (); extern float __lgammaf (float) throw ();



extern float tgammaf (float) throw (); extern float __tgammaf (float) throw ();




extern float gammaf (float) throw (); extern float __gammaf (float) throw ();






extern float lgammaf_r (float, int *__signgamp) throw (); extern float __lgammaf_r (float, int *__signgamp) throw ();






extern float rintf (float __x) throw (); extern float __rintf (float __x) throw ();


extern float nextafterf (float __x, float __y) throw () __attribute__ ((__const__)); extern float __nextafterf (float __x, float __y) throw () __attribute__ ((__const__));

extern float nexttowardf (float __x, long double __y) throw () __attribute__ ((__const__)); extern float __nexttowardf (float __x, long double __y) throw () __attribute__ ((__const__));



extern float remainderf (float __x, float __y) throw (); extern float __remainderf (float __x, float __y) throw ();



extern float scalbf (float __x, float __n) throw (); extern float __scalbf (float __x, float __n) throw ();




extern float scalbnf (float __x, int __n) throw (); extern float __scalbnf (float __x, int __n) throw ();



extern int ilogbf (float __x) throw (); extern int __ilogbf (float __x) throw ();




extern float scalblnf (float __x, long int __n) throw (); extern float __scalblnf (float __x, long int __n) throw ();



extern float nearbyintf (float __x) throw (); extern float __nearbyintf (float __x) throw ();



extern float roundf (float __x) throw (); extern float __roundf (float __x) throw ();



extern float truncf (float __x) throw () __attribute__ ((__const__)); extern float __truncf (float __x) throw () __attribute__ ((__const__));




extern float remquof (float __x, float __y, int *__quo) throw (); extern float __remquof (float __x, float __y, int *__quo) throw ();






extern long int lrintf (float __x) throw (); extern long int __lrintf (float __x) throw ();
extern long long int llrintf (float __x) throw (); extern long long int __llrintf (float __x) throw ();



extern long int lroundf (float __x) throw (); extern long int __lroundf (float __x) throw ();
extern long long int llroundf (float __x) throw (); extern long long int __llroundf (float __x) throw ();



extern float fdimf (float __x, float __y) throw (); extern float __fdimf (float __x, float __y) throw ();


extern float fmaxf (float __x, float __y) throw (); extern float __fmaxf (float __x, float __y) throw ();


extern float fminf (float __x, float __y) throw (); extern float __fminf (float __x, float __y) throw ();



extern int __fpclassifyf (float __value) throw ()
     __attribute__ ((__const__));


extern int __signbitf (float __value) throw ()
     __attribute__ ((__const__));



extern float fmaf (float __x, float __y, float __z) throw (); extern float __fmaf (float __x, float __y, float __z) throw ();
# 83 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 2 3
# 99 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathcalls.h" 1 3
# 54 "/usr/lib/gcc/../../i686-inX-linux/include/bits/mathcalls.h" 3
extern long double acosl (long double __x) throw (); extern long double __acosl (long double __x) throw ();

extern long double asinl (long double __x) throw (); extern long double __asinl (long double __x) throw ();

extern long double atanl (long double __x) throw (); extern long double __atanl (long double __x) throw ();

extern long double atan2l (long double __y, long double __x) throw (); extern long double __atan2l (long double __y, long double __x) throw ();


extern long double cosl (long double __x) throw (); extern long double __cosl (long double __x) throw ();

extern long double sinl (long double __x) throw (); extern long double __sinl (long double __x) throw ();

extern long double tanl (long double __x) throw (); extern long double __tanl (long double __x) throw ();



extern void sincosl (long double __x, long double *__sinx, long double *__cosx) throw (); extern void __sincosl (long double __x, long double *__sinx, long double *__cosx) throw ();






extern long double coshl (long double __x) throw (); extern long double __coshl (long double __x) throw ();

extern long double sinhl (long double __x) throw (); extern long double __sinhl (long double __x) throw ();

extern long double tanhl (long double __x) throw (); extern long double __tanhl (long double __x) throw ();



extern long double acoshl (long double __x) throw (); extern long double __acoshl (long double __x) throw ();

extern long double asinhl (long double __x) throw (); extern long double __asinhl (long double __x) throw ();

extern long double atanhl (long double __x) throw (); extern long double __atanhl (long double __x) throw ();





extern long double expl (long double __x) throw (); extern long double __expl (long double __x) throw ();



extern long double exp10l (long double __x) throw (); extern long double __exp10l (long double __x) throw ();

extern long double pow10l (long double __x) throw (); extern long double __pow10l (long double __x) throw ();



extern long double frexpl (long double __x, int *__exponent) throw (); extern long double __frexpl (long double __x, int *__exponent) throw ();


extern long double ldexpl (long double __x, int __exponent) throw (); extern long double __ldexpl (long double __x, int __exponent) throw ();


extern long double logl (long double __x) throw (); extern long double __logl (long double __x) throw ();


extern long double log10l (long double __x) throw (); extern long double __log10l (long double __x) throw ();


extern long double modfl (long double __x, long double *__iptr) throw (); extern long double __modfl (long double __x, long double *__iptr) throw ();



extern long double expm1l (long double __x) throw (); extern long double __expm1l (long double __x) throw ();


extern long double log1pl (long double __x) throw (); extern long double __log1pl (long double __x) throw ();


extern long double logbl (long double __x) throw (); extern long double __logbl (long double __x) throw ();




extern long double exp2l (long double __x) throw (); extern long double __exp2l (long double __x) throw ();


extern long double log2l (long double __x) throw (); extern long double __log2l (long double __x) throw ();






extern long double powl (long double __x, long double __y) throw (); extern long double __powl (long double __x, long double __y) throw ();


extern long double sqrtl (long double __x) throw (); extern long double __sqrtl (long double __x) throw ();



extern long double hypotl (long double __x, long double __y) throw (); extern long double __hypotl (long double __x, long double __y) throw ();




extern long double cbrtl (long double __x) throw (); extern long double __cbrtl (long double __x) throw ();






extern long double ceill (long double __x) throw (); extern long double __ceill (long double __x) throw ();


extern long double fabsl (long double __x) throw () __attribute__ ((__const__)); extern long double __fabsl (long double __x) throw () __attribute__ ((__const__));


extern long double floorl (long double __x) throw (); extern long double __floorl (long double __x) throw ();


extern long double fmodl (long double __x, long double __y) throw (); extern long double __fmodl (long double __x, long double __y) throw ();




extern int __isinfl (long double __value) throw () __attribute__ ((__const__));


extern int __finitel (long double __value) throw () __attribute__ ((__const__));




extern int isinfl (long double __value) throw () __attribute__ ((__const__));


extern int finitel (long double __value) throw () __attribute__ ((__const__));


extern long double dreml (long double __x, long double __y) throw (); extern long double __dreml (long double __x, long double __y) throw ();



extern long double significandl (long double __x) throw (); extern long double __significandl (long double __x) throw ();




extern long double copysignl (long double __x, long double __y) throw () __attribute__ ((__const__)); extern long double __copysignl (long double __x, long double __y) throw () __attribute__ ((__const__));




extern long double nanl (__const char *__tagb) throw () __attribute__ ((__const__)); extern long double __nanl (__const char *__tagb) throw () __attribute__ ((__const__));




extern int __isnanl (long double __value) throw () __attribute__ ((__const__));



extern int isnanl (long double __value) throw () __attribute__ ((__const__));


extern long double j0l (long double) throw (); extern long double __j0l (long double) throw ();
extern long double j1l (long double) throw (); extern long double __j1l (long double) throw ();
extern long double jnl (int, long double) throw (); extern long double __jnl (int, long double) throw ();
extern long double y0l (long double) throw (); extern long double __y0l (long double) throw ();
extern long double y1l (long double) throw (); extern long double __y1l (long double) throw ();
extern long double ynl (int, long double) throw (); extern long double __ynl (int, long double) throw ();





extern long double erfl (long double) throw (); extern long double __erfl (long double) throw ();
extern long double erfcl (long double) throw (); extern long double __erfcl (long double) throw ();
extern long double lgammal (long double) throw (); extern long double __lgammal (long double) throw ();



extern long double tgammal (long double) throw (); extern long double __tgammal (long double) throw ();




extern long double gammal (long double) throw (); extern long double __gammal (long double) throw ();






extern long double lgammal_r (long double, int *__signgamp) throw (); extern long double __lgammal_r (long double, int *__signgamp) throw ();






extern long double rintl (long double __x) throw (); extern long double __rintl (long double __x) throw ();


extern long double nextafterl (long double __x, long double __y) throw () __attribute__ ((__const__)); extern long double __nextafterl (long double __x, long double __y) throw () __attribute__ ((__const__));

extern long double nexttowardl (long double __x, long double __y) throw () __attribute__ ((__const__)); extern long double __nexttowardl (long double __x, long double __y) throw () __attribute__ ((__const__));



extern long double remainderl (long double __x, long double __y) throw (); extern long double __remainderl (long double __x, long double __y) throw ();



extern long double scalbl (long double __x, long double __n) throw (); extern long double __scalbl (long double __x, long double __n) throw ();




extern long double scalbnl (long double __x, int __n) throw (); extern long double __scalbnl (long double __x, int __n) throw ();



extern int ilogbl (long double __x) throw (); extern int __ilogbl (long double __x) throw ();




extern long double scalblnl (long double __x, long int __n) throw (); extern long double __scalblnl (long double __x, long int __n) throw ();



extern long double nearbyintl (long double __x) throw (); extern long double __nearbyintl (long double __x) throw ();



extern long double roundl (long double __x) throw (); extern long double __roundl (long double __x) throw ();



extern long double truncl (long double __x) throw () __attribute__ ((__const__)); extern long double __truncl (long double __x) throw () __attribute__ ((__const__));




extern long double remquol (long double __x, long double __y, int *__quo) throw (); extern long double __remquol (long double __x, long double __y, int *__quo) throw ();






extern long int lrintl (long double __x) throw (); extern long int __lrintl (long double __x) throw ();
extern long long int llrintl (long double __x) throw (); extern long long int __llrintl (long double __x) throw ();



extern long int lroundl (long double __x) throw (); extern long int __lroundl (long double __x) throw ();
extern long long int llroundl (long double __x) throw (); extern long long int __llroundl (long double __x) throw ();



extern long double fdiml (long double __x, long double __y) throw (); extern long double __fdiml (long double __x, long double __y) throw ();


extern long double fmaxl (long double __x, long double __y) throw (); extern long double __fmaxl (long double __x, long double __y) throw ();


extern long double fminl (long double __x, long double __y) throw (); extern long double __fminl (long double __x, long double __y) throw ();



extern int __fpclassifyl (long double __value) throw ()
     __attribute__ ((__const__));


extern int __signbitl (long double __value) throw ()
     __attribute__ ((__const__));



extern long double fmal (long double __x, long double __y, long double __z) throw (); extern long double __fmal (long double __x, long double __y, long double __z) throw ();
# 100 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 2 3
# 113 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
extern int signgam;
# 154 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
enum
  {
    FP_NAN,

    FP_INFINITE,

    FP_ZERO,

    FP_SUBNORMAL,

    FP_NORMAL

  };
# 240 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
typedef enum
{
  _IEEE_ = -1,
  _SVID_,
  _XOPEN_,
  _POSIX_,
  _ISOC_
} _LIB_VERSION_TYPE;




extern _LIB_VERSION_TYPE _LIB_VERSION;
# 263 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
struct __exception



  {
    int type;
    char *name;
    double arg1;
    double arg2;
    double retval;
  };


extern int matherr (struct __exception *__exc) throw ();
# 411 "/usr/lib/gcc/../../i686-inX-linux/include/math.h" 3
}
# 52 "/usr/include/c++3.1/cmath" 2 3
# 79 "/usr/include/c++3.1/cmath" 3
namespace std
{


  template<typename _Tp> _Tp __cmath_power(_Tp, unsigned int);

  template<typename _Tp>
  inline _Tp
    __cmath_abs(_Tp __x)
    {
      return __x < _Tp() ? -__x : __x;
    }

  inline double
  abs(double __x)
  { return __builtin_fabs(__x); }

  inline float
  abs(float __x)
  { return __builtin_fabsf(__x); }

  inline long double
  abs(long double __x)
  { return __builtin_fabsl(__x); }


  inline float
  acos(float __x) { return ::acosf(__x); }





  using ::acos;


  inline long double
  acos(long double __x) { return ::acosl(__x); }





  using ::asin;


  inline float
  asin(float __x) { return ::asinf(__x); }






  inline long double
  asin(long double __x) { return ::asinl(__x); }





  using ::atan;


  inline float
  atan(float __x) { return ::atanf(__x); }






  inline long double
  atan(long double __x) { return ::atanl(__x); }





  using ::atan2;


  inline float
  atan2(float __y, float __x) { return ::atan2f(__y, __x); }







  inline long double
  atan2(long double __y, long double __x) { return ::atan2l(__y, __x); }






  using ::ceil;


  inline float
  ceil(float __x) { return ::ceilf(__x); }






  inline long double
  ceil(long double __x) { return ::ceill(__x); }





  using ::cos;

  inline float
  cos(float __x)
  { return __builtin_cosf(__x); }

  inline long double
  cos(long double __x)
  { return __builtin_cosl(__x); }

  using ::cosh;


  inline float
  cosh(float __x) { return ::coshf(__x); }






  inline long double
  cosh(long double __x) { return ::coshl(__x); }





  using ::exp;


  inline float
  exp(float __x) { return ::expf(__x); }






  inline long double
  exp(long double __x) { return ::expl(__x); }





  using ::fabs;

  inline float
  fabs(float __x)
  { return __builtin_fabsf(__x); }

  inline long double
  fabs(long double __x)
  { return __builtin_fabsl(__x); }

  using ::floor;


  inline float
  floor(float __x) { return ::floorf(__x); }






  inline long double
  floor(long double __x) { return ::floorl(__x); }





  using ::fmod;


  inline float
  fmod(float __x, float __y) { return ::fmodf(__x, __y); }







  inline long double
  fmod(long double __x, long double __y) { return ::fmodl(__x, __y); }






  using ::frexp;


  inline float
  frexp(float __x, int* __exp) { return ::frexpf(__x, __exp); }






  inline long double
  frexp(long double __x, int* __exp) { return ::frexpl(__x, __exp); }






  using ::ldexp;


  inline float
  ldexp(float __x, int __exp) { return ::ldexpf(__x, __exp); }







  inline long double
  ldexp(long double __x, int __exp) { return ::ldexpl(__x, __exp); }






  using ::log;


  inline float
  log(float __x) { return ::logf(__x); }






  inline long double
  log(long double __x) { return ::logl(__x); }





  using ::log10;


  inline float
  log10(float __x) { return ::log10f(__x); }






  inline long double
  log10(long double __x) { return ::log10l(__x); }





  using ::modf;


  inline float
  modf(float __x, float* __iptr) { return ::modff(__x, __iptr); }
# 382 "/usr/include/c++3.1/cmath" 3
  inline long double
  modf(long double __x, long double* __iptr) { return ::modfl(__x, __iptr); }
# 395 "/usr/include/c++3.1/cmath" 3
  template<typename _Tp>
    inline _Tp
    __pow_helper(_Tp __x, int __n)
    {
      return __n < 0
        ? _Tp(1)/__cmath_power(__x, -__n)
        : __cmath_power(__x, __n);
    }

  using ::pow;


  inline float
  pow(float __x, float __y) { return ::powf(__x, __y); }







  inline long double
  pow(long double __x, long double __y) { return ::powl(__x, __y); }






  inline double
  pow(double __x, int __i)
  { return __pow_helper(__x, __i); }

  inline float
  pow(float __x, int __n)
  { return __pow_helper(__x, __n); }

  inline long double
  pow(long double __x, int __n)
  { return __pow_helper(__x, __n); }

  using ::sin;

  inline float
  sin(float __x)
  { return __builtin_sinf(__x); }

  inline long double
  sin(long double __x)
  { return __builtin_sinl(__x); }

  using ::sinh;


  inline float
  sinh(float __x) { return ::sinhf(__x); }






  inline long double
  sinh(long double __x) { return ::sinhl(__x); }





  using ::sqrt;

  inline float
  sqrt(float __x)
  { return __builtin_sqrtf(__x); }

  inline long double
  sqrt(long double __x)
  { return __builtin_sqrtl(__x); }

  using ::tan;


  inline float
  tan(float __x) { return ::tanf(__x); }






  inline long double
  tan(long double __x) { return ::tanl(__x); }





  using ::tanh;


  inline float
  tanh(float __x) { return ::tanhf(__x); }






  inline long double
  tanh(long double __x) { return ::tanhl(__x); }




}






namespace __gnu_cxx
{
  template<typename _Tp>
    int
    __capture_fpclassify(_Tp __f) { return (sizeof (__f) == sizeof (float) ? __fpclassifyf (__f) : sizeof (__f) == sizeof (double) ? __fpclassify (__f) : __fpclassifyl (__f)); }

  template<typename _Tp>
    int
    __capture_isfinite(_Tp __f) { return (sizeof (__f) == sizeof (float) ? __finitef (__f) : sizeof (__f) == sizeof (double) ? __finite (__f) : __finitel (__f)); }

  template<typename _Tp>
    int
    __capture_isinf(_Tp __f) { return (sizeof (__f) == sizeof (float) ? __isinff (__f) : sizeof (__f) == sizeof (double) ? __isinf (__f) : __isinfl (__f)); }

  template<typename _Tp>
    int
    __capture_isnan(_Tp __f) { return (sizeof (__f) == sizeof (float) ? __isnanf (__f) : sizeof (__f) == sizeof (double) ? __isnan (__f) : __isnanl (__f)); }

  template<typename _Tp>
    int
    __capture_isnormal(_Tp __f) { return ((sizeof (__f) == sizeof (float) ? __fpclassifyf (__f) : sizeof (__f) == sizeof (double) ? __fpclassify (__f) : __fpclassifyl (__f)) == FP_NORMAL); }

  template<typename _Tp>
    int
    __capture_signbit(_Tp __f) { return (sizeof (__f) == sizeof (float) ? __signbitf (__f) : sizeof (__f) == sizeof (double) ? __signbit (__f) : __signbitl (__f)); }

  template<typename _Tp>
    int
    __capture_isgreater(_Tp __f1, _Tp __f2)
    { return (__extension__ ({ __typeof__(__f1) __x = (__f1); __typeof__(__f2) __y = (__f2); !(__extension__ ({ __typeof__(__x) __u = (__x); __typeof__(__y) __v = (__y); (sizeof (__u) == sizeof (float) ? __fpclassifyf (__u) : sizeof (__u) == sizeof (double) ? __fpclassify (__u) : __fpclassifyl (__u)) == FP_NAN || (sizeof (__v) == sizeof (float) ? __fpclassifyf (__v) : sizeof (__v) == sizeof (double) ? __fpclassify (__v) : __fpclassifyl (__v)) == FP_NAN; })) && __x > __y; })); }

  template<typename _Tp>
     int
     __capture_isgreaterequal(_Tp __f1, _Tp __f2)
     { return (__extension__ ({ __typeof__(__f1) __x = (__f1); __typeof__(__f2) __y = (__f2); !(__extension__ ({ __typeof__(__x) __u = (__x); __typeof__(__y) __v = (__y); (sizeof (__u) == sizeof (float) ? __fpclassifyf (__u) : sizeof (__u) == sizeof (double) ? __fpclassify (__u) : __fpclassifyl (__u)) == FP_NAN || (sizeof (__v) == sizeof (float) ? __fpclassifyf (__v) : sizeof (__v) == sizeof (double) ? __fpclassify (__v) : __fpclassifyl (__v)) == FP_NAN; })) && __x >= __y; })); }

  template<typename _Tp>
     int
     __capture_isless(_Tp __f1, _Tp __f2) { return (__extension__ ({ __typeof__(__f1) __x = (__f1); __typeof__(__f2) __y = (__f2); !(__extension__ ({ __typeof__(__x) __u = (__x); __typeof__(__y) __v = (__y); (sizeof (__u) == sizeof (float) ? __fpclassifyf (__u) : sizeof (__u) == sizeof (double) ? __fpclassify (__u) : __fpclassifyl (__u)) == FP_NAN || (sizeof (__v) == sizeof (float) ? __fpclassifyf (__v) : sizeof (__v) == sizeof (double) ? __fpclassify (__v) : __fpclassifyl (__v)) == FP_NAN; })) && __x < __y; })); }

  template<typename _Tp>
     int
     __capture_islessequal(_Tp __f1, _Tp __f2)
     { return (__extension__ ({ __typeof__(__f1) __x = (__f1); __typeof__(__f2) __y = (__f2); !(__extension__ ({ __typeof__(__x) __u = (__x); __typeof__(__y) __v = (__y); (sizeof (__u) == sizeof (float) ? __fpclassifyf (__u) : sizeof (__u) == sizeof (double) ? __fpclassify (__u) : __fpclassifyl (__u)) == FP_NAN || (sizeof (__v) == sizeof (float) ? __fpclassifyf (__v) : sizeof (__v) == sizeof (double) ? __fpclassify (__v) : __fpclassifyl (__v)) == FP_NAN; })) && __x <= __y; })); }

  template<typename _Tp>
     int
     __capture_islessgreater(_Tp __f1, _Tp __f2)
     { return (__extension__ ({ __typeof__(__f1) __x = (__f1); __typeof__(__f2) __y = (__f2); !(__extension__ ({ __typeof__(__x) __u = (__x); __typeof__(__y) __v = (__y); (sizeof (__u) == sizeof (float) ? __fpclassifyf (__u) : sizeof (__u) == sizeof (double) ? __fpclassify (__u) : __fpclassifyl (__u)) == FP_NAN || (sizeof (__v) == sizeof (float) ? __fpclassifyf (__v) : sizeof (__v) == sizeof (double) ? __fpclassify (__v) : __fpclassifyl (__v)) == FP_NAN; })) && (__x < __y || __y < __x); })); }

  template<typename _Tp>
     int
     __capture_isunordered(_Tp __f1, _Tp __f2)
     { return (__extension__ ({ __typeof__(__f1) __u = (__f1); __typeof__(__f2) __v = (__f2); (sizeof (__u) == sizeof (float) ? __fpclassifyf (__u) : sizeof (__u) == sizeof (double) ? __fpclassify (__u) : __fpclassifyl (__u)) == FP_NAN || (sizeof (__v) == sizeof (float) ? __fpclassifyf (__v) : sizeof (__v) == sizeof (double) ? __fpclassify (__v) : __fpclassifyl (__v)) == FP_NAN; })); }
}
# 587 "/usr/include/c++3.1/cmath" 3
namespace __gnu_cxx
{
  template<typename _Tp>
    int
    fpclassify(_Tp __f) { return __capture_fpclassify(__f); }

  template<typename _Tp>
    int
    isfinite(_Tp __f) { return __capture_isfinite(__f); }

  template<typename _Tp>
    int
    isinf(_Tp __f) { return __capture_isinf(__f); }

  template<typename _Tp>
    int
    isnan(_Tp __f) { return __capture_isnan(__f); }

  template<typename _Tp>
    int
    isnormal(_Tp __f) { return __capture_isnormal(__f); }

  template<typename _Tp>
    int
    signbit(_Tp __f) { return __capture_signbit(__f); }

  template<typename _Tp>
    int
    isgreater(_Tp __f1, _Tp __f2) { return __capture_isgreater(__f1, __f2); }

  template<typename _Tp>
    int
    isgreaterequal(_Tp __f1, _Tp __f2)
    { return __capture_isgreaterequal(__f1, __f2); }

  template<typename _Tp>
    int
    isless(_Tp __f1, _Tp __f2) { return __capture_isless(__f1, __f2); }

  template<typename _Tp>
    int
    islessequal(_Tp __f1, _Tp __f2)
    { return __capture_islessequal(__f1, __f2); }

  template<typename _Tp>
    int
    islessgreater(_Tp __f1, _Tp __f2)
    { return __capture_islessgreater(__f1, __f2); }

  template<typename _Tp>
    int
    isunordered(_Tp __f1, _Tp __f2)
    { return __capture_isunordered(__f1, __f2); }
}

namespace std
{
  using __gnu_cxx::fpclassify;
  using __gnu_cxx::isfinite;
  using __gnu_cxx::isinf;
  using __gnu_cxx::isnan;
  using __gnu_cxx::isnormal;
  using __gnu_cxx::signbit;
  using __gnu_cxx::isgreater;
  using __gnu_cxx::isgreaterequal;
  using __gnu_cxx::isless;
  using __gnu_cxx::islessequal;
  using __gnu_cxx::islessgreater;
  using __gnu_cxx::isunordered;
}




# 1 "/usr/include/c++3.1/bits/cmath.tcc" 1 3
# 35 "/usr/include/c++3.1/bits/cmath.tcc" 3
namespace std
{
  template<typename _Tp>
    _Tp
    __cmath_power(_Tp __x, unsigned int __n)
    {
      _Tp __y = __n % 2 ? __x : 1;

      while (__n >>= 1)
        {
          __x = __x * __x;
          if (__n % 2)
            __y = __y * __x;
        }

      return __y;
    }
}
# 662 "/usr/include/c++3.1/cmath" 2 3
# 42 "/usr/include/c++3.1/bits/locale_facets.tcc" 2 3

# 1 "/usr/include/c++3.1/limits" 1 3
# 47 "/usr/include/c++3.1/limits" 3

# 1 "/usr/include/c++3.1/i686-inX-linux/bits/cpu_limits.h" 1 3
# 49 "/usr/include/c++3.1/limits" 2 3
# 887 "/usr/include/c++3.1/limits" 3
namespace std
{
  enum float_round_style
  {
    round_indeterminate = -1,
    round_toward_zero = 0,
    round_to_nearest = 1,
    round_toward_infinity = 2,
    round_toward_neg_infinity = 3
  };

  enum float_denorm_style
  {
    denorm_indeterminate = -1,
    denorm_absent = 0,
    denorm_present = 1
  };




  struct __numeric_limits_base
  {
    static const bool is_specialized = false;

    static const int digits = 0;
    static const int digits10 = 0;
    static const bool is_signed = false;
    static const bool is_integer = false;
    static const bool is_exact = false;
    static const int radix = 0;

    static const int min_exponent = 0;
    static const int min_exponent10 = 0;
    static const int max_exponent = 0;
    static const int max_exponent10 = 0;

    static const bool has_infinity = false;
    static const bool has_quiet_NaN = false;
    static const bool has_signaling_NaN = false;
    static const float_denorm_style has_denorm = denorm_absent;
    static const bool has_denorm_loss = false;

    static const bool is_iec559 = false;
    static const bool is_bounded = false;
    static const bool is_modulo = false;

    static const bool traps = false;
    static const bool tinyness_before = false;
    static const float_round_style round_style = round_toward_zero;
  };

  template<typename _Tp>
    struct numeric_limits : public __numeric_limits_base
    {
      static _Tp min() throw() { return static_cast<_Tp>(0); }
      static _Tp max() throw() { return static_cast<_Tp>(0); }
      static _Tp epsilon() throw() { return static_cast<_Tp>(0); }
      static _Tp round_error() throw() { return static_cast<_Tp>(0); }
      static _Tp infinity() throw() { return static_cast<_Tp>(0); }
      static _Tp quiet_NaN() throw() { return static_cast<_Tp>(0); }
      static _Tp signaling_NaN() throw() { return static_cast<_Tp>(0); }
      static _Tp denorm_min() throw() { return static_cast<_Tp>(0); }
    };



  template<>
    struct numeric_limits<bool>
    {
      static const bool is_specialized = true;

      static bool min() throw()
      { return false; }

      static bool max() throw()
      { return true; }

      static const int digits = 1;
      static const int digits10 = 0;
      static const bool is_signed = false;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static bool epsilon() throw()
      { return false; }
      static bool round_error() throw()
      { return false; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static bool infinity() throw()
      { return false; }
      static bool quiet_NaN() throw()
      { return false; }
      static bool signaling_NaN() throw()
      { return false; }
      static bool denorm_min() throw()
      { return false; }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = false;




      static const bool traps = true
               || true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };



  template<>
    struct numeric_limits<char>
    {
      static const bool is_specialized = true;

      static char min() throw()
      { return (char)(-127 - 1); }
      static char max() throw()
      { return (char)127; }

      static const int digits = 7;
      static const int digits10 = 7;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static char epsilon() throw()
      { return char(); }
      static char round_error() throw()
      { return char(); }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static char infinity() throw()
      { return char(); }
      static char quiet_NaN() throw()
      { return char(); }
      static char signaling_NaN() throw()
      { return char(); }
      static char denorm_min() throw()
      { return static_cast<char>(0); }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1071 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<signed char>
    {
      static const bool is_specialized = true;

      static signed char min() throw()
      { return (-127 - 1); }
      static signed char max() throw()
      { return 127; }

      static const int digits = 7;
      static const int digits10 = 2;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static signed char epsilon() throw()
      { return 0; }
      static signed char round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static signed char infinity() throw()
      { return static_cast<signed char>(0); }
      static signed char quiet_NaN() throw()
      { return static_cast<signed char>(0); }
      static signed char signaling_NaN() throw()
      { return static_cast<signed char>(0); }
      static signed char denorm_min() throw()
      { return static_cast<signed char>(0); }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1128 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<unsigned char>
    {
      static const bool is_specialized = true;

      static unsigned char min() throw()
      { return 0; }
      static unsigned char max() throw()
      { return (127 * 2 + 1); }

      static const int digits = 8;
      static const int digits10 = 2;
      static const bool is_signed = false;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static unsigned char epsilon() throw()
      { return 0; }
      static unsigned char round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static unsigned char infinity() throw()
      { return static_cast<unsigned char>(0); }
      static unsigned char quiet_NaN() throw()
      { return static_cast<unsigned char>(0); }
      static unsigned char signaling_NaN() throw()
      { return static_cast<unsigned char>(0); }
      static unsigned char denorm_min() throw()
      { return static_cast<unsigned char>(0); }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };






  template<>
    struct numeric_limits<wchar_t>
    {
      static const bool is_specialized = true;

      static wchar_t min() throw()
      { return (wchar_t)(-2147483647L - 1); }
      static wchar_t max() throw()
      { return (wchar_t)2147483647L; }

      static const int digits = 31;
      static const int digits10 = 9;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static wchar_t epsilon() throw()
      { return 0; }
      static wchar_t round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static wchar_t infinity() throw()
      { return wchar_t(); }
      static wchar_t quiet_NaN() throw()
      { return wchar_t(); }
      static wchar_t signaling_NaN() throw()
      { return wchar_t(); }
      static wchar_t denorm_min() throw()
      { return wchar_t(); }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1241 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<short>
    {
      static const bool is_specialized = true;

      static short min() throw()
      { return (-32767 - 1); }
      static short max() throw()
      { return 32767; }

      static const int digits = 15;
      static const int digits10 = 4;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static short epsilon() throw()
      { return 0; }
      static short round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static short infinity() throw()
      { return short(); }
      static short quiet_NaN() throw()
      { return short(); }
      static short signaling_NaN() throw()
      { return short(); }
      static short denorm_min() throw()
      { return short(); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1298 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<unsigned short>
    {
      static const bool is_specialized = true;

      static unsigned short min() throw()
      { return 0; }
      static unsigned short max() throw()
      { return (32767 * 2 + 1); }

      static const int digits = 16;
      static const int digits10 = 4;
      static const bool is_signed = false;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static unsigned short epsilon() throw()
      { return 0; }
      static unsigned short round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static unsigned short infinity() throw()
      { return static_cast<unsigned short>(0); }
      static unsigned short quiet_NaN() throw()
      { return static_cast<unsigned short>(0); }
      static unsigned short signaling_NaN() throw()
      { return static_cast<unsigned short>(0); }
      static unsigned short denorm_min() throw()
      { return static_cast<unsigned short>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };






  template<>
    struct numeric_limits<int>
    {
      static const bool is_specialized = true;

      static int min() throw()
      { return (int)(-2147483647L - 1); }
      static int max() throw()
      { return (int)2147483647L; }

      static const int digits = 31;
      static const int digits10 = 9;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static int epsilon() throw()
      { return 0; }
      static int round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static int infinity() throw()
      { return static_cast<int>(0); }
      static int quiet_NaN() throw()
      { return static_cast<int>(0); }
      static int signaling_NaN() throw()
      { return static_cast<int>(0); }
      static int denorm_min() throw()
      { return static_cast<int>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1410 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<unsigned int>
    {
      static const bool is_specialized = true;

      static unsigned int min() throw()
      { return 0; }
          static unsigned int max() throw()
      { return (unsigned)(2147483647L * 2U + 1); }

      static const int digits = 32;
      static const int digits10 = 9;
      static const bool is_signed = false;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static unsigned int epsilon() throw()
      { return 0; }
      static unsigned int round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static unsigned int infinity() throw()
      { return static_cast<unsigned int>(0); }
      static unsigned int quiet_NaN() throw()
      { return static_cast<unsigned int>(0); }
      static unsigned int signaling_NaN() throw()
      { return static_cast<unsigned int>(0); }
      static unsigned int denorm_min() throw()
      { return static_cast<unsigned int>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };






  template<>
    struct numeric_limits<long>
    {
      static const bool is_specialized = true;

      static long min() throw()
      { return (-2147483647L - 1); }
      static long max() throw()
      { return 2147483647L; }

      static const int digits = 31;
      static const int digits10 = 9;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static long epsilon() throw()
      { return 0; }
      static long round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static long infinity() throw()
      { return static_cast<long>(0); }
      static long quiet_NaN() throw()
      { return static_cast<long>(0); }
      static long signaling_NaN() throw()
      { return static_cast<long>(0); }
      static long denorm_min() throw()
      { return static_cast<long>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1522 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<unsigned long>
    {
      static const bool is_specialized = true;

      static unsigned long min() throw()
      { return 0; }
      static unsigned long max() throw()
      { return (2147483647L * 2U + 1); }

      static const int digits = 32;
      static const int digits10 = 9;
      static const bool is_signed = false;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static unsigned long epsilon() throw()
      { return 0; }
      static unsigned long round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static unsigned long infinity() throw()
      { return static_cast<unsigned long>(0); }
      static unsigned long quiet_NaN() throw()
      { return static_cast<unsigned long>(0); }
      static unsigned long signaling_NaN() throw()
      { return static_cast<unsigned long>(0); }
      static unsigned long denorm_min() throw()
      { return static_cast<unsigned long>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };






  template<>
    struct numeric_limits<long long>
    {
      static const bool is_specialized = true;

      static long long min() throw()
      { return (-9223372036854775807LL - 1); }
      static long long max() throw()
      { return 9223372036854775807LL; }

      static const int digits = 63;
      static const int digits10 = 18;
      static const bool is_signed = true;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static long long epsilon() throw()
      { return 0; }
      static long long round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static long long infinity() throw()
      { return static_cast<long long>(0); }
      static long long quiet_NaN() throw()
      { return static_cast<long long>(0); }
      static long long signaling_NaN() throw()
      { return static_cast<long long>(0); }
      static long long denorm_min() throw()
      { return static_cast<long long>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1634 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<unsigned long long>
    {
      static const bool is_specialized = true;

      static unsigned long long min() throw()
      { return 0; }
      static unsigned long long max() throw()
      { return (9223372036854775807LL * 2ULL + 1); }

      static const int digits = 64;
      static const int digits10 = 19;
      static const bool is_signed = false;
      static const bool is_integer = true;
      static const bool is_exact = true;
      static const int radix = 2;
      static unsigned long long epsilon() throw()
      { return 0; }
      static unsigned long long round_error() throw()
      { return 0; }

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static unsigned long long infinity() throw()
      { return static_cast<unsigned long long>(0); }
      static unsigned long long quiet_NaN() throw()
      { return static_cast<unsigned long long>(0); }
      static unsigned long long signaling_NaN() throw()
      { return static_cast<unsigned long long>(0); }
      static unsigned long long denorm_min() throw()
      { return static_cast<unsigned long long>(0); }

      static const bool is_iec559 = true;
      static const bool is_bounded = true;
      static const bool is_modulo = true;

      static const bool traps = true;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };






  template<>
    struct numeric_limits<float>
    {
      static const bool is_specialized = true;

      static float min() throw()
      { return 1.17549435e-38F; }
      static float max() throw()
      { return 3.40282347e+38F; }

      static const int digits = 24;
      static const int digits10 = 6;
      static const bool is_signed = true;
      static const bool is_integer = false;
      static const bool is_exact = false;
      static const int radix = 2;
      static float epsilon() throw()
      { return 1.19209290e-07F; }
      static float round_error() throw()
      { return 1.0F; }

      static const int min_exponent = -125;
      static const int min_exponent10 = -37;
      static const int max_exponent = 128;
      static const int max_exponent10 = 38;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;

      static float infinity() throw()
      { return 0.0F; }
      static float quiet_NaN() throw()
      { return 0.0F; }
      static float signaling_NaN() throw()
      { return 0.0F; }
      static float denorm_min() throw()
      { return 0.0F; }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = false;

      static const bool traps = false;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
    };
# 1765 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<double>
    {
      static const bool is_specialized = true;

      static double min() throw()
      { return 2.2250738585072014e-308; }
      static double max() throw()
      { return 1.7976931348623157e+308; }

      static const int digits = 53;
      static const int digits10 = 15;
      static const bool is_signed = true;
      static const bool is_integer = false;
      static const bool is_exact = false;
      static const int radix = 2;
      static double epsilon() throw()
      { return 2.2204460492503131e-16; }
      static double round_error() throw()
      { return 1.0; }

      static const int min_exponent = -1021;
      static const int min_exponent10 = -307;
      static const int max_exponent = 1024;
      static const int max_exponent10 = 308;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm =
              denorm_absent;
      static const bool has_denorm_loss = false;

      static double infinity() throw()
      { return 0.0; }
      static double quiet_NaN() throw()
      { return 0.0; }
      static double signaling_NaN() throw()
      { return 0.0; }
      static double denorm_min() throw()
      { return 0.0; }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = false;

      static const bool traps = false;
      static const bool tinyness_before = false;
      static const float_round_style round_style =
              round_toward_zero;
    };
# 1844 "/usr/include/c++3.1/limits" 3
  template<>
    struct numeric_limits<long double>
    {
      static const bool is_specialized = true;

      static long double min() throw()
      { return 3.36210314311209350626e-4932L; }
      static long double max() throw()
      { return 1.18973149535723176502e+4932L; }

      static const int digits = 64;
      static const int digits10 = 18;
      static const bool is_signed = true;
      static const bool is_integer = false;
      static const bool is_exact = false;
      static const int radix = 2;
      static long double epsilon() throw()
      { return 1.08420217248550443401e-19L; }
      static long double round_error() throw()
      { return 1.0L; }

      static const int min_exponent = -16381;
      static const int min_exponent10 = -4931;
      static const int max_exponent = 16384;
      static const int max_exponent10 = 4932;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN =
                false;
      static const float_denorm_style has_denorm =
                denorm_absent;
      static const bool has_denorm_loss =
                false;

      static long double infinity() throw()
      { return 0.0L; }
      static long double quiet_NaN() throw()
      { return 0.0L; }
      static long double signaling_NaN() throw()
      { return 0.0L; }
      static long double denorm_min() throw()
      { return 0.0L; }

      static const bool is_iec559 = false;
      static const bool is_bounded = true;
      static const bool is_modulo = false;

      static const bool traps = false;
      static const bool tinyness_before = false;
      static const float_round_style round_style =
        round_toward_zero;
    };
# 1924 "/usr/include/c++3.1/limits" 3
}
# 44 "/usr/include/c++3.1/bits/locale_facets.tcc" 2 3

# 1 "/usr/include/c++3.1/typeinfo" 1 3
# 40 "/usr/include/c++3.1/typeinfo" 3
extern "C++" {

namespace __cxxabiv1
{
  class __class_type_info;
}
# 55 "/usr/include/c++3.1/typeinfo" 3
namespace std
{



  class type_info
  {
  public:




    virtual ~type_info();

  private:

    type_info& operator=(const type_info&);
    type_info(const type_info&);

  protected:
    const char *__name;

  protected:
    explicit type_info(const char *__n): __name(__n) { }

  public:



    const char* name() const
    { return __name; }
# 98 "/usr/include/c++3.1/typeinfo" 3
    bool before(const type_info& __arg) const
    { return __name < __arg.__name; }
    bool operator==(const type_info& __arg) const
    { return __name == __arg.__name; }

    bool operator!=(const type_info& __arg) const
    { return !operator==(__arg); }


  public:

    virtual bool __is_pointer_p() const;

    virtual bool __is_function_p() const;







    virtual bool __do_catch(const type_info *__thr_type, void **__thr_obj,
                            unsigned __outer) const;


    virtual bool __do_upcast(const __cxxabiv1::__class_type_info *__target,
                             void **__obj_ptr) const;
  };



  class bad_cast : public exception
  {
  public:
    bad_cast() throw() { }


    virtual ~bad_cast() throw();
  };


  class bad_typeid : public exception
  {
  public:
    bad_typeid () throw() { }


    virtual ~bad_typeid() throw();
  };
}

}
# 46 "/usr/include/c++3.1/bits/locale_facets.tcc" 2 3

namespace std
{
  template<typename _Facet>
    locale
    locale::combine(const locale& __other) const
    {
      _Impl* __tmp = new _Impl(*_M_impl, 1);
      __tmp->_M_replace_facet(__other._M_impl, &_Facet::id);
      return locale(__tmp);
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    bool
    locale::operator()(const basic_string<_CharT, _Traits, _Alloc>& __s1,
                       const basic_string<_CharT, _Traits, _Alloc>& __s2) const
    {
      typedef std::collate<_CharT> __collate_type;
      const __collate_type& __collate = use_facet<__collate_type>(*this);
      return (__collate.compare(__s1.data(), __s1.data() + __s1.length(),
                                __s2.data(), __s2.data() + __s2.length()) < 0);
    }

  template<typename _Facet>
    const _Facet&
    use_facet(const locale& __loc)
    {
      size_t __i = _Facet::id._M_id();
      locale::facet** __facets = __loc._M_impl->_M_facets;
      if (!(__i < __loc._M_impl->_M_facets_size && __facets[__i]))
        __throw_bad_cast();
      return static_cast<const _Facet&>(*__facets[__i]);
    }

  template<typename _Facet>
    bool
    has_facet(const locale& __loc) throw()
    {
      size_t __i = _Facet::id._M_id();
      locale::facet** __facets = __loc._M_impl->_M_facets;
      return (__i < __loc._M_impl->_M_facets_size && __facets[__i]);
    }



  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    _M_extract_float(_InIter __beg, _InIter __end, ios_base& __io,
                     ios_base::iostate& __err, string& __xtrc) const
    {
      const locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
      const numpunct<_CharT>& __np = use_facet<numpunct<_CharT> >(__loc);


      const char_type __plus = __ctype.widen('+');
      const char_type __minus = __ctype.widen('-');
      int __pos = 0;
      char_type __c = *__beg;
      if ((__c == __plus || __c == __minus) && __beg != __end)
        {
          __xtrc += __ctype.narrow(__c, char());
          ++__pos;
          __c = *(++__beg);
        }


      const char_type __zero = __ctype.widen(_S_atoms[_M_zero]);
      bool __found_zero = false;
      while (__c == __zero && __beg != __end)
        {
          __c = *(++__beg);
          __found_zero = true;
        }
      if (__found_zero)
        {
          __xtrc += _S_atoms[_M_zero];
          ++__pos;
        }


      const size_t __len = _M_E - _M_zero + 1;
      char_type __watoms[__len];
      __ctype.widen(_S_atoms, _S_atoms + __len, __watoms);
      bool __found_dec = false;
      bool __found_sci = false;
      const char_type __dec = __np.decimal_point();

      string __found_grouping;
      const string __grouping = __np.grouping();
      bool __check_grouping = __grouping.size();
      int __sep_pos = 0;
      const char_type __sep = __np.thousands_sep();

      while (__beg != __end)
        {

          typedef char_traits<_CharT> __traits_type;
          const char_type* __p = __traits_type::find(__watoms, 10, __c);


          if (__p && __c)
            {

              ++__pos;
              __xtrc += _S_atoms[__p - __watoms];
              ++__sep_pos;
              __c = *(++__beg);
            }
          else if (__c == __sep && __check_grouping && !__found_dec)
            {


              if (__sep_pos)
                {
                  __found_grouping += static_cast<char>(__sep_pos);
                  __sep_pos = 0;
                  __c = *(++__beg);
                }
              else
                {
                  __err |= ios_base::failbit;
                  break;
                }
            }
          else if (__c == __dec && !__found_dec)
            {



              if (__found_grouping.size())
                __found_grouping += static_cast<char>(__sep_pos);
              ++__pos;
              __xtrc += '.';
              __c = *(++__beg);
              __found_dec = true;
            }
          else if ((__c == __watoms[_M_e] || __c == __watoms[_M_E])
                   && !__found_sci && __pos)
            {

              ++__pos;
              __xtrc += __ctype.narrow(__c, char());
              __c = *(++__beg);


              if (__c == __plus || __c == __minus)
                {
                  ++__pos;
                  __xtrc += __ctype.narrow(__c, char());
                  __c = *(++__beg);
                }
              __found_sci = true;
            }
          else

            break;
        }



      if (__check_grouping && __found_grouping.size())
        {

          if (!__found_dec)
            __found_grouping += static_cast<char>(__sep_pos);
          if (!__verify_grouping(__grouping, __found_grouping))
            __err |= ios_base::failbit;
        }


      __xtrc += char();
      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
    }


  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    _M_extract_int(_InIter __beg, _InIter __end, ios_base& __io,
                   ios_base::iostate& __err, string& __xtrc, int& __base) const
    {
      const locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
      const numpunct<_CharT>& __np = use_facet<numpunct<_CharT> >(__loc);


      ios_base::fmtflags __basefield = __io.flags() & ios_base::basefield;
      if (__basefield == ios_base::oct)
        __base = 8;
      else if (__basefield == ios_base::hex)
        __base = 16;
      else
        __base = 10;


      int __pos = 0;
      char_type __c = *__beg;
      if ((__c == __ctype.widen('+') || __c == __ctype.widen('-'))
          && __beg != __end)
        {
          __xtrc += __ctype.narrow(__c, char());
          ++__pos;
          __c = *(++__beg);
        }


      const char_type __zero = __ctype.widen(_S_atoms[_M_zero]);
      const char_type __x = __ctype.widen('x');
      const char_type __X = __ctype.widen('X');
      if (__base == 10)
        {
          bool __found_zero = false;
          while (__c == __zero && __beg != __end)
            {
              __c = *(++__beg);
              __found_zero = true;
            }
          if (__found_zero)
            {
              __xtrc += _S_atoms[_M_zero];
              ++__pos;
              if (__basefield == 0)
                {
                  if ((__c == __x || __c == __X) && __beg != __end)
                    {
                      __xtrc += __ctype.narrow(__c, char());
                      ++__pos;
                      __c = *(++__beg);
                      __base = 16;
                    }
                  else
                    __base = 8;
                }
            }
        }
      else if (__base == 16)
        {
          if (__c == __zero && __beg != __end)
            {
              __xtrc += _S_atoms[_M_zero];
              ++__pos;
              __c = *(++__beg);
              if ((__c == __x || __c == __X) && __beg != __end)
                {
                  __xtrc += __ctype.narrow(__c, char());
                  ++__pos;
                  __c = *(++__beg);
                }
            }
        }



      size_t __len;
      if (__base == 16)
        __len = _M_size;
      else
        __len = __base;


      char_type __watoms[_M_size];
      __ctype.widen(_S_atoms, _S_atoms + __len, __watoms);
      string __found_grouping;
      const string __grouping = __np.grouping();
      bool __check_grouping = __grouping.size();
      int __sep_pos = 0;
      const char_type __sep = __np.thousands_sep();
      while (__beg != __end)
        {
          typedef char_traits<_CharT> __traits_type;
          const char_type* __p = __traits_type::find(__watoms, __len, __c);


          if (__p && __c)
            {

              __xtrc += _S_atoms[__p - __watoms];
              ++__pos;
              ++__sep_pos;
              __c = *(++__beg);
            }
          else if (__c == __sep && __check_grouping)
            {


              if (__sep_pos)
                {
                  __found_grouping += static_cast<char>(__sep_pos);
                  __sep_pos = 0;
                  __c = *(++__beg);
                }
              else
                {
                  __err |= ios_base::failbit;
                  break;
                }
            }
          else

            break;
        }



      if (__check_grouping && __found_grouping.size())
        {

          __found_grouping += static_cast<char>(__sep_pos);
          if (!__verify_grouping(__grouping, __found_grouping))
            __err |= ios_base::failbit;
        }


      __xtrc += char();
      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
    }



  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, bool& __v) const
    {

      if (!(__io.flags() & ios_base::boolalpha))
        {


          string __xtrc;
          int __base;
          __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);

          unsigned long __ul;
          __convert_to_v(__xtrc.c_str(), __ul, __err, _S_c_locale, __base);
          if (!(__err & ios_base::failbit) && __ul <= 1)
            __v = __ul;
          else
            __err |= ios_base::failbit;
        }


      else
        {
          typedef basic_string<_CharT> __string_type;
          locale __loc = __io.getloc();
          const numpunct<_CharT>& __np = use_facet<numpunct<_CharT> >(__loc);
          const __string_type __true = __np.truename();
          const __string_type __false = __np.falsename();
          const char_type* __trues = __true.c_str();
          const char_type* __falses = __false.c_str();
          const size_t __truen = __true.size() - 1;
          const size_t __falsen = __false.size() - 1;

          for (size_t __n = 0; __beg != __end; ++__n)
            {
              char_type __c = *__beg++;
              bool __testf = __n <= __falsen ? __c == __falses[__n] : false;
              bool __testt = __n <= __truen ? __c == __trues[__n] : false;
              if (!(__testf || __testt))
                {
                  __err |= ios_base::failbit;
                  break;
                }
              else if (__testf && __n == __falsen)
                {
                  __v = 0;
                  break;
                }
              else if (__testt && __n == __truen)
                {
                  __v = 1;
                  break;
                }
            }
          if (__beg == __end)
            __err |= ios_base::eofbit;
        }
      return __beg;
    }


  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, long& __v) const
    {
      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale, __base);
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, unsigned short& __v) const
    {
      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);
      unsigned long __ul;
      __convert_to_v(__xtrc.c_str(), __ul, __err, _S_c_locale, __base);
      if (!(__err & ios_base::failbit)
          && __ul <= numeric_limits<unsigned short>::max())
        __v = static_cast<unsigned short>(__ul);
      else
        __err |= ios_base::failbit;
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, unsigned int& __v) const
    {
      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);
      unsigned long __ul;
      __convert_to_v(__xtrc.c_str(), __ul, __err, _S_c_locale, __base);
      if (!(__err & ios_base::failbit)
          && __ul <= numeric_limits<unsigned int>::max())
        __v = static_cast<unsigned int>(__ul);
      else
        __err |= ios_base::failbit;
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, unsigned long& __v) const
    {
      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale, __base);
      return __beg;
    }


  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, long long& __v) const
    {
      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale, __base);
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, unsigned long long& __v) const
    {
      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale, __base);
      return __beg;
    }


  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, float& __v) const
    {
      string __xtrc;
      __xtrc.reserve(32);
      __beg = _M_extract_float(__beg, __end, __io, __err, __xtrc);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale);
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, double& __v) const
    {
      string __xtrc;
      __xtrc.reserve(32);
      __beg = _M_extract_float(__beg, __end, __io, __err, __xtrc);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale);
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, long double& __v) const
    {
      string __xtrc;
      __xtrc.reserve(32);
      __beg = _M_extract_float(__beg, __end, __io, __err, __xtrc);
      __convert_to_v(__xtrc.c_str(), __v, __err, _S_c_locale);
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    num_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, ios_base& __io,
           ios_base::iostate& __err, void*& __v) const
    {

      typedef ios_base::fmtflags fmtflags;
      fmtflags __fmt = __io.flags();
      fmtflags __fmtmask = ~(ios_base::showpos | ios_base::basefield
                             | ios_base::uppercase | ios_base::internal);
      __io.flags(__fmt & __fmtmask | (ios_base::hex | ios_base::showbase));

      string __xtrc;
      int __base;
      __beg = _M_extract_int(__beg, __end, __io, __err, __xtrc, __base);


      __io.flags(__fmt);

      unsigned long __ul;
      __convert_to_v(__xtrc.c_str(), __ul, __err, _S_c_locale, __base);
      if (!(__err & ios_base::failbit))
        __v = reinterpret_cast<void*>(__ul);
      else
        __err |= ios_base::failbit;
      return __beg;
    }
# 604 "/usr/include/c++3.1/bits/locale_facets.tcc" 3
  template<typename _CharT, typename _OutIter>
    template<typename _ValueT>
      _OutIter
      num_put<_CharT, _OutIter>::
      _M_convert_float(_OutIter __s, ios_base& __io, _CharT __fill, char __mod,
                       _ValueT __v) const
      {


        const int __max_digits = numeric_limits<_ValueT>::digits10 + 1;
        streamsize __prec = __io.precision();

        if (__prec > static_cast<streamsize>(__max_digits))
          __prec = static_cast<streamsize>(__max_digits);


        char __fbuf[16];


        int __len;



        int __cs_size = __max_digits * 3;
        char* __cs = static_cast<char*>(__builtin_alloca(__cs_size));

        const bool __fp = _S_format_float(__io, __fbuf, __mod, __prec);
        if (__fp)
          __len = __convert_from_v(__cs, __cs_size, __fbuf, __v,
                                   _S_c_locale, __prec);
        else
          __len = __convert_from_v(__cs, __cs_size, __fbuf, __v, _S_c_locale);


        if (__len >= __cs_size)
          {
            __cs_size = __len + 1;
            __cs = static_cast<char*>(__builtin_alloca(__cs_size));
            if (__fp)
              __len = __convert_from_v(__cs, __cs_size, __fbuf, __v,
                                       _S_c_locale, __prec);
            else
              __len = __convert_from_v(__cs, __cs_size, __fbuf, __v,
                                       _S_c_locale);
          }
# 667 "/usr/include/c++3.1/bits/locale_facets.tcc" 3
        return _M_widen_float(__s, __io, __fill, __cs, __len);
      }

  template<typename _CharT, typename _OutIter>
    template<typename _ValueT>
      _OutIter
      num_put<_CharT, _OutIter>::
      _M_convert_int(_OutIter __s, ios_base& __io, _CharT __fill, char __mod,
                     char __modl, _ValueT __v) const
      {



        char __fbuf[16];
        _S_format_int(__io, __fbuf, __mod, __modl);


        int __cs_size = 64;
        char* __cs = static_cast<char*>(__builtin_alloca(__cs_size));
        int __len = __convert_from_v(__cs, __cs_size, __fbuf, __v,
                                     _S_c_locale);

        if (__len >= __cs_size)
          {
            __cs_size = __len + 1;
            __cs = static_cast<char*>(__builtin_alloca(__cs_size));
            __len = __convert_from_v(__cs, __cs_size, __fbuf, __v,
                                     _S_c_locale);
          }






        return _M_widen_int(__s, __io, __fill, __cs, __len);
      }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    _M_widen_float(_OutIter __s, ios_base& __io, _CharT __fill, char* __cs,
                   int __len) const
    {


      const locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
      _CharT* __ws = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT)
                                                           * __len));


      _CharT* __ws2 = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT)
                                                            * __len * 2));
      __ctype.widen(__cs, __cs + __len, __ws);


      const _CharT* __p;
      const numpunct<_CharT>& __np = use_facet<numpunct<_CharT> >(__loc);
      if (__p = char_traits<_CharT>::find(__ws, __len, __ctype.widen('.')))
        __ws[__p - __ws] = __np.decimal_point();




      const string __grouping = __np.grouping();
      ios_base::fmtflags __basefield = __io.flags() & ios_base::basefield;
      if (__grouping.size())
        {
          _CharT* __p2;
          int __declen = __p ? __p - __ws : __len;
          __p2 = __add_grouping(__ws2, __np.thousands_sep(),
                                __grouping.c_str(),
                                __grouping.c_str() + __grouping.size(),
                                __ws, __ws + __declen);
          int __newlen = __p2 - __ws2;


          if (__p)
            {
              char_traits<_CharT>::copy(__p2, __p, __len - __declen);
              __newlen += __len - __declen;
            }


          __ws = __ws2;
          __len = __newlen;
        }

      return _M_insert(__s, __io, __fill, __ws, __len);
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    _M_widen_int(_OutIter __s, ios_base& __io, _CharT __fill, char* __cs,
                 int __len) const
    {


      const locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
      _CharT* __ws = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT)
                                                           * __len));


      _CharT* __ws2 = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT)
                                                            * __len * 2));
      __ctype.widen(__cs, __cs + __len, __ws);


      const numpunct<_CharT>& __np = use_facet<numpunct<_CharT> >(__loc);
      const string __grouping = __np.grouping();
      const ios_base::fmtflags __basefield = __io.flags() & ios_base::basefield;
      if (__grouping.size())
        {



          streamsize __off = 0;
          if (__io.flags() & ios_base::showbase)
            if (__basefield == ios_base::oct)
              {
                __off = 1;
                *__ws2 = *__ws;
              }
            else if (__basefield == ios_base::hex)
              {
                __off = 2;
                *__ws2 = *__ws;
                *(__ws2 + 1) = *(__ws + 1);
              }
          _CharT* __p;
          __p = __add_grouping(__ws2 + __off, __np.thousands_sep(),
                               __grouping.c_str(),
                               __grouping.c_str() + __grouping.size(),
                               __ws + __off, __ws + __len);
          __len = __p - __ws2;

          __ws = __ws2;
        }
      return _M_insert(__s, __io, __fill, __ws, __len);
    }



  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    _M_insert(_OutIter __s, ios_base& __io, _CharT __fill, const _CharT* __ws,
              int __len) const
    {

      streamsize __w = __io.width();
      _CharT* __ws2 = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT)
                                                            * __w));
      if (__w > static_cast<streamsize>(__len))
        {
          __pad(__io, __fill, __ws2, __ws, __w, __len, true);
          __len = static_cast<int>(__w);

          __ws = __ws2;
        }
      __io.width(0);



      for (int __j = 0; __j < __len; ++__j, ++__s)
        *__s = __ws[__j];
      return __s;
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill, bool __v) const
    {
      ios_base::fmtflags __flags = __io.flags();
      if ((__flags & ios_base::boolalpha) == 0)
        {
          unsigned long __uv = __v;
          __s = _M_convert_int(__s, __io, __fill, 'u', char_type(), __uv);
        }
      else
        {
          typedef basic_string<_CharT> __string_type;
          locale __loc = __io.getloc();
          const numpunct<_CharT>& __np = use_facet<numpunct<_CharT> >(__loc);
          __string_type __name;
          if (__v)
            __name = __np.truename();
          else
            __name = __np.falsename();
          __s = _M_insert(__s, __io, __fill, __name.c_str(), __name.size());
        }
      return __s;
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill, long __v) const
    { return _M_convert_int(__s, __io, __fill, 'd', char_type(), __v); }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill,
           unsigned long __v) const
    { return _M_convert_int(__s, __io, __fill, 'u', char_type(), __v); }


  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __b, char_type __fill, long long __v) const
    { return _M_convert_int(__s, __b, __fill, 'd', 'l', __v); }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill,
           unsigned long long __v) const
    { return _M_convert_int(__s, __io, __fill, 'u', 'l', __v); }


  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill, double __v) const
    { return _M_convert_float(__s, __io, __fill, char_type(), __v); }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill,
           long double __v) const
    { return _M_convert_float(__s, __io, __fill, 'L', __v); }

  template<typename _CharT, typename _OutIter>
    _OutIter
    num_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type __fill,
           const void* __v) const
    {
      ios_base::fmtflags __flags = __io.flags();
      ios_base::fmtflags __fmt = ~(ios_base::showpos | ios_base::basefield
                                   | ios_base::uppercase | ios_base::internal);
      __io.flags(__flags & __fmt | (ios_base::hex | ios_base::showbase));
      try
        {
          __s = _M_convert_int(__s, __io, __fill, 'u', char_type(),
                               reinterpret_cast<unsigned long>(__v));
          __io.flags(__flags);
        }
      catch (...)
        {
          __io.flags(__flags);
          throw;
        }
      return __s;
    }


  template<typename _CharT, typename _InIter>
    _InIter
    money_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, bool __intl, ios_base& __io,
           ios_base::iostate& __err, long double& __units) const
    {
      string_type __str;
      __beg = this->do_get(__beg, __end, __intl, __io, __err, __str);

      const int __n = numeric_limits<long double>::digits10;
      char* __cs = static_cast<char*>(__builtin_alloca(__n));
      const locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
      const _CharT* __wcs = __str.c_str();
      __ctype.narrow(__wcs, __wcs + __str.size() + 1, char(), __cs);
      __convert_to_v(__cs, __units, __err, _S_c_locale);
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    money_get<_CharT, _InIter>::
    do_get(iter_type __beg, iter_type __end, bool __intl, ios_base& __io,
           ios_base::iostate& __err, string_type& __units) const
    {

      typedef moneypunct<_CharT, true> __money_true;
      typedef moneypunct<_CharT, false> __money_false;
      typedef money_base::part part;
      typedef typename string_type::size_type size_type;

      const locale __loc = __io.getloc();
      const __money_true& __mpt = use_facet<__money_true>(__loc);
      const __money_false& __mpf = use_facet<__money_false>(__loc);
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);

      const money_base::pattern __p = __intl ? __mpt.neg_format()
                                             : __mpf.neg_format();

      const string_type __pos_sign =__intl ? __mpt.positive_sign()
                                           : __mpf.positive_sign();
      const string_type __neg_sign =__intl ? __mpt.negative_sign()
                                           : __mpf.negative_sign();
      const char_type __d = __intl ? __mpt.decimal_point()
                                   : __mpf.decimal_point();
      const char_type __sep = __intl ? __mpt.thousands_sep()
                                     : __mpf.thousands_sep();

      const string __grouping = __intl ? __mpt.grouping() : __mpf.grouping();


      string_type __sign;

      string __grouping_tmp;

      int __sep_pos = 0;

      bool __testvalid = true;

      bool __testdecfound = false;


      string_type __temp_units;

      char_type __c = *__beg;
      char_type __eof = static_cast<char_type>(char_traits<char_type>::eof());
      for (int __i = 0; __beg != __end && __i < 4 && __testvalid; ++__i)
        {
          part __which = static_cast<part>(__p.field[__i]);
          switch (__which)
                {
                case money_base::symbol:
                  if (__io.flags() & ios_base::showbase
                      || __i < 2 || __sign.size() > 1
                      || ((static_cast<part>(__p.field[3]) != money_base::none)
                          && __i == 2))
                    {





                      const string_type __symbol = __intl ? __mpt.curr_symbol()
                                                         : __mpf.curr_symbol();
                      size_type __len = __symbol.size();
                      size_type __j = 0;
                      while (__beg != __end
                             && __j < __len && __symbol[__j] == __c)
                        {
                          __c = *(++__beg);
                          ++__j;
                        }


                      if (__j != __len && (__io.flags() & ios_base::showbase))
                        __testvalid = false;
                    }
                  break;
                case money_base::sign:

                  if (__pos_sign.size() && __neg_sign.size())
                  {

                    if (__c == __pos_sign[0])
                      {
                        __sign = __pos_sign;
                        __c = *(++__beg);
                      }
                    else if (__c == __neg_sign[0])
                      {
                        __sign = __neg_sign;
                        __c = *(++__beg);
                      }
                    else
                      __testvalid = false;
                  }
                  else if (__pos_sign.size() && __c == __pos_sign[0])
                    {
                      __sign = __pos_sign;
                      __c = *(++__beg);
                    }
                  else if (__neg_sign.size() && __c == __neg_sign[0])
                    {
                      __sign = __neg_sign;
                      __c = *(++__beg);
                    }
                  break;
                case money_base::value:


                  while (__beg != __end
                         && (__ctype.is(ctype_base::digit, __c)
                             || (__c == __d && !__testdecfound)
                             || __c == __sep))
                    {
                      if (__c == __d)
                        {
                          __grouping_tmp += static_cast<char>(__sep_pos);
                          __sep_pos = 0;
                          __testdecfound = true;
                        }
                      else if (__c == __sep)
                        {
                          if (__grouping.size())
                            {

                              __grouping_tmp += static_cast<char>(__sep_pos);
                              __sep_pos = 0;
                            }
                          else
                            {
                              __testvalid = false;
                              break;
                            }
                        }
                      else
                        {
                          __temp_units += __c;
                          ++__sep_pos;
                        }
                      __c = *(++__beg);
                    }
                  break;
                case money_base::space:
                case money_base::none:

                  if (__i != 3)
                    while (__beg != __end
                           && __ctype.is(ctype_base::space, __c))
                      __c = *(++__beg);
                  break;
                }
        }


      if (__sign.size() > 1)
        {
          size_type __len = __sign.size();
          size_type __i = 1;
          for (; __c != __eof && __i < __len; ++__i)
            while (__beg != __end && __c != __sign[__i])
              __c = *(++__beg);

          if (__i != __len)
            __testvalid = false;
        }


      while (__temp_units[0] == __ctype.widen('0'))
        __temp_units.erase(__temp_units.begin());

      if (__sign.size() && __sign == __neg_sign)
        __temp_units.insert(__temp_units.begin(), __ctype.widen('-'));


      if (__grouping.size() && __grouping_tmp.size())
        {
          if (!__verify_grouping(__grouping, __grouping_tmp))
            __testvalid = false;
        }


      if (__c == __eof)
        __err |= ios_base::eofbit;


      if (!__testvalid || !__temp_units.size())
        __err |= ios_base::failbit;
      else

        __temp_units.swap(__units);

      return __beg;
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    money_put<_CharT, _OutIter>::
    do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill,
           long double __units) const
    {
      const locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);


      int __cs_size = 64;
      char* __cs = static_cast<char*>(__builtin_alloca(__cs_size));
      int __len = __convert_from_v(__cs, __cs_size, "%.01Lf", __units,
                                   _S_c_locale);

      if (__len >= __cs_size)
        {
          __cs_size = __len + 1;
          __cs = static_cast<char*>(__builtin_alloca(__cs_size));
          __len = __convert_from_v(__cs, __cs_size, "%.01Lf", __units,
                                   _S_c_locale);
        }







      _CharT* __ws = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * __cs_size));
      __ctype.widen(__cs, __cs + __len, __ws);
      string_type __digits(__ws);
      return this->do_put(__s, __intl, __io, __fill, __digits);
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    money_put<_CharT, _OutIter>::
    do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill,
           const string_type& __digits) const
    {
      typedef typename string_type::size_type size_type;
      typedef money_base::part part;

      const locale __loc = __io.getloc();
      const size_type __width = static_cast<size_type>(__io.width());


      typedef moneypunct<_CharT, true> __money_true;
      typedef moneypunct<_CharT, false> __money_false;
      const __money_true& __mpt = use_facet<__money_true>(__loc);
      const __money_false& __mpf = use_facet<__money_false>(__loc);
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);



      const char_type* __beg = __digits.data();
      const char_type* __end = __beg + __digits.size();
      money_base::pattern __p;
      string_type __sign;
      if (*__beg != __ctype.widen('-'))
        {
          __p = __intl ? __mpt.pos_format() : __mpf.pos_format();
          __sign =__intl ? __mpt.positive_sign() : __mpf.positive_sign();
        }
      else
        {
          __p = __intl ? __mpt.neg_format() : __mpf.neg_format();
          __sign =__intl ? __mpt.negative_sign() : __mpf.negative_sign();
          ++__beg;
        }


      __end = __ctype.scan_not(ctype_base::digit, __beg, __end);
      if (__beg != __end)
        {



          string_type __res;
          string_type __value;
          const string_type __symbol = __intl ? __mpt.curr_symbol()
                                              : __mpf.curr_symbol();


          const int __frac = __intl ? __mpt.frac_digits()
                                    : __mpf.frac_digits();
          if (__frac > 0)
            {
              const char_type __d = __intl ? __mpt.decimal_point()
                                           : __mpf.decimal_point();
              if (__end - __beg >= __frac)
                {
                  __value = string_type(__end - __frac, __end);
                  __value.insert(__value.begin(), __d);
                  __end -= __frac;
                }
              else
                {

                  __value = string_type(__beg, __end);
                  int __paddec = __frac - (__end - __beg);
                  char_type __zero = __ctype.widen('0');
                  __value.insert(__value.begin(), __paddec, __zero);
                  __value.insert(__value.begin(), __d);
                  __beg = __end;
                }
            }



          if (__beg != __end)
            {
              const string __grouping = __intl ? __mpt.grouping()
                                               : __mpf.grouping();
              if (__grouping.size())
                {
                  const char_type __sep = __intl ? __mpt.thousands_sep()
                                                 : __mpf.thousands_sep();
                  const char* __gbeg = __grouping.c_str();
                  const char* __gend = __gbeg + __grouping.size();
                  const int __n = (__end - __beg) * 2;
                  _CharT* __ws2 =
                    static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * __n));
                  _CharT* __ws_end = __add_grouping(__ws2, __sep, __gbeg,
                                                    __gend, __beg, __end);
                  __value.insert(0, __ws2, __ws_end - __ws2);
                }
              else
                __value.insert(0, string_type(__beg, __end));
            }


          ios_base::fmtflags __f = __io.flags() & ios_base::adjustfield;
          size_type __len = __value.size() + __sign.size();
          __len += (__io.flags() & ios_base::showbase) ? __symbol.size() : 0;
          bool __testipad = __f == ios_base::internal && __len < __width;


          for (int __i = 0; __i < 4; ++__i)
            {
              part __which = static_cast<part>(__p.field[__i]);
              switch (__which)
                {
                case money_base::symbol:
                  if (__io.flags() & ios_base::showbase)
                    __res += __symbol;
                  break;
                case money_base::sign:



                  if (__sign.size())
                    __res += __sign[0];
                  break;
                case money_base::value:
                  __res += __value;
                  break;
                case money_base::space:



                  if (__testipad)
                    __res += string_type(__width - __len, __fill);
                  else
                    __res += __ctype.widen(__fill);
                  break;
                case money_base::none:
                  if (__testipad)
                    __res += string_type(__width - __len, __fill);
                  break;
                }
            }


          if (__sign.size() > 1)
            __res += string_type(__sign.begin() + 1, __sign.end());


          __len = __res.size();
          if (__width > __len)
            {
              if (__f == ios_base::left)

                __res.append(__width - __len, __fill);
              else

                __res.insert(0, string_type(__width - __len, __fill));
              __len = __width;
            }


          for (size_type __j = 0; __j < __len; ++__j, ++__s)
            *__s = __res[__j];
        }
      __io.width(0);
      return __s;
    }





  template<typename _CharT, typename _InIter>
    time_base::dateorder
    time_get<_CharT, _InIter>::do_date_order() const
    { return time_base::no_order; }

  template<typename _CharT, typename _InIter>
    void
    time_get<_CharT, _InIter>::
    _M_extract_via_format(iter_type& __beg, iter_type& __end, ios_base& __io,
                          ios_base::iostate& __err, tm* __tm,
                          const _CharT* __format) const
    {
      locale __loc = __io.getloc();
      __timepunct<_CharT> const& __tp = use_facet<__timepunct<_CharT> >(__loc);
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
      size_t __len = char_traits<_CharT>::length(__format);

      for (size_t __i = 0; __beg != __end && __i < __len && !__err; ++__i)
        {
          char __c = __format[__i];
          if (__c == '%')
            {

              __c = __format[++__i];
              char __mod = 0;
              int __mem = 0;
              if (__c == 'E' || __c == 'O')
                {
                  __mod = __c;
                  __c = __format[++__i];
                }
              switch (__c)
                {
                  const char* __cs;
                  _CharT __wcs[10];
                case 'a':

                  const char_type* __days1[7];
                  __tp._M_days_abbreviated(__days1);
                  _M_extract_name(__beg, __end, __tm->tm_wday, __days1, 7,
                                  __err);
                  break;
                case 'A':

                  const char_type* __days2[7];
                  __tp._M_days(__days2);
                  _M_extract_name(__beg, __end, __tm->tm_wday, __days2, 7,
                                  __err);
                  break;
                case 'h':
                case 'b':

                  const char_type* __months1[12];
                  __tp._M_months_abbreviated(__months1);
                  _M_extract_name(__beg, __end, __tm->tm_mon, __months1, 12,
                                  __err);
                  break;
                case 'B':

                  const char_type* __months2[12];
                  __tp._M_months(__months2);
                  _M_extract_name(__beg, __end, __tm->tm_mon, __months2, 12,
                                  __err);
                  break;
                case 'c':

                  const char_type* __dt[2];
                  __tp._M_date_time_formats(__dt);
                  _M_extract_via_format(__beg, __end, __io, __err, __tm,
                                        __dt[0]);
                  break;
                case 'd':

                  _M_extract_num(__beg, __end, __tm->tm_mday, 1, 31, 2,
                                 __ctype, __err);
                  break;
                case 'D':

                  __cs = "%m/%d/%y";
                  __ctype.widen(__cs, __cs + 9, __wcs);
                  _M_extract_via_format(__beg, __end, __io, __err, __tm,
                                        __wcs);
                  break;
                case 'H':

                  _M_extract_num(__beg, __end, __tm->tm_hour, 0, 23, 2,
                                 __ctype, __err);
                  break;
                case 'I':

                  _M_extract_num(__beg, __end, __tm->tm_hour, 1, 12, 2,
                                 __ctype, __err);
                  break;
                case 'm':

                  _M_extract_num(__beg, __end, __mem, 1, 12, 2, __ctype,
                                 __err);
                  if (!__err)
                    __tm->tm_mon = __mem - 1;
                  break;
                case 'M':

                  _M_extract_num(__beg, __end, __tm->tm_min, 0, 59, 2,
                                 __ctype, __err);
                  break;
                case 'n':
                  if (__ctype.narrow(*__beg, 0) == '\n')
                    ++__beg;
                  else
                    __err |= ios_base::failbit;
                  break;
                case 'R':

                  __cs = "%H:%M";
                  __ctype.widen(__cs, __cs + 6, __wcs);
                  _M_extract_via_format(__beg, __end, __io, __err, __tm,
                                        __wcs);
                  break;
                case 'S':

                  _M_extract_num(__beg, __end, __tm->tm_sec, 0, 59, 2,
                                 __ctype, __err);
                  break;
                case 't':
                  if (__ctype.narrow(*__beg, 0) == '\t')
                    ++__beg;
                  else
                __err |= ios_base::failbit;
                  break;
                case 'T':

                  __cs = "%H:%M:%S";
                  __ctype.widen(__cs, __cs + 9, __wcs);
                  _M_extract_via_format(__beg, __end, __io, __err, __tm,
                                        __wcs);
                  break;
                case 'x':

                  const char_type* __dates[2];
                  __tp._M_date_formats(__dates);
                  _M_extract_via_format(__beg, __end, __io, __err, __tm,
                                        __dates[0]);
                  break;
                case 'X':

                  const char_type* __times[2];
                  __tp._M_time_formats(__times);
                  _M_extract_via_format(__beg, __end, __io, __err, __tm,
                                        __times[0]);
                  break;
                case 'y':

                  _M_extract_num(__beg, __end, __tm->tm_year, 0, 99, 2,
                                 __ctype, __err);
                  break;
                case 'Y':

                  _M_extract_num(__beg, __end, __mem, 0,
                                 numeric_limits<int>::max(), 4,
                                 __ctype, __err);
                  if (!__err)
                    __tm->tm_year = __mem - 1900;
                  break;
                case 'Z':

                  if (__ctype.is(ctype_base::upper, *__beg))
                    {
                      int __tmp;
                      _M_extract_name(__beg, __end, __tmp,
                                      __timepunct<_CharT>::_S_timezones,
                                      14, __err);


                      char_type __c = *__beg;
                      if (!__err && __tmp == 0
                          && (__c == __ctype.widen('-')
                              || __c == __ctype.widen('+')))
                        {
                          _M_extract_num(__beg, __end, __tmp, 0, 23, 2,
                                          __ctype, __err);
                          _M_extract_num(__beg, __end, __tmp, 0, 59, 2,
                                          __ctype, __err);
                        }
                          }
                      else
                        __err |= ios_base::failbit;
                      break;
                    default:

                      __err |= ios_base::failbit;
                    }
                }
              else
                {

                  if (__c == __ctype.narrow(*__beg, 0))
                    ++__beg;
                  else
                    __err |= ios_base::failbit;
                }
        }
    }

  template<typename _CharT, typename _InIter>
    void
    time_get<_CharT, _InIter>::
    _M_extract_num(iter_type& __beg, iter_type& __end, int& __member,
                   int __min, int __max, size_t __len,
                   const ctype<_CharT>& __ctype,
                   ios_base::iostate& __err) const
    {
      size_t __i = 0;
      string __digits;
      bool __testvalid = true;
      char_type __c = *__beg;
      while (__beg != __end && __i < __len
             && __ctype.is(ctype_base::digit, __c))
        {
          __digits += __ctype.narrow(__c, 0);
          __c = *(++__beg);
          ++__i;
        }
      if (__i == __len)
        {
          int __value = atoi(__digits.c_str());
          if (__min <= __value && __value <= __max)
            __member = __value;
          else
            __testvalid = false;
        }
      else
        __testvalid = false;
      if (!__testvalid)
        __err |= ios_base::failbit;
    }



  template<typename _CharT, typename _InIter>
    void
    time_get<_CharT, _InIter>::
    _M_extract_name(iter_type& __beg, iter_type& __end, int& __member,
                    const _CharT** __names, size_t __indexlen,
                    ios_base::iostate& __err) const
    {
      typedef char_traits<char_type> __traits_type;
      int* __matches = static_cast<int*>(__builtin_alloca(sizeof(int) * __indexlen));
      size_t __nmatches = 0;
      size_t __pos = 0;
      bool __testvalid = true;
      const char_type* __name;

      char_type __c = *__beg;

      for (size_t __i1 = 0; __i1 < __indexlen; ++__i1)
        if (__c == __names[__i1][0])
          __matches[__nmatches++] = __i1;

      while(__nmatches > 1)
        {

          size_t __minlen = 10;
          for (size_t __i2 = 0; __i2 < __nmatches; ++__i2)
            __minlen = min(__minlen,
                           __traits_type::length(__names[__matches[__i2]]));

          if (__pos < __minlen && __beg != __end)
            {
              ++__pos;
              __c = *(++__beg);
              for (size_t __i3 = 0; __i3 < __nmatches; ++__i3)
                {
                  __name = __names[__matches[__i3]];
                  if (__name[__pos] != __c)
                    __matches[__i3] = __matches[--__nmatches];
                }
            }
          else
            break;
        }

      if (__nmatches == 1)
        {

          __name = __names[__matches[0]];
          const size_t __len = __traits_type::length(__name);
          while (__pos < __len && __beg != __end && __name[__pos] == *__beg)
            ++__beg, ++__pos;

          if (__len == __pos)
            __member = __matches[0];
          else
            __testvalid = false;
        }
      else
        __testvalid = false;
      if (!__testvalid)
        __err |= ios_base::failbit;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    time_get<_CharT, _InIter>::
    do_get_time(iter_type __beg, iter_type __end, ios_base& __io,
                ios_base::iostate& __err, tm* __tm) const
    {
      _CharT __wcs[3];
      const char* __cs = "%X";
      locale __loc = __io.getloc();
      ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
      __ctype.widen(__cs, __cs + 3, __wcs);
      _M_extract_via_format(__beg, __end, __io, __err, __tm, __wcs);
      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    time_get<_CharT, _InIter>::
    do_get_date(iter_type __beg, iter_type __end, ios_base& __io,
                ios_base::iostate& __err, tm* __tm) const
    {
      _CharT __wcs[3];
      const char* __cs = "%x";
      locale __loc = __io.getloc();
      ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
      __ctype.widen(__cs, __cs + 3, __wcs);
      _M_extract_via_format(__beg, __end, __io, __err, __tm, __wcs);
      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    time_get<_CharT, _InIter>::
    do_get_weekday(iter_type __beg, iter_type __end, ios_base& __io,
                   ios_base::iostate& __err, tm* __tm) const
    {
      typedef char_traits<char_type> __traits_type;
      locale __loc = __io.getloc();
      __timepunct<_CharT> const& __tp = use_facet<__timepunct<_CharT> >(__loc);
      const char_type* __days[7];
      __tp._M_days_abbreviated(__days);
      int __tmpwday;
      _M_extract_name(__beg, __end, __tmpwday, __days, 7, __err);







      if (!__err)
        {
          size_t __pos = __traits_type::length(__days[__tmpwday]);
          __tp._M_days(__days);
          const char_type* __name = __days[__tmpwday];
          if (__name[__pos] == *__beg)
            {

              const size_t __len = __traits_type::length(__name);
              while (__pos < __len && __beg != __end
                     && __name[__pos] == *__beg)
                ++__beg, ++__pos;
              if (__len != __pos)
                __err |= ios_base::failbit;
            }
          if (!__err)
            __tm->tm_wday = __tmpwday;
        }
      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
     }

  template<typename _CharT, typename _InIter>
    _InIter
    time_get<_CharT, _InIter>::
    do_get_monthname(iter_type __beg, iter_type __end,
                     ios_base& __io, ios_base::iostate& __err, tm* __tm) const
    {
      typedef char_traits<char_type> __traits_type;
      locale __loc = __io.getloc();
      __timepunct<_CharT> const& __tp = use_facet<__timepunct<_CharT> >(__loc);
      const char_type* __months[12];
      __tp._M_months_abbreviated(__months);
      int __tmpmon;
      _M_extract_name(__beg, __end, __tmpmon, __months, 12, __err);







      if (!__err)
        {
          size_t __pos = __traits_type::length(__months[__tmpmon]);
          __tp._M_months(__months);
          const char_type* __name = __months[__tmpmon];
          if (__name[__pos] == *__beg)
            {

              const size_t __len = __traits_type::length(__name);
              while (__pos < __len && __beg != __end
                     && __name[__pos] == *__beg)
                ++__beg, ++__pos;
              if (__len != __pos)
                __err |= ios_base::failbit;
            }
          if (!__err)
            __tm->tm_mon = __tmpmon;
        }

      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
    }

  template<typename _CharT, typename _InIter>
    _InIter
    time_get<_CharT, _InIter>::
    do_get_year(iter_type __beg, iter_type __end, ios_base& __io,
                ios_base::iostate& __err, tm* __tm) const
    {
      locale __loc = __io.getloc();
      const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);

      char_type __c = *__beg;
      size_t __i = 0;
      string __digits;
      while (__i < 4 && __beg != __end && __ctype.is(ctype_base::digit, __c))
        {
          __digits += __ctype.narrow(__c, 0);
          __c = *(++__beg);
          ++__i;
        }
      if (__i == 2 || __i == 4)
        {
          long __l;
          __convert_to_v(__digits.c_str(), __l, __err, _S_c_locale);
          if (!(__err & ios_base::failbit) && __l <= 2147483647)
            {
              __l = __i == 2 ? __l : __l - 1900;
              __tm->tm_year = static_cast<int>(__l);
            }
        }
      else
        __err |= ios_base::failbit;
      if (__beg == __end)
        __err |= ios_base::eofbit;
      return __beg;
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    time_put<_CharT, _OutIter>::
    put(iter_type __s, ios_base& __io, char_type, const tm* __tm,
        const _CharT* __beg, const _CharT* __end) const
    {
      locale __loc = __io.getloc();
      ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
      while (__beg != __end)
        {
          char __c = __ctype.narrow(*__beg, 0);
          ++__beg;
          if (__c == '%')
            {
              char __format;
              char __mod = 0;
              size_t __len = 1;
              __c = __ctype.narrow(*__beg, 0);
              ++__beg;
              if (__c == 'E' || __c == 'O')
                {
                  __mod = __c;
                  __format = __ctype.narrow(*__beg, 0);
                  ++__beg;
                }
              else
                __format = __c;
              __s = this->do_put(__s, __io, char_type(), __tm, __format,
                                 __mod);
            }
          else
            {
              *__s = __c;
              ++__s;
            }
        }
      return __s;
    }

  template<typename _CharT, typename _OutIter>
    _OutIter
    time_put<_CharT, _OutIter>::
    do_put(iter_type __s, ios_base& __io, char_type, const tm* __tm,
           char __format, char __mod) const
    {
      locale __loc = __io.getloc();
      ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
      __timepunct<_CharT> const& __tp = use_facet<__timepunct<_CharT> >(__loc);



      const size_t __maxlen = 64;
      char_type* __res =
        static_cast<char_type*>(__builtin_alloca(sizeof(char_type) * __maxlen));






      char_type __fmt[4];
      __fmt[0] = __ctype.widen('%');
      if (!__mod)
        {
          __fmt[1] = __format;
          __fmt[2] = char_type();
        }
      else
        {
          __fmt[1] = __mod;
          __fmt[2] = __format;
          __fmt[3] = char_type();
        }

      __tp._M_put(__res, __maxlen, __fmt, __tm);


      size_t __len = char_traits<char_type>::length(__res);
      for (size_t __i = 0; __i < __len; ++__i, ++__s)
        *__s = __res[__i];
      return __s;
    }



  template<typename _CharT>
    int
    collate<_CharT>::_M_compare(const _CharT*, const _CharT*) const
    { return 0; }


  template<typename _CharT>
    size_t
    collate<_CharT>::_M_transform(_CharT*, const _CharT*, size_t) const
    { return 0; }

  template<typename _CharT>
    int
    collate<_CharT>::
    do_compare(const _CharT* __lo1, const _CharT* __hi1,
               const _CharT* __lo2, const _CharT* __hi2) const
    {
      const string_type __one(__lo1, __hi1);
      const string_type __two(__lo2, __hi2);
      return _M_compare(__one.c_str(), __two.c_str());
    }

 template<typename _CharT>
    typename collate<_CharT>::string_type
    collate<_CharT>::
    do_transform(const _CharT* __lo, const _CharT* __hi) const
    {
      size_t __len = (__hi - __lo) * 2;

      _CharT* __c =
        static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * __len));
      size_t __res = _M_transform(__c, __lo, __len);

      if (__res >= __len)
        {
          __c =
            static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * (__res + 1)));
          _M_transform(__c, __lo, __res + 1);
        }
      return string_type(__c);
    }

 template<typename _CharT>
    long
    collate<_CharT>::
    do_hash(const _CharT* __lo, const _CharT* __hi) const
    {
      unsigned long __val = 0;
      for (; __lo < __hi; ++__lo)
        __val = *__lo + ((__val << 7) |
                       (__val >> (numeric_limits<unsigned long>::digits - 7)));
      return static_cast<long>(__val);
    }




  template<typename _Tv>
    void
    __convert_to_v(const char* __in, _Tv& __out, ios_base::iostate& __err,
                   const __c_locale& __cloc, int __base = 10);





  template<typename _Tv>
    int
    __convert_from_v(char* __out, const int __size, const char* __fmt,
                     _Tv __v, const __c_locale&, int __prec = -1)
    {
      int __ret;
      const char* __old = setlocale(__LC_ALL, "C");
      if (__prec >= 0)
        __ret = snprintf(__out, __size, __fmt, __prec, __v);
      else
        __ret = snprintf(__out, __size, __fmt, __v);
      setlocale(__LC_ALL, __old);
      return __ret;
    }
# 1995 "/usr/include/c++3.1/bits/locale_facets.tcc" 3
  template<typename _CharT, typename _Traits>
    void
    __pad(ios_base& __io, _CharT __fill, _CharT* __news, const _CharT* __olds,
          const streamsize __newlen, const streamsize __oldlen,
          const bool __num)
    {
      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename traits_type::int_type int_type;

      int_type __plen = static_cast<size_t>(__newlen - __oldlen);
      char_type* __pads = static_cast<char_type*>(__builtin_alloca(sizeof(char_type) * __plen));
      traits_type::assign(__pads, __plen, __fill);

      char_type* __beg;
      char_type* __end;
      size_t __mod = 0;
      size_t __beglen;
      ios_base::fmtflags __adjust = __io.flags() & ios_base::adjustfield;

      if (__adjust == ios_base::left)
        {

          __beg = const_cast<char_type*>(__olds);
          __beglen = __oldlen;
          __end = __pads;
        }
      else if (__adjust == ios_base::internal && __num)
        {



          locale __loc = __io.getloc();
          const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
          const char_type __minus = __ctype.widen('-');
          const char_type __plus = __ctype.widen('+');
          bool __testsign = __olds[0] == __minus || __olds[0] == __plus;
          bool __testhex = __ctype.widen('0') == __olds[0]
                           && (__ctype.widen('x') == __olds[1]
                               || __ctype.widen('X') == __olds[1]);
          if (__testhex)
            {
              __news[0] = __olds[0];
              __news[1] = __olds[1];
              __mod += 2;
              __news += 2;
              __beg = __pads;
              __beglen = __plen;
              __end = const_cast<char_type*>(__olds + __mod);
            }
          else if (__testsign)
            {
              __news[0] = __olds[0] == __plus ? __plus : __minus;
              ++__mod;
              ++__news;
              __beg = __pads;
              __beglen = __plen;
              __end = const_cast<char_type*>(__olds + __mod);
            }
          else
            {

              __beg = __pads;
              __beglen = __plen;
              __end = const_cast<char_type*>(__olds);
            }
        }
      else
        {

          __beg = __pads;
          __beglen = __plen;
          __end = const_cast<char_type*>(__olds);
        }
      traits_type::copy(__news, __beg, __beglen);
      traits_type::copy(__news + __beglen, __end, __newlen - __beglen - __mod);
    }




  template<typename _CharT>
    void
    __pad(ios_base& __io, _CharT __fill, _CharT* __news, const _CharT* __olds,
          const streamsize __newlen, const streamsize __oldlen,
          const bool __num)
    {
      return __pad<_CharT, char_traits<_CharT> >(__io, __fill, __news, __olds,
                                                 __newlen, __oldlen, __num);
    }
# 2094 "/usr/include/c++3.1/bits/locale_facets.tcc" 3
  template<typename _CharT>
    bool
    __verify_grouping(const basic_string<_CharT>& __grouping,
                      basic_string<_CharT>& __grouping_tmp)
    {
      int __i = 0;
      int __j = 0;
      const int __len = __grouping.size();
      const int __n = __grouping_tmp.size();
      bool __test = true;




      while (__test && __i < __n - 1)
        for (__j = 0; __test && __j < __len && __i < __n - 1; ++__j,++__i)
          __test &= __grouping[__j] == __grouping_tmp[__n - __i - 1];


      __j == __len ? __j = 0 : __j;
      __test &= __grouping[__j] >= __grouping_tmp[__n - __i - 1];
      return __test;
    }






  template<typename _CharT>
    _CharT*
    __add_grouping(_CharT* __s, _CharT __sep,
                   const char* __gbeg, const char* __gend,
                   const _CharT* __first, const _CharT* __last)
    {
      if (__last - __first > *__gbeg)
        {
          __s = __add_grouping(__s, __sep,
                               (__gbeg + 1 == __gend ? __gbeg : __gbeg + 1),
                               __gend, __first, __last - *__gbeg);
          __first = __last - *__gbeg;
          *__s++ = __sep;
        }
      do
        *__s++ = *__first++;
      while (__first != __last);
      return __s;
    }




  extern template class moneypunct<char, false>;
  extern template class moneypunct<char, true>;
  extern template class moneypunct_byname<char, false>;
  extern template class moneypunct_byname<char, true>;
  extern template class money_get<char>;
  extern template class money_put<char>;
  extern template class moneypunct<wchar_t, false>;
  extern template class moneypunct<wchar_t, true>;
  extern template class moneypunct_byname<wchar_t, false>;
  extern template class moneypunct_byname<wchar_t, true>;
  extern template class money_get<wchar_t>;
  extern template class money_put<wchar_t>;
  extern template class numpunct<char>;
  extern template class numpunct_byname<char>;
  extern template class num_get<char>;
  extern template class num_put<char>;
  extern template class numpunct<wchar_t>;
  extern template class numpunct_byname<wchar_t>;
  extern template class num_get<wchar_t>;
  extern template class num_put<wchar_t>;
  extern template class __timepunct<char>;
  extern template class time_put<char>;
  extern template class time_put_byname<char>;
  extern template class time_get<char>;
  extern template class time_get_byname<char>;
  extern template class __timepunct<wchar_t>;
  extern template class time_put<wchar_t>;
  extern template class time_put_byname<wchar_t>;
  extern template class time_get<wchar_t>;
  extern template class time_get_byname<wchar_t>;
  extern template class messages<char>;
  extern template class messages_byname<char>;
  extern template class messages<wchar_t>;
  extern template class messages_byname<wchar_t>;
  extern template class ctype_byname<char>;
  extern template class ctype_byname<wchar_t>;
  extern template class codecvt_byname<char, char, mbstate_t>;
  extern template class codecvt_byname<wchar_t, char, mbstate_t>;
  extern template class collate<char>;
  extern template class collate_byname<char>;
  extern template class collate<wchar_t>;
  extern template class collate_byname<wchar_t>;

  extern template
    const codecvt<char, char, mbstate_t>&
    use_facet<codecvt<char, char, mbstate_t> >(const locale&);

  extern template
    const collate<char>&
    use_facet<collate<char> >(const locale&);

  extern template
    const numpunct<char>&
    use_facet<numpunct<char> >(const locale&);

  extern template
    const num_put<char>&
    use_facet<num_put<char> >(const locale&);

  extern template
    const num_get<char>&
    use_facet<num_get<char> >(const locale&);

  extern template
    const moneypunct<char, true>&
    use_facet<moneypunct<char, true> >(const locale&);

  extern template
    const moneypunct<char, false>&
    use_facet<moneypunct<char, false> >(const locale&);

  extern template
    const money_put<char>&
    use_facet<money_put<char> >(const locale&);

  extern template
    const money_get<char>&
    use_facet<money_get<char> >(const locale&);

  extern template
    const __timepunct<char>&
    use_facet<__timepunct<char> >(const locale&);

  extern template
    const time_put<char>&
    use_facet<time_put<char> >(const locale&);

  extern template
    const time_get<char>&
    use_facet<time_get<char> >(const locale&);

  extern template
    const messages<char>&
    use_facet<messages<char> >(const locale&);

  extern template
    const codecvt<wchar_t, char, mbstate_t>&
    use_facet<codecvt<wchar_t, char, mbstate_t> >(locale const&);

  extern template
    const collate<wchar_t>&
    use_facet<collate<wchar_t> >(const locale&);

  extern template
    const numpunct<wchar_t>&
    use_facet<numpunct<wchar_t> >(const locale&);

  extern template
    const num_put<wchar_t>&
    use_facet<num_put<wchar_t> >(const locale&);

  extern template
    const num_get<wchar_t>&
    use_facet<num_get<wchar_t> >(const locale&);

  extern template
    const moneypunct<wchar_t, true>&
    use_facet<moneypunct<wchar_t, true> >(const locale&);

  extern template
    const moneypunct<wchar_t, false>&
    use_facet<moneypunct<wchar_t, false> >(const locale&);

  extern template
    const money_put<wchar_t>&
    use_facet<money_put<wchar_t> >(const locale&);

  extern template
    const money_get<wchar_t>&
    use_facet<money_get<wchar_t> >(const locale&);

  extern template
    const __timepunct<wchar_t>&
    use_facet<__timepunct<wchar_t> >(const locale&);

  extern template
    const time_put<wchar_t>&
    use_facet<time_put<wchar_t> >(const locale&);

  extern template
    const time_get<wchar_t>&
    use_facet<time_get<wchar_t> >(const locale&);

  extern template
    const messages<wchar_t>&
    use_facet<messages<wchar_t> >(const locale&);


  extern template
    bool
    has_facet<ctype<char> >(const locale&);

  extern template
    bool
    has_facet<codecvt<char, char, mbstate_t> >(const locale&);

  extern template
    bool
    has_facet<collate<char> >(const locale&);

  extern template
    bool
    has_facet<numpunct<char> >(const locale&);

  extern template
    bool
    has_facet<num_put<char> >(const locale&);

  extern template
    bool
    has_facet<num_get<char> >(const locale&);

  extern template
    bool
    has_facet<moneypunct<char> >(const locale&);

  extern template
    bool
    has_facet<money_put<char> >(const locale&);

  extern template
    bool
    has_facet<money_get<char> >(const locale&);

  extern template
    bool
    has_facet<__timepunct<char> >(const locale&);

  extern template
    bool
    has_facet<time_put<char> >(const locale&);

  extern template
    bool
    has_facet<time_get<char> >(const locale&);

  extern template
    bool
    has_facet<messages<char> >(const locale&);

 extern template
    bool
    has_facet<ctype<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<codecvt<wchar_t, char, mbstate_t> >(const locale&);

  extern template
    bool
    has_facet<collate<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<numpunct<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<num_put<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<num_get<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<moneypunct<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<money_put<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<money_get<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<__timepunct<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<time_put<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<time_get<wchar_t> >(const locale&);

  extern template
    bool
    has_facet<messages<wchar_t> >(const locale&);
}
# 47 "/usr/include/c++3.1/locale" 2 3
# 38 "/usr/include/c++3.1/bits/ostream.tcc" 2 3

namespace std
{
  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>::sentry::
    sentry(basic_ostream<_CharT,_Traits>& __os)
    : _M_ok(__os.good()), _M_os(__os)
    {

      if (_M_ok && __os.tie())
        __os.tie()->flush();
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::
    operator<<(__ostream_type& (*__pf)(__ostream_type&))
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            { __pf(*this); }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::
    operator<<(__ios_type& (*__pf)(__ios_type&))
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            { __pf(*this); }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::
    operator<<(ios_base& (*__pf)(ios_base&))
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            { __pf(*this); }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(__streambuf_type* __sbin)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              streamsize __xtrct = 0;
              if (__sbin)
                {
                  __streambuf_type* __sbout = this->rdbuf();
                  __xtrct = __copy_streambufs(*this, __sbin, __sbout);
                }
              else
                this->setstate(ios_base::badbit);
              if (!__xtrct)
                this->setstate(ios_base::failbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(bool __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              if (_M_check_facet(_M_fnumput))
                if (_M_fnumput->put(*this, *this, this->fill(), __n).failed())
                  this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(long __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              char_type __c = this->fill();
              ios_base::fmtflags __fmt = this->flags() & ios_base::basefield;
              if (_M_check_facet(_M_fnumput))
                {
                  bool __b = false;
                  if ((__fmt & ios_base::oct) || (__fmt & ios_base::hex))
                    {
                      unsigned long __l = static_cast<unsigned long>(__n);
                      __b = _M_fnumput->put(*this, *this, __c, __l).failed();
                    }
                  else
                    __b = _M_fnumput->put(*this, *this, __c, __n).failed();
                  if (__b)
                    this->setstate(ios_base::badbit);
                }
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(unsigned long __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              if (_M_check_facet(_M_fnumput))
                if (_M_fnumput->put(*this, *this, this->fill(), __n).failed())
                  this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }


  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(long long __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              char_type __c = this->fill();
              ios_base::fmtflags __fmt = this->flags() & ios_base::basefield;
              if (_M_check_facet(_M_fnumput))
                {
                  bool __b = false;
                  if ((__fmt & ios_base::oct) || (__fmt & ios_base::hex))
                    {
                      unsigned long long __l;
                      __l = static_cast<unsigned long long>(__n);
                      __b = _M_fnumput->put(*this, *this, __c, __l).failed();
                    }
                  else
                    __b = _M_fnumput->put(*this, *this, __c, __n).failed();
                  if (__b)
                    this->setstate(ios_base::badbit);
                }
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(unsigned long long __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              if (_M_check_facet(_M_fnumput))
                if (_M_fnumput->put(*this, *this, this->fill(), __n).failed())
                  this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }


  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(double __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              if (_M_check_facet(_M_fnumput))
                if (_M_fnumput->put(*this, *this, this->fill(), __n).failed())
                  this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(long double __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              if (_M_check_facet(_M_fnumput))
                if (_M_fnumput->put(*this, *this, this->fill(), __n).failed())
                  this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::operator<<(const void* __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          try
            {
              if (_M_check_facet(_M_fnumput))
                if (_M_fnumput->put(*this, *this, this->fill(), __n).failed())
                  this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::put(char_type __c)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          int_type __put = rdbuf()->sputc(__c);
          if (traits_type::eq_int_type(__put, traits_type::eof()))
            this->setstate(ios_base::badbit);
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::write(const _CharT* __s, streamsize __n)
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          streamsize __put = this->rdbuf()->sputn(__s, __n);
          if ( __put != __n)
            this->setstate(ios_base::badbit);
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::flush()
    {
      sentry __cerb(*this);
      if (__cerb)
        {
          if (this->rdbuf() && this->rdbuf()->pubsync() == -1)
            this->setstate(ios_base::badbit);
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    typename basic_ostream<_CharT, _Traits>::pos_type
    basic_ostream<_CharT, _Traits>::tellp()
    {
      pos_type __ret = pos_type(-1);
      if (!this->fail())
        __ret = this->rdbuf()->pubseekoff(0, ios_base::cur, ios_base::out);
      return __ret;
    }


  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::seekp(pos_type __pos)
    {
      if (!this->fail())
        {


          pos_type __err = this->rdbuf()->pubseekpos(__pos, ios_base::out);


          if (__err == pos_type(off_type(-1)))
            this->setstate(ios_base::failbit);

        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    basic_ostream<_CharT, _Traits>::
    seekp(off_type __off, ios_base::seekdir __d)
    {
      if (!this->fail())
        {


          pos_type __err = this->rdbuf()->pubseekoff(__off, __d,
                                                     ios_base::out);


          if (__err == pos_type(off_type(-1)))
            this->setstate(ios_base::failbit);

        }
      return *this;
    }


  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out, _CharT __c)
    {
      typedef basic_ostream<_CharT, _Traits> __ostream_type;
      typename __ostream_type::sentry __cerb(__out);
      if (__cerb)
        {
          try
            {
              streamsize __w = __out.width();
              _CharT* __pads = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * (__w + 1)));
              __pads[0] = __c;
              streamsize __len = 1;
              if (__w > __len)
                {
                  __pad(__out, __out.fill(), __pads, &__c, __w, __len, false);
                  __len = __w;
                }
              __out.write(__pads, __len);
              __out.width(0);
            }
          catch(exception& __fail)
            {


              __out.setstate(ios_base::badbit);
              if ((__out.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __out;
    }


  template <class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, char __c)
    {
      typedef basic_ostream<char, _Traits> __ostream_type;
      typename __ostream_type::sentry __cerb(__out);
      if (__cerb)
        {
          try
            {
              streamsize __w = __out.width();
              char* __pads = static_cast<char*>(__builtin_alloca(__w + 1));
              __pads[0] = __c;
              streamsize __len = 1;
              if (__w > __len)
                {
                  __pad(__out, __out.fill(), __pads, &__c, __w, __len, false);
                  __len = __w;
                }
              __out.write(__pads, __len);
              __out.width(0);
            }
          catch(exception& __fail)
            {


              __out.setstate(ios_base::badbit);
              if ((__out.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __out;
     }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out, const _CharT* __s)
    {
      typedef basic_ostream<_CharT, _Traits> __ostream_type;
      typename __ostream_type::sentry __cerb(__out);
      if (__cerb)
        {
          try
            {
              streamsize __w = __out.width();
              _CharT* __pads = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * __w));
              streamsize __len = static_cast<streamsize>(_Traits::length(__s));
              if (__w > __len)
                {
                  __pad(__out, __out.fill(), __pads, __s, __w, __len, false);
                  __s = __pads;
                  __len = __w;
                }
              __out.write(__s, __len);
              __out.width(0);
            }
          catch(exception& __fail)
            {


              __out.setstate(ios_base::badbit);
              if ((__out.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __out;
    }

  template<typename _CharT, typename _Traits>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out, const char* __s)
    {
      typedef basic_ostream<_CharT, _Traits> __ostream_type;



      typedef char_traits<char> __ctraits_type;

      typename __ostream_type::sentry __cerb(__out);
      if (__cerb)
        {
          size_t __clen = __ctraits_type::length(__s);
          _CharT* __ws = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * (__clen + 1)));
          for (size_t __i = 0; __i <= __clen; ++__i)
            __ws[__i] = __out.widen(__s[__i]);
          _CharT* __str = __ws;

          try
            {
              streamsize __len = static_cast<streamsize>(__clen);
              streamsize __w = __out.width();
              _CharT* __pads = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * __w));

              if (__w > __len)
                {
                  __pad(__out, __out.fill(), __pads, __ws, __w, __len, false);
                  __str = __pads;
                  __len = __w;
                }
              __out.write(__str, __len);
              __out.width(0);
            }
          catch(exception& __fail)
            {


              __out.setstate(ios_base::badbit);
              if ((__out.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __out;
    }


  template<class _Traits>
    basic_ostream<char, _Traits>&
    operator<<(basic_ostream<char, _Traits>& __out, const char* __s)
    {
      typedef basic_ostream<char, _Traits> __ostream_type;
      typename __ostream_type::sentry __cerb(__out);
      if (__cerb)
        {
          try
            {
              streamsize __w = __out.width();
              char* __pads = static_cast<char*>(__builtin_alloca(__w));
              streamsize __len = static_cast<streamsize>(_Traits::length(__s));
              if (__w > __len)
                {
                  __pad(__out, __out.fill(), __pads, __s, __w, __len, false);
                  __s = __pads;
                  __len = __w;
                }
              __out.write(__s, __len);
              __out.width(0);
            }
          catch(exception& __fail)
            {


              __out.setstate(ios_base::badbit);
              if ((__out.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __out;
    }


  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_ostream<_CharT, _Traits>&
    operator<<(basic_ostream<_CharT, _Traits>& __out,
               const basic_string<_CharT, _Traits, _Alloc>& __str)
    {
      typedef basic_ostream<_CharT, _Traits> __ostream_type;
      typename __ostream_type::sentry __cerb(__out);
      if (__cerb)
        {
          const _CharT* __s = __str.data();
          streamsize __w = __out.width();
          _CharT* __pads = static_cast<_CharT*>(__builtin_alloca(sizeof(_CharT) * __w));
          streamsize __len = static_cast<streamsize>(__str.size());



          if (__w > __len)
            {
              __pad(__out, __out.fill(), __pads, __s, __w, __len, false);
              __s = __pads;
              __len = __w;
            }
          streamsize __res = __out.rdbuf()->sputn(__s, __len);
          __out.width(0);
          if (__res != __len)
            __out.setstate(ios_base::failbit);
        }
      return __out;
    }




  extern template class basic_ostream<char>;
  extern template ostream& endl(ostream&);
  extern template ostream& ends(ostream&);
  extern template ostream& flush(ostream&);
  extern template ostream& operator<<(ostream&, char);
  extern template ostream& operator<<(ostream&, unsigned char);
  extern template ostream& operator<<(ostream&, signed char);
  extern template ostream& operator<<(ostream&, const char*);
  extern template ostream& operator<<(ostream&, const unsigned char*);
  extern template ostream& operator<<(ostream&, const signed char*);

  extern template class basic_ostream<wchar_t>;
  extern template wostream& endl(wostream&);
  extern template wostream& ends(wostream&);
  extern template wostream& flush(wostream&);
  extern template wostream& operator<<(wostream&, wchar_t);
  extern template wostream& operator<<(wostream&, char);
  extern template wostream& operator<<(wostream&, const wchar_t*);
  extern template wostream& operator<<(wostream&, const char*);
}
# 276 "/usr/include/c++3.1/ostream" 2 3
# 46 "/usr/include/c++3.1/iostream" 2 3
# 1 "/usr/include/c++3.1/istream" 1 3
# 43 "/usr/include/c++3.1/istream" 3




namespace std
{

  template<typename _CharT, typename _Traits>
    class basic_istream : virtual public basic_ios<_CharT, _Traits>
    {
    public:

      typedef _CharT char_type;
      typedef typename _Traits::int_type int_type;
      typedef typename _Traits::pos_type pos_type;
      typedef typename _Traits::off_type off_type;
      typedef _Traits traits_type;


      typedef basic_streambuf<_CharT, _Traits> __streambuf_type;
      typedef basic_ios<_CharT, _Traits> __ios_type;
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef istreambuf_iterator<_CharT, _Traits> __istreambuf_iter;
      typedef num_get<_CharT, __istreambuf_iter> __numget_type;
      typedef ctype<_CharT> __ctype_type;

    protected:

      streamsize _M_gcount;

    public:

      explicit
      basic_istream(__streambuf_type* __sb)
      {
        this->init(__sb);
        _M_gcount = streamsize(0);
      }

      virtual
      ~basic_istream()
      { _M_gcount = streamsize(0); }


      class sentry;
      friend class sentry;



      __istream_type&
      operator>>(__istream_type& (*__pf)(__istream_type&));

      __istream_type&
      operator>>(__ios_type& (*__pf)(__ios_type&));

      __istream_type&
      operator>>(ios_base& (*__pf)(ios_base&));


      __istream_type&
      operator>>(bool& __n);

      __istream_type&
      operator>>(short& __n);

      __istream_type&
      operator>>(unsigned short& __n);

      __istream_type&
      operator>>(int& __n);

      __istream_type&
      operator>>(unsigned int& __n);

      __istream_type&
      operator>>(long& __n);

      __istream_type&
      operator>>(unsigned long& __n);


      __istream_type&
      operator>>(long long& __n);

      __istream_type&
      operator>>(unsigned long long& __n);


      __istream_type&
      operator>>(float& __f);

      __istream_type&
      operator>>(double& __f);

      __istream_type&
      operator>>(long double& __f);

      __istream_type&
      operator>>(void*& __p);

      __istream_type&
      operator>>(__streambuf_type* __sb);


      inline streamsize
      gcount(void) const
      { return _M_gcount; }

      int_type
      get(void);

      __istream_type&
      get(char_type& __c);

      __istream_type&
      get(char_type* __s, streamsize __n, char_type __delim);

      inline __istream_type&
      get(char_type* __s, streamsize __n)
      { return this->get(__s, __n, this->widen('\n')); }

      __istream_type&
      get(__streambuf_type& __sb, char_type __delim);

      inline __istream_type&
      get(__streambuf_type& __sb)
      { return this->get(__sb, this->widen('\n')); }

      __istream_type&
      getline(char_type* __s, streamsize __n, char_type __delim);

      inline __istream_type&
      getline(char_type* __s, streamsize __n)
      { return this->getline(__s, __n, this->widen('\n')); }

      __istream_type&
      ignore(streamsize __n = 1, int_type __delim = traits_type::eof());

      int_type
      peek(void);

      __istream_type&
      read(char_type* __s, streamsize __n);

      streamsize
      readsome(char_type* __s, streamsize __n);

      __istream_type&
      putback(char_type __c);

      __istream_type&
      unget(void);

      int
      sync(void);

      pos_type
      tellg(void);

      __istream_type&
      seekg(pos_type);

      __istream_type&
      seekg(off_type, ios_base::seekdir);
    };

  template<typename _CharT, typename _Traits>
    class basic_istream<_CharT, _Traits>::sentry
    {
    public:
      typedef _Traits traits_type;
      typedef basic_streambuf<_CharT, _Traits> __streambuf_type;
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef typename __istream_type::__ctype_type __ctype_type;
      typedef typename _Traits::int_type __int_type;

      explicit
      sentry(basic_istream<_CharT, _Traits>& __is, bool __noskipws = false);

      operator bool() { return _M_ok; }

    private:
      bool _M_ok;
    };


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    operator>>(basic_istream<_CharT, _Traits>& __in, _CharT& __c);

  template<class _Traits>
    basic_istream<char, _Traits>&
    operator>>(basic_istream<char, _Traits>& __in, unsigned char& __c)
    { return (__in >> reinterpret_cast<char&>(__c)); }

  template<class _Traits>
    basic_istream<char, _Traits>&
    operator>>(basic_istream<char, _Traits>& __in, signed char& __c)
    { return (__in >> reinterpret_cast<char&>(__c)); }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    operator>>(basic_istream<_CharT, _Traits>& __in, _CharT* __s);

  template<class _Traits>
    basic_istream<char,_Traits>&
    operator>>(basic_istream<char,_Traits>& __in, unsigned char* __s)
    { return (__in >> reinterpret_cast<char*>(__s)); }

  template<class _Traits>
    basic_istream<char,_Traits>&
    operator>>(basic_istream<char,_Traits>& __in, signed char* __s)
    { return (__in >> reinterpret_cast<char*>(__s)); }


  template<typename _CharT, typename _Traits>
    class basic_iostream
    : public basic_istream<_CharT, _Traits>,
      public basic_ostream<_CharT, _Traits>
    {
    public:

      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef basic_ostream<_CharT, _Traits> __ostream_type;

      explicit
      basic_iostream(basic_streambuf<_CharT, _Traits>* __sb)
      : __istream_type(__sb), __ostream_type(__sb)
      { }

      virtual
      ~basic_iostream() { }
    };


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    ws(basic_istream<_CharT, _Traits>& __is);
}





# 1 "/usr/include/c++3.1/bits/istream.tcc" 1 3
# 36 "/usr/include/c++3.1/bits/istream.tcc" 3




namespace std
{
  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>::sentry::
    sentry(basic_istream<_CharT, _Traits>& __in, bool __noskipws)
    {
      if (__in.good())
        {
          if (__in.tie())
            __in.tie()->flush();
          if (!__noskipws && (__in.flags() & ios_base::skipws))
            {
              const __int_type __eof = traits_type::eof();
              __streambuf_type* __sb = __in.rdbuf();
              __int_type __c = __sb->sgetc();

              if (__in._M_check_facet(__in._M_fctype))
                while (__c != __eof
                       && __in._M_fctype->is(ctype_base::space, __c))
                  __c = __sb->snextc();



              if (__c == __eof)
                __in.setstate(ios_base::eofbit);

            }
        }

      if (__in.good())
        _M_ok = true;
      else
        {
          _M_ok = false;
          __in.setstate(ios_base::failbit);
        }
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(__istream_type& (*__pf)(__istream_type&))
    {
      __pf(*this);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(__ios_type& (*__pf)(__ios_type&))
    {
      __pf(*this);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(ios_base& (*__pf)(ios_base&))
    {
      __pf(*this);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(bool& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(short& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              long __l;
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __l);


              if (!(__err & ios_base::failbit)
                  && (numeric_limits<short>::min() <= __l
                      && __l <= numeric_limits<short>::max()))
                __n = __l;
              else
                __err |= ios_base::failbit;

              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(unsigned short& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(int& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              long __l;
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __l);


              if (!(__err & ios_base::failbit)
                  && (numeric_limits<int>::min() <= __l
                      && __l <= numeric_limits<int>::max()))
                __n = __l;
              else
                __err |= ios_base::failbit;

              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(unsigned int& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(long& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(unsigned long& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(long long& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
              throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(unsigned long long& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(float& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(double& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(long double& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(void*& __n)
    {
      sentry __cerb(*this, false);
      if (__cerb)
        {
          try
            {
              ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
              if (_M_check_facet(_M_fnumget))
                _M_fnumget->get(*this, 0, *this, __err, __n);
              this->setstate(__err);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    operator>>(__streambuf_type* __sbout)
    {
       sentry __cerb(*this, false);
       if (__cerb)
         {
           try
             {
               streamsize __xtrct = 0;
               if (__sbout)
                 {
                   __streambuf_type* __sbin = this->rdbuf();
                   __xtrct = __copy_streambufs(*this, __sbin, __sbout);
                 }
               if (!__sbout || !__xtrct)
                 this->setstate(ios_base::failbit);
             }
           catch(exception& __fail)
             {


               this->setstate(ios_base::badbit);
               if ((this->exceptions() & ios_base::badbit) != 0)
                 throw;
             }
         }
       return *this;
    }

  template<typename _CharT, typename _Traits>
    typename basic_istream<_CharT, _Traits>::int_type
    basic_istream<_CharT, _Traits>::
    get(void)
    {
      const int_type __eof = traits_type::eof();
      int_type __c = __eof;
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              __c = this->rdbuf()->sbumpc();

              if (__c != __eof)
                _M_gcount = 1;
              else
                this->setstate(ios_base::eofbit | ios_base::failbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __c;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    get(char_type& __c)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __eof = traits_type::eof();
              int_type __bufval = this->rdbuf()->sbumpc();

              if (__bufval != __eof)
                {
                  _M_gcount = 1;
                  __c = traits_type::to_char_type(__bufval);
                }
              else
                this->setstate(ios_base::eofbit | ios_base::failbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    get(char_type* __s, streamsize __n, char_type __delim)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __idelim = traits_type::to_int_type(__delim);
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              int_type __c = __sb->sgetc();

              while (_M_gcount + 1 < __n && __c != __eof && __c != __idelim)
                {
                  *__s++ = traits_type::to_char_type(__c);
                  __c = __sb->snextc();
                  ++_M_gcount;
                }
              if (__c == __eof)
                this->setstate(ios_base::eofbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      *__s = char_type();
      if (!_M_gcount)
        this->setstate(ios_base::failbit);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    get(__streambuf_type& __sb, char_type __delim)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __idelim = traits_type::to_int_type(__delim);
              const int_type __eof = traits_type::eof();
              __streambuf_type* __this_sb = this->rdbuf();
              int_type __c = __this_sb->sgetc();

              while (__c != __eof && __c != __idelim
                     && (__sb.sputc(traits_type::to_char_type(__c)) != __eof))
                {
                  ++_M_gcount;
                  __c = __this_sb->snextc();
                }
              if (__c == __eof)
                this->setstate(ios_base::eofbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      if (!_M_gcount)
        this->setstate(ios_base::failbit);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    getline(char_type* __s, streamsize __n, char_type __delim)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __idelim = traits_type::to_int_type(__delim);
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              int_type __c = __sb->sgetc();

              while (_M_gcount + 1 < __n && __c != __eof && __c != __idelim)
                {
                  *__s++ = traits_type::to_char_type(__c);
                  __c = __sb->snextc();
                  ++_M_gcount;
                }
              if (__c == __eof)
                this->setstate(ios_base::eofbit);
              else
                {
                  if (__c == __idelim)
                    {
                      __sb->snextc();
                      ++_M_gcount;
                    }
                  else
                    this->setstate(ios_base::failbit);
                }
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      *__s = char_type();
      if (!_M_gcount)
        this->setstate(ios_base::failbit);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    ignore(streamsize __n, int_type __delim)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb && __n > 0)
        {
          try
            {
              const int_type __idelim = traits_type::to_int_type(__delim);
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              int_type __c = __sb->sbumpc();
              bool __testdelim = __c == __idelim;
              bool __testeof = __c == __eof;

              __n = min(__n, numeric_limits<streamsize>::max());
              while (_M_gcount < __n - 1 && !__testeof && !__testdelim)
                {
                  ++_M_gcount;
                  __c = __sb->sbumpc();
                  __testeof = __c == __eof;
                  __testdelim = __c == __idelim;
                }
              if ((_M_gcount == __n - 1 && !__testeof) || __testdelim)
                ++_M_gcount;
              if (__testeof)
                this->setstate(ios_base::eofbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    typename basic_istream<_CharT, _Traits>::int_type
    basic_istream<_CharT, _Traits>::
    peek(void)
    {
      int_type __c = traits_type::eof();
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            { __c = this->rdbuf()->sgetc(); }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __c;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    read(char_type* __s, streamsize __n)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              int_type __c = __sb->sgetc();

              while (_M_gcount < __n && __c != __eof)
                {
                  *__s++ = traits_type::to_char_type(__c);
                  ++_M_gcount;
                  __c = __sb->snextc();
                }
              if (__c == __eof)
                this->setstate(ios_base::eofbit | ios_base::failbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      else
        this->setstate(ios_base::failbit);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    streamsize
    basic_istream<_CharT, _Traits>::
    readsome(char_type* __s, streamsize __n)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __eof = traits_type::eof();
              streamsize __num = this->rdbuf()->in_avail();
              if (__num != static_cast<streamsize>(__eof))
                {
                  __num = min(__num, __n);
                  if (__num)
                    _M_gcount = this->rdbuf()->sgetn(__s, __num);
                }
              else
                this->setstate(ios_base::eofbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      else
        this->setstate(ios_base::failbit);
      return _M_gcount;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    putback(char_type __c)
    {
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              if (!__sb || __sb->sputbackc(__c) == __eof)
                this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      else
        this->setstate(ios_base::failbit);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    unget(void)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              if (!__sb || __eof == __sb->sungetc())
                this->setstate(ios_base::badbit);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      else
        this->setstate(ios_base::failbit);
      return *this;
    }

  template<typename _CharT, typename _Traits>
    int
    basic_istream<_CharT, _Traits>::
    sync(void)
    {
      int __ret = traits_type::eof();
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
              __streambuf_type* __sb = this->rdbuf();
              if (!__sb || __ret == __sb->pubsync())
                this->setstate(ios_base::badbit);
              else
                __ret = 0;
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_istream<_CharT, _Traits>::pos_type
    basic_istream<_CharT, _Traits>::
    tellg(void)
    {
      pos_type __ret = pos_type(-1);
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {
             __ret = this->rdbuf()->pubseekoff(0, ios_base::cur, ios_base::in);
            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return __ret;
    }


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    seekg(pos_type __pos)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {


              pos_type __err = this->rdbuf()->pubseekpos(__pos, ios_base::in);


              if (__err == pos_type(off_type(-1)))
                this->setstate(ios_base::failbit);

            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    basic_istream<_CharT, _Traits>::
    seekg(off_type __off, ios_base::seekdir __dir)
    {
      _M_gcount = 0;
      sentry __cerb(*this, true);
      if (__cerb)
        {
          try
            {


              pos_type __err = this->rdbuf()->pubseekoff(__off, __dir,
                                                         ios_base::in);


              if (__err == pos_type(off_type(-1)))
                this->setstate(ios_base::failbit);

            }
          catch(exception& __fail)
            {


              this->setstate(ios_base::badbit);
              if ((this->exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      return *this;
    }


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    operator>>(basic_istream<_CharT, _Traits>& __in, _CharT& __c)
    {
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typename __istream_type::sentry __cerb(__in, false);
      if (__cerb)
        {
          try
            { __in.get(__c); }
          catch(exception& __fail)
            {


              __in.setstate(ios_base::badbit);
              if ((__in.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      else
        __in.setstate(ios_base::failbit);
      return __in;
    }

  template<typename _CharT, typename _Traits>
    basic_istream<_CharT, _Traits>&
    operator>>(basic_istream<_CharT, _Traits>& __in, _CharT* __s)
    {
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef typename __istream_type::__streambuf_type __streambuf_type;
      typedef typename _Traits::int_type int_type;
      typedef _CharT char_type;
      typedef ctype<_CharT> __ctype_type;
      streamsize __extracted = 0;

      typename __istream_type::sentry __cerb(__in, false);
      if (__cerb)
        {
          try
            {

              streamsize __num = __in.width();
              if (__num == 0)
                __num = numeric_limits<streamsize>::max();

              const __ctype_type& __ctype = use_facet<__ctype_type>(__in.getloc());
              const int_type __eof = _Traits::eof();
              __streambuf_type* __sb = __in.rdbuf();
              int_type __c = __sb->sgetc();

              while (__extracted < __num - 1
                     && __c != __eof && !__ctype.is(ctype_base::space, __c))
                {
                  *__s++ = __c;
                  ++__extracted;
                  __c = __sb->snextc();
                }
              if (__c == __eof)
                __in.setstate(ios_base::eofbit);



              *__s = char_type();

              __in.width(0);
            }
          catch(exception& __fail)
            {


              __in.setstate(ios_base::badbit);
              if ((__in.exceptions() & ios_base::badbit) != 0)
                throw;
            }
        }
      if (!__extracted)
        __in.setstate(ios_base::failbit);
      return __in;
    }


  template<typename _CharT, typename _Traits>
    basic_istream<_CharT,_Traits>&
    ws(basic_istream<_CharT,_Traits>& __in)
    {
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef typename __istream_type::__streambuf_type __streambuf_type;
      typedef typename __istream_type::__ctype_type __ctype_type;
      typedef typename __istream_type::int_type __int_type;

      const __ctype_type& __ctype = use_facet<__ctype_type>(__in.getloc());
      const __int_type __eof = _Traits::eof();
      __streambuf_type* __sb = __in.rdbuf();
      __int_type __c = __sb->sgetc();

      while (__c != __eof && __ctype.is(ctype_base::space, __c))
        __c = __sb->snextc();
      if (__c == __eof)
        __in.setstate(ios_base::eofbit);

      return __in;
    }


  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_istream<_CharT, _Traits>&
    operator>>(basic_istream<_CharT, _Traits>& __in,
               basic_string<_CharT, _Traits, _Alloc>& __str)
    {
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef typename __istream_type::int_type __int_type;
      typedef typename __istream_type::__streambuf_type __streambuf_type;
      typedef typename __istream_type::__ctype_type __ctype_type;
      typedef basic_string<_CharT, _Traits, _Alloc> __string_type;
      typedef typename __string_type::size_type __size_type;
      __size_type __extracted = 0;

      typename __istream_type::sentry __cerb(__in, false);
      if (__cerb)
        {
          __str.erase();
          streamsize __w = __in.width();
          __size_type __n;
          __n = __w > 0 ? static_cast<__size_type>(__w) : __str.max_size();

          const __ctype_type& __ctype = use_facet<__ctype_type>(__in.getloc());
          const __int_type __eof = _Traits::eof();
          __streambuf_type* __sb = __in.rdbuf();
          __int_type __c = __sb->sgetc();

          while (__extracted < __n
                 && __c != __eof && !__ctype.is(ctype_base::space, __c))
            {
              __str += _Traits::to_char_type(__c);
              ++__extracted;
              __c = __sb->snextc();
            }
          if (__c == __eof)
            __in.setstate(ios_base::eofbit);
          __in.width(0);
        }


      if (!__extracted)
        __in.setstate (ios_base::failbit);

      return __in;
    }

  template<typename _CharT, typename _Traits, typename _Alloc>
    basic_istream<_CharT, _Traits>&
    getline(basic_istream<_CharT, _Traits>& __in,
            basic_string<_CharT, _Traits, _Alloc>& __str, _CharT __delim)
    {
      typedef basic_istream<_CharT, _Traits> __istream_type;
      typedef typename __istream_type::int_type __int_type;
      typedef typename __istream_type::__streambuf_type __streambuf_type;
      typedef typename __istream_type::__ctype_type __ctype_type;
      typedef basic_string<_CharT, _Traits, _Alloc> __string_type;
      typedef typename __string_type::size_type __size_type;

      __size_type __extracted = 0;
      bool __testdelim = false;
      typename __istream_type::sentry __cerb(__in, true);
      if (__cerb)
        {
          __str.erase();
          __size_type __n = __str.max_size();

          __int_type __idelim = _Traits::to_int_type(__delim);
          __streambuf_type* __sb = __in.rdbuf();
          __int_type __c = __sb->sbumpc();
          const __int_type __eof = _Traits::eof();
          __testdelim = __c == __idelim;

          while (__extracted <= __n && __c != __eof && !__testdelim)
            {
              __str += _Traits::to_char_type(__c);
              ++__extracted;
              __c = __sb->sbumpc();
              __testdelim = __c == __idelim;
            }
          if (__c == __eof)
            __in.setstate(ios_base::eofbit);
        }
      if (!__extracted && !__testdelim)
        __in.setstate(ios_base::failbit);
      return __in;
    }

  template<class _CharT, class _Traits, class _Alloc>
    inline basic_istream<_CharT,_Traits>&
    getline(basic_istream<_CharT, _Traits>& __in,
            basic_string<_CharT,_Traits,_Alloc>& __str)
    { return getline(__in, __str, __in.widen('\n')); }




  extern template class basic_istream<char>;
  extern template istream& ws(istream&);
  extern template istream& operator>>(istream&, char&);
  extern template istream& operator>>(istream&, char*);
  extern template istream& operator>>(istream&, unsigned char&);
  extern template istream& operator>>(istream&, signed char&);
  extern template istream& operator>>(istream&, unsigned char*);
  extern template istream& operator>>(istream&, signed char*);

  extern template class basic_istream<wchar_t>;
  extern template wistream& ws(wistream&);
  extern template wistream& operator>>(wistream&, wchar_t&);
  extern template wistream& operator>>(wistream&, wchar_t*);
}
# 288 "/usr/include/c++3.1/istream" 2 3
# 47 "/usr/include/c++3.1/iostream" 2 3

namespace std
{
  extern istream cin;
  extern ostream cout;
  extern ostream cerr;
  extern ostream clog;
# 62 "/usr/include/c++3.1/iostream" 3
  static ios_base::Init __ioinit;
}
# 19 "../inXDB/DB/TypeGen.cc" 2
# 1 "../inXDB/DB/inXDBC++Format.h" 1



#ident "@(#)$Id: inXDBC++Format.h 1.8 Sat, 27 Oct 2001 21:18:21 -0700 tmwg $ -- Copyright (c) 1998-2001 inX Services"
# 13 "../inXDB/DB/inXDBC++Format.h"
# 1 "/usr/include/c++3.1/fstream" 1 3
# 44 "/usr/include/c++3.1/fstream" 3




# 1 "/usr/include/c++3.1/i686-inX-linux/bits/basic_file.h" 1 3
# 43 "/usr/include/c++3.1/i686-inX-linux/bits/basic_file.h" 3




namespace std
{

  template<typename _CharT>
    class __basic_file;


  template<>
    class __basic_file<char>
    {

      __c_file* _M_cfile;

      bool _M_cfile_created;

    public:
      __basic_file(__c_lock* __lock = 0);

      void
      _M_open_mode(ios_base::openmode __mode, int& __p_mode, int& __rw_mode,
                   char* __c_mode);

      __basic_file*
      open(const char* __name, ios_base::openmode __mode, int __prot = 0664);

      __basic_file*
      sys_open(__c_file* __file, ios_base::openmode __mode);

      char
      sys_getc();

      char
      sys_ungetc(char);

      __basic_file*
      close();

      bool
      is_open() const;

      int
      fd();

      ~__basic_file();

      streamsize
      xsputn(const char* __s, streamsize __n);

      streamsize
      xsgetn(char* __s, streamsize __n);

      streamoff
      seekoff(streamoff __off, ios_base::seekdir __way,
              ios_base::openmode __mode = ios_base::in | ios_base::out);

      streamoff
      seekpos(streamoff __pos,
              ios_base::openmode __mode = ios_base::in | ios_base::out);

      int
      sync();
    };
}
# 49 "/usr/include/c++3.1/fstream" 2 3


namespace std
{
  template<typename _CharT, typename _Traits>
    class basic_filebuf : public basic_streambuf<_CharT, _Traits>
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename traits_type::int_type int_type;
      typedef typename traits_type::pos_type pos_type;
      typedef typename traits_type::off_type off_type;


      typedef basic_streambuf<char_type, traits_type> __streambuf_type;
      typedef basic_filebuf<char_type, traits_type> __filebuf_type;
      typedef __basic_file<char> __file_type;
      typedef typename traits_type::state_type __state_type;
      typedef codecvt<char_type, char, __state_type> __codecvt_type;
      typedef typename __codecvt_type::result __res_type;
      typedef ctype<char_type> __ctype_type;

      friend class ios_base;

    protected:


      __c_lock _M_lock;


      __file_type _M_file;


      __state_type _M_state_cur;
      __state_type _M_state_beg;


      bool _M_buf_allocated;


      char_type _M_unbuf[4];


      bool _M_last_overflowed;

    public:

      basic_filebuf();


      basic_filebuf(__c_file* __f, ios_base::openmode __mode,
                    int_type __s = static_cast<int_type>(8192));


      int
      fd();

      virtual
      ~basic_filebuf()
      {
        this->close();
        _M_last_overflowed = false;
      }


      bool
      is_open() const { return _M_file.is_open(); }

      __filebuf_type*
      open(const char* __s, ios_base::openmode __mode);

      __filebuf_type*
      close();

    protected:
      void
      _M_allocate_internal_buffer();

      void
      _M_destroy_internal_buffer();


      virtual streamsize
      showmanyc();





      virtual int_type
      underflow();

      virtual int_type
      pbackfail(int_type __c = _Traits::eof());
# 154 "/usr/include/c++3.1/fstream" 3
      virtual int_type
      overflow(int_type __c = _Traits::eof());
# 164 "/usr/include/c++3.1/fstream" 3
      int_type
      _M_really_overflow(int_type __c = _Traits::eof());



      void
      _M_convert_to_external(char_type*, streamsize, streamsize&, streamsize&);

      virtual __streambuf_type*
      setbuf(char_type* __s, streamsize __n);

      virtual pos_type
      seekoff(off_type __off, ios_base::seekdir __way,
              ios_base::openmode __mode = ios_base::in | ios_base::out);

      virtual pos_type
      seekpos(pos_type __pos,
              ios_base::openmode __mode = ios_base::in | ios_base::out);

      virtual int
      sync()
      {
        bool __testput = _M_out_cur && _M_out_beg < _M_out_end;



        if (__testput && !_M_file.sync())
          {




            streamoff __cur = _M_file.seekoff(0, ios_base::cur);
            off_type __off = _M_out_cur - _M_out_beg;
            _M_really_overflow();
            _M_file.seekpos(__cur + __off);
          }
        _M_last_overflowed = false;
        return 0;
      }

      virtual void
      imbue(const locale& __loc);

      virtual streamsize
      xsgetn(char_type* __s, streamsize __n)
      {
        streamsize __ret = 0;

        if (_M_pback_init)
          {
            while (__ret < __n && _M_in_cur < _M_in_end)
              {
                *__s = *_M_in_cur;
                ++__ret;
                ++__s;
                ++_M_in_cur;
              }
            _M_pback_destroy();
          }
        if (__ret < __n)
          __ret += __streambuf_type::xsgetn(__s, __n - __ret);
        return __ret;
      }

      virtual streamsize
      xsputn(const char_type* __s, streamsize __n)
      {
        _M_pback_destroy();
        return __streambuf_type::xsputn(__s, __n);
      }

      void
      _M_output_unshift();
    };







  template<typename _CharT, typename _Traits>
    class basic_ifstream : public basic_istream<_CharT, _Traits>
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename traits_type::int_type int_type;
      typedef typename traits_type::pos_type pos_type;
      typedef typename traits_type::off_type off_type;


      typedef basic_filebuf<char_type, traits_type> __filebuf_type;
      typedef basic_istream<char_type, traits_type> __istream_type;

    private:
      __filebuf_type _M_filebuf;

    public:


      basic_ifstream()
      : __istream_type(__null), _M_filebuf()
      { this->init(&_M_filebuf); }
# 279 "/usr/include/c++3.1/fstream" 3
      explicit
      basic_ifstream(const char* __s, ios_base::openmode __mode = ios_base::in)
      : __istream_type(__null), _M_filebuf()
      {
        this->init(&_M_filebuf);
        this->open(__s, __mode);
      }

      ~basic_ifstream()
      { }






      __filebuf_type*
      rdbuf() const
      { return const_cast<__filebuf_type*>(&_M_filebuf); }

      bool
      is_open() { return _M_filebuf.is_open(); }

      void
      open(const char* __s, ios_base::openmode __mode = ios_base::in)
      {
        if (!_M_filebuf.open(__s, __mode | ios_base::in))
          this->setstate(ios_base::failbit);
      }


      void
      close()
      {
        if (!_M_filebuf.close())
          this->setstate(ios_base::failbit);
      }
    };






  template<typename _CharT, typename _Traits>
    class basic_ofstream : public basic_ostream<_CharT,_Traits>
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename traits_type::int_type int_type;
      typedef typename traits_type::pos_type pos_type;
      typedef typename traits_type::off_type off_type;


      typedef basic_filebuf<char_type, traits_type> __filebuf_type;
      typedef basic_ostream<char_type, traits_type> __ostream_type;

    private:
      __filebuf_type _M_filebuf;

    public:


      basic_ofstream()
      : __ostream_type(__null), _M_filebuf()
      { this->init(&_M_filebuf); }
# 356 "/usr/include/c++3.1/fstream" 3
      explicit
      basic_ofstream(const char* __s,
                     ios_base::openmode __mode = ios_base::out|ios_base::trunc)
      : __ostream_type(__null), _M_filebuf()
      {
        this->init(&_M_filebuf);
        this->open(__s, __mode);
      }

      ~basic_ofstream()
      { }






      __filebuf_type*
      rdbuf() const
      { return const_cast<__filebuf_type*>(&_M_filebuf); }





      bool
      is_open() { return _M_filebuf.is_open(); }
# 392 "/usr/include/c++3.1/fstream" 3
      void
      open(const char* __s,
           ios_base::openmode __mode = ios_base::out | ios_base::trunc)
      {
        if (!_M_filebuf.open(__s, __mode | ios_base::out))
          this->setstate(ios_base::failbit);
      }


      void
      close()
      {
        if (!_M_filebuf.close())
          this->setstate(ios_base::failbit);
      }
    };






  template<typename _CharT, typename _Traits>
    class basic_fstream : public basic_iostream<_CharT, _Traits>
    {
    public:

      typedef _CharT char_type;
      typedef _Traits traits_type;
      typedef typename traits_type::int_type int_type;
      typedef typename traits_type::pos_type pos_type;
      typedef typename traits_type::off_type off_type;


      typedef basic_filebuf<char_type, traits_type> __filebuf_type;
      typedef basic_ios<char_type, traits_type> __ios_type;
      typedef basic_iostream<char_type, traits_type> __iostream_type;

    private:
      __filebuf_type _M_filebuf;

    public:


      basic_fstream()
      : __iostream_type(__null), _M_filebuf()
      { this->init(&_M_filebuf); }
# 448 "/usr/include/c++3.1/fstream" 3
      explicit
      basic_fstream(const char* __s,
                    ios_base::openmode __mode = ios_base::in | ios_base::out)
      : __iostream_type(__null), _M_filebuf()
      {
        this->init(&_M_filebuf);
        this->open(__s, __mode);
      }

      ~basic_fstream()
      { }






      __filebuf_type*
      rdbuf() const
      { return const_cast<__filebuf_type*>(&_M_filebuf); }





      bool
      is_open() { return _M_filebuf.is_open(); }
# 484 "/usr/include/c++3.1/fstream" 3
      void
      open(const char* __s,
           ios_base::openmode __mode = ios_base::in | ios_base::out)
      {
        if (!_M_filebuf.open(__s, __mode))
          setstate(ios_base::failbit);
      }


      void
      close()
      {
        if (!_M_filebuf.close())
          setstate(ios_base::failbit);
      }
    };
}





# 1 "/usr/include/c++3.1/bits/fstream.tcc" 1 3
# 39 "/usr/include/c++3.1/bits/fstream.tcc" 3

namespace std
{
  template<typename _CharT, typename _Traits>
    void
    basic_filebuf<_CharT, _Traits>::
    _M_allocate_internal_buffer()
    {
      if (!_M_buf && _M_buf_size_opt)
        {
          _M_buf_size = _M_buf_size_opt;

          if (_M_buf_size != 1)
            {

              try { _M_buf = new char_type[_M_buf_size]; }
              catch(...)
                {
                  delete [] _M_buf;
                  throw;
                }
              _M_buf_allocated = true;
            }
          else
            _M_buf = _M_unbuf;
        }
    }


  template<typename _CharT, typename _Traits>
    void
    basic_filebuf<_CharT, _Traits>::
    _M_destroy_internal_buffer()
    {
      if (_M_buf_allocated)
        {
          delete [] _M_buf;
          _M_buf = __null;
          _M_buf_allocated = false;
          this->setg(__null, __null, __null);
          this->setp(__null, __null);
        }
      else
        {
          if (_M_buf == _M_unbuf)
            {
              _M_buf = __null;
              this->setg(__null, __null, __null);
              this->setp(__null, __null);
            }
        }
    }

  template<typename _CharT, typename _Traits>
    basic_filebuf<_CharT, _Traits>::
    basic_filebuf()
    : __streambuf_type(), _M_file(&_M_lock), _M_state_cur(__state_type()),
    _M_state_beg(__state_type()), _M_buf_allocated(false),
    _M_last_overflowed(false)
    { _M_buf_unified = true; }

  template<typename _CharT, typename _Traits>
    basic_filebuf<_CharT, _Traits>::
    basic_filebuf(__c_file* __f, ios_base::openmode __mode, int_type __s)
    : __streambuf_type(), _M_file(&_M_lock), _M_state_cur(__state_type()),
    _M_state_beg(__state_type()), _M_buf_allocated(false),
    _M_last_overflowed(false)
    {
      _M_buf_unified = true;
      _M_file.sys_open(__f, __mode);
      if (this->is_open())
        {
          _M_mode = __mode;
          if (__s)
            {
              _M_buf_size_opt = __s;
              _M_allocate_internal_buffer();
              _M_set_indeterminate();
            }
        }
    }

  template<typename _CharT, typename _Traits>
    int
    basic_filebuf<_CharT, _Traits>::
    fd()
    { return _M_file.fd(); }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::__filebuf_type*
    basic_filebuf<_CharT, _Traits>::
    open(const char* __s, ios_base::openmode __mode)
    {
      __filebuf_type *__ret = __null;
      if (!this->is_open())
        {
          _M_file.open(__s, __mode);
          if (this->is_open())
            {
              _M_allocate_internal_buffer();
              _M_mode = __mode;


              _M_set_indeterminate();
              if ((__mode & ios_base::ate)
                  && this->seekoff(0, ios_base::end, __mode) < 0)
                this->close();
              __ret = this;
            }
        }
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::__filebuf_type*
    basic_filebuf<_CharT, _Traits>::
    close()
    {
      __filebuf_type *__ret = __null;
      if (this->is_open())
        {
          const int_type __eof = traits_type::eof();
          bool __testput = _M_out_cur && _M_out_beg < _M_out_end;
          if (__testput && _M_really_overflow(__eof) == __eof)
            return __ret;


          _M_mode = ios_base::openmode(0);
          _M_destroy_internal_buffer();
          _M_pback_destroy();
# 179 "/usr/include/c++3.1/bits/fstream.tcc" 3
          if (_M_file.close())
            __ret = this;
        }

      _M_last_overflowed = false;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    streamsize
    basic_filebuf<_CharT, _Traits>::
    showmanyc()
    {
      streamsize __ret = -1;
      bool __testin = _M_mode & ios_base::in;

      if (__testin && this->is_open())
        {
          if (_M_in_cur < _M_in_end)
            __ret = _M_in_end - _M_in_cur;
          else
            __ret = 0;
        }
      _M_last_overflowed = false;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::int_type
    basic_filebuf<_CharT, _Traits>::
    underflow()
    {
      int_type __ret = traits_type::eof();
      bool __testin = _M_mode & ios_base::in;
      bool __testout = _M_mode & ios_base::out;

      if (__testin)
        {



          if (_M_pback_init)
            {
              _M_pback_destroy();
              if (_M_in_cur < _M_in_end)
                return traits_type::to_int_type(*_M_in_cur);
            }



          bool __testget = _M_in_cur && _M_in_beg < _M_in_cur;
          bool __testinit = _M_is_indeterminate();
          if (__testget)
            {
              if (__testout)
                _M_really_overflow();




              else
                _M_file.seekoff(_M_in_cur - _M_in_beg,
                                ios_base::cur, ios_base::in);
            }

          if (__testinit || __testget)
            {
              const locale __loc = this->getloc();
              const __codecvt_type& __cvt = use_facet<__codecvt_type>(__loc);

              streamsize __elen = 0;
              streamsize __ilen = 0;
              if (__cvt.always_noconv())
                {
                  __elen = _M_file.xsgetn(reinterpret_cast<char*>(_M_in_beg),
                                          _M_buf_size);
                  __ilen = __elen;
                }
              else
                {
                  char* __buf = static_cast<char*>(__builtin_alloca(_M_buf_size));
                  __elen = _M_file.xsgetn(__buf, _M_buf_size);

                  const char* __eend;
                  char_type* __iend;
                  __res_type __r = __cvt.in(_M_state_cur, __buf,
                                            __buf + __elen, __eend, _M_in_beg,
                                            _M_in_beg + _M_buf_size, __iend);
                  if (__r == codecvt_base::ok)
                    __ilen = __iend - _M_in_beg;
                  else
                    {

                      __ilen = 0;
                      _M_file.seekoff(-__elen, ios_base::cur, ios_base::in);
                    }
                }

              if (0 < __ilen)
                {
                  _M_set_determinate(__ilen);
                  if (__testout)
                    _M_out_cur = _M_in_cur;
                  __ret = traits_type::to_int_type(*_M_in_cur);






                      _M_file.seekoff(-__elen, ios_base::cur, ios_base::in);



                }
            }
        }
      _M_last_overflowed = false;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::int_type
    basic_filebuf<_CharT, _Traits>::
    pbackfail(int_type __i)
    {
      int_type __ret = traits_type::eof();
      bool __testin = _M_mode & ios_base::in;

      if (__testin)
        {
          bool __testpb = _M_in_beg < _M_in_cur;
          char_type __c = traits_type::to_char_type(__i);
          bool __testeof = traits_type::eq_int_type(__i, __ret);

          if (__testpb)
            {
              bool __testout = _M_mode & ios_base::out;
              bool __testeq = traits_type::eq(__c, this->gptr()[-1]);



              if (!__testeof && __testeq)
                {
                  --_M_in_cur;
                  if (__testout)
                    --_M_out_cur;
                  __ret = __i;
                }
              else if (__testeof)
                {
                  --_M_in_cur;
                  if (__testout)
                    --_M_out_cur;
                  __ret = traits_type::not_eof(__i);
                }
              else if (!__testeof)
                {
                  --_M_in_cur;
                  if (__testout)
                    --_M_out_cur;
                  _M_pback_create();
                  *_M_in_cur = __c;
                  __ret = __i;
                }
            }
          else
            {


              this->seekoff(-1, ios_base::cur);
              this->underflow();
              if (!__testeof)
                {
                  if (!traits_type::eq(__c, *_M_in_cur))
                    {
                      _M_pback_create();
                      *_M_in_cur = __c;
                    }
                  __ret = __i;
                }
              else
                __ret = traits_type::not_eof(__i);
            }
        }
      _M_last_overflowed = false;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::int_type
    basic_filebuf<_CharT, _Traits>::
    overflow(int_type __c)
    {
      int_type __ret = traits_type::eof();
      bool __testput = _M_out_cur && _M_out_cur < _M_buf + _M_buf_size;
      bool __testout = _M_mode & ios_base::out;

      if (__testout)
        {
          if (__testput)
            {
              *_M_out_cur = traits_type::to_char_type(__c);
              _M_out_cur_move(1);
              __ret = traits_type::not_eof(__c);
            }
          else
            __ret = this->_M_really_overflow(__c);
        }

      _M_last_overflowed = false;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    void
    basic_filebuf<_CharT, _Traits>::
    _M_convert_to_external(_CharT* __ibuf, streamsize __ilen,
                           streamsize& __elen, streamsize& __plen)
    {
      const locale __loc = this->getloc();
      const __codecvt_type& __cvt = use_facet<__codecvt_type>(__loc);

      if (__cvt.always_noconv() && __ilen)
        {
          __elen += _M_file.xsputn(reinterpret_cast<char*>(__ibuf), __ilen);
          __plen += __ilen;
        }
      else
        {

          int __ext_multiplier = __cvt.encoding();
          if (__ext_multiplier == -1 || __ext_multiplier == 0)
            __ext_multiplier = sizeof(char_type);
          streamsize __blen = __ilen * __ext_multiplier;
          char* __buf = static_cast<char*>(__builtin_alloca(__blen));
          char* __bend;
          const char_type* __iend;
          __res_type __r = __cvt.out(_M_state_cur, __ibuf, __ibuf + __ilen,
                                     __iend, __buf, __buf + __blen, __bend);

          if (__r != codecvt_base::error)
            __blen = __bend - __buf;

          else
            __blen = 0;

          if (__blen)
            {
              __elen += _M_file.xsputn(__buf, __blen);
              __plen += __blen;
            }


          if (__r == codecvt_base::partial)
            {
              const char_type* __iresume = __iend;
              streamsize __rlen = _M_out_end - __iend;
              __r = __cvt.out(_M_state_cur, __iresume, __iresume + __rlen,
                              __iend, __buf, __buf + __blen, __bend);
              if (__r != codecvt_base::error)
                __rlen = __bend - __buf;
              else
                __rlen = 0;
              if (__rlen)
                {
                  __elen += _M_file.xsputn(__buf, __rlen);
                  __plen += __rlen;
                }
            }
        }
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::int_type
    basic_filebuf<_CharT, _Traits>::
    _M_really_overflow(int_type __c)
    {
      int_type __ret = traits_type::eof();
      bool __testput = _M_out_cur && _M_out_beg < _M_out_end;
      bool __testunbuffered = _M_file.is_open() && !_M_buf_size;

      if (__testput || __testunbuffered)
        {

          streamsize __elen = 0;
          streamsize __plen = 0;



          if (!__testunbuffered)
            _M_convert_to_external(_M_out_beg, _M_out_end - _M_out_beg,
                                   __elen, __plen);


          if (!traits_type::eq_int_type(__c, traits_type::eof()))
            {
              char_type __pending = traits_type::to_char_type(__c);
              _M_convert_to_external(&__pending, 1, __elen, __plen);
            }




          if (__elen == __plen && !_M_file.sync())
            {
              _M_set_indeterminate();
              __ret = traits_type::not_eof(__c);
            }
        }
      _M_last_overflowed = true;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::__streambuf_type*
    basic_filebuf<_CharT, _Traits>::
    setbuf(char_type* __s, streamsize __n)
    {
      if (!this->is_open() && __s == 0 && __n == 0)
        _M_buf_size_opt = 0;
      else if (__s && __n)
        {





          _M_destroy_internal_buffer();


          _M_buf = __s;
          _M_buf_size_opt = _M_buf_size = __n;
          _M_set_indeterminate();
        }
      _M_last_overflowed = false;
      return this;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::pos_type
    basic_filebuf<_CharT, _Traits>::
    seekoff(off_type __off, ios_base::seekdir __way, ios_base::openmode __mode)
    {
      pos_type __ret = pos_type(off_type(-1));
      bool __testin = (ios_base::in & _M_mode & __mode) != 0;
      bool __testout = (ios_base::out & _M_mode & __mode) != 0;


      int __width = use_facet<__codecvt_type>(_M_buf_locale).encoding();
      if (__width < 0)
        __width = 0;
      bool __testfail = __off != 0 && __width <= 0;

      if (this->is_open() && !__testfail && (__testin || __testout))
        {

          _M_pback_destroy();

          if (__way != ios_base::cur || __off != 0)
            {
              off_type __computed_off = __width * __off;

              bool __testget = _M_in_cur && _M_in_beg < _M_in_end;
              bool __testput = _M_out_cur && _M_out_beg < _M_out_end;


              if (__testput || _M_last_overflowed)
                {

                  this->sync();

                  _M_output_unshift();
                }


              else if (__testget && __way == ios_base::cur)
                __computed_off += _M_in_cur - _M_in_beg;

              __ret = _M_file.seekoff(__computed_off, __way, __mode);
              _M_set_indeterminate();
            }


          else
            {
              __ret = _M_file.seekoff(__off, ios_base::cur, __mode);
              __ret += max(_M_out_cur, _M_in_cur) - _M_buf;
            }
        }
      _M_last_overflowed = false;
      return __ret;
    }

  template<typename _CharT, typename _Traits>
    typename basic_filebuf<_CharT, _Traits>::pos_type
    basic_filebuf<_CharT, _Traits>::
    seekpos(pos_type __pos, ios_base::openmode __mode)
    {


      return this->seekoff(off_type(__pos), ios_base::beg, __mode);

    }

  template<typename _CharT, typename _Traits>
    void
    basic_filebuf<_CharT, _Traits>::
    _M_output_unshift()
    { }

  template<typename _CharT, typename _Traits>
    void
    basic_filebuf<_CharT, _Traits>::
    imbue(const locale& __loc)
    {
      bool __testbeg = gptr() == eback() && pptr() == pbase();

      if (__testbeg && _M_buf_locale != __loc)
        {
          _M_buf_locale = __loc;
          _M_buf_locale_init = true;
        }





      _M_last_overflowed = false;
    }




  extern template class basic_filebuf<char>;
  extern template class basic_filebuf<wchar_t>;
  extern template class basic_ifstream<char>;
  extern template class basic_ifstream<wchar_t>;
  extern template class basic_ofstream<char>;
  extern template class basic_ofstream<wchar_t>;
  extern template class basic_fstream<char>;
  extern template class basic_fstream<wchar_t>;
}
# 507 "/usr/include/c++3.1/fstream" 2 3
# 14 "../inXDB/DB/inXDBC++Format.h" 2


        namespace inXdb {

                class Format {







                        private:
                                std::ofstream File;
                                uint Indent;
                                uint Tab;
                                uint Column;
                                std::string Line;

                                void Do_indent();
                                void Do_tab_stop();
                                void Do_after_tab_stop();
                                int Find_break(const std::string &s,
                                                                                const std::string &break_pattern,
                                                                                const bool dont_check_space,
                                                                        int &start_from, uint &pattern_length,
                                                                                        bool &found_equals
                                                                  ) const;
                        protected:
                        public:
                                inline operator bool() {
                                        return bool(File);
                                }

                                inline Format &add_indent(const uint tabs) {
                                        Indent += tabs;

                                        return *this;
                                }
                                inline Format &remove_indent(const uint tabs) {
                                        if (tabs > Indent) {
                                                Indent = 0;
                                        } else {
                                                Indent -= tabs;
                                        }
                                        return *this;
                                }
                                static inline std::string add_indents(const char tabs) {
                                        return std::string("\x01") + tabs;
                                }
                                static inline std::string remove_indents(const char tabs) {
                                        return std::string("\x02") + tabs;
                                }

                                Format &operator <<(const std::string &s);
                                Format &operator <<(const char c);
                                Format &operator <<(const int i);
                                Format &operator <<(const uint u);
                                Format &operator <<(const long l);
                                Format &operator <<(const ulong u);
                                Format &operator <<(const double d);
                                inline Format &operator <<(Format &) {
                                        return *this;
                                }

                                Format(const char *file_name);
                                ~Format();
                };

        }
# 20 "../inXDB/DB/TypeGen.cc" 2
# 1 "../inXDB/DB/inXDB.h" 1



#ident "@(#)$Id: inXDB.h 1.5.1.84 Mon, 15 Apr 2002 13:48:51 -0700 tmwg $ -- Copyright (c) 1997-2002 inX Services"
# 15 "../inXDB/DB/inXDB.h"
# 1 "../object/MmapFile.h" 1



#ident "@(#)$Id: MmapFile.h 1.2 Tue, 08 Jan 2002 19:55:52 -0800 tmwg $ -- Copyright (c) 2000,2002 inX Services"
# 13 "../object/MmapFile.h"
# 1 "../object/File.h" 1



#ident "@(#)$Id: File.h 1.4 Tue, 08 Jan 2002 19:55:52 -0800 tmwg $ -- Copyright (c) 1999-2002 inX Services"
# 14 "../object/File.h"
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/uio.h" 1 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/sys/uio.h" 3
extern "C" {


# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/uio.h" 1 3
# 42 "/usr/lib/gcc/../../i686-inX-linux/include/bits/uio.h" 3
struct iovec
  {
    void *iov_base;
    size_t iov_len;
  };
# 30 "/usr/lib/gcc/../../i686-inX-linux/include/sys/uio.h" 2 3







extern ssize_t readv (int __fd, __const struct iovec *__vector, int __count)
     throw ();






extern ssize_t writev (int __fd, __const struct iovec *__vector, int __count)
     throw ();

}
# 15 "../object/File.h" 2







# 1 "../object/SignalObject.h" 1



#ident "@(#)$Id: SignalObject.h 1.1 Wed, 07 Nov 2001 09:33:14 -0800 tmwg $ -- Copyright (c) 1997-2001 inX Services"







# 1 "../object/inXObject.h" 1



#ident "@(#)$Id: inXObject.h 1.8 Wed, 17 Apr 2002 00:00:41 -0700 tmwg $ -- Copyright (c) 2001,2002 inX Services"
# 20 "../object/inXObject.h"
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/L_buffer.h" 1 3
# 36 "/usr/lib/gcc/../../i686-inX-linux/include/L_buffer.h" 3
extern "C" {




# 1 "/usr/lib/gcc/../../i686-inX-linux/include/nana-config.h" 1 3
# 42 "/usr/lib/gcc/../../i686-inX-linux/include/L_buffer.h" 2 3


# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 45 "/usr/lib/gcc/../../i686-inX-linux/include/L_buffer.h" 2 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stdarg.h" 1 3
# 46 "/usr/lib/gcc/../../i686-inX-linux/include/L_buffer.h" 2 3






typedef struct {
  size_t size;
  char *data;
  size_t free;
  int wraparound;
} L_BUFFER;
# 84 "/usr/lib/gcc/../../i686-inX-linux/include/L_buffer.h" 3
L_BUFFER *L_buffer_create(size_t size);

void L_buffer_wraparound(L_BUFFER *b, int wraparound);


void L_buffer_printf(L_BUFFER *b, const char *format, ...)
  __attribute__((format (printf, 2, 3)));




void L_buffer_vprintf(L_BUFFER *b, const char *format, va_list arg);

void L_buffer_puts(L_BUFFER *b, char *str);

void L_buffer_putchar(L_BUFFER *b, char c);


void L_buffer_dump(L_BUFFER *b, FILE *fp);


void L_buffer_dump_fi(L_BUFFER *b, const int fp);






void L_buffer_clear(L_BUFFER *b);

void L_buffer_delete(L_BUFFER *);


}
# 21 "../object/inXObject.h" 2
# 32 "../object/inXObject.h"
        namespace inXServices {


                typedef int LHandle;
                const LHandle LogFileClosed = -1;





                class inXException : public std::exception {
                        private:
                        protected:
                                static char What[4096];

                                std::string Type;
                                std::string Message;
                                std::string Function;
                                std::string File;
                                uint Line;

                                void start_exception_display(std::ostream &stream) const;
                                void end_exception_display(std::ostream &stream) const;
                        public:
                                inline const std::string &type() const;
                                inline const std::string &message() const;
                                inline const std::string &function() const;
                                inline const std::string &file() const;
                                inline uint line() const;

                                friend std::ostream &operator <<(std::ostream &stream,
                                                                                                                                const inXException &exception
                                                                                                                  );
                                virtual void show(std::ostream &stream) const;
                                const char *what() const throw();

                                virtual inXException &operator =(const inXException &e);

                                inXException();
                                inXException(const char *type, const char *message,
                                                                        const char *function, const char *file,
                                                                        const uint line
                                                                );
                                ~inXException() throw();
                };

                class inXObject {
                        public:
                                static bool Do_Expensive_Checks;
                                static bool Always_Log_Date_Time;
                        private:
                        protected:
                                static char *Program_Name;
                                static L_BUFFER *Argument_Log;
                                static LHandle Log_File;
                                static long Objects;

                                static void Logm(const bool to_stderr, const char *message);
                                static void Log(const bool to_stderr, const char *format, ...)
                                        __attribute__ ((format (printf, 2, 3)));
                                static void Log(const bool to_stderr, const timeval &when,
                                                                                const char *format, ...
                                                                   )
                                        __attribute__ ((format (printf, 3, 4)));

                                static void Log(const bool to_stderr, const char *format,
                                                                                va_list arg
                                                                        );
                                static void Log(const bool to_stderr, const timeval &when,
                                                                                const char *format, va_list arg
                                                                        );

                                virtual bool Expensive_verify_state() const;
                                virtual bool Verify_state() const;

                                void Make();

                                static void Open_log(const std::string &log_file_name);
                                static void Close_log();

                                static void Dup_program_name(const char *program_name);
                        public:
                                static void Args(const char *format, ...)
                                        __attribute__ ((format (printf, 1, 2)));
                                static void TimeArgs(const char *format, ...)
                                        __attribute__ ((format (printf, 1, 2)));

                                static inline const char *program_name();

                                static inline bool do_expensive_checks();

                                virtual int compare(const inXObject &object) const;

                                inline inXObject &operator =(const inXObject &);

                                static void dump_argument_log(const bool clear = false);

                                inXObject(const char *log_file_name = 0);
                                inXObject(const inXObject &);
                                virtual ~inXObject();
                };
# 189 "../object/inXObject.h"
        };

# 1 "../object/inXObject.i" 1



#ident "@(#)$Id: inXObject.i 1.4 Mon, 11 Mar 2002 05:27:34 -0800 tmwg $ -- Copyright (c) 2001,2002 inX Services"
# 13 "../object/inXObject.i"
# 1 "../object/inXObject.h" 1
# 14 "../object/inXObject.i" 2


        namespace inXServices {

inline const std::string &
inXException::type() const {
        return Type;
}

inline const std::string &
inXException::message() const {
        return Message;
}

inline const std::string &
inXException::function() const {
        return Function;
}

inline const std::string &
inXException::file() const {
        return File;
}

inline uint
inXException::line() const {
        return Line;
}
# 54 "../object/inXObject.i"
inline const char *
inXObject::program_name() {
        return Program_Name;
}

inline bool
inXObject::do_expensive_checks() {
        return Do_Expensive_Checks;
}

inline inXObject &
inXObject::operator =(const inXObject &) {
        return *this;
}
# 78 "../object/inXObject.i"
        };



inline int
get_errno() {
        return (*__errno_location ());
}

inline const char *
get_strerror() {
        return strerror((*__errno_location ()));
}
# 192 "../object/inXObject.h" 2
# 13 "../object/SignalObject.h" 2
# 1 "/usr/include/c++3.1/csignal" 1 3
# 48 "/usr/include/c++3.1/csignal" 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 1 3
# 31 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern "C" {

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigset.h" 1 3
# 103 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigset.h" 3
extern int __sigismember (__const __sigset_t *, int);
extern int __sigaddset (__sigset_t *, int);
extern int __sigdelset (__sigset_t *, int);
# 34 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3






typedef __sig_atomic_t sig_atomic_t;
# 56 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/signum.h" 1 3
# 57 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3
# 71 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
typedef void (*__sighandler_t) (int);




extern __sighandler_t __sysv_signal (int __sig, __sighandler_t __handler)
     throw ();

extern __sighandler_t sysv_signal (int __sig, __sighandler_t __handler)
     throw ();






extern __sighandler_t signal (int __sig, __sighandler_t __handler) throw ();
# 103 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern __sighandler_t bsd_signal (int __sig, __sighandler_t __handler) throw ();






extern int kill (__pid_t __pid, int __sig) throw ();






extern int killpg (__pid_t __pgrp, int __sig) throw ();



extern int raise (int __sig) throw ();



extern __sighandler_t ssignal (int __sig, __sighandler_t __handler) throw ();
extern int gsignal (int __sig) throw ();




extern void psignal (int __sig, __const char *__s) throw ();
# 140 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern int __sigpause (int __sig_or_mask, int __is_sig) throw ();




extern int sigpause (int __mask) throw ();
# 168 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern int sigblock (int __mask) throw ();


extern int sigsetmask (int __mask) throw ();


extern int siggetmask (void) throw ();
# 183 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
typedef __sighandler_t sighandler_t;




typedef __sighandler_t sig_t;
# 199 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/siginfo.h" 1 3
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/bits/siginfo.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/wordsize.h" 1 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/bits/siginfo.h" 2 3







typedef union sigval
  {
    int sival_int;
    void *sival_ptr;
  } sigval_t;
# 51 "/usr/lib/gcc/../../i686-inX-linux/include/bits/siginfo.h" 3
typedef struct siginfo
  {
    int si_signo;
    int si_errno;

    int si_code;

    union
      {
        int _pad[((128 / sizeof (int)) - 3)];


        struct
          {
            __pid_t si_pid;
            __uid_t si_uid;
          } _kill;


        struct
          {
            unsigned int _timer1;
            unsigned int _timer2;
          } _timer;


        struct
          {
            __pid_t si_pid;
            __uid_t si_uid;
            sigval_t si_sigval;
          } _rt;


        struct
          {
            __pid_t si_pid;
            __uid_t si_uid;
            int si_status;
            __clock_t si_utime;
            __clock_t si_stime;
          } _sigchld;


        struct
          {
            void *si_addr;
          } _sigfault;


        struct
          {
            long int si_band;
            int si_fd;
          } _sigpoll;
      } _sifields;
  } siginfo_t;
# 128 "/usr/lib/gcc/../../i686-inX-linux/include/bits/siginfo.h" 3
enum
{
  SI_ASYNCNL = -6,

  SI_SIGIO,

  SI_ASYNCIO,

  SI_MESGQ,

  SI_TIMER,

  SI_QUEUE,

  SI_USER,

  SI_KERNEL = 0x80

};



enum
{
  ILL_ILLOPC = 1,

  ILL_ILLOPN,

  ILL_ILLADR,

  ILL_ILLTRP,

  ILL_PRVOPC,

  ILL_PRVREG,

  ILL_COPROC,

  ILL_BADSTK

};


enum
{
  FPE_INTDIV = 1,

  FPE_INTOVF,

  FPE_FLTDIV,

  FPE_FLTOVF,

  FPE_FLTUND,

  FPE_FLTRES,

  FPE_FLTINV,

  FPE_FLTSUB

};


enum
{
  SEGV_MAPERR = 1,

  SEGV_ACCERR

};


enum
{
  BUS_ADRALN = 1,

  BUS_ADRERR,

  BUS_OBJERR

};


enum
{
  TRAP_BRKPT = 1,

  TRAP_TRACE

};


enum
{
  CLD_EXITED = 1,

  CLD_KILLED,

  CLD_DUMPED,

  CLD_TRAPPED,

  CLD_STOPPED,

  CLD_CONTINUED

};


enum
{
  POLL_IN = 1,

  POLL_OUT,

  POLL_MSG,

  POLL_ERR,

  POLL_PRI,

  POLL_HUP

};
# 271 "/usr/lib/gcc/../../i686-inX-linux/include/bits/siginfo.h" 3
struct __pthread_attr_s;

typedef struct sigevent
  {
    sigval_t sigev_value;
    int sigev_signo;
    int sigev_notify;

    union
      {
        int _pad[((64 / sizeof (int)) - 3)];

        struct
          {
            void (*_function) (sigval_t);
            struct __pthread_attr_s *_attribute;
          } _sigev_thread;
      } _sigev_un;
  } sigevent_t;






enum
{
  SIGEV_SIGNAL = 0,

  SIGEV_NONE,

  SIGEV_THREAD

};
# 200 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3



extern int sigemptyset (sigset_t *__set) throw ();


extern int sigfillset (sigset_t *__set) throw ();


extern int sigaddset (sigset_t *__set, int __signo) throw ();


extern int sigdelset (sigset_t *__set, int __signo) throw ();


extern int sigismember (__const sigset_t *__set, int __signo) throw ();



extern int sigisemptyset (__const sigset_t *__set) throw ();


extern int sigandset (sigset_t *__set, __const sigset_t *__left,
                      __const sigset_t *__right) throw ();


extern int sigorset (sigset_t *__set, __const sigset_t *__left,
                     __const sigset_t *__right) throw ();




# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigaction.h" 1 3
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigaction.h" 3
struct sigaction
  {


    union
      {

        __sighandler_t sa_handler;

        void (*sa_sigaction) (int, siginfo_t *, void *);
      }
    __sigaction_handler;







    __sigset_t sa_mask;


    int sa_flags;


    void (*sa_restorer) (void);
  };
# 233 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3


extern int sigprocmask (int __how, __const sigset_t *__restrict __set,
                        sigset_t *__restrict __oset) throw ();



extern int sigsuspend (__const sigset_t *__set) throw ();


extern int sigaction (int __sig, __const struct sigaction *__restrict __act,
                      struct sigaction *__restrict __oact) throw ();


extern int sigpending (sigset_t *__set) throw ();



extern int sigwait (__const sigset_t *__restrict __set, int *__restrict __sig)
     throw ();



extern int sigwaitinfo (__const sigset_t *__restrict __set,
                        siginfo_t *__restrict __info) throw ();



extern int sigtimedwait (__const sigset_t *__restrict __set,
                         siginfo_t *__restrict __info,
                         __const struct timespec *__restrict __timeout)
     throw ();



extern int sigqueue (__pid_t __pid, int __sig, __const union sigval __val)
     throw ();
# 278 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern __const char *__const _sys_siglist[64];
extern __const char *__const sys_siglist[64];


struct sigvec
  {
    __sighandler_t sv_handler;
    int sv_mask;

    int sv_flags;

  };
# 302 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern int sigvec (int __sig, __const struct sigvec *__vec,
                   struct sigvec *__ovec) throw ();



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigcontext.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigcontext.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/asm/sigcontext.h" 1 3
# 18 "/usr/lib/gcc/../../i686-inX-linux/include/asm/sigcontext.h" 3
struct _fpreg {
        unsigned short significand[4];
        unsigned short exponent;
};

struct _fpxreg {
        unsigned short significand[4];
        unsigned short exponent;
        unsigned short padding[3];
};

struct _xmmreg {
        unsigned long element[4];
};

struct _fpstate {

        unsigned long cw;
        unsigned long sw;
        unsigned long tag;
        unsigned long ipoff;
        unsigned long cssel;
        unsigned long dataoff;
        unsigned long datasel;
        struct _fpreg _st[8];
        unsigned short status;
        unsigned short magic;


        unsigned long _fxsr_env[6];
        unsigned long mxcsr;
        unsigned long reserved;
        struct _fpxreg _fxsr_st[8];
        struct _xmmreg _xmm[8];
        unsigned long padding[56];
};



struct sigcontext {
        unsigned short gs, __gsh;
        unsigned short fs, __fsh;
        unsigned short es, __esh;
        unsigned short ds, __dsh;
        unsigned long edi;
        unsigned long esi;
        unsigned long ebp;
        unsigned long esp;
        unsigned long ebx;
        unsigned long edx;
        unsigned long ecx;
        unsigned long eax;
        unsigned long trapno;
        unsigned long err;
        unsigned long eip;
        unsigned short cs, __csh;
        unsigned long eflags;
        unsigned long esp_at_signal;
        unsigned short ss, __ssh;
        struct _fpstate * fpstate;
        unsigned long oldmask;
        unsigned long cr2;
};
# 29 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigcontext.h" 2 3
# 308 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3


extern int sigreturn (struct sigcontext *__scp) throw ();
# 320 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern int siginterrupt (int __sig, int __interrupt) throw ();

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigstack.h" 1 3
# 26 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigstack.h" 3
struct sigstack
  {
    void *ss_sp;
    int ss_onstack;
  };



enum
{
  SS_ONSTACK = 1,

  SS_DISABLE

};
# 50 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigstack.h" 3
typedef struct sigaltstack
  {
    void *ss_sp;
    int ss_flags;
    size_t ss_size;
  } stack_t;
# 323 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3

# 1 "/usr/lib/gcc/../../i686-inX-linux/include/ucontext.h" 1 3
# 27 "/usr/lib/gcc/../../i686-inX-linux/include/ucontext.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/sys/ucontext.h" 1 3
# 27 "/usr/lib/gcc/../../i686-inX-linux/include/sys/ucontext.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/sigcontext.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/sys/ucontext.h" 2 3



typedef int greg_t;





typedef greg_t gregset_t[19];



enum
{
  REG_GS = 0,

  REG_FS,

  REG_ES,

  REG_DS,

  REG_EDI,

  REG_ESI,

  REG_EBP,

  REG_ESP,

  REG_EBX,

  REG_EDX,

  REG_ECX,

  REG_EAX,

  REG_TRAPNO,

  REG_ERR,

  REG_EIP,

  REG_CS,

  REG_EFL,

  REG_UESP,

  REG_SS

};



struct _libc_fpreg
{
  unsigned short int significand[4];
  unsigned short int exponent;
};

struct _libc_fpstate
{
  unsigned long int cw;
  unsigned long int sw;
  unsigned long int tag;
  unsigned long int ipoff;
  unsigned long int cssel;
  unsigned long int dataoff;
  unsigned long int datasel;
  struct _libc_fpreg _st[8];
  unsigned long int status;
};


typedef struct _libc_fpstate *fpregset_t;


typedef struct
  {
    gregset_t gregs;


    fpregset_t fpregs;
    unsigned long int oldmask;
    unsigned long int cr2;
  } mcontext_t;


typedef struct ucontext
  {
    unsigned long int uc_flags;
    struct ucontext *uc_link;
    stack_t uc_stack;
    mcontext_t uc_mcontext;
    __sigset_t uc_sigmask;
    struct _libc_fpstate __fpregs_mem;
  } ucontext_t;
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/ucontext.h" 2 3

extern "C" {


extern int getcontext (ucontext_t *__ucp) throw ();


extern int setcontext (__const ucontext_t *__ucp) throw ();



extern int swapcontext (ucontext_t *__restrict __oucp,
                        __const ucontext_t *__restrict __ucp) throw ();







extern void makecontext (ucontext_t *__ucp, void (*__func) (void),
                         int __argc, ...) throw ();

}
# 325 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 2 3





extern int sigstack (struct sigstack *__ss, struct sigstack *__oss) throw ();



extern int sigaltstack (__const struct sigaltstack *__restrict __ss,
                        struct sigaltstack *__restrict __oss) throw ();







extern int sighold (int __sig) throw ();


extern int sigrelse (int __sig) throw ();


extern int sigignore (int __sig) throw ();


extern __sighandler_t sigset (int __sig, __sighandler_t __disp) throw ();
# 365 "/usr/lib/gcc/../../i686-inX-linux/include/signal.h" 3
extern int __libc_current_sigrtmin (void) throw ();

extern int __libc_current_sigrtmax (void) throw ();



}
# 50 "/usr/include/c++3.1/csignal" 2 3




namespace std
{
  using ::sig_atomic_t;
  using ::signal;
  using ::raise;
}
# 14 "../object/SignalObject.h" 2




        namespace inXServices {

                class SignalObject : public inXObject {
                        private:
                                static SignalObject *Object_to_Cleanup;
                                static SignalObject *Object_Being_Deleted;
                                static bool Dying;
                                static sigset_t Current_Signals;
                                static sigset_t Previous_Signals;

                                SignalObject *Previous;
                                SignalObject *Next;

                                void Setup_signal(const int signal_number);



                                SignalObject &operator =(const SignalObject &);
                                SignalObject(const SignalObject &);

                                void Make();
                        protected:
                        public:



                                static bool block_signals();
                                static void restore_signals();

                                sighandler_t catchit(const int signal, sighandler_t handler);
                                sighandler_t ignore(const int signal);

                                static uint sleep(const uint seconds);
                                static uint alarm(const uint seconds);

                                static void dying(int signal_number);
                                static void die()
                                        __attribute__ ((noreturn));
                                void log_error_and_die(const char *format, ...)



                                        __attribute__ ((noreturn));

                                SignalObject(const char *log_file_name = 0);
                                ~SignalObject();
                };

                extern void fatal_startup_error(const char *format, ...)
                        __attribute__ ((format (printf, 1, 2)))
                        __attribute__ ((noreturn));

        };
# 23 "../object/File.h" 2





        typedef u_int32_t FilePos;

        namespace inXServices {


                typedef int HandlE;
                const HandlE FileClosed = -1;





                class File : protected SignalObject {
                        public:
                                enum OpenMode {
                                        ReadOnly = 0,
                                        WriteOnly = 1,
                                        ReadWrite = 2,
                                        Create = 64,
                                        Exclusive = 128,
                                        Truncate = 512,
                                        Append = 1024,
                                        SynchronousWrite = 4096,
                                        ASynchronousWrite = 8192
                                };
                                enum SeekType {
                                        FromBeginning, FromCurrentPosition, ToEOF
                                };
                                enum LockType {
                                        ReadLock, WriteLock, UnLock
                                };
                        private:
                                std::string Name;
                                HandlE Descriptor;
                        protected:
                        public:
                                inline const std::string &name() const;

                                inline bool is_open() const;
                                inline bool is_closed() const;

                                inline HandlE descriptor() const;

                                File &operator =(const File &file);

                                bool create(const char *file_name, const uint type, const int mode,
                                                                        const void *buffer, const FilePos bytes
                                                          );
                                bool open(const uint type, const int mode);
                                bool open(const char *file_name, const uint type, const int mode);
                                bool temporary(const char *file_name);
                                bool close();

                                FilePos size() const;

                                bool seek(const SeekType whence, const FilePos offset,
                                                         FilePos &position
                                                        );

                                bool check_lock(bool &can_lock,
                                                                         const LockType type, const SeekType whence,
                                                                                const FilePos offset, const FilePos length
                                                                        );
                                bool lock(const LockType type, const SeekType whence,
                                                                const FilePos offset, const FilePos length,
                                                                const bool wait
                                                        );

                                bool read(FilePos bytes,
                                                         void *&buffer, FilePos &bytes_read
                                                        );
                                bool read(FilePos position, FilePos bytes,
                                                         void *&buffer, FilePos &bytes_read
                                                        );
                                bool read(const SeekType whence, FilePos position,
                                                                FilePos bytes,
                                                         void *&buffer, FilePos &read_position,
                                                                FilePos &bytes_read
                                                        );

                                bool write(const void *buffer, const FilePos bytes,
                                                          FilePos &bytes_written, const bool sync = false
                                                         );
                                bool write(const FilePos position, const void *buffer,
                                                                        const FilePos bytes,
                                                          FilePos &bytes_written, const bool sync = false
                                                         );
                                bool write(const SeekType whence, FilePos position,
                                                                        const void *buffer, const FilePos bytes,
                                                          FilePos &write_position, FilePos &bytes_written,
                                                                        const bool sync = false
                                                         );
                                bool write(const FilePos position, const iovec *vector,
                                                                        const uint vectors,
                                                          FilePos &bytes_written, const bool sync = false
                                                         );
                                inline bool write(const FilePos position, const iovec *vector,
                                                                                        const uint vectors, const FilePos bytes,
                                                                           FilePos &bytes_written, const bool sync = false
                                                                          );

                                inline bool sync();
                                inline bool data_sync();

                                bool remove();
                                static bool remove(const char *file_name);

                                bool rename(const char *new_file_name);
                                static bool rename(const char *old_name, const char *new_name);

                                static bool have_directory_access(const char *name,
                                                                                                                                const bool must_write = true
                                                                                                                        );
                                static bool directory_exists(const char *name);
                                static bool make_directory(const char *name, const int mode);
                                static bool remove_directory(const char *name);

                                static bool truncate_or_remove(const char *name, const ulong bytes);

                                File(const char *error_log_file_name = 0);
                                File(const File &file);
                                virtual ~File();
                };

        }

# 1 "../object/File.i" 1



#ident "@(#)$Id: File.i 1.2 Tue, 08 Jan 2002 19:55:52 -0800 tmwg $ -- Copyright (c) 1999-2002 inX Services"
# 16 "../object/File.i"
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 1 3
# 28 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern "C" {
# 175 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/posix_opt.h" 1 3
# 176 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 2 3



# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/environments.h" 1 3
# 23 "/usr/lib/gcc/../../i686-inX-linux/include/bits/environments.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/wordsize.h" 1 3
# 24 "/usr/lib/gcc/../../i686-inX-linux/include/bits/environments.h" 2 3
# 180 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 2 3
# 199 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 200 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 2 3
# 240 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
typedef __intptr_t intptr_t;






typedef __socklen_t socklen_t;
# 260 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int access (__const char *__name, int __type) throw ();




extern int euidaccess (__const char *__name, int __type) throw ();
# 290 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern __off_t lseek (int __fd, __off_t __offset, int __whence) throw ();
# 302 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern __off64_t lseek64 (int __fd, __off64_t __offset, int __whence) throw ();



extern int close (int __fd) throw ();



extern ssize_t read (int __fd, void *__buf, size_t __nbytes) throw ();


extern ssize_t write (int __fd, __const void *__buf, size_t __n) throw ();



extern ssize_t pread (int __fd, void *__buf, size_t __nbytes, __off_t __offset)
     throw ();
extern ssize_t pwrite (int __fd, __const void *__buf, size_t __n,
                       __off_t __offset) throw ();
# 340 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern ssize_t pread64 (int __fd, void *__buf, size_t __nbytes,
                        __off64_t __offset) throw ();


extern ssize_t pwrite64 (int __fd, __const void *__buf, size_t __n,
                         __off64_t __offset) throw ();







extern int pipe (int __pipedes[2]) throw ();
# 362 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern unsigned int alarm (unsigned int __seconds) throw ();
# 371 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern unsigned int sleep (unsigned int __seconds) throw ();






extern __useconds_t ualarm (__useconds_t __value, __useconds_t __interval)
     throw ();



extern int usleep (__useconds_t __useconds) throw ();





extern int pause (void) throw ();



extern int chown (__const char *__file, __uid_t __owner, __gid_t __group)
     throw ();



extern int fchown (int __fd, __uid_t __owner, __gid_t __group) throw ();




extern int lchown (__const char *__file, __uid_t __owner, __gid_t __group)
     throw ();




extern int chdir (__const char *__path) throw ();



extern int fchdir (int __fd) throw ();
# 423 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern char *getcwd (char *__buf, size_t __size) throw ();





extern char *get_current_dir_name (void) throw ();






extern char *getwd (char *__buf) throw ();




extern int dup (int __fd) throw ();


extern int dup2 (int __fd, int __fd2) throw ();


extern char **__environ;

extern char **environ;





extern int execve (__const char *__path, char *__const __argv[],
                   char *__const __envp[]) throw ();




extern int fexecve (int __fd, char *__const __argv[], char *__const __envp[])
     throw ();




extern int execv (__const char *__path, char *__const __argv[]) throw ();



extern int execle (__const char *__path, __const char *__arg, ...) throw ();



extern int execl (__const char *__path, __const char *__arg, ...) throw ();



extern int execvp (__const char *__file, char *__const __argv[]) throw ();




extern int execlp (__const char *__file, __const char *__arg, ...) throw ();




extern int nice (int __inc) throw ();




extern void _exit (int __status) __attribute__ ((__noreturn__));





# 1 "/usr/lib/gcc/../../i686-inX-linux/include/bits/confname.h" 1 3
# 25 "/usr/lib/gcc/../../i686-inX-linux/include/bits/confname.h" 3
enum
  {
    _PC_LINK_MAX,

    _PC_MAX_CANON,

    _PC_MAX_INPUT,

    _PC_NAME_MAX,

    _PC_PATH_MAX,

    _PC_PIPE_BUF,

    _PC_CHOWN_RESTRICTED,

    _PC_NO_TRUNC,

    _PC_VDISABLE,

    _PC_SYNC_IO,

    _PC_ASYNC_IO,

    _PC_PRIO_IO,

    _PC_SOCK_MAXBUF,

    _PC_FILESIZEBITS,

    _PC_REC_INCR_XFER_SIZE,

    _PC_REC_MAX_XFER_SIZE,

    _PC_REC_MIN_XFER_SIZE,

    _PC_REC_XFER_ALIGN,

    _PC_ALLOC_SIZE_MIN,

    _PC_SYMLINK_MAX

  };


enum
  {
    _SC_ARG_MAX,

    _SC_CHILD_MAX,

    _SC_CLK_TCK,

    _SC_NGROUPS_MAX,

    _SC_OPEN_MAX,

    _SC_STREAM_MAX,

    _SC_TZNAME_MAX,

    _SC_JOB_CONTROL,

    _SC_SAVED_IDS,

    _SC_REALTIME_SIGNALS,

    _SC_PRIORITY_SCHEDULING,

    _SC_TIMERS,

    _SC_ASYNCHRONOUS_IO,

    _SC_PRIORITIZED_IO,

    _SC_SYNCHRONIZED_IO,

    _SC_FSYNC,

    _SC_MAPPED_FILES,

    _SC_MEMLOCK,

    _SC_MEMLOCK_RANGE,

    _SC_MEMORY_PROTECTION,

    _SC_MESSAGE_PASSING,

    _SC_SEMAPHORES,

    _SC_SHARED_MEMORY_OBJECTS,

    _SC_AIO_LISTIO_MAX,

    _SC_AIO_MAX,

    _SC_AIO_PRIO_DELTA_MAX,

    _SC_DELAYTIMER_MAX,

    _SC_MQ_OPEN_MAX,

    _SC_MQ_PRIO_MAX,

    _SC_VERSION,

    _SC_PAGESIZE,


    _SC_RTSIG_MAX,

    _SC_SEM_NSEMS_MAX,

    _SC_SEM_VALUE_MAX,

    _SC_SIGQUEUE_MAX,

    _SC_TIMER_MAX,




    _SC_BC_BASE_MAX,

    _SC_BC_DIM_MAX,

    _SC_BC_SCALE_MAX,

    _SC_BC_STRING_MAX,

    _SC_COLL_WEIGHTS_MAX,

    _SC_EQUIV_CLASS_MAX,

    _SC_EXPR_NEST_MAX,

    _SC_LINE_MAX,

    _SC_RE_DUP_MAX,

    _SC_CHARCLASS_NAME_MAX,


    _SC_2_VERSION,

    _SC_2_C_BIND,

    _SC_2_C_DEV,

    _SC_2_FORT_DEV,

    _SC_2_FORT_RUN,

    _SC_2_SW_DEV,

    _SC_2_LOCALEDEF,


    _SC_PII,

    _SC_PII_XTI,

    _SC_PII_SOCKET,

    _SC_PII_INTERNET,

    _SC_PII_OSI,

    _SC_POLL,

    _SC_SELECT,

    _SC_UIO_MAXIOV,

    _SC_IOV_MAX = _SC_UIO_MAXIOV,

    _SC_PII_INTERNET_STREAM,

    _SC_PII_INTERNET_DGRAM,

    _SC_PII_OSI_COTS,

    _SC_PII_OSI_CLTS,

    _SC_PII_OSI_M,

    _SC_T_IOV_MAX,



    _SC_THREADS,

    _SC_THREAD_SAFE_FUNCTIONS,

    _SC_GETGR_R_SIZE_MAX,

    _SC_GETPW_R_SIZE_MAX,

    _SC_LOGIN_NAME_MAX,

    _SC_TTY_NAME_MAX,

    _SC_THREAD_DESTRUCTOR_ITERATIONS,

    _SC_THREAD_KEYS_MAX,

    _SC_THREAD_STACK_MIN,

    _SC_THREAD_THREADS_MAX,

    _SC_THREAD_ATTR_STACKADDR,

    _SC_THREAD_ATTR_STACKSIZE,

    _SC_THREAD_PRIORITY_SCHEDULING,

    _SC_THREAD_PRIO_INHERIT,

    _SC_THREAD_PRIO_PROTECT,

    _SC_THREAD_PROCESS_SHARED,


    _SC_NPROCESSORS_CONF,

    _SC_NPROCESSORS_ONLN,

    _SC_PHYS_PAGES,

    _SC_AVPHYS_PAGES,

    _SC_ATEXIT_MAX,

    _SC_PASS_MAX,


    _SC_XOPEN_VERSION,

    _SC_XOPEN_XCU_VERSION,

    _SC_XOPEN_UNIX,

    _SC_XOPEN_CRYPT,

    _SC_XOPEN_ENH_I18N,

    _SC_XOPEN_SHM,


    _SC_2_CHAR_TERM,

    _SC_2_C_VERSION,

    _SC_2_UPE,


    _SC_XOPEN_XPG2,

    _SC_XOPEN_XPG3,

    _SC_XOPEN_XPG4,


    _SC_CHAR_BIT,

    _SC_CHAR_MAX,

    _SC_CHAR_MIN,

    _SC_INT_MAX,

    _SC_INT_MIN,

    _SC_LONG_BIT,

    _SC_WORD_BIT,

    _SC_MB_LEN_MAX,

    _SC_NZERO,

    _SC_SSIZE_MAX,

    _SC_SCHAR_MAX,

    _SC_SCHAR_MIN,

    _SC_SHRT_MAX,

    _SC_SHRT_MIN,

    _SC_UCHAR_MAX,

    _SC_UINT_MAX,

    _SC_ULONG_MAX,

    _SC_USHRT_MAX,


    _SC_NL_ARGMAX,

    _SC_NL_LANGMAX,

    _SC_NL_MSGMAX,

    _SC_NL_NMAX,

    _SC_NL_SETMAX,

    _SC_NL_TEXTMAX,


    _SC_XBS5_ILP32_OFF32,

    _SC_XBS5_ILP32_OFFBIG,

    _SC_XBS5_LP64_OFF64,

    _SC_XBS5_LPBIG_OFFBIG,


    _SC_XOPEN_LEGACY,

    _SC_XOPEN_REALTIME,

    _SC_XOPEN_REALTIME_THREADS,


    _SC_ADVISORY_INFO,

    _SC_BARRIERS,

    _SC_BASE,

    _SC_C_LANG_SUPPORT,

    _SC_C_LANG_SUPPORT_R,

    _SC_CLOCK_SELECTION,

    _SC_CPUTIME,

    _SC_THREAD_CPUTIME,

    _SC_DEVICE_IO,

    _SC_DEVICE_SPECIFIC,

    _SC_DEVICE_SPECIFIC_R,

    _SC_FD_MGMT,

    _SC_FIFO,

    _SC_PIPE,

    _SC_FILE_ATTRIBUTES,

    _SC_FILE_LOCKING,

    _SC_FILE_SYSTEM,

    _SC_MONOTONIC_CLOCK,

    _SC_MULTI_PROCESS,

    _SC_SINGLE_PROCESS,

    _SC_NETWORKING,

    _SC_READER_WRITER_LOCKS,

    _SC_SPIN_LOCKS,

    _SC_REGEXP,

    _SC_REGEX_VERSION,

    _SC_SHELL,

    _SC_SIGNALS,

    _SC_SPAWN,

    _SC_SPORADIC_SERVER,

    _SC_THREAD_SPORADIC_SERVER,

    _SC_SYSTEM_DATABASE,

    _SC_SYSTEM_DATABASE_R,

    _SC_TIMEOUTS,

    _SC_TYPED_MEMORY_OBJECTS,

    _SC_USER_GROUPS,

    _SC_USER_GROUPS_R,

    _SC_2_PBS,

    _SC_2_PBS_ACCOUNTING,

    _SC_2_PBS_LOCATE,

    _SC_2_PBS_MESSAGE,

    _SC_2_PBS_TRACK,

    _SC_SYMLOOP_MAX,

    _SC_STREAMS,

    _SC_2_PBS_CHECKPOINT,


    _SC_V6_ILP32_OFF32,

    _SC_V6_ILP32_OFFBIG,

    _SC_V6_LP64_OFF64,

    _SC_V6_LPBIG_OFFBIG,


    _SC_HOST_NAME_MAX,

    _SC_TRACE,

    _SC_TRACE_EVENT_FILTER,

    _SC_TRACE_INHERIT,

    _SC_TRACE_LOG

  };





enum
  {
    _CS_PATH,




    _CS_LFS_CFLAGS = 1000,

    _CS_LFS_LDFLAGS,

    _CS_LFS_LIBS,

    _CS_LFS_LINTFLAGS,

    _CS_LFS64_CFLAGS,

    _CS_LFS64_LDFLAGS,

    _CS_LFS64_LIBS,

    _CS_LFS64_LINTFLAGS,




    _CS_XBS5_ILP32_OFF32_CFLAGS = 1100,

    _CS_XBS5_ILP32_OFF32_LDFLAGS,

    _CS_XBS5_ILP32_OFF32_LIBS,

    _CS_XBS5_ILP32_OFF32_LINTFLAGS,

    _CS_XBS5_ILP32_OFFBIG_CFLAGS,

    _CS_XBS5_ILP32_OFFBIG_LDFLAGS,

    _CS_XBS5_ILP32_OFFBIG_LIBS,

    _CS_XBS5_ILP32_OFFBIG_LINTFLAGS,

    _CS_XBS5_LP64_OFF64_CFLAGS,

    _CS_XBS5_LP64_OFF64_LDFLAGS,

    _CS_XBS5_LP64_OFF64_LIBS,

    _CS_XBS5_LP64_OFF64_LINTFLAGS,

    _CS_XBS5_LPBIG_OFFBIG_CFLAGS,

    _CS_XBS5_LPBIG_OFFBIG_LDFLAGS,

    _CS_XBS5_LPBIG_OFFBIG_LIBS,

    _CS_XBS5_LPBIG_OFFBIG_LINTFLAGS,



    _CS_POSIX_V6_ILP32_OFF32_CFLAGS,

    _CS_POSIX_V6_ILP32_OFF32_LDFLAGS,

    _CS_POSIX_V6_ILP32_OFF32_LIBS,

    _CS_POSIX_V6_ILP32_OFF32_LINTFLAGS,

    _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS,

    _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS,

    _CS_POSIX_V6_ILP32_OFFBIG_LIBS,

    _CS_POSIX_V6_ILP32_OFFBIG_LINTFLAGS,

    _CS_POSIX_V6_LP64_OFF64_CFLAGS,

    _CS_POSIX_V6_LP64_OFF64_LDFLAGS,

    _CS_POSIX_V6_LP64_OFF64_LIBS,

    _CS_POSIX_V6_LP64_OFF64_LINTFLAGS,

    _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS,

    _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS,

    _CS_POSIX_V6_LPBIG_OFFBIG_LIBS,

    _CS_POSIX_V6_LPBIG_OFFBIG_LINTFLAGS,



    _CS_V6_WIDTH_RESTRICTED_ENVS

  };
# 501 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 2 3


extern long int pathconf (__const char *__path, int __name) throw ();


extern long int fpathconf (int __fd, int __name) throw ();


extern long int sysconf (int __name) throw () __attribute__ ((__const__));



extern size_t confstr (int __name, char *__buf, size_t __len) throw ();




extern __pid_t getpid (void) throw ();


extern __pid_t getppid (void) throw ();




extern __pid_t getpgrp (void) throw ();
# 536 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern __pid_t __getpgid (__pid_t __pid) throw ();

extern __pid_t getpgid (__pid_t __pid) throw ();






extern int setpgid (__pid_t __pid, __pid_t __pgid) throw ();
# 562 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int setpgrp (void) throw ();
# 580 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern __pid_t setsid (void) throw ();



extern __pid_t getsid (__pid_t __pid) throw ();



extern __uid_t getuid (void) throw ();


extern __uid_t geteuid (void) throw ();


extern __gid_t getgid (void) throw ();


extern __gid_t getegid (void) throw ();




extern int getgroups (int __size, __gid_t __list[]) throw ();



extern int group_member (__gid_t __gid) throw ();






extern int setuid (__uid_t __uid) throw ();




extern int setreuid (__uid_t __ruid, __uid_t __euid) throw ();




extern int seteuid (__uid_t __uid) throw ();






extern int setgid (__gid_t __gid) throw ();




extern int setregid (__gid_t __rgid, __gid_t __egid) throw ();




extern int setegid (__gid_t __gid) throw ();






extern __pid_t fork (void) throw ();






extern __pid_t vfork (void) throw ();





extern char *ttyname (int __fd) throw ();



extern int ttyname_r (int __fd, char *__buf, size_t __buflen) throw ();



extern int isatty (int __fd) throw ();





extern int ttyslot (void) throw ();




extern int link (__const char *__from, __const char *__to) throw ();



extern int symlink (__const char *__from, __const char *__to) throw ();




extern int readlink (__const char *__restrict __path, char *__restrict __buf,
                     size_t __len) throw ();



extern int unlink (__const char *__name) throw ();


extern int rmdir (__const char *__path) throw ();



extern __pid_t tcgetpgrp (int __fd) throw ();


extern int tcsetpgrp (int __fd, __pid_t __pgrp_id) throw ();



extern char *getlogin (void) throw ();




extern int getlogin_r (char *__name, size_t __name_len) throw ();




extern int setlogin (__const char *__name) throw ();
# 726 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
# 1 "/usr/lib/gcc/../../i686-inX-linux/include/getopt.h" 1 3
# 38 "/usr/lib/gcc/../../i686-inX-linux/include/getopt.h" 3
extern "C" {
# 47 "/usr/lib/gcc/../../i686-inX-linux/include/getopt.h" 3
extern char *optarg;
# 61 "/usr/lib/gcc/../../i686-inX-linux/include/getopt.h" 3
extern int optind;




extern int opterr;



extern int optopt;
# 145 "/usr/lib/gcc/../../i686-inX-linux/include/getopt.h" 3
extern int getopt (int ___argc, char *const *___argv, const char *__shortopts);
# 175 "/usr/lib/gcc/../../i686-inX-linux/include/getopt.h" 3
}
# 727 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 2 3







extern int gethostname (char *__name, size_t __len) throw ();






extern int sethostname (__const char *__name, size_t __len) throw ();



extern int sethostid (long int __id) throw ();





extern int getdomainname (char *__name, size_t __len) throw ();
extern int setdomainname (__const char *__name, size_t __len) throw ();





extern int vhangup (void) throw ();


extern int revoke (__const char *__file) throw ();







extern int profil (unsigned short int *__sample_buffer, size_t __size,
                   size_t __offset, unsigned int __scale) throw ();





extern int acct (__const char *__name) throw ();



extern char *getusershell (void) throw ();
extern void endusershell (void) throw ();
extern void setusershell (void) throw ();





extern int daemon (int __nochdir, int __noclose) throw ();






extern int chroot (__const char *__path) throw ();



extern char *getpass (__const char *__prompt) throw ();





extern int fsync (int __fd) throw ();






extern long int gethostid (void) throw ();


extern void sync (void) throw ();




extern int getpagesize (void) throw () __attribute__ ((__const__));




extern int truncate (__const char *__file, __off_t __length) throw ();
# 836 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int truncate64 (__const char *__file, __off64_t __length) throw ();




extern int ftruncate (int __fd, __off_t __length) throw ();
# 851 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int ftruncate64 (int __fd, __off64_t __length) throw ();





extern int getdtablesize (void) throw ();
# 866 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int brk (void *__addr) throw ();





extern void *sbrk (intptr_t __delta) throw ();
# 887 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern long int syscall (long int __sysno, ...) throw ();
# 907 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int lockf (int __fd, int __cmd, __off_t __len) throw ();
# 917 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int lockf64 (int __fd, int __cmd, __off64_t __len) throw ();
# 938 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int fdatasync (int __fildes) throw ();







extern char *crypt (__const char *__key, __const char *__salt) throw ();



extern void encrypt (char *__block, int __edflag) throw ();






extern void swab (__const void *__restrict __from, void *__restrict __to,
                  ssize_t __n) throw ();







extern char *ctermid (char *__s) throw ();
# 983 "/usr/lib/gcc/../../i686-inX-linux/include/unistd.h" 3
extern int pthread_atfork (void (*__prepare) (void),
                           void (*__parent) (void),
                           void (*__child) (void)) throw ();


}
# 17 "../object/File.i" 2

        namespace inXServices {

inline const std::string &
File::name() const {
        return Name;
}
inline bool
File::is_open() const {
        return Descriptor != FileClosed;
}

inline bool
File::is_closed() const {
        return Descriptor == FileClosed;
}

inline HandlE
File::descriptor() const {
        return Descriptor;
}

inline bool
File::write(const FilePos position, const iovec *vector, const uint vectors,
                                        const FilePos,
                                FilePos &bytes_written, const bool sync
                          ) {
        return File::write(position, vector, vectors,
                                                         bytes_written, sync
                                                        );
}

inline bool
File::sync() {
        return fsync(Descriptor) == Success;
}

inline bool
File::data_sync() {
        return fdatasync(Descriptor) == Success;
}

        }
# 155 "../object/File.h" 2
# 14 "../object/MmapFile.h" 2

        namespace inXServices {

                class MmapFile : protected File {
                        private:
                                void * Image;
                                int Mode;
                                FilePos Mapped;

                                bool Open(const uint type);



                                bool temporary(const char *file_name);
                                bool seek(const SeekType whence, const FilePos offset,
                                                         FilePos &position
                                                        );
                                bool read(FilePos bytes,
                                                         void *&buffer, FilePos &bytes_read
                                                        );
                                bool read(const SeekType whence, FilePos position, FilePos bytes,
                                                         void *&buffer, FilePos &read_position, FilePos &bytes_read
                                                        );
                                bool write(const void *buffer, const FilePos bytes,
                                                          FilePos &bytes_written, const bool sync = false
                                                         );
                                bool write(const SeekType whence, FilePos position,
                                                                        const void *buffer, const FilePos bytes,
                                                          FilePos &write_position, FilePos &bytes_written,
                                                                        const bool sync = false
                                                         );
                                static bool remove(const char *file_name);
                                static bool rename(const char *old_name, const char *new_name);
                                static bool have_directory_access(const char *name,
                                                                                                                                const bool must_write = true
                                                                                                                        );
                                static bool directory_exists(const char *name);
                                static bool make_directory(const char *name, const int mode);
                        protected:
# 63 "../object/MmapFile.h"
                                inline bool block_signals();
                                inline void restore_signals();
                                inline void dying(int signal_number);
                                inline void die();
                                inline void Dup_program_name(const char *program_name);

                                inline void *Image_base();
                                inline const void *Image_base() const;
                                inline FilePos Mapped_length() const;
                        public:
                                inline const std::string &name() const;

                                inline bool is_open() const;
                                inline bool is_closed() const;

                                inline bool is_in_map(const void *area) const;
                                inline bool is_not_in_map(const void *area) const;

                                inline bool create(const char *file_name, const uint type,
                                                                                        const int mode, void *buffer,
                                                                                        const FilePos bytes
                                                                                );
                                bool open(const uint type, const int mode);
                                bool open(const char *file_name, const uint type, const int mode);
                                bool open(const char *file_name, const uint type,
                                                                const int open_mode, const int mmap_type
                                                        );
                                bool close();

                                inline FilePos size() const;

                                inline bool lock(const LockType type, const SeekType whence,
                                                                                        const FilePos offset, const FilePos length,
                                                                                        const bool wait
                                                                         );

                                bool read(FilePos position, FilePos bytes,
                                                         void *&buffer, FilePos &bytes_read
                                                        );

                                bool write(FilePos position, const void *buffer,
                                                                        const FilePos bytes,
                                                          FilePos &bytes_written, const bool sync = false
                                                         );
                                bool write(const FilePos position, const iovec *vector,
                                                                        const uint vectors, const FilePos bytes,
                                                          FilePos &bytes_written, const bool sync = false
                                                         );

                                inline bool sync();
                                inline bool data_sync();

                                inline bool remove();

                                bool rename(const char *new_file_name);

                                MmapFile &operator =(const File &file);
                                MmapFile &operator =(const MmapFile &file);

                                MmapFile(const char *error_log_file_name = 0);
                                MmapFile(const MmapFile &file);
                                ~MmapFile();
                };

        }

# 1 "../object/MmapFile.i" 1



#ident "@(#)$Id: MmapFile.i 1.3 Mon, 11 Mar 2002 05:27:34 -0800 tmwg $ -- Copyright (c) 2000-2002 inX Services"
# 13 "../object/MmapFile.i"
# 1 "../object/MmapFile.h" 1
# 14 "../object/MmapFile.i" 2

        namespace inXServices {
# 31 "../object/MmapFile.i"
inline bool
MmapFile::block_signals() {
        return File::block_signals();
}

inline void
MmapFile::restore_signals() {
        File::restore_signals();
}

inline void
MmapFile::dying(int signal_number) {
        File::dying(signal_number);
}

inline void
MmapFile::die() {
        File::die();
}

inline void
MmapFile::Dup_program_name(const char *program_name) {
        File::Dup_program_name(program_name);
}

inline void *
MmapFile::Image_base() {
        return Image;
}

inline const void *
MmapFile::Image_base() const {
        return Image;
}

inline FilePos
MmapFile::Mapped_length() const {
        return Mapped;
}

inline const std::string &
MmapFile::name() const {
        return File::name();
}

inline bool
MmapFile::is_open() const {
        return File::is_open();
}

inline bool
MmapFile::is_closed() const {
        return File::is_closed();
}

inline bool
MmapFile::is_in_map(const void *area) const {
        return area >= Image
                         && area < (reinterpret_cast<const char *>(Image) + Mapped);
}

inline bool
MmapFile::is_not_in_map(const void *area) const {
        return area < Image
                         || area >= (reinterpret_cast<const char *>(Image) + Mapped);
}

inline bool
MmapFile::create(const char *file_name, const uint type, const int mode,
                                                void *buffer, const FilePos bytes
                                         ) {
        Mode = 0;
        Image = 0;
        Mapped = 0;

        return File::create(file_name, type, mode, buffer, bytes);
}

inline FilePos
MmapFile::size() const {
        return File::size();
}

inline bool
MmapFile::lock(const LockType type, const SeekType whence, const FilePos offset,
                                                const FilePos length, const bool wait
                                  ) {
        return File::lock(type, whence, offset, length, wait);
}

inline bool
MmapFile::sync() {
        return File::sync();
}

inline bool
MmapFile::data_sync() {
        return File::data_sync();
}

inline bool
MmapFile::remove() {
        return File::remove();
}

        }
# 130 "../object/MmapFile.h" 2
# 16 "../inXDB/DB/inXDB.h" 2





# 1 "../avl/AVL.h" 1



#ident "@(#)$Id: AVL.h 1.3 Mon, 14 Jan 2002 08:03:36 -0800 tmwg $ -- Copyright (c) 2001,2002 inX Services"
# 15 "../avl/AVL.h"
extern "C" {



# 1 "../avl/avl.h" 1
# 29 "../avl/avl.h"
# 1 "/usr/lib/gcc/i686-inX-linux/3.0.99.10/include/stddef.h" 1 3
# 30 "../avl/avl.h" 2


typedef int avl_comparison_func (const void *avl_a, const void *avl_b,
                                 void *avl_param);
typedef void avl_item_func (void *avl_item, void *avl_param);
typedef void *avl_copy_func (void *avl_item, void *avl_param);




struct libavl_allocator
  {
    void *(*libavl_malloc) (struct libavl_allocator *, size_t libavl_size);
    void (*libavl_free) (struct libavl_allocator *, void *libavl_block);
  };



extern struct libavl_allocator avl_allocator_default;
void *avl_malloc (struct libavl_allocator *, size_t);
void avl_free (struct libavl_allocator *, void *);







struct avl_table
  {
    struct avl_node *avl_root;
    avl_comparison_func *avl_compare;
    void *avl_param;
    struct libavl_allocator *avl_alloc;
    size_t avl_count;
    unsigned long avl_generation;
  };


struct avl_node
  {
    struct avl_node *avl_link[2];
    void *avl_data;
    signed char avl_balance;
  };


struct avl_traverser
  {
    struct avl_table *avl_table;
    struct avl_node *avl_node;
    struct avl_node *avl_stack[32];

    size_t avl_height;
    unsigned long avl_generation;
  };


struct avl_table *avl_create (avl_comparison_func *, void *,
                              struct libavl_allocator *);
struct avl_table *avl_copy (const struct avl_table *, avl_copy_func *,
                            avl_item_func *, struct libavl_allocator *);
void avl_destroy (struct avl_table *, avl_item_func *);
void **avl_probe (struct avl_table *, void *);
void *avl_insert (struct avl_table *, void *);
void *avl_replace (struct avl_table *, void *);
void *avl_delete (struct avl_table *, const void *);
void *avl_find (const struct avl_table *, const void *);
void avl_assert_insert (struct avl_table *, void *);
void *avl_assert_delete (struct avl_table *, void *);




void avl_t_init (struct avl_traverser *, struct avl_table *);
void *avl_t_first (struct avl_traverser *, struct avl_table *);
void *avl_t_last (struct avl_traverser *, struct avl_table *);
void *avl_t_find (struct avl_traverser *, struct avl_table *, void *);
void *avl_t_insert (struct avl_traverser *, struct avl_table *, void *);
void *avl_t_copy (struct avl_traverser *, const struct avl_traverser *);
void *avl_t_next (struct avl_traverser *);
void *avl_t_prev (struct avl_traverser *);
void *avl_t_cur (struct avl_traverser *);
void *avl_t_replace (struct avl_traverser *, void *);
# 20 "../avl/AVL.h" 2

}

        namespace inXServices {

                template <class TYPE> class AVL {
                        private:
                                void *User_Data;
# 37 "../avl/AVL.h"
                                avl_table *Tree;
                                int (TYPE::*Compare_Nodes)(const TYPE &node) const;

                                bool Delete_Data_When_Destroyed;



                                avl_traverser *Traverser;

                        protected:





                                static int Compare(const void *a, const void *b, void *);
                                static int Compare_nodes(const void *a, const void *b, void *);
                                static void Delete(void *data, void *);

                                static void *Copy(void *data, void *);
                        public:
                                size_t nodes() const;

                                TYPE **find_or_insert(TYPE *data);
                                TYPE *find(const TYPE *data) const;
                                TYPE *find_close(const TYPE *data) const;
                                TYPE *insert(TYPE *data);
                                TYPE *remove(const TYPE *data);
                                TYPE *replace(TYPE *data);



                                TYPE *operator ()();

                                void clear();

                                AVL<TYPE> &operator =(const AVL<TYPE> &tree);

                                AVL(const AVL<TYPE> &tree);
                                AVL(int (TYPE::*compare)(const TYPE &node) const,
                                                const bool delete_data = false
                                        );
                                AVL(const bool delete_data = false, void *user_data = 0);
                                ~AVL();
                };

        };

# 1 "../avl/AVL.i" 1



#ident "@(#)$Id: AVL.i 1.4 Mon, 14 Jan 2002 08:03:36 -0800 tmwg $ -- Copyright (c) 2001 inX Services"
# 15 "../avl/AVL.i"
        namespace inXServices {
# 62 "../avl/AVL.i"
template <class TYPE> int
AVL<TYPE>::Compare(const void *a, const void *b, void *) {
        return
                (static_cast<const TYPE *>(a))->compare(*static_cast<const TYPE *>(b));
}

template <class TYPE> int
AVL<TYPE>::Compare_nodes(const void *a, const void *b, void *tree) {
        return
        ((static_cast<const TYPE *>(a))->*(static_cast<AVL<TYPE> *>(tree))->Compare_Nodes)(*(static_cast<const TYPE *>(b)));
}

template <class TYPE> void
AVL<TYPE>::Delete(void *data, void *) {
        delete static_cast<TYPE *>(data);
}



template <class TYPE> void *
AVL<TYPE>::Copy(void *data, void *) {
        return new TYPE(*(static_cast<const TYPE *>(data)));
}


template <class TYPE> inline size_t
AVL<TYPE>::nodes() const {



        return Tree->avl_count;

}


template <class TYPE> inline TYPE **
AVL<TYPE>::find_or_insert(TYPE *data) {
        return
                static_cast<TYPE **>(avl_probe(Tree, static_cast<const void *>(data)));
}


template <class TYPE> inline TYPE *
AVL<TYPE>::find(const TYPE *data) const {






        return static_cast<TYPE *>(avl_find(Tree, static_cast<const void *>(data)));

}


template <class TYPE> inline TYPE *
AVL<TYPE>::find_close(const TYPE *data) const {
        return static_cast<TYPE *>(avl_find_close(Tree,
                                                                                                                                static_cast<const void *>(data))
                                                                                                                  );
}


template <class TYPE> inline TYPE *
AVL<TYPE>::insert(TYPE *data) {
# 139 "../avl/AVL.i"
        return static_cast<TYPE *>(avl_insert(Tree, static_cast<void *>(data)));

}

template <class TYPE> inline TYPE *
AVL<TYPE>::remove(const TYPE *data) {
# 154 "../avl/AVL.i"
        return
                static_cast<TYPE *>(avl_delete(Tree, static_cast<const void *>(data)));

}


template <class TYPE> inline TYPE *
AVL<TYPE>::replace(TYPE *data) {
        return
                static_cast<TYPE *>(avl_replace(Tree, static_cast<const void *>(data)));
}







template <class TYPE> TYPE *
AVL<TYPE>::operator ()() {
# 184 "../avl/AVL.i"
        if (! Traverser) {
                avl_t_init(Traverser = new avl_traverser, Tree);
        }
        TYPE *item(static_cast<TYPE *>(avl_t_next(Traverser)));
        if (! item) {
                delete Traverser;
                Traverser = 0;
        }
        return item;

}

template <class TYPE> inline void
AVL<TYPE>::clear() {
# 206 "../avl/AVL.i"
        avl_destroy(Tree, Delete_Data_When_Destroyed ? &Delete : 0);
        delete Traverser; Traverser = 0;
        if (Compare_Nodes) {
                Tree = avl_create(&Compare_nodes, this, 0);
        } else {
                Tree = avl_create(&Compare, User_Data, 0);
        }

}


template <class TYPE> inline
AVL<TYPE>::AVL(const AVL<TYPE> &tree)
        : User_Data(tree.User_Data),
                Compare_Nodes(tree.Compare_Nodes),
                Delete_Data_When_Destroyed(false),
                Traverser(0) {
        Tree = avl_copy(tree.Tree, &Copy, 0, 0);
}


template <class TYPE> inline
AVL<TYPE>::AVL(const bool delete_data, void *user_data)
        : User_Data(user_data),

                Compare_Nodes(0),

                Delete_Data_When_Destroyed(delete_data),
                Traverser(0) {



        Tree = avl_create(&Compare, user_data, 0);

}


template <class TYPE> inline
AVL<TYPE>::AVL(int (TYPE::*compare)(const TYPE &node) const,
                                                const bool delete_data
                                  )
        : User_Data(0),
                Compare_Nodes(compare),
                Delete_Data_When_Destroyed(delete_data),
                Traverser(0) {
        Tree = avl_create(&Compare_nodes, this, 0);
}


template <class TYPE> inline
AVL<TYPE>::~AVL() {







        avl_destroy(Tree, Delete_Data_When_Destroyed ? &Delete : 0);
        delete Traverser;

}

        };
# 86 "../avl/AVL.h" 2
# 22 "../inXDB/DB/inXDB.h" 2
# 1 "../array/array.h" 1



#ident "@(#)$Id: array.h 1.5 Thu, 06 Dec 2001 06:23:50 -0800 tmwg $ -- Copyright (c) 1998-2000 inX Services"
# 37 "../array/array.h"
        template <class TYPE> class Array {
                private:
                protected:
                        uint Allocation_Increment;
                        uint Allocated;
                        uint Grown;
                        const TYPE Empty;
                        TYPE *Element;

                        void Grow(const uint to);
                public:
                        inline uint allocation_increment() const;
                        inline uint allocated() const;

                        inline Array<TYPE> &operator =(const Array<TYPE> &array);

                        inline TYPE &operator [](const uint index);
                        inline const TYPE &operator [](const uint index) const;

                        inline TYPE *operator +(const uint index);
                        inline const TYPE *operator +(const uint index) const;

                        inline void sort(const size_t elements,
                                                                                int (*compare)(const TYPE *, const TYPE *)
                                                                 );

                        inline Array(const uint allocation_increment = 1500);
                        inline Array(const Array<TYPE> &array);
                        inline ~Array();
        };

template <class TYPE> inline uint
Array<TYPE>::allocation_increment() const {
        return Allocation_Increment;
}

template <class TYPE> inline uint
Array<TYPE>::allocated() const {
        return Allocated;
}

template <class TYPE> inline Array<TYPE> &
Array<TYPE>::operator =(const Array<TYPE> &array) {
        Allocation_Increment = array.Allocation_Increment;
        Allocated = array.Allocated;
        delete[] Element;
        memcpy(Element = new TYPE[Allocated], array.Element,
                                        Allocated * sizeof(TYPE)
                        );

        return *this;
}

template <class TYPE> void
Array<TYPE>::Grow(const uint to) {
        if (++Grown == 3) {
                Allocation_Increment *= 3;
                Grown = 0;
        }
        const uint new_allocation(to + Allocation_Increment);
        TYPE *e(new TYPE[new_allocation]);
        const uint old_bytes(Allocated * sizeof(TYPE));
        memcpy(e, Element, old_bytes);
        memset(e + Allocated, 0, (new_allocation * sizeof(TYPE)) - old_bytes);
        delete[] Element;
        Element = e;
        Allocated = new_allocation;
}

template <class TYPE> inline TYPE &
Array<TYPE>::operator [](const uint index) {
        if (index >= Allocated) {
                Grow(index);
        }
        return Element[index];
}

template <class TYPE> inline const TYPE &
Array<TYPE>::operator [](const uint index) const {
        return index < Allocated
                                ? Element[index]
                                : Empty;
}

template <class TYPE> inline TYPE *
Array<TYPE>::operator +(const uint index) {
        if (index >= Allocated) {
                Grow(index);
        }
        return Element + index;
}

template <class TYPE> inline const TYPE *
Array<TYPE>::operator +(const uint index) const {
        return index < Allocated
                                ? Element + index
                                : 0;
}

template <class TYPE> inline void
Array<TYPE>::sort(const size_t elements,
                                                        int (*compare)(const TYPE *, const TYPE *)
                                          ) {
        qsort(Element, elements, sizeof(TYPE *),
                                reinterpret_cast<int (*)(const void*,const void*)>(compare)
                  );
}

template <class TYPE> inline
Array<TYPE>::Array(const uint allocation_increment)
        : Allocation_Increment(allocation_increment),
                Allocated(Allocation_Increment),
                Grown(0) {
        memset(Element = new TYPE[Allocated], 0, sizeof(TYPE) * Allocated);
}

template <class TYPE> inline
Array<TYPE>::Array(const Array<TYPE> &array)
        : Allocation_Increment(array.Allocation_Increment),
                Allocated(array.Allocated) {
        memcpy(Element = new TYPE[Allocated], array.Element,
                                        Allocated * sizeof(TYPE)
                        );
}

template <class TYPE> inline
Array<TYPE>::~Array() {
        delete[] Element; Element = 0;
}
# 23 "../inXDB/DB/inXDB.h" 2
# 1 "../array/clsarray.h" 1



#ident "@(#)$Id: clsarray.h 1.4 Sat, 27 Oct 2001 22:02:31 -0700 tmwg $ -- Copyright (c) 1998-2001 inX Services"
# 39 "../array/clsarray.h"
        template <class TYPE> class ClassArray {
                private:
                protected:
                        uint Allocation_Increment;
                        uint Allocated;
                        uint Grown;
                        const TYPE Empty;
                        TYPE *Element;

                        void Grow(const uint to);
                public:
                        inline uint allocation_increment() const;
                        inline uint allocated() const;

                        ClassArray<TYPE> &operator =(const ClassArray<TYPE> &array);

                        inline TYPE &operator [](const uint index);
                        inline const TYPE &operator [](const uint index) const;

                        inline TYPE *operator +(const uint index);
                        inline const TYPE *operator +(const uint index) const;

                        inline ClassArray(const uint allocation_increment = 1500);
                        ClassArray(const ClassArray<TYPE> &array);
                        inline ~ClassArray();
        };

template <class TYPE> inline uint
ClassArray<TYPE>::allocation_increment() const {
        return Allocation_Increment;
}

template <class TYPE> inline uint
ClassArray<TYPE>::allocated() const {
        return Allocated;
}

template <class TYPE> ClassArray<TYPE> &
ClassArray<TYPE>::operator =(const ClassArray<TYPE> &array) {
        Allocation_Increment = array.Allocation_Increment;
        delete[] Element;
        TYPE *e(Element = new TYPE[Allocated = array.Allocated]);
        TYPE *a(array.Element);
        for (uint i(Allocated);
                  i--;
                 ) {
                *e++ = *a++;
        }
        return *this;
}

template <class TYPE> void
ClassArray<TYPE>::Grow(const uint to) {
        if (++Grown == 3) {
                Allocation_Increment *= 3;
                Grown = 0;
        }
        const uint new_allocation(to + Allocation_Increment);
        TYPE *e(new TYPE[new_allocation]);
        TYPE *olde(Element);
        TYPE *newe(e);
        for (uint i(Allocated);
                  i--;
                 ) {
                *newe++ = *olde++;
        }
        delete[] Element;
        Element = e;
        Allocated = new_allocation;
}

template <class TYPE> inline TYPE &
ClassArray<TYPE>::operator [](const uint index) {
        if (index >= Allocated) {
                Grow(index);
        }
        return Element[index];
}

template <class TYPE> inline const TYPE &
ClassArray<TYPE>::operator [](const uint index) const {
        return index < Allocated
                                ? Element[index]
                                : Empty;
}

template <class TYPE> inline TYPE *
ClassArray<TYPE>::operator +(const uint index) {
        if (index >= Allocated) {
                Grow(index);
        }
        return Element + index;
}

template <class TYPE> inline const TYPE *
ClassArray<TYPE>::operator +(const uint index) const {
        return index < Allocated
                                ? Element + index
                                : 0;
}

template <class TYPE> inline
ClassArray<TYPE>::ClassArray(const uint allocation_increment)
        : Allocation_Increment(allocation_increment),
                Allocated(Allocation_Increment),
                Grown(0) {
        Element = new TYPE[Allocated];
}

template <class TYPE>
ClassArray<TYPE>::ClassArray(const ClassArray<TYPE> &array)
        : Allocation_Increment(array.Allocation_Increment) {
        TYPE *e(Element = new TYPE[Allocated = array.Allocated]);
        TYPE *a(array.Element);
        for (uint i(Allocated);
                  i--;
                 ) {
                *e++ = *a++;
        }
}

template <class TYPE> inline
ClassArray<TYPE>::~ClassArray() {
        delete[] Element; Element = 0;
}
# 24 "../inXDB/DB/inXDB.h" 2
# 1 "../julian/JulianTime.h" 1



#ident "@(#)$Id: JulianTime.h 1.5 Sat, 27 Oct 2001 21:11:38 -0700 tmwg $ -- Copyright (c) 2000,2001 inX Services"
# 13 "../julian/JulianTime.h"
# 1 "../julian/JulianDate.h" 1



#ident "@(#)$Id: JulianDate.h 1.7 Wed, 27 Mar 2002 13:37:52 -0800 tmwg $ -- Copyright (c) 2000-2002 inX Services"
# 15 "../julian/JulianDate.h"
        namespace inXServices {

                class JulianDate {
                        public:
                                enum DayOfWeek {
                                        Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday
                                };
                        private:
                        protected:
                                static const uint Leap_Month_Days[12];
                                static const uint Month_Days[12];
                                static char Month_Name[12][32];
                                static char Weekday_Name[7][16];






                                int32_t Julian;

                                inline static bool Is_leap_year(const uint year);



                                static void Initialize();



                                static int32_t To_julian(const uint month, const uint day,
                                                                                                        const uint year
                                                                                                );
                        public:
                                uint year() const;
                                uint month() const;
                                uint day() const;

                                const JulianDate &operator ()(uint *month, uint *day,
                                                                                                                        uint *year
                                                                                                          ) const;
                                DayOfWeek day_of_week() const;
                                inline int32_t julian() const;
                                time_t date() const;

                                uint days_in_month() const;

                                const char *month_name() const;
                                static const char *month_name(const uint month);

                                const char *weekday_name() const;
                                static const char *weekday_name(const DayOfWeek wd);

                                JulianDate &operator ++();
                                JulianDate &operator --();

                                JulianDate operator ++(int);
                                JulianDate operator --(int);

                                JulianDate operator +(const uint days) const;
                                JulianDate operator -(const uint days) const;

                                JulianDate &operator +=(const uint days);
                                JulianDate &operator -=(const uint days);

                                JulianDate &easter(const uint year);

                                inline JulianDate &operator =(const JulianDate &date);

                                JulianDate &operator =(const time_t date);

                                inline JulianDate &operator ()(const uint month, const uint day,
                                                                                                                        const uint year
                                                                                                                );

                                inline JulianDate &add_days(const uint days);
                                inline JulianDate &subtract_days(const uint days);
                                JulianDate &add_months(const uint months);
                                JulianDate &subtract_months(const uint months);
                                JulianDate &add_years(const uint years);
                                JulianDate &subtract_years(const uint years);

                                inline bool operator ==(const JulianDate &date) const;
                                inline bool operator !=(const JulianDate &date) const;
                                inline int compare(const JulianDate &date) const;

                                inline bool operator <(const JulianDate &date) const;
                                inline bool operator <=(const JulianDate &date) const;

                                inline bool operator >(const JulianDate &date) const;
                                inline bool operator >=(const JulianDate &date) const;

                                inline operator bool () const;
                                inline bool operator !() const;

                                inline operator time_t () const;

                                size_t print(char *buffer, const size_t buffer_bytes,
                                                                        const char *format
                                                                ) const;


                                inline friend std::ostream &operator <<(std::ostream &stream,
                                                                                                                                                        const JulianDate &date
                                                                                                                                        );
                                friend std::istream &operator >>(std::istream &stream,
                                                                                                                                JulianDate &date
                                                                                                                  );


                                inline JulianDate();
                                inline JulianDate(const uint month, const uint day,
                                                                                        const uint year
                                                                          );
                                inline JulianDate(const JulianDate &date);
                                JulianDate(time_t date);
                                inline ~JulianDate();
                };

        }

# 1 "../julian/JulianDate.i" 1



#ident "@(#)$Id: JulianDate.i 1.7 Wed, 27 Mar 2002 13:37:52 -0800 tmwg $ -- Copyright (c) 2000-2002 inX Services"
# 13 "../julian/JulianDate.i"
# 1 "../julian/JulianDate.h" 1
# 14 "../julian/JulianDate.i" 2

        namespace inXServices {

inline bool
JulianDate::Is_leap_year(const uint year) {
        return (year <= 1582 )
                                ? ! (year % 4)
                                : ! (year % 4) && ((year % 100) || ! (year % 400));
}
# 35 "../julian/JulianDate.i"
inline int32_t
JulianDate::julian() const {
        return Julian;
}

inline JulianDate &
JulianDate::operator ++() {
        ++Julian;

        return *this;
}

inline JulianDate &
JulianDate::operator --() {
        --Julian;

        return *this;
}

inline JulianDate &
JulianDate::operator +=(const uint days) {
        Julian += days;

        return *this;
}

inline JulianDate &
JulianDate::operator -=(const uint days) {
        Julian -= days;

        return *this;
}

inline JulianDate &
JulianDate::operator =(const JulianDate &date) {
        Julian = date.Julian;

        return *this;
}

inline JulianDate &
JulianDate::operator ()(const uint month, const uint day, const uint year) {
        Julian = To_julian(month, day, year);

        return *this;
}

inline JulianDate &
JulianDate::add_days(const uint days) {
        return operator +=(days);
}

inline JulianDate &
JulianDate::subtract_days(const uint days) {
        return operator -=(days);
}

inline bool
JulianDate::operator ==(const JulianDate &date) const {
        return Julian == date.Julian;
}

inline bool
JulianDate::operator !=(const JulianDate &date) const {
        return Julian != date.Julian;
}

inline int
JulianDate::compare(const JulianDate &date) const {
        return long(Julian) - long(date.Julian);
}

inline bool
JulianDate::operator <(const JulianDate &date) const {
        return Julian < date.Julian;
}

inline bool
JulianDate::operator <=(const JulianDate &date) const {
        return Julian <= date.Julian;
}

inline bool
JulianDate::operator >(const JulianDate &date) const {
        return Julian > date.Julian;
}

inline bool
JulianDate::operator >=(const JulianDate &date) const {
        return Julian >= date.Julian;
}

inline
JulianDate::operator bool () const {
        return Julian;
}

inline bool
JulianDate::operator !() const {
        return ! Julian;
}

inline
JulianDate::operator time_t () const {
        return date();
}


inline std::ostream &
inXServices::operator <<(std::ostream &stream, const JulianDate &date) {
        return stream << date.Julian;
}
# 178 "../julian/JulianDate.i"
inline
JulianDate::JulianDate()
        : Julian(0) {
        ;
}

inline
JulianDate::JulianDate(const uint month, const uint day,
                                                                const uint year
                                                         ) {
        operator ()(month, day, year);
}

inline
JulianDate::JulianDate(const JulianDate &date)
        : Julian(date.Julian) {
        ;
}

inline
JulianDate::~JulianDate() {
        ;
}

inline JulianDate
JulianDate::operator ++(int) {
        JulianDate now(*this);
        ++Julian;

        return now;
}

inline JulianDate
JulianDate::operator --(int) {
        JulianDate now(*this);
        --Julian;

        return now;
}

inline JulianDate
JulianDate::operator +(const uint days) const {
        JulianDate now(*this);
        now.Julian += days;

        return now;
}

inline JulianDate
JulianDate::operator -(const uint days) const {
        JulianDate now(*this);
        now.Julian -= days;

        return now;
}

        }
# 136 "../julian/JulianDate.h" 2
# 14 "../julian/JulianTime.h" 2

        namespace inXServices {

                class JulianTime : public JulianDate {
                        private:
                                u_int32_t Seconds;
                        protected:
                        public:
                                inline uint hour() const;
                                inline uint minute() const;
                                inline uint second() const;
                                time_t date() const;

                                inline JulianDate &operator =(const JulianDate &date);
                                inline JulianTime &operator =(const JulianTime &date);

                                JulianDate &operator =(const time_t date);

                                JulianTime &operator ()(const uint month, const uint day,
                                                                                                        const uint year, const uint hour,
                                                                                                        const uint minute, const uint second
                                                                                          );

                                JulianTime &add_seconds(const uint seconds);
                                JulianTime &subtract_seconds(const uint seconds);

                                inline bool operator ==(const JulianTime &date) const;
                                inline bool operator !=(const JulianTime &date) const;
                                inline int compare(const JulianTime &date) const;

                                inline bool operator <(const JulianTime &date) const;
                                inline bool operator <=(const JulianTime &date) const;

                                inline bool operator >(const JulianTime &date) const;
                                inline bool operator >=(const JulianTime &date) const;

                                inline operator bool () const;
                                inline bool operator !() const;

                                inline operator time_t () const;

                                size_t print(char *buffer, const size_t buffer_bytes,
                                                                        const char *format
                                                                ) const;


                                inline friend std::ostream &operator <<(std::ostream &stream,
                                                                                                                                                const JulianTime &date
                                                                                                                                        );
                                friend std::istream &operator >>(std::istream &stream,
                                                                                                                                JulianTime &date
                                                                                                                  );


                                inline JulianTime();
                                inline JulianTime(const uint month, const uint day,
                                                                                        const uint year, const uint hour,
                                                                                        const uint minute, const uint second
                                                                          );
                                inline JulianTime(const JulianDate &date);
                                inline JulianTime(const JulianTime &date);
                                JulianTime(time_t date);
                                inline ~JulianTime();
                };

        }

# 1 "../julian/JulianTime.i" 1



#ident "@(#)$Id: JulianTime.i 1.7 Tue, 08 Jan 2002 19:55:17 -0800 tmwg $ -- Copyright (c) 2000,2001 inX Services"
# 13 "../julian/JulianTime.i"
# 1 "../julian/JulianTime.h" 1
# 14 "../julian/JulianTime.i" 2

        namespace inXServices {

inline uint
JulianTime::hour() const {
        return Seconds / (60 * 60);
}

inline uint
JulianTime::minute() const {
        return (Seconds - (hour() * 60 * 60)) / 60;
}

inline uint
JulianTime::second() const {
        return Seconds % 60;
}

inline JulianDate &
JulianTime::operator =(const JulianDate &date) {
        JulianDate::operator =(date);
        Seconds = 0;

        return *this;
}

inline JulianTime &
JulianTime::operator =(const JulianTime &date) {
        JulianDate::operator =(date);
        Seconds = date.Seconds;

        return *this;
}

inline bool
JulianTime::operator ==(const JulianTime &date) const {
        return Julian == date.Julian && Seconds == date.Seconds;
}

inline bool
JulianTime::operator !=(const JulianTime &date) const {
        return Julian != date.Julian || Seconds != date.Seconds;
}

inline int
JulianTime::compare(const JulianTime &date) const {
        return Julian == date.Julian
                                ? static_cast<long>(Seconds) - static_cast<long>(date.Seconds)
                                : static_cast<long>(Julian) - static_cast<long>(date.Julian);
}

inline bool
JulianTime::operator <(const JulianTime &date) const {
        return Julian < date.Julian && Seconds < date.Seconds;
}

inline bool
JulianTime::operator <=(const JulianTime &date) const {
        return Julian < date.Julian
                         || (Julian == date.Julian && Seconds <= date.Seconds);
}

inline bool
JulianTime::operator >(const JulianTime &date) const {
        return Julian > date.Julian && Seconds > date.Seconds;
}

inline bool
JulianTime::operator >=(const JulianTime &date) const {
        return Julian > date.Julian
                         || (Julian == date.Julian && Seconds >= date.Seconds);
}

inline
JulianTime::operator bool () const {
        return Julian;
}

inline bool
JulianTime::operator !() const {
        return ! Julian;
}

inline
JulianTime::operator time_t () const {
        return date();
}


inline std::ostream &
inXServices::operator <<(std::ostream &stream, const JulianTime &date) {
        return
                stream << static_cast<const JulianDate &>(date) << '/' << date.Seconds;
}


inline
JulianTime::JulianTime()
        : JulianDate(),
                Seconds(0) {
        ;
}

inline
JulianTime::JulianTime(const uint month, const uint day,
                                                                const uint year, const uint hour, const uint minute,
                                                                const uint second
                                                         ) {
        operator ()(month, day, year, hour, minute, second);
}

inline
JulianTime::JulianTime(const JulianDate &date)
        : JulianDate(date),
                Seconds(0) {
        ;
}

inline
JulianTime::JulianTime(const JulianTime &date)
        : JulianDate(date),
                Seconds(date.Seconds) {
        ;
}

inline
JulianTime::~JulianTime() {
        ;
}

        }
# 82 "../julian/JulianTime.h" 2
# 25 "../inXDB/DB/inXDB.h" 2



        typedef int32_t Integer;
        typedef u_int32_t Unsigned;
        typedef inXServices::JulianDate Date;
        typedef inXServices::JulianTime DateTime;
        typedef inXServices::JulianTime DayTime;
        typedef Unsigned Duration;
        typedef timeval PreciseTime;
        typedef double Real;
        typedef Unsigned TrueFalse;
        typedef Integer Character;
        typedef Integer Enumerator;
        typedef Unsigned SubclassID;

        namespace inXdb {

                const size_t inXDataBaseMagicBytes(16);
                const size_t inXDBNameLength(255);

                const Unsigned NoListIndex(~0);

                class inXDataBase;
                class inXDB;

                class inXDBException : public inXServices::inXException {
                        private:
                        protected:
                                inXDataBase &Data_Base;
                        public:
                                inline const inXDataBase &data_base() const;

                                friend std::ostream &operator <<(std::ostream &stream,
                                                                                                                                const inXDBException &exception
                                                                                                                  );
                                void show(std::ostream &stream) const;
                                const char *what() const throw();

                                inXDBException &operator =(const inXDBException &e);

                                inline inXDBException(inXDataBase &data_base);
                                inline inXDBException(inXDataBase &data_base, const uint state,
                                                                                                const FilePos file_number,
                                                                                                const FilePos page_number,
                                                                                                const char *message, const char *function,
                                                                                                const char *file, const uint line,
                                                                                                const char *type = "inXDataBase Error"
                                                                                        );
                                inline ~inXDBException() throw();
                };

extern "C" {
                typedef int (*btcmp_t)(const void *p1, const void *p2, const size_t keys);
}

                class inXDataBase

                        : protected inXServices::MmapFile



                {
                                friend class inXDBException;
                        public:
                                static char Magic[inXDataBaseMagicBytes];
                                static std::string Directory_Name;

                                enum Reason {
                                        Okay,

                                        CannotMakeDirForDB, NoDBName, NoBTreeName,
                                        CannotCreateHeaderFile, CannotCreateLockFile,
                                        CannotCreateDataFile, CannotCreateIndexFile,

                                        CannotOpenHeaderFile, CannotReadFileLocation,
                                        CannotReadFileHeader, CannotReadFileTable,
                                        CannotReadFilePageTable, CannotReadFileEmptyPageTable,
                                        CannotOpenLockFile, CannotOpenDataFile,
                                        CannotOpenBTreeFile, CannotReadBTreeHeader,

                                        CannotCloseFile,

                                        InvalidPageMagic, InvalidPageType, InvalidPageVersion,
                                        InvalidPageBytes, InvalidPageNumber, InvalidPageRevision,
                                        InvalidHeaderOffset, InvalidFileTableOffset,
                                        InvalidPageTableOffset, InvalidEmptyPageTableOffset,
                                        InvalidBTreeOrder, InvalidBTreeFieldDef,

                                        CannotReadDataPage, DataPageCorrupt, CantGetPageLock,

                                        CannotTraverseIndex, CannotReadNodePage, NodePageCorrupt,
                                        IndexMayBeCorrupt,

                                        CannotCheckLockBeginTrx, CannotLockBeginTrx, CannotLockCommitTrx,
                                        TooManyModifiedPages, CannotWriteTransaction,
                                        InvalidPageModification, CannotFindNewBTree,
                                        CannotWriteTrxHeader, CannotRemoveEmptyPage, CannotSync,

                                        CannotCreateDB, NoSuchDB,
                                        CannotCreateType, NoSuchType,
                                        CannotCreateTypeIndex, CannotUseTypeInIndex,
                                        GetTypeNoTrx, GetTypeIndexNoTrx,
                                        CannotCreateObjectInTrx, CannotWriteObjectInTrx,
                                        CannotRemoveObjectInTrx, CannotReadObjectInTrx,
                                        CannotDeleteObjectInTrx
                                };
                                struct BTreeFieldDefinition {
                                        FilePos Offset;
                                        FilePos Length;
                                        enum FieldType {
                                                FixedLengthWordType, FixedLengthUCWordType,
                                                WordType, TextType, TextNoEOFLType,
                                                DirNameType, FileNameType,
                                                CharacterType,
                                                IntegerType, UnsignedType,
                                                RealType,
                                                TrueFalseType,
                                                DateType, DateTimeType, DayTimeType,
                                                DurationType, PreciseTimeType,
                                                MoneyType,
                                                EnumeratorType,
                                                SubclassIDType,
                                                OIDType
                                        } Type;
                                        enum IndexOrder {
                                                Ascending = 1, Descending
                                        } Order;
                                };
                                struct BTreePosition {
                                        FilePos Node;
                                        FilePos Key;

                                        inline BTreePosition();
                                };

                                class Transaction;
                                class Datum;
                                class DataFile;
                                class BTree;
                        private:
                                static FilePos Version;
                                static char *Reason_Description[];

                                enum FileType {
                                        HeaderFile = 0x10000001,
                                        BTreeFile = 0x10000002,
                                        DatumFile = 0x10000003
                                };
                                class Page {
                                                friend class Datum;
                                        public:
                                                enum FileType {
                                                        PageIsFileHeader = 'H',
                                                        PageIsFileTable = 'F',
                                                        PageIsPageTable = 'P',
                                                        PageIsEmptyPageTable = 'E',
                                                        PageIsBTreeHeader = 'B',
                                                        PageIsBTreeNode = 'N',
                                                        PageIsData = 'D',
                                                };
                                                enum PageType {
                                                        FileLocation = 0x10000001,
                                                        FileHeader = 0x10000002,
                                                        FileTable = 0x10000003,
                                                        PageTable = 0x10000004,
                                                        EmptyPageTable = 0x10000005,
                                                        BTreeHeader = 0x10000006,
                                                        BTreeNode = 0x10000007,
                                                        DataPage = 0x10000008,
                                                };
                                        private:
                                        protected:
                                                uchar Magic[inXDataBaseMagicBytes];
                                                PageType Type;
                                                FilePos Version;
                                                FilePos Bytes;
                                                FilePos Number;
                                                FilePos Revision;

                                                static inline size_t Magic_file_type_index();
                                                static inline size_t
                                                        Magic_version_index(const size_t offset = 0);
                                                static inline FilePos Version_from_magic(const uchar *magic);

                                                void Initialize(const FileType file_type);
                                        public:
                                                inline const uchar *magic() const;
                                                inline const FileType magic_file_type() const;
                                                inline const uchar *magic_version() const;

                                                inline PageType type() const;

                                                inline FilePos version() const;
                                                inline uchar version_major() const;
                                                inline uchar version_minor() const;
                                                inline uchar version_release() const;
                                                inline uchar version_revision() const;

                                                inline FilePos bytes() const;
                                                inline FilePos number() const;
                                                inline FilePos revision() const;

                                                inline void Revised();
                                                inline void Expanded(const FilePos bytes);
                                                inline void Page_size(const FilePos bytes);

                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                void dump(std::ostream &stream) const;

                                                Page();
                                                Page(const FileType file_type, const PageType type,
                                                                const FilePos bytes
                                                         );
                                                Page(const FileType file_type, const PageType type,
                                                                const FilePos number, const FilePos bytes,
                                                                const FilePos revision
                                                         );
                                                inline ~Page();
                                };
                                class FileLocation : public Page {
                                                friend class Transaction;
                                        private:
                                                FilePos Page_Chunk_Size;
                                                FilePos File_Header_Offset;
                                        protected:
                                        public:
                                                inline FilePos page_chunk_size() const;

                                                inline FilePos file_header_offset() const;
                                                inline FilePos file_header_offset(const FilePos offset);

                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                void dump(std::ostream &stream) const;

                                                inline FileLocation(const FilePos page_chunk_size);
                                };
                                class FileHeader : public Page {
                                                friend class Transaction;
                                        private:
                                                FilePos File_Table_Offset;
                                                FilePos Page_Table_Offset;
                                                FilePos Empty_Page_Table_Offset;
                                        protected:
                                        public:
                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                inline FilePos file_table_offset() const;
                                                inline FilePos page_table_offset() const;
                                                inline FilePos empty_page_table_offset() const;

                                                void dump(std::ostream &stream) const;

                                                inline FileHeader(const FilePos page_chunk_size);
                                };
                                struct FileInfo {
                                        FileType Type;
                                        FilePos Page_Size;
                                        uchar Name_Bytes;
                                        char Name[];
                                };
                                class FileTable : public Page {
                                                friend class Transaction;
                                        private:
                                                FilePos Files;
                                                uchar File_Info[];
                                        protected:
                                        public:
                                                inline FilePos files() const;

                                                bool room_for(const DataFile &file,
                                                                                                const FilePos needs = 0
                                                                                 ) const;
                                                FilePos needs(const DataFile &file,
                                                                                                const FilePos needs = 0
                                                                                 ) const;
                                                inline void expanded(const FilePos bytes);

                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                const FileInfo &file_info(const uint index) const;

                                                void append(const DataFile &file, const FilePos page_size);

                                                void dump(std::ostream &stream) const;

                                                inline FileTable(const FilePos minimum_page_size,
                                                                                                const std::string header_file_name
                                                                                         );
                                };
                                struct PageInfo;
                                typedef PageInfo *PageInfoP;
                                struct PageInfo {
                                        FilePos File_Number;
                                        FilePos Offset;
                                        FilePos Bytes;

                                        static int compare(const PageInfoP *p1, const PageInfoP *p2);

                                        inline bool is_removed() const;
                                        inline bool is_present() const;
                                        inline void remove();

                                        inline PageInfo();
                                        inline PageInfo(const FilePos file, const FilePos offset,
                                                                                        const FilePos bytes
                                                                                );
                                        inline ~PageInfo();
                                };
                                class PageTable : public Page {
                                        private:
                                        protected:
                                                FilePos Pages;
                                                FilePos Files;
                                                uchar Page_Data[];

                                                uint Index(const uint file, const uint page) const;

                                                inline PageTable(const FileType type,
                                                                                                const PageType page_type,
                                                                                                const FilePos minimum_page_size,
                                                                                                const FilePos files
                                                                                         );
                                        public:
                                                inline FilePos files() const;
                                                FilePos another_file();

                                                inline bool room_for_pages(const FilePos new_pages,
                                                                                                                                const FilePos needs = 0
                                                                                                                  ) const;
                                                inline FilePos needs_pages(const FilePos new_pages,
                                                                                                                                const FilePos needs = 0
                                                                                                                  ) const;
                                                inline bool room_for_files(const FilePos new_files,
                                                                                                                                const FilePos needs = 0
                                                                                                                  ) const;
                                                inline FilePos needs_files(const FilePos new_files,
                                                                                                                                const FilePos needs = 0
                                                                                                                  ) const;
                                                inline void expanded(const FilePos bytes);

                                                inline const FilePos *files_pages() const;
                                                inline FilePos *files_pages();
                                                inline FilePos file_pages(const uint index) const;

                                                inline const PageInfo &file_page(const uint file,
                                                                                                                                                const uint page
                                                                                                                                  ) const;

                                                void add(const uint file, const FilePos number,
                                                                                const FilePos offset, const FilePos bytes
                                                                  );
                                                void move(const uint file, const Page &page,
                                                                                const FilePos offset
                                                                   );
                                                void remove(const uint file, const Page &page);

                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                void dump(std::ostream &stream) const;

                                                inline PageTable(const FilePos minimum_page_size,
                                                                                                const FilePos files
                                                                                         );
                                };
                                class EmptyPageTable : public PageTable {
                                        private:
                                        protected:
                                        public:
                                                bool verify(const inXDataBase &db, Reason &reason) const;
                                                bool verify_state(const PageTable &page_table) const;

                                                void add(const uint empty_pages,
                                                                                Array<PageInfo *> &empty_page
                                                                  );
                                                bool remove(const FilePos file, const FilePos offset,
                                                                                        const FilePos bytes
                                                                          );

                                                static inline FilePos not_found();
                                                FilePos find(const FilePos file, const FilePos bytes);

                                                inline void dump(std::ostream &stream) const;

                                                inline EmptyPageTable(const FilePos minimum_page_size,
                                                                                                                const FilePos files
                                                                                                        );
                                };
                                class DataPage : public Page {
                                        friend class Datum;



                                        private:
                                                FilePos Used;
                                                uchar Page_Data[];
                                        protected:
                                                inline void Used_size(const FilePos bytes);
                                                inline uchar *data();

                                                inline DataPage(const FileType file_type, const PageType type,
                                                                                                const FilePos number, const FilePos bytes,
                                                                                                const FilePos used
                                                                                   );
                                        public:
                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                inline FilePos used() const;
                                                inline const uchar *data() const;

                                                void dump(std::ostream &stream) const;

                                                inline DataPage(const FilePos number, const FilePos bytes,
                                                                                                const FilePos used
                                                                                   );
                                };
                        protected:
                                class DataFile

                                        : protected inXServices::MmapFile



                                {
                                                friend class Transaction;
                                        protected:
                                                std::string Name;
                                                FilePos Number;
                                                FileType Type;
                                                inXDataBase &Data_Base;
                                                inXServices::File *Read_Lock;
                                                inXServices::File *Write_Lock;

                                                bool Can_read_lock(const FilePos number,
                                                                                                        const bool wait_for_lock
                                                                                                )
                                                                throw(inXDBException);

                                                inline void Get_header(Transaction &trx, const bool read_only)
                                                                throw(inXDBException);





                                                inline Datum *Get(const FilePos page, Transaction &trx,
                                                                                                        const bool read_only
                                                                                          )
                                                                throw(inXDBException);

                                                bool Remove_file();

                                                bool Insert(Transaction &trx, const void *buffer)
                                                                throw(inXDBException);
                                                bool Remove(Transaction &trx, const void *buffer)
                                                                throw(inXDBException);

                                                inline DataFile(inXDataBase &data_base, const FileType type);
                                                DataFile(inXDataBase &data_base, const FilePos file,
                                                                                const std::string &file_name, const FileType type
                                                                  )
                                                                throw(inXDBException);

                                                inline DataFile(inXDataBase &data_base,
                                                                                                const std::string &file_name,
                                                                                                const FileType type
                                                                                        );
                                                inline DataFile(inXDataBase &data_base, const FilePos number,
                                                                                                const FileType type
                                                                                        );
                                        public:
                                                inline const std::string &name() const;
                                                inline FilePos file() const;
                                                inline FileType type() const;

                                                inline int compare(const DataFile &file) const;
                                                int compare_name(const DataFile &file) const;

                                                void close()
                                                                throw(inXDBException);
                                                void create(const char *file_name, const FilePos file,
                                                                                        const FilePos block_size
                                                                          )
                                                                throw(inXDBException);
                                                bool open(const FilePos page_size, const bool writable)
                                                                throw(inXDBException);

                                                void statistics(std::ostream &stream)
                                                                throw(inXDBException);
                                                void verify()
                                                                throw(inXDBException);

                                                void dump(std::ostream &stream) const;

                                                inline DataFile(inXDataBase &data_base);
                                                DataFile(inXDataBase &data_base, const FilePos file,
                                                                                const std::string &file_name,
                                                                                const FilePos header_size, const bool writable
                                                                  )
                                                                throw(inXDBException);
                                                DataFile(const BTree &file);

                                                inline DataFile(inXDataBase &data_base,
                                                                                                const std::string &file_name
                                                                                        );
                                                inline DataFile(inXDataBase &data_base, const FilePos number);
                                                ~DataFile()
                                                                throw(inXDBException);
                                };
                                class BTreePage : public Page {
                                                friend class BTree;
                                        private:
                                                FilePos Order;
                                                FilePos Key_Size;
                                                FilePos Page_Size;
                                                FilePos Root;
                                                FilePos First;
                                                FilePos Last;
                                                FilePos Keys;
                                                FilePos Height;
                                                FilePos Fields;
                                                BTreeFieldDefinition Field_Definition[];
                                        protected:
                                        public:
                                                bool verify(const inXDataBase &db, Reason &reason) const;

                                                inline FilePos order() const;
                                                inline FilePos key_size() const;
                                                inline FilePos page_size() const;

                                                inline FilePos node_maximum() const;
                                                inline FilePos node_minimum() const;

                                                inline FilePos root() const;
                                                inline FilePos root(const FilePos root);

                                                inline FilePos first() const;
                                                inline FilePos first(const FilePos first);

                                                inline FilePos last() const;
                                                inline FilePos last(const FilePos last);

                                                inline FilePos keys() const;
                                                inline FilePos keys(const FilePos keys);

                                                inline FilePos height() const;
                                                inline FilePos height(const FilePos height);

                                                inline FilePos fields() const;
                                                inline const BTreeFieldDefinition *field_definition() const;

                                                void dump(std::ostream &stream) const;

                                                BTreePage(const FilePos block_size, const FilePos order,
                                                                                const FilePos key_size, const FilePos page_size,
                                                                                const FilePos fields,
                                                                                const BTreeFieldDefinition *field_definition
                                                                        );
                                };
                                class BTreeNodePage : public DataPage {
                                        private:




                                        protected:
                                        public:
                                                inline FilePos left() const;
                                                inline FilePos left(const FilePos left);

                                                inline FilePos right() const;
                                                inline FilePos right(const FilePos right);

                                                inline FilePos keys() const;
                                                inline FilePos keys(const FilePos keys);

                                                inline const uchar *data() const;
                                                inline uchar *data();

                                                void dump(std::ostream &stream,
                                                                                const BTreePage &header
                                                                        ) const;

                                                inline BTreeNodePage(const FilePos number,
                                                                                                                const FilePos bytes,
                                                                                                                const FilePos used
                                                                                                  );
                                };
                                class BTree : public DataFile {
                                                friend class Transaction;
                                        private:
                                                static btcmp_t Compare[21];

                                                Datum *Header;
                                        protected:
                                                struct Link {
                                                        uchar *Key;
                                                        FilePos Child;

                                                        inline Link(const BTreePage &header);
                                                        inline ~Link();
                                                };
                                                struct Node {
                                                        BTreeNodePage *Node_Page;
                                                        uchar *Key;
                                                        FilePos *Child;

                                                        inline FilePos *child(const FilePos index);
                                                        inline const FilePos *child(const FilePos index) const;

                                                        inline uchar *key(const FilePos index,
                                                                                                                const BTreePage &header
                                                                                                  );
                                                        inline const uchar *key(const FilePos index,
                                                                                                                                const BTreePage &header
                                                                                                                  ) const;

                                                        inline uchar *key_field(const FilePos index,
                                                                                                                                const FilePos field,
                                                                                                                                const BTreePage &header
                                                                                                                  );
                                                        inline const uchar *key_field(const FilePos index,
                                                                                                                                                const FilePos field,
                                                                                                                                                const BTreePage &header
                                                                                                                                  ) const;

                                                        inline bool is_leaf() const;
                                                        inline bool is_branch() const;

                                                        bool Find(const void *buffer, const BTreePage &header,
                                                                                 FilePos &key
                                                                                );

                                                        void Shift_key(const FilePos from, const long long to,
                                                                                                        const BTreePage &header,
                                                                                                        inXDataBase &data_base
                                                                                          )
                                                                        throw(inXDBException);
                                                        void Write_key(const FilePos key, const Link *link,
                                                                                                        const BTreePage &header,
                                                                                                        inXDataBase &data_base
                                                                                          )
                                                                        throw(inXDBException);
                                                        void Insert_key(const Link &link, const FilePos key,
                                                                                                        const BTreePage &header,
                                                                                                        inXDataBase &data_base
                                                                                                )
                                                                        throw(inXDBException);
                                                        inline void Remove_key(const FilePos key,
                                                                                                                        const BTreePage &header,
                                                                                                                        inXDataBase &data_base
                                                                                                                 )
                                                                        throw(inXDBException);
                                                        void Read_key(const FilePos key, const BTreePage &header,
                                                                                                        inXDataBase &data_base,
                                                                                          Link &link
                                                                                         )
                                                                        throw(inXDBException);
                                                        void Move_left(const long long keys,
                                                                                                        const BTreePage &header,
                                                                                                        inXDataBase &data_base,
                                                                                                Node &left
                                                                                          )
                                                                        throw(inXDBException);
                                                        void Move_right(const long long keys,
                                                                                                        const BTreePage &header,
                                                                                                        inXDataBase &data_base,
                                                                                                 Node &left
                                                                                                )
                                                                        throw(inXDBException);

                                                        inline void initialize(const BTreePage &header);
                                                        inline void copy(const Node &node,
                                                                                                        const BTreePage &header
                                                                                                 );

                                                        inline void clear(const BTreePage &header);

                                                        inline Node &operator =(const Node &node);
                                                        inline Node &operator ()(const BTreePage &header,
                                                                                                                                BTreeNodePage *node
                                                                                                                        );
                                                        inline Node &operator ()(const BTreePage &header,
                                                                                                                                const BTreeNodePage *node
                                                                                                                        );
                                                        inline Node &operator ()();

                                                        inline operator bool();

                                                        inline Node();
                                                        inline Node(const BTreePage &header, BTreeNodePage *node);
                                                        inline Node(const Node &node);
                                                        inline ~Node();
                                                };
                                                BTreePosition Current_Position;
                                                Node Current_Node;
                                                BTreePosition *Search_Path;

                                                inline FilePos Node_maximum() const;
                                                inline FilePos Node_minimum() const;

                                                void Free_node(Node *node);
                                                bool Validate(const FilePos key_size, const FilePos fields,
                                                                                                const BTreeFieldDefinition *field_definition
                                                                                 );
                                                inline void Get_header(Transaction &trx, const bool read_only)
                                                                throw(inXDBException);





                                                inline Datum *Get(const FilePos page, Transaction &trx,
                                                                                                        const bool read_only
                                                                                          )
                                                                throw(inXDBException);
                                                void Grow(Transaction &trx, const Link &link)
                                                                throw(inXDBException);
                                                bool Find_key(Transaction &trx, const void *buffer)
                                                                throw(inXDBException);
                                                void Split(const FilePos page, inXDataBase &data_base,
                                                                                        Transaction &trx,
                                                                          Node &node, Node &right, Link &link
                                                                         )
                                                                throw(inXDBException);
                                                void Shift_node(const FilePos parent_key,
                                                                                                const FilePos parent_node,
                                                                                         Node &left, Node &right, Node &parent
                                                                                        )
                                                                throw(inXDBException);
                                                void Shrink(Transaction &trx, const FilePos new_root)
                                                                throw(inXDBException);
                                                void Fuse(Transaction &trx, const FilePos parent_key,
                                                                         Node &left, Node &right, Node &parent
                                                                        )
                                                                throw(inXDBException);
                                                void Remove(Transaction &trx)
                                                                throw(inXDBException);
                                                void Set_cursor(Node &left, Node &right);
# 800 "../inXDB/DB/inXDB.h"
                                                bool Remove_file();

                                                FilePos Keys(Transaction &trx)
                                                                throw(inXDBException);

                                                bool Insert(Transaction &trx, const void *buffer)
                                                                throw(inXDBException);
                                                bool Remove(Transaction &trx, const void *buffer)
                                                                throw(inXDBException);

                                                bool Find(Transaction &trx, const void *buffer)
                                                                throw(inXDBException);
                                                bool First(Transaction &trx)
                                                                throw(inXDBException);
                                                bool Last(Transaction &trx)
                                                                throw(inXDBException);
                                                bool Next(Transaction &trx)
                                                                throw(inXDBException);
                                                bool Previous(Transaction &trx)
                                                                throw(inXDBException);
                                                bool Nth(Transaction &trx, const FilePos index)
                                                                throw(inXDBException);

                                                inline void Get_current(BTreePosition &position);
                                                bool Set_current(Transaction &trx,
                                                                                                const BTreePosition &position
                                                                                         )
                                                                throw(inXDBException);

                                                bool Get_key(void *buffer) const
                                                                throw(inXDBException);
                                                bool Get_key(void *buffer, const size_t buffer_length) const
                                                                throw(inXDBException);
                                                bool Remove_current(Transaction &trx)
                                                                throw(inXDBException);
                                        public:
                                                inline FilePos key_size() const;
                                                inline FilePos keys() const;

                                                void close()
                                                                throw(inXDBException);
                                                void create(FilePos &header_size,
                                                                                const char *file_name, const FilePos file,
                                                                                        const FilePos block_size,
                                                                                        const FilePos key_size, const FilePos fields,
                                                                                        const BTreeFieldDefinition *field_definition
                                                                          )
                                                                throw(inXDBException);
                                                bool open(const FilePos header_offset,
                                                                                const FilePos header_size, const bool writable
                                                                        )
                                                                throw(inXDBException);

                                                void statistics(std::ostream &stream)
                                                                throw(inXDBException);
                                                void verify()
                                                                throw(inXDBException);

                                                void dump(std::ostream &stream) const;

                                                BTree(inXDataBase &data_base)
                                                                throw(inXDBException);
                                                BTree(inXDataBase &data_base, const FilePos file,
                                                                        const std::string &file_name,
                                                                        const FilePos header_offset,
                                                                        const FilePos header_size, const bool writable
                                                          )
                                                                throw(inXDBException);
                                                BTree(const BTree &file);

                                                inline BTree(inXDataBase &data_base,
                                                                                        const std::string &file_name
                                                                                );
                                                inline BTree(inXDataBase &data_base, const FilePos number);
                                                ~BTree()
                                                                throw(inXDBException);
                                };
                        public:
                                class Datum {
                                                friend class inXDataBase;
                                                friend class BTree;
                                                friend class Transaction;
                                        private:
                                                bool Delete_Page;
                                                union {
                                                        uchar *Page_Buffer;
                                                        void *Page_Pointer;
                                                        DataPage *Data_Page;
                                                        BTreePage *BTree_Header;
                                                        BTreeNodePage *BTree_Node;
                                                };
                                                enum DatumType {
                                                        DataType, BTreeHeaderType, BTreeNodeType
                                                } Type;
                                                FilePos File;
                                                FilePos Offset;
                                                FilePos Bytes;
                                                FilePos Used;
                                                bool Removed;
                                                uchar *Modified;
                                                union {
                                                        uchar *Current_Page_Buffer;
                                                        void *Current_Page_Pointer;
                                                        BTreePage *Current_BTree_Header;
                                                        BTreeNodePage *Current_BTree_Node;
                                                };
                                                union {
                                                        uchar *Modified_Page_Buffer;
                                                        void *Modified_Page_Pointer;
                                                        DataPage *Modified_Data_Page;
                                                        BTreePage *Modified_BTree_Header;
                                                        BTreeNodePage *Modified_BTree_Node;
                                                };

                                                uchar *Modifiable_data();
                                                Page *Modified_page(const FilePos number);
                                                uchar *Resize(const FilePos bytes,
                                                                                                const FilePos minimum_page_size
                                                                                 );

                                                BTreePage *Modifiable_tree_header();
                                                inline BTreePage *Tree_header();
                                                inline const BTreePage *Tree_header() const;

                                                BTreeNodePage *Modifiable_tree_node();
                                                inline BTreeNodePage *Tree_node();
                                                inline const BTreeNodePage *Tree_node() const;

                                                inline void Remap(const void *old_start, const void *old_end,
                                                                                                        const long offset
                                                                                          );
                                        protected:
                                                inline Datum(const FilePos file, const FilePos number,
                                                                                        const FilePos bytes,
                                                                                        const FilePos minimum_page_size
                                                                                );
                                                inline Datum(const FilePos file, const FilePos number,
                                                                                        const FilePos node_page_size
                                                                                );
                                        public:
                                                inline int compare(const Datum &datum) const;

                                                inline FilePos file() const;
                                                inline FilePos offset() const;
                                                inline FilePos number() const;
                                                inline FilePos page_bytes() const;
                                                inline FilePos data_bytes() const;

                                                inline FilePos used() const;
                                                inline FilePos new_page_bytes() const;

                                                inline bool is_new() const;
                                                inline bool is_not_new() const;
                                                inline bool is_modified() const;
                                                inline bool is_not_modified() const;
                                                inline bool is_removed() const;
                                                inline bool is_not_removed() const;

                                                inline const uchar *page() const;
                                                inline const uchar *data() const;
                                                inline uchar *data();
                                                inline uchar *resize(const FilePos bytes,
                                                                                                                const FilePos minimum_page_size
                                                                                                  );

                                                inline void remove();

                                                void dump(std::ostream &stream) const;


                                                inline Datum(const FilePos file, const FilePos number);
                                                inline Datum(const FilePos file, const PageInfo &info,
                                                                                        DataPage *data_page
                                                                                );
                                                inline Datum(const FilePos file, const FilePos offset,
                                                                                        BTreePage *tree_page
                                                                                );
                                                inline Datum(const FilePos file, const PageInfo &info,
                                                                                        BTreeNodePage *tree_node
                                                                                );
                                                inline ~Datum();
                                };
                                class Transaction {
                                                friend class inXDataBase;
                                                friend class inXDataBase::BTree;
                                                friend class inXDB;
                                        private:
                                        protected:
                                                struct BTreeTrx {
                                                        enum TrxType {
                                                                Insert, Remove
                                                        } Type;
                                                        BTree *Tree;
                                                        const uchar *Key;
                                                };

                                                bool In_Progress;
                                                const std::string Name;
                                                ulong Number;
                                                inXDataBase &Data_Base;
                                                union {
                                                        uchar *Location_Buffer;
                                                        void *Location_Pointer;
                                                        FileLocation *Location;
                                                };
                                                union {
                                                        uchar *Header_Buffer;
                                                        void *Header_Pointer;
                                                        FileHeader *Header;
                                                };
                                                union {
                                                        uchar *File_Table_Buffer;
                                                        void *File_Table_Pointer;
                                                        FileTable *File_Table;
                                                };
                                                union {
                                                        uchar *Page_Table_Buffer;
                                                        void *Page_Table_Pointer;
                                                        PageTable *Page_Table;
                                                };
                                                union {
                                                        uchar *Empty_Page_Table_Buffer;
                                                        void *Empty_Page_Table_Pointer;
                                                        EmptyPageTable *Empty_Page_Table;
                                                };
                                                Array<FilePos> File_Pages;
                                                inXServices::AVL<Datum> Page_List;
                                                inXServices::AVL<DataFile> DataFile_List;
                                                inXServices::AVL<BTree> BTree_List;
                                                inXServices::AVL<DataFile> File_by_Name;
                                                inXServices::AVL<DataFile> New_File;
                                                uint Index_Transactions;
                                                ClassArray<BTreeTrx> Index_Transaction;
                                                struct DataFileInfo {
                                                        FilePos file;
                                                        FilePos header_size;

                                                        inline int compare(const DataFileInfo &index) const;

                                                        inline DataFileInfo(const FilePos f);
                                                        inline DataFileInfo(const FilePos f, const FilePos hs);
                                                };
                                                inXServices::AVL<DataFileInfo> File_Info;

                                                Datum *Tree_header(BTree &tree, const bool read_only)
                                                                        throw(inXDBException);

                                                Datum *Tree_node(BTree &tree, const FilePos number,
                                                                                                const bool read_only
                                                                                         )
                                                                        throw(inXDBException);

                                                Datum &New_empty_node(BTree &tree, const FilePos bytes);
                                                void Read_headers(const bool from_DB)
                                                                        throw(inXDBException);
                                                void Check_before_commit(Datum &datum, DataFile *file)
                                                                        throw(inXDBException);
                                                void Pages_remapped(const FilePos file,
                                                                                                                const void *old_start,
                                                                                                                const void *old_end,
                                                                                                                const void *new_base
                                                                                                 );

                                                inline void unduplicate();

                                                void abort();
                                                void commit()
                                                                throw(inXDBException);

                                                Datum *Page(const FilePos file, const FilePos number,
                                                                                        const bool read_only, const bool wait_for_lock
                                                                          )
                                                                throw(inXDBException);
                                                void New_file(const DataFile &file, const FilePos file,
                                                                                                const FilePos header_size
                                                                                 );
                                                bool Remove(const Datum &page, BTree &tree,
                                                                                        const bool wait_for_lock = true
                                                                          );

                                                void Forget_page(const FilePos file, const FilePos number)
                                                                throw(inXDBException);


                                                Transaction(inXDataBase &data_base, const std::string &name);

                                                Transaction(inXDataBase &data_base, const std::string &name,
                                                                                        const ulong number,
                                                                                        const bool read_headers_from_DB
                                                                          );
                                        public:
                                                inline int compare(const Transaction &trx) const;

                                                inline const std::string &name() const;
                                                inline ulong number() const;
                                                const std::string trx_name() const;

                                                Datum &new_empty_page(const FilePos file,
                                                                                                                const FilePos bytes
                                                                                                        );
                                                inline const Datum *page(const FilePos file,
                                                                                                                        const FilePos number,
                                                                                                                        const bool wait_for_lock = true
                                                                                                                )
                                                                throw(inXDBException);
                                                inline Datum *modifiable_page(const FilePos file,
                                                                                                                                        const FilePos number,
                                                                                                                                        const bool wait_for_lock
                                                                                                                                                        = true
                                                                                                                          )
                                                                throw(inXDBException);
                                                bool remove(const Datum &page,
                                                                                        const bool wait_for_lock = true
                                                                          );





                                                bool not_modified(std::string *message,
                                                                                                const Datum &page
                                                                                          )
                                                                throw(inXDBException);

                                                DataFile &new_file(const std::string &file_name,
                                                                                                        const FilePos block_size
                                                                                                )
                                                                throw(inXDBException);
                                                BTree &new_index(const std::string &file_name,
                                                                                                const FilePos block_size,
                                                                                                const FilePos key_size,
                                                                                                const FilePos fields,
                                                                                                const BTreeFieldDefinition *field_definition
                                                                                         )
                                                                throw(inXDBException);
                                                BTree &index(const FilePos number)
                                                                throw(inXDBException);
                                                bool insert(BTree &tree, const void *buffer)
                                                                throw(inXDBException);
                                                bool remove(BTree &tree, const void *buffer)
                                                                throw(inXDBException);
                                                inline bool find(BTree &tree, const void *buffer)
                                                                throw(inXDBException);
                                                inline bool first(BTree &tree)
                                                                throw(inXDBException);
                                                inline bool last(BTree &tree)
                                                                throw(inXDBException);
                                                inline bool next(BTree &tree)
                                                                throw(inXDBException);
                                                inline bool previous(BTree &tree)
                                                                throw(inXDBException);
                                                inline bool nth(BTree &tree, const FilePos index)
                                                                throw(inXDBException);
                                                inline void get_current(BTree &tree, BTreePosition &position);
                                                inline bool set_current(BTree &tree,
                                                                                                                        const BTreePosition &position
                                                                                                          )
                                                                throw(inXDBException);
                                                inline bool get_key(BTree &tree, void *buffer)
                                                                throw(inXDBException);
                                                inline bool get_key(BTree &tree, void *buffer,
                                                                                                        const size_t buffer_length
                                                                                                 )
                                                                throw(inXDBException);




                                                inline FilePos keys(const BTree &tree) const;
                                                inline FilePos keys(BTree &tree);

                                                void dump(std::ostream &stream) const;

                                                ~Transaction();
                                };
                        private:
                                friend class Page;
                                friend class FileLocation;
                                friend class FileHeader;
                                friend class FileTable;
                                friend class PageTable;
                                friend class EmptyPageTable;
                                friend class DataFile;
                                friend class BTree;
                                friend class DataPage;
                                friend class Datum;
                                friend class Transaction;

                                bool Writable;
                                std::string Name;
                                Reason State;
                                FilePos File_Number;
                                FilePos Page_Number;
                                union {
                                        uchar *Location_Buffer;
                                        void *Location_Pointer;
                                        FileLocation *Location;
                                };
                                union {
                                        uchar *Header_Buffer;
                                        void *Header_Pointer;
                                        FileHeader *Header;
                                };
                                union {
                                        uchar *File_Table_Buffer;
                                        void *File_Table_Pointer;
                                        FileTable *File_Table;
                                };
                                union {
                                        uchar *Page_Table_Buffer;
                                        void *Page_Table_Pointer;
                                        PageTable *Page_Table;
                                };
                                union {
                                        uchar *Empty_Page_Table_Buffer;
                                        void *Empty_Page_Table_Pointer;
                                        EmptyPageTable *Empty_Page_Table;
                                };
                                inXServices::File *Lock_File;
                        protected:
                                inXServices::AVL<Transaction> Trx_List;
                        private:
                                bool Read_headers()
                                                throw(inXDBException);
                                bool Current_headers(FileLocation **location, FileHeader **header,
                                                                                                FileTable **file_table,
                                                                                                PageTable **page_table,
                                                                                                EmptyPageTable **empty_page_table
                                                                                  )
                                                throw(inXDBException);
                        protected:
                                static const std::string Header_file_name(const std::string &name);
                                static const std::string Lock_file_name(const std::string &name,
                                                                                                                                                const bool read_lock
                                                                                                                                        );
                                static const std::string Index_file_name(const std::string &name);
                                static const std::string Data_file_name(const std::string &name);

                                bool Expensive_verify_state() const;
                                bool Verify_state() const;
                                bool Begin_transaction(const bool wait)
                                                throw(inXDBException);
                        public:
                                inline uchar version_major() const;
                                inline uchar version_minor() const;
                                inline uchar version_release() const;
                                inline uchar version_revision() const;



                                inline const std::string &name() const;
                                inline const Reason state() const;
                                inline const std::string reason() const;
                                inline const FilePos file_number() const;
                                inline const FilePos page_number() const;

                                inline void set_state_to_okay();

                                void close()
                                                throw(inXDBException);
                                void create(const std::string &DB_name)
                                                throw(inXDBException);
                                void open(const std::string &DB_name, const bool writable)
                                                throw(inXDBException);
                                inline void open(const bool writable = true)
                                                throw(inXDBException);

                                inline bool is_open() const;
                                inline bool is_closed() const;

                                Transaction *begin_transaction(const std::string &name,
                                                                                                                        const bool wait,
                                                                                                                        const bool read_headers_from_DB
                                                                                                                                = true
                                                                                                                )
                                                throw(inXDBException);
                                void abort_transaction(Transaction &trx,
                                                                                                const bool first_time = true
                                                                                         )
                                                throw(inXDBException);
                                void commit_transaction(Transaction &trx)
                                                throw(inXDBException);

                                void log_error(inXDataBase *&db, const bool fatal,
                                                                                const char *format, ...
                                                                  )



                                        ;

                                void statistics(std::ostream &stream)
                                                throw(inXDBException);
                                void dump(std::ostream &stream)
                                                throw(inXDBException);

                                inXDataBase(const char *program_name = 0,
                                                                        const char *error_log_file_name = 0
                                                          );
                                ~inXDataBase()
                                                throw(inXDBException);
                };

                const uint inXDB_Name_Length = 128;
                const Unsigned DB_Extra_Heap_Bytes = 1024;






                const FilePos inXDB_BTree_Page_Size = 16384;







                const FilePos inXDB_Type_BTree_Page_Size = 32768;

                class DBObject;

                typedef u_int32_t TimeStamp;
                typedef u_int32_t OIDVersion;
# 1355 "../inXDB/DB/inXDB.h"
                class inXDB : private inXDataBase {
                                friend class DBObject;
                        public:
                                class ObjectList;
                                class DB;
                                class Type;
                                class TypeAttribute;
                                class TypeIndex;
                                class inXDBTransaction;
                                friend class ObjectList;
                                friend class DB;
                                friend class Type;
                                friend class TypeAttribute;
                                friend class TypeIndex;
                                friend class inXDBTransaction;

                                static std::string Source_Code_Directory_Name;


                                struct OID {
                                                friend class inXDB;
                                                friend class inXDBTransaction;
                                        private:
                                                FilePos File;
                                                FilePos Page;
                                                FilePos Unique;
                                                OIDVersion Version;
                                                FilePos Bytes;
                                                TimeStamp Last_Modified;
                                        public:
                                                inline bool is_valid() const;
                                                inline bool is_invalid() const;

                                                inline void invalidate();

                                                inline FilePos file() const;
                                                inline FilePos page() const;
                                                inline FilePos unique() const;
                                                inline OIDVersion version() const;
                                                inline FilePos bytes() const;
                                                inline TimeStamp last_modified() const;

                                                static inline size_t necessary_size();

                                                inline int compare(const OID &ID) const;
                                                inline bool operator ==(const OID &ID) const;
                                                inline bool operator !=(const OID &ID) const;

                                                inline OID &operator =(const OID &ID);

                                                inline OID();
                                                inline OID(const FilePos file, const FilePos page,
                                                                                const FilePos unique, const OIDVersion version
                                                                         );
                                                inline OID(const OID &ID);
                                                inline ~OID();
                                };
                                class inXDBTransaction : protected Transaction {
                                                friend class inXDB;
                                                friend class DB;
                                                friend class Type;
                                                friend class TypeIndex;
                                                friend class DBObject;
                                        private:
                                                inXDB &Data_Base;
                                                Datum *Header_Datum;
                                                BTree *DB_Index;
                                                uint New_DBs;
                                                Array<DB *> New_DB;
                                                uint New_Types;
                                                Array<Type *> New_Type;
                                                uint New_Indeces;
                                                Array<TypeIndex *> New_Index;
                                                inXServices::AVL<DB> DB_List;
                                                inXServices::AVL<Type> Type_List;
                                                inXServices::AVL<TypeIndex> Index_List;
                                                inXServices::AVL<DBObject> Object_List;
                                                uint Removed_Objects;
                                                Array<DBObject *> Removed_Object_List;
                                        protected:
                                                Datum &New_empty_page(OID &object_ID,
                                                                                                         const FilePos file, const FilePos bytes
                                                                                                        );
                                                DataFile &New_file(FilePos &file,
                                                                                                 const std::string &file_name
                                                                                                )
                                                                throw(inXDBException);
                                                BTree &New_index(FilePos &file_number,
                                                                                          const std::string &file_name,
                                                                                                const FilePos block_size,
                                                                                                const FilePos key_size,
                                                                                                const FilePos fields,
                                                                                                const BTreeFieldDefinition *field_definition
                                                                                         )
                                                                throw(inXDBException);
                                                DB *Get_DB(OID &object_ID)
                                                                throw(inXDBException);
                                                DB *Get_DB(const std::string &name)
                                                                throw(inXDBException);
                                                DB *Get_DB(OID &object_ID,
                                                                          const std::string &name
                                                                         )
                                                                throw(inXDBException);
                                                void Add(OID &object_ID,
                                                                        const FilePos file, const void *record,
                                                                                const FilePos bytes
                                                                  )
                                                                throw(inXDBException);
                                                void Add(DBObject &object,
                                                                        const FilePos file, const void *record,
                                                                                const FilePos bytes
                                                                  )
                                                                throw(inXDBException);
                                                inline void Put(OID &object_ID,
                                                                                         const FilePos file, const void *record,
                                                                                                        const FilePos bytes
                                                                                   )
                                                                throw(inXDBException);
                                                bool Put(OID &object_ID,
                                                                        const void *record, const FilePos bytes,
                                                                                const bool wait_for_lock = true
                                                                  )
                                                                throw(inXDBException);
                                                const uchar *Get(OID &object_ID,
                                                                                                        const bool modifiable = false,
                                                                                                        const bool wait_for_lock = true
                                                                                         )
                                                                throw(inXDBException);
                                                bool Remove(DBObject &object)
                                                                throw(inXDBException);

                                                bool Have_data_base(const char *DB_name,
                                                                                                  OID *ID = 0, FilePos *file = 0
                                                                                                 )
                                                                throw(inXDBException);





                                                void Add(OID &object_ID,
                                                                        DB *db, const void *record, const FilePos bytes
                                                                  )
                                                                throw(inXDBException);
                                                void Add(Type *type)
                                                                throw(inXDBException);
                                                void Add(TypeIndex *index)
                                                                throw(inXDBException);






                                                void Remove(DB &db)
                                                                throw(inXDBException);
                                                void Remove(const FilePos file)
                                                                throw(inXDBException);

                                                void abort();
                                                void commit()
                                                                throw(inXDBException);

                                                inXDBTransaction(inXDB &data_base, const std::string &name,
                                                                                                        const ulong number,
                                                                                                        const bool read_headers_from_DB
                                                                                         );
                                        public:
                                                inline const std::string &name() const;
                                                inline inXDB &inX_data_base();
                                                inline bool have_data_base(const std::string &DB_name)
                                                                throw(inXDBException);
                                                DB *data_base(const std::string &name)
                                                                throw(inXDBException);
                                                Type *type(DB &db, const std::string &name)
                                                                throw(inXDBException);
                                                Type *type(DB &db, OID &object_ID)
                                                                throw(inXDBException);
                                                Type *type(OID &object_ID)
                                                                throw(inXDBException);
                                                TypeIndex *indece(Type &type, OID &object_ID)
                                                                throw(inXDBException);




                                                void get_object(DBObject &object,
                                                                                                const bool modifiable = false,
                                                                                                const bool wait_for_lock = true
                                                                                        )
                                                                throw(inXDBException);
                                                DBObject *find_object(OID &object_ID)
                                                                throw(inXDBException);
                                                bool lock_object(const OID &object_ID, const bool read_only,
                                                                                                        const bool wait_for_lock = true
                                                                                         )
                                                                throw(inXDBException);
                                                bool is_modifiable(std::string *message,
                                                                                                 const OID &object_ID,
                                                                                                        const bool wait_for_lock = true
                                                                                                )
                                                                throw(inXDBException);

                                                DB *list_data_bases(BTreePosition &position,
                                                                                                  const bool ascending = true
                                                                                                 );

                                                inline void done(DB **db);
                                                inline void done(Type **type);
                                                inline void done(TypeIndex **index);
                                                inline void done(DBObject *object);
                                                inline void done(const DBObject *object);
                                                inline static void in_process(DBObject &object);
                                                inline static void temporary(const DBObject &object);
                                                void replaced(DBObject &old_object, DBObject *new_object);

                                                ~inXDBTransaction();
                                };
                                enum ClassType {
                                        FixedLengthWordType, FixedLengthUCWordType,
                                        WordType, TextType, TextNoEOFLType,
                                        DirNameType, FileNameType,
                                        CharacterType,
                                        IntegerType, UnsignedType,
                                        RealType,
                                        TrueFalseType,
                                        DateType, DateTimeType, DayTimeType,
                                        DurationType, PreciseTimeType,
                                        MoneyType,
                                        EnumeratorType,
                                        SubclassIDType,

                                        SetType, ListType, ReferenceType,
                                        SetArrayType, ListArrayType,

                                        DataEntryType,

                                        UserType, UserClass
                                };
                                class ObjectList {
                                        private:
                                                struct DBRecord {
                                                        Unsigned Objects;
                                                        OID Object_ID[1];
                                                };
                                                OID Object_ID;
                                                Unsigned Objects_in_Database;
                                                Unsigned Objects_Allocated;
                                                union {
                                                        uchar *Bytes;
                                                        DBRecord *Record;
                                                } DBuffer;

                                                inline size_t Memory_length();
                                                inline size_t Heap_length(const size_t objects);
                                                inline size_t Record_length();
                                        protected:
                                        public:
                                                inline bool is_in_data_base();
                                                inline bool is_not_in_data_base();

                                                inline const OID &ID();
                                                inline Unsigned objects();

                                                OID *operator [](const Unsigned index)
                                                                throw(inXDBException);

                                                void insert(const Unsigned index, const OID &ID)
                                                                throw(inXDBException);
                                                void remove(const Unsigned index);

                                                OID &create(Type &file, const FilePos file_number,
                                                                                        const OID &owner_object
                                                                          )
                                                                throw(inXDBException);
                                                void write(Type &file)
                                                                throw(inXDBException);
                                                void remove(Type &file)
                                                                throw(inXDBException);

                                                ObjectList &operator =(const ObjectList &object_list)
                                                                throw(inXDBException);

                                                ObjectList(const ObjectList &object_list)
                                                                throw(inXDBException);
                                                ObjectList(inXDB &db, OID &object_ID)
                                                                throw(inXDBException);
                                                ObjectList(Type &file, OID &object_ID)
                                                                throw(inXDBException);
                                                ObjectList()
                                                                throw(inXDBException);
                                                ~ObjectList()
                                                                throw(inXDBException);
                                };
                                class TypeAttribute {
                                        public:
                                                enum LayoutConstraint {
                                                        AfterPrevious, RightOfPrevious
                                                };
                                                enum LabelType {
                                                        NoLabel, ToLeft, ToRight, AboveField
                                                };
                                                struct DBFormItem {
                                                        TypeAttribute *Actual_Attribute;
                                                        TypeAttribute *Attribute;
                                                        uint Attribute_Number;
                                                        uint Sub_Attribute_Number;
                                                        char Actual_Name[inXDB_Name_Length];
                                                        char Name[inXDB_Name_Length * 3];
                                                        std::string *Tooltip;
                                                        int Shortcut_Key;
                                                        enum ItemType {
                                                                Is_Reference = 0x0001,
                                                                Is_Boolean = 0x0002,
                                                                Is_Date = 0x0004,
                                                                Is_Duration = 0x0008,
                                                                Is_Enumerator = 0x0010,
                                                                Is_SubclassID = 0x0020,
                                                                Is_DataEntry = 0x0040,
                                                                Is_List_Array = 0x0080,
                                                                Is_List = 0x0100,
                                                                Is_Text = 0x0200,
                                                                Is_Word = 0x0400,
                                                                Is_FileName = 0x0800,
                                                                Is_Character = 0x1000,
                                                                Is_Characters = 0x2000,
                                                                Is_Upper_Case = 0x4000
                                                        };
                                                        uint Type;
                                                        enum WidgetType {
                                                                FindButton, AddButton, ListButton, BrowseButton,
                                                                Label, Field
                                                        } Widget;
                                                        Unsigned Widths;
                                                        uint Width_Type[7];
                                                        int Width[7];
                                                        int Lines;
                                                        int X;
                                                        int Y;
                                                        int W;
                                                        int H;
                                                        DBFormItem *To_Right;
                                                };
                                                struct DBFormLine {
                                                        DBFormItem Items[16];
                                                };
                                        private:
                                                struct DBRecord {
                                                        OID Member_of_Type;
                                                        char Name[inXDB_Name_Length];
                                                        OID Type_Of;
                                                        OID Of;
                                                        OID From_Type;
                                                        Unsigned From_Attribute;
                                                        Unsigned Bytes;
                                                        Unsigned Label_Type;
                                                        bool Empty_OK;
                                                        Unsigned Entry_Characters;
                                                        Integer Minimum;
                                                        Integer Maximum;
                                                        uchar Layout_Column;
                                                        Unsigned Layout;
                                                        Unsigned Lines;
                                                        Unsigned Choice_List_Length;
                                                        Unsigned Choice_Value_List_Length;
                                                        Unsigned Choice_Key_Value_List_Length;
                                                        Unsigned SubclassID_List_Length;
                                                        Unsigned SubclassID_Value_List_Length;
                                                        Unsigned SubclassID_Type_List_Length;
                                                        Unsigned Default_Value_Length;
                                                        Unsigned Description_Length;
                                                        char Heap[sizeof(Unsigned)];
                                                };
                                                Type *DB_Type;
                                                DB &Data_Base;
                                                OID Object_ID;
                                                union {
                                                        uchar *Bytes;
                                                        DBRecord *Record;
                                                } DBuffer;
                                                size_t Heap_Length;
                                                bool Is_List;
                                                bool Is_Array;
                                                bool Is_String;
                                                bool Is_Text;
                                                bool Is_Fixed_Length_String;

                                                inline size_t Memory_length();
                                                inline size_t Heap_length(const size_t record_length);
                                                inline size_t Record_length();

                                                void Update_default(const void *value, const Unsigned bytes);
                                        protected:
                                        public:
                                                inline bool is_in_data_base();
                                                inline bool is_not_in_data_base();

                                                inline Type &DB_type();
                                                inline DB &data_base();

                                                inline const char *name();
                                                inline const char *name(const std::string &new_name);

                                                std::string access_method_name();
                                                std::string argument_input_name();
                                                std::string screen_description();

                                                inline const OID &ID();
                                                inline Type *member_of();
                                                inline Type *type_of();
                                                inline Type *of();
                                                TypeAttribute *from();

                                                inline Unsigned bytes();
                                                inline LabelType label_type();
                                                inline bool show_label();
                                                inline bool dont_show_label();
                                                inline bool empty_is_OK();
                                                inline bool empty_is_not_OK();
                                                inline Unsigned entry_characters();
                                                inline double minimum();
                                                inline double maximum();
                                                inline long long_minimum();
                                                inline long long_maximum();
                                                inline uchar layout_column();
                                                inline LayoutConstraint layout_constraint();
                                                inline Unsigned lines();

                                                inline Unsigned choices();
                                                std::string choice(const Unsigned index);
                                                std::string choice_screen_description(const Unsigned index);

                                                Unsigned values();
                                                inline long value(const Unsigned index);

                                                std::string key_value(const Unsigned index);

                                                inline Unsigned subclass_IDs();
                                                std::string subclass_ID_name(const Unsigned index);
                                                std::string subclass_ID_description(const Unsigned index);
                                                inline SubclassID subclass_ID(const Unsigned index);
                                                inline Type *subclass_ID_type(const Unsigned index);

                                                inline bool has_default();

                                                const char *default_char(const char *value,
                                                                                                                                const Unsigned bytes
                                                                                                                );
                                                const Integer *default_integer(const Integer *value);
                                                const Unsigned *default_unsigned(const Unsigned *value);
                                                const PreciseTime
                                                        *default_precise_time(const PreciseTime *value);
                                                const Real *default_real(const Real *value);
                                                const bool *default_bool(const bool *value);

                                                inline const char *default_char(Unsigned *bytes = 0);
                                                inline const Integer *default_integer();
                                                inline const Unsigned *default_unsigned();
                                                inline const PreciseTime *default_precise_time();
                                                inline const Real *default_real();
                                                inline const bool *default_bool();

                                                inline size_t description_length();
                                                inline const std::string description();
                                                const std::string
                                                        description(const std::string &new_description);

                                                void inserted_attribute_at(const Unsigned index);
                                                void removed_attribute_at(const Unsigned index);

                                                void modify(const std::string &name, Type &type_of, Type *of,
                                                                                        const Unsigned bytes,
                                                                                        const LabelType label_type,
                                                                                        const bool empty_OK,
                                                                                        const Unsigned entry_characters,
                                                                                        const long minimum, const long maximum,
                                                                                        const uchar layout_column,
                                                                                        const LayoutConstraint layout_constraint,
                                                                                        const Unsigned lines
                                                                          );

                                                void create()
                                                                throw(inXDBException);
                                                void write()
                                                                throw(inXDBException);

                                                void append(const std::string &choice, const long *value = 0,
                                                                                        const char *key_value = 0
                                                                          );
                                                void modify(const Unsigned index, const std::string &choice,
                                                                                        const long *value = 0,
                                                                                        const char *key_value = 0
                                                                          );

                                                void append(const std::string &subclass_name,
                                                                                        const Unsigned value, Type &type
                                                                          );
                                                void modify(const Unsigned index,
                                                                                        const std::string &subclass_name,
                                                                                        const Unsigned value, Type &type
                                                                          );

                                                TypeAttribute &operator =(const TypeAttribute &attribute);

                                                inline bool is_on_heap();
                                                inline bool is_string();
                                                inline bool is_text();
                                                inline bool is_fixed_length_string();

                                                std::string qualified_choice(const Unsigned index);
                                                std::string qualified_subclass_ID_name(const Unsigned index);
                                                std::string get_values();
                                                std::string get_value();
                                                std::string get_value(const std::string &which);
                                                std::string get_object_value();
                                                std::string reference_pointer_value(uint &variables,
                                                                                                                                        ClassArray<std::string *>
                                                                                                                                                        &variable,
                                                                                                                                        std::string &pointer_name,
                                                                                                                                  const std::string &accessor,
                                                                                                                                        DB &current_DB,
                                                                                                                                        const bool
                                                                                                                                                        accessor_is_pointer
                                                                                                                                                                = false
                                                                                                                                 );

                                                bool have_text();
                                                bool include_reference_header(class Format &file,
                                                                                                                                OID *type_referenced,
                                                                                                                                        uint &types_referenced,
                                                                                                                                        bool &needs_dereferencing
                                                                                                                          );
                                                void enumerator_declaration(class Format &file);
                                                void subclass_ID_declaration(class Format &file);
                                                void declaration(class Format &file,
                                                                                                const std::string &name_space,
                                                                                                const bool for_index = false,
                                                                                                const char *name_prefix = 0
                                                                                         );
                                                void original_key_declaration(class Format &file,
                                                                                                                                        const char *prefix
                                                                                                                          );
                                                void access_method_returns_const(class Format &file);
                                                void access_method_return_type(class Format &file,
                                                                                                                                        const std::string &name_space
                                                                                                                                );
                                                void argument_type(class Format &file,
                                                                                                                const std::string &name_space
                                                                                                );
                                                const char *argument_pointer();
                                                bool access_method_declaration(class Format &file,
                                                                                                                                        const std::string
                                                                                                                                                        &name_space,
                                                                                                                                        const bool subclass_only,
                                                                                                                                 bool &first_one
                                                                                                                                );
                                                void const_argument_declaration(class Format &file,
                                                                                                                                        const std::string &name_space
                                                                                                                                 );
                                                void argument_declaration(class Format &file,
                                                                                                                                const std::string &name_space
                                                                                                                 );
                                                void args_declaration(class Format &file);
                                                void args_name(class Format &file, const bool for_printf);
                                                void argument_length(class Format &file,
                                                                                                                const char *prefix
                                                                                                  );
                                                void DB_key(class Format &file, Type &for_type,
                                                                                        const std::string &name_space,
                                                                                        const std::string &key_name,
                                                                                        const char *key_prefix,
                                                                                        const bool use_access_method,
                                                                                        const bool use_argument,
                                                                                        const bool prefix_only,
                                                                                        const bool is_original_key = false,
                                                                                        const bool is_from_argument = false,
                                                                                        const char *the_reference = 0
                                                                          );
                                                bool assign_value_to_string(class Format &file,
                                                                                                                                const std::string &name_space,
                                                                                                                                const std::string
                                                                                                                                                &assignment_to,
                                                                                                                                const std::string &object_name,
                                                                                                                                const bool assign_to,
                                                                                                                                const bool used_buffer_already,
                                                                                                                                const uint maximum_length = 0,
                                                                                                                                const bool measure = false,
                                                                                                                                const bool code_measures
                                                                                                                                        = false,
                                                                                                                                const bool use_columns = false,
                                                                                                                                const uint column = 0,
                                                                                                                                const char *width_prefix = 0
                                                                                                                        );
                                                void pointer_to_argument(Format &file, const char *prefix,
                                                                                                                        const bool use_access_method
                                                                                                                );
                                                void copy_original_key(class Format &file,
                                                                                                                        const bool record_is_dbpointer,
                                                                                                                        const std::string &prefix
                                                                                                         );
                                                void make_original_key(class Format &file, Type &for_type,
                                                                                                                        const std::string &name_space,
                                                                                                                        const std::string &dest_prefix,
                                                                                                                        const char *source_prefix,
                                                                                                                        const bool use_access_method,
                                                                                                                        const char *the_reference = 0
                                                                                                         );
                                                void make_empty_original_key(class Format &file,
                                                                                                                                        const std::string &prefix
                                                                                                                         );
                                                void key_changed(class Format &file, Type &for_type,
                                                                                                        const std::string &name_space,
                                                                                                        const std::string &other_key_prefix,
                                                                                                        const bool use_access_method,
                                                                                                        const char *source_prefix,
                                                                                                        const char *the_reference
                                                                                         );
                                                bool setup_list_array(class Format &file, const bool is_const,
                                                                                                                const std::string &access_prefix,
                                                                                                                const bool diff_name_space,
                                                                                                                Type *of_type, const bool reassign,
                                                                                                                const bool test_modify_record,
                                                                                                                const bool modify_record,
                                                                                                                const bool need_start_of_array,
                                                                                                         bool &have_one,
                                                                                                                bool &more_on_heap_after_this,
                                                                                                                bool &have_start_of_array
                                                                                                   );
                                                void access_method(class Format &file, Type &for_type,
                                                                                                                const std::string &name_space,
                                                                                                                const bool is_const,
                                                                                                 uint &added_indent
                                                                                                );
                                                void const_access_method(class Format &file, Type &for_type,
                                                                                                                        const std::string &name_space,
                                                                                                                        Type &type, Type *of_type,
                                                                                                                        const bool inlining
                                                                                                                );
                                                void nonconst_access_method(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                Type &type, Type *of_type,
                                                                                                                                const bool inlining
                                                                                                                        );
                                                void set_method(class Format &file, Type &for_type,
                                                                                                const std::string &name_space, Type &type,
                                                                                                const bool inlining
                                                                                        );
                                                void inline_access_method(class Format &file, Type &for_type,
                                                                                                                                const std::string &name_space
                                                                                                                 );
                                                void dereference_another_OID(class Format &file, Type &type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const bool close_block,
                                                                                                                                const std::string &index_name,
                                                                                                                                const bool write_after = false
                                                                                                                         );
                                                void set_method(class Format &file, Type &for_type,
                                                                                                const std::string &name_space
                                                                                        );
                                                void remove_reference(class Format &file,
                                                                                                                const std::string &name_space
                                                                                                        );
                                                std::string export_method_requirements(uint &variables,
                                                                                                                                                ClassArray<std::string *>
                                                                                                                                                        &variable,
                                                                                                                                         DB &current_DB
                                                                                                                                        );
                                                std::string export_reference_index(uint &variables,
                                                                                                                                                ClassArray<std::string *>
                                                                                                                                                                &variable,
                                                                                                                                          const std::string
                                                                                                                                                                &reference_type
                                                                                                                                         );
                                                std::string do_export(uint &end_blocks,
                                                                                                ClassArray<std::string *> &end_block,
                                                                                                uint &variables,
                                                                                                ClassArray<std::string *> &variable,
                                                                                                bool &output_was_bool,
                                                                                  Type &for_type, const std::string &accessor,
                                                                                                const std::string &full_qualification,
                                                                                                DB &current_DB,
                                                                                                const bool continuation = false
                                                                                 );
                                                void do_import_enumerator(class Format &file);
                                                void do_import_subclass_ID(class Format &file);
                                                uint do_import(class Format &file,
                                                                                                const std::string &name_space,
                                                                                                const bool use_buffer_argument
                                                                                  );
                                                void import_uses(bool &uses_long, bool &uses_length,
                                                                                                        bool &uses_double, bool &uses_date,
                                                                                                        bool &uses_date_time, bool &uses_timeval,
                                                                                                        bool &uses_money, bool &uses_string
                                                                                         );
                                                void form_uses(bool &uses_bool, bool &uses_enum,
                                                                                                bool &uses_list, bool &uses_text,
                                                                                                bool &uses_file_browser
                                                                                  );
                                                void property_uses(bool &uses_charptr, bool &uses_bool,
                                                                                                        bool &uses_long, bool &uses_length,
                                                                                                        bool &uses_double, bool &uses_timeval,
                                                                                                        bool &uses_string, bool &uses_OIDptr,
                                                                                                        bool &uses_money
                                                                                                );
                                                void copy_from_another(class Format &file,
                                                                                                                        const std::string &other
                                                                                                         );
                                                void copy_from_argument(class Format &file, Type &for_type,
                                                                                                                        const std::string &name_space,
                                                                                                                        const std::string &argument,
                                                                                                                        const char *prefix,
                                                                                                                        const bool use_access_method
                                                                                                          );
                                                void is_empty(class Format &file, const std::string &preamble,
                                                                                                const std::string &postamble
                                                                                 );
                                                void compare_to_another(class Format &file, Type &for_type,
                                                                                                                        const std::string &name_space,
                                                                                                                        const std::string &other,
                                                                                                                        const std::string &comparison,
                                                                                                                        const std::string &preamble
                                                                                                          );
                                                void copy_constructor(class Format &file,
                                                                                                                        const bool record_is_dbpointer,
                                                                                                         bool &already_have_one
                                                                                                        );
                                                void new_constructor(class Format &file,
                                                                                                        bool &already_have_one
                                                                                                  );
                                                void empty_constructor(class Format &file,
                                                                                                          bool &already_have_one
                                                                                                         );
                                                void empty_record(class Format &file, Type &for_type,
                                                                                                        const std::string &record_access,
                                                                                                        const bool do_strings
                                                                                          );
                                                void clear_value(class Format &file);
                                                bool widget_comparison_reference(class Format &file,
                                                                                                                                                const std::string
                                                                                                                                                                &name_space,
                                                                                                                                                const uint indeces,
                                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                                                                  );
                                                void widget_value_reference(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                TypeAttribute *actual_attribute = 0
                                                                                                                        );
                                                void delete_widget_comparison_reference(class Format &file,
                                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                                                                                        );
                                                void widget_not_equal_to_object(class Format &file,
                                                                                                                                                Type &for_type,
                                                                                                                                                const std::string
                                                                                                                                                                &name_space,
                                                                                                                                                TypeIndex *index,
                                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                                                                 );
                                                void widget_value(class Format &file, Type &for_type,
                                                                                                        const std::string &name_space,
                                                                                                        const char *widget_prefix,
                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                          );
                                                void widget_to_object(class Format &file, Type &for_type,
                                                                                                                const std::string &name_space,
                                                                                                                const char *object_access,
                                                                                                                const char *widget_prefix,
                                                                                                                TypeAttribute *actual_attribute = 0
                                                                                                        );
                                                void form_list_key(class Format &file, Type &for_type,
                                                                                                        const std::string &name_space,
                                                                                                        const uint indeces,
                                                                                                        TypeAttribute *actual_attribute,
                                                                                                 Unsigned &set_number
                                                                                                );
                                                void form_clear(class Format &file, Type &for_type,
                                                                                                const std::string &form_name,
                                                                                                const bool only_data_entry_types = false,
                                                                                         bool *need_else = 0
                                                                                        );
                                                void form_use_widget_default(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const std::string &object_name,
                                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                                                         );
                                                void show_method_definition(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const uint indeces,
                                                                                                                                const std::string &object_name,
                                                                                                                TypeAttribute *actual_attribute = 0
                                                                                                                        );

                                                bool property_load_needs_buffer();
                                                void property_load(class Format &file, Type &for_type,
                                                                                                                const std::string &name_space,
                                                                                                                const std::string &object_name,
                                                                                                                const std::string &form_name,
                                                                                                                const std::string &access_method,
                                                                                                                TypeAttribute *user_type_of,
                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                const bool need_trx = true
                                                                                                );
                                                bool requires_snprintf();
                                                void retrieve_key_from_property(class Format &file,
                                                                                                                                        Type &for_type,
                                                                                                                                        const std::string
                                                                                                                                                        &name_space,
                                                                                                                                        const std::string &prefix,
                                                                                                                                        const uint index
                                                                                                                                 );
                                                bool widget_width_declaration(Format &file);
                                                void widget_declaration(class Format &file,
                                                                                                                        Type &for_type,
                                                                                                                        const size_t indeces,
                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                                          );
                                                void enum_menu_declaration(class Format &file, Type &for_type,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                        bool &need_newline
                                                                                                                  );
                                                void show_method_declaration(class Format &file,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                          bool &need_newline
                                                                                                                         );
                                                void set_method_declaration(class Format &file,
                                                                                                                                const std::string &name_space,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                         bool &need_newline
                                                                                                                        );
                                                void by_method_declaration(class Format &file, Type &for_type,
                                                                                                                                const size_t indeces,
                                                                                                                        bool &need_newline
                                                                                                                  );
                                                void add_method_declaration(class Format &file,
                                                                                                                         bool &need_newline
                                                                                                                        );
                                                bool regenerate_declaration(class Format &file,
                                                                                                                         bool &need_newline
                                                                                                                        );
                                                void set_method_definition(class Format &file, Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const uint indeces,
                                                                                                                TypeAttribute *actual_attribute = 0
                                                                                                                  );
                                                void form_static_declaration(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                          bool &need_newline
                                                                                                                         );
                                                bool form_has_enum_menu(Type &for_type);
                                                bool form_static_initialize(Format &file, Type &for_type,
                                                                                                                                TypeAttribute *actual_attribute
                                                                                                                        );
                                                void form_static_definition(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                TypeAttribute *actual_attribute
                                                                                                                        );
                                                void form_static_initialization(class Format &file,
                                                                                                                                        Type &for_type,
                                                                                                                                        const std::string &name_space
                                                                                                                                 );
                                                void when_method_declaration(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                          bool &need_newline
                                                                                                                         );
                                                void load_from_form_input(class Format &file, Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const uint indeces,
                                                                                                                                const bool form_is_argument,
                                                                                                                                const char *object_access,
                                                                                                                                const char *widget_prefix,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                                const bool use_trx = false
                                                                                                                 );
                                                void when_method_definition(class Format &file,
                                                                                                                                Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const uint indeces,
                                                                                                                                TypeIndex *primary,
                                                                                                                                TypeAttribute *actual_attribute,
                                                                                                                         uint &reference
                                                                                                                        );
                                                void validate_method(class Format &file, Type &for_type,
                                                                                                                TypeAttribute *actual_attribute = 0
                                                                                                  );
                                                bool save_method(class Format &file,
                                                                                                        TypeAttribute *actual_attribute = 0
                                                                                         );
                                                void value_to_form_value(class Format &file,
                                                                                                                        const std::string &name_space,
                                                                                                                        const std::string &object_name,
                                                                                                                        const std::string &object_access,
                                                                                                                        const std::string &access_name
                                                                                                                );
                                                void form_index_button(class Format &file, Type &for_type,
                                                                                                                        const uint indeces,
                                                                                                                        const std::string &attribute_name,
                                                                                                                        const std::string &key_name,
                                                                                                                        const bool end_line
                                                                                                         );
                                                void form_set_button(class Format &file, Type &for_type,
                                                                                                                const uint indeces,
                                                                                                                const std::string &attribute_name,
                                                                                                                const uint set_number,
                                                                                                                const bool end_line
                                                                                                  );
                                                void form_list_button(class Format &file,
                                                                                                                Type &for_type,
                                                                                                                const uint indeces,
                                                                                                                const std::string &attribute_name,
                                                                                                                const std::string
                                                                                                                                &attribute_screen_name,
                                                                                                                const uint list_number,
                                                                                                                const bool end_line
                                                                                                        );
                                                Unsigned list_box_width(Unsigned &widths, uint width_type[7],
                                                                                                                        int char_width[7]
                                                                                                          );
                                                Unsigned entry_width(Type &for_type,
                                                                                                        bool &is_characters, bool &is_upper_case,
                                                                                                                Unsigned &widths, uint width_type[7],
                                                                                                                int char_width[7]
                                                                                                  );

                                                std::string *tooltip(const char *description);



                                                void form_place(Type &for_type, const size_t type_indeces,
                                                                                                const uint index,
                                                                                                TypeAttribute *actual_attribute,
                                                                                                const uint type_index,
                                                                                         TypeAttribute *& previous_attribute,
                                                                                                Type *& previous_type_of, int &form_line,
                                                                                                int &form_item, DBFormLine *form_lines,
                                                                                                uint &attribute_number,
                                                                                                uint &sub_attribute_number
                                                                                        );
                                                void form_type_list(class Format &file, Type &for_type,
                                                                                                                const std::string &name_space,
                                                                                                                const uint indeces,
                                                                                                                const bool is_list,
                                                                                                                const DBFormItem *item,
                                                                                                  std::string &heading
                                                                                                 );
                                                void form_type_deselect(class Format &file);
                                                bool is_a_button(Type &for_type, const size_t indeces);
                                                void form_regenerate(class Format &file);
                                                void view_list_class_declaration(class Format &file,
                                                                                                                                                Type &owner,
                                                                                                                                                const std::string
                                                                                                                                                        &name_space,
                                                                                                                                                const uint indeces
                                                                                                                                  );
                                                void form_view_list_definition(class Format &file,
                                                                                                                                        Type &for_type,
                                                                                                                                        const std::string
                                                                                                                                                        &name_space,
                                                                                                                                        const uint indeces
                                                                                                                           );
                                                void find_display(class Format &file,
                                                                                                        const std::string &name_space,
                                                                                                        TypeAttribute *ssa, TypeAttribute *sa,
                                                                                                        TypeAttribute *a, TypeIndex &index,
                                                                                                        const char *access_string = 0,
                                                                                                        const bool remove_spaces = true,
                                                                                                        const bool at_end_of_buffer = false,
                                                                                                        const char *base_attribute = "",
                                                                                                        const char *base_qualifier = ""
                                                                                          );
                                                void list_display(class Format &file,
                                                                                                        const std::string &name_space,
                                                                                                        const std::string &object_name,
                                                                                                        TypeAttribute *sa, TypeAttribute *a,
                                                                                                        const Unsigned constrained_length,
                                                                                                        const char *access_string = 0,
                                                                                                        const bool is_pointer = true
                                                                                          );
                                                Unsigned buffer_required_to_hold_key();

                                                bool export_ASCII(std::ostream &output_file);
                                                bool import_ASCII(std::istream &input_file, Type &owner,
                                                                                                        const char *buffer = 0
                                                                                          );

                                                TypeAttribute(Type &db_type)
                                                                throw(inXDBException);
                                                TypeAttribute(const TypeAttribute &attribute)
                                                                throw(inXDBException);
                                                TypeAttribute(DB &db, OID &object_ID)
                                                                throw(inXDBException);
                                                TypeAttribute(Type &db_type, OID &object_ID)
                                                                throw(inXDBException);
                                                TypeAttribute(const std::string &name)
                                                                throw(inXDBException);
                                                TypeAttribute(Type &db_type, const std::string &name,
                                                                                                Type &type_of, Type *of,
                                                                                                const Unsigned bytes,
                                                                                                const LabelType label_type,
                                                                                                const bool empty_OK,
                                                                                                const Unsigned entry_characters,
                                                                                                const long minimum, const long maximum,
                                                                                                const uchar layout_column,
                                                                                                const LayoutConstraint layout_constraint,
                                                                                                const Unsigned lines,
                                                                                                const std::string &description
                                                                                 )
                                                                throw(inXDBException);
                                                ~TypeAttribute()
                                                                throw(inXDBException);
                                };
                                class TypeIndex {
                                                friend class inXDB;
                                                friend class inXDB::inXDBTransaction;
                                                friend class inXDB::DB;
                                                friend class inXDB::Type;
                                                friend class inXServices::AVL<TypeIndex>;
                                                friend class DBObject;
                                        private:
                                                struct DBRecord {
                                                        OID Member_of_Type;
                                                        FilePos File;
                                                        char Name[inXDB_Name_Length];
                                                        Unsigned Maximum_Bytes;
                                                        bool Unique;
                                                        Unsigned Attribute_List_Length;
                                                        Unsigned Sub_Attribute_List_Length;
                                                        Unsigned Sub_Sub_Attribute_List_Length;
                                                        Unsigned Description_Length;
                                                        char Heap[sizeof(Unsigned)];
                                                };
                                                inXDB::Type &DB_Type;
                                                DB &Data_Base;
                                                OID Object_ID;
                                                std::string Name;
                                                union {
                                                        uchar *Bytes;
                                                        DBRecord *Record;
                                                } DBuffer;
                                                size_t Heap_Length;
                                                BTree *Type_Index;

                                                inline size_t Memory_length();
                                                inline size_t Heap_length(const size_t record_length);
                                                inline size_t Record_length();

                                                const std::string Index_file_name();

                                                void Field(TypeAttribute &attribute,
                                                                          BTreeFieldDefinition *field, Unsigned &f
                                                                         )
                                                        throw(inXDBException);
                                                void Create_index()
                                                        throw(inXDBException);

                                                inline void Begin_transaction(Transaction *trx)
                                                                throw(inXDBException);
                                                inline void Transaction_done();

                                                TypeIndex(const TypeIndex &index)
                                                                throw(inXDBException);
                                                TypeIndex(inXDB::Type &db_type)
                                                                throw(inXDBException);
                                                TypeIndex(inXDB::Type &type, OID &object_ID,
                                                                                const DBRecord *record
                                                                        )
                                                                throw(inXDBException);
                                                TypeIndex(inXDB::Type &type, const std::string &name,
                                                                                const bool unique, const std::string &description,
                                                                                ObjectList *attribute_list = 0,
                                                                                ObjectList *sub_attribute_list = 0,
                                                                                ObjectList *sub_sub_attribute_list = 0
                                                                        )
                                                                throw(inXDBException);

                                                TypeIndex(inXDB::Type &type, const std::string &name);
                                                ~TypeIndex()
                                                                throw(inXDBException);
                                        protected:
                                        public:
                                                inline bool is_in_data_base();
                                                inline bool is_not_in_data_base();

                                                inline DB &data_base();
                                                inline inXDB::Type &type();
                                                inline FilePos file();

                                                inline const char *name();
                                                const char *name(const std::string &new_name);
                                                std::string screen_description();

                                                inline const OID &ID();

                                                inline Unsigned maximum_bytes();

                                                inline bool is_unique();
                                                inline bool is_not_unique();

                                                Unsigned attributes();
                                                TypeAttribute *attribute(const Unsigned index);
                                                TypeAttribute *attribute(Unsigned *index,
                                                                                                                        const std::string &name
                                                                                                                );
                                                TypeAttribute *sub_attribute(const Unsigned index);
                                                TypeAttribute *sub_sub_attribute(const Unsigned index);
                                                long contains(TypeAttribute &attribute);

                                                bool requires_snprintf();

                                                inline size_t description_length();
                                                inline const std::string description();
                                                const std::string
                                                        description(const std::string &new_description);

                                                void create()
                                                                throw(inXDBException);
                                                void write()
                                                                throw(inXDBException);

                                                void append(TypeAttribute &attribute, TypeAttribute *sub_sub,
                                                                                        TypeAttribute *sub
                                                                          );

                                                inline TypeIndex &operator =(const TypeIndex &attribute);

                                                std::string *key_check_string();
                                                const std::string key_struct_name();
                                                const std::string key_struct_variable_name();
                                                std::string attribute_accessor(TypeAttribute **index_attribute,
                                                                                                                  const Unsigned index
                                                                                                                 );
                                                bool has_attribute_in_list();
                                                void key_declaration(class Format &file,
                                                                                                                const std::string &DB_name
                                                                                                  );
                                                void original_key_declaration(class Format &file);
                                                void attribute_index_declaration(class Format &file,
                                                                                                                                                const std::string
                                                                                                                                                                &name_space
                                                                                                                                  );
                                                void attribute_index_definition(class Format &file,
                                                                                                                                        const std::string
                                                                                                                                                        &name_space,
                                                                                                                                        const Unsigned index_number,
                                                                                                                                        const Unsigned indeces,
                                                                                                                                        inXDB::Type &for_type
                                                                                                                                 );
                                                void index_constructor_declaration(class Format &file,
                                                                                                                                                const std::string
                                                                                                                                                                &name_space,
                                                                                                                                                inXDB::Type &type,
                                                                                                                                                const std::string &prefix,
                                                                                                                                                const bool
                                                                                                                                                                include_defaults,
                                                                                                                        const bool class_index_type = false
                                                                                                                                         );
                                                void index_constructor_call(class Format &file);
                                                bool DB_key(class Format &file, inXDB::Type &for_type,
                                                                                        const std::string &name_space,
                                                                                        const std::string &key_name,
                                                                                        const char *key_prefix,
                                                                                        const bool already_have_dbpointer,
                                                                                        std::string ***key_made, bool **delete_key,
                                                                                        size_t &possible_keys,
                                                                                        const bool is_original_key = false,
                                                                                        const bool attribute_already_in_list = false,
                                                                                        const bool second_time = false
                                                                          );
                                                void DB_key_from_argument(class Format &file,
                                                                                                                                inXDB::Type &for_type,
                                                                                                                                const std::string &name_space,
                                                                                                                                const std::string &key_name,
                                                                                                                                const bool use_generic_key,
                                                                                                                        const bool from_find_constructor
                                                                                                                 );
                                                void copy_original_key(class Format &file,
                                                                                                                        const bool record_is_dbpointer
                                                                                                         );
                                                size_t how_many_possible_keys();
                                                void make_key_value_ptr(class Format &file,
                                                                                                                        size_t &possible_keys,
                                                                                                                        std::string **key_made,
                                                                                                                        bool *delete_key,
                                                                                                           inXDB::Type &for_type,
                                                                                                                        inXDB::TypeAttribute
                                                                                                                                        *attribute_in_list,
                                                                                                                        inXDB::TypeAttribute *attribute,
                                                                                                                        const std::string &list_object,
                                                                                                                        const bool already_have_dbpointer,
                                                                                                                        const std::string &trx,
                                                                                                                        inXDB::TypeAttribute
                                                                                                                                        *primary_attribute,
                                                                                                                        inXDB::TypeAttribute
                                                                                                                                        *secondary_attribute,
                                                                                                                        const bool last_one
                                                                                                          );
                                                void setup_original_key(std::string &attribute_prefix,
                                                                                                                        std::string &the_reference,
                                                                                                           inXDB::Type &for_type,
                                                                                                                        inXDB::TypeAttribute
                                                                                                                                        *attribute_in_list,
                                                                                                                        inXDB::TypeAttribute *attribute,
                                                                                                                        const std::string &list_object,
                                                                                                                        inXDB::TypeAttribute
                                                                                                                                *primary_attribute
                                                                                                          );
                                                void make_original_key(class Format &file,
                                                                                                                        size_t &possible_keys,
                                                                                                                        std::string **key_made,
                                                                                                                        bool *delete_key,
                                                                                                          inXDB::Type &for_type,
                                                                                                                        const std::string &name_space,
                                                                                                                        const bool already_have_dbpointer,
                                                                                                                        const bool
                                                                                                                                attribute_already_in_list
                                                                                                                                        = false,
                                                                                                                        const bool second_time = false
                                                                                                         );
                                                void make_empty_original_key(class Format &file);
                                                bool key_changed(class Format &file, inXDB::Type &for_type,
                                                                                                const std::string &name_space,
                                                                                                const std::string &other_key_prefix,
                                                                                                std::string ***key_made, bool **delete_key,
                                                                                                size_t &possible_keys
                                                                                         );
                                                void find_by_class_declaration(class Format &file,
                                                                                                                                        inXDB::Type &type,
                                                                                                                                        const bool has_primary
                                                                                                                                );
                                                void form_by_key(class Format &file,
                                                                                                        const std::string &name_space,
                                                                                                        inXDB::Type &type
                                                                                         );
                                                void form_find_by(class Format &file, inXDB::Type &type,
                                                                                                        TypeIndex *primary_index,
                                                                                                        const bool has_primary
                                                                                          );

                                                inline Unsigned buffer_required_to_hold_key();
                                                std::string export_method_requirements(uint &variables,
                                                                                                                                                ClassArray<std::string *>
                                                                                                                                                        &variable,
                                                                                                                                         inXDB::Type &reference_to,
                                                                                                                                                DB &current_DB
                                                                                                                                        );
                                                std::string export_primary_key(uint &end_blocks,
                                                                                                                                        ClassArray<std::string *>
                                                                                                                                                &end_block,
                                                                                                                                        uint &variables,
                                                                                                                                        ClassArray<std::string *>
                                                                                                                                                &variable,
                                                                                                                                        bool &output_was_bool,
                                                                                                                                 Type &for_type,
                                                                                                                                        const std::string
                                                                                                                                                &full_qualification,
                                                                                                                                        DB &current_DB
                                                                                                                                );
                                                std::string export_reference_key(uint &end_blocks,
                                                                                                                                                ClassArray<std::string *>
                                                                                                                                                        &end_block,
                                                                                                                                                uint &variables,
                                                                                                                                                ClassArray<std::string *>
                                                                                                                                                        &variable,
                                                                                                                                                bool &output_was_bool,
                                                                                                                                        Type &for_type,
                                                                                                                                                const std::string
                                                                                                                                                        &attribute_name,
                                                                                                                                                const std::string
                                                                                                                                                        &accessor,
                                                                                                                                                const std::string
                                                                                                                                                        &full_qualification,
                                                                                                                                                DB &current_DB,
                                                                                                                                                const bool continuation
                                                                                                                                                        = false,
                                                                                                                                                const bool recursed
                                                                                                                                                        = false
                                                                                                                                );

                                                inline int compare(const TypeIndex &index) const;

                                                bool export_ASCII(std::ostream &output_file);
                                                bool import_ASCII(std::istream &input_file,
                                                                                                        inXDB::Type &owner,
                                                                                                        Unsigned &max_bytes,
                                                                                                        const char *buffer = 0
                                                                                          );
                                                inline bool insert(const void *buffer)
                                                                throw(inXDBException);
                                                inline bool remove(const void *buffer)
                                                                throw(inXDBException);
                                                inline bool find(const void *buffer)
                                                                throw(inXDBException);
                                                inline bool first()
                                                                throw(inXDBException);
                                                inline bool last()
                                                                throw(inXDBException);
                                                inline bool next()
                                                                throw(inXDBException);
                                                inline bool previous()
                                                                throw(inXDBException);
                                                inline bool operator [](const FilePos index)
                                                                throw(inXDBException);
                                                inline void get_current(BTreePosition &position);
                                                inline bool set_current(const BTreePosition &position)
                                                                throw(inXDBException);
                                                inline bool get_key(void *buffer);
                                                inline bool get_key(void *buffer, const size_t buffer_length);
                                                inline bool remove_current()
                                                                throw(inXDBException);
                                                inline FilePos keys() const;
                                };
                                class Type {
                                                friend class inXDB;
                                                friend class inXDB::inXDBTransaction;
                                                friend class inXDB::DB;
                                                friend class inXDB::TypeAttribute;
                                                friend class inXDB::TypeIndex;
                                                friend class inXServices::AVL<Type>;
                                        private:
                                                struct DBRecord {
                                                        OID Member_of_DB;
                                                        FilePos File;
                                                        char Name[inXDB_Name_Length];
                                                        Enumerator Class_Type;
                                                        bool Persistent;
                                                        Unsigned Bytes;

                                                        Unsigned Attribute_List_Length;
                                                        Unsigned Super_Class_List_Length;
                                                        SubclassID Subclass_ID;
                                                        Unsigned Sub_Class_List_Length;
                                                        OID Primary_Index;
                                                        Unsigned Secondary_Indeces_Length;
                                                        OID Duplicate_Attribute;
                                                        Unsigned Reference_Attribute_List_Length;
                                                        Unsigned Reference_Sub_Attribute_List_Length;
                                                        Unsigned Reference_Attribute_Size_List_Length;
                                                        Unsigned Description_Length;
                                                        char Heap[sizeof(Unsigned)];
                                                };
                                                inXDB::DB &Data_Base;
                                                OID Object_ID;
                                                std::string Name;
                                                union {
                                                        uchar *Bytes;
                                                        DBRecord *Record;
                                                } DBuffer;
                                                size_t Heap_Length;
                                                uint Have_Heap_and_SubclassID;
                                                bool Need_Heap;
                                                bool Has_SubclassID;


                                                inline size_t Memory_length();
                                                inline size_t Heap_length(const size_t record_length);
                                                inline size_t Record_length();

                                                const std::string Record_file_name();






                                                inline void Adjust_average_record_size()
                                                                throw(inXDBException);

                                                inline void Begin_transaction(Transaction *trx)
                                                                throw(inXDBException);
                                                inline void Transaction_done();

                                                bool Check_if_need_heap();
                                                bool Check_if_have_subclass_ID();

                                                Type(const Type &db_type)
                                                                throw(inXDBException);
                                                Type(DB &db, OID &object_ID, const DBRecord *record)
                                                                throw(inXDBException);
                                                Type(DB &db)
                                                                throw(inXDBException);
                                                Type(DB &db, const std::string &name)
                                                                throw(inXDBException);
                                                Type(DB &db, const std::string &name,
                                                                        const inXDB::ClassType class_type,
                                                                        const bool persistent,
                                                                        ObjectList *super_classes = 0,
                                                                        const Unsigned bytes = 0
                                                         )
                                                                throw(inXDBException);

                                                Type(DB &db, const std::string &name, const FilePos garbage);
                                                ~Type()
                                                                throw(inXDBException);
                                        protected:
                                        public:
                                                inline bool is_in_data_base();
                                                inline bool is_not_in_data_base();

                                                inline DB &data_base();
                                                inline FilePos file();

                                                inline const char *name();

                                                std::string screen_description();

                                                inline const OID &ID();

                                                inline inXDB::ClassType class_type();
                                                inline inXDB::ClassType class_type(const ClassType type);

                                                inline bool persistent();
                                                inline bool not_persistent();

                                                inline Unsigned bytes();

                                                bool is_EDI_document(const std::string &DB_name);

                                                bool no_super_classes();
                                                Unsigned super_classes();
                                                Type *super_class(const Unsigned index);

                                                inline SubclassID subclass_ID();
                                                inline SubclassID subclass_ID(const SubclassID sid);

                                                Unsigned sub_classes();
                                                Type *sub_class(const Unsigned index);

                                                Unsigned attributes();
                                                TypeAttribute *attribute(const Unsigned index);
                                                TypeAttribute *attribute(Unsigned *index,
                                                                                                                        const std::string &name
                                                                                                                );

                                                inline bool this_has_primary_index();
                                                inline bool this_has_no_primary_index();
                                                inline TypeIndex *this_primary_index();

                                                inline Unsigned this_secondary_indeces();
                                                TypeIndex *this_secondary_index(const Unsigned index);

                                                bool has_primary_index();
                                                bool has_no_primary_index();
                                                TypeIndex *primary_index();

                                                Unsigned secondary_indeces();
                                                TypeIndex *secondary_index(const Unsigned index);

                                                inline Unsigned reference_attributes();
                                                TypeAttribute *reference_attribute(const Unsigned index);
                                                TypeAttribute *reference_attribute(const Unsigned index,
                                                                                                                                                        TypeAttribute *ra,
                                                                                                                                                        const Unsigned chars,
                                                                                                                                                        TypeAttribute *sa
                                                                                                                                         );

                                                inline Unsigned reference_sub_attributes();
                                                TypeAttribute *reference_sub_attribute(const Unsigned index);

                                                inline Unsigned reference_attribute_sizes();
                                                Unsigned reference_attribute_size(const Unsigned index);

                                                bool reference_requires_snprintf();

                                                bool have_dbrecord();

                                                bool need_heap();
                                                bool has_subclass_ID();
                                                inline bool is_subclassed_ID();
                                                Type *subclassed_ID_type();

                                                bool contains_references();

                                                inline size_t description_length();
                                                inline const std::string description();
                                                const std::string
                                                        description(const std::string &new_description);

                                                void create()
                                                                throw(inXDBException);
                                                void write()
                                                                throw(inXDBException);

                                                void append(Type &sub_class);

                                                void append(TypeAttribute &attribute);
                                                void replace(const Unsigned index, TypeAttribute &attribute);
                                                void insert(const Unsigned index, TypeAttribute &attribute);
                                                void remove(const Unsigned index);

                                                void add_primary_index(TypeIndex &primary_index);
                                                void append_secondary_index(TypeIndex &secondary_index);

                                                inline TypeAttribute *duplicate_attribute();
                                                inline TypeAttribute *duplicate_attribute(TypeAttribute *a);

                                                Type &operator =(const Type &db_type);

                                                inline bool is_system_type();
                                                inline bool is_not_system_type();

                                                inline bool has_no_references_from_other_OIDs();
                                                inline bool has_references_from_other_OIDs();

                                                static bool need_declaration(uint &variables,
                                                                                                                                ClassArray<std::string *>
                                                                                                                                                &variable,
                                                                                                                          const std::string &pointer_name
                                                                                                                         );
                                                const std::string args_access(const bool in_class);
                                                const std::string attribute_access();
                                                std::string references_from_other_OIDs();
                                                std::string qualified_name(DB &current_DB);
                                                std::string qualified_pointer_empty_instance(DB &current_DB);
                                                std::string qualified_pointer(DB &current_DB);
                                                std::string reference_pointer(std::string &pointer_name,
                                                                                                                 DB &current_DB
                                                                                                                );
                                                std::string qualified_pointer_argument(DB &current_DB);
                                                std::string reference_pointer_argument(std::string
                                                                                                                                                                        &pointer_name,
                                                                                                                                                                DB &current_DB
                                                                                                                                                  );
                                                std::string delete_pointer(const std::string &pointer_name,
                                                                                                                                Type &member_of_type,
                                                                                                                                TypeAttribute &member_attribute
                                                                                                                  );
                                                bool super_classes_have_dbrecord();
                                                void record_buffer(class Format &file,
                                                                                                        const bool use_dbrecord,
                                                                                                        const bool for_DB_get,
                                                                                                        const char *prefix = 0
                                                                                                );
                                                void get_record(class Format &file, const bool use_dbrecord,
                                                                                                Type *super_class = 0,
                                                                                                const std::string *DB_name = 0
                                                                                        );
                                                void copy_DB_record(class Format &file,
                                                                                                        const bool recreate_unconditionally,
                                                                                                        const bool recreate_heap_if_bigger,
                                                                                                        const bool over_extend_heap,
                                                                                                        const bool already_filled
                                                                                                 );
                                                void clear_record(class Format &file);
                                                void get_trx_index(class Format &file,
                                                                                                        const std::string &index,
                                                                                                        const Unsigned indeces,
                                                                                                        const bool save_next_index
                                                                                                );
                                                bool create_requires_owner();
                                                bool super_class_create_requires_owner();
                                                bool index_constructor_declaration(TypeIndex &index,
                                                                                                                                                        const size_t indeces,
                                                                                                                                                        const uint index_index,
                                                                                                                                          std::string **
                                                                                                                                                index_type_constructor
                                                                                                                                         );
                                                void declare_new_constructor_arguments(bool &uses_the_user,
                                                                                                                                                                bool &needs_comma,
                                                                                                                                                                class Format &file,
                                                                                                                                        const std::string &DB_name,
                                                                                                                                        const bool show_rec_length,
                                                                                                                                        const bool include_defaults,
                                                                                                                                        const bool show_subclass_ID
                                                                                                                                                                        = true
                                                                                                                                                  );
                                                void declare_new_constructor_args(bool &uses_the_user,
                                                                                                                                                class Format &file,
                                                                                                                                         const bool show_subclass_ID
                                                                                                                                                                = true
                                                                                                                                        );
                                                void declare_new_constructor_args_names(bool &uses_the_user,
                                                                                                                                                                class Format &file,
                                                                                                                                                         const bool
                                                                                                                                                                        for_printf,
                                                                                                                                         const bool show_subclass_ID
                                                                                                                                                                = true
                                                                                                                                                        );
                                                bool declare_constructors(class Format &file,
                                                                                                                                const std::string &DB_name,
                                                                                                                                const size_t indeces,
                                                                                                                  std::string **index_type_constructor
                                                                                                                 );
                                                bool class_header(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                std::string **index_type_constructor,
                                                                                                                bool &needs_dereferencing
                                                                                          );
                                                void inline_header(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const size_t indeces,
                                                                                                        const size_t sub_indeces,
                                                                                                        const bool needs_dereferencing,
                                                                                                 std::string **index_type_constructor
                                                                                                );
                                                void class_definition(class Format &file,
                                                                                                                        const std::string &DB_name,
                                                                                                                        const size_t indeces,
                                                                                                                        const size_t sub_indeces,
                                                                                                                        const bool uses_the_user,
                                                                                                                        const bool needs_dereferencing,
                                                                                                         std::string **index_type_constructor
                                                                                                        );
                                                void class_IO(class Format &file,
                                                                                                const std::string &DB_name,
                                                                                                const size_t indeces,
                                                                                                const size_t sub_indeces
                                                                                 );
                                                void find_constructor(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                TypeIndex &index,
                                                                                                                const uint index_index,
                                                                                                                const uint secondary_index_index,
                                                                                                                const size_t indeces,
                                                                                                                const size_t actual_indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const bool is_static_constructor,
                                                                                                                const std::string &the_decl,
                                                                                                         std::string **index_type_constructor
                                                                                                        );
                                                void find_super_constructor(class Format &file,
                                                                                                                                        const std::string &DB_name,
                                                                                                                                        TypeIndex &index,
                                                                                                                                        const uint index_index,
                                                                                                                                        const size_t indeces,
                                                                                                                                        const size_t actual_indeces,
                                                                                                                                        const size_t sub_indeces,
                                                                                                                         std::string
                                                                                                                                                **index_type_constructor
                                                                                                                        );
                                                void find_super_constructor_method(class Format &file,
                                                                                                                                                const std::string
                                                                                                                                                                &DB_name,
                                                                                                                                                const size_t indeces,
                                                                                                                                        const size_t actual_indeces,
                                                                                                                                                const size_t sub_indeces,
                                                                                                                                                TypeIndex *index,
                                                                                                                                                uint index_index,
                                                                                                                                                const std::string
                                                                                                                                                                *key_check_string
                                                                                                                                         );
                                                void find_or_create_method(class Format &file,
                                                                                                                                const std::string &DB_name,
                                                                                                                                const size_t indeces,
                                                                                                                                const size_t sub_indeces
                                                                                                                  );
                                                void subclass_Create_method(class Format &file,
                                                                                                                                const std::string &DB_name,
                                                                                                                                const bool uses_the_user,
                                                                                                                                const size_t indeces,
                                                                                                                                const size_t sub_indeces
                                                                                                                   );
                                                bool primary_index_name(inXDB::TypeIndex *index,
                                                                                                                        char index_ID[64]
                                                                                                          );
                                                void create_method(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const bool uses_the_user,
                                                                                                        const size_t indeces,
                                                                                                        const size_t sub_indeces
                                                                                                );
                                                void finish_create_method(class Format &file,
                                                                                                                        const std::string &DB_name,
                                                                                                                        const bool uses_the_user,
                                                                                                                        const size_t indeces,
                                                                                                                        const size_t sub_indeces
                                                                                                                 );
                                                void write_method(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const bool uses_the_user,
                                                                                                        const size_t indeces,
                                                                                                        const size_t sub_indeces
                                                                                                );
                                                void remove_references(class Format &file,
                                                                                                                        const std::string &DB_name,
                                                                                                                        const bool use_trx
                                                                                                         );
                                                void remove_method(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const size_t indeces,
                                                                                                        const size_t sub_indeces
                                                                                                );
                                                void remove_references_method(class Format &file,
                                                                                                                                        const std::string &DB_name
                                                                                                                          );
                                                void next_method(class Format &file,
                                                                                                const std::string &DB_name,
                                                                                                const size_t indeces,
                                                                                                const size_t sub_indeces,
                                                                                                const bool is_const
                                                                                         );
                                                void index_method(class Format &file, const size_t indeces,
                                                                                                        const size_t sub_indeces
                                                                                          );
                                                std::string export_object(uint &end_blocks,
                                                                                                                ClassArray<std::string *> &end_block,
                                                                                                        const std::string &full_qualification
                                                                                                  );
                                                std::string export_method();
                                                void import_export_methods(class Format &file,
                                                                                                                                const std::string &DB_name,
                                                                                                                                const size_t indeces,
                                                                                                                                const size_t sub_indeces
                                                                                                                  );
                                                void equals_method(class Format &file, const size_t indeces,
                                                                                                        const size_t actual_indeces,
                                                                                                        const size_t sub_indeces,
                                                                                                        const bool do_sub_class
                                                                                                );
                                                void is_empty_method(class Format &file);
                                                void is_equal_method(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces
                                                                                                  );
                                                void is_not_equal_method(class Format &file,
                                                                                                                        const std::string &DB_name,
                                                                                                                        const size_t indeces
                                                                                                                );
                                                void get_actual_method(class Format &file,
                                                                                                                const size_t indeces
                                                                                                         );
                                                void use_new_constructor_arguments(class Format &file,
                                                                                                                                          Type *for_type,
                                                                                                                                                const bool use_subclass_ID
                                                                                                                                         );
                                                void make_constructor(class Format &file,
                                                                                                                const size_t indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const uint heap_length,
                                                                                                                const bool copy_object_ID,
                                                                                                                const bool is_new_constructor = false,
                                                                                                                TypeIndex *index = 0,
                                                                                                                const bool is_find_all_constructor
                                                                                                                        = false,
                                                                                                                const uint possibilities = 0,
                                                                                                                const bool is_copy_constructor =false,
                                                                                                                const bool record_is_dbpointer =false,
                                                                                                                const bool is_sc_copy_constructor
                                                                                                                        = false
                                                                                                        );
                                                void read_OID_method(class Format &file,
                                                                                                                const std::string &DB_name
                                                                                                  );
                                                void copy_constructor(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                const size_t actual_indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const bool do_sub_class,
                                                                                                                const bool do_super_class,
                                                                                                                const bool do_super_class_recptr
                                                                                                        );
                                                void OID_constructor(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                const size_t sub_indeces
                                                                                                  );
                                                void empty_constructor(class Format &file,
                                                                                                                const size_t indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const bool without_data_base
                                                                                                         );
                                                void new_constructor(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const bool is_static_constructor,
                                                                                                                const std::string &the_decl
                                                                                                  );
                                                void find_all_constructor(class Format &file,
                                                                                                                                const std::string &DB_name,
                                                                                                                                const size_t indeces,
                                                                                                                                const size_t sub_indeces
                                                                                                                 );
                                                void destructor(class Format &file);
                                                void property_empty_method(class Format &file,
                                                                                                                                const size_t indeces
                                                                                                                  );
                                                int Make_shortcut(bool ASCII[256],
                                                                                                const char *name
                                                                                          );
                                                void place_attributes(const size_t indeces,
                                                                                                         int &form_line, int &form_item,
                                                                                                                TypeAttribute::DBFormLine *form_lines,
                                                                                                                int *column_width, int &height,
                                                                                                                int &last_y, uint &text_items
                                                                                                        );
                                                void form_header(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const size_t indeces,
                                                                                                        const uint references,
                                                                                                        const bool has_defaults,
                                                                                                        const bool is_EDI_document,
                                                                                                        const int window_width,
                                                                                                        const int window_height
                                                                                         );
                                                void ref_form_header(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                const bool is_EDI_document
                                                                                                  );
                                                void set_form_header(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                const bool is_EDI_document
                                                                                                  );
                                                void form_form_headers(class Format &file,
                                                                                                                const bool main_form,
                                                                                                                const bool is_EDI_document
                                                                                                         );
                                                void form_type_lists(class Format &file,
                                                                                                                const std::string &DB_name,
                                                                                                                const size_t indeces,
                                                                                                                TypeAttribute::DBFormLine *form_lines
                                                                                                  );
                                                void set_form_key_to_entries(class Format &file,
                                                                                                                                const std::string &DB_name,
                                                                                                                                const size_t indeces,
                                                                                                                                TypeIndex &primary
                                                                                                                         );
                                                void set_form_object_to_entries(class Format &file,
                                                                                                                                        const std::string &DB_name,
                                                                                                                                        const size_t indeces,
                                                                                                                                        TypeIndex &primary
                                                                                                                                 );
                                                void form_check_key(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const size_t indeces,
                                                                                                        const bool has_defaults
                                                                                                 );
                                                void form_defaults(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const size_t indeces,
                                                                                                        const bool is_EDI_document
                                                                                                );
                                                void form_focus(class Format &file,
                                                                                                TypeAttribute::DBFormLine *form_lines
                                                                                        );
                                                void form_clear(class Format &file,
                                                                                                TypeAttribute::DBFormLine *form_lines
                                                                                        );
                                                void form_empty(class Format &file, const size_t indeces);
                                                void form_new(class Format &file, const size_t indeces,
                                                                                        const bool has_defaults
                                                                                 );
                                                void form_show(class Format &file, const std::string &DB_name,
                                                                                                const size_t indeces
                                                                                  );
                                                void form_at_save(class Format &file,
                                                                                                const size_t indeces
                                                                                  );
                                                void form_at_remove(class Format &file,
                                                                                                        const size_t indeces
                                                                                                 );
                                                void form_enable_buttons(class Format &file,
                                                                                                                        const size_t indeces,
                                                                                                                        const uint references
                                                                                                           );
                                                void form_list_key(class Format &file,
                                                                                                        const std::string &DB_name,
                                                                                                        const uint indeces
                                                                                                );
                                                void form_by_key(class Format &file,
                                                                                                const std::string &name_space
                                                                                         );
                                                void form_select_key(class Format &file,
                                                                                                                const size_t indeces
                                                                                                  );
                                                void form_undo(class Format &file, const size_t indeces);
                                                void form_view_list(class Format &file);
                                                void form_statics(class Format &file,
                                                                                                        const std::string &DB_name
                                                                                          );
                                                void form_field_accesses(class Format &file,
                                                                                                                        const std::string &DB_name,
                                                                                                                        const size_t indeces
                                                                                                                );
                                                void form_assign_object(class Format &file);
                                                void form_done_with_object(class Format &file);
                                                void form_begin_trx(class Format &file);
                                                void form_is_empty(class Format &file, const size_t indeces);
                                                void form_validation(class Format &file);
                                                void form_condestructor(class Format &file,
                                                                                                                        const std::string &DB_name,
                                                                                                                        const size_t indeces,
                                                                                                                        const bool has_defaults,
                                                                                                                        const bool is_EDI_document,
                                                                                                                        TypeAttribute::DBFormLine
                                                                                                                                        *form_lines,
                                                                                                                        const uint text_items
                                                                                                          );
                                                void form_find_by_definition(class Format &file,
                                                                                                                                        const std::string &DB_name,
                                                                                                                                        const size_t indeces,
                                                                                                                                        const size_t sub_indeces
                                                                                                                         );
                                                void form_view_list_definition(class Format &file,
                                                                                                                                        const std::string &DB_name,
                                                                                                                                        const size_t indeces
                                                                                                                                );
                                                void form_class(class Format &file,
                                                                                                const std::string &DB_name,
                                                                                                const size_t indeces,
                                                                                                const size_t sub_indeces,
                                                                                                const uint references,
                                                                                                const bool has_defaults,
                                                                                                const bool is_EDI_document,
                                                                                                TypeAttribute::DBFormLine *form_lines,
                                                                                                const uint text_items
                                                                                        );
                                                void ref_form_class(class Format &file, const size_t indeces,
                                                                                                                const bool is_EDI_document,
                                                                                                                int window_width, int window_height,
                                                                                                                TypeAttribute::DBFormLine *form_lines,
                                                                                                                const uint text_items
                                                                                                 );
                                                void set_form_class(class Format &file, const size_t indeces,
                                                                                                                const bool is_EDI_document,
                                                                                                                int window_width, int window_height,
                                                                                                                TypeAttribute::DBFormLine *form_lines,
                                                                                                                const uint text_items
                                                                                                 );

                                                int compare(const Type &type) const;

                                                bool export_ASCII(std::ostream &output_file);
                                                bool import_ASCII(std::istream &input_file, DB &DB,
                                                                                                        const char *buffer = 0
                                                                                          );

                                                inline void add(OID &object_ID,
                                                                                         const void *record, const FilePos bytes
                                                                                        )
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, char **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, uchar **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, long **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, ulong **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, void *record,
                                                                                                const size_t record_bytes
                                                                                        )
                                                                throw(inXDBException);
                                                inline void put(OID &object_ID,
                                                                                         const void *record, const FilePos bytes
                                                                                        )
                                                                throw(inXDBException);
                                                inline void remove(const OID &object_ID)
                                                                throw(inXDBException);
# 3325 "../inXDB/DB/inXDB.h"
                                };
                                class DB {
                                                friend class inXDB;
                                                friend class inXDB::inXDBTransaction;
                                                friend class inXDB::TypeAttribute;
                                                friend class inXDB::Type;
                                                friend class inXDB::TypeIndex;
                                                friend class inXServices::AVL<DB>;
                                        private:
                                                class TypeKey {
                                                        private:
                                                                char Type_Name[inXDB_Name_Length];
                                                                char Index_Name[inXDB_Name_Length];
                                                                OID Object_ID;
                                                                FilePos File;
                                                        protected:
                                                        public:
                                                                static inline size_t sizeof_name();

                                                                inline const char *type_name();
                                                                inline const char *index_name();

                                                                inline OID &ID();

                                                                inline FilePos file();

                                                                inline TypeKey(const char *type_name);
                                                                inline TypeKey(const char *type_name,
                                                                                                                const char *index_name
                                                                                                  );
                                                                inline TypeKey(const char *type_name,
                                                                                                                const OID &object_ID,
                                                                                                                const FilePos file
                                                                                                  );
                                                                inline TypeKey(const char *type_name,
                                                                                                                const char *index_name,
                                                                                                                const OID &object_ID,
                                                                                                                const FilePos file
                                                                                                  );
                                                                inline TypeKey();
                                                                inline ~TypeKey();
                                                };

                                                struct DBRecord {
                                                        FilePos Data_File;
                                                        FilePos Type_File;
                                                        char Name[inXDB_Name_Length];
                                                        Unsigned Description_Length;
                                                        char Heap[sizeof(Unsigned)];
                                                };
                                                inXDBTransaction &Trx;
                                                inXDB &Data_Base;
                                                OID Object_ID;
                                                std::string Name;
                                                union {
                                                        uchar *Bytes;
                                                        DBRecord *Record;
                                                } DBuffer;
                                                size_t Heap_Length;
                                                BTree *Type_Index;

                                                inline size_t Memory_length();
                                                inline size_t Heap_length(const size_t record_length);
                                                inline size_t Record_length();

                                                const std::string Directory_name();
                                                const std::string Record_file_name();
                                                const std::string Index_file_name();

                                                inline void add(OID &object_ID,
                                                                                         const void *record, const FilePos bytes
                                                                                        )
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, char **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, uchar **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, long **record)
                                                                throw(inXDBException);
                                                inline void get(OID &object_ID, ulong **record)
                                                                throw(inXDBException);
                                                inline void get(const size_t record_bytes,
                                                                                         OID &object_ID, void *record
                                                                                        )
                                                                throw(inXDBException);
                                                inline void put(OID &object_ID,
                                                                                         const void *record, const FilePos bytes
                                                                                        )
                                                                throw(inXDBException);
                                                inline void remove(const OID &object_ID)
                                                                throw(inXDBException);

                                                bool Have_type(const std::string &name,
                                                                                   OID *ID = 0, FilePos *file = 0
                                                                                  )
                                                                throw(inXDBException);
                                                bool Have_index(const std::string &type_name,
                                                                                                const std::string &index_name,
                                                                                    OID *ID = 0, FilePos *file = 0
                                                                                   )
                                                                throw(inXDBException);

                                                inline const uchar *Get(OID &object_ID)
                                                                throw(inXDBException);

                                                void Add(OID &object_ID,
                                                                        Type *type, const void *record, const FilePos bytes,
                                                                                const FilePos file
                                                                  )
                                                                throw(inXDBException);
                                                void Add(OID &object_ID,
                                                                        TypeIndex *index, const void *record,
                                                                                const FilePos bytes, const FilePos file
                                                                  )
                                                                throw(inXDBException);
                                                void Get_file(Type *type, const void *record,
                                                                                                const FilePos bytes,
                                                                                  OID &object_ID, FilePos &file
                                                                                 )
                                                                throw(inXDBException);

                                                void Remove(Type &type)
                                                                throw(inXDBException);
                                                void Remove(TypeIndex &index)
                                                                throw(inXDBException);





                                                std::string name_space(DB &db);

                                                void Move_if_different(const std::string &old_name,
                                                                                                                        const std::string &new_name
                                                                                                         );
                                                void Generate_headers(const char *major_version,
                                                                                                                        const char *minor_version
                                                                                                        );
                                                void Generate_makefile();
                                                void Generate_odb_makefile(const char *major_version,
                                                                                                                                const char *minor_version,
                                                                                                                                const char *module_name,
                                                                                                                                const char *submodule_name,
                                                                                                                                const uint includes,
                                                                                                                                const Array<const char *>
                                                                                                                                        &include
                                                                                                                  );
                                                void Generate_odbio_makefile(const char *major_version,
                                                                                                                                const char *minor_version,
                                                                                                                                const char *module_name,
                                                                                                                                const char *submodule_name,
                                                                                                                                const uint includes,
                                                                                                                                const Array<const char *>
                                                                                                                                        &include
                                                                                                                         );
                                                void Generate_dbf_makefile(const char *major_version,
                                                                                                                                const char *minor_version,
                                                                                                                                const char *module_name,
                                                                                                                                const char *submodule_name,
                                                                                                                                const uint includes,
                                                                                                                                const Array<const char *>
                                                                                                                                        &include
                                                                                                                  );
                                                bool Generate_header(Type &for_type, const size_t indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const char *major_version,
                                                                                                                const char *minor_version,
                                                                                                        std::string **index_type_constructor,
                                                                                                                bool &needs_dereferencing
                                                                                                  );
                                                void Generate_inline_header(Type &for_type,
                                                                                                                                const size_t indeces,
                                                                                                                                const size_t sub_indeces,
                                                                                                                                const char *major_version,
                                                                                                                                const char *minor_version,
                                                                                                                                const bool needs_dereferencing,
                                                                                                                         std::string
                                                                                                                                        **index_type_constructor
                                                                                                                        );
                                                void Generate_class(Type &for_type, const size_t indeces,
                                                                                                                const size_t sub_indeces,
                                                                                                                const bool uses_the_user,
                                                                                                                const char *major_version,
                                                                                                                const char *minor_version,
                                                                                                                const bool needs_dereferencing,
                                                                                                  std::string **index_type_constructor
                                                                                                 );
                                                void Generate_class_IO(Type &for_type, const size_t indeces,
                                                                                                                        const size_t sub_indeces,
                                                                                                                        const char *major_version,
                                                                                                                        const char *minor_version
                                                                                                         );
                                                void Generate_form_header(Type &for_type,
                                                                                                                                const size_t indeces,
                                                                                                                                const uint references,
                                                                                                                                const bool has_defaults,
                                                                                                                                const bool is_EDI_document,
                                                                                                                                const char *major_version,
                                                                                                                                const char *minor_version,
                                                                                                                                const int window_width,
                                                                                                                                const int window_height
                                                                                                                 );
                                                void Generate_form_class(Type &for_type,
                                                                                                                        const size_t indeces,
                                                                                                                        const size_t sub_indeces,
                                                                                                                        const uint references,
                                                                                                                        const bool has_defaults,
                                                                                                                        const bool is_EDI_document,
                                                                                                                        const char *major_version,
                                                                                                                        const char *minor_version,
                                                                                                                        TypeAttribute::DBFormLine
                                                                                                                                *form_lines,
                                                                                                                        const uint text_items
                                                                                                                );
                                                void Generate_ref_form_header(Type &for_type,
                                                                                                                                        const size_t indeces,
                                                                                                                                        const bool is_EDI_document,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version
                                                                                                                          );
                                                void Generate_ref_form_class(Type &for_type,
                                                                                                                                        const size_t indeces,
                                                                                                                                        const bool is_EDI_document,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version,
                                                                                                                                        const int window_width,
                                                                                                                                        const int window_height,
                                                                                                                                        TypeAttribute::DBFormLine
                                                                                                                                                *form_lines,
                                                                                                                                        const uint text_items
                                                                                                                         );
                                                void Generate_set_form_header(Type &for_type,
                                                                                                                                        const size_t indeces,
                                                                                                                                        const bool is_EDI_document,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version
                                                                                                                          );
                                                void Generate_set_form_class(Type &for_type,
                                                                                                                                        const size_t indeces,
                                                                                                                                        const bool is_EDI_document,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version,
                                                                                                                                        const int window_width,
                                                                                                                                        const int window_height,
                                                                                                                                        TypeAttribute::DBFormLine
                                                                                                                                                *form_lines,
                                                                                                                                        const uint text_items
                                                                                                                         );
                                                class Format &ident_directive(class Format &file,
                                                                                                                                        const std::string &file_name,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version
                                                                                                                          );
                                                void Generate_header_copyright(class Format &file,
                                                                                                                                        const std::string &file_name,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version
                                                                                                                                );
                                                void Generate_code_copyright(class Format &file,
                                                                                                                                        const std::string &file_name,
                                                                                                                                        const std::string &name,
                                                                                                                                        const char *major_version,
                                                                                                                                        const char *minor_version,
                                                                                                                                        const bool include_inX_header
                                                                                                                                                = false,
                                                                                                                                        const bool
                                                                                                                                                include_libintl_header
                                                                                                                                                        = false,
                                                                                                                                        const bool
                                                                                                                                                include_algorithm_header
                                                                                                                                                        = false,
                                                                                                                                        const bool
                                                                                                                                                include_iostream_header
                                                                                                                                                        = false
                                                                                                                         );
                                                void Generate_Exodus_header(class Format &file,
                                                                                                                                Type *for_type = 0,
                                                                                                                                const size_t indeces = 0,
                                                                                                                                const bool check_for_money
                                                                                                                                        = false
                                                                                                                        );

                                                DB &operator =(const DB &);

                                                DB(const DB &)
                                                                throw(inXDBException);
                                                DB(inXDBTransaction &trx, inXDB &data_base, OID &object_ID)
                                                                throw(inXDBException);
                                                DB(inXDBTransaction &trx, inXDB &data_base,
                                                                const std::string &name
                                                  )
                                                                throw(inXDBException);
                                                DB(inXDBTransaction &trx, inXDB &data_base)
                                                                throw(inXDBException);
                                                ~DB()
                                                                throw(inXDBException);
                                        protected:
                                        public:
                                                inline bool is_in_data_base();
                                                inline bool is_not_in_data_base();
                                                inline inXDB &data_base();

                                                inline const char *name();
                                                std::string screen_description();

                                                inline const OID &ID();

                                                inline FilePos data_file();

                                                inline size_t description_length();
                                                inline const std::string description();
                                                const std::string
                                                        description(const std::string &new_description);

                                                void create()
                                                                throw(inXDBException);
                                                void write()
                                                                throw(inXDBException);

                                                Type *list_types(BTreePosition &position,
                                                                                          const bool ascending = true
                                                                                         );
                                                inline Type *type(const std::string &name)
                                                                throw(inXDBException);
                                                inline Type *type(OID &object_ID)
                                                                throw(inXDBException);



                                                TypeIndex *indece(Type &type, OID &object_ID,
                                                                                                        TypeIndex::DBRecord *record
                                                                                          )
                                                                throw(inXDBException);

                                                void generate(Type &for_type, const bool system_makefile,
                                                                                        const bool DB_makefile,
                                                                                        const char *major_version,
                                                                                        const char *minor_version,
                                                                                        const char *module_name,
                                                                                        const char *submodule_name,
                                                                                        const uint includes,
                                                                                        const Array<const char *> &include
                                                                                 );
                                                inline int compare(const DB &db) const;




                                                static bool compare(const std::string &old_name,
                                                                                                                const std::string &new_name
                                                                                                 );

                                                bool export_ASCII(std::ostream &output_file);
                                                bool import_ASCII(std::istream &input_file,
                                                                                                        const char *buffer = 0
                                                                                          );

                                                void statistics(std::ostream &stream)
                                                                throw(inXDBException);
                                };
                        private:
                                class DBKey {
                                        private:
                                                char DB_Name[inXDB_Name_Length];
                                                OID Object_ID;
                                                FilePos File;
                                        protected:
                                        public:
                                                static inline size_t sizeof_name();

                                                inline const char *DB_name();

                                                inline OID &ID();

                                                inline FilePos file();

                                                inline DBKey(const char *DB_name);
                                                inline DBKey(const char *DB_name, const OID &object_ID,
                                                                                        const FilePos file
                                                                                );
                                                inline DBKey();
                                                inline ~DBKey();
                                };


                                static inXServices::File *RNG;
                                static ulong RNG_Opens;

                                inXServices::AVL<DBObject> *Object_List;
# 3742 "../inXDB/DB/inXDB.h"
                                inXDB &operator =(const inXDB &);
                                inXDB(const inXDB &);
                        protected:
                                inline Transaction *Tranx();

                                void Cache(const FilePos file, Type *type)
                                                throw(inXDBException);

                                inline void add(const void *record, const FilePos bytes,
                                                                                const FilePos file,
                                                                         OID &object_ID
                                                                        )
                                                                        throw(inXDBException);
                                inline void get(OID &object_ID, char **record)
                                                throw(inXDBException);
                                inline void get(OID &object_ID, uchar **record)
                                                throw(inXDBException);
                                inline void get(OID &object_ID, long **record)
                                                throw(inXDBException);
                                inline void get(OID &object_ID, ulong **record)
                                                throw(inXDBException);
                                inline void get(const size_t record_bytes,
                                                                         OID &object_ID, void *record
                                                                        )
                                                throw(inXDBException);
                                inline void remove(const OID &object_ID)
                                                throw(inXDBException);





                                static const std::string Index_file_name(const std::string &name);
                        public:
                                inline const std::string &name() const;
                                const std::string DB_name();

                                inline const Reason state() const;
                                inline const std::string reason() const;
                                inline const FilePos file_number() const;
                                inline const FilePos page_number() const;

                                inline void set_state_to_okay();

                                void close()
                                                throw(inXDBException);
                                void create(const std::string &DB_name)
                                                throw(inXDBException);
                                void open(const std::string &DB_name, const bool writable)
                                                throw(inXDBException);

                                bool lock(const File::LockType type, const ulong UID,
                                                                const ulong PID, const OID &object_ID,
                                                         ulong &locked_by_UID, time_t &locked
                                                        );
                                void list_locks(std::ostream &stream)
                                                throw(inXDBException);
                                void clear_locks()
                                                throw(inXDBException);

                                inXDBTransaction
                                        *begin_transaction(const std::string &name, const bool wait,
                                                                                                const bool read_headers_from_DB = true
                                                                                        )
                                                throw(inXDBException);
                                void abort_transaction(inXDBTransaction &trx,
                                                                                                const bool first_time = true
                                                                                         )
                                                throw(inXDBException);
                                void commit_transaction(inXDBTransaction &trx)
                                                throw(inXDBException);
# 3827 "../inXDB/DB/inXDB.h"
                                void log_error(inXDB *&db, const bool fatal,
                                                                                const char *format, ...
                                                                  )



                                        ;
                                void log_error(inXDB *&db, const bool fatal, const char *format,
                                                                                va_list arg
                                                                  );

                                void statistics(std::ostream &stream)
                                                throw(inXDBException);

                                bool export_ASCII(std::ostream &output_file);
                                bool import_ASCII(std::istream &input_file);

                                inXDB(const char *program_name = 0,
                                                        const char *error_log_file_name = 0
                                          )
                                                throw(inXDBException);
                                inXDB(const std::string &DB_name, const bool writable,
                                                        const char *program_name = 0,
                                                        const char *error_log_file_name = 0
                                          )
                                                throw(inXDBException);
                                ~inXDB()
                                                throw(inXDBException);
                };

                extern inXDB::OID Null_OID;
                extern char IOport_Delimiter;
                extern bool Using_Window;

                extern void window_error_message_box(const std::string &message,
                                                                                                                                const std::string &title,
                                                                                                                 inXDataBase *&data_base
                                                                                                                );
                extern void window_error_message_box(const std::string &message,
                                                                                                                                const std::string &title,
                                                                                                                 inXDB *&data_base
                                                                                                                );

                extern bool import_string(char *buffer, size_t &length,
                                                                                  const size_t buffer_length,
                                                                                                std::istream &input_file
                                                                                 );
                extern bool export_string(const char *buffer, const size_t length,
                                                                                                std::ostream &output_file
                                                                                 );

                extern int date_from_MDY(const char *arg,
                                                                                 time_t &date
                                                                                );

                class DBObject : protected inXServices::inXObject {
                                friend class inXDB::inXDBTransaction;
                        public:
                                static bool dont_lock;
                                static bool dont_wait_for_lock;
                                static bool read_is_modifiable;
                        private:
                                bool Modified;
                                bool Removed;
                                const uchar *DB_Record;
                                uchar *Modified_Record;
                                inXDB *Data_Base;
                                inXDB::inXDBTransaction *Trx;
                                bool Remove_From_Trx_Okay;
                                inXDB::Type *DBType;
                        protected:
                                Unsigned Next_Index;
                        private:
                                inXDB::BTree **DBIndex;
                                inXDB::OID Object_ID;

                                inXDB::Type *Get_type(inXdb::inXDB::inXDBTransaction *trx,
                                                                                                const std::string &DB_name,
                                                                                                const std::string &type_name
                                                                                        )
                                                throw(inXDBException);
                                inXDB::BTree *Get_index(const std::string &DB_name,
                                                                                                        const std::string &type_name,
                                                                                                        const Unsigned indeces,
                                                                                                        const Unsigned index
                                                                                          )
                                                throw(inXDBException);
                        protected:



                                DBObject &operator =(const DBObject &object);

                                inline inXDB::Type *Type(inXdb::inXDB::inXDBTransaction *trx,
                                                                                                        const std::string &DB_name,
                                                                                                        const std::string &type_name
                                                                                                )
                                                throw(inXDBException);
                                inline void Index(const std::string &DB_name,
                                                                                        const std::string &type_name,
                                                                                        const Unsigned indeces, const Unsigned index
                                                                          )
                                                throw(inXDBException);
                                inline bool Never_been_read_from_DB() const;
                                inline bool Is_modified() const;
                                inline bool Is_not_modified() const;
                                inline const uchar *Record() const;
                                inline uchar *Record();

                                inline void Copy_from_existing(const DBObject &existing);

                                inline bool Insert(const Unsigned index, const void *buffer)
                                                throw(inXDBException);
                                inline bool Remove(const Unsigned index, const void *buffer)
                                                throw(inXDBException);
                                inline bool Find(const Unsigned index, const void *buffer) const
                                                throw(inXDBException);
                                inline bool First(const Unsigned index) const
                                                throw(inXDBException);
                                inline bool Last(const Unsigned index) const
                                                throw(inXDBException);
                                inline bool Next(const Unsigned index) const
                                                throw(inXDBException);
                                inline bool Previous(const Unsigned index) const
                                                throw(inXDBException);
                                inline bool Nth(const Unsigned index, const FilePos n) const
                                                throw(inXDBException);
                                inline void Get_current(const Unsigned index,
                                                                                                        inXDB::BTreePosition &position
                                                                                          ) const;
                                inline bool Set_current(const Unsigned index,
                                                                                                        const inXDB::BTreePosition &position
                                                                                          ) const
                                                throw(inXDBException);
                                inline bool Get_key(const Unsigned index, void *buffer) const
                                                throw(inXDBException);
                                inline bool Get_key(const Unsigned index, void *buffer,
                                                                                        const size_t buffer_length
                                                                                 ) const
                                                throw(inXDBException);
                                inline bool Get_key_OID(const Unsigned index)
                                                throw(inXDBException);
                                inline bool Remove_current(const Unsigned index)
                                                throw(inXDBException);

                                inline FilePos Keys(const Unsigned index) const;

                                void Create(inXDB::inXDBTransaction *trx, const FilePos bytes)
                                                throw(inXDBException);
                                bool Write(inXDB::inXDBTransaction *trx, std::string *message,
                                                          const FilePos bytes, const bool wait_for_lock
                                                         )
                                                throw(inXDBException);
                                bool Remove()
                                                throw(inXDBException);
                                void Read(const inXDB::OID &object_ID)
                                                throw(inXDBException);

                                virtual size_t Current_record_length() const;

                                inline void Just_read_from_DB(const uchar *record);
                                void Replace_record(const size_t new_bytes,
                                                                                                const size_t current_bytes,
                                                                                                const bool modifying,
                                                                                                const std::string &type_name
                                                                                 )
                                                throw(inXDBException);

                                inline void Clear_trx();
                                inline void In_trx(inXDB::inXDBTransaction &trx);

                                inline inXDB::inXDBTransaction *Transaction() const;

                                static DBObject *the_DBObject(inXDB::inXDBTransaction &trx,
                                                                                                                        inXDB::OID &object_ID,
                                                                        DBObject *(*make)(inXdb::inXDB::inXDBTransaction *,
                                                                                                                                const inXdb::inXDB::OID &
                                                                                                                  )
                                                                                                          )
                                                throw(inXDBException);
                                static DBObject *the_DBObject(inXDB::inXDBTransaction &trx,
                                                                                                                        inXDB::OID &object_ID,
                                                                                                                const std::string &DB_name,
                                                                                                                        const std::string &type_name,
                                                                                                                        const void *key,
                                                                                                                        const Unsigned index,
                                                                        DBObject *(*make)(inXdb::inXDB::inXDBTransaction *,
                                                                                                                                const inXdb::inXDB::OID &
                                                                                                                  )
                                                                                                          )
                                                throw(inXDBException);
                                static DBObject *the_DBObject(inXDB::inXDBTransaction &trx,
                                                                                                                        inXDB::OID &object_ID,
                                                                                                                const std::string &DB_name,
                                                                                                                        const std::string &type_name,
                                                                                                                        const Unsigned index,
                                                                        DBObject *(*make)(inXdb::inXDB::inXDBTransaction *,
                                                                                                                                const inXdb::inXDB::OID &
                                                                                                                  )
                                                                                                          )
                                                throw(inXDBException);

                                static Unsigned Objects(inXDB::inXDBTransaction &trx,
                                                                                                const std::string &DB_name,
                                                                                                        const std::string &type_name,
                                                                                                        const Unsigned index
                                                                                          )
                                                throw(inXDBException);
                                static bool List_index(inXDB::inXDBTransaction &trx, void *buffer,
                                                                                          const std::string &DB_name,
                                                                                                        const std::string &type_name,
                                                                                                        const Unsigned index
                                                                                         )
                                                throw(inXDBException);

                                DBObject *Next(const Unsigned index,
                                                                                const inXDB::BTreePosition &position,
                                                                                const std::string &DB_name,
                                                                                const std::string &type_name,
                                                                        DBObject *(*make)(inXdb::inXDB::inXDBTransaction *,
                                                                                                                                const inXdb::inXDB::OID &
                                                                                                                  )
                                                                  ) const
                                                throw(inXDBException);
                                static DBObject *Next(inXdb::inXDB::inXDBTransaction &trx,
                                                                                         const Unsigned index,
                                                                                                const std::string &DB_name,
                                                                                                const std::string &type_name,
                                                                                                DBObject *(*make)(
                                                                                                                        inXdb::inXDB::inXDBTransaction *,
                                                                                                                                                const inXdb::inXDB::OID &
                                                                                                                                          )
                                                                                        )
                                                throw(inXDBException);

                                DBObject(const DBObject &object);
                                DBObject(inXDB::inXDBTransaction &trx, const inXDB::OID &object_ID)
                                                throw(inXDBException);
                                DBObject(inXDB::inXDBTransaction &trx);

                                DBObject(const inXDB::OID &object_ID);
                        public:
                                int compare(const DBObject &object) const;
# 4079 "../inXDB/DB/inXDB.h"
                                inline const inXdb::inXDB::OID &ID() const;
                                inline bool is_in_data_base();
                                inline bool is_not_in_data_base();

                                inline bool is_modifiable(std::string *message,
                                                                                                                const bool wait_for_lock = true
                                                                                                 )
                                                throw(inXDBException);

                                void log_error(const bool fatal, const char *format, ...)



                                        ;

                                ~DBObject()
                                                throw(inXDBException);
                };

                extern void hex_dump(std::ostream &stream, const uchar *data,
                                                                                const FilePos bytes
                                                                  );

        }

# 1 "../inXDB/DB/inXDB.i" 1



#ident "@(#)$Id: inXDB.i 1.3.1.50 Mon, 08 Apr 2002 04:34:36 -0700 tmwg $ -- Copyright (c) 1997-2002 inX Services"
# 13 "../inXDB/DB/inXDB.i"
# 1 "../inXDB/DB/inXDB.h" 1
# 14 "../inXDB/DB/inXDB.i" 2

        namespace inXdb {

inline uchar
version_major(const FilePos version) {
        return version >> 24;
}

inline uchar
version_minor(const FilePos version) {
        return static_cast<uchar>(version >> 16) & 0xff;
}

inline uchar
version_release(const FilePos version) {
        return static_cast<uchar>(version >> 8) & 0xff;
}

inline uchar
version_revision(const FilePos version) {
        return version & 0xff;
}

inline const inXDataBase &
inXDBException::data_base() const {
        return Data_Base;
}

inline
inXDBException::inXDBException(inXDataBase &data_base)
        : inXException(),
                Data_Base(data_base) {
        ;
}

inline
inXDBException::inXDBException(inXDataBase &data_base, const uint state,
                                                                                        const FilePos file_number,
                                                                                        const FilePos page_number, const char *message,
                                                                                        const char *function, const char *file,
                                                                                        const uint line, const char *type
                                                                                )
        : inXException(type, message, function, file, line),
                Data_Base(data_base) {
        Data_Base.State = static_cast<const inXDataBase::Reason>(state);
        Data_Base.File_Number = file_number;
        Data_Base.Page_Number = page_number;
}

inline
inXDBException::~inXDBException() throw() {
        ;
}

inline
inXDataBase::BTreePosition::BTreePosition()
        : Node(0) {
        ;
}

inline size_t
inXDataBase::Page::Magic_file_type_index() {
        return 11;
}

inline size_t
inXDataBase::Page::Magic_version_index(const size_t offset) {
        return Magic_file_type_index() + 1 + offset;
}

inline FilePos
inXDataBase::Page::Version_from_magic(const uchar *magic) {
        return static_cast<FilePos>(magic[0] << 24)
                         | static_cast<FilePos>(magic[1] << 16)
                         | static_cast<FilePos>(magic[2] << 8)
                         | static_cast<FilePos>(magic[3]);
}

inline const uchar *
inXDataBase::Page::magic() const {
        return Magic;
}

inline const inXDataBase::Page::FileType
inXDataBase::Page::magic_file_type() const {
        return static_cast<FileType>(Magic[Magic_file_type_index()]);
}

inline const uchar *
inXDataBase::Page::magic_version() const {
        return Magic + Magic_version_index();
}

inline inXDataBase::Page::PageType
inXDataBase::Page::type() const {
        return Type;
}

inline FilePos
inXDataBase::Page::version() const {
        return Version;
}

inline uchar
inXDataBase::Page::version_major() const {
        return inXdb::version_major(Version);
}

inline uchar
inXDataBase::Page::version_minor() const {
        return inXdb::version_minor(Version);
}

inline uchar
inXDataBase::Page::version_release() const {
        return inXdb::version_release(Version);
}

inline uchar
inXDataBase::Page::version_revision() const {
        return inXdb::version_revision(Version);
}

inline FilePos
inXDataBase::Page::bytes() const {
        return Bytes;
}

inline FilePos
inXDataBase::Page::number() const {
        return Number;
}

inline FilePos
inXDataBase::Page::revision() const {
        return Revision;
}

inline void
inXDataBase::Page::Expanded(const FilePos bytes) {
        Bytes += bytes;
}

inline void
inXDataBase::Page::Page_size(const FilePos bytes) {
        Bytes = bytes;
}

inline void
inXDataBase::Page::Revised() {
        if (! ++Revision) {
                Revision = 1;
        }
}

inline
inXDataBase::Page::~Page() {
        ;
}

inline FilePos
inXDataBase::FileLocation::page_chunk_size() const {
        return Page_Chunk_Size;
}

inline FilePos
inXDataBase::FileLocation::file_header_offset() const {
        return File_Header_Offset;
}

inline FilePos
inXDataBase::FileLocation::file_header_offset(const FilePos offset) {
        return File_Header_Offset = offset;
}

inline
inXDataBase::FileLocation::FileLocation(const FilePos page_chunk_size)
        : Page(PageIsFileHeader, Page::FileLocation, page_chunk_size),
                Page_Chunk_Size(page_chunk_size),
                File_Header_Offset(page_chunk_size) {
        ;
}

inline FilePos
inXDataBase::FileHeader::file_table_offset() const {
        return File_Table_Offset;
}

inline FilePos
inXDataBase::FileHeader::page_table_offset() const {
        return Page_Table_Offset;
}

inline FilePos
inXDataBase::FileHeader::empty_page_table_offset() const {
        return Empty_Page_Table_Offset;
}

inline
inXDataBase::FileHeader::FileHeader(const FilePos page_chunk_size)
        : Page(PageIsFileHeader, Page::FileHeader, page_chunk_size),
                File_Table_Offset(page_chunk_size * 2),
                Page_Table_Offset(page_chunk_size * 3),
                Empty_Page_Table_Offset(page_chunk_size * 4) {
        ;
}

inline FilePos
inXDataBase::FileTable::files() const {
        return Files;
}

inline void
inXDataBase::FileTable::expanded(const FilePos bytes) {
        Page::Expanded(bytes);
}

inline
inXDataBase::FileTable::FileTable(const FilePos page_chunk_size,
                                                                                                const std::string header_file_name
                                                                                        )
        : Page(PageIsFileTable, Page::FileTable, page_chunk_size),
                Files(1) {

        do { if (! (header_file_name.length() < inXDBNameLength)) { throw inXServices::inXException("Require", "header_file_name.length() < inXDBNameLength", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 238 ); } } while (0);

        reinterpret_cast<FileInfo *>(File_Info)->Type = inXDataBase::HeaderFile;
        reinterpret_cast<FileInfo *>(File_Info)->Page_Size = page_chunk_size;
        reinterpret_cast<FileInfo *>(File_Info)->Name_Bytes
                = header_file_name.length() + 1;
        strcpy(reinterpret_cast<FileInfo *>(File_Info)->Name,
                                header_file_name.c_str()
                        );
}

inline bool
inXDataBase::PageInfo::is_removed() const {
        return ! Bytes;
}

inline bool
inXDataBase::PageInfo::is_present() const {
        return Bytes;
}

inline void
inXDataBase::PageInfo::remove() {
        Offset = Bytes = 0;
}

inline
inXDataBase::PageInfo::PageInfo() {
        ;
}

inline
inXDataBase::PageInfo::PageInfo(const FilePos file, const FilePos offset,
                                                                                                const FilePos bytes
                                                                                 )
        : File_Number(file),
                Offset(offset),
                Bytes(bytes) {
        ;
}

inline
inXDataBase::PageInfo::~PageInfo() {
        ;
}

inline FilePos
inXDataBase::PageTable::files() const {
        return Files;
}

inline bool
inXDataBase::PageTable::room_for_pages(const FilePos total_new_pages,
                                                                                                                const FilePos needs
                                                                                                  ) const {
        return (bytes() - needs
                                - sizeof(*this)
                                - (sizeof(FilePos) * Files)
                                - (sizeof(PageInfo) * Pages)
                         ) >= (total_new_pages * sizeof(PageInfo));
}

inline FilePos
inXDataBase::PageTable::needs_pages(const FilePos total_new_pages,
                                                                                                        const FilePos needs
                                                                                          ) const {
        return (total_new_pages * sizeof(PageInfo))
                                - (bytes() - needs
                                                - sizeof(*this)
                                                - (sizeof(FilePos) * Files)
                                                - (sizeof(PageInfo) * Pages)
                                  );
}

inline bool
inXDataBase::PageTable::room_for_files(const FilePos total_new_files,
                                                                                                                const FilePos needs
                                                                                                  ) const {
        return (bytes() - needs
                                - sizeof(*this)
                                - (sizeof(FilePos) * Files)
                                - (sizeof(PageInfo) * Pages)
                         ) >= (total_new_files * sizeof(FilePos));
}

inline FilePos
inXDataBase::PageTable::needs_files(const FilePos total_new_files,
                                                                                                        const FilePos needs
                                                                                          ) const {
        return (total_new_files * sizeof(FilePos))
                                - (bytes() - needs
                                                - sizeof(*this)
                                                - (sizeof(FilePos) * Files)
                                                - (sizeof(PageInfo) * Pages)
                                  );
}

inline void
inXDataBase::PageTable::expanded(const FilePos bytes) {
        Page::Expanded(bytes);
}

inline const FilePos *
inXDataBase::PageTable::files_pages() const {
        return reinterpret_cast<const FilePos *>(Page_Data);
}

inline FilePos *
inXDataBase::PageTable::files_pages() {
        return reinterpret_cast<FilePos *>(Page_Data);
}

inline FilePos
inXDataBase::PageTable::file_pages(const uint index) const {
        do { if (! (index < Files)) { throw inXServices::inXException("Ensure", "index < Files", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 352 ); } } while (0);

        return reinterpret_cast<const FilePos *>(Page_Data)[index];
}

inline const inXDataBase::PageInfo &
inXDataBase::PageTable::file_page(const uint file, const uint page) const {
        do { if (! (file < Files)) { throw inXServices::inXException("Ensure", "file < Files", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 359 ); } } while (0);
        do { if (! (page <= reinterpret_cast<const FilePos *>(Page_Data)[file])) { throw inXServices::inXException("Ensure", "page <= reinterpret_cast<const FilePos *>(Page_Data)[file]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 360 ); } } while (0);

        return
                reinterpret_cast<const PageInfo *>(Page_Data + (sizeof(FilePos) * Files))
                                [Index(file, page)];
}

inline
inXDataBase::PageTable::PageTable(const FileType type, const PageType page_type,
                                                                                                const FilePos minimum_page_size,
                                                                                                const FilePos files
                                                                                        )
        : Page(type, page_type, minimum_page_size),
                Pages(0),
                Files(files) {
        ;
}

inline
inXDataBase::PageTable::PageTable(const FilePos minimum_page_size,
                                                                                                const FilePos files
                                                                                        )
        : Page(PageIsPageTable, Page::PageTable, minimum_page_size),
                Pages(0),
                Files(files) {
        ;
}

inline FilePos
inXDataBase::EmptyPageTable::not_found() {
        return static_cast<FilePos>(~0);
}

inline void
inXDataBase::EmptyPageTable::dump(std::ostream &stream) const {
        PageTable::dump(stream);
}

inline
inXDataBase::EmptyPageTable::EmptyPageTable(const FilePos minimum_page_size,
                                                                                                                        const FilePos files
                                                                                                                 )
        : PageTable(PageIsEmptyPageTable, Page::EmptyPageTable, minimum_page_size,
                                                files
                                        ) {
        ;
}

inline void
inXDataBase::DataPage::Used_size(const FilePos bytes) {
        Used = bytes;
}

inline FilePos
inXDataBase::DataPage::used() const {
        return Used;
}

inline uchar *
inXDataBase::DataPage::data() {
        return Page_Data;
}

inline const uchar *
inXDataBase::DataPage::data() const {
        return Page_Data;
}

inline
inXDataBase::DataPage::DataPage(const FileType file_type, const PageType type,
                                                                                        const FilePos number, const FilePos bytes,
                                                                                        const FilePos used
                                                                                 )
        : Page(file_type, type, number, bytes, 0),
                Used(used) {
        ;
}

inline
inXDataBase::DataPage::DataPage(const FilePos number, const FilePos bytes,
                                                                                        const FilePos used
                                                                                 )
        : Page(PageIsData, Page::DataPage, number, bytes, 0),
                Used(used) {
        ;
}

inline inXDataBase::BTreePage *
inXDataBase::Datum::Tree_header() {
        do { if (! (Type == BTreeHeaderType)) { throw inXServices::inXException("Require", "Type == BTreeHeaderType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 449 ); } } while (0);






        return Modified
                                ? reinterpret_cast<BTreePage *>(Modified)
                                : Modifiable_tree_header();

}

inline const inXDataBase::BTreePage *
inXDataBase::Datum::Tree_header() const {
        do { if (! (Type == BTreeHeaderType)) { throw inXServices::inXException("Require", "Type == BTreeHeaderType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 464 ); } } while (0);





        return Modified
                                ? reinterpret_cast<BTreePage *>(Modified)
                                : BTree_Header;

}

inline inXDataBase::BTreeNodePage *
inXDataBase::Datum::Tree_node() {
        do { if (! (Type == BTreeNodeType)) { throw inXServices::inXException("Require", "Type == BTreeNodeType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 478 ); } } while (0);






        return Modified
                                ? reinterpret_cast<BTreeNodePage *>(Modified)
                                : Modifiable_tree_node();

}

inline const inXDataBase::BTreeNodePage *
inXDataBase::Datum::Tree_node() const {
        do { if (! (Type == BTreeNodeType)) { throw inXServices::inXException("Require", "Type == BTreeNodeType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 493 ); } } while (0);





        return Modified
                                ? reinterpret_cast<const BTreeNodePage *>(Modified)
                                : BTree_Node;

}

inline void
inXDataBase::Datum::Remap(const void *old_start, const void *old_end,
                                                                        const long offset
                                                                 ) {
        if (Data_Page >= old_start && Data_Page <= old_end) {
                Page_Buffer += offset;
        }
}

inline int
inXDataBase::Datum::compare(const Datum &datum) const {
        int c(static_cast<int>(File > datum.File)
                                - static_cast<int>(File < datum.File)
                  );
        if (! c) {
                c = static_cast<int>(Data_Page->number() > datum.Data_Page->number())
                                - static_cast<int>(Data_Page->number() < datum.Data_Page->number());
        }
        return c;
}

inline FilePos
inXDataBase::Datum::file() const {
        return File;
}

inline FilePos
inXDataBase::Datum::offset() const {
        return Offset;
}

inline FilePos
inXDataBase::Datum::number() const {
        do { if (! (Data_Page)) { throw inXServices::inXException("Require", "Data_Page", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 538 ); } } while (0);

        return Data_Page->number();
}

inline FilePos
inXDataBase::Datum::page_bytes() const {
        return Data_Page->bytes();
}

inline FilePos
inXDataBase::Datum::data_bytes() const {
        return Bytes;
}

inline FilePos
inXDataBase::Datum::used() const {
        return Used;
}

inline FilePos
inXDataBase::Datum::new_page_bytes() const {
        return Type == DataType ? (Bytes + sizeof(DataPage)) : Bytes;
}

inline bool
inXDataBase::Datum::is_new() const {
        return ! Data_Page->revision();
}

inline bool
inXDataBase::Datum::is_not_new() const {
        return Data_Page->revision();
}

inline bool
inXDataBase::Datum::is_modified() const {
        return Modified;
}

inline bool
inXDataBase::Datum::is_not_modified() const {
        return ! Modified && is_not_new();
}

inline bool
inXDataBase::Datum::is_removed() const {
        return Removed;
}

inline bool
inXDataBase::Datum::is_not_removed() const {
        return ! Removed;
}

inline const uchar *
inXDataBase::Datum::page() const {
        do { if (! (Type == DataType)) { throw inXServices::inXException("Require", "Type == DataType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 595 ); } } while (0);
        do { if (! (Data_Page)) { throw inXServices::inXException("Require", "Data_Page", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 596 ); } } while (0);

        return static_cast<const DataPage *>(Data_Page)->data();
}

inline const uchar *
inXDataBase::Datum::data() const {
        do { if (! (Type == DataType)) { throw inXServices::inXException("Require", "Type == DataType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 603 ); } } while (0);





        return Modified ? Modified : page();

}

inline uchar *
inXDataBase::Datum::data() {
        do { if (! (Type == DataType)) { throw inXServices::inXException("Require", "Type == DataType", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 615 ); } } while (0);

        return Modified ? Modified : Modifiable_data();
}

inline uchar *
inXDataBase::Datum::resize(const FilePos bytes,
                                                                                const FilePos minimum_page_size
                                                                  ) {
        if (Used != bytes) {

                return Resize(bytes, minimum_page_size);
        }
        return data();
}

inline void
inXDataBase::Datum::remove() {
        Removed = true;
}

inline
inXDataBase::Datum::Datum(const FilePos file, const FilePos number,
                                                                        const FilePos bytes, const FilePos minimum_page_size
                                                                 )
        : Delete_Page(true),
                Page_Buffer(0),
                Type(DataType),
                File(file),
                Offset(0),
                Used(bytes),
                Removed(false),
                Modified(0),
                Modified_Page_Buffer(0) {
        Bytes
                = ((Used + sizeof(*Data_Page) + minimum_page_size - 1)
                                / minimum_page_size
                  ) * minimum_page_size;
        memset(Page_Buffer = new uchar[Bytes], 0, Bytes);
        new(Page_Buffer) DataPage(number, Bytes, Used);
        Bytes -= sizeof(*Data_Page);



        memset(Modified = new uchar[Bytes], 0, Bytes);

}

inline
inXDataBase::Datum::Datum(const FilePos file, const FilePos number,
                                                                        const FilePos node_page_size
                                                                 )
        : Delete_Page(true),
                Page_Buffer(0),
                Type(BTreeNodeType),
                File(file),
                Offset(0),
                Bytes(node_page_size),
                Used(node_page_size - sizeof(DataPage)),
                Removed(false),
                Modified(0),
                Modified_Page_Buffer(0) {
        memset(Page_Buffer = new uchar[Bytes], 0, Bytes);
        new(Page_Buffer) BTreeNodePage(number, Bytes, Used);





        memcpy(Modified = new uchar[Bytes], Page_Buffer, Bytes);

}

inline
inXDataBase::Datum::Datum(const FilePos file, const FilePos number)
        : Delete_Page(true),
                Page_Buffer(new uchar[sizeof(DataPage)]),
                Type(DataType),
                File(file),
                Bytes(0),
                Used(0),
                Removed(false),
                Modified(0),



                Modified_Page_Buffer(0) {
        new(Page_Buffer) DataPage(number, 0, 0);
}

inline
inXDataBase::Datum::Datum(const FilePos file, const PageInfo &info,
                                                                        DataPage *data_page
                                                                 )
        : Delete_Page(! data_page->revision()),
                Data_Page(data_page),
                Type(DataType),
                File(file),
                Offset(info.Offset),
                Bytes(info.Bytes - sizeof(*data_page)),
                Used(data_page->used()),
                Removed(false),
                Modified(0),



                Modified_Page_Buffer(0) {
        ;
}

inline
inXDataBase::Datum::Datum(const FilePos file, const FilePos offset,
                                                                        BTreePage *tree_page
                                                                 )
        : Delete_Page(false),
                BTree_Header(tree_page),
                Type(BTreeHeaderType),
                File(file),
                Offset(offset),
                Bytes(tree_page->bytes()),
                Used(Bytes),
                Removed(false),
                Modified(0),
                Current_BTree_Header(tree_page),
                Modified_Page_Buffer(0) {
        ;
}

inline
inXDataBase::Datum::Datum(const FilePos file, const PageInfo &info,
                                                                        BTreeNodePage *tree_node
                                                                 )
        : Delete_Page(! tree_node->revision()),
                BTree_Node(tree_node),
                Type(BTreeNodeType),
                File(file),
                Offset(info.Offset),
                Bytes(info.Bytes),
                Used(Bytes - sizeof(DataPage)),
                Removed(false),
                Modified(0),
                Current_BTree_Node(tree_node),
                Modified_Page_Buffer(0) {
        ;
}

inline
inXDataBase::Datum::~Datum() {
        if (Delete_Page) {
                delete[] Page_Buffer;
        }
        delete[] Modified;
        delete[] Modified_Page_Buffer;
}

inline int
inXDataBase::Transaction::DataFileInfo::compare(const DataFileInfo &index
                                                                                                                          ) const {
        return static_cast<int>(file > index.file)
                                - static_cast<int>(file < index.file);
}

inline void
inXDataBase::Transaction::unduplicate() {
        ++Number;
}

inline int
inXDataBase::Transaction::compare(const Transaction &trx) const {
        int c(Data_Base.name().compare(trx.Data_Base.name()));
        if (! c) {
                if (! (c = Name.compare(trx.Name))) {
                        c = static_cast<int>(Number > trx.Number)
                                        - static_cast<int>(Number < trx.Number);
                }
        }
        return c;
}

inline const std::string &
inXDataBase::Transaction::name() const {
        return Name;
}

inline ulong
inXDataBase::Transaction::number() const {
        return Number;
}

inline const inXDataBase::Datum *
inXDataBase::Transaction::page(const FilePos file, const FilePos number,
                                                                                        const bool wait_for_lock
                                                                                )
        throw(inXDBException) {

        return Page(file, number, true, wait_for_lock);
}

inline inXDataBase::Datum *
inXDataBase::Transaction::modifiable_page(const FilePos file,
                                                                                                                        const FilePos number,
                                                                                                                        const bool wait_for_lock
                                                                                                          )
        throw(inXDBException) {

        return Page(file, number, false, wait_for_lock);
}

inline bool
inXDataBase::Transaction::find(BTree &tree, const void *buffer)
        throw(inXDBException) {
        return tree.Find(*this, buffer);
}

inline bool
inXDataBase::Transaction::first(BTree &tree) throw(inXDBException) {
        return tree.First(*this);
}

inline bool
inXDataBase::Transaction::last(BTree &tree) throw(inXDBException) {
        return tree.Last(*this);
}

inline bool
inXDataBase::Transaction::next(BTree &tree) throw(inXDBException) {
        return tree.Next(*this);
}

inline bool
inXDataBase::Transaction::previous(BTree &tree) throw(inXDBException) {
        return tree.Previous(*this);
}

inline bool
inXDataBase::Transaction::nth(BTree &tree, const FilePos index)
        throw(inXDBException) {
        return tree.Nth(*this, index);
}

bool
inXDataBase::Transaction::set_current(BTree &tree,
                                                                                                        const BTreePosition &position
                                                                                                 )
        throw(inXDBException) {
        return tree.Set_current(*this, position);
}

inline bool
inXDataBase::Transaction::get_key(BTree &tree, void *buffer)
        throw(inXDBException) {
        return tree.Get_key(buffer);
}

inline bool
inXDataBase::Transaction::get_key(BTree &tree, void *buffer,
                                                                                                const size_t buffer_length
                                                                                        )
        throw(inXDBException) {
        return tree.Get_key(buffer, buffer_length);
}

inline FilePos
inXDataBase::Transaction::keys(const BTree &tree) const {
        return tree.keys();
}

inline FilePos
inXDataBase::Transaction::keys(BTree &tree) {
        return tree.Keys(*this);
}

inline uchar
inXDataBase::version_major() const {
        return inXdb::version_major(Version);
}

inline uchar
inXDataBase::version_minor() const {
        return inXdb::version_minor(Version);
}

inline uchar
inXDataBase::version_release() const {
        return inXdb::version_release(Version);
}

inline uchar
inXDataBase::version_revision() const {
        return inXdb::version_revision(Version);
}

inline const std::string &
inXDataBase::name() const {
        return Name;
}

inline const inXDataBase::Reason
inXDataBase::state() const {
        return State;
}

inline const std::string
inXDataBase::reason() const {
        return Reason_Description[State];
}

inline const FilePos
inXDataBase::file_number() const {
        return File_Number;
}

inline const FilePos
inXDataBase::page_number() const {
        return Page_Number;
}

inline void
inXDataBase::set_state_to_okay() {
        State = Okay;
        File_Number = Page_Number = 0;
}

inline bool
inXDataBase::is_open() const {
        return MmapFile::is_open();
}

inline bool
inXDataBase::is_closed() const {
        return MmapFile::is_closed();
}

inline void
inXDataBase::open(const bool writable) throw(inXDBException) {
        do { if (! (Name.length())) { throw inXServices::inXException("Require", "Name.length()", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 950 ); } } while (0);

        open(Name, writable);
}

inline size_t
inXDB::DBKey::sizeof_name() {
        return inXDB_Name_Length;
}

inline const char *
inXDB::DBKey::DB_name() {
        return DB_Name;
}

inline const inXDataBase::Reason
inXDB::state() const {
        return inXDataBase::state();
}

inline const std::string
inXDB::reason() const {
        return inXDataBase::reason();
}

inline const FilePos
inXDB::file_number() const {
        return inXDataBase::file_number();
}

inline const FilePos
inXDB::page_number() const {
        return inXDataBase::page_number();
}

inline void
inXDB::set_state_to_okay() {
        inXDataBase::set_state_to_okay();
}

inline inXDB::OID &
inXDB::DBKey::ID() {
        return Object_ID;
}

inline FilePos
inXDB::DBKey::file() {
        return File;
}

inline
inXDB::DBKey::DBKey(const char *DB_name)
        : Object_ID(Null_OID),
                File(0) {
        strncpy(DB_Name, DB_name, sizeof(DB_Name));
        DB_Name[sizeof(DB_Name) - 1] = 0;
}

inline
inXDB::DBKey::DBKey(const char *DB_name, const OID &object_ID,
                                                        const FilePos file
                                                 )
        : Object_ID(object_ID),
                File(file) {
        strncpy(DB_Name, DB_name, sizeof(DB_Name));
        DB_Name[sizeof(DB_Name) - 1] = 0;
}

inline
inXDB::DBKey::DBKey()
        : Object_ID(Null_OID),
                File(0) {
        memset(DB_Name, 0, sizeof(DB_Name));
}

inline
inXDB::DBKey::~DBKey() {
        ;
}

inline size_t
inXDB::DB::TypeKey::sizeof_name() {
        return inXDB_Name_Length;
}

inline const char *
inXDB::DB::TypeKey::type_name() {
        return Type_Name;
}

inline const char *
inXDB::DB::TypeKey::index_name() {
        return Index_Name;
}

inline inXDB::OID &
inXDB::DB::TypeKey::ID() {
        return Object_ID;
}

inline FilePos
inXDB::DB::TypeKey::file() {
        return File;
}

inline
inXDB::DB::TypeKey::TypeKey(const char *type_name)
        : Object_ID(Null_OID),
                File(0) {
        strncpy(Type_Name, type_name, sizeof(Type_Name));
        Type_Name[sizeof(Type_Name) - 1] = 0;
        memset(Index_Name, 0, sizeof(Index_Name));
}

inline
inXDB::DB::TypeKey::TypeKey(const char *type_name, const char *index_name)
        : Object_ID(Null_OID),
                File(0) {
        strncpy(Type_Name, type_name, sizeof(Type_Name));
        Type_Name[sizeof(Type_Name) - 1] = 0;
        strncpy(Index_Name, index_name, sizeof(Index_Name));
        Index_Name[sizeof(Index_Name) - 1] = 0;
}

inline
inXDB::DB::TypeKey::TypeKey(const char *type_name, const OID &object_ID,
                                                                                const FilePos file
                                                                        )
        : Object_ID(object_ID),
                File(file) {
        strncpy(Type_Name, type_name, sizeof(Type_Name));
        Type_Name[sizeof(Type_Name) - 1] = 0;
        memset(Index_Name, 0, sizeof(Index_Name));
}

inline
inXDB::DB::TypeKey::TypeKey(const char *type_name, const char *index_name,
                                                                                const OID &object_ID, const FilePos file
                                                                        )
        : Object_ID(object_ID),
                File(file) {
        strncpy(Type_Name, type_name, sizeof(Type_Name));
        Type_Name[sizeof(Type_Name) - 1] = 0;
        strncpy(Index_Name, index_name, sizeof(Index_Name));
        Index_Name[sizeof(Index_Name) - 1] = 0;
}

inline
inXDB::DB::TypeKey::TypeKey()
        : Object_ID(Null_OID),
                File(0) {
        memset(Type_Name, 0, sizeof(Type_Name));
        memset(Index_Name, 0, sizeof(Index_Name));
        *Type_Name = *Index_Name = 0;
}

inline
inXDB::DB::TypeKey::~TypeKey() {
        ;
}
# 1128 "../inXDB/DB/inXDB.i"
inline size_t
inXDB::DB::Memory_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap) + Heap_Length;
}

inline size_t
inXDB::DB::Heap_length(const size_t record_length) {
        return record_length - sizeof(*DBuffer.Record)
                                + sizeof(DBuffer.Record->Heap);
}

inline size_t
inXDB::DB::Record_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap)
                                        + DBuffer.Record->Description_Length;
}
# 1159 "../inXDB/DB/inXDB.i"
inline void
inXDB::DB::add(OID &object_ID,
                                        const void *record, const FilePos bytes
                                  ) throw(inXDBException) {
        Trx.Add(object_ID,
                          DBuffer.Record->Data_File, record, bytes
                         );
}
# 1216 "../inXDB/DB/inXDB.i"
inline void
inXDB::DB::put(OID &object_ID,
                                        const void *record, const FilePos bytes
                                  ) throw(inXDBException) {
        Trx.Put(object_ID,
                          record, bytes
                         );
}

inline void
inXDB::DB::remove(const OID & ) throw(inXDBException) {
        abort();






}

inline const uchar *
inXDB::DB::Get(OID &object_ID) throw(inXDBException) {
        return Trx.Get(object_ID);
}

inline bool
inXDB::DB::is_in_data_base() {
        return Object_ID.is_valid();
}

inline bool
inXDB::DB::is_not_in_data_base() {
        return Object_ID.is_invalid();
}

inline inXDB &
inXDB::DB::data_base() {
        return Data_Base;
}

inline const char *
inXDB::DB::name() {
        return DBuffer.Record->Name;
}

inline const inXDB::OID &
inXDB::DB::ID() {
        return Object_ID;
}

inline FilePos
inXDB::DB::data_file() {
        return DBuffer.Record->Data_File;
}

inline size_t
inXDB::DB::description_length() {
        return DBuffer.Record->Description_Length;
}

inline const std::string
inXDB::DB::description() {
        return std::string(DBuffer.Record->Heap);
}

inline inXDB::Type *
inXDB::DB::type(const std::string &name) throw(inXDBException) {
        return Trx.type(*this, name);
}

inline inXDB::Type *
inXDB::DB::type(OID &object_ID) throw(inXDBException) {
        return Trx.type(*this, object_ID);
}

inline int
inXDB::DB::compare(const DB &db) const {
        return Name.compare(db.Name);
}

inline size_t
inXDB::ObjectList::Memory_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Object_ID)
                                + (Objects_Allocated * sizeof(DBuffer.Record->Object_ID));
}

inline size_t
inXDB::ObjectList::Heap_length(const size_t objects) {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Object_ID)
                                + (objects * sizeof(DBuffer.Record->Object_ID));
}

inline size_t
inXDB::ObjectList::Record_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Object_ID)
                                + (DBuffer.Record->Objects * sizeof(DBuffer.Record->Object_ID));
}

inline bool
inXDB::ObjectList::is_in_data_base() {
        return Object_ID.is_valid();
}

inline bool
inXDB::ObjectList::is_not_in_data_base() {
        return Object_ID.is_invalid();
}

inline const inXDB::OID &
inXDB::ObjectList::ID() {
        return Object_ID;
}

inline Unsigned
inXDB::ObjectList::objects() {
        return DBuffer.Record
                                ? DBuffer.Record->Objects
                                : 0;
}

inline size_t
inXDB::Type::Memory_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap)
                                + Heap_Length;
}

inline size_t
inXDB::Type::Heap_length(const size_t record_length) {
        return record_length - sizeof(*DBuffer.Record)
                                + sizeof(DBuffer.Record->Heap);
}

inline size_t
inXDB::Type::Record_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap)
                                + DBuffer.Record->Attribute_List_Length
                                + DBuffer.Record->Super_Class_List_Length
                                + DBuffer.Record->Sub_Class_List_Length
                                + DBuffer.Record->Secondary_Indeces_Length
                                + DBuffer.Record->Reference_Attribute_List_Length
                                + DBuffer.Record->Reference_Sub_Attribute_List_Length
                                + DBuffer.Record->Reference_Attribute_Size_List_Length
                                + DBuffer.Record->Description_Length;
}
# 1370 "../inXDB/DB/inXDB.i"
inline bool
inXDB::Type::is_in_data_base() {
        return Object_ID.is_valid();
}

inline bool
inXDB::Type::is_not_in_data_base() {
        return Object_ID.is_invalid();
}

inline inXDB::DB &
inXDB::Type::data_base() {
        return Data_Base;
}

inline FilePos
inXDB::Type::file() {
        return DBuffer.Record->File;
}

inline const char *
inXDB::Type::name() {
        return DBuffer.Record->Name;
}

inline const inXDB::OID &
inXDB::Type::ID() {
        return Object_ID;
}

inline inXDB::ClassType
inXDB::Type::class_type() {
        return inXDB::ClassType(DBuffer.Record->Class_Type);
}

inline inXDB::ClassType
inXDB::Type::class_type(const ClassType type) {
        return inXDB::ClassType(DBuffer.Record->Class_Type = long(type));
}

inline bool
inXDB::Type::persistent() {
        return DBuffer.Record->Persistent;
}

inline bool
inXDB::Type::not_persistent() {
        return ! DBuffer.Record->Persistent;
}

inline Unsigned
inXDB::Type::bytes() {
        return DBuffer.Record->Bytes;
}

inline SubclassID
inXDB::Type::subclass_ID() {
        return DBuffer.Record->Subclass_ID;
}

inline SubclassID
inXDB::Type::subclass_ID(const SubclassID sid) {
        return DBuffer.Record->Subclass_ID = sid;
}

inline bool
inXDB::Type::this_has_primary_index() {
        return DBuffer.Record->Primary_Index.is_valid();
}

inline bool
inXDB::Type::this_has_no_primary_index() {
        return DBuffer.Record->Primary_Index.is_invalid();
}

inline inXDB::TypeIndex *
inXDB::Type::this_primary_index() {
        return this_has_primary_index()
                                ? Data_Base.Trx.indece(*this, DBuffer.Record->Primary_Index)
                                : 0;
}

Unsigned
inXDB::Type::this_secondary_indeces() {
        return DBuffer.Record->Secondary_Indeces_Length
                                ? *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                                                        + DBuffer.Record->Attribute_List_Length
                                                                                                        + DBuffer.Record->Super_Class_List_Length
                                                                                                        + DBuffer.Record->Sub_Class_List_Length
                                                                                                                  )
                                : 0;
}

inline Unsigned
inXDB::Type::reference_attributes() {
        return DBuffer.Record->Reference_Attribute_List_Length
                                ? *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                                                + DBuffer.Record->Attribute_List_Length
                                                                                                + DBuffer.Record->Super_Class_List_Length
                                                                                                + DBuffer.Record->Sub_Class_List_Length
                                                                                                + DBuffer.Record->Secondary_Indeces_Length
                                                                                                                  )
                                : 0;
}

inline Unsigned
inXDB::Type::reference_sub_attributes() {
        return DBuffer.Record->Reference_Sub_Attribute_List_Length
                                ? *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                                + DBuffer.Record->Attribute_List_Length
                                                                                + DBuffer.Record->Super_Class_List_Length
                                                                                + DBuffer.Record->Sub_Class_List_Length
                                                                                + DBuffer.Record->Secondary_Indeces_Length
                                                                                + DBuffer.Record->Reference_Attribute_List_Length
                                                                                                                  )
                                : 0;
}

inline Unsigned
inXDB::Type::reference_attribute_sizes() {
        return DBuffer.Record->Reference_Attribute_Size_List_Length
                        ? *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                        + DBuffer.Record->Attribute_List_Length
                                                                        + DBuffer.Record->Super_Class_List_Length
                                                                        + DBuffer.Record->Sub_Class_List_Length
                                                                        + DBuffer.Record->Secondary_Indeces_Length
                                                                        + DBuffer.Record->Reference_Attribute_List_Length
                                                                        + DBuffer.Record->Reference_Sub_Attribute_List_Length
                                                                                                          )
                        : 0;
}

inline bool
inXDB::Type::is_subclassed_ID() {
        return DBuffer.Record->Subclass_ID;
}

inline size_t
inXDB::Type::description_length() {
        return DBuffer.Record->Description_Length;
}

inline const std::string
inXDB::Type::description() {
        return std::string(DBuffer.Record->Heap
                                                                + DBuffer.Record->Attribute_List_Length
                                                                + DBuffer.Record->Super_Class_List_Length
                                                                + DBuffer.Record->Sub_Class_List_Length
                                                                + DBuffer.Record->Secondary_Indeces_Length
                                                                + DBuffer.Record->Reference_Attribute_List_Length
                                                                + DBuffer.Record->Reference_Sub_Attribute_List_Length
                                                                + DBuffer.Record->Reference_Attribute_Size_List_Length
                                                   );
}

inline size_t
inXDB::TypeAttribute::Memory_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap)
                                + Heap_Length;
}

inline size_t
inXDB::TypeAttribute::Heap_length(const size_t record_length) {
        return record_length - sizeof(*DBuffer.Record)
                                + sizeof(DBuffer.Record->Heap);
}

inline size_t
inXDB::TypeAttribute::Record_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap)
                                + DBuffer.Record->Choice_List_Length
                                + DBuffer.Record->Choice_Value_List_Length
                                + DBuffer.Record->Choice_Key_Value_List_Length
                                + DBuffer.Record->SubclassID_List_Length
                                + DBuffer.Record->SubclassID_Value_List_Length
                                + DBuffer.Record->SubclassID_Type_List_Length
                                + DBuffer.Record->Default_Value_Length
                                + DBuffer.Record->Description_Length;
}

inline bool
inXDB::TypeAttribute::is_in_data_base() {
        return Object_ID.is_valid();
}

inline bool
inXDB::TypeAttribute::is_not_in_data_base() {
        return Object_ID.is_invalid();
}

inline inXDB::Type &
inXDB::TypeAttribute::DB_type() {
        return *DB_Type;
}

inline inXDB::DB &
inXDB::TypeAttribute::data_base() {
        return DB_Type->data_base();
}

inline const char *
inXDB::TypeAttribute::name() {
        return DBuffer.Record->Name;
}

inline const char *
inXDB::TypeAttribute::name(const std::string &new_name) {
        strncpy(DBuffer.Record->Name, new_name.c_str(),
                                        sizeof(DBuffer.Record->Name)
                         );
        DBuffer.Record->Name[sizeof(DBuffer.Record->Name) - 1] = 0;

        return DBuffer.Record->Name;
}

inline const inXDB::OID &
inXDB::TypeAttribute::ID() {
        return Object_ID;
}

inline inXDB::Type *
inXDB::TypeAttribute::member_of() {
        return Data_Base.type(DBuffer.Record->Member_of_Type);
}

inline inXDB::Type *
inXDB::TypeAttribute::type_of() {
        return Data_Base.type(DBuffer.Record->Type_Of);
}

inline inXDB::Type *
inXDB::TypeAttribute::of() {
        return DBuffer.Record->Of.is_valid()
                                ? Data_Base.type(DBuffer.Record->Of)
                                : 0;
}

inline Unsigned
inXDB::TypeAttribute::bytes() {
        return DBuffer.Record->Bytes;
}

inline inXDB::TypeAttribute::LabelType
inXDB::TypeAttribute::label_type() {
        return inXDB::TypeAttribute::LabelType(DBuffer.Record->Label_Type);
}

inline bool
inXDB::TypeAttribute::show_label() {
        return DBuffer.Record->Label_Type != NoLabel;
}

inline bool
inXDB::TypeAttribute::dont_show_label() {
        return ! DBuffer.Record->Label_Type == NoLabel;
}

inline bool
inXDB::TypeAttribute::empty_is_OK() {
        return DBuffer.Record->Empty_OK;
}

inline bool
inXDB::TypeAttribute::empty_is_not_OK() {
        return ! DBuffer.Record->Empty_OK;
}

inline Unsigned
inXDB::TypeAttribute::entry_characters() {
        return DBuffer.Record->Entry_Characters;
}

inline double
inXDB::TypeAttribute::minimum() {
        return DBuffer.Record->Minimum;
}

inline double
inXDB::TypeAttribute::maximum() {
        return DBuffer.Record->Maximum;
}

inline long
inXDB::TypeAttribute::long_minimum() {
        return long(DBuffer.Record->Minimum);
}

inline long
inXDB::TypeAttribute::long_maximum() {
        return long(DBuffer.Record->Maximum);
}

inline uchar
inXDB::TypeAttribute::layout_column() {
        return DBuffer.Record->Layout_Column;
}

inline inXDB::TypeAttribute::LayoutConstraint
inXDB::TypeAttribute::layout_constraint() {
        return inXDB::TypeAttribute::LayoutConstraint(DBuffer.Record->Layout);
}

inline Unsigned
inXDB::TypeAttribute::lines() {
        return DBuffer.Record->Lines;
}

inline Unsigned
inXDB::TypeAttribute::choices() {
        return DBuffer.Record->Choice_List_Length
                                ? *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap)
                                : 0;
}

inline long
inXDB::TypeAttribute::value(const Unsigned index) {
        return *reinterpret_cast<long *>(DBuffer.Record->Heap
                                                                                                        + DBuffer.Record->Choice_List_Length
                                                                                                        + (sizeof(long) * index)
                                                                                          );
}

inline Unsigned
inXDB::TypeAttribute::subclass_IDs() {
        return DBuffer.Record->SubclassID_List_Length
                                ? *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                                        + DBuffer.Record->Choice_List_Length
                                                                                        + DBuffer.Record->Choice_Value_List_Length
                                                                                        + DBuffer.Record->Choice_Key_Value_List_Length
                                                                                                                  )
                                : 0;
}

inline Unsigned
inXDB::TypeAttribute::subclass_ID(const Unsigned index) {
        return *reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                                        + DBuffer.Record->Choice_List_Length
                                                                                        + DBuffer.Record->Choice_Value_List_Length
                                                                                        + DBuffer.Record->Choice_Key_Value_List_Length
                                                                                        + DBuffer.Record->SubclassID_List_Length
                                                                                        + (sizeof(Unsigned) * index)
                                                                                                        );
}

inline inXDB::Type *
inXDB::TypeAttribute::subclass_ID_type(const Unsigned index) {
        return Data_Base.Trx.type(*reinterpret_cast<OID *>(DBuffer.Record->Heap
                                                                                        + DBuffer.Record->Choice_List_Length
                                                                                        + DBuffer.Record->Choice_Value_List_Length
                                                                                        + DBuffer.Record->Choice_Key_Value_List_Length
                                                                                        + DBuffer.Record->SubclassID_List_Length
                                                                                        + DBuffer.Record->SubclassID_Value_List_Length
                                                                                        + (sizeof(OID) * index)
                                                                                                                                          )
                                                                         );
}

inline bool
inXDB::TypeAttribute::has_default() {
        return DBuffer.Record->Default_Value_Length;
}

inline const char *
inXDB::TypeAttribute::default_char(Unsigned *bytes) {
        if (bytes) {
                *bytes = DBuffer.Record->Default_Value_Length;
        }
        return DBuffer.Record->Default_Value_Length
                                ? DBuffer.Record->Heap
                                                + DBuffer.Record->Choice_List_Length
                                                + DBuffer.Record->Choice_Value_List_Length
                                                + DBuffer.Record->Choice_Key_Value_List_Length
                                                + DBuffer.Record->SubclassID_List_Length
                                                + DBuffer.Record->SubclassID_Value_List_Length
                                                + DBuffer.Record->SubclassID_Type_List_Length
                                : 0;
}

inline const Integer *
inXDB::TypeAttribute::default_integer() {
        return DBuffer.Record->Default_Value_Length
                                ? reinterpret_cast<Integer *>(DBuffer.Record->Heap
                                                                                + DBuffer.Record->Choice_List_Length
                                                                                + DBuffer.Record->Choice_Value_List_Length
                                                                                + DBuffer.Record->Choice_Key_Value_List_Length
                                                                                + DBuffer.Record->SubclassID_List_Length
                                                                                + DBuffer.Record->SubclassID_Value_List_Length
                                                                                + DBuffer.Record->SubclassID_Type_List_Length
                                                                                                                )
                                : 0;
}

inline const Unsigned *
inXDB::TypeAttribute::default_unsigned() {
        return DBuffer.Record->Default_Value_Length
                                ? reinterpret_cast<Unsigned *>(DBuffer.Record->Heap
                                                                                + DBuffer.Record->Choice_List_Length
                                                                                + DBuffer.Record->Choice_Value_List_Length
                                                                                + DBuffer.Record->Choice_Key_Value_List_Length
                                                                                + DBuffer.Record->SubclassID_List_Length
                                                                                + DBuffer.Record->SubclassID_Value_List_Length
                                                                                + DBuffer.Record->SubclassID_Type_List_Length
                                                                                                                 )
                                : 0;
}

inline const PreciseTime *
inXDB::TypeAttribute::default_precise_time() {
        return DBuffer.Record->Default_Value_Length
                                ? reinterpret_cast<PreciseTime *>(DBuffer.Record->Heap
                                                                                        + DBuffer.Record->Choice_List_Length
                                                                                        + DBuffer.Record->Choice_Value_List_Length
                                                                                        + DBuffer.Record->Choice_Key_Value_List_Length
                                                                                        + DBuffer.Record->SubclassID_List_Length
                                                                                        + DBuffer.Record->SubclassID_Value_List_Length
                                                                                        + DBuffer.Record->SubclassID_Type_List_Length
                                                                                                                         )
                                : 0;
}

inline const Real *
inXDB::TypeAttribute::default_real() {
        return DBuffer.Record->Default_Value_Length
                                ? reinterpret_cast<Real *>(DBuffer.Record->Heap
                                                                        + DBuffer.Record->Choice_List_Length
                                                                        + DBuffer.Record->Choice_Value_List_Length
                                                                        + DBuffer.Record->Choice_Key_Value_List_Length
                                                                        + DBuffer.Record->SubclassID_List_Length
                                                                        + DBuffer.Record->SubclassID_Value_List_Length
                                                                        + DBuffer.Record->SubclassID_Type_List_Length
                                                                                                        )
                                : 0;
}

inline const bool *
inXDB::TypeAttribute::default_bool() {
        return DBuffer.Record->Default_Value_Length
                                ? reinterpret_cast<bool *>(DBuffer.Record->Heap
                                                                        + DBuffer.Record->Choice_List_Length
                                                                        + DBuffer.Record->Choice_Value_List_Length
                                                                        + DBuffer.Record->Choice_Key_Value_List_Length
                                                                        + DBuffer.Record->SubclassID_List_Length
                                                                        + DBuffer.Record->SubclassID_Value_List_Length
                                                                        + DBuffer.Record->SubclassID_Type_List_Length
                                                                                                        )
                                : 0;
}

inline size_t
inXDB::TypeAttribute::description_length() {
        return DBuffer.Record->Description_Length;
}

inline const std::string
inXDB::TypeAttribute::description() {
        return std::string(DBuffer.Record->Heap
                                                                + DBuffer.Record->Choice_List_Length
                                                                + DBuffer.Record->Choice_Value_List_Length
                                                                + DBuffer.Record->Choice_Key_Value_List_Length
                                                                + DBuffer.Record->SubclassID_List_Length
                                                                + DBuffer.Record->SubclassID_Value_List_Length
                                                                + DBuffer.Record->SubclassID_Type_List_Length
                                                                + DBuffer.Record->Default_Value_Length
                                                   );
}

inline bool
inXDB::TypeAttribute::is_on_heap() {
        return Is_List || Is_Array || Is_String || Is_Text;
}

inline bool
inXDB::TypeAttribute::is_string() {
        return Is_String;
}

inline bool
inXDB::TypeAttribute::is_text() {
        return Is_Text;
}

inline bool
inXDB::TypeAttribute::is_fixed_length_string() {
        return Is_Fixed_Length_String;
}
# 1868 "../inXDB/DB/inXDB.i"
inline inXDB::TypeAttribute *
inXDB::Type::duplicate_attribute() {
        return DBuffer.Record->Duplicate_Attribute.is_valid()
                        ? new TypeAttribute(Data_Base, DBuffer.Record->Duplicate_Attribute)
                        : 0;
}

inline inXDB::TypeAttribute *
inXDB::Type::duplicate_attribute(TypeAttribute *a) {
        if (a) {
                DBuffer.Record->Duplicate_Attribute = a->ID();
        } else {
                DBuffer.Record->Duplicate_Attribute.invalidate();
        }
        return a;
}

inline bool
inXDB::Type::is_system_type() {
        return DBuffer.Record->Class_Type < UserType;
}

inline bool
inXDB::Type::is_not_system_type() {
        return DBuffer.Record->Class_Type >= UserType;
}

inline bool
inXDB::Type::has_no_references_from_other_OIDs() {
        return class_type() == UserType || super_classes();
}

inline bool
inXDB::Type::has_references_from_other_OIDs() {
        return class_type() != UserType && no_super_classes();
}

inline int
inXDB::Type::compare(const Type &type) const {
        int c(Data_Base.compare(type.Data_Base));
        if (! c) {
                c = Name.compare(type.Name);
        }
        return c;
}

inline void
inXDB::Type::add(OID &object_ID,
                                          const void *record, const FilePos bytes
                                         )
        throw(inXDBException) {
        Data_Base.Trx.Add(object_ID,
                                                   DBuffer.Record->File, record, bytes
                                                  );
}
# 1981 "../inXDB/DB/inXDB.i"
inline void
inXDB::Type::put(OID &object_ID,
                                          const void *record, const FilePos bytes
                                         ) throw(inXDBException) {
abort();



}

inline void
inXDB::Type::remove(const OID & ) throw(inXDBException) {
abort();






}

inline size_t
inXDB::TypeIndex::Memory_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap) + Heap_Length;
}

inline size_t
inXDB::TypeIndex::Heap_length(const size_t record_length) {
        return record_length - sizeof(*DBuffer.Record)
                                + sizeof(DBuffer.Record->Heap);
}

inline size_t
inXDB::TypeIndex::Record_length() {
        return sizeof(*DBuffer.Record) - sizeof(DBuffer.Record->Heap)
                                + DBuffer.Record->Attribute_List_Length
                                + DBuffer.Record->Sub_Attribute_List_Length
                                + DBuffer.Record->Sub_Sub_Attribute_List_Length
                                + DBuffer.Record->Description_Length;
}
# 2033 "../inXDB/DB/inXDB.i"
inline bool
inXDB::TypeIndex::is_in_data_base() {
        return Object_ID.is_valid();
}

inline bool
inXDB::TypeIndex::is_not_in_data_base() {
        return Object_ID.is_invalid();
}

inline inXDB::Type &
inXDB::TypeIndex::type() {
        return DB_Type;
}

inline FilePos
inXDB::TypeIndex::file() {
        return DBuffer.Record->File;
}

inline const char *
inXDB::TypeIndex::name() {
        return DBuffer.Record->Name;
}

inline const inXDB::OID &
inXDB::TypeIndex::ID() {
        return Object_ID;
}

inline Unsigned
inXDB::TypeIndex::maximum_bytes() {
        return DBuffer.Record->Maximum_Bytes;
}

inline bool
inXDB::TypeIndex::is_unique() {
        return DBuffer.Record->Unique;
}

inline bool
inXDB::TypeIndex::is_not_unique() {
        return ! DBuffer.Record->Unique;
}

inline size_t
inXDB::TypeIndex::description_length() {
        return DBuffer.Record->Description_Length;
}

inline const std::string
inXDB::TypeIndex::description() {
        return std::string(DBuffer.Record->Heap
                                                                + DBuffer.Record->Attribute_List_Length
                                                                + DBuffer.Record->Sub_Attribute_List_Length
                                                                + DBuffer.Record->Sub_Sub_Attribute_List_Length
                                                   );
}

inline Unsigned
inXDB::TypeIndex::buffer_required_to_hold_key() {
        return maximum_bytes() + 1;
}

inline int
inXDB::TypeIndex::compare(const TypeIndex &index) const {
        int c(DB_Type.compare(index.DB_Type));
        if (! c) {
                c = Name.compare(index.Name);
        }
        return c;
}
# 2174 "../inXDB/DB/inXDB.i"
inline bool
inXDB::TypeIndex::remove_current() throw(inXDBException) {
        abort();






}
# 2266 "../inXDB/DB/inXDB.i"
inline const std::string &
inXDB::name() const {
        return inXDataBase::name();
}

inline inXDB::Type *
DBObject::Type(inXdb::inXDB::inXDBTransaction *trx, const std::string &DB_name,
                                                const std::string &type_name
                                  )
        throw(inXDBException) {
        if (! DBType) {
                Get_type(trx, DB_name, type_name);
        }
        return DBType;
}

inline void
DBObject::Index(const std::string &DB_name, const std::string &type_name,
                                                const Unsigned indeces, const Unsigned index
                                        )
        throw(inXDBException) {
        if (! DBIndex || ! DBIndex[index]) {
                Get_index(DB_name, type_name, indeces, index);
        }
}

inline bool
DBObject::Never_been_read_from_DB() const {
        return ! DB_Record;
}

inline bool
DBObject::Is_modified() const {
        return Modified;
}

inline bool
DBObject::Is_not_modified() const {
        return ! Modified;
}

inline const uchar *
DBObject::Record() const {
        return Modified_Record ? Modified_Record : DB_Record;
}

inline uchar *
DBObject::Record() {
        do { if (! (Modified_Record)) { throw inXServices::inXException("Require", "Modified_Record", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2314 ); } } while (0);

        return Modified_Record;
}

inline void
DBObject::Copy_from_existing(const DBObject &existing) {
        Removed = existing.Removed;
        Object_ID = existing.Object_ID;
}
# 2412 "../inXDB/DB/inXDB.i"
inline bool
inXDB::OID::is_valid() const {
        return Unique;
}

inline bool
inXDB::OID::is_invalid() const {
        return ! Unique;
}

inline void
inXDB::OID::invalidate() {
        memset(this, 0, sizeof(*this));
}

inline FilePos
inXDB::OID::file() const {
        return File;
}

inline FilePos
inXDB::OID::page() const {
        return Page;
}

inline FilePos
inXDB::OID::unique() const {
        return Unique;
}

inline OIDVersion
inXDB::OID::version() const {
        return Version;
}

inline FilePos
inXDB::OID::bytes() const {
        return Bytes;
}

inline TimeStamp
inXDB::OID::last_modified() const {
        return Last_Modified;
}

inline size_t
inXDB::OID::necessary_size() {
        return sizeof(FilePos) + sizeof(FilePos) + sizeof(FilePos);
}

inline int
inXDB::OID::compare(const OID &ID) const {
        int c(static_cast<int>(File > ID.File)
                                - static_cast<int>(File < ID.File)
                  );
        if (! c) {
                c = static_cast<int>(Page > ID.Page)
                                - static_cast<int>(Page < ID.Page);
        }

        return c;
}

inline bool
inXDB::OID::operator ==(const OID &ID) const {
        return ! memcmp(this, &ID, necessary_size());
}

inline bool
inXDB::OID::operator !=(const OID &ID) const {
        return memcmp(this, &ID, necessary_size());
}

inline inXDB::OID &
inXDB::OID::operator =(const OID &ID) {
        memcpy(this, &ID, sizeof(*this));

        return *this;
}

inline
inXDB::OID::OID()
        : Unique(0) {
}

inline
inXDB::OID::OID(const FilePos file, const FilePos page, const FilePos unique,
                                                const OIDVersion version
                                        )
        : File(file),
                Page(page),
                Unique(unique),
                Version(version) {
        ;
}

inline
inXDB::OID::OID(const OID &ID) {
        memcpy(this, &ID, sizeof(*this));
}

inline
inXDB::OID::~OID() {
        ;
}
# 2544 "../inXDB/DB/inXDB.i"
inline bool
DBObject::Insert(const Unsigned index, const void *buffer)
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2547 ); } } while (0);

        return Trx->insert(*DBIndex[index], buffer);
}

inline bool
DBObject::Remove(const Unsigned index, const void *buffer)
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2555 ); } } while (0);

        return Trx->remove(*DBIndex[index], buffer);
}

inline bool
DBObject::Find(const Unsigned index, const void *buffer) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2563 ); } } while (0);

        return Trx->find(*DBIndex[index], buffer);
}

inline bool
DBObject::First(const Unsigned index) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2571 ); } } while (0);

        return Trx->first(*DBIndex[index]);
}

inline bool
DBObject::Last(const Unsigned index) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2579 ); } } while (0);

        return Trx->last(*DBIndex[index]);
}

inline bool
DBObject::Next(const Unsigned index) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2587 ); } } while (0);

        return Trx->next(*DBIndex[index]);
}

inline bool
DBObject::Previous(const Unsigned index) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2595 ); } } while (0);

        return Trx->previous(*DBIndex[index]);
}

inline bool
DBObject::Nth(const Unsigned index, const FilePos n) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2603 ); } } while (0);

        return Trx->nth(*DBIndex[index], n);
}

inline void
DBObject::Get_current(const Unsigned index,
                                                                inXDB::BTreePosition &position
                                                        ) const {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2612 ); } } while (0);

        Trx->get_current(*DBIndex[index], position);
}

inline bool
DBObject::Set_current(const Unsigned index,
                                                                const inXDB::BTreePosition &position
                                                        ) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2622 ); } } while (0);

        return Trx->set_current(*DBIndex[index], position);
}

inline bool
DBObject::Get_key(const Unsigned index, void *buffer) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2630 ); } } while (0);

        return Trx->get_key(*DBIndex[index], buffer);
}

inline bool
DBObject::Get_key(const Unsigned index, void *buffer,
                                                        const size_t buffer_length
                                          ) const
        throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2640 ); } } while (0);

        return Trx->get_key(*DBIndex[index], buffer, buffer_length);
}

inline bool
DBObject::Get_key_OID(const Unsigned index) throw(inXDBException) {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2647 ); } } while (0);

        return Trx->get_key(*DBIndex[index], &Object_ID, sizeof(Object_ID));
}
# 2661 "../inXDB/DB/inXDB.i"
inline FilePos
DBObject::Keys(const Unsigned index) const {
        do { if (! (DBIndex[index])) { throw inXServices::inXException("Require", "DBIndex[index]", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2663 ); } } while (0);

        return DBIndex[index]->keys();
}

inline void
DBObject::Just_read_from_DB(const uchar *record) {
        if (Modified) {
                Modified = false;
                delete[] Modified_Record; Modified_Record = 0;
        }
        DB_Record = record;
}

inline void
DBObject::Clear_trx() {
        DB_Record = 0;
        Trx = 0;
        DBType = 0;
        delete[] DBIndex; DBIndex = 0;
}

inline void
DBObject::In_trx(inXDB::inXDBTransaction &trx) {
        DB_Record = 0;
        Trx = &trx;
        DBType = 0;
        delete[] DBIndex; DBIndex = 0;
}

inline inXDB::inXDBTransaction *
DBObject::Transaction() const {
        return Trx;
}

inline const inXDB::OID &
DBObject::ID() const {
        return Object_ID;
}

inline bool
DBObject::is_in_data_base() {
        return ! Removed && Object_ID.is_valid();
}

inline bool
DBObject::is_not_in_data_base() {
        return Removed || Object_ID.is_invalid();
}

bool
DBObject::is_modifiable(std::string *message, const bool wait_for_lock)
        throw(inXDBException) {
        do { if (! (Trx)) { throw inXServices::inXException("Ensure", "Trx", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2716 ); } } while (0);

        return Trx->is_modifiable(message,
                                                                          Object_ID, wait_for_lock
                                                                         );
}

inline void
inXDB::inXDBTransaction::Put(OID &object_ID,
                                                                          const FilePos file, const void *record,
                                                                                        const FilePos bytes
                                                                         )
        throw(inXDBException) {
        object_ID.File = file;
        Put(object_ID,
                 record, bytes
                );
}

inline const std::string &
inXDB::inXDBTransaction::name() const {
        return Transaction::name();
}

inline inXDB &
inXDB::inXDBTransaction::inX_data_base() {
        return Data_Base;
}

inline bool
inXDB::inXDBTransaction::have_data_base(const std::string &DB_name)
        throw(inXDBException) {
        return Have_data_base(DB_name.c_str());
}

inline void
inXDB::inXDBTransaction::done(DB **db) {
        if (db && *db) {
                if ((*db)->is_not_in_data_base()) {
                        delete *db;
                }
                *db = 0;
        }
}

inline void
inXDB::inXDBTransaction::done(Type **type) {
        if (type && *type) {
                if ((*type)->is_not_in_data_base() || (*type)->is_system_type()) {
                        delete *type;
                }
                *type = 0;
        }
}

inline void
inXDB::inXDBTransaction::done(TypeIndex **index) {
        if (index && *index) {
                if ((*index)->is_not_in_data_base()) {
                        delete *index;
                }
                *index = 0;
        }
}

inline void
inXDB::inXDBTransaction::done(DBObject *object) {
        if (object && object->ID().is_invalid()) {
                delete object;
        }
}

inline void
inXDB::inXDBTransaction::done(const DBObject *object) {
        if (object && object->ID().is_invalid()) {
                delete object;
        }
}

inline void
inXDB::inXDBTransaction::in_process(DBObject &object) {
        do { if (! (object.ID().is_invalid())) { throw inXServices::inXException("Ensure", "object.ID().is_invalid()", __PRETTY_FUNCTION__, "../inXDB/DB/inXDB.i", 2797 ); } } while (0);

        object.Clear_trx();
}

inline void
inXDB::inXDBTransaction::temporary(const DBObject &object) {
        if (object.Is_not_modified()) {
                delete &object;
        }
}

        }
# 4105 "../inXDB/DB/inXDB.h" 2
# 1 "../inXDB/DB/inXDBData.i" 1



#ident "@(#)$Id: inXDBData.i 1.4 Sat, 09 Mar 2002 07:44:57 -0800 tmwg $ -- Copyright (c) 2001,2002 inX Services"
# 15 "../inXDB/DB/inXDBData.i"
        namespace inXdb {

inline const std::string &
inXDataBase::DataFile::name() const {
        return Name;
}

inline FilePos
inXDataBase::DataFile::file() const {
        return Number;
}

inline inXDataBase::FileType
inXDataBase::DataFile::type() const {
        return Type;
}

inline int
inXDataBase::DataFile::compare(const DataFile &file) const {
        return static_cast<int>(Number > file.Number)
                                - static_cast<int>(Number < file.Number);
}

inline
inXDataBase::DataFile::DataFile(inXDataBase &data_base, const FileType type)
        : MmapFile(),
                Name(),
                Number(0),
                Type(type),
                Data_Base(data_base),
                Read_Lock(0),
                Write_Lock(0) {
        ;
}

inline
inXDataBase::DataFile::DataFile(inXDataBase &data_base,
                                                                                        const std::string &file_name,
                                                                                        const FileType type
                                                                                 )
        : MmapFile(),
                Name(file_name),
                Number(0),
                Type(type),
                Data_Base(data_base),
                Read_Lock(0),
                Write_Lock(0) {
        ;
}

inline
inXDataBase::DataFile::DataFile(inXDataBase &data_base, const FilePos number,
                                                                                        const FileType type
                                                                                 )
        : MmapFile(),
                Name(),
                Number(number),
                Type(type),
                Data_Base(data_base),
                Read_Lock(0),
                Write_Lock(0) {
        ;
}

inline
inXDataBase::DataFile::DataFile(inXDataBase &data_base,
                                                                                        const std::string &file_name
                                                                                 )
        : MmapFile(),
                Name(file_name),
                Number(0),
                Type(DatumFile),
                Data_Base(data_base),
                Read_Lock(0),
                Write_Lock(0) {
        ;
}

inline
inXDataBase::DataFile::DataFile(inXDataBase &data_base, const FilePos number)
        : MmapFile(),
                Name(),
                Number(number),
                Type(DatumFile),
                Data_Base(data_base),
                Read_Lock(0),
                Write_Lock(0) {
        ;
}

inline
inXDataBase::DataFile::DataFile(inXDataBase &data_base)
        : MmapFile(),
                Name(),
                Number(0),
                Type(DatumFile),
                Data_Base(data_base),
                Read_Lock(0),
                Write_Lock(0) {
        ;
}

        }
# 4106 "../inXDB/DB/inXDB.h" 2
# 1 "../inXDB/DB/inXDBTree.i" 1



#ident "@(#)$Id: inXDBTree.i 1.15 Tue, 08 Jan 2002 19:57:09 -0800 tmwg $ -- Copyright (c) 1999,2001 inX Services"
# 15 "../inXDB/DB/inXDBTree.i"
        namespace inXdb {

inline FilePos
inXDataBase::BTreePage::order() const {
        return Order;
}

inline FilePos
inXDataBase::BTreePage::key_size() const {
        return Key_Size;
}

inline FilePos
inXDataBase::BTreePage::page_size() const {
        return Page_Size;
}

inline FilePos
inXDataBase::BTreePage::node_maximum() const {
        return order() - 1;
}

inline FilePos
inXDataBase::BTreePage::node_minimum() const {
        return ((order() + 1) / 2) - 1;
}

inline FilePos
inXDataBase::BTreePage::root() const {
        return Root;
}

inline FilePos
inXDataBase::BTreePage::root(const FilePos r) {
        return Root = r;
}

inline FilePos
inXDataBase::BTreePage::first() const {
        return First;
}

inline FilePos
inXDataBase::BTreePage::first(const FilePos f) {
        return First = f;
}

inline FilePos
inXDataBase::BTreePage::last() const {
        return Last;
}

inline FilePos
inXDataBase::BTreePage::last(const FilePos l) {
        return Last = l;
}

inline FilePos
inXDataBase::BTreePage::keys() const {
        return Keys;
}

inline FilePos
inXDataBase::BTreePage::keys(const FilePos k) {
        return Keys = k;
}

inline FilePos
inXDataBase::BTreePage::height() const {
        return Height;
}

inline FilePos
inXDataBase::BTreePage::height(const FilePos h) {
        return Height = h;
}

inline FilePos
inXDataBase::BTreePage::fields() const {
        return Fields;
}

inline const inXDataBase::BTreeFieldDefinition *
inXDataBase::BTreePage::field_definition() const {
        return Field_Definition;
}

inline FilePos
inXDataBase::BTreeNodePage::left() const {
        return reinterpret_cast<const FilePos *>(DataPage::data())[0];
}

inline FilePos
inXDataBase::BTreeNodePage::left(const FilePos l) {
        return reinterpret_cast<FilePos *>(DataPage::data())[0] = l;
}

inline FilePos
inXDataBase::BTreeNodePage::right() const {
        return reinterpret_cast<const FilePos *>(DataPage::data())[1];
}

inline FilePos
inXDataBase::BTreeNodePage::right(const FilePos r) {
        return reinterpret_cast<FilePos *>(DataPage::data())[1] = r;
}

inline FilePos
inXDataBase::BTreeNodePage::keys() const {
        return reinterpret_cast<const FilePos *>(DataPage::data())[2];
}

inline FilePos
inXDataBase::BTreeNodePage::keys(const FilePos k) {
        return reinterpret_cast<FilePos *>(DataPage::data())[2] = k;
}

inline const uchar *
inXDataBase::BTreeNodePage::data() const {
        return
                reinterpret_cast<const uchar *>(
                                                                reinterpret_cast<const FilePos *>(DataPage::data()) + 3
                                                                                                 );
}

inline uchar *
inXDataBase::BTreeNodePage::data() {
        return
                reinterpret_cast<uchar *>(reinterpret_cast<FilePos *>(DataPage::data())
                                                                                        + 3
                                                                                 );
}

inline
inXDataBase::BTreeNodePage::BTreeNodePage(const FilePos number,
                                                                                                                        const FilePos bytes,
                                                                                                                        const FilePos used
                                                                                                          )
        : DataPage(PageIsBTreeNode, Page::BTreeNode, number, bytes, used) {
        ;
}

inline
inXDataBase::BTree::Link::Link(const BTreePage &header)
        : Key(0),
                Child(0) {
        Key = new uchar[header.key_size()];
}

inline
inXDataBase::BTree::Link::~Link() {
        delete Key;
}

inline FilePos *
inXDataBase::BTree::Node::child(const FilePos index) {
        return Child + index;
}

inline const FilePos *
inXDataBase::BTree::Node::child(const FilePos index) const {
        return Child + index;
}

inline uchar *
inXDataBase::BTree::Node::key(const FilePos index, const BTreePage &header) {
        return Key + ((index - 1) * header.key_size());
}

inline const uchar *
inXDataBase::BTree::Node::key(const FilePos index,
                                                                                        const BTreePage &header
                                                                          ) const {
        return Key + ((index - 1) * header.key_size());
}

inline uchar *
inXDataBase::BTree::Node::key_field(const FilePos index, const FilePos field,
                                                                                                        const BTreePage &header
                                                                                          ) {
        return key(index, header)
                                + header.field_definition()[field].Offset;
}

inline const uchar *
inXDataBase::BTree::Node::key_field(const FilePos index, const FilePos field,
                                                                                                        const BTreePage &header
                                                                                          ) const {
        return key(index, header)
                                + header.field_definition()[field].Offset;
}

inline bool
inXDataBase::BTree::Node::is_leaf() const {
        return ! *Child;
}

inline bool
inXDataBase::BTree::Node::is_branch() const {
        return *Child;
}

inline void
inXDataBase::BTree::Node::Remove_key(const FilePos key,
                                                                                                        const BTreePage &header,
                                                                                                        inXDataBase &data_base
                                                                                                )
                throw(inXDBException) {
        Shift_key(key + 1, -1, header, data_base);
}

inline void
inXDataBase::BTree::Node::initialize(const BTreePage &header) {
        Key = Node_Page->data();
        Child = reinterpret_cast<FilePos *>(Node_Page->data()
                                                                                                                + (header.order() * header.key_size())
                                                                                                  );
}

inline void
inXDataBase::BTree::Node::copy(const Node &node, const BTreePage &header) {
        Node_Page->left(node.Node_Page->left());
        Node_Page->right(node.Node_Page->right());
        Node_Page->keys(node.Node_Page->keys());
        memcpy(Key, node.Key, header.order() * header.key_size());
        memcpy(Child, node.Child, (header.order() + 1) * sizeof(*Child));
}

inline void
inXDataBase::BTree::Node::clear(const BTreePage &header) {
        Node_Page->left(0);
        Node_Page->right(0);
        Node_Page->keys(0);
        memset(Key, 0, header.order() * header.key_size());
        memset(Child, 0, (header.order() + 1) * sizeof(*Child));
}

inline inXDataBase::BTree::Node &
inXDataBase::BTree::Node::operator =(const Node &node) {
        Node_Page = node.Node_Page;
        Key = node.Key;
        Child = node.Child;

        return *this;
}

inline inXDataBase::BTree::Node &
inXDataBase::BTree::Node::operator ()(const BTreePage &header,
                                                                                                        BTreeNodePage *node
                                                                                                 ) {
        Node_Page = node;
        initialize(header);

        return *this;
}

inline inXDataBase::BTree::Node &
inXDataBase::BTree::Node::operator ()(const BTreePage &header,
                                                                                                        const BTreeNodePage *node
                                                                                                 ) {
        Node_Page = const_cast<BTreeNodePage *>(node);
        initialize(header);

        return *this;
}

inline inXDataBase::BTree::Node &
inXDataBase::BTree::Node::operator ()() {
        Node_Page = 0;
        Key = 0;
        Child = 0;

        return *this;
}

inline
inXDataBase::BTree::Node::operator bool() {
        return Node_Page;
}

inline
inXDataBase::BTree::Node::Node()
        : Node_Page(0),
                Key(0),
                Child(0) {
        ;
}

inline
inXDataBase::BTree::Node::Node(const BTreePage &header, BTreeNodePage *node)
        : Node_Page(node) {
        initialize(header);
}

inline
inXDataBase::BTree::Node::Node(const Node &node)
        : Node_Page(node.Node_Page),
                Key(node.Key),
                Child(node.Child) {
        ;
}

inline
inXDataBase::BTree::Node::~Node() {
        ;
}

inline void
inXDataBase::BTree::Get_header(Transaction &trx, const bool read_only)
        throw(inXDBException) {
        if (! Header) {
                Header = trx.Tree_header(*this, read_only);
        }
}

inline inXDataBase::Datum *
inXDataBase::BTree::Get(const FilePos page, Transaction &trx,
                                                                        const bool read_only
                                                          ) throw(inXDBException) {
        return trx.Tree_node(*this, page, read_only);
}

inline FilePos
inXDataBase::BTree::key_size() const {
        do { if (! (Header)) { throw inXServices::inXException("Require", "Header", __PRETTY_FUNCTION__, "../inXDB/DB/inXDBTree.i", 339 ); } } while (0);

        return static_cast<const Datum *>(Header)->Tree_header()->key_size();
}

inline FilePos
inXDataBase::BTree::keys() const {
        do { if (! (Header)) { throw inXServices::inXException("Require", "Header", __PRETTY_FUNCTION__, "../inXDB/DB/inXDBTree.i", 346 ); } } while (0);

        return static_cast<const Datum *>(Header)->Tree_header()->keys();
}

inline void
inXDataBase::BTree::Get_current(BTreePosition &position) {
        memcpy(&position, &Current_Position, sizeof(position));
}

inline void
inXDataBase::Transaction::get_current(BTree &tree, BTreePosition &position) {
        tree.Get_current(position);
}

inline
inXDataBase::BTree::BTree(inXDataBase &data_base, const std::string &file_name)
        : DataFile(data_base, file_name, BTreeFile),
                Header(0) {
        ;
}

inline
inXDataBase::BTree::BTree(inXDataBase &data_base, const FilePos number)
        : DataFile(data_base, number, BTreeFile),
                Header(0) {
        ;
}


        }
# 4107 "../inXDB/DB/inXDB.h" 2


                        class Money;
# 21 "../inXDB/DB/TypeGen.cc" 2
# 1 "/usr/include/X11/FL/Fl_Widget.h" 1 3
# 29 "/usr/include/X11/FL/Fl_Widget.h" 3
# 1 "/usr/include/X11/FL/Enumerations.H" 1 3
# 29 "/usr/include/X11/FL/Enumerations.H" 3
# 1 "/usr/include/X11/FL/Fl_Export.H" 1 3
# 30 "/usr/include/X11/FL/Enumerations.H" 2 3
# 53 "/usr/include/X11/FL/Enumerations.H" 3
typedef unsigned char uchar;
typedef unsigned long ulong;

enum Fl_Event {
  FL_NO_EVENT = 0,
  FL_PUSH = 1,
  FL_RELEASE = 2,
  FL_ENTER = 3,
  FL_LEAVE = 4,
  FL_DRAG = 5,
  FL_FOCUS = 6,
  FL_UNFOCUS = 7,
  FL_KEYDOWN = 8,
  FL_KEYUP = 9,
  FL_CLOSE = 10,
  FL_MOVE = 11,
  FL_SHORTCUT = 12,
  FL_DEACTIVATE = 13,
  FL_ACTIVATE = 14,
  FL_HIDE = 15,
  FL_SHOW = 16,
  FL_PASTE = 17,
  FL_SELECTIONCLEAR = 18,
  FL_MOUSEWHEEL = 19,
  FL_DND_ENTER = 20,
  FL_DND_DRAG = 21,
  FL_DND_LEAVE = 22,
  FL_DND_RELEASE = 23
};


enum Fl_When {
  FL_WHEN_NEVER = 0,
  FL_WHEN_CHANGED = 1,
  FL_WHEN_RELEASE = 4,
  FL_WHEN_RELEASE_ALWAYS= 6,
  FL_WHEN_ENTER_KEY = 8,
  FL_WHEN_ENTER_KEY_ALWAYS=10,
  FL_WHEN_ENTER_KEY_CHANGED=11,
  FL_WHEN_NOT_CHANGED = 2
};
# 149 "/usr/include/X11/FL/Enumerations.H" 3
enum Fl_Boxtype {
  FL_NO_BOX = 0, FL_FLAT_BOX,

  FL_UP_BOX, FL_DOWN_BOX,
  FL_UP_FRAME, FL_DOWN_FRAME,
  FL_THIN_UP_BOX, FL_THIN_DOWN_BOX,
  FL_THIN_UP_FRAME, FL_THIN_DOWN_FRAME,
  FL_ENGRAVED_BOX, FL_EMBOSSED_BOX,
  FL_ENGRAVED_FRAME, FL_EMBOSSED_FRAME,
  FL_BORDER_BOX, _FL_SHADOW_BOX,
  FL_BORDER_FRAME, _FL_SHADOW_FRAME,
  _FL_ROUNDED_BOX, _FL_RSHADOW_BOX,
  _FL_ROUNDED_FRAME, _FL_RFLAT_BOX,
  _FL_ROUND_UP_BOX, _FL_ROUND_DOWN_BOX,
  _FL_DIAMOND_UP_BOX, _FL_DIAMOND_DOWN_BOX,
  _FL_OVAL_BOX, _FL_OSHADOW_BOX,
  _FL_OVAL_FRAME, _FL_OFLAT_BOX,
  _FL_PLASTIC_UP_BOX, _FL_PLASTIC_DOWN_BOX,
  _FL_PLASTIC_UP_FRAME, _FL_PLASTIC_DOWN_FRAME,
  FL_FREE_BOXTYPE
};
extern Fl_Boxtype fl_define_FL_ROUND_UP_BOX();


extern Fl_Boxtype fl_define_FL_SHADOW_BOX();


extern Fl_Boxtype fl_define_FL_ROUNDED_BOX();


extern Fl_Boxtype fl_define_FL_RFLAT_BOX();

extern Fl_Boxtype fl_define_FL_RSHADOW_BOX();

extern Fl_Boxtype fl_define_FL_DIAMOND_BOX();


extern Fl_Boxtype fl_define_FL_OVAL_BOX();





extern Fl_Boxtype fl_define_FL_PLASTIC_UP_BOX();






inline Fl_Boxtype fl_down(Fl_Boxtype b) {return (Fl_Boxtype)(b|1);}
inline Fl_Boxtype fl_frame(Fl_Boxtype b) {return (Fl_Boxtype)(b|2);}







enum Fl_Labeltype {
  FL_NORMAL_LABEL = 0,
  FL_NO_LABEL,
  _FL_SHADOW_LABEL,
  _FL_ENGRAVED_LABEL,
  _FL_EMBOSSED_LABEL,
  _FL_MULTI_LABEL,
  _FL_ICON_LABEL,

  FL_FREE_LABELTYPE
};

extern Fl_Labeltype fl_define_FL_SHADOW_LABEL();

extern Fl_Labeltype fl_define_FL_ENGRAVED_LABEL();

extern Fl_Labeltype fl_define_FL_EMBOSSED_LABEL();


enum Fl_Align {
  FL_ALIGN_CENTER = 0,
  FL_ALIGN_TOP = 1,
  FL_ALIGN_BOTTOM = 2,
  FL_ALIGN_LEFT = 4,
  FL_ALIGN_RIGHT = 8,
  FL_ALIGN_INSIDE = 16,
  FL_ALIGN_TEXT_OVER_IMAGE = 32,
  FL_ALIGN_IMAGE_OVER_TEXT = 0,
  FL_ALIGN_CLIP = 64,
  FL_ALIGN_WRAP = 128,
  FL_ALIGN_TOP_LEFT = FL_ALIGN_TOP | FL_ALIGN_LEFT,
  FL_ALIGN_TOP_RIGHT = FL_ALIGN_TOP | FL_ALIGN_RIGHT,
  FL_ALIGN_BOTTOM_LEFT = FL_ALIGN_BOTTOM | FL_ALIGN_LEFT,
  FL_ALIGN_BOTTOM_RIGHT = FL_ALIGN_BOTTOM | FL_ALIGN_RIGHT,
  FL_ALIGN_LEFT_TOP = FL_ALIGN_TOP_LEFT,
  FL_ALIGN_RIGHT_TOP = FL_ALIGN_TOP_RIGHT,
  FL_ALIGN_LEFT_BOTTOM = FL_ALIGN_BOTTOM_LEFT,
  FL_ALIGN_RIGHT_BOTTOM = FL_ALIGN_BOTTOM_RIGHT,
  FL_ALIGN_NOWRAP = 0
};

enum Fl_Font {
  FL_HELVETICA = 0,
  FL_HELVETICA_BOLD,
  FL_HELVETICA_ITALIC,
  FL_HELVETICA_BOLD_ITALIC,
  FL_COURIER,
  FL_COURIER_BOLD,
  FL_COURIER_ITALIC,
  FL_COURIER_BOLD_ITALIC,
  FL_TIMES,
  FL_TIMES_BOLD,
  FL_TIMES_ITALIC,
  FL_TIMES_BOLD_ITALIC,
  FL_SYMBOL,
  FL_SCREEN,
  FL_SCREEN_BOLD,
  FL_ZAPF_DINGBATS,

  FL_FREE_FONT = 16,
  FL_BOLD = 1,
  FL_ITALIC = 2
};

extern int FL_NORMAL_SIZE;

enum Fl_Color {
  FL_BLACK = 0,
  FL_RED = 1,
  FL_GREEN = 2,
  FL_YELLOW = 3,
  FL_BLUE = 4,
  FL_MAGENTA = 5,
  FL_CYAN = 6,
  FL_WHITE = 7,
  FL_INACTIVE_COLOR = 8,
  FL_SELECTION_COLOR = 15,

  FL_FREE_COLOR = 16,
  FL_NUM_FREE_COLOR = 16,

  FL_GRAY_RAMP = 32,


  FL_GRAY0 = 32,
  FL_DARK3 = 39,
  FL_DARK2 = 45,
  FL_DARK1 = 47,
  FL_GRAY = 49,
  FL_LIGHT1 = 50,
  FL_LIGHT2 = 52,
  FL_LIGHT3 = 54,

  FL_COLOR_CUBE = 56
};

 Fl_Color fl_inactive(Fl_Color c);
 Fl_Color fl_contrast(Fl_Color fg, Fl_Color bg);
 Fl_Color fl_color_average(Fl_Color c1, Fl_Color c2, float weight);
inline Fl_Color fl_lighter(Fl_Color c) { return fl_color_average(c, FL_WHITE, .67f); }
inline Fl_Color fl_darker(Fl_Color c) { return fl_color_average(c, FL_BLACK, .67f); }
inline Fl_Color fl_rgb_color(uchar r, uchar g, uchar b) {
  return (Fl_Color)(((((r << 8) | g) << 8) | b) << 8);
}

inline Fl_Color fl_gray_ramp(int i) {return (Fl_Color)(i+FL_GRAY_RAMP);}



inline Fl_Color fl_color_cube(int r, int g, int b) {
  return (Fl_Color)((b*5 + r) * 8 + g + FL_COLOR_CUBE);}

enum Fl_Cursor {
  FL_CURSOR_DEFAULT = 0,
  FL_CURSOR_ARROW = 35,
  FL_CURSOR_CROSS = 66,
  FL_CURSOR_WAIT = 76,
  FL_CURSOR_INSERT = 77,
  FL_CURSOR_HAND = 31,
  FL_CURSOR_HELP = 47,
  FL_CURSOR_MOVE = 27,

  FL_CURSOR_NS = 78,
  FL_CURSOR_WE = 79,
  FL_CURSOR_NWSE = 80,
  FL_CURSOR_NESW = 81,
  FL_CURSOR_NONE = 255,

  FL_CURSOR_N = 70,
  FL_CURSOR_NE = 69,
  FL_CURSOR_E = 49,
  FL_CURSOR_SE = 8,
  FL_CURSOR_S = 9,
  FL_CURSOR_SW = 7,
  FL_CURSOR_W = 36,
  FL_CURSOR_NW = 68


};

enum {
  FL_READ = 1,
  FL_WRITE = 4,
  FL_EXCEPT = 8
};

enum Fl_Mode {
  FL_RGB = 0,
  FL_INDEX = 1,
  FL_SINGLE = 0,
  FL_DOUBLE = 2,
  FL_ACCUM = 4,
  FL_ALPHA = 8,
  FL_DEPTH = 16,
  FL_STENCIL = 32,
  FL_RGB8 = 64,
  FL_MULTISAMPLE= 128,
  FL_STEREO = 256
};



enum Fl_Damage {
  FL_DAMAGE_CHILD = 0x01,
  FL_DAMAGE_EXPOSE = 0x02,
  FL_DAMAGE_SCROLL = 0x04,
  FL_DAMAGE_OVERLAY = 0x08,
  FL_DAMAGE_ALL = 0x80
};
# 30 "/usr/include/X11/FL/Fl_Widget.h" 2 3

class Fl_Widget;
class Fl_Window;
class Fl_Group;
class Fl_Image;

typedef void (Fl_Callback )(Fl_Widget*, void*);
typedef Fl_Callback* Fl_Callback_p;
typedef void (Fl_Callback0)(Fl_Widget*);
typedef void (Fl_Callback1)(Fl_Widget*, long);
typedef void (Fl_Widget::*Fl_CallbackW)(Fl_Widget*);

struct Fl_Label {
  const char* value;
  Fl_Image* image;
  Fl_Image* deimage;
  uchar type;
  uchar font;
  uchar size;
  unsigned color;
  void draw(int,int,int,int, Fl_Align) const ;
  void measure(int&, int&) const ;
};

class Fl_Widget {
  friend class Fl_Group;

  Fl_Group* parent_;
  union {
        Fl_Callback* callback_;
        Fl_CallbackW wcallback_;
  };
  void* user_data_;
  Fl_Widget* user_widget_;
  int x_,y_,w_,h_;
  Fl_Label label_;
  int flags_;
  unsigned color_;
  unsigned color2_;
  uchar type_;
  uchar damage_;
  uchar box_;
  uchar align_;
  uchar when_;

  const char *tooltip_;


  Fl_Widget & operator=(const Fl_Widget &);
  Fl_Widget(const Fl_Widget &);

protected:

  Fl_Widget(int,int,int,int,const char* =0);

  void x(int v) {x_ = v;}
  void y(int v) {y_ = v;}
  void w(int v) {w_ = v;}
  void h(int v) {h_ = v;}

  int flags() const {return flags_;}
  void set_flag(int c) {flags_ |= c;}
  void clear_flag(int c) {flags_ &= ~c;}
  enum {INACTIVE=1, INVISIBLE=2, OUTPUT=4, SHORTCUT_LABEL=64, CHANGED=128};
public:
  int x() const {return x_;}
  int y() const {return y_;}
  int w() const {return w_;}
  int h() const {return h_;}
  Fl_Boxtype box() const {return (Fl_Boxtype)box_;}
protected:
  void draw_box() const;
  void draw_box(Fl_Boxtype, Fl_Color) const;
  void draw_box(Fl_Boxtype, int,int,int,int, Fl_Color) const;
  void draw_focus() {draw_focus(box(),x(),y(),w(),h());}
  void draw_focus(Fl_Boxtype, int,int,int,int) const;
  void draw_label() const;
  void draw_label(int, int, int, int) const;

public:

  virtual ~Fl_Widget();

  virtual void draw() = 0;
  virtual int handle(int);
  Fl_Group* parent() const {return parent_;}
  void parent(Fl_Group* w) {parent_ = w;}

  uchar type() const {return type_;}
  void type(uchar t) {type_ = t;}

  virtual void resize(int,int,int,int);
  int damage_resize(int,int,int,int);
  void position(int X,int Y) {resize(X,Y,w_,h_);}
  void size(int W,int H) {resize(x_,y_,W,H);}

  Fl_Align align() const {return (Fl_Align)align_;}
  void align(uchar a) {align_ = a;}
  void box(Fl_Boxtype a) {box_ = a;}
  Fl_Color color() const {return (Fl_Color)color_;}
  void color(unsigned a) {color_ = a;}
  Fl_Color selection_color() const {return (Fl_Color)color2_;}
  void selection_color(unsigned a) {color2_ = a;}
  void color(unsigned a, unsigned b) {color_=a; color2_=b;}
  const char* label() const {return label_.value;}
  void label(const char* a) {label_.value=a;}
  void label(Fl_Labeltype a,const char* b) {label_.type = a; label_.value = b;}
  Fl_Labeltype labeltype() const {return (Fl_Labeltype)label_.type;}
  void labeltype(Fl_Labeltype a) {label_.type = a;}
  Fl_Color labelcolor() const {return (Fl_Color)label_.color;}
  void labelcolor(unsigned a) {label_.color=a;}
  Fl_Font labelfont() const {return (Fl_Font)label_.font;}
  void labelfont(uchar a) {label_.font=a;}
  uchar labelsize() const {return label_.size;}
  void labelsize(uchar a) {label_.size=a;}
  Fl_Image* image() {return label_.image;}
  void image(Fl_Image* a) {label_.image=a;}
  void image(Fl_Image& a) {label_.image=&a;}
  Fl_Image* deimage() {return label_.deimage;}
  void deimage(Fl_Image* a) {label_.deimage=a;}
  void deimage(Fl_Image& a) {label_.deimage=&a;}
  const char *tooltip() const {return tooltip_;}
  void tooltip(const char *t) {tooltip_=t;}
  Fl_Callback_p callback() const {return callback_;}
  void callback(Fl_Callback* c, void* p) {callback_=c; user_data_=p;}
  void callback(Fl_Callback* c) {callback_=c;}
  void callback(Fl_Callback0*c) {callback_=(Fl_Callback*)c;}
  void callback(Fl_Callback1*c, long p=0) {callback_=(Fl_Callback*)c; user_data_=(void*)p;}
  void callback(Fl_CallbackW c, Fl_Widget* w) {wcallback_=c; user_widget_=w;}
  void* user_data() const {return user_data_;}
  void user_data(void* v) {user_data_ = v; user_widget_=0;}
  Fl_Widget* user_widget() const {return user_widget_;}
  void user_widget(Fl_Widget* w) {user_data_ = 0; user_widget_=w;}
  long argument() const {return (long)user_data_;}
  void argument(long v) {user_data_ = (void*)v; user_widget_=0;}
  Fl_When when() const {return (Fl_When)when_;}
  void when(uchar i) {when_ = i;}

  int visible() const {return !(flags_&INVISIBLE);}
  int visible_r() const;
  void show();
  void hide();
  void set_visible() {flags_ &= ~INVISIBLE;}
  void clear_visible() {flags_ |= INVISIBLE;}
  int active() const {return !(flags_&INACTIVE);}
  int active_r() const;
  void activate();
  void deactivate();
  int output() const {return (flags_&OUTPUT);}
  void set_output() {flags_ |= OUTPUT;}
  void clear_output() {flags_ &= ~OUTPUT;}
  int takesevents() const {return !(flags_&(INACTIVE|INVISIBLE|OUTPUT));}
  int changed() const {return flags_&CHANGED;}
  void set_changed() {flags_ |= CHANGED;}
  void clear_changed() {flags_ &= ~CHANGED;}
  int take_focus();

  static void default_callback(Fl_Widget*, void*);
  void do_callback() {user_widget_?(user_widget_->*wcallback_)(this):callback_(this,user_data_); }
  void do_callback(Fl_Widget* o,void* arg=0) {callback_(o,arg);}
  void do_callback(Fl_Widget* o,long arg) {callback_(o,(void*)arg);}
  int test_shortcut();
  static int test_shortcut(const char*);
  int contains(const Fl_Widget*) const ;
  int inside(const Fl_Widget* o) const {return o ? o->contains(this) : 0;}

  void redraw();
  uchar damage() const {return damage_;}
  void clear_damage(uchar c = 0) {damage_ = c;}
  void damage(uchar c);
  void damage(uchar c,int,int,int,int);
  void draw_label(int, int, int, int, Fl_Align) const;
  void measure_label(int& x, int& y) {label_.measure(x,y);}

  Fl_Window* window() const ;


  Fl_Color color2() const {return (Fl_Color)color2_;}
  void color2(unsigned a) {color2_ = a;}
};
# 22 "../inXDB/DB/TypeGen.cc" 2



        using namespace std;
        using namespace inXServices;
        using namespace inXdb;

bool
inXDB::Type::reference_requires_snprintf() {
        bool needed(false);
        for (ulong i(0);
                  ! needed && i < reference_attributes();
                  ++i
                 ) {
                TypeAttribute *a(reference_sub_attribute(i));
                if (! a) {
                        a = reference_attribute(i);
                }
                needed = a->requires_snprintf();
                delete a;
        }
        return needed;
}
>Fix:
	Remove -frename-registers
>Release-Note:
>Audit-Trail:
>Unformatted:


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2002-10-28 12:14 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2002-04-25  9:35 c++/6396: 3.1 flow.c 583 ICE with -frename-registers jakub
  -- strict thread matches above, loose matches on Subject: below --
2002-10-28  4:14 reichelt
2002-04-25 10:36 George Garvey
2002-04-21 11:56 c++/6396: 3.1 flow.c:583 " tmwg-gcc

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).