1
/* Copyright 2001-2004 The Apache Software Foundation
3
* Licensed under the Apache License, Version 2.0 (the "License");
4
* you may not use this file except in compliance with the License.
5
* You may obtain a copy of the License at
7
* http://www.apache.org/licenses/LICENSE-2.0
9
* Unless required by applicable law or agreed to in writing, software
10
* distributed under the License is distributed on an "AS IS" BASIS,
11
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
* See the License for the specific language governing permissions and
13
* limitations under the License.
16
#ifndef MODPERL_ERROR_H
17
#define MODPERL_ERROR_H
19
/* to check whether $@ is set by ModPerl::Util::exit */
20
#define MODPERL_RC_EXIT APR_OS_START_USERERR + 0
24
* return the string representation of the error code
25
* @param rc error code
26
* @return the error string
28
* The return value must be immediately copied unless used only in a
29
* limited visible scope where it's clear that Perl_form() is not
30
* called again (which could happen indirectly). If unsure, copy.
32
char *modperl_error_strerror(pTHX_ apr_status_t rc);
34
void modperl_croak(pTHX_ apr_status_t rc, const char* func);
36
#define MP_RUN_CROAK(rc_run, func) STMT_START \
38
apr_status_t rc = rc_run; \
39
if (rc != APR_SUCCESS) { \
40
modperl_croak(aTHX_ rc, func); \
44
#endif /* MODPERL_ERROR_H */