svn commit: trunk/busybox: applets coreutils include libbb modutils etc...

landley at busybox.net landley at busybox.net
Wed Aug 9 20:56:24 UTC 2006


Author: landley
Date: 2006-08-09 13:56:23 -0700 (Wed, 09 Aug 2006)
New Revision: 15793

Log:
Another whack at scripts/individual.  Now builds 212 applets.


Removed:
   trunk/busybox/applets/version.c

Modified:
   trunk/busybox/applets/Makefile.in
   trunk/busybox/coreutils/install.c
   trunk/busybox/include/libbb.h
   trunk/busybox/include/platform.h
   trunk/busybox/libbb/messages.c
   trunk/busybox/libbb/xfuncs.c
   trunk/busybox/modutils/insmod.c
   trunk/busybox/scripts/individual


Changeset:
Modified: trunk/busybox/applets/Makefile.in
===================================================================
--- trunk/busybox/applets/Makefile.in	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/applets/Makefile.in	2006-08-09 20:56:23 UTC (rev 15793)
@@ -10,7 +10,7 @@
 endif
 srcdir=$(top_srcdir)/applets
 
-APPLET_SRC:= $(patsubst %,$(srcdir)/%,applets.c busybox.c version.c)
+APPLET_SRC:= $(patsubst %,$(srcdir)/%,applets.c busybox.c)
 APPLET_OBJ:= $(patsubst $(srcdir)/%.c,$(APPLETS_DIR)%.o, $(APPLET_SRC))
 
 APPLET_SRC-y+=$(APPLET_SRC)

Deleted: trunk/busybox/applets/version.c
===================================================================
--- trunk/busybox/applets/version.c	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/applets/version.c	2006-08-09 20:56:23 UTC (rev 15793)
@@ -1,17 +0,0 @@
-/* vi: set sw=4 ts=4: */
-/*
- * Version stuff.
- *
- * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
- */
-
-#include "busybox.h"
-
-#ifndef BB_EXTRA_VERSION
-#define BANNER "BusyBox v" BB_VER " (" BB_BT ")"
-#else
-#define BANNER "BusyBox v" BB_VER " (" BB_EXTRA_VERSION ")"
-#endif
-
-const char BB_BANNER[]=BANNER;
-const char * const bb_msg_full_version = BANNER " multi-call binary";

Modified: trunk/busybox/coreutils/install.c
===================================================================
--- trunk/busybox/coreutils/install.c	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/coreutils/install.c	2006-08-09 20:56:23 UTC (rev 15793)
@@ -8,16 +8,10 @@
  *           owner/group, will probably modify bb_make_directory(...)
  */
 
-#include <sys/stat.h>
-#include <sys/types.h>
-#include <errno.h>
-#include <stdlib.h>
-#include <string.h>
-#include <unistd.h>
-#include <getopt.h> /* struct option */
-
 #include "busybox.h"
 #include "libcoreutils/coreutils.h"
+#include <libgen.h>
+#include <getopt.h> /* struct option */
 
 #define INSTALL_OPT_CMD	1
 #define INSTALL_OPT_DIRECTORY	2

Modified: trunk/busybox/include/libbb.h
===================================================================
--- trunk/busybox/include/libbb.h	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/include/libbb.h	2006-08-09 20:56:23 UTC (rev 15793)
@@ -222,8 +222,10 @@
 extern void trim(char *s);
 extern char *skip_whitespace(const char *);
 
+#ifndef BUILD_INDIVIDUAL
 extern struct BB_applet *find_applet_by_name(const char *name);
 void run_applet_by_name(const char *name, int argc, char **argv);
+#endif
 
 /* dmalloc will redefine these to it's own implementation. It is safe
  * to have the prototypes here unconditionally.  */

Modified: trunk/busybox/include/platform.h
===================================================================
--- trunk/busybox/include/platform.h	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/include/platform.h	2006-08-09 20:56:23 UTC (rev 15793)
@@ -154,6 +154,7 @@
 
 #if defined __GLIBC__ || defined __UCLIBC__ \
 	|| defined __dietlibc__ || defined _NEWLIB_VERSION
+#define _XOPEN_SOURCE
 #include <features.h>
 #define HAVE_FEATURES_H
 #include <stdint.h>

Modified: trunk/busybox/libbb/messages.c
===================================================================
--- trunk/busybox/libbb/messages.c	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/libbb/messages.c	2006-08-09 20:56:23 UTC (rev 15793)
@@ -9,12 +9,14 @@
 
 #ifdef L_full_version
 #ifndef BB_EXTRA_VERSION
-#define LIBBB_BANNER "BusyBox's library v" BB_VER " (" BB_BT ")"
+#define BANNER "BusyBox v" BB_VER " (" BB_BT ")"
 #else
-#define LIBBB_BANNER "BusyBox's library v" BB_VER " (" BB_EXTRA_VERSION ")"
+#define BANNER "BusyBox v" BB_VER " (" BB_EXTRA_VERSION ")"
 #endif
-	const char * const libbb_msg_full_version = LIBBB_BANNER;
+const char BB_BANNER[]=BANNER;
+const char * const bb_msg_full_version = BANNER " multi-call binary";
 #endif
+
 #ifdef L_memory_exhausted
 	const char * const bb_msg_memory_exhausted = "memory exhausted";
 #endif

Modified: trunk/busybox/libbb/xfuncs.c
===================================================================
--- trunk/busybox/libbb/xfuncs.c	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/libbb/xfuncs.c	2006-08-09 20:56:23 UTC (rev 15793)
@@ -208,7 +208,7 @@
 {
 	static int failed;
 	pid_t pid;
-	void *app = find_applet_by_name(argv[0]);
+	void *app = ENABLE_FEATURE_SH_STANDALONE_SHELL ? find_applet_by_name(argv[0]) : 0;
 
 	// Be nice to nommu machines.
 	failed = 0;

Modified: trunk/busybox/modutils/insmod.c
===================================================================
--- trunk/busybox/modutils/insmod.c	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/modutils/insmod.c	2006-08-09 20:56:23 UTC (rev 15793)
@@ -59,6 +59,7 @@
  */
 
 #include "busybox.h"
+#include <libgen.h>
 #include <sys/utsname.h>
 
 #if !defined(CONFIG_FEATURE_2_4_MODULES) && \

Modified: trunk/busybox/scripts/individual
===================================================================
--- trunk/busybox/scripts/individual	2006-08-09 20:55:35 UTC (rev 15792)
+++ trunk/busybox/scripts/individual	2006-08-09 20:56:23 UTC (rev 15793)
@@ -1,5 +1,10 @@
 #!/bin/sh
 
+# Compile individual versions of each busybox applet.
+
+if [ $# -eq 0 ]
+then
+
 # Clear out the build directory.  (Make clean should do this instead of here.)
 
 rm -rf build
@@ -23,30 +28,62 @@
 make
 cd ../..
 
+# And again
+
+cd coreutils/libcoreutils
+make
+cd ../..
+
+# Sensing a pattern here?
+
+#cd networking/libiproute
+#make
+#cd ../..
+
+fi
+
 # About 3/5 of the applets build from one .c file (with the same name as the
 # corresponding applet), and all it needs to link against.  However, to build
 # them all we need more than that.
 
 # Figure out which applets need extra libraries added to their command line.
 
-function extra_libraries()
+function substithing()
 {
-  archival="ar bunzip2 unlzma cpio dpkg gunzip rpm2cpio rpm tar uncompress unzip dpkg_deb gzip "
-  if [ "${archival/$1 //}" != "${archival}" ]
+  if [ "${1/ $3 //}" != "$1" ]
   then
-    echo "archival/libunarchive/libunarchive.a"
+    echo $2
   fi
+}
 
+function extra_libraries()
+{
+  # gzip needs gunzip.c (when gunzip is enabled, anyway).
+  substithing " gzip " "archival/gunzip.c archival/uncompress.c" "$1"
+
+  # init needs init_shared.c
+  substithing " init " "init/init_shared.c" "$1"
+
+  # ifconfig needs interface.c
+  substithing " ifconfig " "networking/interface.c" "$1"
+
+  # Applets that need libunarchive.a
+  substithing " ar bunzip2 unlzma cpio dpkg gunzip rpm2cpio rpm tar uncompress unzip dpkg_deb gzip " "archival/libunarchive/libunarchive.a" "$1"
+
+  # Applets that need libcoreutils.a
+  substithing " cp mv " "coreutils/libcoreutils/libcoreutils.a" "$1"
+
+  # Applets that need libiproute.a
+  substithing " ip " "networking/libiproute/libiproute.a" "$1"
+
   # What needs -libm?
+  substithing " awk dc " "-lm" "$1"
 
-  libm="awk dc "
-  if [ "${libm/$1 //}" != "${libm}" ]
-  then
-    echo "-lm"
-  fi
+  # What needs -lcrypt?
+  substithing " httpd vlock " "-lcrypt" "$1"
 }
 
-# Query applets.h to figure out which need something funky
+# Query applets.h to figure out which applets need special treatment
 
 strange_names=`sed -rn -e 's/\#.*//' -e 's/.*APPLET_NOUSAGE\(([^,]*),([^,]*),.*/\1 \2/p' -e 's/.*APPLET_ODDNAME\(([^,]*),([^,]*),.*, *([^)]*).*/\1 \2@\3/p' include/applets.h`
 
@@ -59,7 +96,7 @@
       APPFILT="${2/@*/}"
       if [ "${APPFILT}" == "$2" ]
       then
-        HELPNAME='"nousage\n"'
+        HELPNAME='"nousage\n"'   # These should be _fixed_.
       else
         HELPNAME="${2/*@/}"_full_usage
       fi
@@ -70,14 +107,17 @@
 #echo APPLET=${APPLET} APPFILT=${APPFILT} HELPNAME=${HELPNAME} 2=${2}
 }
 
-for APPLET in `sed 's .*/  ' busybox.links`
-do
-  export APPLET
+# Iterate through every name in busybox.links
+
+function buildit ()
+{
+  export APPLET="$1"
   export APPFILT=${APPLET}
   export HELPNAME=${APPLET}_full_usage
+
   bonkname $strange_names
 
-  j=`find . -name "${APPFILT}.c"`
+  j=`find archival console-tools coreutils debianutils editors findutils init loginutils miscutils modutils networking procps shell sysklogd util-linux -name "${APPFILT}.c"`
   if [ -z "$j" ]
   then
     echo no file for $APPLET
@@ -86,13 +126,24 @@
     gcc -Os -o build/$APPLET applets/individual.c $j \
 	`extra_libraries $APPFILT` libbb/libbb.a -Iinclude \
 	-DBUILD_INDIVIDUAL \
-	"-Drun_applet_by_name(...)" "-Dfind_applet_by_name(...) 0" \
+	'-Drun_applet_by_name(...)' '-Dfind_applet_by_name(...)=0' \
 	-DAPPLET_main=${APPFILT}_main -DAPPLET_full_usage=${HELPNAME}
     if [ $? -ne 0 ];
     then
       echo "Failed $APPLET"
     fi
   fi
-done
+}
 
+if [ $# -eq 0 ]
+then
+  for APPLET in `sed 's .*/  ' busybox.links`
+  do
+    buildit "$APPLET"
+  done
+else
+  buildit "$1"
+fi
+
+
 strip build/*




More information about the busybox-cvs mailing list