From e46f8382f32dcb45d213bfe4c5734a68cc074dac Mon Sep 17 00:00:00 2001 From: Werner Almesberger Date: Mon, 22 Aug 2016 22:18:46 -0300 Subject: [PATCH] eeshow/kicad/ext.c (clone_file_names, free_file_names): manage set of names --- eeshow/kicad/ext.c | 34 ++++++++++++++++++++++++++++++++++ eeshow/kicad/ext.h | 2 ++ 2 files changed, 36 insertions(+) diff --git a/eeshow/kicad/ext.c b/eeshow/kicad/ext.c index 15d4e75..d4221ee 100644 --- a/eeshow/kicad/ext.c +++ b/eeshow/kicad/ext.c @@ -84,3 +84,37 @@ void classify_files(struct file_names *fn, char *const *args, } } } + + +struct file_names *clone_file_names(const struct file_names *fn) +{ + struct file_names *new; + unsigned i; + + new = alloc_type(struct file_names); + new->pro = fn && fn->pro ? stralloc(fn->pro) : NULL; + new->sch = fn && fn->sch ? stralloc(fn->sch) : NULL; + new->pl = fn && fn->pl ? stralloc(fn->pl) : NULL; + new->n_libs = fn ? fn->n_libs : 0; + if (!fn) { + new->libs = NULL; + return new; + } + new->libs = alloc_type_n(const char *, fn->n_libs); + for (i = 0; i != fn->n_libs; i++) + new->libs[i] = stralloc(fn->libs[i]); + return new; +} + + +void free_file_names(struct file_names *fn) +{ + unsigned i; + + free((void *) fn->pro); + free((void *) fn->sch); + free((void *) fn->pl); + for (i = 0; i != fn->n_libs; i++) + free((void *) fn->libs[i]); + free(fn->libs); +} diff --git a/eeshow/kicad/ext.h b/eeshow/kicad/ext.h index 0986edd..603b9e0 100644 --- a/eeshow/kicad/ext.h +++ b/eeshow/kicad/ext.h @@ -35,5 +35,7 @@ struct file_names { enum ext identify(const char *path); void classify_files(struct file_names *fn, char *const *args, unsigned n_args); +struct file_names *clone_file_names(const struct file_names *fn); +void free_file_names(struct file_names *fn); #endif /* !KICAD_EXT_H */