From 5695e99d5f6418f8f5b990bdcb1f153935d0fb06 Mon Sep 17 00:00:00 2001 From: Scott Wood Date: Fri, 4 Jan 2008 15:10:45 -0600 Subject: Handle absolute pathnames correctly in dtc_open_file. Also, free file->dir when freeing file. Signed-off-by: Scott Wood --- srcpos.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'srcpos.c') diff --git a/srcpos.c b/srcpos.c index 7340c33..7a0c47e 100644 --- a/srcpos.c +++ b/srcpos.c @@ -86,6 +86,16 @@ struct dtc_file *dtc_open_file(const char *fname, return file; } + if (fname[0] == '/') { + file->file = fopen(fname, "r"); + + if (!file->file) + goto out; + + file->name = strdup(fname); + return file; + } + if (!search) search = &default_search; @@ -100,6 +110,7 @@ struct dtc_file *dtc_open_file(const char *fname, } out: + free((void *)file->dir); free(file); return NULL; } @@ -109,5 +120,6 @@ void dtc_close_file(struct dtc_file *file) if (fclose(file->file)) die("Error closing \"%s\": %s\n", file->name, strerror(errno)); + free((void *)file->dir); free(file); } -- cgit v1.1