DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - metrics - download
Index: T i

⟦7889eae8c⟧ TextFile

    Length: 2741 (0xab5)
    Types: TextFile
    Names: »isoservent.c«

Derivation

└─⟦3d0c2be1b⟧ Bits:30001254 ISODE-5.0 Tape
    └─⟦eba4602b1⟧ »./isode-5.0.tar.Z« 
        └─⟦d3ac74d73⟧ 
            └─⟦this⟧ »isode-5.0/compat/isoservent.c« 

TextFile

/* isoservent.c - look-up ISODE services */

#ifndef	lint
static char *rcsid = "$Header: /f/osi/compat/RCS/isoservent.c,v 6.0 89/03/18 23:25:17 mrose Rel $";
#endif

/* 
 * $Header: /f/osi/compat/RCS/isoservent.c,v 6.0 89/03/18 23:25:17 mrose Rel $
 *
 *
 * $Log:	isoservent.c,v $
 * Revision 6.0  89/03/18  23:25:17  mrose
 * Release 5.0
 * 
 */

/*
 *				  NOTICE
 *
 *    Acquisition, use, and distribution of this module and related
 *    materials are subject to the restrictions of a license agreement.
 *    Consult the Preface in the User's Manual for the full terms of
 *    this agreement.
 *
 */


/* LINTLIBRARY */

#include <ctype.h>
#include <stdio.h>
#include "general.h"
#include "manifest.h"
#include "isoservent.h"
#include "tailor.h"

/* \f

   DATA */

static char *isoservices = "isoservices";

static FILE *servf = NULL;
static int  stayopen = 0;

static struct isoservent    iss;

/* \f

 */

int	setisoservent (f)
int	f;
{
    if (servf == NULL)
	servf = fopen (isodefile (isoservices), "r");
    else
	rewind (servf);
    stayopen |= f;

    return (servf != NULL);
}


int	endisoservent () {
    if (servf && !stayopen) {
	(void) fclose (servf);
	servf = NULL;
    }

    return 1;
}

/* \f

 */

struct isoservent  *getisoservent () {
    int	    mask,
	    vecp;
    register char  *cp;
    register struct isoservent *is = &iss;
    static char buffer[BUFSIZ + 1],
	        file[BUFSIZ];
    static char *vec[NVEC + NSLACK + 1];

    if (servf == NULL
	    && (servf = fopen (isodefile (isoservices), "r")) == NULL)
	return NULL;

    bzero ((char *) is, sizeof *is);

    while (fgets (buffer, sizeof buffer, servf) != NULL) {
	if (*buffer == '#')
	    continue;
	if (cp = index (buffer, '\n'))
	    *cp = NULL;
	if ((vecp = str2vecX (buffer, vec, 1 + 1, &mask, NULL)) < 3)
	    continue;

	if ((cp = index (vec[0], '/')) == NULL)
	    continue;
	*cp++ = NULL;

	is -> is_provider = vec[0];
	is -> is_entity = cp;
	is -> is_selectlen = str2sel (vec[1], (mask & (1 << 1)) ? 1 : 0,
				is -> is_selector, ISSIZE);

	is -> is_vec = vec + 2;
	is -> is_tail = vec + vecp;

	if (strncmp (cp = is -> is_vec[0], isodeconfig, isodeconlen) == 0)
	    (void) strcpy (is -> is_vec[0] = file,
			   isodefile (cp + isodeconlen));

	return is;
    }

    return NULL;
}

/* \f

 */

#ifdef	DEBUG
_printsrv (is)
register struct isoservent *is;
{
    register int    n = is -> is_tail - is -> is_vec - 1;
    register char **ap = is -> is_vec;

    LLOG (addr_log, LLOG_DEBUG,
	  ("\tENT: \"%s\" PRV: \"%s\" SEL: %s",
	   is -> is_entity, is -> is_provider,
	   sel2str (is -> is_selector, is -> is_selectlen, 1)));

    for (; n >= 0; ap++, n--)
	LLOG (addr_log, LLOG_DEBUG,
	      ("\t\t%d: \"%s\"\n", ap - is -> is_vec, *ap));
}
#endif