1 /*- 2 * Copyright (c) 1994-1995 S�ren Schmidt 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer, 10 * in this position and unchanged. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 3. The name of the author may not be used to endorse or promote products 15 * derived from this software withough specific prior written permission 16 * 17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 * 28 * $Id$ 29 */ 30 31 %{ 32 33 #include "lex.h" 34 35 %} 36 37 D [0-9] 38 X [0-9a-fA-F] 39 A . 40 L [OCNB] 41 42 %% 43 44 nop { return TNOP; } 45 lshift { return TLSH; } 46 rshift { return TRSH; } 47 clock { return TCLK; } 48 nlock { return TNLK; } 49 slock { return TSLK; } 50 lalt|alt { return TLALT; } 51 btab { return TBTAB; } 52 lctrl|ctrl { return TLCTR; } 53 nscr { return TNEXT; } 54 rctrl { return TRCTR; } 55 ralt { return TRALT; } 56 alock { return TALK; } 57 ashift { return TASH; } 58 meta { return TMETA; } 59 boot { return TRBT; } 60 debug { return TDBG; } 61 susp { return TSUSP; } 62 63 NUL|nul { number = 0; return TNUM; } 64 SOH|soh { number = 1; return TNUM; } 65 STX|stx { number = 2; return TNUM; } 66 ETX|etx { number = 3; return TNUM; } 67 EOT|eot { number = 4; return TNUM; } 68 ENQ|enq { number = 5; return TNUM; } 69 ACK|ack { number = 6; return TNUM; } 70 BEL|bel { number = 7; return TNUM; } 71 BS|bs { number = 8; return TNUM; } 72 HT|ht { number = 9; return TNUM; } 73 LF|lf|NL|nl { number = 10; return TNUM; } 74 VT|vt { number = 11; return TNUM; } 75 FF|ff|NP|np { number = 12; return TNUM; } 76 CR|cr { number = 13; return TNUM; } 77 SO|so { number = 14; return TNUM; } 78 SI|si { number = 15; return TNUM; } 79 DLE|dle { number = 16; return TNUM; } 80 DC1|dc1 { number = 17; return TNUM; } 81 DC2|dc2 { number = 18; return TNUM; } 82 DC3|dc3 { number = 19; return TNUM; } 83 DC4|dc4 { number = 20; return TNUM; } 84 NAK|nak { number = 21; return TNUM; } 85 SYN|syn { number = 22; return TNUM; } 86 ETB|etb { number = 23; return TNUM; } 87 CAN|can { number = 24; return TNUM; } 88 EM|em { number = 25; return TNUM; } 89 SUB|sub { number = 26; return TNUM; } 90 ESC|esc { number = 27; return TNUM; } 91 FS|fs { number = 28; return TNUM; } 92 GS|gs { number = 29; return TNUM; } 93 RS|rs { number = 30; return TNUM; } 94 NS|ns { number = 31; return TNUM; } 95 SP|sp { number = 32; return TNUM; } 96 DEL|del { number = 127; return TNUM; } 97 98 fkey{D}({D}*) { 99 sscanf(yytext+4, "%d", &number); 100 return TFUNC; 101 } 102 scr{D}({D}*) { 103 sscanf(yytext+3, "%d", &number); 104 return TSCRN; 105 } 106 '{A}' { letter = *(yytext+1); return TLET; } 107 #({A}*) { /* ignore */ } 108 0x{X}({X}*) { sscanf(yytext, "%x", &number); return TNUM; } 109 {D}({D}*) { sscanf(yytext, "%d", &number); return TNUM; } 110 {L} { 111 if (*yytext == 'O') number = 0; 112 if (*yytext == 'C') number = 1; 113 if (*yytext == 'N') number = 2; 114 if (*yytext == 'B') number = 3; 115 return TFLAG; 116 } 117 [ \t\n] { /* ignore */ } 118