/* ----------------------------------------------------------------------------
 * This file was automatically generated by SWIG (http://www.swig.org).
 * Version 1.3.25
 * 
 * This file is not intended to be easily readable and contains a number of 
 * coding conventions designed to improve portability and efficiency. Do not make
 * changes to this file unless you know what you are doing--modify the SWIG 
 * interface file instead. 
 * ----------------------------------------------------------------------------- */

/***********************************************************************
 *
 *  This section contains generic SWIG labels for method/variable
 *  declarations/attributes, and other compiler dependent labels.
 *
 ************************************************************************/

/* template workaround for compilers that cannot correctly implement the C++ standard */
#ifndef SWIGTEMPLATEDISAMBIGUATOR
#  if defined(__SUNPRO_CC) && (__SUNPRO_CC <= 0x560)
#    define SWIGTEMPLATEDISAMBIGUATOR template
#  else
#    define SWIGTEMPLATEDISAMBIGUATOR 
#  endif
#endif

/* inline attribute */
#ifndef SWIGINLINE
# if defined(__cplusplus) || (defined(__GNUC__) && !defined(__STRICT_ANSI__))
#   define SWIGINLINE inline
# else
#   define SWIGINLINE
# endif
#endif

/* attribute recognised by some compilers to avoid 'unused' warnings */
#ifndef SWIGUNUSED
# if defined(__GNUC__) || defined(__ICC)
#   define SWIGUNUSED __attribute__ ((unused)) 
# else
#   define SWIGUNUSED 
# endif
#endif

/* internal SWIG method */
#ifndef SWIGINTERN
# define SWIGINTERN static SWIGUNUSED
#endif

/* internal inline SWIG method */
#ifndef SWIGINTERNINLINE
# define SWIGINTERNINLINE SWIGINTERN SWIGINLINE
#endif

/* exporting methods for Windows DLLs */
#ifndef SWIGEXPORT
# if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__)
#   if defined(STATIC_LINKED)
#     define SWIGEXPORT
#   else
#     define SWIGEXPORT __declspec(dllexport)
#   endif
# else
#   define SWIGEXPORT
# endif
#endif

/* calling conventions for Windows */
#ifndef SWIGSTDCALL
# if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__)
#   define SWIGSTDCALL __stdcall
# else
#   define SWIGSTDCALL
# endif 
#endif


/***********************************************************************
 * swigrun.swg
 *
 *     This file contains generic CAPI SWIG runtime support for pointer
 *     type checking.
 *
 ************************************************************************/

/* This should only be incremented when either the layout of swig_type_info changes,
   or for whatever reason, the runtime changes incompatibly */
#define SWIG_RUNTIME_VERSION "2"

/* define SWIG_TYPE_TABLE_NAME as "SWIG_TYPE_TABLE" */
#ifdef SWIG_TYPE_TABLE
# define SWIG_QUOTE_STRING(x) #x
# define SWIG_EXPAND_AND_QUOTE_STRING(x) SWIG_QUOTE_STRING(x)
# define SWIG_TYPE_TABLE_NAME SWIG_EXPAND_AND_QUOTE_STRING(SWIG_TYPE_TABLE)
#else
# define SWIG_TYPE_TABLE_NAME
#endif

/*
  You can use the SWIGRUNTIME and SWIGRUNTIMEINLINE macros for
  creating a static or dynamic library from the swig runtime code.
  In 99.9% of the cases, swig just needs to declare them as 'static'.
  
  But only do this if is strictly necessary, ie, if you have problems
  with your compiler or so.
*/

#ifndef SWIGRUNTIME
# define SWIGRUNTIME SWIGINTERN
#endif

#ifndef SWIGRUNTIMEINLINE
# define SWIGRUNTIMEINLINE SWIGRUNTIME SWIGINLINE
#endif

#include <string.h>

#ifdef __cplusplus
extern "C" {
#endif

typedef void *(*swig_converter_func)(void *);
typedef struct swig_type_info *(*swig_dycast_func)(void **);

/* Structure to store inforomation on one type */
typedef struct swig_type_info {
  const char             *name;			/* mangled name of this type */
  const char             *str;			/* human readable name of this type */
  swig_dycast_func        dcast;		/* dynamic cast function down a hierarchy */
  struct swig_cast_info  *cast;			/* linked list of types that can cast into this type */
  void                   *clientdata;		/* language specific type data */
} swig_type_info;

/* Structure to store a type and conversion function used for casting */
typedef struct swig_cast_info {
  swig_type_info         *type;			/* pointer to type that is equivalent to this type */
  swig_converter_func     converter;		/* function to cast the void pointers */
  struct swig_cast_info  *next;			/* pointer to next cast in linked list */
  struct swig_cast_info  *prev;			/* pointer to the previous cast */
} swig_cast_info;

/* Structure used to store module information
 * Each module generates one structure like this, and the runtime collects
 * all of these structures and stores them in a circularly linked list.*/
typedef struct swig_module_info {
  swig_type_info         **types;		/* Array of pointers to swig_type_info structures that are in this module */
  size_t                 size;		        /* Number of types in this module */
  struct swig_module_info *next;		/* Pointer to next element in circularly linked list */
  swig_type_info         **type_initial;	/* Array of initially generated type structures */
  swig_cast_info         **cast_initial;	/* Array of initially generated casting structures */
  void                    *clientdata;		/* Language specific module data */
} swig_module_info;


/* 
  Compare two type names skipping the space characters, therefore
  "char*" == "char *" and "Class<int>" == "Class<int >", etc.

  Return 0 when the two name types are equivalent, as in
  strncmp, but skipping ' '.
*/
SWIGRUNTIME int
SWIG_TypeNameComp(const char *f1, const char *l1,
		  const char *f2, const char *l2) {
  for (;(f1 != l1) && (f2 != l2); ++f1, ++f2) {
    while ((*f1 == ' ') && (f1 != l1)) ++f1;
    while ((*f2 == ' ') && (f2 != l2)) ++f2;
    if (*f1 != *f2) return (int)(*f1 - *f2);
  }
  return (l1 - f1) - (l2 - f2);
}

/*
  Check type equivalence in a name list like <name1>|<name2>|...
  Return 0 if not equal, 1 if equal
*/
SWIGRUNTIME int
SWIG_TypeEquiv(const char *nb, const char *tb) {
  int equiv = 0;
  const char* te = tb + strlen(tb);
  const char* ne = nb;
  while (!equiv && *ne) {
    for (nb = ne; *ne; ++ne) {
      if (*ne == '|') break;
    }
    equiv = (SWIG_TypeNameComp(nb, ne, tb, te) == 0) ? 1 : 0;
    if (*ne) ++ne;
  }
  return equiv;
}

/*
  Check type equivalence in a name list like <name1>|<name2>|...
  Return 0 if equal, -1 if nb < tb, 1 if nb > tb
*/
SWIGRUNTIME int
SWIG_TypeCompare(const char *nb, const char *tb) {
  int equiv = 0;
  const char* te = tb + strlen(tb);
  const char* ne = nb;
  while (!equiv && *ne) {
    for (nb = ne; *ne; ++ne) {
      if (*ne == '|') break;
    }
    equiv = (SWIG_TypeNameComp(nb, ne, tb, te) == 0) ? 1 : 0;
    if (*ne) ++ne;
  }
  return equiv;
}


/* think of this as a c++ template<> or a scheme macro */
#define SWIG_TypeCheck_Template(comparison, ty)         \
  if (ty) {                                             \
    swig_cast_info *iter = ty->cast;                    \
    while (iter) {                                      \
      if (comparison) {                                 \
        if (iter == ty->cast) return iter;              \
        /* Move iter to the top of the linked list */   \
        iter->prev->next = iter->next;                  \
        if (iter->next)                                 \
          iter->next->prev = iter->prev;                \
        iter->next = ty->cast;                          \
        iter->prev = 0;                                 \
        if (ty->cast) ty->cast->prev = iter;            \
        ty->cast = iter;                                \
        return iter;                                    \
      }                                                 \
      iter = iter->next;                                \
    }                                                   \
  }                                                     \
  return 0

/*
  Check the typename
*/
SWIGRUNTIME swig_cast_info *
SWIG_TypeCheck(const char *c, swig_type_info *ty) {
  SWIG_TypeCheck_Template(strcmp(iter->type->name, c) == 0, ty);
}

/* Same as previous function, except strcmp is replaced with a pointer comparison */
SWIGRUNTIME swig_cast_info *
SWIG_TypeCheckStruct(swig_type_info *from, swig_type_info *into) {
  SWIG_TypeCheck_Template(iter->type == from, into);
}

/*
  Cast a pointer up an inheritance hierarchy
*/
SWIGRUNTIMEINLINE void *
SWIG_TypeCast(swig_cast_info *ty, void *ptr) {
  return ((!ty) || (!ty->converter)) ? ptr : (*ty->converter)(ptr);
}

/* 
   Dynamic pointer casting. Down an inheritance hierarchy
*/
SWIGRUNTIME swig_type_info *
SWIG_TypeDynamicCast(swig_type_info *ty, void **ptr) {
  swig_type_info *lastty = ty;
  if (!ty || !ty->dcast) return ty;
  while (ty && (ty->dcast)) {
    ty = (*ty->dcast)(ptr);
    if (ty) lastty = ty;
  }
  return lastty;
}

/*
  Return the name associated with this type
*/
SWIGRUNTIMEINLINE const char *
SWIG_TypeName(const swig_type_info *ty) {
  return ty->name;
}

/*
  Return the pretty name associated with this type,
  that is an unmangled type name in a form presentable to the user.
*/
SWIGRUNTIME const char *
SWIG_TypePrettyName(const swig_type_info *type) {
  /* The "str" field contains the equivalent pretty names of the
     type, separated by vertical-bar characters.  We choose
     to print the last name, as it is often (?) the most
     specific. */
  if (type->str != NULL) {
    const char *last_name = type->str;
    const char *s;
    for (s = type->str; *s; s++)
      if (*s == '|') last_name = s+1;
    return last_name;
  }
  else
    return type->name;
}

/* 
   Set the clientdata field for a type
*/
SWIGRUNTIME void
SWIG_TypeClientData(swig_type_info *ti, void *clientdata) {
  if (!ti->clientdata) {
    swig_cast_info *cast = ti->cast;
    /* if (ti->clientdata == clientdata) return; */
    ti->clientdata = clientdata;
    
    while (cast) {
      if (!cast->converter)
	SWIG_TypeClientData(cast->type, clientdata);
      cast = cast->next;
    }
  }
}

/*
  Search for a swig_type_info structure only by mangled name
  Search is a O(log #types)
  
  We start searching at module start, and finish searching when start == end.  
  Note: if start == end at the beginning of the function, we go all the way around
  the circular list.
*/
SWIGRUNTIME swig_type_info *
SWIG_MangledTypeQueryModule(swig_module_info *start, 
                            swig_module_info *end, 
		            const char *name) {
  swig_module_info *iter = start;
  do {
    if (iter->size) {
      register size_t l = 0;
      register size_t r = iter->size - 1;
      do {
	/* since l+r >= 0, we can (>> 1) instead (/ 2) */
	register size_t i = (l + r) >> 1; 
	const char *iname = iter->types[i]->name;
	if (iname) {
	  register int compare = strcmp(name, iname);
	  if (compare == 0) {	    
	    return iter->types[i];
	  } else if (compare < 0) {
	    if (i) {
	      r = i - 1;
	    } else {
	      break;
	    }
	  } else if (compare > 0) {
	    l = i + 1;
	  }
	} else {
	  break; /* should never happen */
	}
      } while (l <= r);
    }
    iter = iter->next;
  } while (iter != end);
  return 0;
}

/*
  Search for a swig_type_info structure for either a mangled name or a human readable name.
  It first searches the mangled names of the types, which is a O(log #types)
  If a type is not found it then searches the human readable names, which is O(#types).
  
  We start searching at module start, and finish searching when start == end.  
  Note: if start == end at the beginning of the function, we go all the way around
  the circular list.
*/
SWIGRUNTIME swig_type_info *
SWIG_TypeQueryModule(swig_module_info *start, 
                     swig_module_info *end, 
		     const char *name) {
  /* STEP 1: Search the name field using binary search */
  swig_type_info *ret = SWIG_MangledTypeQueryModule(start, end, name);
  if (ret) {
    return ret;
  } else {
    /* STEP 2: If the type hasn't been found, do a complete search
       of the str field (the human readable name) */
    swig_module_info *iter = start;
    do {
      register size_t i = 0;
      for (; i < iter->size; ++i) {
	if (iter->types[i]->str && (SWIG_TypeEquiv(iter->types[i]->str, name)))
	  return iter->types[i];
      }
      iter = iter->next;
    } while (iter != end);
  }
  
  /* neither found a match */
  return 0;
}


/* 
   Pack binary data into a string
*/
SWIGRUNTIME char *
SWIG_PackData(char *c, void *ptr, size_t sz) {
  static const char hex[17] = "0123456789abcdef";
  register const unsigned char *u = (unsigned char *) ptr;
  register const unsigned char *eu =  u + sz;
  for (; u != eu; ++u) {
    register unsigned char uu = *u;
    *(c++) = hex[(uu & 0xf0) >> 4];
    *(c++) = hex[uu & 0xf];
  }
  return c;
}

/* 
   Unpack binary data from a string
*/
SWIGRUNTIME const char *
SWIG_UnpackData(const char *c, void *ptr, size_t sz) {
  register unsigned char *u = (unsigned char *) ptr;
  register const unsigned char *eu = u + sz;
  for (; u != eu; ++u) {
    register char d = *(c++);
    register unsigned char uu = 0;
    if ((d >= '0') && (d <= '9'))
      uu = ((d - '0') << 4);
    else if ((d >= 'a') && (d <= 'f'))
      uu = ((d - ('a'-10)) << 4);
    else 
      return (char *) 0;
    d = *(c++);
    if ((d >= '0') && (d <= '9'))
      uu |= (d - '0');
    else if ((d >= 'a') && (d <= 'f'))
      uu |= (d - ('a'-10));
    else 
      return (char *) 0;
    *u = uu;
  }
  return c;
}

/* 
   Pack 'void *' into a string buffer.
*/
SWIGRUNTIME char *
SWIG_PackVoidPtr(char *buff, void *ptr, const char *name, size_t bsz) {
  char *r = buff;
  if ((2*sizeof(void *) + 2) > bsz) return 0;
  *(r++) = '_';
  r = SWIG_PackData(r,&ptr,sizeof(void *));
  if (strlen(name) + 1 > (bsz - (r - buff))) return 0;
  strcpy(r,name);
  return buff;
}

SWIGRUNTIME const char *
SWIG_UnpackVoidPtr(const char *c, void **ptr, const char *name) {
  if (*c != '_') {
    if (strcmp(c,"NULL") == 0) {
      *ptr = (void *) 0;
      return name;
    } else {
      return 0;
    }
  }
  return SWIG_UnpackData(++c,ptr,sizeof(void *));
}

SWIGRUNTIME char *
SWIG_PackDataName(char *buff, void *ptr, size_t sz, const char *name, size_t bsz) {
  char *r = buff;
  size_t lname = (name ? strlen(name) : 0);
  if ((2*sz + 2 + lname) > bsz) return 0;
  *(r++) = '_';
  r = SWIG_PackData(r,ptr,sz);
  if (lname) {
    strncpy(r,name,lname+1);
  } else {
    *r = 0;
  }
  return buff;
}

SWIGRUNTIME const char *
SWIG_UnpackDataName(const char *c, void *ptr, size_t sz, const char *name) {
  if (*c != '_') {
    if (strcmp(c,"NULL") == 0) {
      memset(ptr,0,sz);
      return name;
    } else {
      return 0;
    }
  }
  return SWIG_UnpackData(++c,ptr,sz);
}

#ifdef __cplusplus
}
#endif


/* ---------------------------------------------------------------------- -*- c -*-
 * perl5.swg
 *
 * Perl5 runtime library
 * $Header: /cvsroot/swig/SWIG/Lib/perl5/perlrun.swg,v 1.21 2005/02/01 00:08:17 wuzzeb Exp $
 * ----------------------------------------------------------------------------- */

#define SWIGPERL
#define SWIGPERL5
#ifdef __cplusplus
/* Needed on some windows machines---since MS plays funny games with the header files under C++ */
#include <math.h>
#include <stdlib.h>
extern "C" {
#endif
#include "EXTERN.h"
#include "perl.h"
#include "XSUB.h"

/* Get rid of free and malloc defined by perl */
#undef free
#undef malloc

#ifndef pTHX_
#define pTHX_
#endif

#include <string.h>
#ifdef __cplusplus
}
#endif

/* Macro to call an XS function */

#ifdef PERL_OBJECT 
#  define SWIG_CALLXS(_name) _name(cv,pPerl) 
#else 
#  ifndef MULTIPLICITY 
#    define SWIG_CALLXS(_name) _name(cv) 
#  else 
#    define SWIG_CALLXS(_name) _name(PERL_GET_THX, cv) 
#  endif 
#endif 

/* Contract support */

#define SWIG_contract_assert(expr,msg) if (!(expr)) { SWIG_croak(msg); } else

/* Note: SwigMagicFuncHack is a typedef used to get the C++ compiler to just shut up already */

#ifdef PERL_OBJECT
#define MAGIC_PPERL  CPerlObj *pPerl = (CPerlObj *) this;
typedef int (CPerlObj::*SwigMagicFunc)(SV *, MAGIC *);

#ifdef __cplusplus
extern "C" {
#endif
typedef int (CPerlObj::*SwigMagicFuncHack)(SV *, MAGIC *);
#ifdef __cplusplus
}
#endif

#define SWIG_MAGIC(a,b) (SV *a, MAGIC *b)
#define SWIGCLASS_STATIC
#else
#define MAGIC_PPERL
#define SWIGCLASS_STATIC static
#ifndef MULTIPLICITY
#define SWIG_MAGIC(a,b) (SV *a, MAGIC *b)
typedef int (*SwigMagicFunc)(SV *, MAGIC *);

#ifdef __cplusplus
extern "C" {
#endif
typedef int (*SwigMagicFuncHack)(SV *, MAGIC *);
#ifdef __cplusplus
}
#endif


#else
#define SWIG_MAGIC(a,b) (struct interpreter *interp, SV *a, MAGIC *b)
typedef int (*SwigMagicFunc)(struct interpreter *, SV *, MAGIC *);
#ifdef __cplusplus
extern "C" {
#endif
typedef int (*SwigMagicFuncHack)(struct interpreter *, SV *, MAGIC *);
#ifdef __cplusplus
}
#endif

#endif
#endif

#if defined(WIN32) && defined(PERL_OBJECT) && !defined(PerlIO_exportFILE)
#define PerlIO_exportFILE(fh,fl) (FILE*)(fh)
#endif

/* Modifications for newer Perl 5.005 releases */

#if !defined(PERL_REVISION) || ((PERL_REVISION >= 5) && ((PERL_VERSION < 5) || ((PERL_VERSION == 5) && (PERL_SUBVERSION < 50))))
#  ifndef PL_sv_yes
#    define PL_sv_yes sv_yes
#  endif
#  ifndef PL_sv_undef
#    define PL_sv_undef sv_undef
#  endif
#  ifndef PL_na
#    define PL_na na
#  endif
#endif

#include <stdlib.h>

#ifdef __cplusplus
extern "C" {
#endif

#define SWIG_OWNER 1
#define SWIG_SHADOW 2

/* Common SWIG API */

#ifdef PERL_OBJECT
#  define SWIG_ConvertPtr(obj, pp, type, flags) \
     SWIG_Perl_ConvertPtr(pPerl, obj, pp, type, flags)
#  define SWIG_NewPointerObj(p, type, flags) \
     SWIG_Perl_NewPointerObj(pPerl, p, type, flags)
#  define SWIG_MakePackedObj(sv, p, s, type)	\
     SWIG_Perl_MakePackedObj(pPerl, sv, p, s, type)
#  define SWIG_ConvertPacked(obj, p, s, type, flags) \
     SWIG_Perl_ConvertPacked(pPerl, obj, p, s, type, flags)

#else
#  define SWIG_ConvertPtr(obj, pp, type, flags) \
     SWIG_Perl_ConvertPtr(obj, pp, type, flags)
#  define SWIG_NewPointerObj(p, type, flags) \
     SWIG_Perl_NewPointerObj(p, type, flags)
#  define SWIG_MakePackedObj(sv, p, s, type)	\
     SWIG_Perl_MakePackedObj(sv, p, s, type )
#  define SWIG_ConvertPacked(obj, p, s, type, flags) \
     SWIG_Perl_ConvertPacked(obj, p, s, type, flags)
#endif

/* Runtime API */
#define SWIG_GetModule(clientdata) SWIG_Perl_GetModule()
#define SWIG_SetModule(clientdata, pointer) SWIG_Perl_SetModule(pointer)

/* Perl-specific API */
#ifdef PERL_OBJECT
#  define SWIG_MakePtr(sv, ptr, type, flags) \
     SWIG_Perl_MakePtr(pPerl, sv, ptr, type, flags)
#  define SWIG_SetError(str) \
     SWIG_Perl_SetError(pPerl, str)
#else
#  define SWIG_MakePtr(sv, ptr, type, flags) \
     SWIG_Perl_MakePtr(sv, ptr, type, flags)
#  define SWIG_SetError(str) \
     SWIG_Perl_SetError(str)
#  define SWIG_SetErrorSV(str) \
     SWIG_Perl_SetErrorSV(str)
#endif

#define SWIG_SetErrorf SWIG_Perl_SetErrorf


#ifdef PERL_OBJECT
#  define SWIG_MAYBE_PERL_OBJECT CPerlObj *pPerl,
#else
#  define SWIG_MAYBE_PERL_OBJECT
#endif

static swig_cast_info *
SWIG_Perl_TypeCheckRV(SWIG_MAYBE_PERL_OBJECT SV *rv, swig_type_info *ty) {
  SWIG_TypeCheck_Template(sv_derived_from(rv, (char *) iter->type->name), ty);
}

/* Function for getting a pointer value */

static int
SWIG_Perl_ConvertPtr(SWIG_MAYBE_PERL_OBJECT SV *sv, void **ptr, swig_type_info *_t, int flags) {
  swig_cast_info *tc;
  void *voidptr = (void *)0;

  /* If magical, apply more magic */
  if (SvGMAGICAL(sv))
    mg_get(sv);

  /* Check to see if this is an object */
  if (sv_isobject(sv)) {
    SV *tsv = (SV*) SvRV(sv);
    IV tmp = 0;
    if ((SvTYPE(tsv) == SVt_PVHV)) {
      MAGIC *mg;
      if (SvMAGICAL(tsv)) {
        mg = mg_find(tsv,'P');
        if (mg) {
          sv = mg->mg_obj;
          if (sv_isobject(sv)) {
            tmp = SvIV((SV*)SvRV(sv));
          }
        }
      } else {
        return -1;
      }
    } else {
      tmp = SvIV((SV*)SvRV(sv));
    }
    voidptr = (void *)tmp;
    if (!_t) {
      *(ptr) = voidptr;
      return 0;
    }
  } else if (! SvOK(sv)) {            /* Check for undef */
    *(ptr) = (void *) 0;
    return 0;
  } else if (SvTYPE(sv) == SVt_RV) {  /* Check for NULL pointer */
    *(ptr) = (void *) 0;
    if (!SvROK(sv))
      return 0;
    else
      return -1;
  } else {                            /* Don't know what it is */
    *(ptr) = (void *) 0;
    return -1;
  }
  if (_t) {
    /* Now see if the types match */
    char *_c = HvNAME(SvSTASH(SvRV(sv)));
    tc = SWIG_TypeCheck(_c,_t);
    if (!tc) {
      *ptr = voidptr;
      return -1;
    }
    *ptr = SWIG_TypeCast(tc,voidptr);
    return 0;
  }
  *ptr = voidptr;
  return 0;
}

static void
SWIG_Perl_MakePtr(SWIG_MAYBE_PERL_OBJECT SV *sv, void *ptr, swig_type_info *t, int flags) {
  if (ptr && (flags & SWIG_SHADOW)) {
    SV *self;
    SV *obj=newSV(0);
    HV *hash=newHV();
    HV *stash;
    sv_setref_pv(obj, (char *) t->name, ptr);
    stash=SvSTASH(SvRV(obj));
    if (flags & SWIG_OWNER) {
      HV *hv;
      GV *gv=*(GV**)hv_fetch(stash, "OWNER", 5, TRUE);
      if (!isGV(gv))
        gv_init(gv, stash, "OWNER", 5, FALSE);
      hv=GvHVn(gv);
      hv_store_ent(hv, obj, newSViv(1), 0);
    }
    sv_magic((SV *)hash, (SV *)obj, 'P', Nullch, 0);
    SvREFCNT_dec(obj);
    self=newRV_noinc((SV *)hash);
    sv_setsv(sv, self);
    SvREFCNT_dec((SV *)self);
    sv_bless(sv, stash);
  }
  else {
    sv_setref_pv(sv, (char *) t->name, ptr);
  }
}

static SWIGINLINE SV *
SWIG_Perl_NewPointerObj(SWIG_MAYBE_PERL_OBJECT void *ptr, swig_type_info *t, int flags) {
  SV *result = sv_newmortal();
  SWIG_MakePtr(result, ptr, t, flags);
  return result;
}

static void
  SWIG_Perl_MakePackedObj(SWIG_MAYBE_PERL_OBJECT SV *sv, void *ptr, int sz, swig_type_info *type) {
  char result[1024];
  char *r = result;
  if ((2*sz + 1 + strlen(type->name)) > 1000) return;
  *(r++) = '_';
  r = SWIG_PackData(r,ptr,sz);
  strcpy(r,type->name);
  sv_setpv(sv, result);
}

/* Convert a packed value value */
static int
SWIG_Perl_ConvertPacked(SWIG_MAYBE_PERL_OBJECT SV *obj, void *ptr, int sz, swig_type_info *ty, int flags) {
  swig_cast_info *tc;
  const char  *c = 0;

  if ((!obj) || (!SvOK(obj))) return -1;
  c = SvPV(obj, PL_na);
  /* Pointer values must start with leading underscore */
  if (*c != '_') return -1;
  c++;
  c = SWIG_UnpackData(c,ptr,sz);
  if (ty) {
    tc = SWIG_TypeCheck(c,ty);
    if (!tc) return -1;
  }
  return 0;
}

static SWIGINLINE void
SWIG_Perl_SetError(SWIG_MAYBE_PERL_OBJECT const char *error) {
  if (error) sv_setpv(perl_get_sv("@", TRUE), error);
}

static SWIGINLINE void
SWIG_Perl_SetErrorSV(SWIG_MAYBE_PERL_OBJECT SV *error) {
  if (error) sv_setsv(perl_get_sv("@", TRUE), error);
}

static void
SWIG_Perl_SetErrorf(const char *fmt, ...) {
  va_list args;
  va_start(args, fmt);
  sv_vsetpvfn(perl_get_sv("@", TRUE), fmt, strlen(fmt), &args, Null(SV**), 0, Null(bool*));
  va_end(args);
}

/* Macros for low-level exception handling */
#define SWIG_fail       goto fail
#define SWIG_croak(x)   { SWIG_SetError(x); goto fail; }
#define SWIG_croakSV(x) { SWIG_SetErrorSV(x); goto fail; }
/* most preprocessors do not support vararg macros :-( */
/* #define SWIG_croakf(x...) { SWIG_SetErrorf(x); goto fail; } */


typedef XS(SwigPerlWrapper);
typedef SwigPerlWrapper *SwigPerlWrapperPtr;

/* Structure for command table */
typedef struct {
  const char         *name;
  SwigPerlWrapperPtr  wrapper;
} swig_command_info;

/* Information for constant table */

#define SWIG_INT     1
#define SWIG_FLOAT   2
#define SWIG_STRING  3
#define SWIG_POINTER 4
#define SWIG_BINARY  5

/* Constant information structure */
typedef struct swig_constant_info {
    int              type;
    const char      *name;
    long             lvalue;
    double           dvalue;
    void            *pvalue;
    swig_type_info **ptype;
} swig_constant_info;

#ifdef __cplusplus
}
#endif

/* Structure for variable table */
typedef struct {
  const char   *name;
  SwigMagicFunc   set;
  SwigMagicFunc   get;
  swig_type_info  **type;
} swig_variable_info;

/* Magic variable code */
#ifndef PERL_OBJECT
#define swig_create_magic(s,a,b,c) _swig_create_magic(s,a,b,c)
  #ifndef MULTIPLICITY
     static void _swig_create_magic(SV *sv, char *name, int (*set)(SV *, MAGIC *), int (*get)(SV *,MAGIC *)) {
  #else
     static void _swig_create_magic(SV *sv, char *name, int (*set)(struct interpreter*, SV *, MAGIC *), int (*get)(struct interpreter*, SV *,MAGIC *)) {
  #endif
#else
#  define swig_create_magic(s,a,b,c) _swig_create_magic(pPerl,s,a,b,c)
static void _swig_create_magic(CPerlObj *pPerl, SV *sv, const char *name, int (CPerlObj::*set)(SV *, MAGIC *), int (CPerlObj::*get)(SV *, MAGIC *)) {
#endif
  MAGIC *mg;
  sv_magic(sv,sv,'U',(char *) name,strlen(name));
  mg = mg_find(sv,'U');
  mg->mg_virtual = (MGVTBL *) malloc(sizeof(MGVTBL));
  mg->mg_virtual->svt_get = (SwigMagicFuncHack) get;
  mg->mg_virtual->svt_set = (SwigMagicFuncHack) set;
  mg->mg_virtual->svt_len = 0;
  mg->mg_virtual->svt_clear = 0;
  mg->mg_virtual->svt_free = 0;
}


static swig_module_info *
SWIG_Perl_GetModule() {
  static void *type_pointer = (void *)0;
  SV *pointer;

  /* first check if pointer already created */
  if (!type_pointer) {
    pointer = get_sv("swig_runtime_data::type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, FALSE);
    if (pointer && SvOK(pointer)) {
      type_pointer = INT2PTR(swig_type_info **, SvIV(pointer));
    }
  }

  return (swig_module_info *) type_pointer;
}

static void
SWIG_Perl_SetModule(swig_module_info *module) {
  SV *pointer;

  /* create a new pointer */
  pointer = get_sv("swig_runtime_data::type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, TRUE);
  sv_setiv(pointer, PTR2IV(module));
}


#ifdef do_open
  #undef do_open
#endif
#ifdef do_close
  #undef do_close
#endif
#ifdef scalar
  #undef scalar
#endif
#ifdef list
  #undef list
#endif
#ifdef apply
  #undef apply
#endif
#ifdef convert
  #undef convert
#endif
#ifdef Error
  #undef Error
#endif
#ifdef form
  #undef form
#endif
#ifdef vform
  #undef vform
#endif
#ifdef LABEL
  #undef LABEL
#endif
#ifdef METHOD
  #undef METHOD
#endif
#ifdef Move
  #undef Move
#endif
#ifdef yylex
  #undef yylex
#endif
#ifdef yyparse
  #undef yyparse
#endif
#ifdef yyerror
  #undef yyerror
#endif
#ifdef invert
  #undef invert
#endif
#ifdef ref
  #undef ref
#endif
#ifdef ENTER
  #undef ENTER
#endif
#ifdef read
  #undef read
#endif
#ifdef write
  #undef write
#endif
#ifdef eof
  #undef eof
#endif



/* -------- TYPES TABLE (BEGIN) -------- */

#define SWIGTYPE_p_apr_array_header_t swig_types[0]
#define SWIGTYPE_p_apr_file_t swig_types[1]
#define SWIGTYPE_p_apr_hash_t swig_types[2]
#define SWIGTYPE_p_apr_int32_t swig_types[3]
#define SWIGTYPE_p_apr_int64_t swig_types[4]
#define SWIGTYPE_p_apr_pool_t swig_types[5]
#define SWIGTYPE_p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void swig_types[6]
#define SWIGTYPE_p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t swig_types[7]
#define SWIGTYPE_p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t swig_types[8]
#define SWIGTYPE_p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t swig_types[9]
#define SWIGTYPE_p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t swig_types[10]
#define SWIGTYPE_p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t swig_types[11]
#define SWIGTYPE_p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t swig_types[12]
#define SWIGTYPE_p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t swig_types[13]
#define SWIGTYPE_p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t swig_types[14]
#define SWIGTYPE_p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t swig_types[15]
#define SWIGTYPE_p_f_p_void__p_svn_error_t swig_types[16]
#define SWIGTYPE_p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t swig_types[17]
#define SWIGTYPE_p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t swig_types[18]
#define SWIGTYPE_p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void swig_types[19]
#define SWIGTYPE_p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t swig_types[20]
#define SWIGTYPE_p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t swig_types[21]
#define SWIGTYPE_p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void swig_types[22]
#define SWIGTYPE_p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void swig_types[23]
#define SWIGTYPE_p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void swig_types[24]
#define SWIGTYPE_p_int swig_types[25]
#define SWIGTYPE_p_long swig_types[26]
#define SWIGTYPE_p_p_apr_array_header_t swig_types[27]
#define SWIGTYPE_p_p_apr_hash_t swig_types[28]
#define SWIGTYPE_p_p_char swig_types[29]
#define SWIGTYPE_p_p_svn_auth_provider_object_t swig_types[30]
#define SWIGTYPE_p_p_svn_client_commit_info_t swig_types[31]
#define SWIGTYPE_p_p_svn_client_ctx_t swig_types[32]
#define SWIGTYPE_p_p_svn_commit_info_t swig_types[33]
#define SWIGTYPE_p_p_svn_ra_session_t swig_types[34]
#define SWIGTYPE_p_p_svn_string_t swig_types[35]
#define SWIGTYPE_p_svn_auth_baton_t swig_types[36]
#define SWIGTYPE_p_svn_auth_cred_simple_t swig_types[37]
#define SWIGTYPE_p_svn_auth_cred_ssl_client_cert_pw_t swig_types[38]
#define SWIGTYPE_p_svn_auth_cred_ssl_client_cert_t swig_types[39]
#define SWIGTYPE_p_svn_auth_cred_ssl_server_trust_t swig_types[40]
#define SWIGTYPE_p_svn_auth_cred_username_t swig_types[41]
#define SWIGTYPE_p_svn_auth_iterstate_t swig_types[42]
#define SWIGTYPE_p_svn_auth_provider_object_t swig_types[43]
#define SWIGTYPE_p_svn_auth_provider_t swig_types[44]
#define SWIGTYPE_p_svn_auth_ssl_server_cert_info_t swig_types[45]
#define SWIGTYPE_p_svn_client_commit_info_t swig_types[46]
#define SWIGTYPE_p_svn_client_commit_item2_t swig_types[47]
#define SWIGTYPE_p_svn_client_commit_item_t swig_types[48]
#define SWIGTYPE_p_svn_client_ctx_t swig_types[49]
#define SWIGTYPE_p_svn_client_diff_summarize_kind_t swig_types[50]
#define SWIGTYPE_p_svn_client_diff_summarize_t swig_types[51]
#define SWIGTYPE_p_svn_client_proplist_item_t swig_types[52]
#define SWIGTYPE_p_svn_commit_info_t swig_types[53]
#define SWIGTYPE_p_svn_config_t swig_types[54]
#define SWIGTYPE_p_svn_delta_editor_t swig_types[55]
#define SWIGTYPE_p_svn_diff_datasource_e swig_types[56]
#define SWIGTYPE_p_svn_diff_file_ignore_space_t swig_types[57]
#define SWIGTYPE_p_svn_diff_file_options_t swig_types[58]
#define SWIGTYPE_p_svn_diff_fns_t swig_types[59]
#define SWIGTYPE_p_svn_diff_output_fns_t swig_types[60]
#define SWIGTYPE_p_svn_diff_t swig_types[61]
#define SWIGTYPE_p_svn_dirent_t swig_types[62]
#define SWIGTYPE_p_svn_errno_t swig_types[63]
#define SWIGTYPE_p_svn_error_t swig_types[64]
#define SWIGTYPE_p_svn_info_t swig_types[65]
#define SWIGTYPE_p_svn_io_dirent_t swig_types[66]
#define SWIGTYPE_p_svn_io_file_del_t swig_types[67]
#define SWIGTYPE_p_svn_lock_t swig_types[68]
#define SWIGTYPE_p_svn_log_changed_path_t swig_types[69]
#define SWIGTYPE_p_svn_node_kind_t swig_types[70]
#define SWIGTYPE_p_svn_opt_revision_t swig_types[71]
#define SWIGTYPE_p_svn_opt_revision_value_t swig_types[72]
#define SWIGTYPE_p_svn_opt_subcommand_desc2_t swig_types[73]
#define SWIGTYPE_p_svn_opt_subcommand_desc_t swig_types[74]
#define SWIGTYPE_p_svn_prop_kind swig_types[75]
#define SWIGTYPE_p_svn_prop_t swig_types[76]
#define SWIGTYPE_p_svn_ra_callbacks2_t swig_types[77]
#define SWIGTYPE_p_svn_ra_callbacks_t swig_types[78]
#define SWIGTYPE_p_svn_ra_plugin_t swig_types[79]
#define SWIGTYPE_p_svn_ra_reporter2_t swig_types[80]
#define SWIGTYPE_p_svn_ra_reporter_t swig_types[81]
#define SWIGTYPE_p_svn_ra_session_t swig_types[82]
#define SWIGTYPE_p_svn_stream_t swig_types[83]
#define SWIGTYPE_p_svn_string_t swig_types[84]
#define SWIGTYPE_p_svn_stringbuf_t swig_types[85]
#define SWIGTYPE_p_svn_txdelta_op_t swig_types[86]
#define SWIGTYPE_p_svn_txdelta_stream_t swig_types[87]
#define SWIGTYPE_p_svn_txdelta_window_t swig_types[88]
#define SWIGTYPE_p_svn_version_checklist_t swig_types[89]
#define SWIGTYPE_p_svn_version_t swig_types[90]
#define SWIGTYPE_p_svn_wc_adm_access_t swig_types[91]
#define SWIGTYPE_p_svn_wc_diff_callbacks2_t swig_types[92]
#define SWIGTYPE_p_svn_wc_diff_callbacks_t swig_types[93]
#define SWIGTYPE_p_svn_wc_entry_callbacks_t swig_types[94]
#define SWIGTYPE_p_svn_wc_entry_t swig_types[95]
#define SWIGTYPE_p_svn_wc_external_item_t swig_types[96]
#define SWIGTYPE_p_svn_wc_merge_outcome_t swig_types[97]
#define SWIGTYPE_p_svn_wc_notify_action_t swig_types[98]
#define SWIGTYPE_p_svn_wc_notify_lock_state_t swig_types[99]
#define SWIGTYPE_p_svn_wc_notify_state_t swig_types[100]
#define SWIGTYPE_p_svn_wc_notify_t swig_types[101]
#define SWIGTYPE_p_svn_wc_revision_status_t swig_types[102]
#define SWIGTYPE_p_svn_wc_schedule_t swig_types[103]
#define SWIGTYPE_p_svn_wc_status2_t swig_types[104]
#define SWIGTYPE_p_svn_wc_status_t swig_types[105]
#define SWIGTYPE_p_svn_wc_traversal_info_t swig_types[106]
#define SWIGTYPE_p_void swig_types[107]
static swig_type_info *swig_types[108];
static swig_module_info swig_module = {swig_types, 108, 0, 0, 0, 0};
#define SWIG_TypeQuery(name) SWIG_TypeQueryModule(&swig_module, &swig_module, name)
#define SWIG_MangledTypeQuery(name) SWIG_MangledTypeQueryModule(&swig_module, &swig_module, name)

/* -------- TYPES TABLE (END) -------- */

#define SWIG_init    boot_SVN___Client

#define SWIG_name   "SVN::_Client::boot_SVN___Client"
#define SWIG_prefix "SVN::_Client::"

#ifdef __cplusplus
extern "C"
#endif
#ifndef PERL_OBJECT
#ifndef MULTIPLICITY
SWIGEXPORT void SWIG_init (CV* cv);
#else
SWIGEXPORT void SWIG_init (pTHXo_ CV* cv);
#endif
#else
SWIGEXPORT void SWIG_init (CV *cv, CPerlObj *);
#endif


#include "svn_time.h"
#include "svn_pools.h"


#ifdef SWIGPYTHON
#include "swigutil_py.h"
#endif

#ifdef SWIGPERL
#include "swigutil_pl.h"
#endif

#ifdef SWIGRUBY
#include <apu.h>
#include <apr_xlate.h>
#include "swigutil_rb.h"
#endif


#include "svn_client.h"



#ifdef PERL_OBJECT
#define MAGIC_CLASS _wrap_SVN::_Client_var::
class _wrap_SVN::_Client_var : public CPerlObj {
public:
#else
#define MAGIC_CLASS
#endif
SWIGCLASS_STATIC int swig_magic_readonly(pTHX_ SV *sv, MAGIC *mg) {
    MAGIC_PPERL
    sv = sv; mg = mg;
    croak("Value is read-only.");
    return 0;
}


#ifdef PERL_OBJECT
};
#endif

#ifdef __cplusplus
extern "C" {
#endif
XS(_wrap_svn_client_version) {
    {
        svn_version_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: svn_client_version();");
        }
        {
            result = (svn_version_t *)svn_client_version();
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_version_t, SWIG_SHADOW|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_simple_prompt_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        svn_auth_simple_prompt_func_t arg2 = (svn_auth_simple_prompt_func_t) 0 ;
        void *arg3 = (void *) 0 ;
        int arg4 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        SV *_global_callback ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_get_simple_prompt_provider(prompt_func,prompt_baton,retry_limit,pool);");
        }
        {
            arg2 = svn_swig_pl_thunk_simple_prompt;
            _global_callback = ST(0);
            arg3 = (void *) _global_callback;
        }
        arg4 = (int) SvIV(ST(1));
        if (items > 2) {
            
        }
        {
            svn_client_get_simple_prompt_provider(arg1,arg2,arg3,arg4,arg5);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_username_prompt_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        svn_auth_username_prompt_func_t arg2 = (svn_auth_username_prompt_func_t) 0 ;
        void *arg3 = (void *) 0 ;
        int arg4 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        SV *_global_callback ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_get_username_prompt_provider(prompt_func,prompt_baton,retry_limit,pool);");
        }
        {
            arg2 = svn_swig_pl_thunk_username_prompt;
            _global_callback = ST(0);
            arg3 = (void *) _global_callback;
        }
        arg4 = (int) SvIV(ST(1));
        if (items > 2) {
            
        }
        {
            svn_client_get_username_prompt_provider(arg1,arg2,arg3,arg4,arg5);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_simple_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 0) || (items > 1)) {
            SWIG_croak("Usage: svn_client_get_simple_provider(pool);");
        }
        if (items > 0) {
            
        }
        {
            svn_client_get_simple_provider(arg1,arg2);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_username_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 0) || (items > 1)) {
            SWIG_croak("Usage: svn_client_get_username_provider(pool);");
        }
        if (items > 0) {
            
        }
        {
            svn_client_get_username_provider(arg1,arg2);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_ssl_server_trust_file_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 0) || (items > 1)) {
            SWIG_croak("Usage: svn_client_get_ssl_server_trust_file_provider(pool);");
        }
        if (items > 0) {
            
        }
        {
            svn_client_get_ssl_server_trust_file_provider(arg1,arg2);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_ssl_client_cert_file_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 0) || (items > 1)) {
            SWIG_croak("Usage: svn_client_get_ssl_client_cert_file_provider(pool);");
        }
        if (items > 0) {
            
        }
        {
            svn_client_get_ssl_client_cert_file_provider(arg1,arg2);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_ssl_client_cert_pw_file_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 0) || (items > 1)) {
            SWIG_croak("Usage: svn_client_get_ssl_client_cert_pw_file_provider(pool);");
        }
        if (items > 0) {
            
        }
        {
            svn_client_get_ssl_client_cert_pw_file_provider(arg1,arg2);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_ssl_server_trust_prompt_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        svn_auth_ssl_server_trust_prompt_func_t arg2 = (svn_auth_ssl_server_trust_prompt_func_t) 0 ;
        void *arg3 = (void *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        SV *_global_callback ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 1) || (items > 2)) {
            SWIG_croak("Usage: svn_client_get_ssl_server_trust_prompt_provider(prompt_func,prompt_baton,pool);");
        }
        {
            arg2 = svn_swig_pl_thunk_ssl_server_trust_prompt;
            _global_callback = ST(0);
            arg3 = (void *) _global_callback;
        }
        if (items > 1) {
            
        }
        {
            svn_client_get_ssl_server_trust_prompt_provider(arg1,arg2,arg3,arg4);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_ssl_client_cert_prompt_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        svn_auth_ssl_client_cert_prompt_func_t arg2 = (svn_auth_ssl_client_cert_prompt_func_t) 0 ;
        void *arg3 = (void *) 0 ;
        int arg4 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        SV *_global_callback ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_get_ssl_client_cert_prompt_provider(prompt_func,prompt_baton,retry_limit,pool);");
        }
        {
            arg2 = svn_swig_pl_thunk_ssl_client_cert_prompt;
            _global_callback = ST(0);
            arg3 = (void *) _global_callback;
        }
        arg4 = (int) SvIV(ST(1));
        if (items > 2) {
            
        }
        {
            svn_client_get_ssl_client_cert_prompt_provider(arg1,arg2,arg3,arg4,arg5);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_get_ssl_client_cert_pw_prompt_provider) {
    {
        svn_auth_provider_object_t **arg1 = (svn_auth_provider_object_t **) 0 ;
        svn_auth_ssl_client_cert_pw_prompt_func_t arg2 = (svn_auth_ssl_client_cert_pw_prompt_func_t) 0 ;
        void *arg3 = (void *) 0 ;
        int arg4 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        apr_pool_t *_global_pool ;
        svn_auth_provider_object_t *temp1 ;
        SV *_global_callback ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_auth_provider_object_t **)&temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_get_ssl_client_cert_pw_prompt_provider(prompt_func,prompt_baton,retry_limit,pool);");
        }
        {
            arg2 = svn_swig_pl_thunk_ssl_client_cert_pw_prompt;
            _global_callback = ST(0);
            arg3 = (void *) _global_callback;
        }
        arg4 = (int) SvIV(ST(1));
        if (items > 2) {
            
        }
        {
            svn_client_get_ssl_client_cert_pw_prompt_provider(arg1,arg2,arg3,arg4,arg5);
            
            
            
            
        }
        
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_auth_provider_object_t,0);
        }
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist_item_t_node_name_set) {
    {
        svn_client_proplist_item_t *arg1 = (svn_client_proplist_item_t *) 0 ;
        svn_stringbuf_t *arg2 = (svn_stringbuf_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_proplist_item_t_node_name_set(self,node_name);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_proplist_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_proplist_item_t_node_name_set. Expected _p_svn_client_proplist_item_t");
            }
        }
        {
            apr_size_t len;
            char *buf;
            
            if (!SvOK(ST(1))) {
                arg2 = NULL;
            } else if (SvPOK(ST(1))) {
                buf = SvPV(ST(1), len);
                /* Another case of ugly pool handling, this should use the current
                           default pool, or make a new one if it doesn't exist yet */
                arg2 = svn_stringbuf_ncreate(buf,len,
                svn_swig_pl_make_pool ((SV *)NULL));
            } else {
                croak("Not a string");
            }
        }
        if (arg1) (arg1)->node_name = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist_item_t_node_name_get) {
    {
        svn_client_proplist_item_t *arg1 = (svn_client_proplist_item_t *) 0 ;
        svn_stringbuf_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_proplist_item_t_node_name_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_proplist_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_proplist_item_t_node_name_get. Expected _p_svn_client_proplist_item_t");
            }
        }
        result = (svn_stringbuf_t *) ((arg1)->node_name);
        
        {
            SV *sv = sv_newmortal();
            sv_setpvn(sv,result->data,result->len);
            ST(argvi) = sv;
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist_item_t_prop_hash_set) {
    {
        svn_client_proplist_item_t *arg1 = (svn_client_proplist_item_t *) 0 ;
        apr_hash_t *arg2 = (apr_hash_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_proplist_item_t_prop_hash_set(self,prop_hash);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_proplist_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_proplist_item_t_prop_hash_set. Expected _p_svn_client_proplist_item_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_apr_hash_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_proplist_item_t_prop_hash_set. Expected _p_apr_hash_t");
            }
        }
        if (arg1) (arg1)->prop_hash = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist_item_t_prop_hash_get) {
    {
        svn_client_proplist_item_t *arg1 = (svn_client_proplist_item_t *) 0 ;
        apr_hash_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_proplist_item_t_prop_hash_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_proplist_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_proplist_item_t_prop_hash_get. Expected _p_svn_client_proplist_item_t");
            }
        }
        result = (apr_hash_t *) ((arg1)->prop_hash);
        
        {
            ST(argvi) = svn_swig_pl_prophash_to_hash(result);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_client_proplist_item_t) {
    {
        svn_client_proplist_item_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_client_proplist_item_t();");
        }
        {
            result = (svn_client_proplist_item_t *)(svn_client_proplist_item_t *) calloc(1, sizeof(svn_client_proplist_item_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_proplist_item_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_client_proplist_item_t) {
    {
        svn_client_proplist_item_t *arg1 = (svn_client_proplist_item_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_client_proplist_item_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_proplist_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_client_proplist_item_t. Expected _p_svn_client_proplist_item_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist_item_dup) {
    {
        svn_client_proplist_item_t *arg1 = (svn_client_proplist_item_t *) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        svn_client_proplist_item_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 1) || (items > 2)) {
            SWIG_croak("Usage: svn_client_proplist_item_dup(item,pool);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_proplist_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_proplist_item_dup. Expected _p_svn_client_proplist_item_t");
            }
        }
        if (items > 1) {
            
        }
        {
            result = (svn_client_proplist_item_t *)svn_client_proplist_item_dup((struct svn_client_proplist_item_t const *)arg1,arg2);
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_proplist_item_t, SWIG_SHADOW|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_info_t_revision_set) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_info_t_revision_set(self,revision);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_info_t_revision_set. Expected _p_svn_client_commit_info_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->revision = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_info_t_revision_get) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_info_t_revision_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_info_t_revision_get. Expected _p_svn_client_commit_info_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->revision);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_info_t_date_set) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_info_t_date_set(self,date);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_info_t_date_set. Expected _p_svn_client_commit_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->date) free((char *)arg1->date);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->date = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_info_t_date_get) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_info_t_date_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_info_t_date_get. Expected _p_svn_client_commit_info_t");
            }
        }
        result = (char *) ((arg1)->date);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_info_t_author_set) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_info_t_author_set(self,author);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_info_t_author_set. Expected _p_svn_client_commit_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->author) free((char *)arg1->author);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->author = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_info_t_author_get) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_info_t_author_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_info_t_author_get. Expected _p_svn_client_commit_info_t");
            }
        }
        result = (char *) ((arg1)->author);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_client_commit_info_t) {
    {
        svn_client_commit_info_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_client_commit_info_t();");
        }
        {
            result = (svn_client_commit_info_t *)(svn_client_commit_info_t *) calloc(1, sizeof(svn_client_commit_info_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_commit_info_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_client_commit_info_t) {
    {
        svn_client_commit_info_t *arg1 = (svn_client_commit_info_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_client_commit_info_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_client_commit_info_t. Expected _p_svn_client_commit_info_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_path_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_path_set(self,path);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_path_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->path) free((char *)arg1->path);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->path = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_path_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_path_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_path_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (char *) ((arg1)->path);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_kind_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        svn_node_kind_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_kind_set(self,kind);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_kind_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        arg2 = (svn_node_kind_t) SvIV(ST(1));
        if (arg1) (arg1)->kind = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_kind_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        svn_node_kind_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_kind_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_kind_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (svn_node_kind_t) ((arg1)->kind);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_url_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_url_set(self,url);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_url_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->url) free((char *)arg1->url);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->url = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_url_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_url_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_url_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (char *) ((arg1)->url);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_revision_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_revision_set(self,revision);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_revision_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->revision = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_revision_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_revision_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_revision_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->revision);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_copyfrom_url_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_copyfrom_url_set(self,copyfrom_url);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_copyfrom_url_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            if (arg2) {
                arg1->copyfrom_url = (char const *) malloc(strlen(arg2)+1);
                strcpy((char*)arg1->copyfrom_url,arg2);
            } else {
                arg1->copyfrom_url = 0;
            }
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_copyfrom_url_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_copyfrom_url_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_copyfrom_url_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (char *) ((arg1)->copyfrom_url);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_copyfrom_rev_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_copyfrom_rev_set(self,copyfrom_rev);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_copyfrom_rev_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->copyfrom_rev = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_copyfrom_rev_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_copyfrom_rev_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_copyfrom_rev_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->copyfrom_rev);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_state_flags_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        apr_byte_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_state_flags_set(self,state_flags);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_state_flags_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        arg2 = (apr_byte_t) SvUV(ST(1));
        if (arg1) (arg1)->state_flags = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_state_flags_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        apr_byte_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_state_flags_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_state_flags_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result =  ((arg1)->state_flags);
        
        ST(argvi) = sv_newmortal();
        sv_setuv(ST(argvi++), (UV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_wcprop_changes_set) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_wcprop_changes_set(self,wcprop_changes);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_wcprop_changes_set. Expected _p_svn_client_commit_item2_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_apr_array_header_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_commit_item2_t_wcprop_changes_set. Expected _p_apr_array_header_t");
            }
        }
        if (arg1) (arg1)->wcprop_changes = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_t_wcprop_changes_get) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        apr_array_header_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item2_t_wcprop_changes_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_t_wcprop_changes_get. Expected _p_svn_client_commit_item2_t");
            }
        }
        result = (apr_array_header_t *) ((arg1)->wcprop_changes);
        
        {
            ST(argvi) = svn_swig_pl_convert_array(result,
            SWIGTYPE_p_svn_prop_t);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_client_commit_item2_t) {
    {
        svn_client_commit_item2_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_client_commit_item2_t();");
        }
        {
            result = (svn_client_commit_item2_t *)(svn_client_commit_item2_t *) calloc(1, sizeof(svn_client_commit_item2_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_commit_item2_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_client_commit_item2_t) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_client_commit_item2_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_client_commit_item2_t. Expected _p_svn_client_commit_item2_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item2_dup) {
    {
        svn_client_commit_item2_t *arg1 = (svn_client_commit_item2_t *) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        svn_client_commit_item2_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 1) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item2_dup(item,pool);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item2_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item2_dup. Expected _p_svn_client_commit_item2_t");
            }
        }
        if (items > 1) {
            
        }
        {
            result = (svn_client_commit_item2_t *)svn_client_commit_item2_dup((struct svn_client_commit_item2_t const *)arg1,arg2);
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_commit_item2_t, SWIG_SHADOW|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_path_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_path_set(self,path);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_path_set. Expected _p_svn_client_commit_item_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->path) free((char *)arg1->path);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->path = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_path_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_path_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_path_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result = (char *) ((arg1)->path);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_kind_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        svn_node_kind_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_kind_set(self,kind);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_kind_set. Expected _p_svn_client_commit_item_t");
            }
        }
        arg2 = (svn_node_kind_t) SvIV(ST(1));
        if (arg1) (arg1)->kind = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_kind_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        svn_node_kind_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_kind_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_kind_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result = (svn_node_kind_t) ((arg1)->kind);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_url_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_url_set(self,url);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_url_set. Expected _p_svn_client_commit_item_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->url) free((char *)arg1->url);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->url = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_url_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_url_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_url_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result = (char *) ((arg1)->url);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_revision_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_revision_set(self,revision);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_revision_set. Expected _p_svn_client_commit_item_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->revision = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_revision_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_revision_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_revision_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->revision);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_copyfrom_url_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_copyfrom_url_set(self,copyfrom_url);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_copyfrom_url_set. Expected _p_svn_client_commit_item_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            if (arg2) {
                arg1->copyfrom_url = (char const *) malloc(strlen(arg2)+1);
                strcpy((char*)arg1->copyfrom_url,arg2);
            } else {
                arg1->copyfrom_url = 0;
            }
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_copyfrom_url_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_copyfrom_url_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_copyfrom_url_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result = (char *) ((arg1)->copyfrom_url);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_state_flags_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        apr_byte_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_state_flags_set(self,state_flags);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_state_flags_set. Expected _p_svn_client_commit_item_t");
            }
        }
        arg2 = (apr_byte_t) SvUV(ST(1));
        if (arg1) (arg1)->state_flags = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_state_flags_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        apr_byte_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_state_flags_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_state_flags_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result =  ((arg1)->state_flags);
        
        ST(argvi) = sv_newmortal();
        sv_setuv(ST(argvi++), (UV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_wcprop_changes_set) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_commit_item_t_wcprop_changes_set(self,wcprop_changes);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_wcprop_changes_set. Expected _p_svn_client_commit_item_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_apr_array_header_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_commit_item_t_wcprop_changes_set. Expected _p_apr_array_header_t");
            }
        }
        if (arg1) (arg1)->wcprop_changes = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit_item_t_wcprop_changes_get) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        apr_array_header_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_commit_item_t_wcprop_changes_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_commit_item_t_wcprop_changes_get. Expected _p_svn_client_commit_item_t");
            }
        }
        result = (apr_array_header_t *) ((arg1)->wcprop_changes);
        
        {
            ST(argvi) = svn_swig_pl_convert_array(result,
            SWIGTYPE_p_svn_prop_t);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_client_commit_item_t) {
    {
        svn_client_commit_item_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_client_commit_item_t();");
        }
        {
            result = (svn_client_commit_item_t *)(svn_client_commit_item_t *) calloc(1, sizeof(svn_client_commit_item_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_commit_item_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_client_commit_item_t) {
    {
        svn_client_commit_item_t *arg1 = (svn_client_commit_item_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_client_commit_item_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_commit_item_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_client_commit_item_t. Expected _p_svn_client_commit_item_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_path_set) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_path_set(self,path);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_path_set. Expected _p_svn_client_diff_summarize_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->path) free((char *)arg1->path);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->path = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_path_get) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_path_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_path_get. Expected _p_svn_client_diff_summarize_t");
            }
        }
        result = (char *) ((arg1)->path);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_summarize_kind_set) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        svn_client_diff_summarize_kind_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_summarize_kind_set(self,summarize_kind);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_summarize_kind_set. Expected _p_svn_client_diff_summarize_t");
            }
        }
        arg2 = (svn_client_diff_summarize_kind_t) SvIV(ST(1));
        if (arg1) (arg1)->summarize_kind = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_summarize_kind_get) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        svn_client_diff_summarize_kind_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_summarize_kind_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_summarize_kind_get. Expected _p_svn_client_diff_summarize_t");
            }
        }
        result = (svn_client_diff_summarize_kind_t) ((arg1)->summarize_kind);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_prop_changed_set) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        svn_boolean_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_prop_changed_set(self,prop_changed);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_prop_changed_set. Expected _p_svn_client_diff_summarize_t");
            }
        }
        arg2 = (svn_boolean_t) SvIV(ST(1));
        if (arg1) (arg1)->prop_changed = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_prop_changed_get) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        svn_boolean_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_prop_changed_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_prop_changed_get. Expected _p_svn_client_diff_summarize_t");
            }
        }
        result = (svn_boolean_t) ((arg1)->prop_changed);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_node_kind_set) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        svn_node_kind_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_node_kind_set(self,node_kind);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_node_kind_set. Expected _p_svn_client_diff_summarize_t");
            }
        }
        arg2 = (svn_node_kind_t) SvIV(ST(1));
        if (arg1) (arg1)->node_kind = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_t_node_kind_get) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        svn_node_kind_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_diff_summarize_t_node_kind_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_t_node_kind_get. Expected _p_svn_client_diff_summarize_t");
            }
        }
        result = (svn_node_kind_t) ((arg1)->node_kind);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_client_diff_summarize_t) {
    {
        svn_client_diff_summarize_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_client_diff_summarize_t();");
        }
        {
            result = (svn_client_diff_summarize_t *)(svn_client_diff_summarize_t *) calloc(1, sizeof(svn_client_diff_summarize_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_diff_summarize_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_client_diff_summarize_t) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_client_diff_summarize_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_client_diff_summarize_t. Expected _p_svn_client_diff_summarize_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_dup) {
    {
        svn_client_diff_summarize_t *arg1 = (svn_client_diff_summarize_t *) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        svn_client_diff_summarize_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 1) || (items > 2)) {
            SWIG_croak("Usage: svn_client_diff_summarize_dup(diff,pool);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_diff_summarize_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_diff_summarize_dup. Expected _p_svn_client_diff_summarize_t");
            }
        }
        if (items > 1) {
            
        }
        {
            result = (svn_client_diff_summarize_t *)svn_client_diff_summarize_dup((struct svn_client_diff_summarize_t const *)arg1,arg2);
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_diff_summarize_t, SWIG_SHADOW|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_auth_baton_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_auth_baton_t *arg2 = (svn_auth_baton_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_auth_baton_set(self,auth_baton);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_auth_baton_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_svn_auth_baton_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_auth_baton_set. Expected _p_svn_auth_baton_t");
            }
        }
        if (arg1) (arg1)->auth_baton = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_auth_baton_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_auth_baton_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_auth_baton_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_auth_baton_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_auth_baton_t *) ((arg1)->auth_baton);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_auth_baton_t, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_func_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_wc_notify_func_t arg2 = (svn_wc_notify_func_t) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_func_set(self,notify_func);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_func_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_notify_func_set. Expected _p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void");
            }
        }
        if (arg1) (arg1)->notify_func = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_func_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_wc_notify_func_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_func_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_func_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_wc_notify_func_t) ((arg1)->notify_func);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_baton_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *arg2 = (void *) 0 ;
        SV *_global_callback ;
        int argvi = 0;
        SV * _saved[1] ;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_baton_set(self,notify_baton);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_baton_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            _global_callback = ST(1);
            arg2 = (void *) _global_callback;
        }
        _saved[0] = ST(1);
        if (arg1) (arg1)->notify_baton = arg2;
        
        
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_baton_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_baton_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_baton_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (void *) ((arg1)->notify_baton);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_func_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_client_get_commit_log_t arg2 = (svn_client_get_commit_log_t) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_func_set(self,log_msg_func);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_func_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_log_msg_func_set. Expected _p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t");
            }
        }
        if (arg1) (arg1)->log_msg_func = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_func_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_client_get_commit_log_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_func_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_func_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_client_get_commit_log_t) ((arg1)->log_msg_func);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_baton_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *arg2 = (void *) 0 ;
        SV *_global_callback ;
        int argvi = 0;
        SV * _saved[1] ;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_baton_set(self,log_msg_baton);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_baton_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            _global_callback = ST(1);
            arg2 = (void *) _global_callback;
        }
        _saved[0] = ST(1);
        if (arg1) (arg1)->log_msg_baton = arg2;
        
        
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_baton_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_baton_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_baton_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (void *) ((arg1)->log_msg_baton);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_config_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        apr_hash_t *arg2 = (apr_hash_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_config_set(self,config);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_config_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            arg2 = svn_swig_pl_objs_to_hash_by_name (ST(1), "svn_config_t *",
            svn_swig_pl_make_pool ((SV *)NULL));
        }
        if (arg1) (arg1)->config = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_config_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        apr_hash_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_config_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_config_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (apr_hash_t *) ((arg1)->config);
        
        {
            ST(argvi) = svn_swig_pl_convert_hash(result, 
            SWIGTYPE_p_svn_config_t);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_cancel_func_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_cancel_func_t arg2 = (svn_cancel_func_t) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_cancel_func_set(self,cancel_func);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_cancel_func_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_f_p_void__p_svn_error_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_cancel_func_set. Expected _p_f_p_void__p_svn_error_t");
            }
        }
        if (arg1) (arg1)->cancel_func = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_cancel_func_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_cancel_func_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_cancel_func_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_cancel_func_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_cancel_func_t) ((arg1)->cancel_func);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_f_p_void__p_svn_error_t, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_cancel_baton_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *arg2 = (void *) 0 ;
        SV *_global_callback ;
        int argvi = 0;
        SV * _saved[1] ;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_cancel_baton_set(self,cancel_baton);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_cancel_baton_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            _global_callback = ST(1);
            arg2 = (void *) _global_callback;
        }
        _saved[0] = ST(1);
        if (arg1) (arg1)->cancel_baton = arg2;
        
        
        {
            /* callback baton */
            ST(argvi) = sv_2mortal (newRV_inc (_global_callback)); argvi++; 
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_cancel_baton_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_cancel_baton_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_cancel_baton_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (void *) ((arg1)->cancel_baton);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_func2_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_wc_notify_func2_t arg2 = (svn_wc_notify_func2_t) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_func2_set(self,notify_func2);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_func2_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_notify_func2_set. Expected _p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void");
            }
        }
        if (arg1) (arg1)->notify_func2 = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_func2_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_wc_notify_func2_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_func2_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_func2_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_wc_notify_func2_t) ((arg1)->notify_func2);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_baton2_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *arg2 = (void *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_baton2_set(self,notify_baton2);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_baton2_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_notify_baton2_set. Expected _p_void");
            }
        }
        if (arg1) (arg1)->notify_baton2 = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_notify_baton2_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_notify_baton2_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_notify_baton2_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (void *) ((arg1)->notify_baton2);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_func2_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_client_get_commit_log2_t arg2 = (svn_client_get_commit_log2_t) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_func2_set(self,log_msg_func2);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_func2_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_log_msg_func2_set. Expected _p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t");
            }
        }
        if (arg1) (arg1)->log_msg_func2 = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_func2_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_client_get_commit_log2_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_func2_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_func2_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_client_get_commit_log2_t) ((arg1)->log_msg_func2);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_baton2_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *arg2 = (void *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_baton2_set(self,log_msg_baton2);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_baton2_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_log_msg_baton2_set. Expected _p_void");
            }
        }
        if (arg1) (arg1)->log_msg_baton2 = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_log_msg_baton2_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_log_msg_baton2_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_log_msg_baton2_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (void *) ((arg1)->log_msg_baton2);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_progress_func_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_ra_progress_notify_func_t arg2 = (svn_ra_progress_notify_func_t) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_progress_func_set(self,progress_func);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_progress_func_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_progress_func_set. Expected _p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void");
            }
        }
        if (arg1) (arg1)->progress_func = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_progress_func_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        svn_ra_progress_notify_func_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_progress_func_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_progress_func_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (svn_ra_progress_notify_func_t) ((arg1)->progress_func);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_progress_baton_set) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *arg2 = (void *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_client_ctx_t_progress_baton_set(self,progress_baton);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_progress_baton_set. Expected _p_svn_client_ctx_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ctx_t_progress_baton_set. Expected _p_void");
            }
        }
        if (arg1) (arg1)->progress_baton = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ctx_t_progress_baton_get) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        void *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_client_ctx_t_progress_baton_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_ctx_t_progress_baton_get. Expected _p_svn_client_ctx_t");
            }
        }
        result = (void *) ((arg1)->progress_baton);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_client_ctx_t) {
    {
        svn_client_ctx_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_client_ctx_t();");
        }
        {
            result = (svn_client_ctx_t *)(svn_client_ctx_t *) calloc(1, sizeof(svn_client_ctx_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_client_ctx_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_client_ctx_t) {
    {
        svn_client_ctx_t *arg1 = (svn_client_ctx_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_client_ctx_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_client_ctx_t. Expected _p_svn_client_ctx_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_create_context) {
    {
        svn_client_ctx_t **arg1 = (svn_client_ctx_t **) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_ctx_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = &temp1;
        }
        if ((items < 0) || (items > 1)) {
            SWIG_croak("Usage: svn_client_create_context(pool);");
        }
        if (items > 0) {
            
        }
        {
            result = (svn_error_t *)svn_client_create_context(arg1,arg2);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            (*arg1)->notify_func = svn_swig_pl_notify_func;
            (*arg1)->notify_baton = (void *) &PL_sv_undef;
            (*arg1)->log_msg_func = svn_swig_pl_get_commit_log_func;
            (*arg1)->log_msg_baton = (void *) &PL_sv_undef;
            (*arg1)->cancel_func = svn_swig_pl_cancel_func;
            (*arg1)->cancel_baton = (void *) &PL_sv_undef;
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi), (void *)*arg1,
            SWIGTYPE_p_svn_client_ctx_t, 0);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_checkout2) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_client_ctx_t *arg8 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg9 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg9 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 7) || (items > 8)) {
            SWIG_croak("Usage: svn_client_checkout2(URL,path,peg_revision,revision,recurse,ignore_externals,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        arg7 = (svn_boolean_t) SvIV(ST(5));
        {
            if (SWIG_ConvertPtr(ST(6), (void **) &arg8, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 8 of svn_client_checkout2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 7) {
            
        }
        {
            result = (svn_error_t *)svn_client_checkout2(arg1,(char const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_checkout) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_checkout(URL,path,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_checkout. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_checkout(arg1,(char const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_update2) {
    {
        apr_array_header_t **arg1 = (apr_array_header_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg4 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_update2(result_revs,paths,revision,recurse,ignore_externals,ctx,pool);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_p_apr_array_header_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_client_update2. Expected _p_p_apr_array_header_t");
            }
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(1),
            _global_pool);
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (svn_boolean_t) SvIV(ST(3));
        arg5 = (svn_boolean_t) SvIV(ST(4));
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_update2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_update2(arg1,(apr_array_header_t const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_update) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_update(path,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_update. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_update(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_switch) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_switch(path,url,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_switch. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_switch(arg1,(char const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_add3) {
    {
        char *arg1 = (char *) 0 ;
        svn_boolean_t arg2 ;
        svn_boolean_t arg3 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_add3(path,recursive,force,no_ignore,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        arg2 = (svn_boolean_t) SvIV(ST(1));
        arg3 = (svn_boolean_t) SvIV(ST(2));
        arg4 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_add3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_add3((char const *)arg1,arg2,arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_add2) {
    {
        char *arg1 = (char *) 0 ;
        svn_boolean_t arg2 ;
        svn_boolean_t arg3 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_add2(path,recursive,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        arg2 = (svn_boolean_t) SvIV(ST(1));
        arg3 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_add2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_add2((char const *)arg1,arg2,arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_add) {
    {
        char *arg1 = (char *) 0 ;
        svn_boolean_t arg2 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_add(path,recursive,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        arg2 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_add. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_add((char const *)arg1,arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_mkdir2) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_mkdir2(paths,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_mkdir2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 2) {
            
        }
        {
            result = (svn_error_t *)svn_client_mkdir2(arg1,(apr_array_header_t const *)arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_mkdir) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_mkdir(paths,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_mkdir. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 2) {
            
        }
        {
            result = (svn_error_t *)svn_client_mkdir(arg1,(apr_array_header_t const *)arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_delete2) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg3 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_delete2(paths,force,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg3 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_delete2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_delete2(arg1,(apr_array_header_t const *)arg2,arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_delete) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg3 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_delete(paths,force,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg3 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_delete. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_delete(arg1,(apr_array_header_t const *)arg2,arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_import2) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_import2(path,url,nonrecursive,no_ignore,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(2));
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_import2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_import2(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_import) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_import(path,url,nonrecursive,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_import. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_import(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit3) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg3 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_commit3(targets,recurse,keep_locks,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg3 = (svn_boolean_t) SvIV(ST(1));
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_commit3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_commit3(arg1,(apr_array_header_t const *)arg2,arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit2) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg3 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_commit2(targets,recurse,keep_locks,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg3 = (svn_boolean_t) SvIV(ST(1));
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_commit2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_commit2(arg1,(apr_array_header_t const *)arg2,arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_commit) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        apr_array_header_t *arg2 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg3 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_commit(targets,nonrecursive,ctx,pool);");
        }
        {
            arg2 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg3 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_commit. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_commit(arg1,(apr_array_header_t const *)arg2,arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_status2) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_wc_status_func2_t arg4 = (svn_wc_status_func2_t) 0 ;
        void *arg5 = (void *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        svn_boolean_t arg10 ;
        svn_client_ctx_t *arg11 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg12 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg12 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 10) || (items > 11)) {
            SWIG_croak("Usage: svn_client_status2(path,revision,status_func,status_baton,recurse,get_all,update,no_ignore,ignore_externals,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg4, SWIGTYPE_p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_status2. Expected _p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, 0,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_status2. Expected _p_void");
            }
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        arg7 = (svn_boolean_t) SvIV(ST(5));
        arg8 = (svn_boolean_t) SvIV(ST(6));
        arg9 = (svn_boolean_t) SvIV(ST(7));
        arg10 = (svn_boolean_t) SvIV(ST(8));
        {
            if (SWIG_ConvertPtr(ST(9), (void **) &arg11, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 11 of svn_client_status2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 10) {
            
        }
        {
            result = (svn_error_t *)svn_client_status2(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7,arg8,arg9,arg10,arg11,arg12);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_status) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_wc_status_func_t arg4 = (svn_wc_status_func_t) 0 ;
        void *arg5 = (void *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        svn_client_ctx_t *arg10 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg11 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg11 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 8) || (items > 9)) {
            SWIG_croak("Usage: svn_client_status(path,revision,status_func,status_baton,recurse,get_all,update,no_ignore,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = svn_swig_pl_status_func;
            arg5 = ST(2); /* our function is the baton. */
        }
        arg6 = (svn_boolean_t) SvIV(ST(3));
        arg7 = (svn_boolean_t) SvIV(ST(4));
        arg8 = (svn_boolean_t) SvIV(ST(5));
        arg9 = (svn_boolean_t) SvIV(ST(6));
        {
            if (SWIG_ConvertPtr(ST(7), (void **) &arg10, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_status. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 8) {
            
        }
        {
            result = (svn_error_t *)svn_client_status(arg1,(char const *)arg2,arg3,arg4,arg5,arg6,arg7,arg8,arg9,arg10,arg11);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_log3) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        int arg5 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_log_message_receiver_t arg8 = (svn_log_message_receiver_t) 0 ;
        void *arg9 = (void *) 0 ;
        svn_client_ctx_t *arg10 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg11 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg11 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 9) || (items > 10)) {
            SWIG_croak("Usage: svn_client_log3(targets,peg_revision,start,end,limit,discover_changed_paths,strict_node_history,receiver,receiver_baton,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (int) SvIV(ST(4));
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        {
            arg8 = svn_swig_pl_thunk_log_receiver;
            arg9 = (void *)ST(7);
        }
        {
            if (SWIG_ConvertPtr(ST(8), (void **) &arg10, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_log3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 9) {
            
        }
        {
            result = (svn_error_t *)svn_client_log3((apr_array_header_t const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7,arg8,arg9,arg10,arg11);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_log2) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        int arg4 ;
        svn_boolean_t arg5 ;
        svn_boolean_t arg6 ;
        svn_log_message_receiver_t arg7 = (svn_log_message_receiver_t) 0 ;
        void *arg8 = (void *) 0 ;
        svn_client_ctx_t *arg9 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg10 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg10 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 8) || (items > 9)) {
            SWIG_croak("Usage: svn_client_log2(targets,start,end,limit,discover_changed_paths,strict_node_history,receiver,receiver_baton,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (int) SvIV(ST(3));
        arg5 = (svn_boolean_t) SvIV(ST(4));
        arg6 = (svn_boolean_t) SvIV(ST(5));
        {
            arg7 = svn_swig_pl_thunk_log_receiver;
            arg8 = (void *)ST(6);
        }
        {
            if (SWIG_ConvertPtr(ST(7), (void **) &arg9, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 9 of svn_client_log2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 8) {
            
        }
        {
            result = (svn_error_t *)svn_client_log2((apr_array_header_t const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7,arg8,arg9,arg10);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_log) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg4 ;
        svn_boolean_t arg5 ;
        svn_log_message_receiver_t arg6 = (svn_log_message_receiver_t) 0 ;
        void *arg7 = (void *) 0 ;
        svn_client_ctx_t *arg8 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg9 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg9 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 7) || (items > 8)) {
            SWIG_croak("Usage: svn_client_log(targets,start,end,discover_changed_paths,strict_node_history,receiver,receiver_baton,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (svn_boolean_t) SvIV(ST(3));
        arg5 = (svn_boolean_t) SvIV(ST(4));
        {
            arg6 = svn_swig_pl_thunk_log_receiver;
            arg7 = (void *)ST(5);
        }
        {
            if (SWIG_ConvertPtr(ST(6), (void **) &arg8, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 8 of svn_client_log. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 7) {
            
        }
        {
            result = (svn_error_t *)svn_client_log((apr_array_header_t const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7,arg8,arg9);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_blame3) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_diff_file_options_t *arg5 = (svn_diff_file_options_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_client_blame_receiver_t arg7 = (svn_client_blame_receiver_t) 0 ;
        void *arg8 = (void *) 0 ;
        svn_client_ctx_t *arg9 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg10 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg10 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 8) || (items > 9)) {
            SWIG_croak("Usage: svn_client_blame3(path_or_url,peg_revision,start,end,diff_options,ignore_mime_type,receiver,receiver_baton,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg5, SWIGTYPE_p_svn_diff_file_options_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_blame3. Expected _p_svn_diff_file_options_t");
            }
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        {
            arg7 = svn_swig_pl_blame_func;
            arg8 = ST(6); /* our function is the baton. */
        }
        {
            if (SWIG_ConvertPtr(ST(7), (void **) &arg9, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 9 of svn_client_blame3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 8) {
            
        }
        {
            result = (svn_error_t *)svn_client_blame3((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_diff_file_options_t const *)arg5,arg6,arg7,arg8,arg9,arg10);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_blame2) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_client_blame_receiver_t arg5 = (svn_client_blame_receiver_t) 0 ;
        void *arg6 = (void *) 0 ;
        svn_client_ctx_t *arg7 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg8 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg8 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_blame2(path_or_url,peg_revision,start,end,receiver,receiver_baton,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = svn_swig_pl_blame_func;
            arg6 = ST(4); /* our function is the baton. */
        }
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg7, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_blame2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_blame2((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7,arg8);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_blame) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_client_blame_receiver_t arg4 = (svn_client_blame_receiver_t) 0 ;
        void *arg5 = (void *) 0 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_blame(path_or_url,start,end,receiver,receiver_baton,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = svn_swig_pl_blame_func;
            arg5 = ST(3); /* our function is the baton. */
        }
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_blame. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_blame((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff3) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        char *arg10 = (char *) 0 ;
        apr_file_t *arg11 = (apr_file_t *) 0 ;
        apr_file_t *arg12 = (apr_file_t *) 0 ;
        svn_client_ctx_t *arg13 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg14 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg14 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 13) || (items > 14)) {
            SWIG_croak("Usage: svn_client_diff3(diff_options,path1,revision1,path2,revision2,recurse,ignore_ancestry,no_diff_deleted,ignore_content_type,header_encoding,outfile,errfile,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(3))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(3), PL_na);
        {
            arg5 = &rev5;
            if (ST(4) == NULL || ST(4) == &PL_sv_undef || !SvOK(ST(4))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(4)) && sv_derived_from(ST(4), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(4), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(4))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(4));
            }
            else if (SvPOK(ST(4))) {
                char *input = SvPV_nolen(ST(4));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        if (!SvOK((SV*) ST(9))) arg10 = 0;
        else arg10 = (char *) SvPV(ST(9), PL_na);
        {
            arg11 = svn_swig_pl_make_file(ST(10), _global_pool);
        }
        {
            arg12 = svn_swig_pl_make_file(ST(11), _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(12), (void **) &arg13, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 13 of svn_client_diff3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 13) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff3((apr_array_header_t const *)arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9,(char const *)arg10,arg11,arg12,arg13,arg14);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff2) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        apr_file_t *arg10 = (apr_file_t *) 0 ;
        apr_file_t *arg11 = (apr_file_t *) 0 ;
        svn_client_ctx_t *arg12 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg13 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg13 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 12) || (items > 13)) {
            SWIG_croak("Usage: svn_client_diff2(diff_options,path1,revision1,path2,revision2,recurse,ignore_ancestry,no_diff_deleted,ignore_content_type,outfile,errfile,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(3))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(3), PL_na);
        {
            arg5 = &rev5;
            if (ST(4) == NULL || ST(4) == &PL_sv_undef || !SvOK(ST(4))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(4)) && sv_derived_from(ST(4), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(4), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(4))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(4));
            }
            else if (SvPOK(ST(4))) {
                char *input = SvPV_nolen(ST(4));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        {
            arg10 = svn_swig_pl_make_file(ST(9), _global_pool);
        }
        {
            arg11 = svn_swig_pl_make_file(ST(10), _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(11), (void **) &arg12, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 12 of svn_client_diff2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 12) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff2((apr_array_header_t const *)arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9,arg10,arg11,arg12,arg13);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        apr_file_t *arg9 = (apr_file_t *) 0 ;
        apr_file_t *arg10 = (apr_file_t *) 0 ;
        svn_client_ctx_t *arg11 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg12 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg12 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 11) || (items > 12)) {
            SWIG_croak("Usage: svn_client_diff(diff_options,path1,revision1,path2,revision2,recurse,ignore_ancestry,no_diff_deleted,outfile,errfile,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(3))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(3), PL_na);
        {
            arg5 = &rev5;
            if (ST(4) == NULL || ST(4) == &PL_sv_undef || !SvOK(ST(4))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(4)) && sv_derived_from(ST(4), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(4), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(4))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(4));
            }
            else if (SvPOK(ST(4))) {
                char *input = SvPV_nolen(ST(4));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        {
            arg9 = svn_swig_pl_make_file(ST(8), _global_pool);
        }
        {
            arg10 = svn_swig_pl_make_file(ST(9), _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(10), (void **) &arg11, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 11 of svn_client_diff. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 11) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff((apr_array_header_t const *)arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9,arg10,arg11,arg12);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_peg3) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        char *arg10 = (char *) 0 ;
        apr_file_t *arg11 = (apr_file_t *) 0 ;
        apr_file_t *arg12 = (apr_file_t *) 0 ;
        svn_client_ctx_t *arg13 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg14 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg14 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 13) || (items > 14)) {
            SWIG_croak("Usage: svn_client_diff_peg3(diff_options,path,peg_revision,start_revision,end_revision,recurse,ignore_ancestry,no_diff_deleted,ignore_content_type,header_encoding,outfile,errfile,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(4) == NULL || ST(4) == &PL_sv_undef || !SvOK(ST(4))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(4)) && sv_derived_from(ST(4), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(4), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(4))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(4));
            }
            else if (SvPOK(ST(4))) {
                char *input = SvPV_nolen(ST(4));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        if (!SvOK((SV*) ST(9))) arg10 = 0;
        else arg10 = (char *) SvPV(ST(9), PL_na);
        {
            arg11 = svn_swig_pl_make_file(ST(10), _global_pool);
        }
        {
            arg12 = svn_swig_pl_make_file(ST(11), _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(12), (void **) &arg13, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 13 of svn_client_diff_peg3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 13) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff_peg3((apr_array_header_t const *)arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9,(char const *)arg10,arg11,arg12,arg13,arg14);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_peg2) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        apr_file_t *arg10 = (apr_file_t *) 0 ;
        apr_file_t *arg11 = (apr_file_t *) 0 ;
        svn_client_ctx_t *arg12 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg13 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg13 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 12) || (items > 13)) {
            SWIG_croak("Usage: svn_client_diff_peg2(diff_options,path,peg_revision,start_revision,end_revision,recurse,ignore_ancestry,no_diff_deleted,ignore_content_type,outfile,errfile,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(4) == NULL || ST(4) == &PL_sv_undef || !SvOK(ST(4))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(4)) && sv_derived_from(ST(4), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(4), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(4))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(4));
            }
            else if (SvPOK(ST(4))) {
                char *input = SvPV_nolen(ST(4));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        {
            arg10 = svn_swig_pl_make_file(ST(9), _global_pool);
        }
        {
            arg11 = svn_swig_pl_make_file(ST(10), _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(11), (void **) &arg12, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 12 of svn_client_diff_peg2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 12) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff_peg2((apr_array_header_t const *)arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9,arg10,arg11,arg12,arg13);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_peg) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        apr_file_t *arg9 = (apr_file_t *) 0 ;
        apr_file_t *arg10 = (apr_file_t *) 0 ;
        svn_client_ctx_t *arg11 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg12 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg12 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 11) || (items > 12)) {
            SWIG_croak("Usage: svn_client_diff_peg(diff_options,path,peg_revision,start_revision,end_revision,recurse,ignore_ancestry,no_diff_deleted,outfile,errfile,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(4) == NULL || ST(4) == &PL_sv_undef || !SvOK(ST(4))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(4)) && sv_derived_from(ST(4), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(4), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(4))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(4));
            }
            else if (SvPOK(ST(4))) {
                char *input = SvPV_nolen(ST(4));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        {
            arg9 = svn_swig_pl_make_file(ST(8), _global_pool);
        }
        {
            arg10 = svn_swig_pl_make_file(ST(9), _global_pool);
        }
        {
            if (SWIG_ConvertPtr(ST(10), (void **) &arg11, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 11 of svn_client_diff_peg. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 11) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff_peg((apr_array_header_t const *)arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,arg9,arg10,arg11,arg12);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_boolean_t arg6 ;
        svn_client_diff_summarize_func_t arg7 = (svn_client_diff_summarize_func_t) 0 ;
        void *arg8 = (void *) 0 ;
        svn_client_ctx_t *arg9 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg10 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg10 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 9) || (items > 10)) {
            SWIG_croak("Usage: svn_client_diff_summarize(path1,revision1,path2,revision2,recurse,ignore_ancestry,summarize_func,summarize_baton,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(4));
        arg6 = (svn_boolean_t) SvIV(ST(5));
        {
            if (SWIG_ConvertPtr(ST(6), (void **) &arg7, SWIGTYPE_p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_diff_summarize. Expected _p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(7), (void **) &arg8, 0,0) < 0) {
                SWIG_croak("Type error in argument 8 of svn_client_diff_summarize. Expected _p_void");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(8), (void **) &arg9, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 9 of svn_client_diff_summarize. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 9) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff_summarize((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7,arg8,arg9,arg10);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_diff_summarize_peg) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_boolean_t arg6 ;
        svn_client_diff_summarize_func_t arg7 = (svn_client_diff_summarize_func_t) 0 ;
        void *arg8 = (void *) 0 ;
        svn_client_ctx_t *arg9 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg10 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg10 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 9) || (items > 10)) {
            SWIG_croak("Usage: svn_client_diff_summarize_peg(path,peg_revision,start_revision,end_revision,recurse,ignore_ancestry,summarize_func,summarize_baton,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(4));
        arg6 = (svn_boolean_t) SvIV(ST(5));
        {
            if (SWIG_ConvertPtr(ST(6), (void **) &arg7, SWIGTYPE_p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_diff_summarize_peg. Expected _p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(7), (void **) &arg8, 0,0) < 0) {
                SWIG_croak("Type error in argument 8 of svn_client_diff_summarize_peg. Expected _p_void");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(8), (void **) &arg9, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 9 of svn_client_diff_summarize_peg. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 9) {
            
        }
        {
            result = (svn_error_t *)svn_client_diff_summarize_peg((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7,arg8,arg9,arg10);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_merge2) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        char *arg5 = (char *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        apr_array_header_t *arg10 = (apr_array_header_t *) 0 ;
        svn_client_ctx_t *arg11 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg12 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg12 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 11) || (items > 12)) {
            SWIG_croak("Usage: svn_client_merge2(source1,revision1,source2,revision2,target_wcpath,recurse,ignore_ancestry,force,dry_run,merge_options,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(4))) arg5 = 0;
        else arg5 = (char *) SvPV(ST(4), PL_na);
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        {
            if (SWIG_ConvertPtr(ST(9), (void **) &arg10, SWIGTYPE_p_apr_array_header_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_merge2. Expected _p_apr_array_header_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(10), (void **) &arg11, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 11 of svn_client_merge2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 11) {
            
        }
        {
            result = (svn_error_t *)svn_client_merge2((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,(char const *)arg5,arg6,arg7,arg8,arg9,(apr_array_header_t const *)arg10,arg11,arg12);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_merge) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        char *arg5 = (char *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        svn_client_ctx_t *arg10 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg11 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg11 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 10) || (items > 11)) {
            SWIG_croak("Usage: svn_client_merge(source1,revision1,source2,revision2,target_wcpath,recurse,ignore_ancestry,force,dry_run,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(4))) arg5 = 0;
        else arg5 = (char *) SvPV(ST(4), PL_na);
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        {
            if (SWIG_ConvertPtr(ST(9), (void **) &arg10, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_merge. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 10) {
            
        }
        {
            result = (svn_error_t *)svn_client_merge((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,(char const *)arg5,arg6,arg7,arg8,arg9,arg10,arg11);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_merge_peg2) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        char *arg5 = (char *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        apr_array_header_t *arg10 = (apr_array_header_t *) 0 ;
        svn_client_ctx_t *arg11 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg12 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg12 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 11) || (items > 12)) {
            SWIG_croak("Usage: svn_client_merge_peg2(source,revision1,revision2,peg_revision,target_wcpath,recurse,ignore_ancestry,force,dry_run,merge_options,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(4))) arg5 = 0;
        else arg5 = (char *) SvPV(ST(4), PL_na);
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        {
            if (SWIG_ConvertPtr(ST(9), (void **) &arg10, SWIGTYPE_p_apr_array_header_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_merge_peg2. Expected _p_apr_array_header_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(10), (void **) &arg11, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 11 of svn_client_merge_peg2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 11) {
            
        }
        {
            result = (svn_error_t *)svn_client_merge_peg2((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,(char const *)arg5,arg6,arg7,arg8,arg9,(apr_array_header_t const *)arg10,arg11,arg12);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_merge_peg) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        char *arg5 = (char *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        svn_boolean_t arg9 ;
        svn_client_ctx_t *arg10 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg11 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg11 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 10) || (items > 11)) {
            SWIG_croak("Usage: svn_client_merge_peg(source,revision1,revision2,peg_revision,target_wcpath,recurse,ignore_ancestry,force,dry_run,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(4))) arg5 = 0;
        else arg5 = (char *) SvPV(ST(4), PL_na);
        arg6 = (svn_boolean_t) SvIV(ST(5));
        arg7 = (svn_boolean_t) SvIV(ST(6));
        arg8 = (svn_boolean_t) SvIV(ST(7));
        arg9 = (svn_boolean_t) SvIV(ST(8));
        {
            if (SWIG_ConvertPtr(ST(9), (void **) &arg10, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_merge_peg. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 10) {
            
        }
        {
            result = (svn_error_t *)svn_client_merge_peg((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,(char const *)arg5,arg6,arg7,arg8,arg9,arg10,arg11);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_cleanup) {
    {
        char *arg1 = (char *) 0 ;
        svn_client_ctx_t *arg2 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg3 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg3 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_cleanup(dir,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_cleanup. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 2) {
            
        }
        {
            result = (svn_error_t *)svn_client_cleanup((char const *)arg1,arg2,arg3);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_relocate) {
    {
        char *arg1 = (char *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_relocate(dir,from,to,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_relocate. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_relocate((char const *)arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_revert) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg2 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_revert(paths,recursive,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg2 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_revert. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_revert((apr_array_header_t const *)arg1,arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_resolved) {
    {
        char *arg1 = (char *) 0 ;
        svn_boolean_t arg2 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_resolved(path,recursive,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        arg2 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_resolved. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_resolved((char const *)arg1,arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_copy3) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_copy3(src_path,src_revision,dst_path,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(2), PL_na);
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_copy3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_copy3(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_copy2) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_copy2(src_path,src_revision,dst_path,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(2), PL_na);
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_copy2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_copy2(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_copy) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_copy(src_path,src_revision,dst_path,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(2), PL_na);
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_copy. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_copy(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_move4) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_move4(src_path,dst_path,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_move4. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_move4(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_move3) {
    {
        svn_commit_info_t **arg1 = (svn_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_commit_info_t **)&temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_move3(src_path,dst_path,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_move3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_move3(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_commit_info_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_move2) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_move2(src_path,dst_path,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_move2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_move2(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_move) {
    {
        svn_client_commit_info_t **arg1 = (svn_client_commit_info_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        char *arg4 = (char *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_client_commit_info_t *temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            temp1 = NULL;
            arg1 = &temp1;
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_move(src_path,src_revision,dst_path,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        if (!SvOK((SV*) ST(2))) arg4 = 0;
        else arg4 = (char *) SvPV(ST(2), PL_na);
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_move. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_move(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(char const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (arg1 == NULL) {
                ST(argvi) = &PL_sv_undef;
                argvi++;
            }  else {
                ST(argvi) = sv_newmortal();
                SWIG_MakePtr(ST(argvi), (void *)*arg1,
                SWIGTYPE_p_svn_client_commit_info_t, 0);
                argvi++;
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_propset2) {
    {
        char *arg1 = (char *) 0 ;
        svn_string_t *arg2 = (svn_string_t *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_string_t value2 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_propset2(propname,propval,target,recurse,skip_checks,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            if (SvOK(ST(1))) {
                value2.data = SvPV(ST(1), value2.len);
                arg2 = &value2;
            }
            else {
                arg2 = NULL;
            }
        }
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(3));
        arg5 = (svn_boolean_t) SvIV(ST(4));
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_propset2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_propset2((char const *)arg1,(struct svn_string_t const *)arg2,(char const *)arg3,arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_propset) {
    {
        char *arg1 = (char *) 0 ;
        svn_string_t *arg2 = (svn_string_t *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_boolean_t arg4 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_string_t value2 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_propset(propname,propval,target,recurse,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            if (SvOK(ST(1))) {
                value2.data = SvPV(ST(1), value2.len);
                arg2 = &value2;
            }
            else {
                arg2 = NULL;
            }
        }
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        arg4 = (svn_boolean_t) SvIV(ST(3));
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_propset((char const *)arg1,(struct svn_string_t const *)arg2,(char const *)arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_revprop_set) {
    {
        char *arg1 = (char *) 0 ;
        svn_string_t *arg2 = (svn_string_t *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_revnum_t *arg5 = (svn_revnum_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_client_ctx_t *arg7 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg8 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_string_t value2 ;
        svn_opt_revision_t rev4 ;
        long temp5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg8 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg5 = &temp5;
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_revprop_set(propname,propval,URL,revision,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            if (SvOK(ST(1))) {
                value2.data = SvPV(ST(1), value2.len);
                arg2 = &value2;
            }
            else {
                arg2 = NULL;
            }
        }
        if (!SvOK((SV*) ST(2))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(2), PL_na);
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg7, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_revprop_set. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_revprop_set((char const *)arg1,(struct svn_string_t const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7,arg8);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg5));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_propget2) {
    {
        apr_hash_t **arg1 = (apr_hash_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_client_ctx_t *arg7 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg8 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_hash_t *temp1 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg8 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_propget2(propname,target,peg_revision,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg7, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_propget2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_propget2(arg1,(char const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = svn_swig_pl_prophash_to_hash(*arg1);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_propget) {
    {
        apr_hash_t **arg1 = (apr_hash_t **) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_hash_t *temp1 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_propget(propname,target,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_propget. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_propget(arg1,(char const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = svn_swig_pl_prophash_to_hash(*arg1);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_revprop_get) {
    {
        char *arg1 = (char *) 0 ;
        svn_string_t **arg2 = (svn_string_t **) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_revnum_t *arg5 = (svn_revnum_t *) 0 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_string_t *temp2 ;
        svn_opt_revision_t rev4 ;
        long temp5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg2 = &temp2;
        }
        arg5 = &temp5;
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_revprop_get(propname,URL,revision,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_revprop_get. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_revprop_get((char const *)arg1,arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (*arg2) {
                ST(argvi) = sv_newmortal();
                sv_setpvn (ST(argvi), (*arg2)->data, (*arg2)->len);
            }
            else
            ST(argvi) = &PL_sv_undef;
            argvi++;
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg5));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist2) {
    {
        apr_array_header_t **arg1 = (apr_array_header_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_array_header_t *temp1 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = &temp1;
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_proplist2(target,peg_revision,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_proplist2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_proplist2(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = svn_swig_pl_convert_array(*arg1,
            SWIGTYPE_p_svn_client_proplist_item_t);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_proplist) {
    {
        apr_array_header_t **arg1 = (apr_array_header_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_array_header_t *temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = &temp1;
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_proplist(target,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_proplist. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_proplist(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = svn_swig_pl_convert_array(*arg1,
            SWIGTYPE_p_svn_client_proplist_item_t);
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_revprop_list) {
    {
        apr_hash_t **arg1 = (apr_hash_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_revnum_t *arg4 = (svn_revnum_t *) 0 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_hash_t *temp1 ;
        svn_opt_revision_t rev3 ;
        long temp4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        arg4 = &temp4;
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_revprop_list(URL,revision,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_revprop_list. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_revprop_list(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = svn_swig_pl_prophash_to_hash(*arg1);
            argvi++;
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg4));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_export3) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_boolean_t arg7 ;
        svn_boolean_t arg8 ;
        char *arg9 = (char *) 0 ;
        svn_client_ctx_t *arg10 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg11 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg11 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 9) || (items > 10)) {
            SWIG_croak("Usage: svn_client_export3(from,to,peg_revision,revision,overwrite,ignore_externals,recurse,native_eol,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        arg7 = (svn_boolean_t) SvIV(ST(5));
        arg8 = (svn_boolean_t) SvIV(ST(6));
        if (!SvOK((SV*) ST(7))) arg9 = 0;
        else arg9 = (char *) SvPV(ST(7), PL_na);
        {
            if (SWIG_ConvertPtr(ST(8), (void **) &arg10, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 10 of svn_client_export3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 9) {
            
        }
        {
            result = (svn_error_t *)svn_client_export3(arg1,(char const *)arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8,(char const *)arg9,arg10,arg11);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_export2) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        char *arg6 = (char *) 0 ;
        svn_client_ctx_t *arg7 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg8 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg8 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_export2(from,to,revision,force,native_eol,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        if (!SvOK((SV*) ST(4))) arg6 = 0;
        else arg6 = (char *) SvPV(ST(4), PL_na);
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg7, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_export2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_export2(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,(char const *)arg6,arg7,arg8);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_export) {
    {
        svn_revnum_t *arg1 = (svn_revnum_t *) 0 ;
        char *arg2 = (char *) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        long temp1 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_export(from,to,revision,force,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_export. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_export(arg1,(char const *)arg2,(char const *)arg3,arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (argvi >= items) {
                EXTEND(sp,1);
            }
            ST(argvi) = sv_newmortal();
            sv_setiv(ST(argvi),(IV) *(arg1));
            argvi++;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_list) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg4 ;
        apr_uint32_t arg5 ;
        svn_boolean_t arg6 ;
        svn_client_list_func_t arg7 = (svn_client_list_func_t) 0 ;
        void *arg8 = (void *) 0 ;
        svn_client_ctx_t *arg9 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg10 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg10 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 9) || (items > 10)) {
            SWIG_croak("Usage: svn_client_list(path_or_url,peg_revision,revision,recurse,dirent_fields,fetch_locks,list_func,baton,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (svn_boolean_t) SvIV(ST(3));
        arg5 = (apr_uint32_t) SvUV(ST(4));
        arg6 = (svn_boolean_t) SvIV(ST(5));
        {
            if (SWIG_ConvertPtr(ST(6), (void **) &arg7, SWIGTYPE_p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_list. Expected _p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(7), (void **) &arg8, 0,0) < 0) {
                SWIG_croak("Type error in argument 8 of svn_client_list. Expected _p_void");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(8), (void **) &arg9, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 9 of svn_client_list. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 9) {
            
        }
        {
            result = (svn_error_t *)svn_client_list((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7,arg8,arg9,arg10);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ls3) {
    {
        apr_hash_t **arg1 = (apr_hash_t **) 0 ;
        apr_hash_t **arg2 = (apr_hash_t **) 0 ;
        char *arg3 = (char *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg5 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg6 ;
        svn_client_ctx_t *arg7 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg8 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_hash_t *temp1 ;
        svn_opt_revision_t rev4 ;
        svn_opt_revision_t rev5 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg8 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_ls3(locks,path_or_url,peg_revision,revision,recurse,ctx,pool);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg2, SWIGTYPE_p_p_apr_hash_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_client_ls3. Expected _p_p_apr_hash_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg3 = 0;
        else arg3 = (char *) SvPV(ST(1), PL_na);
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg5 = &rev5;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev5.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg5, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev5.kind = svn_opt_revision_number;
                rev5.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev5.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev5.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev5.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev5.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev5.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev5.kind = svn_opt_revision_date;
                    rev5.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg7, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_ls3. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_ls3(arg1,arg2,(char const *)arg3,(struct svn_opt_revision_t const *)arg4,(struct svn_opt_revision_t const *)arg5,arg6,arg7,arg8);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi++) = svn_swig_pl_convert_hash
            (*arg1, SWIGTYPE_p_svn_dirent_t);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ls2) {
    {
        apr_hash_t **arg1 = (apr_hash_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg5 ;
        svn_client_ctx_t *arg6 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg7 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_hash_t *temp1 ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg7 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_ls2(path_or_url,peg_revision,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg5 = (svn_boolean_t) SvIV(ST(3));
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg6, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 6 of svn_client_ls2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_ls2(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6,arg7);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi++) = svn_swig_pl_convert_hash
            (*arg1, SWIGTYPE_p_svn_dirent_t);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_ls) {
    {
        apr_hash_t **arg1 = (apr_hash_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_boolean_t arg4 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        apr_hash_t *temp1 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = &temp1;
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_ls(path_or_url,revision,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            arg3 = &rev3;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        arg4 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_ls. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_ls(arg1,(char const *)arg2,arg3,arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi++) = svn_swig_pl_convert_hash
            (*arg1, SWIGTYPE_p_svn_dirent_t);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_cat2) {
    {
        svn_stream_t *arg1 = (svn_stream_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg4 = (svn_opt_revision_t *) 0 ;
        svn_client_ctx_t *arg5 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg6 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        svn_opt_revision_t rev4 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg6 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 5) || (items > 6)) {
            SWIG_croak("Usage: svn_client_cat2(out,path_or_url,peg_revision,revision,ctx,pool);");
        }
        {
            svn_swig_pl_make_stream (&arg1, ST(0));
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = &rev4;
            if (ST(3) == NULL || ST(3) == &PL_sv_undef || !SvOK(ST(3))) {
                rev4.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(3)) && sv_derived_from(ST(3), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(3), (void **)&arg4, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(3))) {
                rev4.kind = svn_opt_revision_number;
                rev4.value.number = SvIV(ST(3));
            }
            else if (SvPOK(ST(3))) {
                char *input = SvPV_nolen(ST(3));
                if (strcasecmp(input, "BASE") == 0)
                rev4.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev4.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev4.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev4.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev4.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev4.kind = svn_opt_revision_date;
                    rev4.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            if (SWIG_ConvertPtr(ST(4), (void **) &arg5, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 5 of svn_client_cat2. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 5) {
            
        }
        {
            result = (svn_error_t *)svn_client_cat2(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,(struct svn_opt_revision_t const *)arg4,arg5,arg6);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_cat) {
    {
        svn_stream_t *arg1 = (svn_stream_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_cat(out,path_or_url,revision,ctx,pool);");
        }
        {
            svn_swig_pl_make_stream (&arg1, ST(0));
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_cat. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_cat(arg1,(char const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_lock) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        char *arg2 = (char *) 0 ;
        svn_boolean_t arg3 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 4) || (items > 5)) {
            SWIG_croak("Usage: svn_client_lock(targets,comment,steal_lock,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        arg3 = (svn_boolean_t) SvIV(ST(2));
        {
            if (SWIG_ConvertPtr(ST(3), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_lock. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 4) {
            
        }
        {
            result = (svn_error_t *)svn_client_lock((apr_array_header_t const *)arg1,(char const *)arg2,arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_unlock) {
    {
        apr_array_header_t *arg1 = (apr_array_header_t *) 0 ;
        svn_boolean_t arg2 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_unlock(targets,break_lock,ctx,pool);");
        }
        {
            arg1 = (apr_array_header_t *) svn_swig_pl_strings_to_array(ST(0),
            _global_pool);
        }
        arg2 = (svn_boolean_t) SvIV(ST(1));
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_unlock. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_unlock((apr_array_header_t const *)arg1,arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_URL_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_URL_set(self,URL);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_URL_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->URL) free((char *)arg1->URL);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->URL = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_URL_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_URL_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_URL_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->URL);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_rev_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_rev_set(self,rev);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_rev_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->rev = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_rev_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_rev_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_rev_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->rev);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_kind_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_node_kind_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_kind_set(self,kind);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_kind_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (svn_node_kind_t) SvIV(ST(1));
        if (arg1) (arg1)->kind = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_kind_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_node_kind_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_kind_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_kind_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_node_kind_t) ((arg1)->kind);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_repos_root_URL_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_repos_root_URL_set(self,repos_root_URL);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_repos_root_URL_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->repos_root_URL) free((char *)arg1->repos_root_URL);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->repos_root_URL = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_repos_root_URL_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_repos_root_URL_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_repos_root_URL_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->repos_root_URL);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_repos_UUID_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_repos_UUID_set(self,repos_UUID);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_repos_UUID_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->repos_UUID) free((char *)arg1->repos_UUID);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->repos_UUID = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_repos_UUID_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_repos_UUID_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_repos_UUID_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->repos_UUID);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_last_changed_rev_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_last_changed_rev_set(self,last_changed_rev);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_last_changed_rev_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->last_changed_rev = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_last_changed_rev_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_last_changed_rev_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_last_changed_rev_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->last_changed_rev);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_last_changed_date_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_time_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_last_changed_date_set(self,last_changed_date);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_last_changed_date_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (apr_time_t) strtoll(SvPV(ST(1), PL_na), 0, 0);
        if (arg1) (arg1)->last_changed_date = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_last_changed_date_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_time_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_last_changed_date_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_last_changed_date_get. Expected _p_svn_info_t");
            }
        }
        result =  ((arg1)->last_changed_date);
        
        {
            char temp[256];
            sprintf(temp, "%" APR_INT64_T_FMT, (apr_int64_t) result);
            ST(argvi) = sv_newmortal();
            sv_setpv((SV*)ST(argvi++), temp);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_last_changed_author_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_last_changed_author_set(self,last_changed_author);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_last_changed_author_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->last_changed_author) free((char *)arg1->last_changed_author);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->last_changed_author = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_last_changed_author_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_last_changed_author_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_last_changed_author_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->last_changed_author);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_lock_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_lock_t *arg2 = (svn_lock_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_lock_set(self,lock);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_lock_set. Expected _p_svn_info_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_svn_lock_t,0) < 0) {
                SWIG_croak("Type error in argument 2 of svn_info_t_lock_set. Expected _p_svn_lock_t");
            }
        }
        if (arg1) (arg1)->lock = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_lock_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_lock_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_lock_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_lock_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_lock_t *) ((arg1)->lock);
        
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_lock_t, SWIG_SHADOW|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_has_wc_info_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_boolean_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_has_wc_info_set(self,has_wc_info);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_has_wc_info_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (svn_boolean_t) SvIV(ST(1));
        if (arg1) (arg1)->has_wc_info = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_has_wc_info_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_boolean_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_has_wc_info_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_has_wc_info_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_boolean_t) ((arg1)->has_wc_info);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_schedule_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_wc_schedule_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_schedule_set(self,schedule);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_schedule_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (svn_wc_schedule_t) SvIV(ST(1));
        if (arg1) (arg1)->schedule = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_schedule_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_wc_schedule_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_schedule_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_schedule_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_wc_schedule_t) ((arg1)->schedule);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_copyfrom_url_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_copyfrom_url_set(self,copyfrom_url);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_copyfrom_url_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            if (arg2) {
                arg1->copyfrom_url = (char const *) malloc(strlen(arg2)+1);
                strcpy((char*)arg1->copyfrom_url,arg2);
            } else {
                arg1->copyfrom_url = 0;
            }
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_copyfrom_url_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_copyfrom_url_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_copyfrom_url_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->copyfrom_url);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_copyfrom_rev_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_revnum_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_copyfrom_rev_set(self,copyfrom_rev);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_copyfrom_rev_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (svn_revnum_t) SvIV(ST(1));
        if (arg1) (arg1)->copyfrom_rev = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_copyfrom_rev_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        svn_revnum_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_copyfrom_rev_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_copyfrom_rev_get. Expected _p_svn_info_t");
            }
        }
        result = (svn_revnum_t) ((arg1)->copyfrom_rev);
        
        ST(argvi) = sv_newmortal();
        sv_setiv(ST(argvi++), (IV) result);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_text_time_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_time_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_text_time_set(self,text_time);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_text_time_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (apr_time_t) strtoll(SvPV(ST(1), PL_na), 0, 0);
        if (arg1) (arg1)->text_time = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_text_time_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_time_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_text_time_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_text_time_get. Expected _p_svn_info_t");
            }
        }
        result =  ((arg1)->text_time);
        
        {
            char temp[256];
            sprintf(temp, "%" APR_INT64_T_FMT, (apr_int64_t) result);
            ST(argvi) = sv_newmortal();
            sv_setpv((SV*)ST(argvi++), temp);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_prop_time_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_time_t arg2 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_prop_time_set(self,prop_time);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_prop_time_set. Expected _p_svn_info_t");
            }
        }
        arg2 = (apr_time_t) strtoll(SvPV(ST(1), PL_na), 0, 0);
        if (arg1) (arg1)->prop_time = arg2;
        
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_prop_time_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_time_t result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_prop_time_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_prop_time_get. Expected _p_svn_info_t");
            }
        }
        result =  ((arg1)->prop_time);
        
        {
            char temp[256];
            sprintf(temp, "%" APR_INT64_T_FMT, (apr_int64_t) result);
            ST(argvi) = sv_newmortal();
            sv_setpv((SV*)ST(argvi++), temp);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_checksum_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_checksum_set(self,checksum);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_checksum_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->checksum) free((char *)arg1->checksum);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->checksum = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_checksum_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_checksum_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_checksum_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->checksum);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_conflict_old_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_conflict_old_set(self,conflict_old);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_conflict_old_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->conflict_old) free((char *)arg1->conflict_old);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->conflict_old = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_conflict_old_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_conflict_old_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_conflict_old_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->conflict_old);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_conflict_new_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_conflict_new_set(self,conflict_new);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_conflict_new_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->conflict_new) free((char *)arg1->conflict_new);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->conflict_new = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_conflict_new_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_conflict_new_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_conflict_new_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->conflict_new);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_conflict_wrk_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_conflict_wrk_set(self,conflict_wrk);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_conflict_wrk_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->conflict_wrk) free((char *)arg1->conflict_wrk);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->conflict_wrk = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_conflict_wrk_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_conflict_wrk_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_conflict_wrk_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->conflict_wrk);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_prejfile_set) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *arg2 = (char *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 2) || (items > 2)) {
            SWIG_croak("Usage: svn_info_t_prejfile_set(self,prejfile);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_prejfile_set. Expected _p_svn_info_t");
            }
        }
        if (!SvOK((SV*) ST(1))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(1), PL_na);
        {
            apr_size_t len = strlen(arg2) + 1;
            char *copied;
            if (arg1->prejfile) free((char *)arg1->prejfile);
            copied = malloc(len);
            memcpy(copied, arg2, len);
            arg1->prejfile = copied;
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_t_prejfile_get) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        char *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: svn_info_t_prejfile_get(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_t_prejfile_get. Expected _p_svn_info_t");
            }
        }
        result = (char *) ((arg1)->prejfile);
        
        ST(argvi) = sv_newmortal();
        if (result) {
            sv_setpv((SV*)ST(argvi++), (char *) result);
        } else {
            sv_setsv((SV*)ST(argvi++), &PL_sv_undef);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_new_svn_info_t) {
    {
        svn_info_t *result;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 0) || (items > 0)) {
            SWIG_croak("Usage: new_svn_info_t();");
        }
        {
            result = (svn_info_t *)(svn_info_t *) calloc(1, sizeof(svn_info_t));
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_info_t, SWIG_SHADOW|SWIG_OWNER);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_delete_svn_info_t) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        int argvi = 0;
        dXSARGS;
        
        if ((items < 1) || (items > 1)) {
            SWIG_croak("Usage: delete_svn_info_t(self);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of delete_svn_info_t. Expected _p_svn_info_t");
            }
        }
        {
            free((char *) arg1);
            
            
            
            
        }
        
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_info_dup) {
    {
        svn_info_t *arg1 = (svn_info_t *) 0 ;
        apr_pool_t *arg2 = (apr_pool_t *) 0 ;
        svn_info_t *result;
        apr_pool_t *_global_pool ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg2 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 1) || (items > 2)) {
            SWIG_croak("Usage: svn_info_dup(info,pool);");
        }
        {
            if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_svn_info_t,0) < 0) {
                SWIG_croak("Type error in argument 1 of svn_info_dup. Expected _p_svn_info_t");
            }
        }
        if (items > 1) {
            
        }
        {
            result = (svn_info_t *)svn_info_dup((struct svn_info_t const *)arg1,arg2);
            
            
            
            
        }
        ST(argvi) = sv_newmortal();
        SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_svn_info_t, SWIG_SHADOW|0);
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_info) {
    {
        char *arg1 = (char *) 0 ;
        svn_opt_revision_t *arg2 = (svn_opt_revision_t *) 0 ;
        svn_opt_revision_t *arg3 = (svn_opt_revision_t *) 0 ;
        svn_info_receiver_t arg4 = (svn_info_receiver_t) 0 ;
        void *arg5 = (void *) 0 ;
        svn_boolean_t arg6 ;
        svn_client_ctx_t *arg7 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg8 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_opt_revision_t rev2 ;
        svn_opt_revision_t rev3 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg8 = svn_swig_pl_make_pool (ST(items-1));
        }
        if ((items < 6) || (items > 7)) {
            SWIG_croak("Usage: svn_client_info(path_or_url,peg_revision,revision,receiver,receiver_baton,recurse,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg1 = 0;
        else arg1 = (char *) SvPV(ST(0), PL_na);
        {
            arg2 = &rev2;
            if (ST(1) == NULL || ST(1) == &PL_sv_undef || !SvOK(ST(1))) {
                rev2.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(1)) && sv_derived_from(ST(1), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(1), (void **)&arg2, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(1))) {
                rev2.kind = svn_opt_revision_number;
                rev2.value.number = SvIV(ST(1));
            }
            else if (SvPOK(ST(1))) {
                char *input = SvPV_nolen(ST(1));
                if (strcasecmp(input, "BASE") == 0)
                rev2.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev2.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev2.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev2.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev2.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev2.kind = svn_opt_revision_date;
                    rev2.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg3 = &rev3;
            if (ST(2) == NULL || ST(2) == &PL_sv_undef || !SvOK(ST(2))) {
                rev3.kind = svn_opt_revision_unspecified;
            }
            else if (sv_isobject(ST(2)) && sv_derived_from(ST(2), "_p_svn_opt_revision_t")) {
                SWIG_ConvertPtr(ST(2), (void **)&arg3, SWIGTYPE_p_svn_opt_revision_t, 0);
            }
            else if (looks_like_number(ST(2))) {
                rev3.kind = svn_opt_revision_number;
                rev3.value.number = SvIV(ST(2));
            }
            else if (SvPOK(ST(2))) {
                char *input = SvPV_nolen(ST(2));
                if (strcasecmp(input, "BASE") == 0)
                rev3.kind = svn_opt_revision_base;
                else if (strcasecmp(input, "HEAD") == 0)
                rev3.kind = svn_opt_revision_head;
                else if (strcasecmp(input, "WORKING") == 0)
                rev3.kind = svn_opt_revision_working;
                else if (strcasecmp(input, "COMMITTED") == 0)
                rev3.kind = svn_opt_revision_committed;
                else if (strcasecmp(input, "PREV") == 0)
                rev3.kind = svn_opt_revision_previous;
                else if (*input == '{') {
                    svn_boolean_t matched;
                    apr_time_t tm;
                    svn_error_t *err;
                    
                    char *end = strchr(input,'}');
                    if (!end)
                    SWIG_croak("unknown opt_revision_t type");
                    *end = '\0';
                    err = svn_parse_date (&matched, &tm, input + 1, apr_time_now(),
                    svn_swig_pl_make_pool ((SV *)NULL));
                    if (err) {
                        svn_error_clear (err);
                        SWIG_croak("unknown opt_revision_t type");
                    }
                    if (!matched)
                    SWIG_croak("unknown opt_revision_t type");
                    
                    rev3.kind = svn_opt_revision_date;
                    rev3.value.date = tm;
                } else
                SWIG_croak("unknown opt_revision_t type");
            } else
            SWIG_croak("unknown opt_revision_t type");
        }
        {
            arg4 = svn_swig_pl_info_receiver;
            arg5 = (void *)ST(3);
        }
        arg6 = (svn_boolean_t) SvIV(ST(4));
        {
            if (SWIG_ConvertPtr(ST(5), (void **) &arg7, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 7 of svn_client_info. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 6) {
            
        }
        {
            result = (svn_error_t *)svn_client_info((char const *)arg1,(struct svn_opt_revision_t const *)arg2,(struct svn_opt_revision_t const *)arg3,arg4,arg5,arg6,arg7,arg8);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_url_from_path) {
    {
        char **arg1 = (char **) 0 ;
        char *arg2 = (char *) 0 ;
        apr_pool_t *arg3 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        char const *temp1 = NULL ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg3 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = (char **)&temp1;
        if ((items < 1) || (items > 2)) {
            SWIG_croak("Usage: svn_client_url_from_path(path_or_url,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        if (items > 1) {
            
        }
        {
            result = (svn_error_t *)svn_client_url_from_path((char const **)arg1,(char const *)arg2,arg3);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (*arg1 == NULL)
            ST(argvi) = &PL_sv_undef;
            else
            ST(argvi) = sv_2mortal(newSVpv(*arg1, 0));
            ++argvi;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_uuid_from_url) {
    {
        char **arg1 = (char **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        char const *temp1 = NULL ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = (char **)&temp1;
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_uuid_from_url(url,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_uuid_from_url. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 2) {
            
        }
        {
            result = (svn_error_t *)svn_client_uuid_from_url((char const **)arg1,(char const *)arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (*arg1 == NULL)
            ST(argvi) = &PL_sv_undef;
            else
            ST(argvi) = sv_2mortal(newSVpv(*arg1, 0));
            ++argvi;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_uuid_from_path) {
    {
        char **arg1 = (char **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_wc_adm_access_t *arg3 = (svn_wc_adm_access_t *) 0 ;
        svn_client_ctx_t *arg4 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg5 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        char const *temp1 = NULL ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg5 = svn_swig_pl_make_pool (ST(items-1));
        }
        arg1 = (char **)&temp1;
        if ((items < 3) || (items > 4)) {
            SWIG_croak("Usage: svn_client_uuid_from_path(path,adm_access,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg3, SWIGTYPE_p_svn_wc_adm_access_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_uuid_from_path. Expected _p_svn_wc_adm_access_t");
            }
        }
        {
            if (SWIG_ConvertPtr(ST(2), (void **) &arg4, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 4 of svn_client_uuid_from_path. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 3) {
            
        }
        {
            result = (svn_error_t *)svn_client_uuid_from_path((char const **)arg1,(char const *)arg2,arg3,arg4,arg5);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            if (*arg1 == NULL)
            ST(argvi) = &PL_sv_undef;
            else
            ST(argvi) = sv_2mortal(newSVpv(*arg1, 0));
            ++argvi;
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}


XS(_wrap_svn_client_open_ra_session) {
    {
        svn_ra_session_t **arg1 = (svn_ra_session_t **) 0 ;
        char *arg2 = (char *) 0 ;
        svn_client_ctx_t *arg3 = (svn_client_ctx_t *) 0 ;
        apr_pool_t *arg4 = (apr_pool_t *) 0 ;
        svn_error_t *result;
        apr_pool_t *_global_pool ;
        svn_ra_session_t *temp1 ;
        int argvi = 0;
        dXSARGS;
        
        {
            _global_pool = arg4 = svn_swig_pl_make_pool (ST(items-1));
        }
        {
            arg1 = (svn_ra_session_t **)&temp1;
        }
        if ((items < 2) || (items > 3)) {
            SWIG_croak("Usage: svn_client_open_ra_session(url,ctx,pool);");
        }
        if (!SvOK((SV*) ST(0))) arg2 = 0;
        else arg2 = (char *) SvPV(ST(0), PL_na);
        {
            if (SWIG_ConvertPtr(ST(1), (void **) &arg3, SWIGTYPE_p_svn_client_ctx_t,0) < 0) {
                SWIG_croak("Type error in argument 3 of svn_client_open_ra_session. Expected _p_svn_client_ctx_t");
            }
        }
        if (items > 2) {
            
        }
        {
            result = (svn_error_t *)svn_client_open_ra_session(arg1,(char const *)arg2,arg3,arg4);
            
            
            
            
        }
        {
            if (result) {
                SV *exception_handler = perl_get_sv ("SVN::Error::handler", FALSE);
                
                if (SvOK(exception_handler)) {
                    SV *callback_result;
                    
                    svn_swig_pl_callback_thunk (CALL_SV, exception_handler,
                    &callback_result, "S", result,
                    SWIGTYPE_p_svn_error_t);
                } else {
                    ST(argvi) = sv_newmortal();
                    SWIG_MakePtr (ST(argvi), (void *)result, SWIGTYPE_p_svn_error_t ,0);
                    argvi++;
                }
            }
        }
        {
            ST(argvi) = sv_newmortal();
            SWIG_MakePtr(ST(argvi++), (void *)*arg1, SWIGTYPE_p_svn_ra_session_t,0);
        }
        XSRETURN(argvi);
        fail:
        ;
    }
    croak(Nullch);
}



/* -------- TYPE CONVERSION AND EQUIVALENCE RULES (BEGIN) -------- */

static swig_type_info _swigt__p_apr_array_header_t = {"_p_apr_array_header_t", "apr_array_header_t *", 0, 0, 0};
static swig_type_info _swigt__p_apr_file_t = {"_p_apr_file_t", "apr_file_t *", 0, 0, 0};
static swig_type_info _swigt__p_apr_hash_t = {"_p_apr_hash_t", "apr_hash_t *", 0, 0, 0};
static swig_type_info _swigt__p_apr_int32_t = {"_p_apr_int32_t", "apr_int32_t *|time_t *", 0, 0, 0};
static swig_type_info _swigt__p_apr_int64_t = {"_p_apr_int64_t", "apr_int64_t *|svn_filesize_t *", 0, 0, 0};
static swig_type_info _swigt__p_apr_pool_t = {"_p_apr_pool_t", "apr_pool_t *", 0, 0, 0};
static swig_type_info _swigt__p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void = {"_p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void", "void (*)(apr_off_t,apr_off_t,void *,apr_pool_t *)|svn_ra_progress_notify_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t = {"_p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(apr_getopt_t *,void *,apr_pool_t *)|svn_opt_subcommand_t *", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(char const **,char const **,apr_array_header_t *,void *,apr_pool_t *)|svn_client_get_commit_log_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(char const **,char const **,apr_array_header_t const *,void *,apr_pool_t *)|svn_client_get_commit_log2_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(svn_auth_cred_simple_t **,void *,char const *,char const *,svn_boolean_t,apr_pool_t *)|svn_auth_simple_prompt_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(svn_auth_cred_ssl_client_cert_pw_t **,void *,char const *,svn_boolean_t,apr_pool_t *)|svn_auth_ssl_client_cert_pw_prompt_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(svn_auth_cred_ssl_client_cert_t **,void *,char const *,svn_boolean_t,apr_pool_t *)|svn_auth_ssl_client_cert_prompt_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(svn_auth_cred_ssl_server_trust_t **,void *,char const *,apr_uint32_t,svn_auth_ssl_server_cert_info_t const *,svn_boolean_t,apr_pool_t *)|svn_auth_ssl_server_trust_prompt_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t = {"_p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(svn_auth_cred_username_t **,void *,char const *,svn_boolean_t,apr_pool_t *)|svn_auth_username_prompt_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t = {"_p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(svn_client_diff_summarize_t const *,void *,apr_pool_t *)|svn_client_diff_summarize_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void__p_svn_error_t = {"_p_f_p_void__p_svn_error_t", "struct svn_error_t *(*)(void *)|svn_cancel_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t = {"_p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(void *,apr_int64_t,svn_revnum_t,char const *,char const *,char const *,apr_pool_t *)|svn_client_blame_receiver_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t = {"_p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(void *,apr_hash_t *,svn_revnum_t,char const *,char const *,char const *,apr_pool_t *)|svn_log_message_receiver_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void = {"_p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void", "void (*)(void *,char const *,enum svn_wc_notify_action_t,enum svn_node_kind_t,char const *,enum svn_wc_notify_state_t,enum svn_wc_notify_state_t,long)|svn_wc_notify_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t = {"_p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(void *,char const *,svn_dirent_t const *,svn_lock_t const *,char const *,apr_pool_t *)|svn_client_list_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t = {"_p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t", "struct svn_error_t *(*)(void *,char const *,svn_info_t const *,apr_pool_t *)|svn_info_receiver_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void = {"_p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void", "void (*)(void *,char const *,struct svn_wc_status2_t *)|svn_wc_status_func2_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void = {"_p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void", "void (*)(void *,char const *,struct svn_wc_status_t *)|svn_wc_status_func_t", 0, 0, 0};
static swig_type_info _swigt__p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void = {"_p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void", "void (*)(void *,struct svn_wc_notify_t const *,apr_pool_t *)|svn_wc_notify_func2_t", 0, 0, 0};
static swig_type_info _swigt__p_int = {"_p_int", "int *|svn_boolean_t *", 0, 0, 0};
static swig_type_info _swigt__p_long = {"_p_long", "long *|svn_revnum_t *", 0, 0, 0};
static swig_type_info _swigt__p_p_apr_array_header_t = {"_p_p_apr_array_header_t", "apr_array_header_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_apr_hash_t = {"_p_p_apr_hash_t", "apr_hash_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_char = {"_p_p_char", "char **", 0, 0, 0};
static swig_type_info _swigt__p_p_svn_auth_provider_object_t = {"_p_p_svn_auth_provider_object_t", "struct svn_auth_provider_object_t **|svn_auth_provider_object_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_svn_client_commit_info_t = {"_p_p_svn_client_commit_info_t", "struct svn_client_commit_info_t **|svn_client_commit_info_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_svn_client_ctx_t = {"_p_p_svn_client_ctx_t", "struct svn_client_ctx_t **|svn_client_ctx_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_svn_commit_info_t = {"_p_p_svn_commit_info_t", "struct svn_commit_info_t **|svn_commit_info_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_svn_ra_session_t = {"_p_p_svn_ra_session_t", "struct svn_ra_session_t **|svn_ra_session_t **", 0, 0, 0};
static swig_type_info _swigt__p_p_svn_string_t = {"_p_p_svn_string_t", "struct svn_string_t **|svn_string_t **", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_baton_t = {"_p_svn_auth_baton_t", "struct svn_auth_baton_t *|svn_auth_baton_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_cred_simple_t = {"_p_svn_auth_cred_simple_t", "struct svn_auth_cred_simple_t *|svn_auth_cred_simple_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_cred_ssl_client_cert_pw_t = {"_p_svn_auth_cred_ssl_client_cert_pw_t", "struct svn_auth_cred_ssl_client_cert_pw_t *|svn_auth_cred_ssl_client_cert_pw_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_cred_ssl_client_cert_t = {"_p_svn_auth_cred_ssl_client_cert_t", "struct svn_auth_cred_ssl_client_cert_t *|svn_auth_cred_ssl_client_cert_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_cred_ssl_server_trust_t = {"_p_svn_auth_cred_ssl_server_trust_t", "struct svn_auth_cred_ssl_server_trust_t *|svn_auth_cred_ssl_server_trust_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_cred_username_t = {"_p_svn_auth_cred_username_t", "struct svn_auth_cred_username_t *|svn_auth_cred_username_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_iterstate_t = {"_p_svn_auth_iterstate_t", "struct svn_auth_iterstate_t *|svn_auth_iterstate_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_provider_object_t = {"_p_svn_auth_provider_object_t", "struct svn_auth_provider_object_t *|svn_auth_provider_object_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_provider_t = {"_p_svn_auth_provider_t", "struct svn_auth_provider_t *|svn_auth_provider_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_auth_ssl_server_cert_info_t = {"_p_svn_auth_ssl_server_cert_info_t", "struct svn_auth_ssl_server_cert_info_t *|svn_auth_ssl_server_cert_info_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_commit_info_t = {"_p_svn_client_commit_info_t", "struct svn_client_commit_info_t *|svn_client_commit_info_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_commit_item2_t = {"_p_svn_client_commit_item2_t", "struct svn_client_commit_item2_t *|svn_client_commit_item2_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_commit_item_t = {"_p_svn_client_commit_item_t", "struct svn_client_commit_item_t *|svn_client_commit_item_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_ctx_t = {"_p_svn_client_ctx_t", "struct svn_client_ctx_t *|svn_client_ctx_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_diff_summarize_kind_t = {"_p_svn_client_diff_summarize_kind_t", "enum svn_client_diff_summarize_kind_t *|svn_client_diff_summarize_kind_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_diff_summarize_t = {"_p_svn_client_diff_summarize_t", "struct svn_client_diff_summarize_t *|svn_client_diff_summarize_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_client_proplist_item_t = {"_p_svn_client_proplist_item_t", "struct svn_client_proplist_item_t *|svn_client_proplist_item_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_commit_info_t = {"_p_svn_commit_info_t", "struct svn_commit_info_t *|svn_commit_info_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_config_t = {"_p_svn_config_t", "struct svn_config_t *|svn_config_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_delta_editor_t = {"_p_svn_delta_editor_t", "struct svn_delta_editor_t *|svn_delta_editor_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_diff_datasource_e = {"_p_svn_diff_datasource_e", "enum svn_diff_datasource_e *|svn_diff_datasource_e *", 0, 0, 0};
static swig_type_info _swigt__p_svn_diff_file_ignore_space_t = {"_p_svn_diff_file_ignore_space_t", "enum svn_diff_file_ignore_space_t *|svn_diff_file_ignore_space_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_diff_file_options_t = {"_p_svn_diff_file_options_t", "struct svn_diff_file_options_t *|svn_diff_file_options_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_diff_fns_t = {"_p_svn_diff_fns_t", "struct svn_diff_fns_t *|svn_diff_fns_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_diff_output_fns_t = {"_p_svn_diff_output_fns_t", "struct svn_diff_output_fns_t *|svn_diff_output_fns_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_diff_t = {"_p_svn_diff_t", "struct svn_diff_t *|svn_diff_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_dirent_t = {"_p_svn_dirent_t", "struct svn_dirent_t *|svn_dirent_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_errno_t = {"_p_svn_errno_t", "enum svn_errno_t *|svn_errno_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_error_t = {"_p_svn_error_t", "struct svn_error_t *|svn_error_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_info_t = {"_p_svn_info_t", "struct svn_info_t *|svn_info_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_io_dirent_t = {"_p_svn_io_dirent_t", "struct svn_io_dirent_t *|svn_io_dirent_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_io_file_del_t = {"_p_svn_io_file_del_t", "enum svn_io_file_del_t *|svn_io_file_del_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_lock_t = {"_p_svn_lock_t", "struct svn_lock_t *|svn_lock_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_log_changed_path_t = {"_p_svn_log_changed_path_t", "struct svn_log_changed_path_t *|svn_log_changed_path_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_node_kind_t = {"_p_svn_node_kind_t", "enum svn_node_kind_t *|svn_node_kind_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_opt_revision_t = {"_p_svn_opt_revision_t", "struct svn_opt_revision_t *|svn_opt_revision_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_opt_revision_value_t = {"_p_svn_opt_revision_value_t", "union svn_opt_revision_value_t *|svn_opt_revision_value_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_opt_subcommand_desc2_t = {"_p_svn_opt_subcommand_desc2_t", "struct svn_opt_subcommand_desc2_t *|svn_opt_subcommand_desc2_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_opt_subcommand_desc_t = {"_p_svn_opt_subcommand_desc_t", "struct svn_opt_subcommand_desc_t *|svn_opt_subcommand_desc_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_prop_kind = {"_p_svn_prop_kind", "enum svn_prop_kind *|svn_prop_kind_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_prop_t = {"_p_svn_prop_t", "struct svn_prop_t *|svn_prop_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_ra_callbacks2_t = {"_p_svn_ra_callbacks2_t", "struct svn_ra_callbacks2_t *|svn_ra_callbacks2_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_ra_callbacks_t = {"_p_svn_ra_callbacks_t", "struct svn_ra_callbacks_t *|svn_ra_callbacks_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_ra_plugin_t = {"_p_svn_ra_plugin_t", "struct svn_ra_plugin_t *|svn_ra_plugin_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_ra_reporter2_t = {"_p_svn_ra_reporter2_t", "struct svn_ra_reporter2_t *|svn_ra_reporter2_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_ra_reporter_t = {"_p_svn_ra_reporter_t", "struct svn_ra_reporter_t *|svn_ra_reporter_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_ra_session_t = {"_p_svn_ra_session_t", "struct svn_ra_session_t *|svn_ra_session_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_stream_t = {"_p_svn_stream_t", "struct svn_stream_t *|svn_stream_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_string_t = {"_p_svn_string_t", "struct svn_string_t *|svn_string_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_stringbuf_t = {"_p_svn_stringbuf_t", "struct svn_stringbuf_t *|svn_stringbuf_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_txdelta_op_t = {"_p_svn_txdelta_op_t", "struct svn_txdelta_op_t *|svn_txdelta_op_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_txdelta_stream_t = {"_p_svn_txdelta_stream_t", "struct svn_txdelta_stream_t *|svn_txdelta_stream_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_txdelta_window_t = {"_p_svn_txdelta_window_t", "struct svn_txdelta_window_t *|svn_txdelta_window_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_version_checklist_t = {"_p_svn_version_checklist_t", "struct svn_version_checklist_t *|svn_version_checklist_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_version_t = {"_p_svn_version_t", "struct svn_version_t *|svn_version_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_adm_access_t = {"_p_svn_wc_adm_access_t", "struct svn_wc_adm_access_t *|svn_wc_adm_access_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_diff_callbacks2_t = {"_p_svn_wc_diff_callbacks2_t", "struct svn_wc_diff_callbacks2_t *|svn_wc_diff_callbacks2_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_diff_callbacks_t = {"_p_svn_wc_diff_callbacks_t", "struct svn_wc_diff_callbacks_t *|svn_wc_diff_callbacks_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_entry_callbacks_t = {"_p_svn_wc_entry_callbacks_t", "struct svn_wc_entry_callbacks_t *|svn_wc_entry_callbacks_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_entry_t = {"_p_svn_wc_entry_t", "struct svn_wc_entry_t *|svn_wc_entry_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_external_item_t = {"_p_svn_wc_external_item_t", "struct svn_wc_external_item_t *|svn_wc_external_item_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_merge_outcome_t = {"_p_svn_wc_merge_outcome_t", "enum svn_wc_merge_outcome_t *|svn_wc_merge_outcome_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_notify_action_t = {"_p_svn_wc_notify_action_t", "enum svn_wc_notify_action_t *|svn_wc_notify_action_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_notify_lock_state_t = {"_p_svn_wc_notify_lock_state_t", "enum svn_wc_notify_lock_state_t *|svn_wc_notify_lock_state_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_notify_state_t = {"_p_svn_wc_notify_state_t", "enum svn_wc_notify_state_t *|svn_wc_notify_state_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_notify_t = {"_p_svn_wc_notify_t", "struct svn_wc_notify_t *|svn_wc_notify_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_revision_status_t = {"_p_svn_wc_revision_status_t", "struct svn_wc_revision_status_t *|svn_wc_revision_status_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_schedule_t = {"_p_svn_wc_schedule_t", "enum svn_wc_schedule_t *|svn_wc_schedule_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_status2_t = {"_p_svn_wc_status2_t", "struct svn_wc_status2_t *|svn_wc_status2_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_status_t = {"_p_svn_wc_status_t", "struct svn_wc_status_t *|svn_wc_status_t *", 0, 0, 0};
static swig_type_info _swigt__p_svn_wc_traversal_info_t = {"_p_svn_wc_traversal_info_t", "struct svn_wc_traversal_info_t *|svn_wc_traversal_info_t *", 0, 0, 0};
static swig_type_info _swigt__p_void = {"_p_void", "void *", 0, 0, 0};

static swig_type_info *swig_type_initial[] = {
  &_swigt__p_apr_array_header_t,
  &_swigt__p_apr_file_t,
  &_swigt__p_apr_hash_t,
  &_swigt__p_apr_int32_t,
  &_swigt__p_apr_int64_t,
  &_swigt__p_apr_pool_t,
  &_swigt__p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void,
  &_swigt__p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_void__p_svn_error_t,
  &_swigt__p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void,
  &_swigt__p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t,
  &_swigt__p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void,
  &_swigt__p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void,
  &_swigt__p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void,
  &_swigt__p_int,
  &_swigt__p_long,
  &_swigt__p_p_apr_array_header_t,
  &_swigt__p_p_apr_hash_t,
  &_swigt__p_p_char,
  &_swigt__p_p_svn_auth_provider_object_t,
  &_swigt__p_p_svn_client_commit_info_t,
  &_swigt__p_p_svn_client_ctx_t,
  &_swigt__p_p_svn_commit_info_t,
  &_swigt__p_p_svn_ra_session_t,
  &_swigt__p_p_svn_string_t,
  &_swigt__p_svn_auth_baton_t,
  &_swigt__p_svn_auth_cred_simple_t,
  &_swigt__p_svn_auth_cred_ssl_client_cert_pw_t,
  &_swigt__p_svn_auth_cred_ssl_client_cert_t,
  &_swigt__p_svn_auth_cred_ssl_server_trust_t,
  &_swigt__p_svn_auth_cred_username_t,
  &_swigt__p_svn_auth_iterstate_t,
  &_swigt__p_svn_auth_provider_object_t,
  &_swigt__p_svn_auth_provider_t,
  &_swigt__p_svn_auth_ssl_server_cert_info_t,
  &_swigt__p_svn_client_commit_info_t,
  &_swigt__p_svn_client_commit_item2_t,
  &_swigt__p_svn_client_commit_item_t,
  &_swigt__p_svn_client_ctx_t,
  &_swigt__p_svn_client_diff_summarize_kind_t,
  &_swigt__p_svn_client_diff_summarize_t,
  &_swigt__p_svn_client_proplist_item_t,
  &_swigt__p_svn_commit_info_t,
  &_swigt__p_svn_config_t,
  &_swigt__p_svn_delta_editor_t,
  &_swigt__p_svn_diff_datasource_e,
  &_swigt__p_svn_diff_file_ignore_space_t,
  &_swigt__p_svn_diff_file_options_t,
  &_swigt__p_svn_diff_fns_t,
  &_swigt__p_svn_diff_output_fns_t,
  &_swigt__p_svn_diff_t,
  &_swigt__p_svn_dirent_t,
  &_swigt__p_svn_errno_t,
  &_swigt__p_svn_error_t,
  &_swigt__p_svn_info_t,
  &_swigt__p_svn_io_dirent_t,
  &_swigt__p_svn_io_file_del_t,
  &_swigt__p_svn_lock_t,
  &_swigt__p_svn_log_changed_path_t,
  &_swigt__p_svn_node_kind_t,
  &_swigt__p_svn_opt_revision_t,
  &_swigt__p_svn_opt_revision_value_t,
  &_swigt__p_svn_opt_subcommand_desc2_t,
  &_swigt__p_svn_opt_subcommand_desc_t,
  &_swigt__p_svn_prop_kind,
  &_swigt__p_svn_prop_t,
  &_swigt__p_svn_ra_callbacks2_t,
  &_swigt__p_svn_ra_callbacks_t,
  &_swigt__p_svn_ra_plugin_t,
  &_swigt__p_svn_ra_reporter2_t,
  &_swigt__p_svn_ra_reporter_t,
  &_swigt__p_svn_ra_session_t,
  &_swigt__p_svn_stream_t,
  &_swigt__p_svn_string_t,
  &_swigt__p_svn_stringbuf_t,
  &_swigt__p_svn_txdelta_op_t,
  &_swigt__p_svn_txdelta_stream_t,
  &_swigt__p_svn_txdelta_window_t,
  &_swigt__p_svn_version_checklist_t,
  &_swigt__p_svn_version_t,
  &_swigt__p_svn_wc_adm_access_t,
  &_swigt__p_svn_wc_diff_callbacks2_t,
  &_swigt__p_svn_wc_diff_callbacks_t,
  &_swigt__p_svn_wc_entry_callbacks_t,
  &_swigt__p_svn_wc_entry_t,
  &_swigt__p_svn_wc_external_item_t,
  &_swigt__p_svn_wc_merge_outcome_t,
  &_swigt__p_svn_wc_notify_action_t,
  &_swigt__p_svn_wc_notify_lock_state_t,
  &_swigt__p_svn_wc_notify_state_t,
  &_swigt__p_svn_wc_notify_t,
  &_swigt__p_svn_wc_revision_status_t,
  &_swigt__p_svn_wc_schedule_t,
  &_swigt__p_svn_wc_status2_t,
  &_swigt__p_svn_wc_status_t,
  &_swigt__p_svn_wc_traversal_info_t,
  &_swigt__p_void,
};

static swig_cast_info _swigc__p_apr_array_header_t[] = {  {&_swigt__p_apr_array_header_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_apr_file_t[] = {  {&_swigt__p_apr_file_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_apr_hash_t[] = {  {&_swigt__p_apr_hash_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_apr_int32_t[] = {  {&_swigt__p_apr_int32_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_apr_int64_t[] = {  {&_swigt__p_apr_int64_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_apr_pool_t[] = {  {&_swigt__p_apr_pool_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void[] = {  {&_swigt__p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void__p_svn_error_t[] = {  {&_swigt__p_f_p_void__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void[] = {  {&_swigt__p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t[] = {  {&_swigt__p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void[] = {  {&_swigt__p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void[] = {  {&_swigt__p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void[] = {  {&_swigt__p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_int[] = {  {&_swigt__p_int, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_long[] = {  {&_swigt__p_long, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_apr_array_header_t[] = {  {&_swigt__p_p_apr_array_header_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_apr_hash_t[] = {  {&_swigt__p_p_apr_hash_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_char[] = {  {&_swigt__p_p_char, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_svn_auth_provider_object_t[] = {  {&_swigt__p_p_svn_auth_provider_object_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_svn_client_commit_info_t[] = {  {&_swigt__p_p_svn_client_commit_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_svn_client_ctx_t[] = {  {&_swigt__p_p_svn_client_ctx_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_svn_commit_info_t[] = {  {&_swigt__p_p_svn_commit_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_svn_ra_session_t[] = {  {&_swigt__p_p_svn_ra_session_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_p_svn_string_t[] = {  {&_swigt__p_p_svn_string_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_baton_t[] = {  {&_swigt__p_svn_auth_baton_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_cred_simple_t[] = {  {&_swigt__p_svn_auth_cred_simple_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_cred_ssl_client_cert_pw_t[] = {  {&_swigt__p_svn_auth_cred_ssl_client_cert_pw_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_cred_ssl_client_cert_t[] = {  {&_swigt__p_svn_auth_cred_ssl_client_cert_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_cred_ssl_server_trust_t[] = {  {&_swigt__p_svn_auth_cred_ssl_server_trust_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_cred_username_t[] = {  {&_swigt__p_svn_auth_cred_username_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_iterstate_t[] = {  {&_swigt__p_svn_auth_iterstate_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_provider_object_t[] = {  {&_swigt__p_svn_auth_provider_object_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_provider_t[] = {  {&_swigt__p_svn_auth_provider_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_auth_ssl_server_cert_info_t[] = {  {&_swigt__p_svn_auth_ssl_server_cert_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_commit_info_t[] = {  {&_swigt__p_svn_client_commit_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_commit_item2_t[] = {  {&_swigt__p_svn_client_commit_item2_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_commit_item_t[] = {  {&_swigt__p_svn_client_commit_item_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_ctx_t[] = {  {&_swigt__p_svn_client_ctx_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_diff_summarize_kind_t[] = {  {&_swigt__p_svn_client_diff_summarize_kind_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_diff_summarize_t[] = {  {&_swigt__p_svn_client_diff_summarize_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_client_proplist_item_t[] = {  {&_swigt__p_svn_client_proplist_item_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_commit_info_t[] = {  {&_swigt__p_svn_commit_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_config_t[] = {  {&_swigt__p_svn_config_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_delta_editor_t[] = {  {&_swigt__p_svn_delta_editor_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_diff_datasource_e[] = {  {&_swigt__p_svn_diff_datasource_e, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_diff_file_ignore_space_t[] = {  {&_swigt__p_svn_diff_file_ignore_space_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_diff_file_options_t[] = {  {&_swigt__p_svn_diff_file_options_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_diff_fns_t[] = {  {&_swigt__p_svn_diff_fns_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_diff_output_fns_t[] = {  {&_swigt__p_svn_diff_output_fns_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_diff_t[] = {  {&_swigt__p_svn_diff_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_dirent_t[] = {  {&_swigt__p_svn_dirent_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_errno_t[] = {  {&_swigt__p_svn_errno_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_error_t[] = {  {&_swigt__p_svn_error_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_info_t[] = {  {&_swigt__p_svn_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_io_dirent_t[] = {  {&_swigt__p_svn_io_dirent_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_io_file_del_t[] = {  {&_swigt__p_svn_io_file_del_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_lock_t[] = {  {&_swigt__p_svn_lock_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_log_changed_path_t[] = {  {&_swigt__p_svn_log_changed_path_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_node_kind_t[] = {  {&_swigt__p_svn_node_kind_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_opt_revision_t[] = {  {&_swigt__p_svn_opt_revision_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_opt_revision_value_t[] = {  {&_swigt__p_svn_opt_revision_value_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_opt_subcommand_desc2_t[] = {  {&_swigt__p_svn_opt_subcommand_desc2_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_opt_subcommand_desc_t[] = {  {&_swigt__p_svn_opt_subcommand_desc_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_prop_kind[] = {  {&_swigt__p_svn_prop_kind, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_prop_t[] = {  {&_swigt__p_svn_prop_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_ra_callbacks2_t[] = {  {&_swigt__p_svn_ra_callbacks2_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_ra_callbacks_t[] = {  {&_swigt__p_svn_ra_callbacks_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_ra_plugin_t[] = {  {&_swigt__p_svn_ra_plugin_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_ra_reporter2_t[] = {  {&_swigt__p_svn_ra_reporter2_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_ra_reporter_t[] = {  {&_swigt__p_svn_ra_reporter_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_ra_session_t[] = {  {&_swigt__p_svn_ra_session_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_stream_t[] = {  {&_swigt__p_svn_stream_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_string_t[] = {  {&_swigt__p_svn_string_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_stringbuf_t[] = {  {&_swigt__p_svn_stringbuf_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_txdelta_op_t[] = {  {&_swigt__p_svn_txdelta_op_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_txdelta_stream_t[] = {  {&_swigt__p_svn_txdelta_stream_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_txdelta_window_t[] = {  {&_swigt__p_svn_txdelta_window_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_version_checklist_t[] = {  {&_swigt__p_svn_version_checklist_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_version_t[] = {  {&_swigt__p_svn_version_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_adm_access_t[] = {  {&_swigt__p_svn_wc_adm_access_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_diff_callbacks2_t[] = {  {&_swigt__p_svn_wc_diff_callbacks2_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_diff_callbacks_t[] = {  {&_swigt__p_svn_wc_diff_callbacks_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_entry_callbacks_t[] = {  {&_swigt__p_svn_wc_entry_callbacks_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_entry_t[] = {  {&_swigt__p_svn_wc_entry_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_external_item_t[] = {  {&_swigt__p_svn_wc_external_item_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_merge_outcome_t[] = {  {&_swigt__p_svn_wc_merge_outcome_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_notify_action_t[] = {  {&_swigt__p_svn_wc_notify_action_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_notify_lock_state_t[] = {  {&_swigt__p_svn_wc_notify_lock_state_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_notify_state_t[] = {  {&_swigt__p_svn_wc_notify_state_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_notify_t[] = {  {&_swigt__p_svn_wc_notify_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_revision_status_t[] = {  {&_swigt__p_svn_wc_revision_status_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_schedule_t[] = {  {&_swigt__p_svn_wc_schedule_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_status2_t[] = {  {&_swigt__p_svn_wc_status2_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_status_t[] = {  {&_swigt__p_svn_wc_status_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_svn_wc_traversal_info_t[] = {  {&_swigt__p_svn_wc_traversal_info_t, 0, 0, 0},{0, 0, 0, 0}};
static swig_cast_info _swigc__p_void[] = {  {&_swigt__p_void, 0, 0, 0},{0, 0, 0, 0}};

static swig_cast_info *swig_cast_initial[] = {
  _swigc__p_apr_array_header_t,
  _swigc__p_apr_file_t,
  _swigc__p_apr_hash_t,
  _swigc__p_apr_int32_t,
  _swigc__p_apr_int64_t,
  _swigc__p_apr_pool_t,
  _swigc__p_f_apr_off_t_apr_off_t_p_void_p_apr_pool_t__void,
  _swigc__p_f_p_apr_getopt_t_p_void_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_q_const__char_p_p_q_const__char_p_apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_q_const__char_p_p_q_const__char_p_q_const__apr_array_header_t_p_void_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_svn_auth_cred_simple_t_p_void_p_q_const__char_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_svn_auth_cred_ssl_client_cert_pw_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_svn_auth_cred_ssl_client_cert_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_svn_auth_cred_ssl_server_trust_t_p_void_p_q_const__char_apr_uint32_t_p_q_const__svn_auth_ssl_server_cert_info_t_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_p_svn_auth_cred_username_t_p_void_p_q_const__char_svn_boolean_t_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_q_const__svn_client_diff_summarize_t_p_void_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_void__p_svn_error_t,
  _swigc__p_f_p_void_apr_int64_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_void_p_apr_hash_t_svn_revnum_t_p_q_const__char_p_q_const__char_p_q_const__char_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_void_p_q_const__char_enum_svn_wc_notify_action_t_enum_svn_node_kind_t_p_q_const__char_enum_svn_wc_notify_state_t_enum_svn_wc_notify_state_t_long__void,
  _swigc__p_f_p_void_p_q_const__char_p_q_const__svn_dirent_t_p_q_const__svn_lock_t_p_q_const__char_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_void_p_q_const__char_p_q_const__svn_info_t_p_apr_pool_t__p_svn_error_t,
  _swigc__p_f_p_void_p_q_const__char_p_struct_svn_wc_status2_t__void,
  _swigc__p_f_p_void_p_q_const__char_p_struct_svn_wc_status_t__void,
  _swigc__p_f_p_void_p_q_const__struct_svn_wc_notify_t_p_apr_pool_t__void,
  _swigc__p_int,
  _swigc__p_long,
  _swigc__p_p_apr_array_header_t,
  _swigc__p_p_apr_hash_t,
  _swigc__p_p_char,
  _swigc__p_p_svn_auth_provider_object_t,
  _swigc__p_p_svn_client_commit_info_t,
  _swigc__p_p_svn_client_ctx_t,
  _swigc__p_p_svn_commit_info_t,
  _swigc__p_p_svn_ra_session_t,
  _swigc__p_p_svn_string_t,
  _swigc__p_svn_auth_baton_t,
  _swigc__p_svn_auth_cred_simple_t,
  _swigc__p_svn_auth_cred_ssl_client_cert_pw_t,
  _swigc__p_svn_auth_cred_ssl_client_cert_t,
  _swigc__p_svn_auth_cred_ssl_server_trust_t,
  _swigc__p_svn_auth_cred_username_t,
  _swigc__p_svn_auth_iterstate_t,
  _swigc__p_svn_auth_provider_object_t,
  _swigc__p_svn_auth_provider_t,
  _swigc__p_svn_auth_ssl_server_cert_info_t,
  _swigc__p_svn_client_commit_info_t,
  _swigc__p_svn_client_commit_item2_t,
  _swigc__p_svn_client_commit_item_t,
  _swigc__p_svn_client_ctx_t,
  _swigc__p_svn_client_diff_summarize_kind_t,
  _swigc__p_svn_client_diff_summarize_t,
  _swigc__p_svn_client_proplist_item_t,
  _swigc__p_svn_commit_info_t,
  _swigc__p_svn_config_t,
  _swigc__p_svn_delta_editor_t,
  _swigc__p_svn_diff_datasource_e,
  _swigc__p_svn_diff_file_ignore_space_t,
  _swigc__p_svn_diff_file_options_t,
  _swigc__p_svn_diff_fns_t,
  _swigc__p_svn_diff_output_fns_t,
  _swigc__p_svn_diff_t,
  _swigc__p_svn_dirent_t,
  _swigc__p_svn_errno_t,
  _swigc__p_svn_error_t,
  _swigc__p_svn_info_t,
  _swigc__p_svn_io_dirent_t,
  _swigc__p_svn_io_file_del_t,
  _swigc__p_svn_lock_t,
  _swigc__p_svn_log_changed_path_t,
  _swigc__p_svn_node_kind_t,
  _swigc__p_svn_opt_revision_t,
  _swigc__p_svn_opt_revision_value_t,
  _swigc__p_svn_opt_subcommand_desc2_t,
  _swigc__p_svn_opt_subcommand_desc_t,
  _swigc__p_svn_prop_kind,
  _swigc__p_svn_prop_t,
  _swigc__p_svn_ra_callbacks2_t,
  _swigc__p_svn_ra_callbacks_t,
  _swigc__p_svn_ra_plugin_t,
  _swigc__p_svn_ra_reporter2_t,
  _swigc__p_svn_ra_reporter_t,
  _swigc__p_svn_ra_session_t,
  _swigc__p_svn_stream_t,
  _swigc__p_svn_string_t,
  _swigc__p_svn_stringbuf_t,
  _swigc__p_svn_txdelta_op_t,
  _swigc__p_svn_txdelta_stream_t,
  _swigc__p_svn_txdelta_window_t,
  _swigc__p_svn_version_checklist_t,
  _swigc__p_svn_version_t,
  _swigc__p_svn_wc_adm_access_t,
  _swigc__p_svn_wc_diff_callbacks2_t,
  _swigc__p_svn_wc_diff_callbacks_t,
  _swigc__p_svn_wc_entry_callbacks_t,
  _swigc__p_svn_wc_entry_t,
  _swigc__p_svn_wc_external_item_t,
  _swigc__p_svn_wc_merge_outcome_t,
  _swigc__p_svn_wc_notify_action_t,
  _swigc__p_svn_wc_notify_lock_state_t,
  _swigc__p_svn_wc_notify_state_t,
  _swigc__p_svn_wc_notify_t,
  _swigc__p_svn_wc_revision_status_t,
  _swigc__p_svn_wc_schedule_t,
  _swigc__p_svn_wc_status2_t,
  _swigc__p_svn_wc_status_t,
  _swigc__p_svn_wc_traversal_info_t,
  _swigc__p_void,
};


/* -------- TYPE CONVERSION AND EQUIVALENCE RULES (END) -------- */

static swig_constant_info swig_constants[] = {
{ SWIG_INT,     (char *) SWIG_prefix "SVN_CLIENT_COMMIT_ITEM_ADD", (long) 0x01, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "SVN_CLIENT_COMMIT_ITEM_DELETE", (long) 0x02, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "SVN_CLIENT_COMMIT_ITEM_TEXT_MODS", (long) 0x04, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "SVN_CLIENT_COMMIT_ITEM_PROP_MODS", (long) 0x08, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "SVN_CLIENT_COMMIT_ITEM_IS_COPY", (long) 0x10, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "SVN_CLIENT_COMMIT_ITEM_LOCK_TOKEN", (long) 0x20, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "svn_client_diff_summarize_kind_normal", (long) svn_client_diff_summarize_kind_normal, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "svn_client_diff_summarize_kind_added", (long) svn_client_diff_summarize_kind_added, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "svn_client_diff_summarize_kind_modified", (long) svn_client_diff_summarize_kind_modified, 0, 0, 0},
{ SWIG_INT,     (char *) SWIG_prefix "svn_client_diff_summarize_kind_deleted", (long) svn_client_diff_summarize_kind_deleted, 0, 0, 0},
{ SWIG_STRING,  (char *) SWIG_prefix "SVN_CLIENT_AUTH_USERNAME", 0, 0, (void *)"username", 0},
{ SWIG_STRING,  (char *) SWIG_prefix "SVN_CLIENT_AUTH_PASSWORD", 0, 0, (void *)"password", 0},
{0,0,0,0,0,0}
};
#ifdef __cplusplus
}
#endif
static swig_variable_info swig_variables[] = {
{0,0,0,0}
};
static swig_command_info swig_commands[] = {
{"SVN::_Client::svn_client_version", _wrap_svn_client_version},
{"SVN::_Client::svn_client_get_simple_prompt_provider", _wrap_svn_client_get_simple_prompt_provider},
{"SVN::_Client::svn_client_get_username_prompt_provider", _wrap_svn_client_get_username_prompt_provider},
{"SVN::_Client::svn_client_get_simple_provider", _wrap_svn_client_get_simple_provider},
{"SVN::_Client::svn_client_get_username_provider", _wrap_svn_client_get_username_provider},
{"SVN::_Client::svn_client_get_ssl_server_trust_file_provider", _wrap_svn_client_get_ssl_server_trust_file_provider},
{"SVN::_Client::svn_client_get_ssl_client_cert_file_provider", _wrap_svn_client_get_ssl_client_cert_file_provider},
{"SVN::_Client::svn_client_get_ssl_client_cert_pw_file_provider", _wrap_svn_client_get_ssl_client_cert_pw_file_provider},
{"SVN::_Client::svn_client_get_ssl_server_trust_prompt_provider", _wrap_svn_client_get_ssl_server_trust_prompt_provider},
{"SVN::_Client::svn_client_get_ssl_client_cert_prompt_provider", _wrap_svn_client_get_ssl_client_cert_prompt_provider},
{"SVN::_Client::svn_client_get_ssl_client_cert_pw_prompt_provider", _wrap_svn_client_get_ssl_client_cert_pw_prompt_provider},
{"SVN::_Client::svn_client_proplist_item_t_node_name_set", _wrap_svn_client_proplist_item_t_node_name_set},
{"SVN::_Client::svn_client_proplist_item_t_node_name_get", _wrap_svn_client_proplist_item_t_node_name_get},
{"SVN::_Client::svn_client_proplist_item_t_prop_hash_set", _wrap_svn_client_proplist_item_t_prop_hash_set},
{"SVN::_Client::svn_client_proplist_item_t_prop_hash_get", _wrap_svn_client_proplist_item_t_prop_hash_get},
{"SVN::_Client::new_svn_client_proplist_item_t", _wrap_new_svn_client_proplist_item_t},
{"SVN::_Client::delete_svn_client_proplist_item_t", _wrap_delete_svn_client_proplist_item_t},
{"SVN::_Client::svn_client_proplist_item_dup", _wrap_svn_client_proplist_item_dup},
{"SVN::_Client::svn_client_commit_info_t_revision_set", _wrap_svn_client_commit_info_t_revision_set},
{"SVN::_Client::svn_client_commit_info_t_revision_get", _wrap_svn_client_commit_info_t_revision_get},
{"SVN::_Client::svn_client_commit_info_t_date_set", _wrap_svn_client_commit_info_t_date_set},
{"SVN::_Client::svn_client_commit_info_t_date_get", _wrap_svn_client_commit_info_t_date_get},
{"SVN::_Client::svn_client_commit_info_t_author_set", _wrap_svn_client_commit_info_t_author_set},
{"SVN::_Client::svn_client_commit_info_t_author_get", _wrap_svn_client_commit_info_t_author_get},
{"SVN::_Client::new_svn_client_commit_info_t", _wrap_new_svn_client_commit_info_t},
{"SVN::_Client::delete_svn_client_commit_info_t", _wrap_delete_svn_client_commit_info_t},
{"SVN::_Client::svn_client_commit_item2_t_path_set", _wrap_svn_client_commit_item2_t_path_set},
{"SVN::_Client::svn_client_commit_item2_t_path_get", _wrap_svn_client_commit_item2_t_path_get},
{"SVN::_Client::svn_client_commit_item2_t_kind_set", _wrap_svn_client_commit_item2_t_kind_set},
{"SVN::_Client::svn_client_commit_item2_t_kind_get", _wrap_svn_client_commit_item2_t_kind_get},
{"SVN::_Client::svn_client_commit_item2_t_url_set", _wrap_svn_client_commit_item2_t_url_set},
{"SVN::_Client::svn_client_commit_item2_t_url_get", _wrap_svn_client_commit_item2_t_url_get},
{"SVN::_Client::svn_client_commit_item2_t_revision_set", _wrap_svn_client_commit_item2_t_revision_set},
{"SVN::_Client::svn_client_commit_item2_t_revision_get", _wrap_svn_client_commit_item2_t_revision_get},
{"SVN::_Client::svn_client_commit_item2_t_copyfrom_url_set", _wrap_svn_client_commit_item2_t_copyfrom_url_set},
{"SVN::_Client::svn_client_commit_item2_t_copyfrom_url_get", _wrap_svn_client_commit_item2_t_copyfrom_url_get},
{"SVN::_Client::svn_client_commit_item2_t_copyfrom_rev_set", _wrap_svn_client_commit_item2_t_copyfrom_rev_set},
{"SVN::_Client::svn_client_commit_item2_t_copyfrom_rev_get", _wrap_svn_client_commit_item2_t_copyfrom_rev_get},
{"SVN::_Client::svn_client_commit_item2_t_state_flags_set", _wrap_svn_client_commit_item2_t_state_flags_set},
{"SVN::_Client::svn_client_commit_item2_t_state_flags_get", _wrap_svn_client_commit_item2_t_state_flags_get},
{"SVN::_Client::svn_client_commit_item2_t_wcprop_changes_set", _wrap_svn_client_commit_item2_t_wcprop_changes_set},
{"SVN::_Client::svn_client_commit_item2_t_wcprop_changes_get", _wrap_svn_client_commit_item2_t_wcprop_changes_get},
{"SVN::_Client::new_svn_client_commit_item2_t", _wrap_new_svn_client_commit_item2_t},
{"SVN::_Client::delete_svn_client_commit_item2_t", _wrap_delete_svn_client_commit_item2_t},
{"SVN::_Client::svn_client_commit_item2_dup", _wrap_svn_client_commit_item2_dup},
{"SVN::_Client::svn_client_commit_item_t_path_set", _wrap_svn_client_commit_item_t_path_set},
{"SVN::_Client::svn_client_commit_item_t_path_get", _wrap_svn_client_commit_item_t_path_get},
{"SVN::_Client::svn_client_commit_item_t_kind_set", _wrap_svn_client_commit_item_t_kind_set},
{"SVN::_Client::svn_client_commit_item_t_kind_get", _wrap_svn_client_commit_item_t_kind_get},
{"SVN::_Client::svn_client_commit_item_t_url_set", _wrap_svn_client_commit_item_t_url_set},
{"SVN::_Client::svn_client_commit_item_t_url_get", _wrap_svn_client_commit_item_t_url_get},
{"SVN::_Client::svn_client_commit_item_t_revision_set", _wrap_svn_client_commit_item_t_revision_set},
{"SVN::_Client::svn_client_commit_item_t_revision_get", _wrap_svn_client_commit_item_t_revision_get},
{"SVN::_Client::svn_client_commit_item_t_copyfrom_url_set", _wrap_svn_client_commit_item_t_copyfrom_url_set},
{"SVN::_Client::svn_client_commit_item_t_copyfrom_url_get", _wrap_svn_client_commit_item_t_copyfrom_url_get},
{"SVN::_Client::svn_client_commit_item_t_state_flags_set", _wrap_svn_client_commit_item_t_state_flags_set},
{"SVN::_Client::svn_client_commit_item_t_state_flags_get", _wrap_svn_client_commit_item_t_state_flags_get},
{"SVN::_Client::svn_client_commit_item_t_wcprop_changes_set", _wrap_svn_client_commit_item_t_wcprop_changes_set},
{"SVN::_Client::svn_client_commit_item_t_wcprop_changes_get", _wrap_svn_client_commit_item_t_wcprop_changes_get},
{"SVN::_Client::new_svn_client_commit_item_t", _wrap_new_svn_client_commit_item_t},
{"SVN::_Client::delete_svn_client_commit_item_t", _wrap_delete_svn_client_commit_item_t},
{"SVN::_Client::svn_client_diff_summarize_t_path_set", _wrap_svn_client_diff_summarize_t_path_set},
{"SVN::_Client::svn_client_diff_summarize_t_path_get", _wrap_svn_client_diff_summarize_t_path_get},
{"SVN::_Client::svn_client_diff_summarize_t_summarize_kind_set", _wrap_svn_client_diff_summarize_t_summarize_kind_set},
{"SVN::_Client::svn_client_diff_summarize_t_summarize_kind_get", _wrap_svn_client_diff_summarize_t_summarize_kind_get},
{"SVN::_Client::svn_client_diff_summarize_t_prop_changed_set", _wrap_svn_client_diff_summarize_t_prop_changed_set},
{"SVN::_Client::svn_client_diff_summarize_t_prop_changed_get", _wrap_svn_client_diff_summarize_t_prop_changed_get},
{"SVN::_Client::svn_client_diff_summarize_t_node_kind_set", _wrap_svn_client_diff_summarize_t_node_kind_set},
{"SVN::_Client::svn_client_diff_summarize_t_node_kind_get", _wrap_svn_client_diff_summarize_t_node_kind_get},
{"SVN::_Client::new_svn_client_diff_summarize_t", _wrap_new_svn_client_diff_summarize_t},
{"SVN::_Client::delete_svn_client_diff_summarize_t", _wrap_delete_svn_client_diff_summarize_t},
{"SVN::_Client::svn_client_diff_summarize_dup", _wrap_svn_client_diff_summarize_dup},
{"SVN::_Client::svn_client_ctx_t_auth_baton_set", _wrap_svn_client_ctx_t_auth_baton_set},
{"SVN::_Client::svn_client_ctx_t_auth_baton_get", _wrap_svn_client_ctx_t_auth_baton_get},
{"SVN::_Client::svn_client_ctx_t_notify_func_set", _wrap_svn_client_ctx_t_notify_func_set},
{"SVN::_Client::svn_client_ctx_t_notify_func_get", _wrap_svn_client_ctx_t_notify_func_get},
{"SVN::_Client::svn_client_ctx_t_notify_baton_set", _wrap_svn_client_ctx_t_notify_baton_set},
{"SVN::_Client::svn_client_ctx_t_notify_baton_get", _wrap_svn_client_ctx_t_notify_baton_get},
{"SVN::_Client::svn_client_ctx_t_log_msg_func_set", _wrap_svn_client_ctx_t_log_msg_func_set},
{"SVN::_Client::svn_client_ctx_t_log_msg_func_get", _wrap_svn_client_ctx_t_log_msg_func_get},
{"SVN::_Client::svn_client_ctx_t_log_msg_baton_set", _wrap_svn_client_ctx_t_log_msg_baton_set},
{"SVN::_Client::svn_client_ctx_t_log_msg_baton_get", _wrap_svn_client_ctx_t_log_msg_baton_get},
{"SVN::_Client::svn_client_ctx_t_config_set", _wrap_svn_client_ctx_t_config_set},
{"SVN::_Client::svn_client_ctx_t_config_get", _wrap_svn_client_ctx_t_config_get},
{"SVN::_Client::svn_client_ctx_t_cancel_func_set", _wrap_svn_client_ctx_t_cancel_func_set},
{"SVN::_Client::svn_client_ctx_t_cancel_func_get", _wrap_svn_client_ctx_t_cancel_func_get},
{"SVN::_Client::svn_client_ctx_t_cancel_baton_set", _wrap_svn_client_ctx_t_cancel_baton_set},
{"SVN::_Client::svn_client_ctx_t_cancel_baton_get", _wrap_svn_client_ctx_t_cancel_baton_get},
{"SVN::_Client::svn_client_ctx_t_notify_func2_set", _wrap_svn_client_ctx_t_notify_func2_set},
{"SVN::_Client::svn_client_ctx_t_notify_func2_get", _wrap_svn_client_ctx_t_notify_func2_get},
{"SVN::_Client::svn_client_ctx_t_notify_baton2_set", _wrap_svn_client_ctx_t_notify_baton2_set},
{"SVN::_Client::svn_client_ctx_t_notify_baton2_get", _wrap_svn_client_ctx_t_notify_baton2_get},
{"SVN::_Client::svn_client_ctx_t_log_msg_func2_set", _wrap_svn_client_ctx_t_log_msg_func2_set},
{"SVN::_Client::svn_client_ctx_t_log_msg_func2_get", _wrap_svn_client_ctx_t_log_msg_func2_get},
{"SVN::_Client::svn_client_ctx_t_log_msg_baton2_set", _wrap_svn_client_ctx_t_log_msg_baton2_set},
{"SVN::_Client::svn_client_ctx_t_log_msg_baton2_get", _wrap_svn_client_ctx_t_log_msg_baton2_get},
{"SVN::_Client::svn_client_ctx_t_progress_func_set", _wrap_svn_client_ctx_t_progress_func_set},
{"SVN::_Client::svn_client_ctx_t_progress_func_get", _wrap_svn_client_ctx_t_progress_func_get},
{"SVN::_Client::svn_client_ctx_t_progress_baton_set", _wrap_svn_client_ctx_t_progress_baton_set},
{"SVN::_Client::svn_client_ctx_t_progress_baton_get", _wrap_svn_client_ctx_t_progress_baton_get},
{"SVN::_Client::new_svn_client_ctx_t", _wrap_new_svn_client_ctx_t},
{"SVN::_Client::delete_svn_client_ctx_t", _wrap_delete_svn_client_ctx_t},
{"SVN::_Client::svn_client_create_context", _wrap_svn_client_create_context},
{"SVN::_Client::svn_client_checkout2", _wrap_svn_client_checkout2},
{"SVN::_Client::svn_client_checkout", _wrap_svn_client_checkout},
{"SVN::_Client::svn_client_update2", _wrap_svn_client_update2},
{"SVN::_Client::svn_client_update", _wrap_svn_client_update},
{"SVN::_Client::svn_client_switch", _wrap_svn_client_switch},
{"SVN::_Client::svn_client_add3", _wrap_svn_client_add3},
{"SVN::_Client::svn_client_add2", _wrap_svn_client_add2},
{"SVN::_Client::svn_client_add", _wrap_svn_client_add},
{"SVN::_Client::svn_client_mkdir2", _wrap_svn_client_mkdir2},
{"SVN::_Client::svn_client_mkdir", _wrap_svn_client_mkdir},
{"SVN::_Client::svn_client_delete2", _wrap_svn_client_delete2},
{"SVN::_Client::svn_client_delete", _wrap_svn_client_delete},
{"SVN::_Client::svn_client_import2", _wrap_svn_client_import2},
{"SVN::_Client::svn_client_import", _wrap_svn_client_import},
{"SVN::_Client::svn_client_commit3", _wrap_svn_client_commit3},
{"SVN::_Client::svn_client_commit2", _wrap_svn_client_commit2},
{"SVN::_Client::svn_client_commit", _wrap_svn_client_commit},
{"SVN::_Client::svn_client_status2", _wrap_svn_client_status2},
{"SVN::_Client::svn_client_status", _wrap_svn_client_status},
{"SVN::_Client::svn_client_log3", _wrap_svn_client_log3},
{"SVN::_Client::svn_client_log2", _wrap_svn_client_log2},
{"SVN::_Client::svn_client_log", _wrap_svn_client_log},
{"SVN::_Client::svn_client_blame3", _wrap_svn_client_blame3},
{"SVN::_Client::svn_client_blame2", _wrap_svn_client_blame2},
{"SVN::_Client::svn_client_blame", _wrap_svn_client_blame},
{"SVN::_Client::svn_client_diff3", _wrap_svn_client_diff3},
{"SVN::_Client::svn_client_diff2", _wrap_svn_client_diff2},
{"SVN::_Client::svn_client_diff", _wrap_svn_client_diff},
{"SVN::_Client::svn_client_diff_peg3", _wrap_svn_client_diff_peg3},
{"SVN::_Client::svn_client_diff_peg2", _wrap_svn_client_diff_peg2},
{"SVN::_Client::svn_client_diff_peg", _wrap_svn_client_diff_peg},
{"SVN::_Client::svn_client_diff_summarize", _wrap_svn_client_diff_summarize},
{"SVN::_Client::svn_client_diff_summarize_peg", _wrap_svn_client_diff_summarize_peg},
{"SVN::_Client::svn_client_merge2", _wrap_svn_client_merge2},
{"SVN::_Client::svn_client_merge", _wrap_svn_client_merge},
{"SVN::_Client::svn_client_merge_peg2", _wrap_svn_client_merge_peg2},
{"SVN::_Client::svn_client_merge_peg", _wrap_svn_client_merge_peg},
{"SVN::_Client::svn_client_cleanup", _wrap_svn_client_cleanup},
{"SVN::_Client::svn_client_relocate", _wrap_svn_client_relocate},
{"SVN::_Client::svn_client_revert", _wrap_svn_client_revert},
{"SVN::_Client::svn_client_resolved", _wrap_svn_client_resolved},
{"SVN::_Client::svn_client_copy3", _wrap_svn_client_copy3},
{"SVN::_Client::svn_client_copy2", _wrap_svn_client_copy2},
{"SVN::_Client::svn_client_copy", _wrap_svn_client_copy},
{"SVN::_Client::svn_client_move4", _wrap_svn_client_move4},
{"SVN::_Client::svn_client_move3", _wrap_svn_client_move3},
{"SVN::_Client::svn_client_move2", _wrap_svn_client_move2},
{"SVN::_Client::svn_client_move", _wrap_svn_client_move},
{"SVN::_Client::svn_client_propset2", _wrap_svn_client_propset2},
{"SVN::_Client::svn_client_propset", _wrap_svn_client_propset},
{"SVN::_Client::svn_client_revprop_set", _wrap_svn_client_revprop_set},
{"SVN::_Client::svn_client_propget2", _wrap_svn_client_propget2},
{"SVN::_Client::svn_client_propget", _wrap_svn_client_propget},
{"SVN::_Client::svn_client_revprop_get", _wrap_svn_client_revprop_get},
{"SVN::_Client::svn_client_proplist2", _wrap_svn_client_proplist2},
{"SVN::_Client::svn_client_proplist", _wrap_svn_client_proplist},
{"SVN::_Client::svn_client_revprop_list", _wrap_svn_client_revprop_list},
{"SVN::_Client::svn_client_export3", _wrap_svn_client_export3},
{"SVN::_Client::svn_client_export2", _wrap_svn_client_export2},
{"SVN::_Client::svn_client_export", _wrap_svn_client_export},
{"SVN::_Client::svn_client_list", _wrap_svn_client_list},
{"SVN::_Client::svn_client_ls3", _wrap_svn_client_ls3},
{"SVN::_Client::svn_client_ls2", _wrap_svn_client_ls2},
{"SVN::_Client::svn_client_ls", _wrap_svn_client_ls},
{"SVN::_Client::svn_client_cat2", _wrap_svn_client_cat2},
{"SVN::_Client::svn_client_cat", _wrap_svn_client_cat},
{"SVN::_Client::svn_client_lock", _wrap_svn_client_lock},
{"SVN::_Client::svn_client_unlock", _wrap_svn_client_unlock},
{"SVN::_Client::svn_info_t_URL_set", _wrap_svn_info_t_URL_set},
{"SVN::_Client::svn_info_t_URL_get", _wrap_svn_info_t_URL_get},
{"SVN::_Client::svn_info_t_rev_set", _wrap_svn_info_t_rev_set},
{"SVN::_Client::svn_info_t_rev_get", _wrap_svn_info_t_rev_get},
{"SVN::_Client::svn_info_t_kind_set", _wrap_svn_info_t_kind_set},
{"SVN::_Client::svn_info_t_kind_get", _wrap_svn_info_t_kind_get},
{"SVN::_Client::svn_info_t_repos_root_URL_set", _wrap_svn_info_t_repos_root_URL_set},
{"SVN::_Client::svn_info_t_repos_root_URL_get", _wrap_svn_info_t_repos_root_URL_get},
{"SVN::_Client::svn_info_t_repos_UUID_set", _wrap_svn_info_t_repos_UUID_set},
{"SVN::_Client::svn_info_t_repos_UUID_get", _wrap_svn_info_t_repos_UUID_get},
{"SVN::_Client::svn_info_t_last_changed_rev_set", _wrap_svn_info_t_last_changed_rev_set},
{"SVN::_Client::svn_info_t_last_changed_rev_get", _wrap_svn_info_t_last_changed_rev_get},
{"SVN::_Client::svn_info_t_last_changed_date_set", _wrap_svn_info_t_last_changed_date_set},
{"SVN::_Client::svn_info_t_last_changed_date_get", _wrap_svn_info_t_last_changed_date_get},
{"SVN::_Client::svn_info_t_last_changed_author_set", _wrap_svn_info_t_last_changed_author_set},
{"SVN::_Client::svn_info_t_last_changed_author_get", _wrap_svn_info_t_last_changed_author_get},
{"SVN::_Client::svn_info_t_lock_set", _wrap_svn_info_t_lock_set},
{"SVN::_Client::svn_info_t_lock_get", _wrap_svn_info_t_lock_get},
{"SVN::_Client::svn_info_t_has_wc_info_set", _wrap_svn_info_t_has_wc_info_set},
{"SVN::_Client::svn_info_t_has_wc_info_get", _wrap_svn_info_t_has_wc_info_get},
{"SVN::_Client::svn_info_t_schedule_set", _wrap_svn_info_t_schedule_set},
{"SVN::_Client::svn_info_t_schedule_get", _wrap_svn_info_t_schedule_get},
{"SVN::_Client::svn_info_t_copyfrom_url_set", _wrap_svn_info_t_copyfrom_url_set},
{"SVN::_Client::svn_info_t_copyfrom_url_get", _wrap_svn_info_t_copyfrom_url_get},
{"SVN::_Client::svn_info_t_copyfrom_rev_set", _wrap_svn_info_t_copyfrom_rev_set},
{"SVN::_Client::svn_info_t_copyfrom_rev_get", _wrap_svn_info_t_copyfrom_rev_get},
{"SVN::_Client::svn_info_t_text_time_set", _wrap_svn_info_t_text_time_set},
{"SVN::_Client::svn_info_t_text_time_get", _wrap_svn_info_t_text_time_get},
{"SVN::_Client::svn_info_t_prop_time_set", _wrap_svn_info_t_prop_time_set},
{"SVN::_Client::svn_info_t_prop_time_get", _wrap_svn_info_t_prop_time_get},
{"SVN::_Client::svn_info_t_checksum_set", _wrap_svn_info_t_checksum_set},
{"SVN::_Client::svn_info_t_checksum_get", _wrap_svn_info_t_checksum_get},
{"SVN::_Client::svn_info_t_conflict_old_set", _wrap_svn_info_t_conflict_old_set},
{"SVN::_Client::svn_info_t_conflict_old_get", _wrap_svn_info_t_conflict_old_get},
{"SVN::_Client::svn_info_t_conflict_new_set", _wrap_svn_info_t_conflict_new_set},
{"SVN::_Client::svn_info_t_conflict_new_get", _wrap_svn_info_t_conflict_new_get},
{"SVN::_Client::svn_info_t_conflict_wrk_set", _wrap_svn_info_t_conflict_wrk_set},
{"SVN::_Client::svn_info_t_conflict_wrk_get", _wrap_svn_info_t_conflict_wrk_get},
{"SVN::_Client::svn_info_t_prejfile_set", _wrap_svn_info_t_prejfile_set},
{"SVN::_Client::svn_info_t_prejfile_get", _wrap_svn_info_t_prejfile_get},
{"SVN::_Client::new_svn_info_t", _wrap_new_svn_info_t},
{"SVN::_Client::delete_svn_info_t", _wrap_delete_svn_info_t},
{"SVN::_Client::svn_info_dup", _wrap_svn_info_dup},
{"SVN::_Client::svn_client_info", _wrap_svn_client_info},
{"SVN::_Client::svn_client_url_from_path", _wrap_svn_client_url_from_path},
{"SVN::_Client::svn_client_uuid_from_url", _wrap_svn_client_uuid_from_url},
{"SVN::_Client::svn_client_uuid_from_path", _wrap_svn_client_uuid_from_path},
{"SVN::_Client::svn_client_open_ra_session", _wrap_svn_client_open_ra_session},
{0,0}
};
/*************************************************************************
 * Type initialization:
 * This problem is tough by the requirement that no dynamic 
 * memory is used. Also, since swig_type_info structures store pointers to 
 * swig_cast_info structures and swig_cast_info structures store pointers back
 * to swig_type_info structures, we need some lookup code at initialization. 
 * The idea is that swig generates all the structures that are needed. 
 * The runtime then collects these partially filled structures. 
 * The SWIG_InitializeModule function takes these initial arrays out of 
 * swig_module, and does all the lookup, filling in the swig_module.types
 * array with the correct data and linking the correct swig_cast_info
 * structures together.

 * The generated swig_type_info structures are assigned staticly to an initial 
 * array. We just loop though that array, and handle each type individually.
 * First we lookup if this type has been already loaded, and if so, use the
 * loaded structure instead of the generated one. Then we have to fill in the
 * cast linked list. The cast data is initially stored in something like a
 * two-dimensional array. Each row corresponds to a type (there are the same
 * number of rows as there are in the swig_type_initial array). Each entry in
 * a column is one of the swig_cast_info structures for that type.
 * The cast_initial array is actually an array of arrays, because each row has
 * a variable number of columns. So to actually build the cast linked list,
 * we find the array of casts associated with the type, and loop through it 
 * adding the casts to the list. The one last trick we need to do is making
 * sure the type pointer in the swig_cast_info struct is correct.

 * First off, we lookup the cast->type name to see if it is already loaded. 
 * There are three cases to handle:
 *  1) If the cast->type has already been loaded AND the type we are adding
 *     casting info to has not been loaded (it is in this module), THEN we
 *     replace the cast->type pointer with the type pointer that has already
 *     been loaded.
 *  2) If BOTH types (the one we are adding casting info to, and the 
 *     cast->type) are loaded, THEN the cast info has already been loaded by
 *     the previous module so we just ignore it.
 *  3) Finally, if cast->type has not already been loaded, then we add that
 *     swig_cast_info to the linked list (because the cast->type) pointer will
 *     be correct.
**/

#ifdef __cplusplus
extern "C" {
#endif
    
    SWIGRUNTIME void
    SWIG_InitializeModule(void *clientdata) {
        swig_type_info *type, *ret;
        swig_cast_info *cast;
        size_t i;
        swig_module_info *module_head;
        static int init_run = 0;
        
        clientdata = clientdata;
        
        if (init_run) return;
        init_run = 1;
        
        /* Initialize the swig_module */
        swig_module.type_initial = swig_type_initial;
        swig_module.cast_initial = swig_cast_initial;
        
        /* Try and load any already created modules */
        module_head = SWIG_GetModule(clientdata);
        if (module_head) {
            swig_module.next = module_head->next;
            module_head->next = &swig_module;
        } else {
            /* This is the first module loaded */
            swig_module.next = &swig_module;
            SWIG_SetModule(clientdata, &swig_module);
        }
        
        /* Now work on filling in swig_module.types */
        for (i = 0; i < swig_module.size; ++i) {
            type = 0;
            
            /* if there is another module already loaded */
            if (swig_module.next != &swig_module) {
                type = SWIG_MangledTypeQueryModule(swig_module.next, &swig_module, swig_module.type_initial[i]->name);
            }
            if (type) {
                /* Overwrite clientdata field */
                if (swig_module.type_initial[i]->clientdata) type->clientdata = swig_module.type_initial[i]->clientdata;
            } else {
                type = swig_module.type_initial[i];
            }
            
            /* Insert casting types */
            cast = swig_module.cast_initial[i];
            while (cast->type) {
                /* Don't need to add information already in the list */
                ret = 0;
                if (swig_module.next != &swig_module) {
                    ret = SWIG_MangledTypeQueryModule(swig_module.next, &swig_module, cast->type->name);
                }
                if (ret && type == swig_module.type_initial[i]) {
                    cast->type = ret;
                    ret = 0;
                }
                
                if (!ret) {
                    if (type->cast) {
                        type->cast->prev = cast;
                        cast->next = type->cast;
                    }
                    type->cast = cast;
                }
                
                cast++;
            }
            
            /* Set entry in modules->types array equal to the type */
            swig_module.types[i] = type;
        }
    }
    
    /* This function will propagate the clientdata field of type to
    * any new swig_type_info structures that have been added into the list
    * of equivalent types.  It is like calling
    * SWIG_TypeClientData(type, clientdata) a second time.
    */
    SWIGRUNTIME void
    SWIG_PropagateClientData(void) {
        size_t i;
        swig_cast_info *equiv;
        static int init_run = 0;
        
        if (init_run) return;
        init_run = 1;
        
        for (i = 0; i < swig_module.size; i++) {
            if (swig_module.types[i]->clientdata) {
                equiv = swig_module.types[i]->cast;
                while (equiv) {
                    if (!equiv->converter) {
                        if (equiv->type && !equiv->type->clientdata)
                        SWIG_TypeClientData(equiv->type, swig_module.types[i]->clientdata);
                    }
                    equiv = equiv->next;
                }
            }
        }
    }
    
#ifdef __cplusplus
}
#endif



#ifdef __cplusplus
extern "C"
#endif

XS(SWIG_init) {
    dXSARGS;
    int i;
    
    SWIG_InitializeModule(0);
    
    /* Install commands */
    for (i = 0; swig_commands[i].name; i++) {
        newXS((char*) swig_commands[i].name,swig_commands[i].wrapper, (char*)__FILE__);
    }
    
    /* Install variables */
    for (i = 0; swig_variables[i].name; i++) {
        SV *sv;
        sv = perl_get_sv((char*) swig_variables[i].name, TRUE | 0x2);
        if (swig_variables[i].type) {
            SWIG_MakePtr(sv,(void *)1, *swig_variables[i].type,0);
        } else {
            sv_setiv(sv,(IV) 0);
        }
        swig_create_magic(sv, (char *) swig_variables[i].name, swig_variables[i].set, swig_variables[i].get); 
    }
    
    /* Install constant */
    for (i = 0; swig_constants[i].type; i++) {
        SV *sv;
        sv = perl_get_sv((char*)swig_constants[i].name, TRUE | 0x2);
        switch(swig_constants[i].type) {
            case SWIG_INT:
            sv_setiv(sv, (IV) swig_constants[i].lvalue);
            break;
            case SWIG_FLOAT:
            sv_setnv(sv, (double) swig_constants[i].dvalue);
            break;
            case SWIG_STRING:
            sv_setpv(sv, (char *) swig_constants[i].pvalue);
            break;
            case SWIG_POINTER:
            SWIG_MakePtr(sv, swig_constants[i].pvalue, *(swig_constants[i].ptype),0);
            break;
            case SWIG_BINARY:
            SWIG_MakePackedObj(sv, swig_constants[i].pvalue, swig_constants[i].lvalue, *(swig_constants[i].ptype));
            break;
            default:
            break;
        }
        SvREADONLY_on(sv);
    }
    
    ST(0) = &PL_sv_yes;
    XSRETURN(1);
}



syntax highlighted by Code2HTML, v. 0.9.1