1*2de3b87aSKai Wang/*- 2*2de3b87aSKai Wang * Copyright (c) 2010 Kai Wang 3*2de3b87aSKai Wang * All rights reserved. 4*2de3b87aSKai Wang * 5*2de3b87aSKai Wang * Redistribution and use in source and binary forms, with or without 6*2de3b87aSKai Wang * modification, are permitted provided that the following conditions 7*2de3b87aSKai Wang * are met: 8*2de3b87aSKai Wang * 1. Redistributions of source code must retain the above copyright 9*2de3b87aSKai Wang * notice, this list of conditions and the following disclaimer. 10*2de3b87aSKai Wang * 2. Redistributions in binary form must reproduce the above copyright 11*2de3b87aSKai Wang * notice, this list of conditions and the following disclaimer in the 12*2de3b87aSKai Wang * documentation and/or other materials provided with the distribution. 13*2de3b87aSKai Wang * 14*2de3b87aSKai Wang * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15*2de3b87aSKai Wang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16*2de3b87aSKai Wang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17*2de3b87aSKai Wang * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18*2de3b87aSKai Wang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19*2de3b87aSKai Wang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20*2de3b87aSKai Wang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21*2de3b87aSKai Wang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22*2de3b87aSKai Wang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23*2de3b87aSKai Wang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24*2de3b87aSKai Wang * SUCH DAMAGE. 25*2de3b87aSKai Wang * 26*2de3b87aSKai Wang * $Id: dwarf_pro_nametbl.m4 2074 2011-10-27 03:34:33Z jkoshy $ 27*2de3b87aSKai Wang */ 28*2de3b87aSKai Wang 29*2de3b87aSKai Wangdefine(`MAKE_NAMETBL_PRO_API',` 30*2de3b87aSKai WangDwarf_Unsigned 31*2de3b87aSKai Wangdwarf_add_$1name(Dwarf_P_Debug dbg, Dwarf_P_Die die, char *$1_name, 32*2de3b87aSKai Wang Dwarf_Error *error) 33*2de3b87aSKai Wang{ 34*2de3b87aSKai Wang Dwarf_NameTbl nt; 35*2de3b87aSKai Wang Dwarf_NamePair np; 36*2de3b87aSKai Wang 37*2de3b87aSKai Wang if (dbg == NULL || die == NULL || $1_name == NULL) { 38*2de3b87aSKai Wang DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT); 39*2de3b87aSKai Wang return (0); 40*2de3b87aSKai Wang } 41*2de3b87aSKai Wang 42*2de3b87aSKai Wang if (dbg->dbgp_$1s == NULL) { 43*2de3b87aSKai Wang dbg->dbgp_$1s = calloc(1, sizeof(struct _Dwarf_NameTbl)); 44*2de3b87aSKai Wang if (dbg->dbgp_$1s == NULL) { 45*2de3b87aSKai Wang DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY); 46*2de3b87aSKai Wang return (0); 47*2de3b87aSKai Wang } 48*2de3b87aSKai Wang STAILQ_INIT(&dbg->dbgp_$1s->nt_nplist); 49*2de3b87aSKai Wang } 50*2de3b87aSKai Wang 51*2de3b87aSKai Wang nt = dbg->dbgp_$1s; 52*2de3b87aSKai Wang 53*2de3b87aSKai Wang if ((np = calloc(1, sizeof(struct _Dwarf_NamePair))) == NULL) { 54*2de3b87aSKai Wang DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY); 55*2de3b87aSKai Wang return (0); 56*2de3b87aSKai Wang } 57*2de3b87aSKai Wang 58*2de3b87aSKai Wang np->np_nt = nt; 59*2de3b87aSKai Wang np->np_die = die; 60*2de3b87aSKai Wang if ((np->np_name = strdup($1_name)) == NULL) { 61*2de3b87aSKai Wang free(np); 62*2de3b87aSKai Wang DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY); 63*2de3b87aSKai Wang return (0); 64*2de3b87aSKai Wang } 65*2de3b87aSKai Wang 66*2de3b87aSKai Wang STAILQ_INSERT_TAIL(&nt->nt_nplist, np, np_next); 67*2de3b87aSKai Wang 68*2de3b87aSKai Wang return (1); 69*2de3b87aSKai Wang} 70*2de3b87aSKai Wang') 71