changed how getnextsc() counts line and column numbers.
changed how PEEPNEXTSC() works
This commit is contained in:
		| @ -34,7 +34,7 @@ POST_UNINSTALL = : | ||||
| build_triplet = @build@ | ||||
| host_triplet = @host@ | ||||
| subdir = . | ||||
| DIST_COMMON = $(am__configure_deps) $(srcdir)/Makefile.am \ | ||||
| DIST_COMMON = README $(am__configure_deps) $(srcdir)/Makefile.am \ | ||||
| 	$(srcdir)/Makefile.in $(srcdir)/README.in \ | ||||
| 	$(top_srcdir)/configure ac/config.guess ac/config.sub \ | ||||
| 	ac/depcomp ac/install-sh ac/ltmain.sh ac/missing | ||||
|  | ||||
| @ -345,7 +345,7 @@ static int matchtre ( | ||||
|  | ||||
| #define CURSC(sed) ((sed)->src.cc) | ||||
| #define NXTSC(sed) getnextsc(sed) | ||||
| #define PEEPNXTSC(sed) ((sed->src.cur < sed->src.end)? *sed->src.cur: QSE_CHAR_EOF) | ||||
| #define PEEPNXTSC(sed) peepnextsc(sed) | ||||
|  | ||||
| static int open_script_stream (qse_sed_t* sed) | ||||
| { | ||||
| @ -394,14 +394,14 @@ static int close_script_stream (qse_sed_t* sed) | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static int read_script_stream (qse_sed_t* sed, qse_size_t rem) | ||||
| static int read_script_stream (qse_sed_t* sed) | ||||
| { | ||||
| 	qse_ssize_t n; | ||||
|  | ||||
| 	sed->errnum = QSE_SED_ENOERR; | ||||
| 	n = sed->src.fun ( | ||||
| 		sed, QSE_SED_IO_READ, &sed->src.arg,  | ||||
| 		&sed->src.buf[rem], QSE_COUNTOF(sed->src.buf) - rem | ||||
| 		sed->src.buf, QSE_COUNTOF(sed->src.buf) | ||||
| 	); | ||||
| 	if (n <= -1) | ||||
| 	{ | ||||
| @ -416,50 +416,61 @@ static int read_script_stream (qse_sed_t* sed, qse_size_t rem) | ||||
| 		return 0; | ||||
| 	} | ||||
|  | ||||
| 	sed->src.end = &sed->src.buf[rem] + n; | ||||
| 	sed->src.cur = sed->src.buf; | ||||
| 	sed->src.end = sed->src.buf + n; | ||||
| 	return 1; | ||||
| } | ||||
|  | ||||
| static qse_cint_t getnextsc (qse_sed_t* sed) | ||||
| { | ||||
| 	if (sed->src.cur + 1 >= sed->src.end && !sed->src.eof) | ||||
| 	{ | ||||
| 		qse_size_t rem = sed->src.end - sed->src.cur; | ||||
| 		if (sed->src.cur != sed->src.buf && rem > 0) | ||||
| 		{ | ||||
| 			QSE_MEMCPY (sed->src.buf, sed->src.cur, rem * QSE_SIZEOF(qse_char_t)); | ||||
| 			sed->src.cur = sed->src.buf; | ||||
| 			sed->src.end = sed->src.buf + rem; | ||||
| 		} | ||||
| 		if (read_script_stream (sed, rem) <= -1) return -1; | ||||
|  | ||||
| 		if (sed->src.cur + 1 >= sed->src.end && !sed->src.eof) | ||||
| 		{ | ||||
| 			/* read again if it didn't read enough */ | ||||
| 			qse_size_t rem = sed->src.end - sed->src.cur; | ||||
| 			QSE_ASSERT (sed->src.buf == sed->src.cur); | ||||
| 			if (read_script_stream (sed, rem) <= -1) return -1; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (sed->src.cur < sed->src.end)  | ||||
| 	{ | ||||
| 	/* adjust the line and column number of the next | ||||
| 	 * character based on the current character */ | ||||
| 	if (sed->src.cc == QSE_T('\n'))  | ||||
| 	{ | ||||
| 		/* TODO: support different line end convension */ | ||||
| 		sed->src.loc.line++; | ||||
| 		sed->src.loc.colm = 1; | ||||
| 	} | ||||
| 		else sed->src.loc.colm++; | ||||
|  | ||||
| 		sed->src.cc = *sed->src.cur++; | ||||
| 		/* TODO: support different line end convension */ | ||||
| 		/*if (sed->src.cc == QSE_T('\n')) sed->src.loc.lin++;*/ | ||||
| 	else  | ||||
| 	{ | ||||
| 		/* take note that if you keep on calling getnextsc() | ||||
| 		 * after QSE_CHAR_EOF is read, this column number | ||||
| 		 * keeps increasing also. there should be a bug of | ||||
| 		 * reading more than necessary somewhere in the code | ||||
| 		 * if this happens. */ | ||||
| 		sed->src.loc.colm++; | ||||
| 	} | ||||
| 	else sed->src.cc = QSE_CHAR_EOF; | ||||
|  | ||||
| 	if (sed->src.cur >= sed->src.end && !sed->src.eof)  | ||||
| 	{ | ||||
| 		/* read in more character if buffer is empty */ | ||||
| 		if (read_script_stream (sed) <= -1) return -1; | ||||
| 	} | ||||
|  | ||||
| 	sed->src.cc =  | ||||
| 		(sed->src.cur < sed->src.end)?  | ||||
| 		(*sed->src.cur++): QSE_CHAR_EOF; | ||||
|  | ||||
| 	return sed->src.cc; | ||||
| } | ||||
|  | ||||
| static qse_cint_t peepnextsc (qse_sed_t* sed) | ||||
| { | ||||
| 	if (sed->src.cur >= sed->src.end && !sed->src.eof)  | ||||
| 	{ | ||||
| 		/* read in more character if buffer is empty. | ||||
| 		 * it is ok to fill the buffer in the peeping | ||||
| 		 * function if it doesn't change sed->src.cc. */ | ||||
| 		if (read_script_stream (sed) <= -1) return -1; | ||||
| 	} | ||||
|  | ||||
| 	/* no changes in line nubmers, the 'cur' pointer, and | ||||
| 	 * most importantly 'cc' unlike getnextsc(). */ | ||||
| 	return | ||||
| 		(sed->src.cur < sed->src.end)?  | ||||
| 		(*sed->src.cur): QSE_CHAR_EOF; | ||||
| } | ||||
|  | ||||
| static void free_address (qse_sed_t* sed, qse_sed_cmd_t* cmd) | ||||
| { | ||||
| 	if (cmd->a2.type == QSE_SED_ADR_REX) | ||||
|  | ||||
| @ -180,7 +180,7 @@ static int open_input_stream ( | ||||
| #if 0 | ||||
| 	if (base == &xtn->s.in) | ||||
| 	{ | ||||
| 		qse_sed_setfilename (sed, ....); | ||||
| 		qse_sed_setscriptname (sed, ....); | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
| @ -276,7 +276,17 @@ static qse_ssize_t read_input_stream ( | ||||
| 					qse_sed_seterrnum (sed, QSE_SED_EIOFIL, &ea); | ||||
| 				} | ||||
| 			} | ||||
| 			else n += newline_forced; /* success */ | ||||
| 			else if (newline_forced) | ||||
| 			{ | ||||
| 				/* set the line number to 0 for the newline | ||||
| 				 * squeezed in. see the getnextsc() in sed.c  | ||||
| 				 * to know how line and column numbers are | ||||
| 				 * incremented */ | ||||
| 				sed->src.loc.line = 0;  | ||||
| 				sed->src.loc.colm = 0; | ||||
| 				n += newline_forced;  | ||||
| 			} | ||||
|  | ||||
| 			break; | ||||
| 		} | ||||
| 	 | ||||
| @ -326,11 +336,6 @@ static qse_ssize_t read_input_stream ( | ||||
| 			buf[0] = QSE_T('\n');  | ||||
| 			buf++; len--;	 | ||||
| 			newline_forced = 1; | ||||
|  | ||||
| 			/* set the line number to 0 for the newline | ||||
| 			 * squeezed in */ | ||||
| 			sed->src.loc.line = 0;  | ||||
| 			sed->src.loc.colm = 0; | ||||
| 		} | ||||
| 	} | ||||
| 	while (1); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user