/* $Id$ */ /* Copyright (c) 2020 Pierre Pronchery */ /* This file is part of DeforaOS System libMarshall */ /* All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "System/Marshall.h" /* MarshallCall */ /* public */ /* functions */ /* marshall_call */ int marshall_call(Variable * res, MarshallCall call, size_t args_cnt, ...) { int ret; va_list ap; va_start(ap, args_cnt); ret = marshall_callv(res, call, args_cnt, ap); va_end(ap); return ret; } /* marshall_callv */ int marshall_callv(Variable * res, MarshallCall call, size_t args_cnt, va_list ap) { int ret; Variable ** args; size_t i; if(args_cnt == 0) args = NULL; else if((args = object_new(sizeof(*args) * args_cnt)) == NULL) return -1; for(i = 0; i < args_cnt; i++) args[i] = va_arg(ap, Variable *); ret = marshall_callp(res, call, args_cnt, args); object_delete(args); return ret; }