wok-current rev 517

Busybox: Add top and cpio (with cpio -o -H new support)
author Pascal Bellard <pascal.bellard@slitaz.org>
date Tue Apr 08 14:42:37 2008 +0000 (2008-04-08)
parents f43146da6d21
children 70b2d74dff92
files busybox/receipt busybox/stuff/busybox-1.10.0-cpio.u busybox/stuff/busybox-1.10.0-vcsa2txt.u busybox/stuff/busybox-1.10.0.config
line diff
     1.1 --- a/busybox/receipt	Tue Apr 08 14:23:22 2008 +0000
     1.2 +++ b/busybox/receipt	Tue Apr 08 14:42:37 2008 +0000
     1.3 @@ -16,6 +16,7 @@
     1.4  {
     1.5      patch -p0 < stuff/$PACKAGE-$VERSION-patch.u
     1.6      patch -p0 < stuff/$PACKAGE-$VERSION-vcsa2txt.u
     1.7 +    patch -p0 < stuff/$PACKAGE-$VERSION-cpio.u
     1.8      cp stuff/$PACKAGE-$VERSION.config $PACKAGE-$VERSION/.config
     1.9      cd $PACKAGE-$VERSION
    1.10      make oldconfig
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/busybox/stuff/busybox-1.10.0-cpio.u	Tue Apr 08 14:42:37 2008 +0000
     2.3 @@ -0,0 +1,220 @@
     2.4 +diff -purN busybox-1.10.0/archival/Config.in busybox/archival/Config.in
     2.5 +--- busybox-1.10.0/archival/Config.in	2008-03-29 21:47:37.000000000 +0100
     2.6 ++++ busybox-1.10.0/archival/Config.in	2008-03-29 21:47:37.000000000 +0100
     2.7 +@@ -78,6 +78,14 @@ config CPIO
     2.8 + 	  Unless you have a specific application which requires cpio, you should
     2.9 + 	  probably say N here.
    2.10 + 
    2.11 ++config FEATURE_CPIO_O
    2.12 ++	bool "Support for archive creation"
    2.13 ++	default n
    2.14 ++	depends on CPIO
    2.15 ++	help
    2.16 ++	  This implementation of cpio can create cpio archives in the "newc"
    2.17 ++	  format only.
    2.18 ++
    2.19 + config DPKG
    2.20 + 	bool "dpkg"
    2.21 + 	default n
    2.22 +diff -purN busybox-1.10.0/archival/cpio.c busybox/archival/cpio.c
    2.23 +--- busybox-1.10.0/archival/cpio.c	2008-03-29 21:47:55.000000000 +0100
    2.24 ++++ busybox-1.10.0/archival/cpio.c	2008-03-29 21:47:55.000000000 +0100
    2.25 +@@ -21,12 +21,146 @@
    2.26 + #define CPIO_OPT_FILE                   0x10
    2.27 + #define CPIO_OPT_CREATE_LEADING_DIR     0x20
    2.28 + #define CPIO_OPT_PRESERVE_MTIME         0x40
    2.29 ++#define CPIO_OPT_CREATE                 0x80
    2.30 ++#define CPIO_OPT_FORMAT                0x100
    2.31 ++
    2.32 ++#if ENABLE_FEATURE_CPIO_O
    2.33 ++static void cpio_pad(off_t *size, int n)
    2.34 ++{
    2.35 ++    int i;
    2.36 ++    for (*size += i = (-*size) & n; --i >= 0; bb_putchar(0));
    2.37 ++}
    2.38 ++
    2.39 ++static void cpio_o(void)
    2.40 ++{
    2.41 ++    struct name_s {
    2.42 ++        struct name_s *next;
    2.43 ++        char name[0];
    2.44 ++    };
    2.45 ++    struct inodes_s {
    2.46 ++        struct name_s *names;
    2.47 ++        struct inodes_s *next;
    2.48 ++        struct stat st;
    2.49 ++    } *links = NULL;
    2.50 ++    off_t bytes = 0; // output bytes count
    2.51 ++#if CONFIG_FEATURE_COPYBUF_KB < 1
    2.52 ++    char buf[1024];
    2.53 ++#else
    2.54 ++    char buf[CONFIG_FEATURE_COPYBUF_KB * 1024];
    2.55 ++#endif
    2.56 ++	
    2.57 ++    while (1) {
    2.58 ++        const char *name = "TRAILER!!!";
    2.59 ++        char *line = xmalloc_getline(stdin);
    2.60 ++        // allocate inode struct each loop to avoid struct stat copy
    2.61 ++        struct inodes_s *inode = xzalloc(sizeof(*inode)); // die if fail
    2.62 ++
    2.63 ++        inode->st.st_nlink++; // =1
    2.64 ++        if (line) {
    2.65 ++            /* Strip leading `./' from the filename.  */
    2.66 ++            for (name = line; name[0] == '.' && name[1] == '/';) {
    2.67 ++                while (*++name == '/');
    2.68 ++            }
    2.69 ++            if (!*name) goto free_and_continue; // line empty
    2.70 ++            if (lstat(name, &inode->st)) {
    2.71 ++          abort_cpio_o:
    2.72 ++                bb_perror_msg_and_die(name);
    2.73 ++            }
    2.74 ++        }
    2.75 ++
    2.76 ++        // hard links will are stored and will be processed later
    2.77 ++        if (!S_ISDIR(inode->st.st_mode) && inode->st.st_nlink > 1) {
    2.78 ++            struct name_s *n;
    2.79 ++            struct inodes_s *l;
    2.80 ++
    2.81 ++            for (l = links; l && l->st.st_ino != inode->st.st_ino; l = l->next);
    2.82 ++            if (l == NULL) { // not found: new hard links set
    2.83 ++                l = inode; // l->names = NULL; l->st = inode->st
    2.84 ++                l->next = links;
    2.85 ++                links = l;
    2.86 ++            }
    2.87 ++            n = xmalloc(sizeof(*n) + strlen(name) + 1); // die if fail
    2.88 ++            strcpy(n->name, name);
    2.89 ++            n->next = l->names;
    2.90 ++            l->names = n; // will not free inode if l == inode
    2.91 ++            goto free_and_continue;
    2.92 ++        }
    2.93 ++
    2.94 ++        // no more files ? process hard links
    2.95 ++        if (!line && links) {
    2.96 ++            struct name_s *n;
    2.97 ++
    2.98 ++            free(inode); // trailer pseudo inode
    2.99 ++            inode = links;
   2.100 ++            n = links->names;
   2.101 ++            name = line = xstrdup(n->name);    // line will free *name memory
   2.102 ++            links->names = n->next;
   2.103 ++            if (links->names == NULL)          // inode will free *links memory
   2.104 ++                links = links->next;
   2.105 ++            else links->st.st_size = 0;        // not last link: no data
   2.106 ++            free(n);
   2.107 ++        }
   2.108 ++
   2.109 ++        bytes += printf("070701%08lx%08lx%08lx%08lx%08lx%08lx%08lx"
   2.110 ++                        "%08lx%08lx%08lx%08lx%08lx%08lx%s%c",
   2.111 ++                        (unsigned long) inode->st.st_ino,
   2.112 ++                        (unsigned long) inode->st.st_mode, 
   2.113 ++                        (unsigned long) inode->st.st_uid,
   2.114 ++                        (unsigned long) inode->st.st_gid,
   2.115 ++                        (unsigned long) inode->st.st_nlink,
   2.116 ++                        (unsigned long) inode->st.st_mtime,
   2.117 ++                        (unsigned long) inode->st.st_size,
   2.118 ++                        (unsigned long) major(inode->st.st_dev),
   2.119 ++                        (unsigned long) minor(inode->st.st_dev),
   2.120 ++                        (unsigned long) major(inode->st.st_rdev), 
   2.121 ++                        (unsigned long) minor(inode->st.st_rdev),
   2.122 ++                        strlen(name) + 1UL, 0UL, name, 0);
   2.123 ++
   2.124 ++        cpio_pad(&bytes, (line) ? 4-1 : 512-1);
   2.125 ++
   2.126 ++        if (inode->st.st_size) {
   2.127 ++
   2.128 ++            if (S_ISLNK(inode->st.st_mode)) {
   2.129 ++                char *lpath = xmalloc_readlink_or_warn(name);
   2.130 ++
   2.131 ++                if (!lpath) goto abort_cpio_o;
   2.132 ++                bytes += printf("%s", lpath);
   2.133 ++                free(lpath);
   2.134 ++            }
   2.135 ++
   2.136 ++            if (S_ISREG(inode->st.st_mode)) {
   2.137 ++                int fd = open_or_warn(name, O_RDONLY);
   2.138 ++
   2.139 ++                while (1) {
   2.140 ++                    int len = full_read(fd, buf, sizeof(buf));
   2.141 ++                    if (len < 0) goto abort_cpio_o;
   2.142 ++                    if (len == 0) break;
   2.143 ++                    bytes += len;
   2.144 ++                    fwrite(buf, 1, len, stdout);
   2.145 ++                }
   2.146 ++                close(fd);
   2.147 ++            }
   2.148 ++
   2.149 ++            cpio_pad(&bytes, 4-1);
   2.150 ++        }
   2.151 ++
   2.152 ++        if (!line) return; // was trailer
   2.153 ++
   2.154 ++    free_and_continue:
   2.155 ++        if (!inode->names) free(inode);
   2.156 ++            free(line);
   2.157 ++    }
   2.158 ++}
   2.159 ++#endif
   2.160 + 
   2.161 + int cpio_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
   2.162 + int cpio_main(int argc, char **argv)
   2.163 + {
   2.164 + 	archive_handle_t *archive_handle;
   2.165 + 	char *cpio_filename = NULL;
   2.166 ++#if ENABLE_FEATURE_CPIO_O
   2.167 ++	const char *cpio_fmt = "";
   2.168 ++#endif
   2.169 + 	unsigned opt;
   2.170 + 
   2.171 + 	/* Initialise */
   2.172 +@@ -35,10 +169,26 @@ int cpio_main(int argc, char **argv)
   2.173 + 	archive_handle->seek = seek_by_read;
   2.174 + 	archive_handle->flags = ARCHIVE_EXTRACT_NEWER | ARCHIVE_PRESERVE_DATE;
   2.175 + 
   2.176 ++#if ENABLE_FEATURE_CPIO_O
   2.177 ++	opt = getopt32(argv, "ituvF:dmoH:", &cpio_filename,&cpio_fmt);
   2.178 ++
   2.179 ++	if (opt & CPIO_OPT_CREATE) {
   2.180 ++		if (*cpio_fmt != 'n')
   2.181 ++			goto cpio_show_usage;
   2.182 ++		if (cpio_filename) {
   2.183 ++			fclose(stdout);
   2.184 ++			stdout = fopen(cpio_filename,"w");
   2.185 ++		}
   2.186 ++		cpio_o();
   2.187 ++		return EXIT_SUCCESS;
   2.188 ++	}
   2.189 ++#else
   2.190 + 	opt = getopt32(argv, "ituvF:dm", &cpio_filename);
   2.191 ++#endif
   2.192 + 
   2.193 + 	/* One of either extract or test options must be given */
   2.194 + 	if ((opt & (CPIO_OPT_TEST | CPIO_OPT_EXTRACT)) == 0) {
   2.195 ++ cpio_show_usage:
   2.196 + 		bb_show_usage();
   2.197 + 	}
   2.198 + 
   2.199 +diff -purN busybox-1.10.0/include/usage.h busybox/include/usage.h
   2.200 +--- busybox-1.10.0/include/usage.h	2008-03-29 21:48:22.000000000 +0100
   2.201 ++++ busybox-1.10.0/include/usage.h	2008-03-29 21:48:22.000000000 +0100
   2.202 +@@ -496,13 +496,19 @@
   2.203 +      "\n	-l,-s	Create (sym)links" \
   2.204 + 
   2.205 + #define cpio_trivial_usage \
   2.206 +-       "-[dimtuv][F cpiofile]"
   2.207 ++       "-[dim" USE_FEATURE_CPIO_O("o") "tuv][F cpiofile]" \
   2.208 ++       USE_FEATURE_CPIO_O( "[H newc]" ) 
   2.209 + #define cpio_full_usage \
   2.210 +-       "Extract or list files from a cpio archive\n" \
   2.211 ++       "Extract or list files from a cpio archive" \
   2.212 ++       USE_FEATURE_CPIO_O( ", or create a cpio archive" ) "\n" \
   2.213 +        "Main operation mode:" \
   2.214 +      "\n	d	Make leading directories" \
   2.215 +      "\n	i	Extract" \
   2.216 +      "\n	m	Preserve mtime" \
   2.217 ++       USE_FEATURE_CPIO_O( \
   2.218 ++     "\n	o	Create" \
   2.219 ++     "\n	H newc	Define format" \
   2.220 ++       ) \
   2.221 +      "\n	t	List" \
   2.222 +      "\n	v	Verbose" \
   2.223 +      "\n	u	Unconditional overwrite" \
     3.1 --- a/busybox/stuff/busybox-1.10.0-vcsa2txt.u	Tue Apr 08 14:23:22 2008 +0000
     3.2 +++ b/busybox/stuff/busybox-1.10.0-vcsa2txt.u	Tue Apr 08 14:42:37 2008 +0000
     3.3 @@ -11,7 +11,7 @@
     3.4  
     3.5  --- busybox-1.10.0/include/usage.h	Sat Mar 22 02:31:50 2008
     3.6  +++ busybox-1.10.0/include/usage.h	Sat Mar 22 02:31:50 2008
     3.7 -@@ -4313,6 +4313,13 @@
     3.8 +@@ -4314,6 +4314,13 @@
     3.9        "\n	set_ingress_map	[vlan-name] [skb_priority] [vlan_qos]" \
    3.10        "\n	set_name_type	[name-type]" \
    3.11   
     4.1 --- a/busybox/stuff/busybox-1.10.0.config	Tue Apr 08 14:23:22 2008 +0000
     4.2 +++ b/busybox/stuff/busybox-1.10.0.config	Tue Apr 08 14:42:37 2008 +0000
     4.3 @@ -1,4 +1,4 @@
     4.4 -# TODO: add RESET CLEAR RMMOD LSMOD, patch CPIO
     4.5 +# TODO: add RESET CLEAR RMMOD LSMOD
     4.6  #
     4.7  # Automatically generated make config: don't edit
     4.8  # Busybox version: 1.10.0
     4.9 @@ -100,7 +100,8 @@
    4.10  # CONFIG_FEATURE_AR_LONG_FILENAMES is not set
    4.11  CONFIG_BUNZIP2=y
    4.12  # CONFIG_BZIP2 is not set
    4.13 -# CONFIG_CPIO is not set
    4.14 +CONFIG_CPIO=y
    4.15 +CONFIG_FEATURE_CPIO_O=y
    4.16  CONFIG_DPKG=y
    4.17  CONFIG_DPKG_DEB=y
    4.18  CONFIG_FEATURE_DPKG_DEB_EXTRACT_ONLY=y
    4.19 @@ -487,7 +488,7 @@
    4.20  CONFIG_FEATURE_USE_TERMIOS=y
    4.21  CONFIG_VOLUMEID=y
    4.22  CONFIG_FEATURE_VOLUMEID_EXT=y
    4.23 -# CONFIG_FEATURE_VOLUMEID_REISERFS is not set
    4.24 +CONFIG_FEATURE_VOLUMEID_REISERFS=y
    4.25  CONFIG_FEATURE_VOLUMEID_FAT=y
    4.26  # CONFIG_FEATURE_VOLUMEID_HFS is not set
    4.27  # CONFIG_FEATURE_VOLUMEID_JFS is not set
    4.28 @@ -730,11 +731,11 @@
    4.29  # CONFIG_FEATURE_PS_UNUSUAL_SYSTEMS is not set
    4.30  CONFIG_RENICE=y
    4.31  CONFIG_BB_SYSCTL=y
    4.32 -# CONFIG_TOP is not set
    4.33 -# CONFIG_FEATURE_TOP_CPU_USAGE_PERCENTAGE is not set
    4.34 -# CONFIG_FEATURE_TOP_CPU_GLOBAL_PERCENTS is not set
    4.35 +CONFIG_TOP=y
    4.36 +CONFIG_FEATURE_TOP_CPU_USAGE_PERCENTAGE=y
    4.37 +CONFIG_FEATURE_TOP_CPU_GLOBAL_PERCENTS=y
    4.38  # CONFIG_FEATURE_TOP_DECIMALS is not set
    4.39 -# CONFIG_FEATURE_TOPMEM is not set
    4.40 +CONFIG_FEATURE_TOPMEM=y
    4.41  CONFIG_UPTIME=y
    4.42  CONFIG_WATCH=y
    4.43