wok-next rev 1774
busybox: enhance modinfo
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Fri Nov 28 17:25:29 2008 +0000 (2008-11-28) |
parents | 98a51003b20d |
children | f0cb83ba12fd |
files | busybox/stuff/busybox-1.12.0-modinfo.u |
line diff
1.1 --- a/busybox/stuff/busybox-1.12.0-modinfo.u Fri Nov 28 17:23:48 2008 +0000 1.2 +++ b/busybox/stuff/busybox-1.12.0-modinfo.u Fri Nov 28 17:25:29 2008 +0000 1.3 @@ -59,7 +59,7 @@ 1.4 1.5 --- busybox-1.12.0/modutils/modinfo.c 1.6 +++ busybox-1.12.0/modutils/modinfo.c 1.7 -@@ -0,0 +1,82 @@ 1.8 +@@ -0,0 +1,104 @@ 1.9 +/* vi: set sw=4 ts=4: */ 1.10 +/* 1.11 + * modinfo - retrieve module info 1.12 @@ -73,43 +73,66 @@ 1.13 +#include <libbb.h> 1.14 +#include <fnmatch.h> 1.15 + 1.16 ++#define ALL_TAGS 0x3F 1.17 ++ 1.18 +enum { 1.19 -+ ARG_F = (1<<4), /* field name */ 1.20 -+ ARG_0 = (1<<5) /* \0 as separator */ 1.21 ++ ARG_F = (1<<6), /* field name */ 1.22 ++ ARG_0 = (1<<7) /* \0 as separator */ 1.23 +}; 1.24 + 1.25 +struct modinfo_env { 1.26 + char **argv; 1.27 ++ const char **literals; 1.28 + char *field; 1.29 ++ int tags; 1.30 +}; 1.31 + 1.32 ++static int display(char *data, const char *pattern, int flag) 1.33 ++{ 1.34 ++ if (flag) { 1.35 ++ int n = printf("%s:",pattern); 1.36 ++ while (n++ < 16) bb_putchar(' '); 1.37 ++ } 1.38 ++ return printf("%s%c",data, (option_mask32 & ARG_0) ? '\0' : '\n'); 1.39 ++} 1.40 ++ 1.41 +static void modinfo(char *name, char *path, void *env) 1.42 +{ 1.43 + size_t len; 1.44 -+ int i, length; 1.45 ++ int i, j, length; 1.46 + char *ptr, *the_module; 1.47 + char **argv = ((struct modinfo_env *) env)->argv; 1.48 -+ char *field = ((struct modinfo_env *) env)->field; 1.49 ++ const char **literals = ((struct modinfo_env *) env)->literals; 1.50 ++ const char *field = ((struct modinfo_env *) env)->field; 1.51 ++ int tags = ((struct modinfo_env *) env)->tags; 1.52 + extern void *xalloc_load_module(const char filename[], size_t *len); 1.53 + 1.54 + for (i = 0; argv[i]; i++) { 1.55 + if (fnmatch(argv[i],name,0) == 0) { 1.56 ++ if (tags & 1) { /* filename */ 1.57 ++ display(path,literals[0],1 != tags); 1.58 ++ } 1.59 + len = MAXINT(ssize_t); 1.60 -+ ptr = the_module = xalloc_load_module(path, &len); 1.61 -+ length = strlen(field); 1.62 -+ do { 1.63 -+ ptr = memchr(ptr, *field, len - (ptr - (char*)the_module)); 1.64 -+ if (ptr == NULL) /* no occurance left, done */ 1.65 -+ break; 1.66 -+ if (!strncmp(ptr, field, length) && ptr[length] == '=') { 1.67 -+ ptr += length + 1; 1.68 -+ ptr += printf("%s%c",ptr, 1.69 -+ (option_mask32 & ARG_0) ? '\0' : '\n'); 1.70 -+ } 1.71 -+ ++ptr; 1.72 -+ } while (1); 1.73 ++ the_module = xalloc_load_module(path, &len); 1.74 ++ if (field) tags |= ALL_TAGS+1; 1.75 ++ for (j = 1; (1<<j) & (ALL_TAGS+ALL_TAGS+1); j++) { 1.76 ++ const char *pattern = field; 1.77 ++ if ((1<<j) & ALL_TAGS) pattern = literals[j]; 1.78 ++ if (!((1<<j) & tags)) continue; 1.79 ++ length = strlen(pattern); 1.80 ++ ptr = the_module; 1.81 ++ do { 1.82 ++ ptr = memchr(ptr, *pattern, len - (ptr - (char*)the_module)); 1.83 ++ if (ptr == NULL) /* no occurance left, done */ 1.84 ++ break; 1.85 ++ if (!strncmp(ptr, pattern, length) && ptr[length] == '=') { 1.86 ++ ptr += length + 1; 1.87 ++ ptr += display(ptr,pattern,(1<<j) != tags); 1.88 ++ } 1.89 ++ ++ptr; 1.90 ++ } while (1); 1.91 ++ } 1.92 + free(the_module); 1.93 -+ break; 1.94 + } 1.95 + } 1.96 +} 1.97 @@ -118,25 +141,24 @@ 1.98 +int modinfo_main(int argc UNUSED_PARAM, char **argv) 1.99 +{ 1.100 + static const char *shortcuts[] = { 1.101 ++ "filename", 1.102 ++ "description", 1.103 + "author", 1.104 -+ "description", 1.105 + "license", 1.106 -+ "parm" 1.107 ++ "vermagic", 1.108 ++ "parm", 1.109 + }; 1.110 -+ int i; 1.111 + struct modinfo_env env; 1.112 + extern void mod_walk(void (*action)(char *name, char *path, void *env), 1.113 + void *data); 1.114 + 1.115 + env.field = NULL; 1.116 -+ getopt32(argv, "adlpF:0", &env.field); 1.117 ++ env.literals = shortcuts; 1.118 ++ getopt32(argv, "fdalvpF:0", &env.field); 1.119 + env.argv = argv += optind; 1.120 ++ env.tags = (option_mask32) ? option_mask32 & ALL_TAGS : ALL_TAGS; 1.121 + 1.122 -+ for (i = 0; i < sizeof(shortcuts)/sizeof(shortcuts[0]); i++) 1.123 -+ if (option_mask32 & (1 << i)) 1.124 -+ env.field = (char *) shortcuts[i]; 1.125 -+ 1.126 -+ if (!env.field || !*env.argv) 1.127 ++ if (!*env.argv) 1.128 + bb_show_usage(); 1.129 + 1.130 + mod_walk(modinfo, &env);