Annotation of freem/src/tp_check.c, revision 1.1

1.1     ! snw         1: /*
        !             2:  *                            *
        !             3:  *                           * *
        !             4:  *                          *   *
        !             5:  *                     ***************
        !             6:  *                      * *       * *
        !             7:  *                       *  MUMPS  *
        !             8:  *                      * *       * *
        !             9:  *                     ***************
        !            10:  *                          *   *
        !            11:  *                           * *
        !            12:  *                            *
        !            13:  *
        !            14:  *   tp_check.c
        !            15:  *    TP database checkpointing code
        !            16:  *
        !            17:  *  
        !            18:  *   Author: Serena Willis <jpw@coherent-logic.com>
        !            19:  *    Copyright (C) 1998 MUG Deutschland
        !            20:  *    Copyright (C) 2022 Coherent Logic Development LLC
        !            21:  *
        !            22:  *
        !            23:  *   This file is part of FreeM.
        !            24:  *
        !            25:  *   FreeM is free software: you can redistribute it and/or modify
        !            26:  *   it under the terms of the GNU Affero Public License as published by
        !            27:  *   the Free Software Foundation, either version 3 of the License, or
        !            28:  *   (at your option) any later version.
        !            29:  *
        !            30:  *   FreeM is distributed in the hope that it will be useful,
        !            31:  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            32:  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            33:  *   GNU Affero Public License for more details.
        !            34:  *
        !            35:  *   You should have received a copy of the GNU Affero Public License
        !            36:  *   along with FreeM.  If not, see <https://www.gnu.org/licenses/>.
        !            37:  *
        !            38:  **/
        !            39: 
        !            40: #include <stdlib.h>
        !            41: #include <string.h>
        !            42: #include <unistd.h>
        !            43: #include "tp_check.h"
        !            44: #include "mpsdef.h"
        !            45: #include "transact.h"
        !            46: #include "journal.h"
        !            47: #include "fs.h"
        !            48: 
        !            49: short frm_global_exists(char *, char *, char *);
        !            50: 
        !            51: cptab *cptab_head[TP_MAX_NEST];
        !            52: 
        !            53: cptab *cptab_insert(int tlevel, char *global)
        !            54: {
        !            55:     cptab *t;
        !            56:     char mode;
        !            57: 
        !            58:     short g_exists;
        !            59:     
        !            60:     char *gc_ns;
        !            61:     char *gc_pth;
        !            62:     
        !            63:     gc_ns = (char *) malloc (STRLEN * sizeof (char));
        !            64:     NULLPTRCHK(gc_ns,"cptab_insert");
        !            65: 
        !            66:     gc_pth = (char *) malloc (STRLEN * sizeof (char));
        !            67:     NULLPTRCHK(gc_pth,"cptab_insert");
        !            68: 
        !            69:     for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
        !            70: 
        !            71:         if ((strcmp (t->global, global) == 0) && (t->mode > CP_UNUSED)) {
        !            72:             /* found match */
        !            73:             return t;
        !            74:         }
        !            75: 
        !            76:     }
        !            77: 
        !            78:     /* insert */
        !            79:     t = (cptab *) malloc (sizeof (cptab));
        !            80:     NULLPTRCHK(t,"cptab_insert");
        !            81: 
        !            82:     t->global = (char *) malloc (sizeof (char) * (strlen (global) + 1));
        !            83:     NULLPTRCHK(t->global,"cptab_insert");
        !            84: 
        !            85:     strcpy (t->global, global);
        !            86: 
        !            87:     g_exists = frm_global_exists (gc_ns, gc_pth, global);
        !            88:     
        !            89:     t->file = (char *) malloc (sizeof (char) * (strlen (gc_pth)));
        !            90:     NULLPTRCHK(t->file,"cptab_insert");
        !            91: 
        !            92:     t->cp_file = (char *) malloc (sizeof (char) * STRLEN);
        !            93:     NULLPTRCHK(t->cp_file,"cptab_insert");
        !            94:     
        !            95:     strcpy (t->file, gc_pth);
        !            96:     stcnv_m2c (t->file);
        !            97:     
        !            98:     snprintf (t->cp_file, STRLEN - 1, "%s.%d.%d.chk", t->file, pid, tp_level);
        !            99: 
        !           100:     free (gc_ns);
        !           101:     free (gc_pth);
        !           102:     
        !           103:     if (!g_exists) {
        !           104:         t->mode = CP_REMOVE;
        !           105:     }
        !           106:     else {
        !           107:         t->mode = CP_RESTORE;
        !           108:     }
        !           109: 
        !           110:     t->next = cptab_head[tlevel];
        !           111:     cptab_head[tlevel] = t;
        !           112: 
        !           113:     return t;
        !           114: }
        !           115: 
        !           116: short cptab_precommit(int tlevel)
        !           117: {
        !           118:     cptab *t;
        !           119:     /*char *cmd;*/
        !           120:     char *pctmp;
        !           121:     int rc;
        !           122: 
        !           123:     /*
        !           124:     cmd = (char *) malloc (STRLEN * sizeof (char));
        !           125:     NULLPTRCHK(cmd,"cptab_precommit");
        !           126:     */
        !           127:     
        !           128:     pctmp = (char *) malloc (STRLEN * sizeof (char));
        !           129:     NULLPTRCHK(pctmp,"cptab_precommit");
        !           130:     
        !           131:     for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
        !           132:         
        !           133:         if (t->mode == CP_RESTORE) {
        !           134: 
        !           135:             /*
        !           136:             snprintf (cmd, STRLEN - 1, "/bin/cp %s %s", t->file, t->cp_file);
        !           137:             rc = system (cmd);
        !           138:             */
        !           139:             
        !           140:             rc = cp (t->cp_file, t->file);
        !           141:             
        !           142:             if (rc != 0) {
        !           143: 
        !           144:                 strcpy (pctmp, t->file);
        !           145:                 stcnv_c2m (pctmp);
        !           146:                 
        !           147:                 jnl_ent_write (JNLA_CHECKPOINT_FAIL, " \201", pctmp);
        !           148:                 
        !           149:                 /*free (cmd);*/
        !           150:                 free (pctmp);
        !           151: 
        !           152:                 return FALSE;
        !           153:                 
        !           154:             }
        !           155:             else {
        !           156: 
        !           157:                 strcpy (pctmp, t->file);
        !           158:                 stcnv_c2m (pctmp);
        !           159:                 
        !           160:                 jnl_ent_write (JNLA_CHECKPOINT_OK, " \201", pctmp);
        !           161: 
        !           162:             }
        !           163: 
        !           164:         }
        !           165:         
        !           166:     }
        !           167:     
        !           168:     /*free (cmd);*/
        !           169:     free (pctmp);
        !           170:     
        !           171:     return TRUE;    
        !           172: }
        !           173: 
        !           174: void cptab_postcommit(int tlevel)
        !           175: {
        !           176:     cptab *t;
        !           177:     /*char *cmd;*/
        !           178:     int rc;
        !           179: 
        !           180:     /*
        !           181:     cmd = (char *) malloc (STRLEN * sizeof (char));
        !           182:     NULLPTRCHK(cmd,"cptab_postcommit");
        !           183:     */
        !           184: 
        !           185:     for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
        !           186: 
        !           187:         if (t->mode == CP_RESTORE) {
        !           188:             /*
        !           189:             snprintf (cmd, STRLEN - 1, "/bin/rm -f '%s'", t->cp_file);
        !           190:             rc = system (cmd);
        !           191:             */
        !           192:             unlink (t->cp_file);
        !           193:         }
        !           194:         
        !           195:     }
        !           196: 
        !           197:     cptab_head[tlevel] = NULL;
        !           198: }
        !           199: 
        !           200: short cptab_rollback(int tlevel)
        !           201: {
        !           202:     cptab *t;
        !           203:     /*char *cmd;*/
        !           204:     int rc;
        !           205: 
        !           206:     /*
        !           207:     cmd = (char *) malloc (STRLEN * sizeof (char));
        !           208:     NULLPTRCHK(cmd,"cptab_rollback");
        !           209:     */
        !           210:     
        !           211:     for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
        !           212:         
        !           213:         switch (t->mode) {
        !           214: 
        !           215:             case CP_REMOVE:
        !           216:                 unlink (t->file);
        !           217:                 /*
        !           218:                 snprintf (cmd, STRLEN - 1, "/bin/rm -f '%s'", t->file);
        !           219:                 rc = system (cmd);
        !           220:                 */
        !           221:                 break;
        !           222: 
        !           223:             case CP_RESTORE:
        !           224:                 /*
        !           225:                 snprintf (cmd, STRLEN - 1, "/bin/cp '%s' '%s'", t->cp_file, t->file);
        !           226:                 rc = system (cmd);
        !           227:                 */
        !           228:                 rc = cp (t->file, t->cp_file);
        !           229:                 
        !           230:                 if (rc != 0) {
        !           231:                     cptab_head[tlevel] = NULL;
        !           232:                     /*free (cmd);*/
        !           233:                     return FALSE;
        !           234:                 }
        !           235: 
        !           236:                 /*
        !           237:                 snprintf (cmd, STRLEN - 1, "/bin/rm -f %s", t->cp_file);
        !           238:                 rc = system (cmd);
        !           239:                 */
        !           240: 
        !           241:                 unlink (t->cp_file);
        !           242:                 if (rc != 0) {
        !           243:                     cptab_head[tlevel] = NULL;
        !           244:                     /*free (cmd);*/
        !           245:                     return FALSE;
        !           246:                 }
        !           247: 
        !           248:                 break;
        !           249: 
        !           250:                 
        !           251:         }
        !           252: 
        !           253:     }
        !           254: 
        !           255:     cptab_head[tlevel] = NULL;
        !           256:     
        !           257:     return TRUE;
        !           258: 
        !           259: }
        !           260: 
        !           261: void cptab_dump(int tlevel)
        !           262: {
        !           263:     cptab *gt;
        !           264:     char cp_mode[15];
        !           265:     
        !           266:     printf ("\n  Global database checkpoints:\n");
        !           267: 
        !           268:     printf ("\n   %-30s%-20s%s\n", "GLOBAL", "MODE", "FILES");
        !           269:     printf ("   %-30s%-20s%s\n", "------", "----", "-----");
        !           270: 
        !           271:     for (gt = cptab_head[tlevel]; gt != NULL; gt = gt->next) {
        !           272: 
        !           273:         switch (gt->mode) {
        !           274: 
        !           275:             case CP_UNUSED:
        !           276:                 strcpy (cp_mode, "CP_UNUSED");
        !           277:                 break;
        !           278: 
        !           279:             case CP_REMOVE:
        !           280:                 strcpy (cp_mode, "CP_REMOVE");
        !           281:                 break;
        !           282: 
        !           283:             case CP_RESTORE:
        !           284:                 strcpy (cp_mode, "CP_RESTORE");
        !           285:                 break;
        !           286: 
        !           287:         }
        !           288: 
        !           289:         if (gt->mode > CP_UNUSED) {
        !           290:             printf ("   %-30s%-20sIN:   %s\n", gt->global, cp_mode, gt->file); 
        !           291:         }
        !           292:         else {
        !           293:             printf ("   N/A\n");
        !           294:         }
        !           295:         
        !           296:         if (gt->mode == CP_RESTORE) {
        !           297:             printf ("   %-30s%-20sOUT:  %s\n", "", "", gt->cp_file);
        !           298:         }
        !           299:         
        !           300:     }
        !           301: }
        !           302: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>