preproc: clean up handing of the dependency lists
[nasm.git] / nasmlib / srcfile.c
blob7bee01760d3280c016ff3399a6bb19d66c4ba33a
1 /* ----------------------------------------------------------------------- *
3 * Copyright 1996-2016 The NASM Authors - All Rights Reserved
4 * See the file AUTHORS included with the NASM distribution for
5 * the specific copyright holders.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following
9 * conditions are met:
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above
14 * copyright notice, this list of conditions and the following
15 * disclaimer in the documentation and/or other materials provided
16 * with the distribution.
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 * ----------------------------------------------------------------------- */
35 * srcfile.c - keep track of the current position in the input stream
38 #include "compiler.h"
40 #include <string.h>
41 #include <inttypes.h>
43 #include "nasmlib.h"
44 #include "hashtbl.h"
46 static const char *file_name = NULL;
47 static int32_t line_number = 0;
49 static struct hash_table filename_hash;
51 void src_init(void)
53 hash_init(&filename_hash, HASH_MEDIUM);
56 void src_free(void)
58 struct hash_tbl_node *iter = NULL;
59 void *dp;
61 while ((dp = hash_iterate(&filename_hash, &iter, NULL)) != NULL)
62 nasm_free(dp);
64 hash_free(&filename_hash);
68 * Set the current filename, returning the old one. The input
69 * filename is duplicated if needed.
71 const char *src_set_fname(const char *newname)
73 struct hash_insert hi;
74 const char *oldname;
75 void **dp;
77 if (newname) {
78 dp = hash_find(&filename_hash, newname, &hi);
79 if (dp) {
80 newname = (const char *)(*dp);
81 } else {
82 newname = nasm_strdup(newname);
83 hash_add(&hi, newname, (void *)newname);
87 oldname = file_name;
88 file_name = newname;
89 return oldname;
92 int32_t src_set_linnum(int32_t newline)
94 int32_t oldline = line_number;
95 line_number = newline;
96 return oldline;
99 void src_set(int32_t line, const char *fname)
101 src_set_fname(fname);
102 src_set_linnum(line);
105 const char *src_get_fname(void)
107 return file_name;
110 int32_t src_get_linnum(void)
112 return line_number;
115 int32_t src_get(int32_t *xline, const char **xname)
117 const char *xn = *xname;
118 int32_t xl = *xline;
120 *xline = line_number;
121 *xname = file_name;
123 /* XXX: Is the strcmp() really needed here? */
124 if (!file_name || !xn || (xn != file_name && strcmp(xn, file_name)))
125 return -2;
126 else
127 return line_number - xl;