diff -Nur chkconfig-1.2.22.orig/chkconfig.c chkconfig-1.2.22/chkconfig.c --- chkconfig-1.2.22.orig/chkconfig.c Sat Dec 30 05:25:26 2000 +++ chkconfig-1.2.22/chkconfig.c Thu Apr 5 23:39:20 2001 @@ -12,6 +12,7 @@ #include static char *progname; +extern int addItem; #define _(String) gettext((String)) @@ -74,12 +75,10 @@ if (s.type == TYPE_XINETD) return 0; for (i = 0; i < 7; i++) { - if (!isConfigured(name, i)) { if ((1 << i) & s.levels) doSetService(s, i, 1); else doSetService(s, i, 0); - } } return 0; @@ -246,7 +245,7 @@ } int main(int argc, char ** argv) { - int listItem = 0, addItem = 0, delItem = 0; + int listItem = 0, delItem = 0; int rc, i, x; char * levels = NULL; int help=0, version=0; diff -Nur chkconfig-1.2.22.orig/leveldb.c chkconfig-1.2.22/leveldb.c --- chkconfig-1.2.22.orig/leveldb.c Fri Feb 2 18:51:01 2001 +++ chkconfig-1.2.22/leveldb.c Thu Apr 5 23:39:01 2001 @@ -11,6 +11,10 @@ #include #include #include +#include +#include + +int addItem = 0; /* Changes 1998-09-22 - Arnaldo Carvalho de Melo @@ -225,6 +229,9 @@ char overflow; char levelbuf[20]; char * english_desc = NULL; + DIR *dir; + struct dirent *dirent; + int i; sprintf(filename, RUNLEVELS "/init.d/%s", name); @@ -316,6 +323,21 @@ } serv.name = strdup(name); + + if (addItem) { + strcpy(levelbuf,"/etc/rc.d/rc0.d"); + for(i=0;i<7;i++,levelbuf[12]++) { + dir=opendir(levelbuf); + if (!dir) return 1; + while ((dirent=readdir(dir))) { + if (strlen(dirent->d_name)<4) continue; + if (strcmp(dirent->d_name+3,name)) continue; + if (*dirent->d_name=='K') serv.levels &= ~(1<d_name=='S') serv.levels |= 1<