X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=config%2Futil.c;h=a365594770d9daaaaf3220c80eb1522113930072;hb=c38004b50bcc9378ad1981165dc8dfbb3445c0a9;hp=eef006ce5daa6e62ac0f98f2906d85e816f1e568;hpb=e72388a0aa23da8bc8e24a0cbe9d523c5a9ce294;p=carl9170fw.git diff --git a/config/util.c b/config/util.c index eef006c..a365594 100644 --- a/config/util.c +++ b/config/util.c @@ -5,6 +5,8 @@ * Released under the terms of the GNU GPL v2.0. */ +#include +#include #include #include "lkc.h" @@ -14,34 +16,57 @@ struct file *file_lookup(const char *name) struct file *file; for (file = file_list; file; file = file->next) { - if (!strcmp(name, file->name)) + if (!strcmp(name, file->name)) { return file; + } } - file = malloc(sizeof(*file)); + file = xmalloc(sizeof(*file)); memset(file, 0, sizeof(*file)); - file->name = strdup(name); + file->name = xstrdup(name); file->next = file_list; file_list = file; return file; } -/* Allocate initial growable sting */ -struct gstr str_new(void) +/* write a dependency file as used by kbuild to track dependencies */ +int file_write_dep(const char *name) { - struct gstr gs; - gs.s = malloc(sizeof(char) * 64); - gs.len = 64; - strcpy(gs.s, "\0"); - return gs; + struct file *file; + FILE *out; + + if (!name) + name = ".kconfig.d"; + out = fopen("..config.tmp", "w"); + if (!out) + return 1; + fprintf(out, "deps_config := \\\n"); + for (file = file_list; file; file = file->next) { + if (file->next) + fprintf(out, "\t%s \\\n", file->name); + else + fprintf(out, "\t%s\n", file->name); + } + fprintf(out, "\n%s: \\\n" + "\t$(deps_config)\n\n", conf_get_autoconfig_name()); + + env_write_dep(out, conf_get_autoconfig_name()); + + fprintf(out, "\n$(deps_config): ;\n"); + fclose(out); + rename("..config.tmp", name); + return 0; } -/* Allocate and assign growable string */ -struct gstr str_assign(const char *s) + +/* Allocate initial growable string */ +struct gstr str_new(void) { struct gstr gs; - gs.s = strdup(s); - gs.len = strlen(s) + 1; + gs.s = xmalloc(sizeof(char) * 64); + gs.len = 64; + gs.max_width = 0; + strcpy(gs.s, "\0"); return gs; } @@ -61,7 +86,7 @@ void str_append(struct gstr *gs, const char *s) if (s) { l = strlen(gs->s) + strlen(s) + 1; if (l > gs->len) { - gs->s = realloc(gs->s, l); + gs->s = xrealloc(gs->s, l); gs->len = l; } strcat(gs->s, s); @@ -85,3 +110,51 @@ const char *str_get(struct gstr *gs) return gs->s; } +void *xmalloc(size_t size) +{ + void *p = malloc(size); + if (p) + return p; + fprintf(stderr, "Out of memory.\n"); + exit(1); +} + +void *xcalloc(size_t nmemb, size_t size) +{ + void *p = calloc(nmemb, size); + if (p) + return p; + fprintf(stderr, "Out of memory.\n"); + exit(1); +} + +void *xrealloc(void *p, size_t size) +{ + p = realloc(p, size); + if (p) + return p; + fprintf(stderr, "Out of memory.\n"); + exit(1); +} + +char *xstrdup(const char *s) +{ + char *p; + + p = strdup(s); + if (p) + return p; + fprintf(stderr, "Out of memory.\n"); + exit(1); +} + +char *xstrndup(const char *s, size_t n) +{ + char *p; + + p = strndup(s, n); + if (p) + return p; + fprintf(stderr, "Out of memory.\n"); + exit(1); +}