Turns out that the compiler needs access to the libpc headers too; refactor
into a separate target to avoid build loops and make it work.
This commit is contained in:
		
							parent
							
								
									11854f4dfe
								
							
						
					
					
						commit
						698613cd7d
					
				
					 11 changed files with 41 additions and 266 deletions
				
			
		|  | @ -111,6 +111,7 @@ cprogram { | ||||||
| 		"+scope_h", | 		"+scope_h", | ||||||
| 		"+type_h", | 		"+type_h", | ||||||
| 		"h+emheaders", | 		"h+emheaders", | ||||||
|  | 		"lang/pc/include+headers", | ||||||
| 		"modules+headers", | 		"modules+headers", | ||||||
| 		"modules/src/alloc+lib", | 		"modules/src/alloc+lib", | ||||||
| 		"modules/src/em_code+lib_k", | 		"modules/src/em_code+lib_k", | ||||||
|  |  | ||||||
|  | @ -1,65 +0,0 @@ | ||||||
| # $Id$ |  | ||||||
| 
 |  | ||||||
| # C compilation part. Not to be called directly. |  | ||||||
| # Instead, it is to be called by the Makefile. |  | ||||||
| # SRC_DIR, UTIL_HOME, TARGET_HOME, CC, COPTIONS, LINT, LINTOPTIONS, LDOPTIONS, |  | ||||||
| # CC_AND_MKDEP, SUF, LIBSUF should be set here. |  | ||||||
| 
 |  | ||||||
| #PARAMS		do not remove this line! |  | ||||||
| 
 |  | ||||||
| # PRODUCE is either e (readable EM) or k (compact EM) |  | ||||||
| PRODUCE =	k |  | ||||||
| 
 |  | ||||||
| MDIR =		$(TARGET_HOME)/modules |  | ||||||
| LIBDIR =	$(MDIR)/lib |  | ||||||
| LINTLIBDIR =	$(UTIL_HOME)/modules/lib |  | ||||||
| 
 |  | ||||||
| MALLOC =	$(LIBDIR)/malloc.$(SUF) |  | ||||||
| 
 |  | ||||||
| EMLIB =		$(LIBDIR)/libem_mes.$(LIBSUF) \ |  | ||||||
| 		$(LIBDIR)/libem$(PRODUCE).$(LIBSUF) \ |  | ||||||
| 		$(TARGET_HOME)/lib.bin/em_data.$(LIBSUF) |  | ||||||
| 
 |  | ||||||
| MODLIB =	$(LIBDIR)/libinput.$(LIBSUF) \ |  | ||||||
| 		$(LIBDIR)/libassert.$(LIBSUF) \ |  | ||||||
| 		$(LIBDIR)/liballoc.$(LIBSUF) \ |  | ||||||
| 		$(MALLOC) \ |  | ||||||
| 		$(LIBDIR)/libflt.$(LIBSUF) \ |  | ||||||
| 		$(LIBDIR)/libprint.$(LIBSUF) \ |  | ||||||
| 		$(LIBDIR)/libstring.$(LIBSUF) \ |  | ||||||
| 		$(LIBDIR)/libsystem.$(LIBSUF) |  | ||||||
| 
 |  | ||||||
| LIBS =		$(EMLIB) $(MODLIB) |  | ||||||
| 
 |  | ||||||
| LINTLIBS =	$(LINTLIBDIR)/$(LINTPREF)em_mes.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)emk.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)input.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)assert.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)alloc.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)flt.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)print.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)string.$(LINTSUF) \ |  | ||||||
| 		$(LINTLIBDIR)/$(LINTPREF)system.$(LINTSUF) |  | ||||||
| 
 |  | ||||||
| PROFILE = |  | ||||||
| INCLUDES =	-I. -I$(SRC_DIR) -I$(TARGET_HOME)/modules/h -I$(TARGET_HOME)/h -I$(TARGET_HOME)/modules/pkg |  | ||||||
| CFLAGS =	$(PROFILE) $(INCLUDES) $(COPTIONS) -DSTATIC=static |  | ||||||
| LINTFLAGS =	$(INCLUDES) $(LINTOPTIONS) -DNORCSID -DSTATIC=static |  | ||||||
| LDFLAGS =	$(PROFILE) $(LDOPTIONS) |  | ||||||
| 
 |  | ||||||
| # C_SRC and OBJ should be set here. |  | ||||||
| #LISTS		do not remove this line! |  | ||||||
| 
 |  | ||||||
| all:		main |  | ||||||
| 
 |  | ||||||
| clean: |  | ||||||
| 		rm -f *.$(SUF) main |  | ||||||
| 
 |  | ||||||
| lint: |  | ||||||
| 		$(LINT) $(LINTFLAGS) $(C_SRC) $(LINTLIBS) |  | ||||||
| 
 |  | ||||||
| main:		$(OBJ) |  | ||||||
| 		$(CC) $(LDFLAGS) $(OBJ) $(LIBS) -o main |  | ||||||
| 
 |  | ||||||
| # do not remove the next line; it is used for generating dependencies |  | ||||||
| #DEPENDENCIES |  | ||||||
|  | @ -1,154 +0,0 @@ | ||||||
| # $Id$ |  | ||||||
| 
 |  | ||||||
| # make Pascal compiler |  | ||||||
| 
 |  | ||||||
| #PARAMS		do not remove this line! |  | ||||||
| 
 |  | ||||||
| UTIL_BIN = \ |  | ||||||
| 	$(UTIL_HOME)/bin |  | ||||||
| SRC_DIR = \ |  | ||||||
| 	$(SRC_HOME)/lang/pc/comp |  | ||||||
| 
 |  | ||||||
| TABGEN=	$(UTIL_BIN)/tabgen |  | ||||||
| LLGEN =	$(UTIL_BIN)/LLgen |  | ||||||
| LLGENOPTIONS = \ |  | ||||||
| 	-v |  | ||||||
| 
 |  | ||||||
| SRC_G =	$(SRC_DIR)/program.g $(SRC_DIR)/declar.g \ |  | ||||||
| 	$(SRC_DIR)/expression.g $(SRC_DIR)/statement.g |  | ||||||
| GEN_G =	tokenfile.g |  | ||||||
| GFILES=	$(GEN_G) $(SRC_G) |  | ||||||
| 
 |  | ||||||
| SRC_C =	$(SRC_DIR)/LLlex.c $(SRC_DIR)/LLmessage.c $(SRC_DIR)/body.c \ |  | ||||||
| 	$(SRC_DIR)/error.c $(SRC_DIR)/label.c $(SRC_DIR)/readwrite.c \ |  | ||||||
| 	$(SRC_DIR)/main.c $(SRC_DIR)/tokenname.c $(SRC_DIR)/idf.c \ |  | ||||||
| 	$(SRC_DIR)/input.c $(SRC_DIR)/type.c $(SRC_DIR)/def.c \ |  | ||||||
| 	$(SRC_DIR)/misc.c $(SRC_DIR)/enter.c $(SRC_DIR)/progs.c \ |  | ||||||
| 	$(SRC_DIR)/typequiv.c $(SRC_DIR)/node.c $(SRC_DIR)/cstoper.c \ |  | ||||||
| 	$(SRC_DIR)/chk_expr.c $(SRC_DIR)/options.c $(SRC_DIR)/scope.c \ |  | ||||||
| 	$(SRC_DIR)/desig.c $(SRC_DIR)/code.c $(SRC_DIR)/lookup.c \ |  | ||||||
| 	$(SRC_DIR)/stab.c |  | ||||||
| GEN_C =	tokenfile.c program.c declar.c expression.c statement.c \ |  | ||||||
| 	symbol2str.c char.c Lpars.c casestat.c tmpvar.c next.c |  | ||||||
| CFILES=	$(SRC_C) $(GEN_C) |  | ||||||
| 
 |  | ||||||
| SRC_H =	$(SRC_DIR)/LLlex.h $(SRC_DIR)/chk_expr.h $(SRC_DIR)/class.h \ |  | ||||||
| 	$(SRC_DIR)/const.h $(SRC_DIR)/debug.h $(SRC_DIR)/f_info.h \ |  | ||||||
| 	$(SRC_DIR)/idf.h $(SRC_DIR)/input.h $(SRC_DIR)/main.h \ |  | ||||||
| 	$(SRC_DIR)/misc.h $(SRC_DIR)/required.h $(SRC_DIR)/tokenname.h |  | ||||||
| 
 |  | ||||||
| GEN_H =	errout.h idfsize.h numsize.h strsize.h target_sizes.h \ |  | ||||||
| 	inputtype.h density.h nocross.h def.h debugcst.h \ |  | ||||||
| 	type.h Lpars.h node.h dbsymtab.h scope.h desig.h |  | ||||||
| 
 |  | ||||||
| HFILES=	$(GEN_H) $(SRC_H) |  | ||||||
| 
 |  | ||||||
| NEXTFILES = \ |  | ||||||
| 	$(SRC_DIR)/def.H $(SRC_DIR)/type.H $(SRC_DIR)/node.H \ |  | ||||||
| 	$(SRC_DIR)/scope.H $(SRC_DIR)/desig.H \ |  | ||||||
| 	$(SRC_DIR)/tmpvar.C $(SRC_DIR)/casestat.C |  | ||||||
| 
 |  | ||||||
| all:		make.main |  | ||||||
| 		make -f make.main main |  | ||||||
| 
 |  | ||||||
| install:	all |  | ||||||
| 		cp main $(TARGET_HOME)/lib.bin/em_pc |  | ||||||
| 
 |  | ||||||
| cmp:		all |  | ||||||
| 		-cmp main $(TARGET_HOME)/lib.bin/em_pc |  | ||||||
| 
 |  | ||||||
| opr: |  | ||||||
| 		make pr | opr |  | ||||||
| 
 |  | ||||||
| pr: |  | ||||||
| 		@pr $(SRC_DIR)/proto.make $(SRC_DIR)/proto.main Parameters \ |  | ||||||
| 			$(SRC_DIR)/char.tab $(SRC_G) $(SRC_H) $(NEXTFILES) $(SRC_C) |  | ||||||
| 
 |  | ||||||
| lint:		make.main |  | ||||||
| 		make -f make.main lint |  | ||||||
| 
 |  | ||||||
| Cfiles:		hfiles LLfiles $(GEN_C) $(GEN_H) Makefile |  | ||||||
| 		echo $(CFILES) | tr ' ' '\012' > Cfiles |  | ||||||
| 		echo $(HFILES) | tr ' ' '\012' >> Cfiles |  | ||||||
| 
 |  | ||||||
| resolved:	Cfiles |  | ||||||
| 		CC="$(CC)" UTIL_HOME="$(UTIL_HOME)" do_resolve `cat Cfiles` > Cfiles.new |  | ||||||
| 		-if cmp -s Cfiles Cfiles.new ; then rm -f Cfiles.new ; else mv Cfiles.new Cfiles ; fi |  | ||||||
| 		touch resolved |  | ||||||
| 
 |  | ||||||
| # there is no file called "dependencies"; we want dependencies checked  |  | ||||||
| # every time. This means that make.main is made every time. Oh well ... |  | ||||||
| # it does not take much time. |  | ||||||
| dependencies:	resolved |  | ||||||
| 		do_deps `grep '.c$$' Cfiles` |  | ||||||
| 
 |  | ||||||
| make.main:	dependencies make_macros lists $(SRC_DIR)/proto.main |  | ||||||
| 		rm_deps $(SRC_DIR)/proto.main | sed -e '/^.PARAMS/r make_macros' -e '/^.LISTS/r lists' > make.main |  | ||||||
| 		cat *.dep >> make.main |  | ||||||
| 
 |  | ||||||
| make_macros:    Makefile |  | ||||||
| 		echo 'SRC_DIR=$(SRC_DIR)' > make_macros |  | ||||||
| 		echo 'UTIL_HOME=$(UTIL_HOME)' >> make_macros |  | ||||||
| 		echo 'TARGET_HOME=$(TARGET_HOME)' >> make_macros |  | ||||||
| 		echo 'CC=$(CC)' >> make_macros |  | ||||||
| 		echo 'COPTIONS=$(COPTIONS)' >> make_macros |  | ||||||
| 		echo 'LDOPTIONS=$(LDOPTIONS)' >> make_macros |  | ||||||
| 		echo 'LINT=$(LINT)' >> make_macros |  | ||||||
| 		echo 'LINTSUF=$(LINTSUF)' >> make_macros |  | ||||||
| 		echo 'LINTPREF=$(LINTPREF)' >> make_macros |  | ||||||
| 		echo 'LINTOPTIONS=$(LINTOPTIONS)' >> make_macros |  | ||||||
| 		echo 'SUF=$(SUF)' >> make_macros |  | ||||||
| 		echo 'LIBSUF=$(LIBSUF)' >> make_macros |  | ||||||
| 		echo 'CC_AND_MKDEP=$(CC_AND_MKDEP)' >> make_macros |  | ||||||
| 
 |  | ||||||
| lists:		Cfiles |  | ||||||
| 		echo "C_SRC = \\" > lists |  | ||||||
| 		echo $(CFILES) >> lists |  | ||||||
| 		echo "OBJ = \\" >> lists |  | ||||||
| 		echo $(CFILES) | sed -e 's|[^ ]*/||g' -e 's/\.c/.$$(SUF)/g' >> lists |  | ||||||
| 
 |  | ||||||
| clean: |  | ||||||
| 		-make -f make.main clean |  | ||||||
| 		rm -f $(GEN_C) $(GEN_G) $(GEN_H) hfiles LLfiles Cfiles LL.output |  | ||||||
| 		rm -f resolved *.dep lists make.main make_macros |  | ||||||
| 
 |  | ||||||
| LLfiles:	$(GFILES) |  | ||||||
| 		$(LLGEN) $(LLGENOPTIONS) $(GFILES) |  | ||||||
| 		@touch LLfiles |  | ||||||
| 
 |  | ||||||
| hfiles:		Parameters $(SRC_DIR)/make.hfiles |  | ||||||
| 		$(SRC_DIR)/make.hfiles Parameters |  | ||||||
| 		touch hfiles |  | ||||||
| 
 |  | ||||||
| tokenfile.g:	$(SRC_DIR)/tokenname.c $(SRC_DIR)/make.tokfile |  | ||||||
| 		$(SRC_DIR)/make.tokfile <$(SRC_DIR)/tokenname.c >tokenfile.g |  | ||||||
| 
 |  | ||||||
| symbol2str.c:	$(SRC_DIR)/tokenname.c $(SRC_DIR)/make.tokcase |  | ||||||
| 		$(SRC_DIR)/make.tokcase <$(SRC_DIR)/tokenname.c >symbol2str.c |  | ||||||
| 
 |  | ||||||
| def.h:		$(SRC_DIR)/make.allocd $(SRC_DIR)/def.H |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/def.H > def.h |  | ||||||
| 
 |  | ||||||
| type.h:		$(SRC_DIR)/make.allocd $(SRC_DIR)/type.H |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/type.H > type.h |  | ||||||
| 
 |  | ||||||
| scope.h:	$(SRC_DIR)/make.allocd $(SRC_DIR)/scope.H |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/scope.H > scope.h |  | ||||||
| 
 |  | ||||||
| node.h:		$(SRC_DIR)/make.allocd $(SRC_DIR)/node.H |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/node.H > node.h |  | ||||||
| 
 |  | ||||||
| desig.h:	$(SRC_DIR)/make.allocd $(SRC_DIR)/desig.H |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/desig.H > desig.h |  | ||||||
| 
 |  | ||||||
| tmpvar.c:	$(SRC_DIR)/make.allocd $(SRC_DIR)/tmpvar.C |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/tmpvar.C > tmpvar.c |  | ||||||
| 
 |  | ||||||
| casestat.c:	$(SRC_DIR)/make.allocd $(SRC_DIR)/casestat.C |  | ||||||
| 		$(SRC_DIR)/make.allocd < $(SRC_DIR)/casestat.C > casestat.c |  | ||||||
| 
 |  | ||||||
| next.c:		$(NEXTFILES) $(SRC_DIR)/make.next |  | ||||||
| 		$(SRC_DIR)/make.next $(NEXTFILES) > next.c |  | ||||||
| 
 |  | ||||||
| char.c:		$(SRC_DIR)/char.tab |  | ||||||
| 		$(TABGEN) -f$(SRC_DIR)/char.tab >char.c |  | ||||||
							
								
								
									
										4
									
								
								lang/pc/include/build.lua
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								lang/pc/include/build.lua
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | ||||||
|  | clibrary { | ||||||
|  | 	name = "headers", | ||||||
|  | 	hdrs = {"./*.h"} | ||||||
|  | } | ||||||
|  | @ -36,32 +36,35 @@ extern char *_fcvt(double value, int ndigit, int *decpt, int *sign); | ||||||
| extern char *_wdw(struct file *f); | extern char *_wdw(struct file *f); | ||||||
| extern char *argv(int i); | extern char *argv(int i); | ||||||
| extern char *strbuf(char *s); | extern char *strbuf(char *s); | ||||||
|  | extern char* _hol0(void); | ||||||
| extern double _abr(double r); | extern double _abr(double r); | ||||||
| extern double _atn(double x); | extern double _atn(double x); | ||||||
| extern double _cos(double x); | extern double _cos(double x); | ||||||
| extern double _exp(double x); | extern double _exp(double x); | ||||||
|  | extern double _fef(double fl, int* res); | ||||||
|  | extern double _fif(double f1, double f2, double* f3); | ||||||
| extern double _log(double x); | extern double _log(double x); | ||||||
| extern double _rdr(struct file *f); | extern double _rdr(struct file *f); | ||||||
| extern double _rnd(double r); | extern double _rnd(double r); | ||||||
| extern void _sig(void (*)(unsigned int)); |  | ||||||
| extern double _sin(double x); | extern double _sin(double x); | ||||||
| extern double _sqt(double x); | extern double _sqt(double x); | ||||||
| extern void _xcls(struct file *f); | extern int _abi(int i); | ||||||
|  | extern int _asz(struct descr *dp); | ||||||
|  | extern int _bcp(int sz, unsigned char *y, unsigned char *x); | ||||||
|  | extern int _dvi(unsigned int j, unsigned int i); | ||||||
|  | extern int _efl(struct file *f); | ||||||
|  | extern int _eln(struct file *f); | ||||||
|  | extern int _fstdig(struct file *f); | ||||||
|  | extern int _getint(struct file *f); | ||||||
|  | extern int _getsig(struct file *f); | ||||||
|  | extern int _mdi(int j, int i); | ||||||
|  | extern int _nxtdig(struct file *f); | ||||||
|  | extern int _rdc(struct file *f); | ||||||
|  | extern int _rdi(struct file *f); | ||||||
| extern int argc(void); | extern int argc(void); | ||||||
| extern void argshift(void); |  | ||||||
| extern void buff(struct file *f); |  | ||||||
| extern void diag(struct file *f); |  | ||||||
| extern void nobuff(struct file *f); |  | ||||||
| extern void notext(struct file *f); |  | ||||||
| extern void pclose(struct file *f); |  | ||||||
| extern void pcreat(struct file *f, char *s); |  | ||||||
| extern int perrno(void); | extern int perrno(void); | ||||||
| extern void popen(struct file *f, char *s); |  | ||||||
| extern void procentry(char *name); |  | ||||||
| extern void procexit(char *name); |  | ||||||
| extern int strfetch(char *s, int i); | extern int strfetch(char *s, int i); | ||||||
| extern int strlen(char *s); | extern int strlen(char *s); | ||||||
| extern void strstore(char *s, int i, int c); |  | ||||||
| extern int strtobuf(char *s, char *b, int l); | extern int strtobuf(char *s, char *b, int l); | ||||||
| extern int uread(int fd, char *b, int n); | extern int uread(int fd, char *b, int n); | ||||||
| extern int uwrite(int fd, char *b, int n); | extern int uwrite(int fd, char *b, int n); | ||||||
|  | @ -70,41 +73,27 @@ extern long _dvil(unsigned long j, unsigned long i); | ||||||
| extern long _mdil(long j, long i); | extern long _mdil(long j, long i); | ||||||
| extern long _mdl(long j, long i); | extern long _mdl(long j, long i); | ||||||
| extern long _rdl(struct file *f); | extern long _rdl(struct file *f); | ||||||
| extern int _abi(int i); |  | ||||||
| extern void _ass(int line, int bool); | extern void _ass(int line, int bool); | ||||||
| extern int _asz(struct descr *dp); |  | ||||||
| extern int _bcp(int sz, unsigned char *y, unsigned char *x); |  | ||||||
| extern void _catch(unsigned erno); | extern void _catch(unsigned erno); | ||||||
| extern void _cls(struct file *f); | extern void _cls(struct file *f); | ||||||
| extern void _cre(int sz, struct file *f); | extern void _cre(int sz, struct file *f); | ||||||
| extern void _dis(int n, void **ptr); | extern void _dis(int n, void **ptr); | ||||||
| extern int _dvi(unsigned int j, unsigned int i); |  | ||||||
| extern int _efl(struct file *f); |  | ||||||
| extern int _eln(struct file *f); |  | ||||||
| extern double _fef(double fl, int* res); |  | ||||||
| extern double _fif(double f1, double f2, double* f3); |  | ||||||
| extern void _flush(struct file *f); | extern void _flush(struct file *f); | ||||||
| extern int _fstdig(struct file *f); |  | ||||||
| extern void _get(struct file *f); | extern void _get(struct file *f); | ||||||
| extern int _getint(struct file *f); |  | ||||||
| extern int _getsig(struct file *f); |  | ||||||
| extern void _hlt(int ecode); | extern void _hlt(int ecode); | ||||||
| extern void _incpt(struct file *f); | extern void _incpt(struct file *f); | ||||||
| extern void _ini(char *args, int c, struct file **p, char *mainlb); | extern void _ini(char *args, int c, struct file **p, char *mainlb); | ||||||
| extern int _mdi(int j, int i); |  | ||||||
| extern void _new(int n, void **ptr); | extern void _new(int n, void **ptr); | ||||||
| extern void _nfa(int bool); | extern void _nfa(int bool); | ||||||
| extern int _nxtdig(struct file *f); |  | ||||||
| extern void _opn(int sz, struct file *f); | extern void _opn(int sz, struct file *f); | ||||||
| extern void _outcpt(struct file *f); | extern void _outcpt(struct file *f); | ||||||
| extern void _pac(struct descr *ad, struct descr *zd, char *zp, int i, char *ap); | extern void _pac(struct descr *ad, struct descr *zd, char *zp, int i, char *ap); | ||||||
| extern void _pag(struct file *f); | extern void _pag(struct file *f); | ||||||
| extern void _put(struct file *f); | extern void _put(struct file *f); | ||||||
| extern void _rcka(struct array_descr *descr, int index); | extern void _rcka(struct array_descr *descr, int index); | ||||||
| extern int _rdc(struct file *f); |  | ||||||
| extern int _rdi(struct file *f); |  | ||||||
| extern void _rf(struct file *f); | extern void _rf(struct file *f); | ||||||
| extern void _rln(struct file *f); | extern void _rln(struct file *f); | ||||||
|  | extern void _sig(void (*)(unsigned int)); | ||||||
| extern void _skipsp(struct file *f); | extern void _skipsp(struct file *f); | ||||||
| extern void _trp(int trapno); | extern void _trp(int trapno); | ||||||
| extern void _unp(struct descr *ad, struct descr *zd, int i, char *ap, char *zp, int noext); | extern void _unp(struct descr *ad, struct descr *zd, int i, char *ap, char *zp, int noext); | ||||||
|  | @ -126,6 +115,17 @@ extern void _wsr(int w, double r, struct file *f); | ||||||
| extern void _wss(int w, int len, char* s, struct file* f); | extern void _wss(int w, int len, char* s, struct file* f); | ||||||
| extern void _wstrin(int width, int len, char* buf, struct file* f); | extern void _wstrin(int width, int len, char* buf, struct file* f); | ||||||
| extern void _wsz(int w, char* s, struct file* f); | extern void _wsz(int w, char* s, struct file* f); | ||||||
| extern char* _hol0(void); | extern void _xcls(struct file *f); | ||||||
|  | extern void argshift(void); | ||||||
|  | extern void buff(struct file *f); | ||||||
|  | extern void diag(struct file *f); | ||||||
|  | extern void nobuff(struct file *f); | ||||||
|  | extern void notext(struct file *f); | ||||||
|  | extern void pclose(struct file *f); | ||||||
|  | extern void pcreat(struct file *f, char *s); | ||||||
|  | extern void popen(struct file *f, char *s); | ||||||
|  | extern void procentry(char *name); | ||||||
|  | extern void procexit(char *name); | ||||||
|  | extern void strstore(char *s, int i, int c); | ||||||
| 
 | 
 | ||||||
| #endif  | #endif  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| # $Id$
 |  | ||||||
| 
 |  | ||||||
| head: |  | ||||||
| 	echo This Makefile needs arguments |  | ||||||
| 
 |  | ||||||
| clean: |  | ||||||
| 	rm -f *.old |  | ||||||
| 
 |  | ||||||
| opr: |  | ||||||
| 	make pr | opr |  | ||||||
| 
 |  | ||||||
| pr: |  | ||||||
| 	@pr Makefile *.[ec] |  | ||||||
|  | @ -17,9 +17,10 @@ for _, plat in ipairs(vars.plats) do | ||||||
|         }, |         }, | ||||||
| 		hdrs = {}, -- must be empty | 		hdrs = {}, -- must be empty | ||||||
| 		deps = { | 		deps = { | ||||||
| 			"lang/cem/libcc.ansi/headers+pkg", |  | ||||||
| 			"plat/"..plat.."/include+pkg", |  | ||||||
| 			"h+emheaders", | 			"h+emheaders", | ||||||
|  | 			"lang/cem/libcc.ansi/headers+pkg", | ||||||
|  | 			"lang/pc/include+headers", | ||||||
|  | 			"plat/"..plat.."/include+pkg", | ||||||
| 		}, | 		}, | ||||||
|         vars = { plat = plat } |         vars = { plat = plat } | ||||||
|     } |     } | ||||||
|  | @ -29,7 +30,8 @@ for _, plat in ipairs(vars.plats) do | ||||||
| 		srcs = { "./head_pc.e" }, | 		srcs = { "./head_pc.e" }, | ||||||
| 		vars = { plat = plat }, | 		vars = { plat = plat }, | ||||||
| 		deps = { | 		deps = { | ||||||
| 			"h+emheaders" | 			"h+emheaders", | ||||||
|  | 			"lang/pc/include+headers", | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -11,7 +11,7 @@ definerule("ackfile", | ||||||
| 		suffix = { type="string", optional=true }, | 		suffix = { type="string", optional=true }, | ||||||
| 	}, | 	}, | ||||||
| 	function (e) | 	function (e) | ||||||
| 		local em = e.vars.plat:find("^em") | 		local em = (e.vars.plat or ""):find("^em") | ||||||
| 		local suffix = e.suffix or (em and ".m" or ".o") | 		local suffix = e.suffix or (em and ".m" or ".o") | ||||||
| 		local c = "-c"..suffix | 		local c = "-c"..suffix | ||||||
| 		local plat = e.vars.plat | 		local plat = e.vars.plat | ||||||
|  | @ -47,7 +47,7 @@ definerule("acklibrary", | ||||||
| 		deps = { type="targets", default={} }, | 		deps = { type="targets", default={} }, | ||||||
| 	}, | 	}, | ||||||
| 	function (e) | 	function (e) | ||||||
| 		local em = e.vars.plat:find("^em") | 		local em = (e.vars.plat or ""):find("^em") | ||||||
| 		return clibrary { | 		return clibrary { | ||||||
| 			name = e.name, | 			name = e.name, | ||||||
| 			srcs = e.srcs, | 			srcs = e.srcs, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue