/* GnuTLS --- Guile bindings for GnuTLS. Copyright (C) 2007-2012, 2019 Free Software Foundation, Inc. GnuTLS is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. GnuTLS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with GnuTLS; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ /* Written by Ludovic Courtès . */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include "errors.h" #include "enums.h" SCM_SYMBOL (gnutls_error_key, "gnutls-error"); void scm_gnutls_error_with_args (int c_err, const char *c_func, SCM args) { SCM err, func; /* Note: If error code C_ERR is unknown, then ERR will be `#f'. */ err = scm_from_gnutls_error (c_err); func = scm_from_locale_symbol (c_func); (void) scm_throw (gnutls_error_key, scm_cons2 (err, func, args)); /* XXX: This is actually never reached, but since the Guile headers don't declare `scm_throw ()' as `noreturn', we must add this to avoid GCC's complaints. */ abort (); } void scm_gnutls_error (int c_err, const char *c_func) { scm_gnutls_error_with_args (c_err, c_func, SCM_EOL); } SCM_DEFINE (scm_gnutls_fatal_error_p, "fatal-error?", 1, 0, 0, (SCM err), "Return true if @var{error} is fatal.") #define FUNC_NAME s_scm_gnutls_fatal_error_p { int c_err = scm_to_gnutls_error (err, 1, FUNC_NAME); return scm_from_bool (gnutls_error_is_fatal (c_err)); } #undef FUNC_NAME void scm_init_gnutls_error (void) { #include "errors.x" } /* arch-tag: 48f07ecf-65c4-480c-b043-a51eab592d6b */