1 /*        $NetBSD: tok822_find.c,v 1.1.1.1 2009/06/23 10:08:48 tron Exp $       */
2 
3 /*++
4 /* NAME
5 /*        tok822_find 3
6 /* SUMMARY
7 /*        token list search operators
8 /* SYNOPSIS
9 /*        #include <tok822.h>
10 /*
11 /*        TOK822    *tok822_find_type(head, type)
12 /*        TOK822    *head;
13 /*        int       type;
14 /*
15 /*        TOK822    *tok822_rfind_type(tail, type)
16 /*        TOK822    *tail;
17 /*        int       type;
18 /* DESCRIPTION
19 /*        This module implements token list search operations.
20 /*
21 /*        tok822_find_type() searches a list of tokens for the first
22 /*        instance of the specified token type. The result is the
23 /*        found token or a null pointer when the search failed.
24 /*
25 /*        tok822_rfind_type() searches a list of tokens in reverse direction
26 /*        for the first instance of the specified token type. The result
27 /*        is the found token or a null pointer when the search failed.
28 /* LICENSE
29 /* .ad
30 /* .fi
31 /*        The Secure Mailer license must be distributed with this software.
32 /* AUTHOR(S)
33 /*        Wietse Venema
34 /*        IBM T.J. Watson Research
35 /*        P.O. Box 704
36 /*        Yorktown Heights, NY 10598, USA
37 /*--*/
38 
39 /* System library. */
40 
41 #include <sys_defs.h>
42 
43 /* Utility library. */
44 
45 #include <vstring.h>
46 
47 /* Global library. */
48 
49 #include <tok822.h>
50 
51 /* tok822_find_type - find specific token type, forward search */
52 
tok822_find_type(TOK822 * head,int op)53 TOK822 *tok822_find_type(TOK822 *head, int op)
54 {
55     TOK822 *tp;
56 
57     for (tp = head; tp != 0 && tp->type != op; tp = tp->next)
58            /* void */ ;
59     return (tp);
60 }
61 
62 /* tok822_rfind_type - find specific token type, backward search */
63 
tok822_rfind_type(TOK822 * tail,int op)64 TOK822 *tok822_rfind_type(TOK822 *tail, int op)
65 {
66     TOK822 *tp;
67 
68     for (tp = tail; tp != 0 && tp->type != op; tp = tp->prev)
69            /* void */ ;
70     return (tp);
71 }
72