Ignore:
Timestamp:
Nov 4, 2007, 3:16:40 AM (16 years ago)
Author:
Bruno Cornec
Message:

Update to busybox 1.7.2

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/2.2.5/mindi-busybox/docs/new-applet-HOWTO.txt

    r821 r1765  
    77Matt Kraai - initial writeup
    88Mark Whitley - the remix
    9 Thomas Lundquist - Added stuff for the new directory layout.
     9Thomas Lundquist - Trying to keep it updated.
     10
     11When doing this you should consider using the latest svn trunk.
     12This is a good thing if you plan to getting it commited into mainline.
    1013
    1114Initial Write
     
    1720And be sure to put it in <applet>.c. Usage does not have to be taken care of by
    1821your applet.
    19 Make sure to #include "busybox.h" as the first include file in your applet so
     22Make sure to #include "libbb.h" as the first include file in your applet so
    2023the bb_config.h and appropriate platform specific files are included properly.
    2124
    2225For a new applet mu, here is the code that would go in mu.c:
     26
     27(busybox.h already includes most usual header files. You do not need
     28#include <stdio.h> etc...)
     29
    2330
    2431----begin example code------
     
    3340 */
    3441
    35 #include "busybox.h"
    36 #include <other.h>
     42#include "libbb.h"
     43#include "other.h"
    3744
     45int mu_main(int argc, char **argv);
    3846int mu_main(int argc, char **argv)
    3947{
     
    4149    char mu;
    4250
    43     fd = bb_xopen("/dev/random", O_RDONLY);
     51    fd = xopen("/dev/random", O_RDONLY);
    4452
    4553    if ((n = safe_read(fd, &mu, 1)) < 1)
     
    6977applet that could be useful in other applets, consider putting them in libbb.
    7078
     79And it may be possible that some of the other applets uses functions you
     80could use. If so, you have to rip the function out of the applet and make
     81a libbb function out of it.
     82
     83Adding a libbb function:
     84------------------------
     85
     86Make a new file named <function_name>.c
     87
     88----start example code------
     89
     90#include "libbb.h"
     91#include "other.h"
     92
     93int function(char *a)
     94{
     95    return *a;
     96}
     97
     98----end example code------
     99
     100Add <function_name>.o in the right alphabetically sorted place
     101in libbb/Kbuild. You should look at the conditional part of
     102libbb/Kbuild aswell.
     103
     104You should also try to find a suitable place in include/libbb.h for
     105the function declaration. If not, add it somewhere anyway, with or without
     106ifdefs to include or not.
     107
     108You can look at libbb/Config.in and try to find out if the function is
     109tuneable and add it there if it is.
     110
    71111
    72112Placement / Directory
     
    78118sorted alphabetically.
    79119
    80 Add the applet to Makefile.in in the chosen directory:
     120Add the applet to Kbuild in the chosen directory:
    81121
    82 obj-$(CONFIG_MU)               += mu.o
     122lib-$(CONFIG_MU)               += mu.o
    83123
    84124Add the applet to Config.in in the chosen directory:
     
    119159algorithm in busybox.c and the Gods of BusyBox smite you. Yea, verily:
    120160
     161Be sure to read the top of applets.h before adding your applet.
     162
    121163    /* all programs above here are alphabetically "less than" 'mu' */
    122     #ifdef CONFIG_MU
    123         APPLET("mu", mu_main, _BB_DIR_USR_BIN, mu_usage)
    124     #endif
     164    USE_MU(APPLET(mu, _BB_DIR_USR_BIN, _BB_SUID_NEVER))
    125165    /* all programs below here are alphabetically "greater than" 'mu' */
    126 
    127 
    128 Documentation
    129 -------------
    130 
    131 If you're feeling especially nice, you should also document your applet in the
    132 docs directory (but nobody ever does that).
    133 
    134 Adding some text to docs/Configure.help is a nice start.
    135166
    136167
     
    138169----------------------
    139170
    140 Then create a diff -urN of the files you added and/or modified. Typically:
    141     <appletdir>/<applet>.c
    142     include/usage.c
    143     include/applets.h
    144     <appletdir>/Makefile.in
    145     <appletdir>/config.in
     171Then create a diff by adding the new files with svn (remember your libbb files)
     172    svn add <where you put it>/mu.c
     173eventually also:
     174    svn add libbb/function.c
     175then
     176    svn diff
    146177and send it to the mailing list:
    147178    busybox@busybox.net
Note: See TracChangeset for help on using the changeset viewer.