/* ----------------------------------------------------------------------------
 * This file was automatically generated by SWIG (http://www.swig.org).
 * Version 1.3.11u-20020223-1709
 * 
 * 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. 
 * ----------------------------------------------------------------------------- */

/***********************************************************************
 * common.swg
 *
 *     This file contains generic SWIG runtime support for pointer
 *     type checking as well as a few commonly used macros to control
 *     external linkage.
 *
 * Author : David Beazley (beazley@cs.uchicago.edu)
 *
 * Copyright (c) 1999-2000, The University of Chicago
 * 
 * This file may be freely redistributed without license or fee provided
 * this copyright message remains intact.
 ************************************************************************/

#include <string.h>

#if defined(_WIN32) || defined(__WIN32__)
#       if defined(_MSC_VER)
#               if defined(STATIC_LINKED)
#                       define SWIGEXPORT(a) a
#               else
#                       define SWIGEXPORT(a) __declspec(dllexport) a
#               endif
#       else
#               if defined(__BORLANDC__)
#                       define SWIGEXPORT(a) a _export
#               else
#                       define SWIGEXPORT(a) a
#       endif
#endif
#else
#       define SWIGEXPORT(a) a
#endif

#ifdef SWIG_GLOBAL
#define SWIGRUNTIME(a) SWIGEXPORT(a)
#else
#define SWIGRUNTIME(a) static a
#endif



#ifdef __cplusplus
extern "C" {
#endif

typedef void *(*swig_converter_func)(void *);

typedef struct swig_type_info {
  const char             *name;                 
  swig_converter_func     converter;
  const char             *str;
  struct swig_type_info  *next;
  struct swig_type_info  *prev;
  void                   *clientdata;	
} swig_type_info;

#ifdef SWIG_NOINCLUDE
SWIGEXPORT(swig_type_info *) SWIG_TypeRegister(swig_type_info *);
SWIGEXPORT(swig_type_info *) SWIG_TypeCheck(char *c, swig_type_info *);
SWIGEXPORT(void *) SWIG_TypeCast(swig_type_info *, void *);
SWIGEXPORT(swig_type_info *) SWIG_TypeQuery(const char *);
SWIGEXPORT(void) SWIG_TypeClientData(swig_type_info *, void *);
#else

static swig_type_info *swig_type_list = 0;

/* Register a type mapping with the type-checking */
SWIGRUNTIME(swig_type_info *)
SWIG_TypeRegister(swig_type_info *ti)
{
  swig_type_info *tc, *head, *ret, *next;
  /* Check to see if this type has already been registered */
  tc = swig_type_list;
  while (tc) {
    if (strcmp(tc->name, ti->name) == 0) {
      /* Already exists in the table.  Just add additional types to the list */
      head = tc;
      next = tc->next;
      goto l1;
    }
    tc = tc->prev;
  }
  head = ti;
  next = 0;

  /* Place in list */
  ti->prev = swig_type_list;
  swig_type_list = ti;

  /* Build linked lists */
 l1:
  ret = head;
  tc = ti + 1;
  /* Patch up the rest of the links */
  while (tc->name) {
    head->next = tc;
    tc->prev = head;
    head = tc;
    tc++;
  }
  head->next = next;
  return ret;
}

/* Check the typename */
SWIGRUNTIME(swig_type_info *) 
SWIG_TypeCheck(char *c, swig_type_info *ty)
{
  swig_type_info *s;
  if (!ty) return 0;        /* Void pointer */
  s = ty->next;             /* First element always just a name */
  while (s) {
    if (strcmp(s->name,c) == 0) {
      if (s == ty->next) return s;
      /* Move s to the top of the linked list */
      s->prev->next = s->next;
      if (s->next) {
	s->next->prev = s->prev;
      }
      /* Insert s as second element in the list */
      s->next = ty->next;
      if (ty->next) ty->next->prev = s;
      ty->next = s;
      return s;
    }
    s = s->next;
  }
  return 0;
}

/* Cast a pointer (needed for C++ inheritance */
SWIGRUNTIME(void *) 
SWIG_TypeCast(swig_type_info *ty, void *ptr) 
{
  if ((!ty) || (!ty->converter)) return ptr;
  return (*ty->converter)(ptr);
}

/* Search for a swig_type_info structure */
SWIGRUNTIME(swig_type_info *)
SWIG_TypeQuery(const char *name) {
  swig_type_info *ty = swig_type_list;
  while (ty) {
    if (ty->str && (strcmp(name,ty->str) == 0)) return ty;
    if (ty->name && (strcmp(name,ty->name) == 0)) return ty;
    ty = ty->prev;
  }
  return 0;
}

/* Set the clientdata field for a type */
SWIGRUNTIME(void)
SWIG_TypeClientData(swig_type_info *ti, void *clientdata) {
  swig_type_info *tc, *equiv;
  if (ti->clientdata) return;
  ti->clientdata = clientdata;
  equiv = ti->next;
  while (equiv) {
    if (!equiv->converter) {
      tc = swig_type_list;
      while (tc) {
	if ((strcmp(tc->name, equiv->name) == 0))
	  SWIG_TypeClientData(tc,clientdata);
	tc = tc->prev;
      }
    }
    equiv = equiv->next;
  }
}
#endif

#ifdef __cplusplus
}

#endif




/* -----------------------------------------------------------------------------
 * perl5.swg
 *
 * Perl5 runtime library
 * $Header: /cvsroot/MPEG-LibMPEG3/libmpeg3.c,v 1.3 2002/03/13 00:32:10 synaptic 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

/* 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

#ifdef SWIG_NOINCLUDE

#ifndef PERL_OBJECT
extern int SWIG_ConvertPtr(SV *, void **, swig_type_info *);
extern void SWIG_MakePtr(SV *, void *, swig_type_info *);
#else
extern int _SWIG_ConvertPtr(CPerlObj *, SV *, void **, swig_type_info *);
extern void _SWIG_MakePtr(CPerlObj *, SV *, void *, swig_type_info *);
#define SWIG_ConvertPtr(a,b,c) _SWIG_ConvertPtr(pPerl,a,b,c)
#define SWIG_MakePtr(a,b,c) _SWIG_MakePtr(pPerl,a,b,c)
#endif

#else

/* Function for getting a pointer value */

#ifndef PERL_OBJECT
SWIGRUNTIME(int) 
SWIG_ConvertPtr(SV *sv, void **ptr, swig_type_info *_t)
#else
#define SWIG_ConvertPtr(a,b,c) _SWIG_ConvertPtr(pPerl,a,b,c)
SWIGRUNTIME(int)
_SWIG_ConvertPtr(CPerlObj *pPerl, SV *sv, void **ptr, swig_type_info *_t)
#endif
{
  char *_c;
  swig_type_info *tc;
  IV   tmp;

  /* 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);
    if ((SvTYPE(tsv) == SVt_PVHV)) {
      MAGIC *mg;
      if (SvMAGICAL(tsv)) {
	mg = mg_find(tsv,'P');
	if (mg) {
	  SV *rsv = mg->mg_obj;
	  if (sv_isobject(rsv)) {
	    tmp = SvIV((SV*)SvRV(rsv));
	  }
	}
      } else {
	return -1;
      }
    } else {
      tmp = SvIV((SV*)SvRV(sv));
    }
    if (!_t) {
      *(ptr) = (void *) tmp;
      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 */      
    _c = HvNAME(SvSTASH(SvRV(sv)));
    tc = SWIG_TypeCheck(_c,_t);
    if (!tc) {
      *ptr = (void *) tmp;
      return -1;
    }
    *ptr = SWIG_TypeCast(tc,(void *)tmp);
    return 0;
  }
  *ptr = (void *) tmp;
  return 0;
}
#ifndef PERL_OBJECT
SWIGRUNTIME(void) 
SWIG_MakePtr(SV *sv, void *ptr, swig_type_info *t)
#else
#define SWIG_MakePtr(a,b,c) _SWIG_MakePtr(pPerl,a,b,c)
SWIGRUNTIME(void)
_SWIG_MakePtr(CPerlObj *pPerl, SV *sv, void *ptr, swig_type_info *t)
#endif
{
  sv_setref_pv(sv, (char *) t->name, ptr);
}

#endif

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_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;
}







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

#define  SWIGTYPE_p_unsigned_char swig_types[0] 
#define  SWIGTYPE_p_p_unsigned_char swig_types[1] 
#define  SWIGTYPE_p_float swig_types[2] 
#define  SWIGTYPE_p_mpeg3_t swig_types[3] 
#define  SWIGTYPE_p_p_char swig_types[4] 
#define  SWIGTYPE_p_long swig_types[5] 
#define  SWIGTYPE_p_short swig_types[6] 
static swig_type_info *swig_types[8];

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

#define SWIG_init    boot_MPEG__LibMPEG3

#define SWIG_name   "MPEG::LibMPEG3::boot_MPEG__LibMPEG3"
#define SWIG_prefix "MPEG::LibMPEG3::"

#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 "libmpeg3.h"

extern int mpeg3_check_sig(char *);
extern mpeg3_t *mpeg3_open(char *);
extern mpeg3_t *mpeg3_open_copy(char *,mpeg3_t *);
extern int mpeg3_close(mpeg3_t *);
extern int mpeg3_set_cpus(mpeg3_t *,int );
extern int mpeg3_set_mmx(mpeg3_t *,int );
extern int mpeg3_has_audio(mpeg3_t *);
extern int mpeg3_total_astreams(mpeg3_t *);
extern int mpeg3_audio_channels(mpeg3_t *,int );
extern int mpeg3_sample_rate(mpeg3_t *,int );
extern char *mpeg3_audio_format(mpeg3_t *,int );
extern long mpeg3_audio_samples(mpeg3_t *,int );
extern int mpeg3_set_sample(mpeg3_t *,long ,int );
extern long mpeg3_get_sample(mpeg3_t *,int );
extern int mpeg3_read_audio(mpeg3_t *,float *,short *,int ,long ,int );
extern int mpeg3_reread_audio(mpeg3_t *,float *,short *,int ,long ,int );
extern int mpeg3_read_audio_chunk(mpeg3_t *,unsigned char *,long *,long ,int );
extern int mpeg3_has_video(mpeg3_t *);
extern int mpeg3_total_vstreams(mpeg3_t *);
extern int mpeg3_video_width(mpeg3_t *,int );
extern int mpeg3_video_height(mpeg3_t *,int );
extern float mpeg3_aspect_ratio(mpeg3_t *,int );
extern float mpeg3_frame_rate(mpeg3_t *,int );
extern long mpeg3_video_frames(mpeg3_t *,int );
extern int mpeg3_set_frame(mpeg3_t *,long ,int );
extern long mpeg3_get_frame(mpeg3_t *,int );
extern int mpeg3_seek_percentage(mpeg3_t *,double );
extern double mpeg3_tell_percentage(mpeg3_t *);
extern int mpeg3_previous_frame(mpeg3_t *,int );
extern int mpeg3_end_of_audio(mpeg3_t *,int );
extern int mpeg3_end_of_video(mpeg3_t *,int );
extern double mpeg3_get_time(mpeg3_t *);
extern int mpeg3_read_frame(mpeg3_t *,unsigned char **,int ,int ,int ,int ,int ,int ,int ,int );
extern int mpeg3_colormodel(mpeg3_t *,int );
extern int mpeg3_set_rowspan(mpeg3_t *,int ,int );
extern int mpeg3_read_yuvframe(mpeg3_t *,char *,char *,char *,int ,int ,int ,int ,int );
extern int mpeg3_read_yuvframe_ptr(mpeg3_t *,char **,char **,char **,int );
extern int mpeg3_drop_frames(mpeg3_t *,long ,int );
extern int mpeg3_read_video_chunk(mpeg3_t *,unsigned char *,long *,long ,int );

  int Y_SIZE = 0, UV_SIZE=0;
  
  unsigned char *get_yuvframe( mpeg3_t *file, int w, int h ) {
    char *y, *u, *v;
    unsigned char *output;
    
    Y_SIZE  = w * h;
    UV_SIZE = Y_SIZE / 4;

    // This is Perl's fancy malloc
    New( 0, output, Y_SIZE + ( 2 * UV_SIZE ), char );

    y = &output[0];
    u = &output[Y_SIZE];
    v = &output[Y_SIZE + UV_SIZE];

    mpeg3_read_yuvframe( file,
			 y, u, v,
			 0, 0, 
			 w, h,
			 0 );

    return &output[0];
  }


#ifdef PERL_OBJECT
#define MAGIC_CLASS _wrap_LibMPEG3_var::
class _wrap_LibMPEG3_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;
}
SWIGCLASS_STATIC int _wrap_set_Y_SIZE(pTHX_ SV* sv, MAGIC *mg) {
    MAGIC_PPERL
    mg = mg;
    Y_SIZE = (int ) SvIV(sv);
    return 1;
}


SWIGCLASS_STATIC int _wrap_val_Y_SIZE(pTHX_ SV *sv, MAGIC *mg) {
    MAGIC_PPERL
    mg = mg;
    sv_setiv(sv, (IV) Y_SIZE);
    return 1;
}


SWIGCLASS_STATIC int _wrap_set_UV_SIZE(pTHX_ SV* sv, MAGIC *mg) {
    MAGIC_PPERL
    mg = mg;
    UV_SIZE = (int ) SvIV(sv);
    return 1;
}


SWIGCLASS_STATIC int _wrap_val_UV_SIZE(pTHX_ SV *sv, MAGIC *mg) {
    MAGIC_PPERL
    mg = mg;
    sv_setiv(sv, (IV) UV_SIZE);
    return 1;
}




#ifdef PERL_OBJECT
};
#endif

#ifdef __cplusplus
extern "C" {
#endif
XS(_wrap_mpeg3_check_sig) {
    char *arg1 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_check_sig(path);");
    if (!SvOK((SV*) ST(0))) arg1 = 0;
    else arg1 = (char *) SvPV(ST(0), PL_na);
    result = (int )mpeg3_check_sig(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_open) {
    char *arg1 ;
    mpeg3_t *result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_open(path);");
    if (!SvOK((SV*) ST(0))) arg1 = 0;
    else arg1 = (char *) SvPV(ST(0), PL_na);
    result = (mpeg3_t *)mpeg3_open(arg1);
    
    ST(argvi) = sv_newmortal();
    SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_mpeg3_t);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_open_copy) {
    char *arg1 ;
    mpeg3_t *arg2 ;
    mpeg3_t *result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_open_copy(path,old_file);");
    if (!SvOK((SV*) ST(0))) arg1 = 0;
    else arg1 = (char *) SvPV(ST(0), PL_na);
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 2 of mpeg3_open_copy. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (mpeg3_t *)mpeg3_open_copy(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_mpeg3_t);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_close) {
    mpeg3_t *arg1 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_close(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_close. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (int )mpeg3_close(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_set_cpus) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_set_cpus(file,cpus);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_set_cpus. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_set_cpus(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_set_mmx) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_set_mmx(file,use_mmx);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_set_mmx. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_set_mmx(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_has_audio) {
    mpeg3_t *arg1 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_has_audio(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_has_audio. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (int )mpeg3_has_audio(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_total_astreams) {
    mpeg3_t *arg1 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_total_astreams(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_total_astreams. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (int )mpeg3_total_astreams(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_audio_channels) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_audio_channels(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_audio_channels. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_audio_channels(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_sample_rate) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_sample_rate(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_sample_rate. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_sample_rate(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_audio_format) {
    mpeg3_t *arg1 ;
    int arg2 ;
    char *result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_audio_format(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_audio_format. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (char *)mpeg3_audio_format(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setpv((SV*)ST(argvi++), (char *) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_audio_samples) {
    mpeg3_t *arg1 ;
    int arg2 ;
    long result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_audio_samples(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_audio_samples. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (long )mpeg3_audio_samples(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_set_sample) {
    mpeg3_t *arg1 ;
    long arg2 ;
    int arg3 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 3) || (items > 3)) 
    croak("Usage: mpeg3_set_sample(file,sample,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_set_sample. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (long ) SvIV(ST(1));
    arg3 = (int ) SvIV(ST(2));
    result = (int )mpeg3_set_sample(arg1,arg2,arg3);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_get_sample) {
    mpeg3_t *arg1 ;
    int arg2 ;
    long result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_get_sample(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_get_sample. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (long )mpeg3_get_sample(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_read_audio) {
    mpeg3_t *arg1 ;
    float *arg2 ;
    short *arg3 ;
    int arg4 ;
    long arg5 ;
    int arg6 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 6) || (items > 6)) 
    croak("Usage: mpeg3_read_audio(file,output_f,output_i,channel,samples,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_read_audio. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_float) < 0) {
            croak("Type error in argument 2 of mpeg3_read_audio. Expected %s", SWIGTYPE_p_float->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_short) < 0) {
            croak("Type error in argument 3 of mpeg3_read_audio. Expected %s", SWIGTYPE_p_short->name);
        }
    }
    arg4 = (int ) SvIV(ST(3));
    arg5 = (long ) SvIV(ST(4));
    arg6 = (int ) SvIV(ST(5));
    result = (int )mpeg3_read_audio(arg1,arg2,arg3,arg4,arg5,arg6);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_reread_audio) {
    mpeg3_t *arg1 ;
    float *arg2 ;
    short *arg3 ;
    int arg4 ;
    long arg5 ;
    int arg6 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 6) || (items > 6)) 
    croak("Usage: mpeg3_reread_audio(file,output_f,output_i,channel,samples,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_reread_audio. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_float) < 0) {
            croak("Type error in argument 2 of mpeg3_reread_audio. Expected %s", SWIGTYPE_p_float->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_short) < 0) {
            croak("Type error in argument 3 of mpeg3_reread_audio. Expected %s", SWIGTYPE_p_short->name);
        }
    }
    arg4 = (int ) SvIV(ST(3));
    arg5 = (long ) SvIV(ST(4));
    arg6 = (int ) SvIV(ST(5));
    result = (int )mpeg3_reread_audio(arg1,arg2,arg3,arg4,arg5,arg6);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_read_audio_chunk) {
    mpeg3_t *arg1 ;
    unsigned char *arg2 ;
    long *arg3 ;
    long arg4 ;
    int arg5 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 5) || (items > 5)) 
    croak("Usage: mpeg3_read_audio_chunk(file,output,size,max_size,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_read_audio_chunk. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_unsigned_char) < 0) {
            croak("Type error in argument 2 of mpeg3_read_audio_chunk. Expected %s", SWIGTYPE_p_unsigned_char->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_long) < 0) {
            croak("Type error in argument 3 of mpeg3_read_audio_chunk. Expected %s", SWIGTYPE_p_long->name);
        }
    }
    arg4 = (long ) SvIV(ST(3));
    arg5 = (int ) SvIV(ST(4));
    result = (int )mpeg3_read_audio_chunk(arg1,arg2,arg3,arg4,arg5);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_has_video) {
    mpeg3_t *arg1 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_has_video(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_has_video. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (int )mpeg3_has_video(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_total_vstreams) {
    mpeg3_t *arg1 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_total_vstreams(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_total_vstreams. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (int )mpeg3_total_vstreams(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_video_width) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_video_width(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_video_width. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_video_width(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_video_height) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_video_height(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_video_height. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_video_height(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_aspect_ratio) {
    mpeg3_t *arg1 ;
    int arg2 ;
    float result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_aspect_ratio(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_aspect_ratio. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (float )mpeg3_aspect_ratio(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setnv(ST(argvi++), (double) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_frame_rate) {
    mpeg3_t *arg1 ;
    int arg2 ;
    float result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_frame_rate(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_frame_rate. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (float )mpeg3_frame_rate(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setnv(ST(argvi++), (double) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_video_frames) {
    mpeg3_t *arg1 ;
    int arg2 ;
    long result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_video_frames(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_video_frames. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (long )mpeg3_video_frames(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_set_frame) {
    mpeg3_t *arg1 ;
    long arg2 ;
    int arg3 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 3) || (items > 3)) 
    croak("Usage: mpeg3_set_frame(file,frame,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_set_frame. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (long ) SvIV(ST(1));
    arg3 = (int ) SvIV(ST(2));
    result = (int )mpeg3_set_frame(arg1,arg2,arg3);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_get_frame) {
    mpeg3_t *arg1 ;
    int arg2 ;
    long result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_get_frame(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_get_frame. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (long )mpeg3_get_frame(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_seek_percentage) {
    mpeg3_t *arg1 ;
    double arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_seek_percentage(file,percentage);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_seek_percentage. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (double ) SvNV(ST(1));
    
    result = (int )mpeg3_seek_percentage(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_tell_percentage) {
    mpeg3_t *arg1 ;
    double result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_tell_percentage(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_tell_percentage. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (double )mpeg3_tell_percentage(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setnv(ST(argvi++), (double) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_previous_frame) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_previous_frame(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_previous_frame. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_previous_frame(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_end_of_audio) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_end_of_audio(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_end_of_audio. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_end_of_audio(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_end_of_video) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_end_of_video(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_end_of_video. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_end_of_video(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_get_time) {
    mpeg3_t *arg1 ;
    double result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 1) || (items > 1)) 
    croak("Usage: mpeg3_get_time(file);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_get_time. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    result = (double )mpeg3_get_time(arg1);
    
    ST(argvi) = sv_newmortal();
    sv_setnv(ST(argvi++), (double) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_read_frame) {
    mpeg3_t *arg1 ;
    unsigned char **arg2 ;
    int arg3 ;
    int arg4 ;
    int arg5 ;
    int arg6 ;
    int arg7 ;
    int arg8 ;
    int arg9 ;
    int arg10 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 10) || (items > 10)) 
    croak("Usage: mpeg3_read_frame(file,output_rows,in_x,in_y,in_w,in_h,out_w,out_h,color_model,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_read_frame. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_p_unsigned_char) < 0) {
            croak("Type error in argument 2 of mpeg3_read_frame. Expected %s", SWIGTYPE_p_p_unsigned_char->name);
        }
    }
    arg3 = (int ) SvIV(ST(2));
    arg4 = (int ) SvIV(ST(3));
    arg5 = (int ) SvIV(ST(4));
    arg6 = (int ) SvIV(ST(5));
    arg7 = (int ) SvIV(ST(6));
    arg8 = (int ) SvIV(ST(7));
    arg9 = (int ) SvIV(ST(8));
    arg10 = (int ) SvIV(ST(9));
    result = (int )mpeg3_read_frame(arg1,arg2,arg3,arg4,arg5,arg6,arg7,arg8,arg9,arg10);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_colormodel) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 2) || (items > 2)) 
    croak("Usage: mpeg3_colormodel(file,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_colormodel. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    result = (int )mpeg3_colormodel(arg1,arg2);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_set_rowspan) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int arg3 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 3) || (items > 3)) 
    croak("Usage: mpeg3_set_rowspan(file,bytes,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_set_rowspan. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    arg3 = (int ) SvIV(ST(2));
    result = (int )mpeg3_set_rowspan(arg1,arg2,arg3);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_read_yuvframe) {
    mpeg3_t *arg1 ;
    char *arg2 ;
    char *arg3 ;
    char *arg4 ;
    int arg5 ;
    int arg6 ;
    int arg7 ;
    int arg8 ;
    int arg9 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 9) || (items > 9)) 
    croak("Usage: mpeg3_read_yuvframe(file,y_output,u_output,v_output,in_x,in_y,in_w,in_h,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_read_yuvframe. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    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);
    if (!SvOK((SV*) ST(3))) arg4 = 0;
    else arg4 = (char *) SvPV(ST(3), PL_na);
    arg5 = (int ) SvIV(ST(4));
    arg6 = (int ) SvIV(ST(5));
    arg7 = (int ) SvIV(ST(6));
    arg8 = (int ) SvIV(ST(7));
    arg9 = (int ) SvIV(ST(8));
    result = (int )mpeg3_read_yuvframe(arg1,arg2,arg3,arg4,arg5,arg6,arg7,arg8,arg9);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_read_yuvframe_ptr) {
    mpeg3_t *arg1 ;
    char **arg2 ;
    char **arg3 ;
    char **arg4 ;
    int arg5 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 5) || (items > 5)) 
    croak("Usage: mpeg3_read_yuvframe_ptr(file,y_output,u_output,v_output,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_read_yuvframe_ptr. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_p_char) < 0) {
            croak("Type error in argument 2 of mpeg3_read_yuvframe_ptr. Expected %s", SWIGTYPE_p_p_char->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_p_char) < 0) {
            croak("Type error in argument 3 of mpeg3_read_yuvframe_ptr. Expected %s", SWIGTYPE_p_p_char->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(3), (void **) &arg4, SWIGTYPE_p_p_char) < 0) {
            croak("Type error in argument 4 of mpeg3_read_yuvframe_ptr. Expected %s", SWIGTYPE_p_p_char->name);
        }
    }
    arg5 = (int ) SvIV(ST(4));
    result = (int )mpeg3_read_yuvframe_ptr(arg1,arg2,arg3,arg4,arg5);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_drop_frames) {
    mpeg3_t *arg1 ;
    long arg2 ;
    int arg3 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 3) || (items > 3)) 
    croak("Usage: mpeg3_drop_frames(file,frames,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_drop_frames. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (long ) SvIV(ST(1));
    arg3 = (int ) SvIV(ST(2));
    result = (int )mpeg3_drop_frames(arg1,arg2,arg3);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_mpeg3_read_video_chunk) {
    mpeg3_t *arg1 ;
    unsigned char *arg2 ;
    long *arg3 ;
    long arg4 ;
    int arg5 ;
    int result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 5) || (items > 5)) 
    croak("Usage: mpeg3_read_video_chunk(file,output,size,max_size,stream);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of mpeg3_read_video_chunk. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_unsigned_char) < 0) {
            croak("Type error in argument 2 of mpeg3_read_video_chunk. Expected %s", SWIGTYPE_p_unsigned_char->name);
        }
    }
    {
        if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_long) < 0) {
            croak("Type error in argument 3 of mpeg3_read_video_chunk. Expected %s", SWIGTYPE_p_long->name);
        }
    }
    arg4 = (long ) SvIV(ST(3));
    arg5 = (int ) SvIV(ST(4));
    result = (int )mpeg3_read_video_chunk(arg1,arg2,arg3,arg4,arg5);
    
    ST(argvi) = sv_newmortal();
    sv_setiv(ST(argvi++), (IV) result);
    XSRETURN(argvi);
}


XS(_wrap_get_yuvframe) {
    mpeg3_t *arg1 ;
    int arg2 ;
    int arg3 ;
    unsigned char *result;
    int argvi = 0;
    dXSARGS;
    
    if ((items < 3) || (items > 3)) 
    croak("Usage: get_yuvframe(file,w,h);");
    {
        if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_mpeg3_t) < 0) {
            croak("Type error in argument 1 of get_yuvframe. Expected %s", SWIGTYPE_p_mpeg3_t->name);
        }
    }
    arg2 = (int ) SvIV(ST(1));
    arg3 = (int ) SvIV(ST(2));
    result = (unsigned char *)get_yuvframe(arg1,arg2,arg3);
    
    {
        ST(argvi) = sv_2mortal( newSVpvn( result, Y_SIZE + (2*UV_SIZE ) ) );
        free(result);
        argvi++;
    }
    XSRETURN(argvi);
}



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

static swig_type_info _swigt__p_unsigned_char[] = {{"_p_unsigned_char", 0, "unsigned char *"},{"_p_unsigned_char"},{0}};
static swig_type_info _swigt__p_p_unsigned_char[] = {{"_p_p_unsigned_char", 0, "unsigned char **"},{"_p_p_unsigned_char"},{0}};
static swig_type_info _swigt__p_float[] = {{"_p_float", 0, "float *"},{"_p_float"},{0}};
static swig_type_info _swigt__p_mpeg3_t[] = {{"_p_mpeg3_t", 0, "mpeg3_t *"},{"_p_mpeg3_t"},{0}};
static swig_type_info _swigt__p_p_char[] = {{"_p_p_char", 0, "char **"},{"_p_p_char"},{0}};
static swig_type_info _swigt__p_long[] = {{"_p_long", 0, "long *"},{"_p_long"},{0}};
static swig_type_info _swigt__p_short[] = {{"_p_short", 0, "short *"},{"_p_short"},{0}};

static swig_type_info *swig_types_initial[] = {
_swigt__p_unsigned_char, 
_swigt__p_p_unsigned_char, 
_swigt__p_float, 
_swigt__p_mpeg3_t, 
_swigt__p_p_char, 
_swigt__p_long, 
_swigt__p_short, 
0
};


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

static swig_constant_info swig_constants[] = {
{0}
};
#ifdef __cplusplus
}
#endif
static swig_variable_info swig_variables[] = {
    { "MPEG::LibMPEG3::Y_SIZE", MAGIC_CLASS _wrap_set_Y_SIZE, MAGIC_CLASS _wrap_val_Y_SIZE },
    { "MPEG::LibMPEG3::UV_SIZE", MAGIC_CLASS _wrap_set_UV_SIZE, MAGIC_CLASS _wrap_val_UV_SIZE },
{0}
};
static swig_command_info swig_commands[] = {
{"MPEG::LibMPEG3::mpeg3_check_sig", _wrap_mpeg3_check_sig},
{"MPEG::LibMPEG3::mpeg3_open", _wrap_mpeg3_open},
{"MPEG::LibMPEG3::mpeg3_open_copy", _wrap_mpeg3_open_copy},
{"MPEG::LibMPEG3::mpeg3_close", _wrap_mpeg3_close},
{"MPEG::LibMPEG3::mpeg3_set_cpus", _wrap_mpeg3_set_cpus},
{"MPEG::LibMPEG3::mpeg3_set_mmx", _wrap_mpeg3_set_mmx},
{"MPEG::LibMPEG3::mpeg3_has_audio", _wrap_mpeg3_has_audio},
{"MPEG::LibMPEG3::mpeg3_total_astreams", _wrap_mpeg3_total_astreams},
{"MPEG::LibMPEG3::mpeg3_audio_channels", _wrap_mpeg3_audio_channels},
{"MPEG::LibMPEG3::mpeg3_sample_rate", _wrap_mpeg3_sample_rate},
{"MPEG::LibMPEG3::mpeg3_audio_format", _wrap_mpeg3_audio_format},
{"MPEG::LibMPEG3::mpeg3_audio_samples", _wrap_mpeg3_audio_samples},
{"MPEG::LibMPEG3::mpeg3_set_sample", _wrap_mpeg3_set_sample},
{"MPEG::LibMPEG3::mpeg3_get_sample", _wrap_mpeg3_get_sample},
{"MPEG::LibMPEG3::mpeg3_read_audio", _wrap_mpeg3_read_audio},
{"MPEG::LibMPEG3::mpeg3_reread_audio", _wrap_mpeg3_reread_audio},
{"MPEG::LibMPEG3::mpeg3_read_audio_chunk", _wrap_mpeg3_read_audio_chunk},
{"MPEG::LibMPEG3::mpeg3_has_video", _wrap_mpeg3_has_video},
{"MPEG::LibMPEG3::mpeg3_total_vstreams", _wrap_mpeg3_total_vstreams},
{"MPEG::LibMPEG3::mpeg3_video_width", _wrap_mpeg3_video_width},
{"MPEG::LibMPEG3::mpeg3_video_height", _wrap_mpeg3_video_height},
{"MPEG::LibMPEG3::mpeg3_aspect_ratio", _wrap_mpeg3_aspect_ratio},
{"MPEG::LibMPEG3::mpeg3_frame_rate", _wrap_mpeg3_frame_rate},
{"MPEG::LibMPEG3::mpeg3_video_frames", _wrap_mpeg3_video_frames},
{"MPEG::LibMPEG3::mpeg3_set_frame", _wrap_mpeg3_set_frame},
{"MPEG::LibMPEG3::mpeg3_get_frame", _wrap_mpeg3_get_frame},
{"MPEG::LibMPEG3::mpeg3_seek_percentage", _wrap_mpeg3_seek_percentage},
{"MPEG::LibMPEG3::mpeg3_tell_percentage", _wrap_mpeg3_tell_percentage},
{"MPEG::LibMPEG3::mpeg3_previous_frame", _wrap_mpeg3_previous_frame},
{"MPEG::LibMPEG3::mpeg3_end_of_audio", _wrap_mpeg3_end_of_audio},
{"MPEG::LibMPEG3::mpeg3_end_of_video", _wrap_mpeg3_end_of_video},
{"MPEG::LibMPEG3::mpeg3_get_time", _wrap_mpeg3_get_time},
{"MPEG::LibMPEG3::mpeg3_read_frame", _wrap_mpeg3_read_frame},
{"MPEG::LibMPEG3::mpeg3_colormodel", _wrap_mpeg3_colormodel},
{"MPEG::LibMPEG3::mpeg3_set_rowspan", _wrap_mpeg3_set_rowspan},
{"MPEG::LibMPEG3::mpeg3_read_yuvframe", _wrap_mpeg3_read_yuvframe},
{"MPEG::LibMPEG3::mpeg3_read_yuvframe_ptr", _wrap_mpeg3_read_yuvframe_ptr},
{"MPEG::LibMPEG3::mpeg3_drop_frames", _wrap_mpeg3_drop_frames},
{"MPEG::LibMPEG3::mpeg3_read_video_chunk", _wrap_mpeg3_read_video_chunk},
{"MPEG::LibMPEG3::get_yuvframe", _wrap_get_yuvframe},
{0,0}
};

#ifdef __cplusplus
extern "C"
#endif

XS(SWIG_init) {
    dXSARGS;
    int i;
    for (i = 0; swig_types_initial[i]; i++) {
        swig_types[i] = SWIG_TypeRegister(swig_types_initial[i]);
    }
    
    /* 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);
        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));
            break;
            case SWIG_BINARY:
            /*      obj = SWIG_NewPackedObj(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);
}