X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=augeas-c.c;fp=augeas-c.c;h=81f87f92fc0bda3e22072e15b8a824ce49ac9880;hb=6d61606ee8c5c81d5492d062bd1e15fe2165edc7;hp=f3f52231886f66220b0f82137f95ae66da74ad72;hpb=bb20badcb781cbecc9e33a352d0078545d27a967;p=ocaml-augeas.git diff --git a/augeas-c.c b/augeas-c.c index f3f5223..81f87f9 100644 --- a/augeas-c.c +++ b/augeas-c.c @@ -29,6 +29,8 @@ #include #include +#include + #ifdef __GNUC__ #define NORETURN __attribute__ ((noreturn)) #else @@ -73,9 +75,11 @@ static const int error_map[] = { }; static const int error_map_len = sizeof error_map / sizeof error_map[0]; -/* Raise an Augeas.Error exception. */ +/* Raise an Augeas.Error exception, and optionally close the + * specified handle. + */ static void -raise_error (augeas_t t, const char *msg) +raise_error_and_maybe_close (augeas_t t, const char *msg, bool close_handle) { value *exn = caml_named_value ("Augeas.Error"); value args[4]; @@ -85,8 +89,11 @@ raise_error (augeas_t t, const char *msg) int ocaml_code = -1; int i; - if (code == AUG_ENOMEM) + if (code == AUG_ENOMEM) { + if (close_handle) + aug_close (t); caml_raise_out_of_memory (); + } aug_err_minor = aug_error_minor_message (t); aug_err_details = aug_error_details (t); @@ -107,8 +114,12 @@ raise_error (augeas_t t, const char *msg) args[2] = caml_copy_string (aug_err_minor ? : ""); args[3] = caml_copy_string (aug_err_details ? : ""); + if (close_handle) + aug_close (t); + caml_raise_with_args (*exn, 4, args); } +#define raise_error(t, msg) raise_error_and_maybe_close(t, msg, false) static void raise_init_error (const char *msg)