]> git.sur5r.net Git - bacula/bacula/commitdiff
Sort Scheduled Jobs list
authorKern Sibbald <kern@sibbald.com>
Mon, 21 Jun 2004 12:40:46 +0000 (12:40 +0000)
committerKern Sibbald <kern@sibbald.com>
Mon, 21 Jun 2004 12:40:46 +0000 (12:40 +0000)
git-svn-id: https://bacula.svn.sourceforge.net/svnroot/bacula/trunk@1434 91ce42f0-d328-0410-95d8-f526ca767f89

12 files changed:
bacula/src/console/console_conf.c
bacula/src/dird/dird.c
bacula/src/dird/dird_conf.c
bacula/src/dird/ua_status.c
bacula/src/filed/filed_conf.c
bacula/src/gnome2-console/console_conf.c
bacula/src/lib/dlist.h
bacula/src/lib/parse_conf.c
bacula/src/lib/parse_conf.h
bacula/src/stored/stored_conf.c
bacula/src/version.h
bacula/src/wx-console/console_conf.c

index 9ae6cad4f937650fcf28e47ebd3090d6c46a2d5f..5893a4f9689cddc3231713770fdbeb5334b7804a 100644 (file)
@@ -47,6 +47,8 @@
  */
 int r_first = R_FIRST;
 int r_last  = R_LAST;
+static RES *sres_head[R_LAST - R_FIRST];
+RES **res_head = sres_head;
 
 /* Forward referenced subroutines */
 
index e866dcfad121afc69072ab2e3aea319ca5b579f1..2e368e4027209dbc6caccd53f11a9738999d7f96 100644 (file)
@@ -347,6 +347,22 @@ static int find_free_reload_table_entry()
 /*
  * If we get here, we have received a SIGHUP, which means to
  *    reread our configuration file. 
+ *
+ * The algorithm used is as follows: we count how many jobs are
+ *   running since the last reload and set those jobs to make a
+ *   callback. Also, we set each job with the current reload table
+ *   id. . The old config is saved with the reload table
+ *   id in a reload table. The new config file is read. Now, as
+ *   each job exits, it calls back to the reload_job_end_cb(), which
+ *   decrements the count of open jobs for the given reload table.
+ *   When the count goes to zero, we release those resources.
+ *   This allows us to have pointers into the resource table (from
+ *   jobs), and once they exit and all the pointers are released, we
+ *   release the old table. Note, if no new jobs are running since the
+ *   last reload, then the old resources will be immediately release.
+ *   A console is considered a job because it may have pointers to
+ *   resources, but a SYSTEM job is not since it *should* not have any
+ *   permanent pointers to jobs.
  */
 extern "C"
 void reload_config(int sig)
index 6800fead5f54d2fff143a4cc5e3a97fa4e851aa5..91e48879503cce4ab4bd8bd5364c4476622fe46b 100644 (file)
@@ -8,14 +8,14 @@
  *   1. The generic lexical scanner in lib/lex.c and lib/lex.h
  *
  *   2. The generic config  scanner in lib/parse_config.c and 
- *     lib/parse_config.h.
- *     These files contain the parser code, some utility
- *     routines, and the common store routines (name, int,
- *     string).
+ *      lib/parse_config.h.
+ *      These files contain the parser code, some utility
+ *      routines, and the common store routines (name, int,
+ *      string).
  *
  *   3. The daemon specific file, which contains the Resource
- *     definitions as well as any specific store routines
- *     for the resource records.
+ *      definitions as well as any specific store routines
+ *      for the resource records.
  *
  *     Kern Sibbald, January MM
  *
@@ -50,6 +50,8 @@
  */
 int r_first = R_FIRST;
 int r_last  = R_LAST;
+static RES *sres_head[R_LAST - R_FIRST];
+RES **res_head = sres_head;
 
 /* Imported subroutines */
 extern void store_run(LEX *lc, RES_ITEM *item, int index, int pass);
@@ -81,7 +83,7 @@ int  res_all_size = sizeof(res_all);
 /* 
  *    Director Resource
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 static RES_ITEM dir_items[] = {
    {"name",        store_name,     ITEM(res_dir.hdr.name), 0, ITEM_REQUIRED, 0},
@@ -105,7 +107,7 @@ static RES_ITEM dir_items[] = {
 /* 
  *    Console Resource
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 static RES_ITEM con_items[] = {
    {"name",        store_name,     ITEM(res_con.hdr.name), 0, ITEM_REQUIRED, 0},
@@ -128,7 +130,7 @@ static RES_ITEM con_items[] = {
 /* 
  *    Client or File daemon resource
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 
 static RES_ITEM cli_items[] = {
@@ -150,7 +152,7 @@ static RES_ITEM cli_items[] = {
 
 /* Storage daemon resource
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 static RES_ITEM store_items[] = {
    {"name",        store_name,     ITEM(res_store.hdr.name),   0, ITEM_REQUIRED, 0},
@@ -173,7 +175,7 @@ static RES_ITEM store_items[] = {
 /* 
  *    Catalog Resource Directives
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 static RES_ITEM cat_items[] = {
    {"name",     store_name,     ITEM(res_cat.hdr.name),    0, ITEM_REQUIRED, 0},
@@ -193,7 +195,7 @@ static RES_ITEM cat_items[] = {
 /* 
  *    Job Resource Directives
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 RES_ITEM job_items[] = {
    {"name",      store_name,    ITEM(res_job.hdr.name), 0, ITEM_REQUIRED, 0},
@@ -240,20 +242,20 @@ RES_ITEM job_items[] = {
 
 /* FileSet resource
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 static RES_ITEM fs_items[] = {
    {"name",        store_name, ITEM(res_fs.hdr.name), 0, ITEM_REQUIRED, 0},
    {"description", store_str,  ITEM(res_fs.hdr.desc), 0, 0, 0},
    {"include",     store_inc,  NULL,                  0, ITEM_NO_EQUALS, 0},
    {"exclude",     store_inc,  NULL,                  1, ITEM_NO_EQUALS, 0},
-   {NULL,         NULL,       NULL,                  0, 0, 0} 
+   {NULL,          NULL,       NULL,                  0, 0, 0} 
 };
 
 /* Schedule -- see run_conf.c */
 /* Schedule
  *
- *   name         handler     value                 code flags    default_value
+ *   name          handler     value                 code flags    default_value
  */
 static RES_ITEM sch_items[] = {
    {"name",     store_name,  ITEM(res_sch.hdr.name), 0, ITEM_REQUIRED, 0},
@@ -264,7 +266,7 @@ static RES_ITEM sch_items[] = {
 
 /* Pool resource
  *
- *   name            handler     value                        code flags default_value
+ *   name             handler     value                        code flags default_value
  */
 static RES_ITEM pool_items[] = {
    {"name",            store_name,    ITEM(res_pool.hdr.name),      0, ITEM_REQUIRED, 0},
@@ -292,7 +294,7 @@ static RES_ITEM pool_items[] = {
 
 /* 
  * Counter Resource
- *   name            handler     value                        code flags default_value
+ *   name             handler     value                        code flags default_value
  */
 static RES_ITEM counter_items[] = {
    {"name",            store_name,    ITEM(res_counter.hdr.name),        0, ITEM_REQUIRED, 0},
@@ -315,7 +317,7 @@ extern RES_ITEM msgs_items[];
  *  NOTE!!! keep it in the same order as the R_codes
  *    or eliminate all resources[rindex].name
  *
- *  name            items        rcode        res_head
+ *  name             items        rcode        res_head
  */
 RES_TABLE resources[] = {
    {"director",      dir_items,   R_DIRECTOR,  NULL},
@@ -330,13 +332,13 @@ RES_TABLE resources[] = {
    {"counter",       counter_items, R_COUNTER, NULL},
    {"console",       con_items,   R_CONSOLE,   NULL},
    {"jobdefs",       job_items,   R_JOBDEFS,   NULL},
-   {NULL,           NULL,        0,           NULL}
+   {NULL,            NULL,        0,           NULL}
 };
 
 
 /* Keywords (RHS) permitted in Job Level records   
  *
- *   level_name      level             job_type
+ *   level_name      level              job_type
  */
 struct s_jl joblevels[] = {
    {"Full",          L_FULL,            JT_BACKUP},
@@ -351,19 +353,19 @@ struct s_jl joblevels[] = {
    {"Data",          L_VERIFY_DATA,     JT_VERIFY},
    {" ",             L_NONE,            JT_ADMIN},
    {" ",             L_NONE,            JT_RESTORE},
-   {NULL,           0,                          0}
+   {NULL,            0,                          0}
 };
 
 /* Keywords (RHS) permitted in Job type records   
  *
- *   type_name      job_type
+ *   type_name       job_type
  */
 struct s_jt jobtypes[] = {
    {"backup",        JT_BACKUP},
    {"admin",         JT_ADMIN},
    {"verify",        JT_VERIFY},
    {"restore",       JT_RESTORE},
-   {NULL,           0}
+   {NULL,            0}
 };
 
 #ifdef old_deprecated_code
@@ -373,7 +375,7 @@ static struct s_kw BakVerFields[] = {
    {"client",        'C'},
    {"fileset",       'F'},
    {"level",         'L'}, 
-   {NULL,           0}
+   {NULL,            0}
 };
 
 /* Keywords (RHS) permitted in Restore records */
@@ -384,7 +386,7 @@ static struct s_kw RestoreFields[] = {
    {"where",         'W'},            /* root of restore */
    {"replace",       'R'},            /* replacement options */
    {"bootstrap",     'B'},            /* bootstrap file */
-   {NULL,             0}
+   {NULL,              0}
 };
 #endif
 
@@ -394,7 +396,7 @@ struct s_kw ReplaceOptions[] = {
    {"ifnewer",        REPLACE_IFNEWER},
    {"ifolder",        REPLACE_IFOLDER},
    {"never",          REPLACE_NEVER},
-   {NULL,              0}
+   {NULL,               0}
 };
 
 const char *level_to_str(int level)
@@ -406,8 +408,8 @@ const char *level_to_str(int level)
    bsnprintf(level_no, sizeof(level_no), "%d", level);    /* default if not found */
    for (i=0; joblevels[i].level_name; i++) {
       if (level == joblevels[i].level) {
-        str = joblevels[i].level_name;
-        break;
+         str = joblevels[i].level_name;
+         break;
       }
    }
    return str;
@@ -424,93 +426,93 @@ void dump_resource(int type, RES *reshdr, void sendit(void *sock, const char *fm
       sendit(sock, "No %s resource defined\n", res_to_str(type));
       return;
    }
-   if (type < 0) {                   /* no recursion */
+   if (type < 0) {                    /* no recursion */
       type = - type;
       recurse = false;
    }
    switch (type) {
    case R_DIRECTOR:
       sendit(sock, "Director: name=%s MaxJobs=%d FDtimeout=%s SDtimeout=%s\n", 
-        reshdr->name, res->res_dir.MaxConcurrentJobs, 
-        edit_uint64(res->res_dir.FDConnectTimeout, ed1),
-        edit_uint64(res->res_dir.SDConnectTimeout, ed2));
+         reshdr->name, res->res_dir.MaxConcurrentJobs, 
+         edit_uint64(res->res_dir.FDConnectTimeout, ed1),
+         edit_uint64(res->res_dir.SDConnectTimeout, ed2));
       if (res->res_dir.query_file) {
          sendit(sock, "   query_file=%s\n", res->res_dir.query_file);
       }
       if (res->res_dir.messages) {
          sendit(sock, "  --> ");
-        dump_resource(-R_MSGS, (RES *)res->res_dir.messages, sendit, sock);
+         dump_resource(-R_MSGS, (RES *)res->res_dir.messages, sendit, sock);
       }
       break;
    case R_CONSOLE:
       sendit(sock, "Console: name=%s SSL=%d\n", 
-        res->res_con.hdr.name, res->res_con.enable_ssl);
+         res->res_con.hdr.name, res->res_con.enable_ssl);
       break;
    case R_COUNTER:
       if (res->res_counter.WrapCounter) {
          sendit(sock, "Counter: name=%s min=%d max=%d cur=%d wrapcntr=%s\n",
-           res->res_counter.hdr.name, res->res_counter.MinValue, 
-           res->res_counter.MaxValue, res->res_counter.CurrentValue,
-           res->res_counter.WrapCounter->hdr.name);
+            res->res_counter.hdr.name, res->res_counter.MinValue, 
+            res->res_counter.MaxValue, res->res_counter.CurrentValue,
+            res->res_counter.WrapCounter->hdr.name);
       } else {
          sendit(sock, "Counter: name=%s min=%d max=%d\n",
-           res->res_counter.hdr.name, res->res_counter.MinValue, 
-           res->res_counter.MaxValue);
+            res->res_counter.hdr.name, res->res_counter.MinValue, 
+            res->res_counter.MaxValue);
       }
       if (res->res_counter.Catalog) {
          sendit(sock, "  --> ");
-        dump_resource(-R_CATALOG, (RES *)res->res_counter.Catalog, sendit, sock);
+         dump_resource(-R_CATALOG, (RES *)res->res_counter.Catalog, sendit, sock);
       }
       break;
 
    case R_CLIENT:
       sendit(sock, "Client: name=%s address=%s FDport=%d MaxJobs=%u\n",
-        res->res_client.hdr.name, res->res_client.address, res->res_client.FDport,
-        res->res_client.MaxConcurrentJobs);
+         res->res_client.hdr.name, res->res_client.address, res->res_client.FDport,
+         res->res_client.MaxConcurrentJobs);
       sendit(sock, "      JobRetention=%s FileRetention=%s AutoPrune=%d\n",
-        edit_utime(res->res_client.JobRetention, ed1), 
-        edit_utime(res->res_client.FileRetention, ed2),
-        res->res_client.AutoPrune);
+         edit_utime(res->res_client.JobRetention, ed1), 
+         edit_utime(res->res_client.FileRetention, ed2),
+         res->res_client.AutoPrune);
       if (res->res_client.catalog) {
          sendit(sock, "  --> ");
-        dump_resource(-R_CATALOG, (RES *)res->res_client.catalog, sendit, sock);
+         dump_resource(-R_CATALOG, (RES *)res->res_client.catalog, sendit, sock);
       }
       break;
    case R_STORAGE:
       sendit(sock, "Storage: name=%s address=%s SDport=%d MaxJobs=%u\n\
       DeviceName=%s MediaType=%s\n",
-        res->res_store.hdr.name, res->res_store.address, res->res_store.SDport,
-        res->res_store.MaxConcurrentJobs,
-        res->res_store.dev_name, res->res_store.media_type);
+         res->res_store.hdr.name, res->res_store.address, res->res_store.SDport,
+         res->res_store.MaxConcurrentJobs,
+         res->res_store.dev_name, res->res_store.media_type);
       break;
    case R_CATALOG:
       sendit(sock, "Catalog: name=%s address=%s DBport=%d db_name=%s\n\
       db_user=%s\n",
-        res->res_cat.hdr.name, NPRT(res->res_cat.db_address),
-        res->res_cat.db_port, res->res_cat.db_name, NPRT(res->res_cat.db_user));
+         res->res_cat.hdr.name, NPRT(res->res_cat.db_address),
+         res->res_cat.db_port, res->res_cat.db_name, NPRT(res->res_cat.db_user));
       break;
    case R_JOB:
    case R_JOBDEFS:
       sendit(sock, "%s: name=%s JobType=%d level=%s Priority=%d MaxJobs=%u\n", 
          type == R_JOB ? "Job" : "JobDefs",
-        res->res_job.hdr.name, res->res_job.JobType, 
-        level_to_str(res->res_job.level), res->res_job.Priority,
-        res->res_job.MaxConcurrentJobs);
+         res->res_job.hdr.name, res->res_job.JobType, 
+         level_to_str(res->res_job.level), res->res_job.Priority,
+         res->res_job.MaxConcurrentJobs);
       sendit(sock, "     Resched=%d Times=%d Interval=%s Spool=%d\n",
-         res->res_job.RescheduleOnError, res->res_job.RescheduleTimes,
-         edit_uint64_with_commas(res->res_job.RescheduleInterval, ed1),
-         res->res_job.spool_data);
+          res->res_job.RescheduleOnError, res->res_job.RescheduleTimes,
+          edit_uint64_with_commas(res->res_job.RescheduleInterval, ed1),
+          res->res_job.spool_data);
       if (res->res_job.client) {
          sendit(sock, "  --> ");
-        dump_resource(-R_CLIENT, (RES *)res->res_job.client, sendit, sock);
+         dump_resource(-R_CLIENT, (RES *)res->res_job.client, sendit, sock);
       }
       if (res->res_job.fileset) {
          sendit(sock, "  --> ");
-        dump_resource(-R_FILESET, (RES *)res->res_job.fileset, sendit, sock);
+         dump_resource(-R_FILESET, (RES *)res->res_job.fileset, sendit, sock);
       }
       if (res->res_job.schedule) {
          sendit(sock, "  --> ");
-        dump_resource(-R_SCHEDULE, (RES *)res->res_job.schedule, sendit, sock);
+         dump_resource(-R_SCHEDULE, (RES *)res->res_job.schedule, sendit, sock);
       }
       if (res->res_job.RestoreWhere) {
          sendit(sock, "  --> Where=%s\n", NPRT(res->res_job.RestoreWhere));
@@ -532,32 +534,32 @@ void dump_resource(int type, RES *reshdr, void sendit(void *sock, const char *fm
       }
       if (res->res_job.storage) {
          sendit(sock, "  --> ");
-        dump_resource(-R_STORAGE, (RES *)res->res_job.storage, sendit, sock);
+         dump_resource(-R_STORAGE, (RES *)res->res_job.storage, sendit, sock);
       }
       if (res->res_job.pool) {
          sendit(sock, "  --> ");
-        dump_resource(-R_POOL, (RES *)res->res_job.pool, sendit, sock);
+         dump_resource(-R_POOL, (RES *)res->res_job.pool, sendit, sock);
       }
       if (res->res_job.full_pool) {
          sendit(sock, "  --> ");
-        dump_resource(-R_POOL, (RES *)res->res_job.full_pool, sendit, sock);
+         dump_resource(-R_POOL, (RES *)res->res_job.full_pool, sendit, sock);
       }
       if (res->res_job.inc_pool) {
          sendit(sock, "  --> ");
-        dump_resource(-R_POOL, (RES *)res->res_job.inc_pool, sendit, sock);
+         dump_resource(-R_POOL, (RES *)res->res_job.inc_pool, sendit, sock);
       }
       if (res->res_job.dif_pool) {
          sendit(sock, "  --> ");
-        dump_resource(-R_POOL, (RES *)res->res_job.dif_pool, sendit, sock);
+         dump_resource(-R_POOL, (RES *)res->res_job.dif_pool, sendit, sock);
       }
       if (res->res_job.verify_job) {
          sendit(sock, "  --> ");
-        dump_resource(-type, (RES *)res->res_job.verify_job, sendit, sock);
+         dump_resource(-type, (RES *)res->res_job.verify_job, sendit, sock);
       }
       break;
       if (res->res_job.messages) {
          sendit(sock, "  --> ");
-        dump_resource(-R_MSGS, (RES *)res->res_job.messages, sendit, sock);
+         dump_resource(-R_MSGS, (RES *)res->res_job.messages, sendit, sock);
       }
       break;
    case R_FILESET:
@@ -565,145 +567,145 @@ void dump_resource(int type, RES *reshdr, void sendit(void *sock, const char *fm
       int i, j, k;
       sendit(sock, "FileSet: name=%s\n", res->res_fs.hdr.name);
       for (i=0; i<res->res_fs.num_includes; i++) {
-        INCEXE *incexe = res->res_fs.include_items[i];
-        for (j=0; j<incexe->num_opts; j++) {
-           FOPTS *fo = incexe->opts_list[j];
+         INCEXE *incexe = res->res_fs.include_items[i];
+         for (j=0; j<incexe->num_opts; j++) {
+            FOPTS *fo = incexe->opts_list[j];
             sendit(sock, "      O %s\n", fo->opts);
-           for (k=0; k<fo->regex.size(); k++) {
+            for (k=0; k<fo->regex.size(); k++) {
                sendit(sock, "      R %s\n", fo->regex.get(k));
-           }
-           for (k=0; k<fo->wild.size(); k++) {
+            }
+            for (k=0; k<fo->wild.size(); k++) {
                sendit(sock, "      W %s\n", fo->wild.get(k));
-           }
-           for (k=0; k<fo->base.size(); k++) {
+            }
+            for (k=0; k<fo->base.size(); k++) {
                sendit(sock, "      B %s\n", fo->base.get(k));
-           }
+            }
             sendit(sock, "      N\n");
-        }
-        for (j=0; j<incexe->name_list.size(); j++) {
+         }
+         for (j=0; j<incexe->name_list.size(); j++) {
             sendit(sock, "      I %s\n", incexe->name_list.get(j));
-        }
-        if (incexe->name_list.size()) {
+         }
+         if (incexe->name_list.size()) {
             sendit(sock, "      N\n");
-        }
+         }
       }
-        
+         
       for (i=0; i<res->res_fs.num_excludes; i++) {
-        INCEXE *incexe = res->res_fs.exclude_items[i];
-        for (j=0; j<incexe->name_list.size(); j++) {
+         INCEXE *incexe = res->res_fs.exclude_items[i];
+         for (j=0; j<incexe->name_list.size(); j++) {
             sendit(sock, "      E %s\n", incexe->name_list.get(j));
-        }
-        if (incexe->name_list.size()) {
+         }
+         if (incexe->name_list.size()) {
             sendit(sock, "      N\n");
-        }
+         }
       }
       break;
    }
    case R_SCHEDULE:
       if (res->res_sch.run) {
-        int i;
-        RUN *run = res->res_sch.run;
-        char buf[1000], num[30];
+         int i;
+         RUN *run = res->res_sch.run;
+         char buf[1000], num[30];
          sendit(sock, "Schedule: name=%s\n", res->res_sch.hdr.name);
-        if (!run) {
-           break;
-        }
+         if (!run) {
+            break;
+         }
 next_run:
          sendit(sock, "  --> Run Level=%s\n", level_to_str(run->level));
          bstrncpy(buf, "      hour=", sizeof(buf));
-        for (i=0; i<24; i++) {
-           if (bit_is_set(i, run->hour)) {
+         for (i=0; i<24; i++) {
+            if (bit_is_set(i, run->hour)) {
                bsnprintf(num, sizeof(num), "%d ", i);
-              bstrncat(buf, num, sizeof(buf));
-           }
-        }
+               bstrncat(buf, num, sizeof(buf));
+            }
+         }
          bstrncat(buf, "\n", sizeof(buf));
-        sendit(sock, buf);
+         sendit(sock, buf);
          bstrncpy(buf, "      mday=", sizeof(buf));
-        for (i=0; i<31; i++) {
-           if (bit_is_set(i, run->mday)) {
+         for (i=0; i<31; i++) {
+            if (bit_is_set(i, run->mday)) {
                bsnprintf(num, sizeof(num), "%d ", i);
-              bstrncat(buf, num, sizeof(buf));
-           }
-        }
+               bstrncat(buf, num, sizeof(buf));
+            }
+         }
          bstrncat(buf, "\n", sizeof(buf));
-        sendit(sock, buf);
+         sendit(sock, buf);
          bstrncpy(buf, "      month=", sizeof(buf));
-        for (i=0; i<12; i++) {
-           if (bit_is_set(i, run->month)) {
+         for (i=0; i<12; i++) {
+            if (bit_is_set(i, run->month)) {
                bsnprintf(num, sizeof(num), "%d ", i);
-              bstrncat(buf, num, sizeof(buf));
-           }
-        }
+               bstrncat(buf, num, sizeof(buf));
+            }
+         }
          bstrncat(buf, "\n", sizeof(buf));
-        sendit(sock, buf);
+         sendit(sock, buf);
          bstrncpy(buf, "      wday=", sizeof(buf));
-        for (i=0; i<7; i++) {
-           if (bit_is_set(i, run->wday)) {
+         for (i=0; i<7; i++) {
+            if (bit_is_set(i, run->wday)) {
                bsnprintf(num, sizeof(num), "%d ", i);
-              bstrncat(buf, num, sizeof(buf));
-           }
-        }
+               bstrncat(buf, num, sizeof(buf));
+            }
+         }
          bstrncat(buf, "\n", sizeof(buf));
-        sendit(sock, buf);
+         sendit(sock, buf);
          bstrncpy(buf, "      wom=", sizeof(buf));
-        for (i=0; i<5; i++) {
-           if (bit_is_set(i, run->wom)) {
+         for (i=0; i<5; i++) {
+            if (bit_is_set(i, run->wom)) {
                bsnprintf(num, sizeof(num), "%d ", i);
-              bstrncat(buf, num, sizeof(buf));
-           }
-        }
+               bstrncat(buf, num, sizeof(buf));
+            }
+         }
          bstrncat(buf, "\n", sizeof(buf));
-        sendit(sock, buf);
+         sendit(sock, buf);
          bstrncpy(buf, "      woy=", sizeof(buf));
-        for (i=0; i<54; i++) {
-           if (bit_is_set(i, run->woy)) {
+         for (i=0; i<54; i++) {
+            if (bit_is_set(i, run->woy)) {
                bsnprintf(num, sizeof(num), "%d ", i);
-              bstrncat(buf, num, sizeof(buf));
-           }
-        }
+               bstrncat(buf, num, sizeof(buf));
+            }
+         }
          bstrncat(buf, "\n", sizeof(buf));
-        sendit(sock, buf);
+         sendit(sock, buf);
          sendit(sock, "      mins=%d\n", run->minute);
-        if (run->pool) {
+         if (run->pool) {
             sendit(sock, "     --> ");
-           dump_resource(-R_POOL, (RES *)run->pool, sendit, sock);
-        }
-        if (run->storage) {
+            dump_resource(-R_POOL, (RES *)run->pool, sendit, sock);
+         }
+         if (run->storage) {
             sendit(sock, "     --> ");
-           dump_resource(-R_STORAGE, (RES *)run->storage, sendit, sock);
-        }
-        if (run->msgs) {
+            dump_resource(-R_STORAGE, (RES *)run->storage, sendit, sock);
+         }
+         if (run->msgs) {
             sendit(sock, "     --> ");
-           dump_resource(-R_MSGS, (RES *)run->msgs, sendit, sock);
-        }
-        /* If another Run record is chained in, go print it */
-        if (run->next) {
-           run = run->next;
-           goto next_run;
-        }
+            dump_resource(-R_MSGS, (RES *)run->msgs, sendit, sock);
+         }
+         /* If another Run record is chained in, go print it */
+         if (run->next) {
+            run = run->next;
+            goto next_run;
+         }
       } else {
          sendit(sock, "Schedule: name=%s\n", res->res_sch.hdr.name);
       }
       break;
    case R_POOL:
       sendit(sock, "Pool: name=%s PoolType=%s\n", res->res_pool.hdr.name,
-             res->res_pool.pool_type);
+              res->res_pool.pool_type);
       sendit(sock, "      use_cat=%d use_once=%d acpt_any=%d cat_files=%d\n",
-             res->res_pool.use_catalog, res->res_pool.use_volume_once,
-             res->res_pool.accept_any_volume, res->res_pool.catalog_files);
+              res->res_pool.use_catalog, res->res_pool.use_volume_once,
+              res->res_pool.accept_any_volume, res->res_pool.catalog_files);
       sendit(sock, "      max_vols=%d auto_prune=%d VolRetention=%s\n",
-             res->res_pool.max_volumes, res->res_pool.AutoPrune,
-             edit_utime(res->res_pool.VolRetention, ed1));
+              res->res_pool.max_volumes, res->res_pool.AutoPrune,
+              edit_utime(res->res_pool.VolRetention, ed1));
       sendit(sock, "      VolUse=%s recycle=%d LabelFormat=%s\n", 
-             edit_utime(res->res_pool.VolUseDuration, ed1),
-             res->res_pool.Recycle,
-             NPRT(res->res_pool.label_format));
+              edit_utime(res->res_pool.VolUseDuration, ed1),
+              res->res_pool.Recycle,
+              NPRT(res->res_pool.label_format));
       sendit(sock, "      CleaningPrefix=%s\n",
-             NPRT(res->res_pool.cleaning_prefix));
+              NPRT(res->res_pool.cleaning_prefix));
       sendit(sock, "      recyleOldest=%d MaxVolJobs=%d MaxVolFiles=%d\n",
-             res->res_pool.purge_oldest_volume, 
-             res->res_pool.MaxVolJobs, res->res_pool.MaxVolFiles);
+              res->res_pool.purge_oldest_volume, 
+              res->res_pool.MaxVolJobs, res->res_pool.MaxVolFiles);
       break;
    case R_MSGS:
       sendit(sock, "Messages: name=%s\n", res->res_msgs.hdr.name);
@@ -750,7 +752,7 @@ static void free_incexe(INCEXE *incexe)
 void free_resource(RES *sres, int type)
 {
    int num;
-   RES *nres;                        /* next resource if linked */
+   RES *nres;                         /* next resource if linked */
    URES *res = (URES *)sres;
 
    if (res == NULL)
@@ -768,147 +770,147 @@ void free_resource(RES *sres, int type)
    switch (type) {
    case R_DIRECTOR:
       if (res->res_dir.working_directory) {
-        free(res->res_dir.working_directory);
+         free(res->res_dir.working_directory);
       }
       if (res->res_dir.pid_directory) {
-        free(res->res_dir.pid_directory);
+         free(res->res_dir.pid_directory);
       }
       if (res->res_dir.subsys_directory) {
-        free(res->res_dir.subsys_directory);
+         free(res->res_dir.subsys_directory);
       }
       if (res->res_dir.password) {
-        free(res->res_dir.password);
+         free(res->res_dir.password);
       }
       if (res->res_dir.query_file) {
-        free(res->res_dir.query_file);
+         free(res->res_dir.query_file);
       }
       if (res->res_dir.DIRaddr) {
-        free(res->res_dir.DIRaddr);
+         free(res->res_dir.DIRaddr);
       }
       break;
    case R_COUNTER:
        break;
    case R_CONSOLE:
       if (res->res_con.password) {
-        free(res->res_con.password);
+         free(res->res_con.password);
       }
       for (int i=0; i<Num_ACL; i++) {
-        if (res->res_con.ACL_lists[i]) {
-           delete res->res_con.ACL_lists[i];
-           res->res_con.ACL_lists[i] = NULL;
-        }
+         if (res->res_con.ACL_lists[i]) {
+            delete res->res_con.ACL_lists[i];
+            res->res_con.ACL_lists[i] = NULL;
+         }
       }
       break;
    case R_CLIENT:
       if (res->res_client.address) {
-        free(res->res_client.address);
+         free(res->res_client.address);
       }
       if (res->res_client.password) {
-        free(res->res_client.password);
+         free(res->res_client.password);
       }
       break;
    case R_STORAGE:
       if (res->res_store.address) {
-        free(res->res_store.address);
+         free(res->res_store.address);
       }
       if (res->res_store.password) {
-        free(res->res_store.password);
+         free(res->res_store.password);
       }
       if (res->res_store.media_type) {
-        free(res->res_store.media_type);
+         free(res->res_store.media_type);
       }
       if (res->res_store.dev_name) {
-        free(res->res_store.dev_name);
+         free(res->res_store.dev_name);
       }
       break;
    case R_CATALOG:
       if (res->res_cat.db_address) {
-        free(res->res_cat.db_address);
+         free(res->res_cat.db_address);
       }
       if (res->res_cat.db_socket) {
-        free(res->res_cat.db_socket);
+         free(res->res_cat.db_socket);
       }
       if (res->res_cat.db_user) {
-        free(res->res_cat.db_user);
+         free(res->res_cat.db_user);
       }
       if (res->res_cat.db_name) {
-        free(res->res_cat.db_name);
+         free(res->res_cat.db_name);
       }
       if (res->res_cat.db_password) {
-        free(res->res_cat.db_password);
+         free(res->res_cat.db_password);
       }
       break;
    case R_FILESET:
       if ((num=res->res_fs.num_includes)) {
-        while (--num >= 0) {   
-           free_incexe(res->res_fs.include_items[num]);
-        }
-        free(res->res_fs.include_items);
+         while (--num >= 0) {   
+            free_incexe(res->res_fs.include_items[num]);
+         }
+         free(res->res_fs.include_items);
       }
       res->res_fs.num_includes = 0;
       if ((num=res->res_fs.num_excludes)) {
-        while (--num >= 0) {   
-           free_incexe(res->res_fs.exclude_items[num]);
-        }
-        free(res->res_fs.exclude_items);
+         while (--num >= 0) {   
+            free_incexe(res->res_fs.exclude_items[num]);
+         }
+         free(res->res_fs.exclude_items);
       }
       res->res_fs.num_excludes = 0;
       break;
    case R_POOL:
       if (res->res_pool.pool_type) {
-        free(res->res_pool.pool_type);
+         free(res->res_pool.pool_type);
       }
       if (res->res_pool.label_format) {
-        free(res->res_pool.label_format);
+         free(res->res_pool.label_format);
       }
       if (res->res_pool.cleaning_prefix) {
-        free(res->res_pool.cleaning_prefix);
+         free(res->res_pool.cleaning_prefix);
       }
       break;
    case R_SCHEDULE:
       if (res->res_sch.run) {
-        RUN *nrun, *next;
-        nrun = res->res_sch.run;
-        while (nrun) {
-           next = nrun->next;
-           free(nrun);
-           nrun = next;
-        }
+         RUN *nrun, *next;
+         nrun = res->res_sch.run;
+         while (nrun) {
+            next = nrun->next;
+            free(nrun);
+            nrun = next;
+         }
       }
       break;
    case R_JOB:
    case R_JOBDEFS:
       if (res->res_job.RestoreWhere) {
-        free(res->res_job.RestoreWhere);
+         free(res->res_job.RestoreWhere);
       }
       if (res->res_job.RestoreBootstrap) {
-        free(res->res_job.RestoreBootstrap);
+         free(res->res_job.RestoreBootstrap);
       }
       if (res->res_job.WriteBootstrap) {
-        free(res->res_job.WriteBootstrap);
+         free(res->res_job.WriteBootstrap);
       }
       if (res->res_job.RunBeforeJob) {
-        free(res->res_job.RunBeforeJob);
+         free(res->res_job.RunBeforeJob);
       }
       if (res->res_job.RunAfterJob) {
-        free(res->res_job.RunAfterJob);
+         free(res->res_job.RunAfterJob);
       }
       if (res->res_job.RunAfterFailedJob) {
-        free(res->res_job.RunAfterFailedJob);
+         free(res->res_job.RunAfterFailedJob);
       }
       if (res->res_job.ClientRunBeforeJob) {
-        free(res->res_job.ClientRunBeforeJob);
+         free(res->res_job.ClientRunBeforeJob);
       }
       if (res->res_job.ClientRunAfterJob) {
-        free(res->res_job.ClientRunAfterJob);
+         free(res->res_job.ClientRunAfterJob);
       }
       break;
    case R_MSGS:
       if (res->res_msgs.mail_cmd) {
-        free(res->res_msgs.mail_cmd);
+         free(res->res_msgs.mail_cmd);
       }
       if (res->res_msgs.operator_cmd) {
-        free(res->res_msgs.operator_cmd);
+         free(res->res_msgs.operator_cmd);
       }
       free_msgs_res((MSGS *)res);  /* free message resource */
       res = NULL;
@@ -944,16 +946,16 @@ void save_resource(int type, RES_ITEM *items, int pass)
        * Ensure that all required items are present
        */
       for (i=0; items[i].name; i++) {
-        if (items[i].flags & ITEM_REQUIRED) {
-              if (!bit_is_set(i, res_all.res_dir.hdr.item_present)) {  
+         if (items[i].flags & ITEM_REQUIRED) {
+               if (!bit_is_set(i, res_all.res_dir.hdr.item_present)) {  
                   Emsg2(M_ERROR_TERM, 0, "%s item is required in %s resource, but not found.\n",
-                   items[i].name, resources[rindex]);
-               }
-        }
-        /* If this triggers, take a look at lib/parse_conf.h */
-        if (i >= MAX_RES_ITEMS) {
+                    items[i].name, resources[rindex]);
+                }
+         }
+         /* If this triggers, take a look at lib/parse_conf.h */
+         if (i >= MAX_RES_ITEMS) {
             Emsg1(M_ERROR_TERM, 0, "Too many items in %s resource\n", resources[rindex]);
-        }
+         }
       }
    }
 
@@ -972,74 +974,74 @@ void save_resource(int type, RES_ITEM *items, int pass)
       case R_POOL:
       case R_MSGS:
       case R_FILESET:
-        break;
+         break;
 
       /* Resources containing another resource */
       case R_DIRECTOR:
-        if ((res = (URES *)GetResWithName(R_DIRECTOR, res_all.res_dir.hdr.name)) == NULL) {
+         if ((res = (URES *)GetResWithName(R_DIRECTOR, res_all.res_dir.hdr.name)) == NULL) {
             Emsg1(M_ERROR_TERM, 0, "Cannot find Director resource %s\n", res_all.res_dir.hdr.name);
-        }
-        res->res_dir.messages = res_all.res_dir.messages;
-        break;
+         }
+         res->res_dir.messages = res_all.res_dir.messages;
+         break;
       case R_JOB:
       case R_JOBDEFS:
-        if ((res = (URES *)GetResWithName(type, res_all.res_dir.hdr.name)) == NULL) {
+         if ((res = (URES *)GetResWithName(type, res_all.res_dir.hdr.name)) == NULL) {
             Emsg1(M_ERROR_TERM, 0, "Cannot find Job resource %s\n", 
-                 res_all.res_dir.hdr.name);
-        }
-        res->res_job.messages   = res_all.res_job.messages;
-        res->res_job.schedule   = res_all.res_job.schedule;
-        res->res_job.client     = res_all.res_job.client;
-        res->res_job.fileset    = res_all.res_job.fileset;
-        res->res_job.storage    = res_all.res_job.storage;
-        res->res_job.pool       = res_all.res_job.pool;
-        res->res_job.full_pool  = res_all.res_job.full_pool;
-        res->res_job.inc_pool   = res_all.res_job.inc_pool;
-        res->res_job.dif_pool   = res_all.res_job.dif_pool;
-        res->res_job.verify_job = res_all.res_job.verify_job;
-        res->res_job.jobdefs    = res_all.res_job.jobdefs;
-        break;
+                  res_all.res_dir.hdr.name);
+         }
+         res->res_job.messages   = res_all.res_job.messages;
+         res->res_job.schedule   = res_all.res_job.schedule;
+         res->res_job.client     = res_all.res_job.client;
+         res->res_job.fileset    = res_all.res_job.fileset;
+         res->res_job.storage    = res_all.res_job.storage;
+         res->res_job.pool       = res_all.res_job.pool;
+         res->res_job.full_pool  = res_all.res_job.full_pool;
+         res->res_job.inc_pool   = res_all.res_job.inc_pool;
+         res->res_job.dif_pool   = res_all.res_job.dif_pool;
+         res->res_job.verify_job = res_all.res_job.verify_job;
+         res->res_job.jobdefs    = res_all.res_job.jobdefs;
+         break;
       case R_COUNTER:
-        if ((res = (URES *)GetResWithName(R_COUNTER, res_all.res_counter.hdr.name)) == NULL) {
+         if ((res = (URES *)GetResWithName(R_COUNTER, res_all.res_counter.hdr.name)) == NULL) {
             Emsg1(M_ERROR_TERM, 0, "Cannot find Counter resource %s\n", res_all.res_counter.hdr.name);
-        }
-        res->res_counter.Catalog = res_all.res_counter.Catalog;
-        res->res_counter.WrapCounter = res_all.res_counter.WrapCounter;
-        break;
+         }
+         res->res_counter.Catalog = res_all.res_counter.Catalog;
+         res->res_counter.WrapCounter = res_all.res_counter.WrapCounter;
+         break;
 
       case R_CLIENT:
-        if ((res = (URES *)GetResWithName(R_CLIENT, res_all.res_client.hdr.name)) == NULL) {
+         if ((res = (URES *)GetResWithName(R_CLIENT, res_all.res_client.hdr.name)) == NULL) {
             Emsg1(M_ERROR_TERM, 0, "Cannot find Client resource %s\n", res_all.res_client.hdr.name);
-        }
-        res->res_client.catalog = res_all.res_client.catalog;
-        break;
+         }
+         res->res_client.catalog = res_all.res_client.catalog;
+         break;
       case R_SCHEDULE:
-        /*
-         * Schedule is a bit different in that it contains a RUN record
+         /*
+          * Schedule is a bit different in that it contains a RUN record
           * chain which isn't a "named" resource. This chain was linked
-         * in by run_conf.c during pass 2, so here we jam the pointer 
-         * into the Schedule resource.                         
-         */
-        if ((res = (URES *)GetResWithName(R_SCHEDULE, res_all.res_client.hdr.name)) == NULL) {
+          * in by run_conf.c during pass 2, so here we jam the pointer 
+          * into the Schedule resource.                         
+          */
+         if ((res = (URES *)GetResWithName(R_SCHEDULE, res_all.res_client.hdr.name)) == NULL) {
             Emsg1(M_ERROR_TERM, 0, "Cannot find Schedule resource %s\n", res_all.res_client.hdr.name);
-        }
-        res->res_sch.run = res_all.res_sch.run;
-        break;
+         }
+         res->res_sch.run = res_all.res_sch.run;
+         break;
       default:
          Emsg1(M_ERROR, 0, "Unknown resource type %d in save_resource.\n", type);
-        error = 1;
-        break;
+         error = 1;
+         break;
       }
       /* Note, the resource name was already saved during pass 1,
        * so here, we can just release it.
        */
       if (res_all.res_dir.hdr.name) {
-        free(res_all.res_dir.hdr.name);
-        res_all.res_dir.hdr.name = NULL;
+         free(res_all.res_dir.hdr.name);
+         res_all.res_dir.hdr.name = NULL;
       }
       if (res_all.res_dir.hdr.desc) {
-        free(res_all.res_dir.hdr.desc);
-        res_all.res_dir.hdr.desc = NULL;
+         free(res_all.res_dir.hdr.desc);
+         res_all.res_dir.hdr.desc = NULL;
       }
       return;
    }
@@ -1093,22 +1095,22 @@ void save_resource(int type, RES_ITEM *items, int pass)
       res = (URES *)malloc(size);
       memcpy(res, &res_all, size);
       if (!resources[rindex].res_head) {
-        resources[rindex].res_head = (RES *)res; /* store first entry */
+         resources[rindex].res_head = (RES *)res; /* store first entry */
          Dmsg3(900, "Inserting first %s res: %s index=%d\n", res_to_str(type),
-              res->res_dir.hdr.name, rindex);
+               res->res_dir.hdr.name, rindex);
       } else {
-        RES *next;
-        /* Add new res to end of chain */
-        for (next=resources[rindex].res_head; next->next; next=next->next) {
-           if (strcmp(next->name, res->res_dir.hdr.name) == 0) {
-              Emsg2(M_ERROR_TERM, 0,
+         RES *next;
+         /* Add new res to end of chain */
+         for (next=resources[rindex].res_head; next->next; next=next->next) {
+            if (strcmp(next->name, res->res_dir.hdr.name) == 0) {
+               Emsg2(M_ERROR_TERM, 0,
                   _("Attempt to define second %s resource named \"%s\" is not permitted.\n"),
-                 resources[rindex].name, res->res_dir.hdr.name);
-           }
-        }
-        next->next = (RES *)res;
+                  resources[rindex].name, res->res_dir.hdr.name);
+            }
+         }
+         next->next = (RES *)res;
          Dmsg4(900, "Inserting %s res: %s index=%d pass=%d\n", res_to_str(type),
-              res->res_dir.hdr.name, rindex, pass);
+               res->res_dir.hdr.name, rindex, pass);
       }
    }
 }
@@ -1125,9 +1127,9 @@ void store_jobtype(LEX *lc, RES_ITEM *item, int index, int pass)
    /* Store the type both pass 1 and pass 2 */
    for (i=0; jobtypes[i].type_name; i++) {
       if (strcasecmp(lc->str, jobtypes[i].type_name) == 0) {
-        *(int *)(item->value) = jobtypes[i].job_type;
-        i = 0;
-        break;
+         *(int *)(item->value) = jobtypes[i].job_type;
+         i = 0;
+         break;
       }
    }
    if (i != 0) {
@@ -1149,9 +1151,9 @@ void store_level(LEX *lc, RES_ITEM *item, int index, int pass)
    /* Store the level pass 2 so that type is defined */
    for (i=0; joblevels[i].level_name; i++) {
       if (strcasecmp(lc->str, joblevels[i].level_name) == 0) {
-        *(int *)(item->value) = joblevels[i].level;
-        i = 0;
-        break;
+         *(int *)(item->value) = joblevels[i].level;
+         i = 0;
+         break;
       }
    }
    if (i != 0) {
@@ -1168,9 +1170,9 @@ void store_replace(LEX *lc, RES_ITEM *item, int index, int pass)
    /* Scan Replacement options */
    for (i=0; ReplaceOptions[i].name; i++) {
       if (strcasecmp(lc->str, ReplaceOptions[i].name) == 0) {
-        *(int *)(item->value) = ReplaceOptions[i].token;
-        i = 0;
-        break;
+         *(int *)(item->value) = ReplaceOptions[i].token;
+         i = 0;
+         break;
       }
    }
    if (i != 0) {
@@ -1191,16 +1193,16 @@ void store_acl(LEX *lc, RES_ITEM *item, int index, int pass)
    for (;;) {
       token = lex_get_token(lc, T_NAME);
       if (pass == 1) {
-        if (((alist **)item->value)[item->code] == NULL) {   
-           ((alist **)item->value)[item->code] = new alist(10, owned_by_alist);
+         if (((alist **)item->value)[item->code] == NULL) {   
+            ((alist **)item->value)[item->code] = new alist(10, owned_by_alist);
 //          Dmsg1(900, "Defined new ACL alist at %d\n", item->code);
-        }
-        ((alist **)item->value)[item->code]->append(bstrdup(lc->str));
+         }
+         ((alist **)item->value)[item->code]->append(bstrdup(lc->str));
 //       Dmsg2(900, "Appended to %d %s\n", item->code, lc->str);
       }
       token = lex_get_token(lc, T_ALL);
       if (token == T_COMMA) {
-        continue;                    /* get another ACL */
+         continue;                    /* get another ACL */
       }
       break;
    }
@@ -1236,59 +1238,59 @@ static void store_backup(LEX *lc, RES_ITEM *item, int index, int pass)
       }
       Dmsg1(900, "Got keyword: %s\n", lc->str);
       for (i=0; BakVerFields[i].name; i++) {
-        if (strcasecmp(lc->str, BakVerFields[i].name) == 0) {
-           found = true;
-           if (lex_get_token(lc, T_ALL) != T_EQUALS) {
+         if (strcasecmp(lc->str, BakVerFields[i].name) == 0) {
+            found = true;
+            if (lex_get_token(lc, T_ALL) != T_EQUALS) {
                scan_err1(lc, "Expected an equals, got: %s", lc->str);
-           }
-           token = lex_get_token(lc, T_NAME);
+            }
+            token = lex_get_token(lc, T_NAME);
             Dmsg1(900, "Got value: %s\n", lc->str);
-           switch (BakVerFields[i].token) {
+            switch (BakVerFields[i].token) {
             case 'C':
-              /* Find Client Resource */
-              if (pass == 2) {
-                 res = GetResWithName(R_CLIENT, lc->str);
-                 if (res == NULL) {
+               /* Find Client Resource */
+               if (pass == 2) {
+                  res = GetResWithName(R_CLIENT, lc->str);
+                  if (res == NULL) {
                      scan_err1(lc, "Could not find specified Client Resource: %s",
-                               lc->str);
-                 }
-                 res_all.res_job.client = (CLIENT *)res;
-              }
-              break;
+                                lc->str);
+                  }
+                  res_all.res_job.client = (CLIENT *)res;
+               }
+               break;
             case 'F':
-              /* Find FileSet Resource */
-              if (pass == 2) {
-                 res = GetResWithName(R_FILESET, lc->str);
-                 if (res == NULL) {
+               /* Find FileSet Resource */
+               if (pass == 2) {
+                  res = GetResWithName(R_FILESET, lc->str);
+                  if (res == NULL) {
                      scan_err1(lc, "Could not find specified FileSet Resource: %s\n",
-                                lc->str);
-                 }
-                 res_all.res_job.fileset = (FILESET *)res;
-              }
-              break;
+                                 lc->str);
+                  }
+                  res_all.res_job.fileset = (FILESET *)res;
+               }
+               break;
             case 'L':
-              /* Get level */
-              for (i=0; joblevels[i].level_name; i++) {
-                 if (joblevels[i].job_type == item->code && 
-                      strcasecmp(lc->str, joblevels[i].level_name) == 0) {
-                    ((JOB *)(item->value))->level = joblevels[i].level;
-                    i = 0;
-                    break;
-                 }
-              }
-              if (i != 0) {
+               /* Get level */
+               for (i=0; joblevels[i].level_name; i++) {
+                  if (joblevels[i].job_type == item->code && 
+                       strcasecmp(lc->str, joblevels[i].level_name) == 0) {
+                     ((JOB *)(item->value))->level = joblevels[i].level;
+                     i = 0;
+                     break;
+                  }
+               }
+               if (i != 0) {
                   scan_err1(lc, "Expected a Job Level keyword, got: %s", lc->str);
-              }
-              break;
-           } /* end switch */
-           break;
-        } /* end if strcmp() */
+               }
+               break;
+            } /* end switch */
+            break;
+         } /* end if strcmp() */
       } /* end for */
       if (!found) {
          scan_err1(lc, "%s not a valid Backup/verify keyword", lc->str);
       }
    } /* end while */
-   lc->options = options;            /* reset original options */
+   lc->options = options;             /* reset original options */
    set_bit(index, res_all.hdr.item_present);
 }
 
@@ -1317,92 +1319,92 @@ static void store_restore(LEX *lc, RES_ITEM *item, int index, int pass)
       }
       for (i=0; RestoreFields[i].name; i++) {
          Dmsg1(900, "Restore kw=%s\n", lc->str);
-        if (strcasecmp(lc->str, RestoreFields[i].name) == 0) {
-           found = true;
-           if (lex_get_token(lc, T_ALL) != T_EQUALS) {
+         if (strcasecmp(lc->str, RestoreFields[i].name) == 0) {
+            found = true;
+            if (lex_get_token(lc, T_ALL) != T_EQUALS) {
                scan_err1(lc, "Expected an equals, got: %s", lc->str);
-           }
-           token = lex_get_token(lc, T_ALL);
+            }
+            token = lex_get_token(lc, T_ALL);
             Dmsg1(900, "Restore value=%s\n", lc->str);
-           switch (RestoreFields[i].token) {
+            switch (RestoreFields[i].token) {
             case 'B':
-              /* Bootstrap */
-              if (token != T_IDENTIFIER && token != T_UNQUOTED_STRING && token != T_QUOTED_STRING) {
+               /* Bootstrap */
+               if (token != T_IDENTIFIER && token != T_UNQUOTED_STRING && token != T_QUOTED_STRING) {
                   scan_err1(lc, "Expected a Restore bootstrap file, got: %s", lc->str);
-              }
-              if (pass == 1) {
-                 res_all.res_job.RestoreBootstrap = bstrdup(lc->str);
-              }
-              break;
+               }
+               if (pass == 1) {
+                  res_all.res_job.RestoreBootstrap = bstrdup(lc->str);
+               }
+               break;
             case 'C':
-              /* Find Client Resource */
-              if (pass == 2) {
-                 res = GetResWithName(R_CLIENT, lc->str);
-                 if (res == NULL) {
+               /* Find Client Resource */
+               if (pass == 2) {
+                  res = GetResWithName(R_CLIENT, lc->str);
+                  if (res == NULL) {
                      scan_err1(lc, "Could not find specified Client Resource: %s",
-                               lc->str);
-                 }
-                 res_all.res_job.client = (CLIENT *)res;
-              }
-              break;
+                                lc->str);
+                  }
+                  res_all.res_job.client = (CLIENT *)res;
+               }
+               break;
             case 'F':
-              /* Find FileSet Resource */
-              if (pass == 2) {
-                 res = GetResWithName(R_FILESET, lc->str);
-                 if (res == NULL) {
+               /* Find FileSet Resource */
+               if (pass == 2) {
+                  res = GetResWithName(R_FILESET, lc->str);
+                  if (res == NULL) {
                      scan_err1(lc, "Could not find specified FileSet Resource: %s\n",
-                                lc->str);
-                 }
-                 res_all.res_job.fileset = (FILESET *)res;
-              }
-              break;
+                                 lc->str);
+                  }
+                  res_all.res_job.fileset = (FILESET *)res;
+               }
+               break;
             case 'J':
-              /* JobId */
-              if (token != T_NUMBER) {
+               /* JobId */
+               if (token != T_NUMBER) {
                   scan_err1(lc, "expected an integer number, got: %s", lc->str);
-              }
-              errno = 0;
-              res_all.res_job.RestoreJobId = strtol(lc->str, NULL, 0);
+               }
+               errno = 0;
+               res_all.res_job.RestoreJobId = strtol(lc->str, NULL, 0);
                Dmsg1(900, "RestorJobId=%d\n", res_all.res_job.RestoreJobId);
-              if (errno != 0) {
+               if (errno != 0) {
                   scan_err1(lc, "expected an integer number, got: %s", lc->str);
-              }
-              break;
+               }
+               break;
             case 'W':
-              /* Where */
-              if (token != T_IDENTIFIER && token != T_UNQUOTED_STRING && token != T_QUOTED_STRING) {
+               /* Where */
+               if (token != T_IDENTIFIER && token != T_UNQUOTED_STRING && token != T_QUOTED_STRING) {
                   scan_err1(lc, "Expected a Restore root directory, got: %s", lc->str);
-              }
-              if (pass == 1) {
-                 res_all.res_job.RestoreWhere = bstrdup(lc->str);
-              }
-              break;
+               }
+               if (pass == 1) {
+                  res_all.res_job.RestoreWhere = bstrdup(lc->str);
+               }
+               break;
             case 'R':
-              /* Replacement options */
-              if (token != T_IDENTIFIER && token != T_UNQUOTED_STRING && token != T_QUOTED_STRING) {
+               /* Replacement options */
+               if (token != T_IDENTIFIER && token != T_UNQUOTED_STRING && token != T_QUOTED_STRING) {
                   scan_err1(lc, "Expected a keyword name, got: %s", lc->str);
-              }
-              /* Fix to scan Replacement options */
-              for (i=0; ReplaceOptions[i].name; i++) {
-                 if (strcasecmp(lc->str, ReplaceOptions[i].name) == 0) {
-                     ((JOB *)(item->value))->replace = ReplaceOptions[i].token;
-                    i = 0;
-                    break;
-                 }
-              }
-              if (i != 0) {
+               }
+               /* Fix to scan Replacement options */
+               for (i=0; ReplaceOptions[i].name; i++) {
+                  if (strcasecmp(lc->str, ReplaceOptions[i].name) == 0) {
+                      ((JOB *)(item->value))->replace = ReplaceOptions[i].token;
+                     i = 0;
+                     break;
+                  }
+               }
+               if (i != 0) {
                   scan_err1(lc, "Expected a Restore replacement option, got: %s", lc->str);
-              }
-              break;
-           } /* end switch */
-           break;
-        } /* end if strcmp() */
+               }
+               break;
+            } /* end switch */
+            break;
+         } /* end if strcmp() */
       } /* end for */
       if (!found) {
          scan_err1(lc, "%s not a valid Restore keyword", lc->str);
       }
    } /* end while */
-   lc->options = options;            /* reset original options */
+   lc->options = options;             /* reset original options */
    set_bit(index, res_all.hdr.item_present);
 }
 #endif
index 77461a8cdf68dba939b40884349980f2e3283aa7..a633b9093e96b80a36e24d78042c4d6dfca2a0fe 100644 (file)
@@ -294,11 +294,21 @@ static void do_client_status(UAContext *ua, CLIENT *client)
 static void prt_runhdr(UAContext *ua)
 {
    bsendmsg(ua, _("\nScheduled Jobs:\n"));
-   bsendmsg(ua, _("Level          Type     Scheduled          Name               Volume\n"));
-   bsendmsg(ua, _("===============================================================================\n"));
+   bsendmsg(ua, _("Level          Type     Pri  Scheduled          Name               Volume\n"));
+   bsendmsg(ua, _("===================================================================================\n"));
 }
 
-static void prt_runtime(UAContext *ua, JOB *job, int level, time_t runtime, POOL *pool)
+/* Scheduling packet */
+struct sched_pkt {
+   dlink link;                       /* keep this as first item!!! */
+   JOB *job;
+   int level;
+   int priority;
+   time_t runtime;
+   POOL *pool;
+};
+
+static void prt_runtime(UAContext *ua, sched_pkt *sp)
 {
    char dt[MAX_TIME_LENGTH];      
    const char *level_ptr;
@@ -307,9 +317,9 @@ static void prt_runtime(UAContext *ua, JOB *job, int level, time_t runtime, POOL
    JCR *jcr = ua->jcr;
    MEDIA_DBR mr;
    memset(&mr, 0, sizeof(mr));
-   if (job->JobType == JT_BACKUP) {
+   if (sp->job->JobType == JT_BACKUP) {
       jcr->db = NULL;
-      ok = complete_jcr_for_job(jcr, job, pool);
+      ok = complete_jcr_for_job(jcr, sp->job, sp->pool);
       if (jcr->db) {
         close_db = true;             /* new db opened, remember to close it */
       }
@@ -320,18 +330,19 @@ static void prt_runtime(UAContext *ua, JOB *job, int level, time_t runtime, POOL
          bstrncpy(mr.VolumeName, "*unknown*", sizeof(mr.VolumeName));
       }
    }
-   bstrftime_nc(dt, sizeof(dt), runtime);
-   switch (job->JobType) {
+   bstrftime_nc(dt, sizeof(dt), sp->runtime);
+   switch (sp->job->JobType) {
    case JT_ADMIN:
    case JT_RESTORE:
       level_ptr = " ";
       break;
    default:
-      level_ptr = level_to_str(level);
+      level_ptr = level_to_str(sp->level);
       break;
    }
-   bsendmsg(ua, _("%-14s %-8s %-18s %-18s %s\n"), 
-      level_ptr, job_type_to_str(job->JobType), dt, job->hdr.name, mr.VolumeName);
+   bsendmsg(ua, _("%-14s %-8s %3d  %-18s %-18s %s\n"), 
+      level_ptr, job_type_to_str(sp->job->JobType), sp->priority, dt, 
+      sp->job->hdr.name, mr.VolumeName);
    if (close_db) {
       db_close_database(jcr, jcr->db);
    }
@@ -339,6 +350,26 @@ static void prt_runtime(UAContext *ua, JOB *job, int level, time_t runtime, POOL
 
 }
 
+/*
+ * Sort items by runtime, priority
+ */
+static int my_compare(void *item1, void *item2)
+{
+   sched_pkt *p1 = (sched_pkt *)item1;
+   sched_pkt *p2 = (sched_pkt *)item2;
+   if (p1->runtime < p2->runtime) {
+      return -1;
+   } else if (p1->runtime > p2->runtime) {
+      return 1;
+   }    
+   if (p1->priority < p2->priority) {
+      return -1;
+   } else if (p1->priority > p2->priority) {
+      return 1;
+   }
+   return 0;
+}
+
 /*         
  * Find all jobs to be run in roughly the
  *  next 24 hours.
@@ -349,7 +380,10 @@ static void list_scheduled_jobs(UAContext *ua)
    RUN *run;
    JOB *job;
    int level, num_jobs = 0;
+   int priority;
    bool hdr_printed = false;
+   dlist sched;
+   sched_pkt *sp;
 
    Dmsg0(200, "enter list_sched_jobs()\n");
 
@@ -364,16 +398,28 @@ static void list_scheduled_jobs(UAContext *ua)
         if (run->level) {
            level = run->level;
         }
+        priority = job->Priority;   
+        if (run->Priority) {
+           priority = run->Priority;
+        }
         if (!hdr_printed) {
            prt_runhdr(ua);
            hdr_printed = true;
         }
-        prt_runtime(ua, job, level, runtime, run->pool);
+        sp = (sched_pkt *)malloc(sizeof(sched_pkt));
+        sp->job = job;
+        sp->level = level;
+        sp->priority = priority;
+        sp->runtime = runtime;
+        sp->pool = run->pool;
+        sched.binary_insert(sp, my_compare);
         num_jobs++;
       }
-
    } /* end for loop over resources */
    UnlockRes();
+   foreach_dlist(sp, &sched) {
+      prt_runtime(ua, sp);
+   }
    if (num_jobs == 0) {
       bsendmsg(ua, _("No Scheduled Jobs.\n"));
    } 
@@ -392,7 +438,7 @@ static void list_running_jobs(UAContext *ua)
    bool pool_mem = false;
 
    Dmsg0(200, "enter list_run_jobs()\n");
-   bsendmsg(ua, _("Running Jobs:\n"));
+   bsendmsg(ua, _("\nRunning Jobs:\n"));
    lock_jcr_chain();
    foreach_jcr(jcr) {
       njobs++;
index dbbe9a0fcc8226bd09839ac0faef0d497dd5a921..cc032d78dfa61cb33cbe318278afcf636e05f8d7 100644 (file)
@@ -51,6 +51,9 @@
  */
 int r_first = R_FIRST;
 int r_last  = R_LAST;
+static RES *sres_head[R_LAST - R_FIRST];
+RES **res_head = sres_head;
+
 
 /* Forward referenced subroutines */
 
index 84cc55e7ad8d3cc2ebd6b30ea6352e3c765a182c..e2c0da44b29a37bef8e4e99029bcd5b0bccde1c8 100644 (file)
@@ -49,6 +49,8 @@
  */
 int r_first = R_FIRST;
 int r_last  = R_LAST;
+static RES *sres_head[R_LAST - R_FIRST];
+RES **res_head = sres_head;
 
 /* Forward referenced subroutines */
 
index 7c591ef93be001fde8ea427b02d07c54a5647d2a..084e414dc948aa93e584688d9748948dc6553a59 100644 (file)
@@ -58,6 +58,8 @@ class dlist {
    uint32_t num_items;
 public:
    dlist(void *item, void *link);
+   dlist(void);
+   ~dlist() { destroy(); }
    void init(void *item, void *link);
    void prepend(void *item);
    void append(void *item);
@@ -94,6 +96,11 @@ inline dlist::dlist(void *item, void *link)
    this->init(item, link);
 }
 
+inline dlist::dlist(void)
+{
+   memset(this, 0, sizeof(dlist));
+}
+
 inline bool dlist::empty()
 {
    return head == NULL;
index 1d5a78793b5bc71435dff44e6c67720925e4715a..711fe40602ba2ba3becd95d0fd39a5184dd57d7b 100755 (executable)
@@ -707,91 +707,91 @@ parse_config(const char *cf, int exit_on_error)
       while ((token=lex_get_token(lc, T_ALL)) != T_EOF) {
          Dmsg1(900, "parse got token=%s\n", lex_tok_to_str(token));
         switch (state) {
-           case p_none:
-              if (token == T_EOL) {
+        case p_none:
+           if (token == T_EOL) {
+              break;
+           }
+           if (token != T_IDENTIFIER) {
+               scan_err1(lc, _("Expected a Resource name identifier, got: %s"), lc->str);
+              set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
+              return 0;
+           }
+           for (i=0; resources[i].name; i++)
+              if (strcasecmp(resources[i].name, lc->str) == 0) {
+                 state = p_resource;
+                 items = resources[i].items;
+                 res_type = resources[i].rcode;
+                 init_resource(res_type, items);
                  break;
               }
-              if (token != T_IDENTIFIER) {
-                  scan_err1(lc, _("Expected a Resource name identifier, got: %s"), lc->str);
+           if (state == p_none) {
+               scan_err1(lc, _("expected resource name, got: %s"), lc->str);
+              set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
+              return 0;
+           }
+           break;
+        case p_resource:
+           switch (token) {
+           case T_BOB:
+              level++;
+              break;
+           case T_IDENTIFIER:
+              if (level != 1) {
+                  scan_err1(lc, _("not in resource definition: %s"), lc->str);
                  set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
                  return 0;
               }
-              for (i=0; resources[i].name; i++)
-                 if (strcasecmp(resources[i].name, lc->str) == 0) {
-                    state = p_resource;
-                    items = resources[i].items;
-                    res_type = resources[i].rcode;
-                    init_resource(res_type, items);
+              for (i=0; items[i].name; i++) {
+                 if (strcasecmp(items[i].name, lc->str) == 0) {
+                    /* If the ITEM_NO_EQUALS flag is set we do NOT              
+                     *   scan for = after the keyword  */
+                    if (!(items[i].flags & ITEM_NO_EQUALS)) {
+                       token = lex_get_token(lc, T_ALL);
+                        Dmsg1 (900, "in T_IDENT got token=%s\n", lex_tok_to_str(token));
+                       if (token != T_EQUALS) {
+                           scan_err1(lc, _("expected an equals, got: %s"), lc->str);
+                          set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
+                          return 0;
+                       }
+                    }
+                     Dmsg1(900, "calling handler for %s\n", items[i].name);
+                    /* Call item handler */
+                    items[i].handler(lc, &items[i], i, pass);
+                    i = -1;
                     break;
                  }
-              if (state == p_none) {
-                  scan_err1(lc, _("expected resource name, got: %s"), lc->str);
+              }
+              if (i >= 0) {
+                  Dmsg2(900, "level=%d id=%s\n", level, lc->str);
+                  Dmsg1(900, "Keyword = %s\n", lc->str);
+                  scan_err1(lc, _("Keyword \"%s\" not permitted in this resource.\n"
+                     "Perhaps you left the trailing brace off of the previous resource."), lc->str);
                  set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
                  return 0;
               }
               break;
-           case p_resource:
-              switch (token) {
-                 case T_BOB:
-                    level++;
-                    break;
-                 case T_IDENTIFIER:
-                    if (level != 1) {
-                        scan_err1(lc, _("not in resource definition: %s"), lc->str);
-                       set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
-                       return 0;
-                    }
-                    for (i=0; items[i].name; i++) {
-                       if (strcasecmp(items[i].name, lc->str) == 0) {
-                          /* If the ITEM_NO_EQUALS flag is set we do NOT              
-                           *   scan for = after the keyword  */
-                          if (!(items[i].flags & ITEM_NO_EQUALS)) {
-                             token = lex_get_token(lc, T_ALL);
-                              Dmsg1 (900, "in T_IDENT got token=%s\n", lex_tok_to_str(token));
-                             if (token != T_EQUALS) {
-                                 scan_err1(lc, _("expected an equals, got: %s"), lc->str);
-                                set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
-                                return 0;
-                             }
-                          }
-                           Dmsg1(900, "calling handler for %s\n", items[i].name);
-                          /* Call item handler */
-                          items[i].handler(lc, &items[i], i, pass);
-                          i = -1;
-                          break;
-                       }
-                    }
-                    if (i >= 0) {
-                        Dmsg2(900, "level=%d id=%s\n", level, lc->str);
-                        Dmsg1(900, "Keyword = %s\n", lc->str);
-                        scan_err1(lc, _("Keyword \"%s\" not permitted in this resource.\n"
-                           "Perhaps you left the trailing brace off of the previous resource."), lc->str);
-                       set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
-                       return 0;
-                    }
-                    break;
-
-                 case T_EOB:
-                    level--;
-                    state = p_none;
-                     Dmsg0(900, "T_EOB => define new resource\n");
-                    save_resource(res_type, items, pass);  /* save resource */
-                    break;
 
-                 case T_EOL:
-                    break;
+           case T_EOB:
+              level--;
+              state = p_none;
+               Dmsg0(900, "T_EOB => define new resource\n");
+              save_resource(res_type, items, pass);  /* save resource */
+              break;
 
-                 default:
-                     scan_err2(lc, _("unexpected token %d %s in resource definition"),    
-                       token, lex_tok_to_str(token));
-                    set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
-                    return 0;
-              }
+           case T_EOL:
               break;
+
            default:
-               scan_err1(lc, _("Unknown parser state %d\n"), state);
+               scan_err2(lc, _("unexpected token %d %s in resource definition"),    
+                 token, lex_tok_to_str(token));
               set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
               return 0;
+           }
+           break;
+        default:
+            scan_err1(lc, _("Unknown parser state %d\n"), state);
+           set_exit_on_error(1); /* Never reached if exit_on_error == 1 */
+           return 0;
         }
       }
       if (state != p_none) {
index 536e89e3c1ef8c9457fc560931c4949062fe32c0..7e7e926d9fd252b44aead3fb351fc985a4b5bbbd 100644 (file)
@@ -21,7 +21,7 @@
 
  */
 
-struct RES_ITEM;                   /* Declare forward referenced structure */ 
+struct RES_ITEM;                    /* Declare forward referenced structure */ 
 typedef void (MSG_RES_HANDLER)(LEX *lc, RES_ITEM *item, int index, int pass);
 
 /* This is the structure that defines
@@ -30,29 +30,29 @@ typedef void (MSG_RES_HANDLER)(LEX *lc, RES_ITEM *item, int index, int pass);
  * tables.
  */
 struct RES_ITEM {
-   const char *name;                 /* Resource name i.e. Director, ... */
-   MSG_RES_HANDLER *handler;         /* Routine storing the resource item */
-   void **value;                     /* Where to store the item */
-   int code;                         /* item code/additional info */
-   int flags;                        /* flags: default, required, ... */
-   int default_value;                /* default value */
+   const char *name;                  /* Resource name i.e. Director, ... */
+   MSG_RES_HANDLER *handler;          /* Routine storing the resource item */
+   void **value;                      /* Where to store the item */
+   int  code;                         /* item code/additional info */
+   int  flags;                        /* flags: default, required, ... */
+   int  default_value;                /* default value */
 };
 
 /* For storing name_addr items in res_items table */
 #define ITEM(x) ((void **)&res_all.x)
 
-#define MAX_RES_ITEMS 50             /* maximum resource items per RES */
+#define MAX_RES_ITEMS 50              /* maximum resource items per RES */
 
 /* This is the universal header that is
  * at the beginning of every resource
  * record.
  */
 struct RES {
-   RES *next;                        /* pointer to next resource of this type */
-   char *name;                       /* resource name */
-   char *desc;                       /* resource description */
-   int  rcode;                       /* resource id or type */
-   int  refcnt;                      /* reference count for releasing */
+   RES *next;                         /* pointer to next resource of this type */
+   char *name;                        /* resource name */
+   char *desc;                        /* resource description */
+   int   rcode;                       /* resource id or type */
+   int   refcnt;                      /* reference count for releasing */
    char  item_present[MAX_RES_ITEMS]; /* set if item is present in conf file */
 };
 
@@ -62,27 +62,27 @@ struct RES {
  * This is the structure that defines the
  * resources that are available to this daemon.
  */
-struct RES_TABLE {      
-   const char *name;                 /* resource name */
-   RES_ITEM *items;          /* list of resource keywords */
-   int rcode;                        /* code if needed */
-   RES *res_head;                    /* where to store it */
+struct RES_TABLE {       
+   const char *name;                  /* resource name */
+   RES_ITEM *items;                   /* list of resource keywords */
+   int rcode;                         /* code if needed */
+   RES *res_head;                     /* where to store it */
 };
 
 /* Common Resource definitions */
 
-#define MAX_RES_NAME_LENGTH MAX_NAME_LENGTH-1      /* maximum resource name length */
+#define MAX_RES_NAME_LENGTH MAX_NAME_LENGTH-1       /* maximum resource name length */
 
-#define ITEM_REQUIRED   0x1          /* item required */
-#define ITEM_DEFAULT    0x2          /* default supplied */
+#define ITEM_REQUIRED    0x1          /* item required */
+#define ITEM_DEFAULT     0x2          /* default supplied */
 #define ITEM_NO_EQUALS   0x4          /* Don't scan = after name */
 
 /* Message Resource */
 struct MSGS {
-   RES  hdr;
-   char *mail_cmd;                   /* mail command */
-   char *operator_cmd;               /* Operator command */
-   DEST *dest_chain;                 /* chain of destinations */
+   RES   hdr;
+   char *mail_cmd;                    /* mail command */
+   char *operator_cmd;                /* Operator command */
+   DEST *dest_chain;                  /* chain of destinations */
    char send_msg[nbytes_for_bits(M_MAX+1)];  /* bit array of types */
 };
 
@@ -118,7 +118,7 @@ const char *res_to_str(int rcode);
 
 #ifdef the_old_way
 #define foreach_res(var, type) \
-       for((var)=NULL; (((void *)(var))=GetNextRes((type), (RES *)var));) 
+        for((var)=NULL; (((void *)(var))=GetNextRes((type), (RES *)var));) 
 #endif
 
 
index b4c84f5b1ca70f486a5479f8a43c455a7ab863f6..79107c177200a47e0bcd9f0a957de60ddbfe6190 100644 (file)
@@ -35,6 +35,8 @@ extern int debug_level;
 /* First and last resource ids */
 int r_first = R_FIRST;
 int r_last  = R_LAST;
+static RES *sres_head[R_LAST - R_FIRST];
+RES **res_head = sres_head;
 
 
 /* Forward referenced subroutines */
index 27fb0a9f1de2971c049c6454e6dafe8204f4d2d5..15cf4033c0a494fe31e2382c08da98fdec368def 100644 (file)
@@ -2,8 +2,8 @@
 #undef  VERSION
 #define VERSION "1.35.0"
 #define VSTRING "1"
-#define BDATE   "19 June 2004"
-#define LSMDATE "19Jun04"
+#define BDATE   "21 June 2004"
+#define LSMDATE "21Jun04"
 
 /* Debug flags */
 #undef  DEBUG
index d8eefe04f670ed14ea15a7b8f93dd834c61523a3..cd0fe754facfb1093ba61b849f88f86ead111f00 100644 (file)
@@ -47,6 +47,8 @@
  */
 int r_first = R_FIRST;
 int r_last  = R_LAST;
+static RES *sres_head[R_LAST - R_FIRST];
+RES **res_head = sres_head;
 
 /* Forward referenced subroutines */