/* * This file was generated automatically by ExtUtils::ParseXS version 2.21 from the * contents of Log.xs. Do not edit this file, edit Log.xs instead. * * ANY CHANGES MADE HERE WILL BE LOST! * */ #line 1 "Log.xs" /* * *********** WARNING ************** * This file generated by ModPerl::WrapXS/0.01 * Any changes made here will be lost * *********************************** * 01: lib/ModPerl/WrapXS.pm:540 * 02: lib/ModPerl/WrapXS.pm:1174 * 03: Makefile.PL:423 * 04: Makefile.PL:325 * 05: Makefile.PL:56 */ #define MP_IN_XS #include "mod_perl.h" #include "modperl_xs_sv_convert.h" #include "modperl_xs_util.h" #include "modperl_xs_typedefs.h" #include "Apache2/Log/Apache2__Log.h" #line 38 "Log.c" #ifndef PERL_UNUSED_VAR # define PERL_UNUSED_VAR(var) if (0) var = var #endif #ifndef PERL_ARGS_ASSERT_CROAK_XS_USAGE #define PERL_ARGS_ASSERT_CROAK_XS_USAGE assert(cv); assert(params) /* prototype to pass -Wmissing-prototypes */ STATIC void S_croak_xs_usage(pTHX_ const CV *const cv, const char *const params); STATIC void S_croak_xs_usage(pTHX_ const CV *const cv, const char *const params) { const GV *const gv = CvGV(cv); PERL_ARGS_ASSERT_CROAK_XS_USAGE; if (gv) { const char *const gvname = GvNAME(gv); const HV *const stash = GvSTASH(gv); const char *const hvname = stash ? HvNAME(stash) : NULL; if (hvname) Perl_croak(aTHX_ "Usage: %s::%s(%s)", hvname, gvname, params); else Perl_croak(aTHX_ "Usage: %s(%s)", gvname, params); } else { /* Pants. I don't think that it should be possible to get here. */ Perl_croak(aTHX_ "Usage: CODE(0x%"UVxf")(%s)", PTR2UV(cv), params); } } #undef PERL_ARGS_ASSERT_CROAK_XS_USAGE #ifdef PERL_IMPLICIT_CONTEXT #define croak_xs_usage(a,b) S_croak_xs_usage(aTHX_ a,b) #else #define croak_xs_usage S_croak_xs_usage #endif #endif /* NOTE: the prototype of newXSproto() is different in versions of perls, * so we define a portable version of newXSproto() */ #ifdef newXS_flags #define newXSproto_portable(name, c_impl, file, proto) newXS_flags(name, c_impl, file, proto, 0) #else #define newXSproto_portable(name, c_impl, file, proto) (PL_Sv=(SV*)newXS(name, c_impl, file), sv_setpv(PL_Sv, proto), (CV*)PL_Sv) #endif /* !defined(newXS_flags) */ #line 90 "Log.c" XS(XS_Apache2__Log_log_pid); /* prototype to pass -Wmissing-prototypes */ XS(XS_Apache2__Log_log_pid) { #ifdef dVAR dVAR; dXSARGS; #else dXSARGS; #endif if (items != 2) croak_xs_usage(cv, "p, fname"); { APR__Pool p; const char * fname = (const char *)SvPV_nolen(ST(1)); if (SvROK(ST(0)) && sv_derived_from(ST(0), "APR::Pool")) { IV tmp = SvIV((SV*)SvRV(ST(0))); if (tmp == 0) { Perl_croak(aTHX_ "invalid pool object (already destroyed?)"); } p = INT2PTR(APR__Pool, tmp); } else { Perl_croak(aTHX_ SvROK(ST(0)) ? "p is not of type APR::Pool" : "p is not a blessed reference"); }; ap_log_pid(p, fname); } XSRETURN_EMPTY; } XS(XS_Apache2__ServerRec_log); /* prototype to pass -Wmissing-prototypes */ XS(XS_Apache2__ServerRec_log) { #ifdef dVAR dVAR; dXSARGS; #else dXSARGS; #endif if (items != 1) croak_xs_usage(cv, "obj"); { SV * obj = ST(0); SV * RETVAL; #line 44 "Log.xs" RETVAL = mpxs_Apache2__ServerRec_log(obj); #line 141 "Log.c" ST(0) = RETVAL; sv_2mortal(ST(0)); } XSRETURN(1); } XS(XS_Apache2__RequestRec_log); /* prototype to pass -Wmissing-prototypes */ XS(XS_Apache2__RequestRec_log) { #ifdef dVAR dVAR; dXSARGS; #else dXSARGS; #endif if (items != 1) croak_xs_usage(cv, "obj"); { SV * obj = ST(0); SV * RETVAL; #line 57 "Log.xs" RETVAL = mpxs_Apache2__RequestRec_log(obj); #line 165 "Log.c" ST(0) = RETVAL; sv_2mortal(ST(0)); } XSRETURN(1); } XS(XS_Apache2__RequestRec_log_reason); /* prototype to pass -Wmissing-prototypes */ XS(XS_Apache2__RequestRec_log_reason) { #ifdef dVAR dVAR; dXSARGS; #else dXSARGS; #endif if (items < 2 || items > 3) croak_xs_usage(cv, "r, msg, file=r->uri"); { Apache2__RequestRec r = modperl_xs_sv2request_rec(aTHX_ ST(0), "Apache2::RequestRec", cv); char * msg = (char *)SvPV_nolen(ST(1)); char * file; if (items < 3) file = r->uri; else { file = (char *)SvPV_nolen(ST(2)); } #line 72 "Log.xs" modperl_log_reason(r, msg, file); #line 195 "Log.c" } XSRETURN_EMPTY; } #ifdef __cplusplus extern "C" #endif XS(boot_Apache2__Log); /* prototype to pass -Wmissing-prototypes */ XS(boot_Apache2__Log) { #ifdef dVAR dVAR; dXSARGS; #else dXSARGS; #endif #if (PERL_REVISION == 5 && PERL_VERSION < 9) char* file = __FILE__; #else const char* file = __FILE__; #endif PERL_UNUSED_VAR(cv); /* -W */ PERL_UNUSED_VAR(items); /* -W */ XS_VERSION_BOOTCHECK ; (void)newXS("Apache2::Log::log_pid", XS_Apache2__Log_log_pid, file); (void)newXS("Apache2::ServerRec::log", XS_Apache2__ServerRec_log, file); (void)newXS("Apache2::RequestRec::log", XS_Apache2__RequestRec_log, file); (void)newXS("Apache2::RequestRec::log_reason", XS_Apache2__RequestRec_log_reason, file); /* Initialisation Section */ #line 79 "Log.xs" mpxs_Apache2__Log_BOOT(aTHX); items = items; /* -Wall */ cv = newXS("Apache2::Log::LOG_MARK", MPXS_Apache2__Log_LOG_MARK, __FILE__); cv = newXS("Apache2::Log::alert", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::crit", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::debug", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::emerg", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::error", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::info", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::notice", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::Log::warn", MPXS_Apache2__Log_dispatch, __FILE__); cv = newXS("Apache2::RequestRec::log_error", MPXS_Apache2__Log_log_error, __FILE__); cv = newXS("Apache2::RequestRec::log_rerror", MPXS_Apache2__Log_log_xerror, __FILE__); cv = newXS("Apache2::RequestRec::warn", MPXS_Apache2__Log_log_error, __FILE__); cv = newXS("Apache2::ServerRec::log_error", MPXS_Apache2__Log_log_error, __FILE__); cv = newXS("Apache2::ServerRec::log_serror", MPXS_Apache2__Log_log_xerror, __FILE__); cv = newXS("Apache2::ServerRec::warn", MPXS_Apache2__Log_log_error, __FILE__); #line 248 "Log.c" /* End of Initialisation Section */ #if (PERL_REVISION == 5 && PERL_VERSION >= 9) if (PL_unitcheckav) call_list(PL_scopestack_ix, PL_unitcheckav); #endif XSRETURN_YES; }