From 5bf1b058baa3acee54cad80f0d378f105808b555 Mon Sep 17 00:00:00 2001 From: midipix Date: Fri, 2 Sep 2016 14:58:09 -0400 Subject: internals: error trace implementation: added slbt_record_error(). --- src/internal/slibtool_errinfo_impl.c | 41 ++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 src/internal/slibtool_errinfo_impl.c (limited to 'src/internal/slibtool_errinfo_impl.c') diff --git a/src/internal/slibtool_errinfo_impl.c b/src/internal/slibtool_errinfo_impl.c new file mode 100644 index 0000000..889f566 --- /dev/null +++ b/src/internal/slibtool_errinfo_impl.c @@ -0,0 +1,41 @@ +/*******************************************************************/ +/* slibtool: a skinny libtool implementation, written in C */ +/* Copyright (C) 2016 Z. Gilboa */ +/* Released under the Standard MIT License; see COPYING.SLIBTOOL. */ +/*******************************************************************/ + +#include +#include "slibtool_driver_impl.h" +#include "slibtool_errinfo_impl.h" + +int slbt_record_error( + const struct slbt_driver_ctx * dctx, + int syserror, + int liberror, + const char * function, + int line, + unsigned flags, + void * ctx) +{ + struct slbt_driver_ctx_impl * ictx; + struct slbt_error_info * erri; + + ictx = slbt_get_driver_ictx(dctx); + + if (ictx->errinfp == ictx->erricap) + return -1; + + *ictx->errinfp = &ictx->erribuf[ictx->errinfp - ictx->erriptr]; + erri = *ictx->errinfp; + + erri->syserror = syserror; + erri->liberror = liberror; + erri->function = function; + erri->line = line; + erri->flags = flags; + erri->ctx = ctx; + + ictx->errinfp++; + + return -1; +} -- cgit v1.2.3