view uip/ali.c @ 16:07f8972434be

fix for Yosemita Clang
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 12 Nov 2014 02:46:27 +0900
parents 441a2190cfae
children
line wrap: on
line source

/* ali.c - the new ali */
#ifndef	lint
static char ident[] = "@(#)$Id: ali.c,v 1.1.1.1 2005/04/18 14:46:07 kono Exp $";
#endif	/* lint */

#include "../h/mh.h"
#include "../h/addrsbr.h"
#include "../h/aliasbr.h"
#include <stdio.h>
#ifdef LOCALE
#include	<locale.h>
#endif


#define	NVEC	50		/* maximum number of names */

/*  */

static struct swit switches[] = {
#define	ALIASW	0
    "alias aliasfile", 0,
#define	NALIASW	1
    "noalias", -7,

#define	LISTSW	2
    "list", 0,
#define	NLISTSW	3
    "nolist", 0,

#define	NORMSW	4
    "normalize", 0,
#define	NNORMSW	5
    "nonormalize", 0,

#define	USERSW	6
    "user", 0,
#define	NUSERSW	7
    "nouser", 0,

#define	HELPSW	8
    "help", 4,

    NULL, 0
};

/*  */

static	int     pos = 1;

extern struct aka  *akahead;

static void print_aka ( register char  *p, int     list, margin);

/*  */

/* ARGSUSED */

main (argc, argv)
int     argc;
char   *argv[];
{
    int     i,
            vecp = 0,
	    inverted = 0,
            list = 0,
	    noalias = 0,
	    normalize = AD_NHST;
    char   *cp,
          **ap,
          **argp,
            buf[100],
           *vec[NVEC],
           *arguments[MAXARGS];
    struct aka *ak;

#ifdef LOCALE
	setlocale(LC_ALL, "");
#endif
#ifdef JAPAN
	ml_init();
#endif /* JAPAN */
    invo_name = r1bindex (argv[0], '/');
    mts_init (invo_name);
    if ((cp = m_find (invo_name)) != NULL) {
	ap = brkstring (cp = getcpy (cp), " ", "\n");
	ap = copyip (ap, arguments);
    }
    else
	ap = arguments;
    (void) copyip (argv + 1, ap);
    argp = arguments;

/*  */

    while (cp = *argp++) {
	if (*cp == '-')
	    switch (smatch (++cp, switches)) {
		case AMBIGSW: 
		    ambigsw (cp, switches);
		    done (1);
		case UNKWNSW: 
		    adios (NULLCP, "-%s unknown", cp);
		case HELPSW: 
		    (void) sprintf (buf, "%s [switches] aliases ...",
			    invo_name);
		    help (buf, switches);
		    done (1);

		case ALIASW: 
		    if (!(cp = *argp++) || *cp == '-')
			adios (NULLCP, "missing argument to %s", argp[-2]);
		    if ((i = alias (cp)) != AK_OK)
			adios (NULLCP, "aliasing error in %s - %s",
				cp, akerror (i));
		    continue;
		case NALIASW: 
		    noalias++;
		    continue;

		case LISTSW: 
		    list++;
		    continue;
		case NLISTSW: 
		    list = 0;
		    continue;

		case NORMSW: 
		    normalize = AD_HOST;
		    continue;
		case NNORMSW: 
		    normalize = AD_NHST;
		    continue;

		case USERSW: 
		    inverted++;
		    continue;
		case NUSERSW: 
		    inverted = 0;
		    continue;
	    }
	vec[vecp++] = cp;
    }

    if (!noalias) {
	if (cp = m_find ("Aliasfile")) { /* allow Aliasfile: profile entry */
	    char *dp = NULL;

	    for (ap = brkstring(dp = getcpy(cp), " ", "\n"); ap && *ap; ap++)
		if ((i = alias (*ap)) != AK_OK)
		    adios (NULLCP,
			    "aliasing error in %s - %s", *ap, akerror (i));
	    if (dp)
		free(dp);
	}
	(void) alias (AliasFile);
    }
	

/*  */

    if (vecp)
	for (i = 0; i < vecp; i++)
	    if (inverted)
		print_usr (vec[i], list, normalize);
	    else
		print_aka (akvalue (vec[i]), list, 0);
    else {
	if (inverted)
	    adios (NULLCP,
		    "usage: %s -user addresses ...  (you forgot the addresses)",
		invo_name);

	for (ak = akahead; ak; ak = ak -> ak_next) {
	    printf ("%s: ", ak -> ak_name);
	    pos += strlen (ak -> ak_name) + 1;
	    print_aka (akresult (ak), list, pos);
	}
    }

    done (0);
}

/*  */

void
print_aka (p, list, margin)
register char  *p;
int     list,
        margin;
{
    register char   c;
#ifdef JAPAN
    char *pp;
#endif

    if (p == NULL) {
	printf ("<empty>\n");
	return;
    }

    while ((c = *p++))
	switch (c) {
	    case ',': 
		if (*p)
		    if (list)
			printf ("\n%*s", margin, "");
		    else
			if (pos >= 68) {
			    printf (",\n ");
			    pos = 2;
			}
			else {
			    printf (", ");
			    pos += 2;
			}

	    case 0: 
		break;

	    default: 
#ifdef JAPAN
		if ((pp = index(p, ','))) {
		    *pp = '\0';
		    ml_fputs(p-1, stdout);
		    *pp = ',';
		    pos += pp - p + 1;
		    p = pp;
		} else {
		    ml_fputs(p-1, stdout);
		    pos += strlen(p) + 1;
		    p += strlen(p);
		}
#else
		pos++;
		(void) putchar (c);
#endif
	}

    (void) putchar ('\n');
    pos = 1;
}

/*  */

print_usr (s, list, norm)
register char  *s;
int     list,
        norm;
{
    register char  *cp,
                   *pp,
                   *vp;
    register struct aka *ak;
    register struct mailname   *mp,
                               *np;

    if ((pp = getname (s)) == NULL)
	adios (NULLCP, "no address in \"%s\"", s);
    if ((mp = getm (pp, NULLCP, 0, norm, NULLCP)) == NULL)
	adios (NULLCP, "bad address \"%s\"", s);
    while (getname (""))
	continue;

    vp = NULL;
    for (ak = akahead; ak; ak = ak -> ak_next) {
	pp = akresult (ak);
	while (cp = getname (pp)) {
	    if ((np = getm (cp, NULLCP, 0, norm, NULLCP)) == NULL)
		continue;
	    if (uleq (mp -> m_host, np -> m_host)
		    && uleq (mp -> m_mbox, np -> m_mbox)) {
		vp = vp ? add (ak -> ak_name, add (",", vp))
		    : getcpy (ak -> ak_name);
		mnfree (np);
		while (getname (""))
		    continue;
		break;
	    }
	    mnfree (np);
	}
    }
    mnfree (mp);

#ifdef	notdef
    printf ("%s: ", s);
    print_aka (vp ? vp : s, list, pos += strlen (s) + 1);
#else
    print_aka (vp ? vp : s, list, 0);
#endif
    if (vp)
	free (vp);
}