linux下编译yacc命令,Lex/Yacc的学习——《编译原理及实践》附录B tiny编译器源码在linux下编译实现...

首先,在网上下载tiny编译器源码。

解压后,发现里面文件全部为大写命名,需要编写脚本,将大写转换成小写。

脚本:

for i in *

do

mv $i `ls $i | tr [A-Z] [a-z]`

done

接着,修改makefile文件,内容为:

#

# makefile for TINY

# Borland C Version

# K. Louden 2/3/98

#

CC = gcc

CFLAGS =

OBJS = main.o util.o scan.o parse.o symtab.o analyze.o code.o cgen.o

all: tiny tm

tiny: $(OBJS)

$(CC) $(CFLAGS) -o $@ $(OBJS)

main.o: main.c globals.h util.h scan.h parse.h analyze.h cgen.h

$(CC) $(CFLAGS) -c main.c

util.o: util.c util.h globals.h

$(CC) $(CFLAGS) -c util.c

scan.o: scan.c scan.h util.h globals.h

$(CC) $(CFLAGS) -c scan.c

parse.o: parse.c parse.h scan.h globals.h util.h

$(CC) $(CFLAGS) -c parse.c

symtab.o: symtab.c symtab.h

$(CC) $(CFLAGS) -c symtab.c

analyze.o: analyze.c globals.h symtab.h analyze.h

$(CC) $(CFLAGS) -c analyze.c

code.o: code.c code.h globals.h

$(CC) $(CFLAGS) -c code.c

cgen.o: cgen.c globals.h symtab.h code.h cgen.h

$(CC) $(CFLAGS) -c cgen.c

clean:

rm -f tiny tm *.o

tm: tm.c

$(CC) $(CFLAGS) -o $@ tm.c

注意:当在网上粘帖到本地文件时,请注意TAB与空格的转换会导致makefile文件不符合格式,此时需要将$前的空格换成TAB。

然后进入终端,进入文件目录,输入命令 make

便会提示编译成功!生成tiny和tm可执行文件。运行tiny,需要指定输入文件,文件必须以.tny结尾。运行无错后,生成.tm文件。此时运行tm,将生成的.tm文件名作为参数,即可进入调试界面!

至此 成功!

备注:当把源文件放在windows下的dev c++中直接编译main.c时,会显示Linker error。原因是,没有建立工程,所以编译不能链接成功。解决方法是,建立工程。

当把源文件放在linux下直接用命令:gcc main.c -o main -ll时,会显示没有定义各种变量、函数,错误原因同上。需要用编译工程的方法进行编译,所以makefile文件如上所写

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值