| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 | %{/*	This file is part of the software similarity tester SIM.	Written by Dick Grune, Vrije Universiteit, Amsterdam.	$Id: lisplang.l,v 2.9 2007/08/29 09:10:33 dick Exp $*//*	LISP language front end for the similarity tester.	Author:	Gertjan Akkerman <[email protected]>	Date:	Thu, 9 Apr 87 11:15:23 MDT*/#include	"language.h"#include	"token.h"#include	"lex.h"#include	"lang.h"/* Language-dependent Code */#include	"idf.h"static const struct idf reserved[] = {	{"append",	NORM('a')},	{"append1",	NORM('b')},	{"atom",	NORM('t')},	{"car",		NORM('h')},	{"cdr",		NORM('t')},	{"cond",	NORM('c')},	{"cons",	NORM('s')},	{"defun",	NORM('u')},	{"do",		NORM('d')},	{"eq",		NORM('e')},	{"equal",	NORM('e')},		/* See eq */	{"for",		NORM('f')},	{"if",		NORM('i')},	{"list",	NORM('l')},	{"nconc",	NORM('n')},	{"rplaca",	NORM('A')},	{"rplacd",	NORM('D')}};/* Token sets for module algollike */const TOKEN NonFinals[] = {	NORM('('),	NORM('['),	NOTOKEN};const TOKEN NonInitials[] = {	NORM(')'),	NORM(']'),	NOTOKEN};const TOKEN Openers[] = {	NORM('('),	NORM('['),	NOTOKEN};const TOKEN Closers[] = {	NORM(')'),	NORM(']'),	NOTOKEN};%}%option nounput%option never-interactive%Start	CommentLayout		([ \t\r\f])ASCII95		([- !"#$%&'()*+,./0-9:;<=>?@A-Z\[\\\]^_`a-z{|}~])AnyQuoted	(\\.)StrChar		([^"\n\\]|{AnyQuoted})ChrChar		([^'\\]|{AnyQuoted})IdfChar		([-!#$%&*+,/0-9:;<=>?@A-Z\\^_`a-z{}~])EscIdf		(({IdfChar}|\\.)+)QuotIdf		("|"[^\|\n]*"|")Idf		({EscIdf}|{QuotIdf})%%";".*$	{				/* comment */	}\"{StrChar}*\"	{			/* strings */		return_ch('"');	}{Idf}	{				/* identifier */		return_tk(idf_in_list(yytext, reserved, sizeof reserved, IDF));	}\n	{				/* count newlines */		return_eol();	}{Layout}	{			/* ignore layout */	}{ASCII95}	{			/* copy other text */		return_ch(yytext[0]);	}.	{				/* count non-ASCII chars */		lex_non_ascii_cnt++;	}%%/* Language-INdependent Code */voidyystart(void) {	BEGIN INITIAL;}intyywrap(void) {	return 1;}
 |