root/usr/src/cmd/bnu/gtcfile.c
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License, Version 1.0 only
 * (the "License").  You may not use this file except in compliance
 * with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */
/*      Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/*        All Rights Reserved   */


#ident  "%Z%%M% %I%     %E% SMI"        /* from SVR4 bnu:gtcfile.c 2.5 */

#include "uucp.h"

#define NCSAVE  30      /* no more than 30 saved C files, please */
static int ncsave;
static struct cs_struct csave[NCSAVE];
int Dfileused = FALSE;
static char jobid[NAMESIZE];

extern void wfcommit(), wfremove(), putdfiles();
extern int job_size(), fgrade(), retseq();

/*      commitall()
 *
 *      commit any and all saved C files
 *
 *      returns
 *              nothing
 */

void
commitall()
{
        char sys[NAMESIZE+5];
        char cmfile[NAMESIZE+5];
        int i;
        int n;

        for (i = 0; i < ncsave; i++) {
                if (Sgrades) {
                        if ((job_size(&csave[i]) == FAIL) ||
                            (fgrade(&csave[i]) == FAIL)) {
                                wfremove(csave[i].file);
                                continue;
                        }
                }
                else {
                        Dfileused = TRUE;
                        csave[i].grade = Grade;
                }

                /* make new file name for for the job */

                if (Sgrades) {
                        n = retseq(csave[i].sys);
                        (void) sprintf(cmfile, "%c.%.*s%c%.4x", *csave[i].file,
                                SYSNSIZE, csave[i].sys, csave[i].grade, n);
                }
                else
                        (void) strncpy(cmfile, csave[i].file, NAMESIZE-1);
                cmfile[NAMESIZE-1] = '\0';

                DEBUG(9, "User job queued to %c queue\n", csave[i].grade);
                (void) sprintf(sys, "/%c", csave[i].grade);
                (void) strcat(csave[i].sys, sys);
                if (Dfileused) {
                        putdfiles(csave[i]);
                        Dfileused = FALSE;
                }
                wfcommit(csave[i].file, cmfile, csave[i].sys);
                (void) strncpy(csave[i].file, cmfile, NAMESIZE);
        }

        ncsave = 0;

        /* set real jobid */

        (void) strncpy(jobid, BASENAME(csave[0].file, '.'), NAMESIZE);
        return;
}

/*
 *      gtcfile - copy into file the name of the saved C file for system sys
 *
 *      returns
 *              SUCCESS -> found one
 *              FAIL    -> none saved
 *
 */

int
gtcfile(file, sys)
char    *file, *sys;
{
        register int    i;

        for (i = 0; i < ncsave; i++)
                if (strncmp(sys, csave[i].sys, SYSNSIZE) == SAME) {
                        (void) strncpy(file, csave[i].file, NAMESIZE-1);
                        return(SUCCESS);
                }

        return(FAIL);
}

/*
 *      jid - returns the real job id of this uucp file transfer
 *
 *      returns
 *              jobid
 *
 */

char *
jid()
{
        return(jobid);
}

/*
 *      svcfile  - save the name of a C. file for system sys for re-using
 *      returns
 *              none
 */

void
svcfile(file, sys, grd)
char    *file, *sys, *grd;
{
        ASSERT(ncsave < NCSAVE, "TOO MANY SAVED C FILES", "", ncsave);
        (void) strncpy(csave[ncsave].file, BASENAME(file, '/'), NAMESIZE-1);
        (void) strncpy(csave[ncsave].sys, sys, NAMESIZE-1);
        (void) strncpy (csave[ncsave].sgrade, grd, NAMESIZE-1);
        ncsave++;
        return;
}

void
wfabort()
{
        register int    i;

        for (i = 0; i < ncsave; i++)
                wfremove(csave[i].file);
        ncsave = 0;
        return;
}

/*
 *      wfcommit - move wfile1 in current directory to SPOOL/sys/dir/wfile2
 *      return
 *              none
 */

void
wfcommit(wfile1, wfile2, sys)
char    *wfile1, *wfile2, *sys;
{
        char    cmitfile[MAXFULLNAME];
        char    remote[NAMESIZE];
        char    *fileBase;
        char    *p;

        /* make remote directory if it does not exist */

        (void) strncpy(remote, sys, NAMESIZE);
        if ((p = strchr(remote, '/')) != NULL) {
                *p++ = '\0';

                DEBUG(6, "create remote spool area %s\n", remote);
                mkremdir(remote);
        }

        if (p != NULL)
                DEBUG(6, "create service grade directory %s under remote spool\n", p);
        else
                DEBUG(6, "create remote spool area %s\n", sys);

        mkremdir(sys);

        DEBUG(6, "commit %s ", wfile1);

        fileBase = BASENAME(wfile2, '/');
        sprintf(cmitfile, "%s/%s", RemSpool, fileBase);
        DEBUG(6, "to %s\n", cmitfile);

        ASSERT(access(cmitfile, 0) != 0, Fl_EXISTS, cmitfile, 0);
        ASSERT(xmv(wfile1, cmitfile) == 0, Ct_LINK, cmitfile, errno);
        return;
}