]> andersk Git - moira.git/blobdiff - gen/ca.dc
performance improvements
[moira.git] / gen / ca.dc
index 4725d44c90b05a33753f09169afe23eceed1392a..d452559ae5339e6ec48e0a5675a64b9e661338cf 100644 (file)
--- a/gen/ca.dc
+++ b/gen/ca.dc
@@ -15,6 +15,7 @@
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <sys/time.h>
+#include <strings.h>
 EXEC SQL INCLUDE sqlca;
 
 extern int errno;
@@ -32,7 +33,7 @@ int argc;
 char **argv;
 {
     FILE *out = stdout;
-    char *outf = NULL, outft[64];
+    char *outf = NULL, outft[64], *p, last[256];
     struct stat sb;
     struct save_queue *sq;
     struct prec *prec;
@@ -42,6 +43,8 @@ char **argv;
     int id;
     EXEC SQL END DECLARE SECTION;
 
+    initialize_sms_error_table ();
+
 #ifsql INGRES
     EXEC SQL CONNECT sms;
 #endsql
@@ -124,17 +127,16 @@ char **argv;
       SELECT DISTINCT u.login, u.fullname, f.name
       FROM users u, filesys f
        WHERE f.label = u.login and u.status = 1 and f.type = "AFS"
-       ORDER BY login;
+       ORDER BY name;
     EXEC SQL OPEN z;
-    first = 0;
     while (1) {
        EXEC SQL FETCH z INTO :login, :name, :dir;
        if (sqlca.sqlcode != 0) break;
-       if (strncmp(dir, "/afs/athena", 11)) break;
-       if (first != login[0]) {
-           first = login[0];
-           fprintf(out, "*%s:%s%c\n", "AFS", "/afs/athena.mit.edu/user/",
-                   first);
+       p = rindex(dir, '/');
+       if (p) *p = 0;
+       if (strcmp(last, dir)) {
+           strcpy(last, dir);
+           fprintf(out, "*%s:%s\n", "AFS", dir);
        }
        strtrim(login);
        strtrim(name);
@@ -159,6 +161,10 @@ char **argv;
 
  sqlerr:
     com_err(whoami, MR_INGRES_ERR, " code %d\n", sqlca.sqlcode);
+#ifsql INGRES
+    if (sqlca.sqlcode == 17700)
+      exit(MR_DEADLOCK);
+#endsql
     critical_alert("DCM", "Central America build encountered INGRES ERROR %d",
                   sqlca.sqlcode);
     exit(MR_INGRES_ERR);
This page took 0.03286 seconds and 4 git commands to generate.