亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? inout.mod

?? minix3的源代碼
?? MOD
字號:
(*  (c) copyright 1988 by the Vrije Universiteit, Amsterdam, The Netherlands.  See the copyright notice in the ACK home directory, in the file "Copyright".*)(*$R-*)IMPLEMENTATION MODULE InOut ;(*  Module:	Wirth's Input/Output module  Author:	Ceriel J.H. Jacobs  Version:	$Header: /cvsup/minix/src/lib/ack/libm2/InOut.mod,v 1.1 2005/10/10 15:27:46 beng Exp $*)  IMPORT	Streams;  FROM	Conversions IMPORT			ConvertCardinal, ConvertInteger,			ConvertOctal, ConvertHex;  FROM	Traps IMPORT	Message;  CONST	TAB = 11C;  TYPE	numbuf = ARRAY[0..255] OF CHAR;  VAR	unread: BOOLEAN;	unreadch: CHAR;	CurrIn, CurrOut: Streams.Stream;	result: Streams.StreamResult;  PROCEDURE Read(VAR c : CHAR);  BEGIN	IF unread THEN		unread := FALSE;		c := unreadch;		Done := TRUE;	ELSE		Streams.Read(CurrIn, c, result);		Done := result = Streams.succeeded;	END;  END Read;  PROCEDURE UnRead(ch: CHAR);  BEGIN	unread := TRUE;	unreadch := ch;  END UnRead;  PROCEDURE Write(c: CHAR);  BEGIN	Streams.Write(CurrOut, c, result);  END Write;  PROCEDURE OpenInput(defext: ARRAY OF CHAR);  VAR namebuf : ARRAY [1..128] OF CHAR;  BEGIN	IF CurrIn # Streams.InputStream THEN		Streams.CloseStream(CurrIn, result);	END;	MakeFileName("Name of input file: ", defext, namebuf);	IF NOT Done THEN RETURN; END;	openinput(namebuf);  END OpenInput;  PROCEDURE OpenInputFile(filename: ARRAY OF CHAR);  BEGIN	IF CurrIn # Streams.InputStream THEN		Streams.CloseStream(CurrIn, result);	END;	openinput(filename);  END OpenInputFile;  PROCEDURE openinput(namebuf: ARRAY OF CHAR);  BEGIN	IF (namebuf[0] = '-') AND (namebuf[1] = 0C) THEN		CurrIn := Streams.InputStream;		Done := TRUE;	ELSE		Streams.OpenStream(CurrIn, namebuf, Streams.text,				   Streams.reading, result);		Done := result = Streams.succeeded;	END;  END openinput;  PROCEDURE CloseInput;  BEGIN	IF CurrIn # Streams.InputStream THEN		Streams.CloseStream(CurrIn, result);	END;	CurrIn := Streams.InputStream;  END CloseInput;  PROCEDURE OpenOutput(defext: ARRAY OF CHAR);  VAR namebuf : ARRAY [1..128] OF CHAR;  BEGIN	IF CurrOut # Streams.OutputStream THEN		Streams.CloseStream(CurrOut, result);	END;	MakeFileName("Name of output file: ", defext, namebuf);	IF NOT Done THEN RETURN; END;	openoutput(namebuf);  END OpenOutput;  PROCEDURE OpenOutputFile(filename: ARRAY OF CHAR);  BEGIN	IF CurrOut # Streams.OutputStream THEN		Streams.CloseStream(CurrOut, result);	END;	openoutput(filename);  END OpenOutputFile;  PROCEDURE openoutput(namebuf: ARRAY OF CHAR);  BEGIN	IF (namebuf[1] = '-') AND (namebuf[2] = 0C) THEN		CurrOut := Streams.OutputStream;		Done := TRUE;	ELSE		Streams.OpenStream(CurrOut, namebuf, Streams.text,				   Streams.writing, result);		Done := result = Streams.succeeded;	END;  END openoutput;  PROCEDURE CloseOutput;  BEGIN	IF CurrOut # Streams.OutputStream THEN		Streams.CloseStream(CurrOut, result);	END;	CurrOut := Streams.OutputStream;  END CloseOutput;  PROCEDURE MakeFileName(prompt, defext : ARRAY OF CHAR;		       VAR buf : ARRAY OF CHAR);  VAR	i : INTEGER;	j : CARDINAL;  BEGIN	Done := TRUE;	IF Streams.isatty(Streams.InputStream, result) THEN		XWriteString(prompt);	END;	XReadString(buf);	i := 0;	WHILE buf[i] # 0C DO i := i + 1 END;	IF i # 0 THEN		i := i - 1;		IF buf[i] = '.' THEN	    		FOR j := 0 TO HIGH(defext) DO				i := i + 1;				buf[i] := defext[j];	    		END;	    		buf[i+1] := 0C;		END;		RETURN;	END;	Done := FALSE;  END MakeFileName;  PROCEDURE ReadInt(VAR integ : INTEGER);  CONST    	SAFELIMITDIV10 = MAX(INTEGER) DIV 10;    	SAFELIMITREM10 = MAX(INTEGER) MOD 10;  TYPE	itype = [0..31];	ibuf =  ARRAY itype OF CHAR;  VAR    	int : INTEGER;    	neg : BOOLEAN;    	safedigit: [0 .. 9];    	chvalue: CARDINAL;	buf : ibuf;	index : itype;  BEGIN    	ReadString(buf);	IF NOT Done THEN		RETURN	END;	index := 0;    	IF buf[index] = '-' THEN		neg := TRUE;		INC(index);    	ELSIF buf[index] = '+' THEN		neg := FALSE;		INC(index);    	ELSE		neg := FALSE    	END;    	safedigit := SAFELIMITREM10;    	IF neg THEN safedigit := safedigit + 1 END;    	int := 0;	WHILE (buf[index] >= '0') & (buf[index] <= '9') DO  		chvalue := ORD(buf[index]) - ORD('0');	   	IF (int > SAFELIMITDIV10) OR 		   ( (int = SAFELIMITDIV10) AND		     (chvalue > safedigit)) THEN			Message("integer too large");			HALT;	    	ELSE			int := 10*int + VAL(INTEGER, chvalue);			INC(index)	    	END;	END;	IF neg THEN   		integ := -int	ELSE		integ := int	END;	IF buf[index] > " " THEN		Message("illegal integer");		HALT;	END;	Done := TRUE;  END ReadInt;  PROCEDURE ReadCard(VAR card : CARDINAL);  CONST    	SAFELIMITDIV10 = MAX(CARDINAL) DIV 10;    	SAFELIMITREM10 = MAX(CARDINAL) MOD 10;  TYPE	itype = [0..31];	ibuf =  ARRAY itype OF CHAR;      VAR    	int : CARDINAL;    	index  : itype;	buf : ibuf;    	safedigit: [0 .. 9];    	chvalue: CARDINAL;  BEGIN    	ReadString(buf);	IF NOT Done THEN RETURN; END;	index := 0;    	safedigit := SAFELIMITREM10;    	int := 0;	WHILE (buf[index] >= '0') & (buf[index] <= '9') DO  		chvalue := ORD(buf[index]) - ORD('0');	    	IF (int > SAFELIMITDIV10) OR 		   ( (int = SAFELIMITDIV10) AND		     (chvalue > safedigit)) THEN			Message("cardinal too large");			HALT;	    	ELSE			int := 10*int + chvalue;			INC(index);	    	END;	END;	IF buf[index] > " " THEN		Message("illegal cardinal");		HALT;	END;	card := int;	Done := TRUE;  END ReadCard;  PROCEDURE ReadString(VAR s : ARRAY OF CHAR);  TYPE charset = SET OF CHAR;  VAR	i : CARDINAL;    	ch : CHAR;  BEGIN    	i := 0;	REPEAT		Read(ch);	UNTIL NOT (ch IN charset{' ', TAB, 12C, 15C});	IF NOT Done THEN		RETURN;	END;	UnRead(ch);    	REPEAT		Read(ch);		termCH := ch;		IF i <= HIGH(s) THEN			s[i] := ch;			IF (NOT Done) OR (ch <= " ") THEN				s[i] := 0C;			END;		END;		INC(i);    	UNTIL (NOT Done) OR (ch <= " ");	IF Done THEN UnRead(ch); END;  END ReadString;  PROCEDURE XReadString(VAR s : ARRAY OF CHAR);  VAR	j : CARDINAL;    	ch : CHAR;  BEGIN	j := 0;	LOOP		Streams.Read(Streams.InputStream, ch, result);		IF result # Streams.succeeded THEN			EXIT;		END;		IF ch <= " " THEN			s[j] := 0C;			EXIT;		END;		IF j < HIGH(s) THEN			s[j] := ch;			INC(j);		END;	END;  END XReadString;  PROCEDURE XWriteString(s: ARRAY OF CHAR);  VAR i: CARDINAL;  BEGIN	i := 0;	LOOP		IF (i <= HIGH(s)) AND (s[i] # 0C) THEN			Streams.Write(Streams.OutputStream, s[i], result);			INC(i);		ELSE			EXIT;		END;	END;  END XWriteString;  PROCEDURE WriteCard(card, width : CARDINAL);  VAR    	buf : numbuf;  BEGIN	ConvertCardinal(card, width, buf);	WriteString(buf);  END WriteCard;  PROCEDURE WriteInt(int : INTEGER; width : CARDINAL);  VAR    	buf : numbuf;  BEGIN    	ConvertInteger(int, width, buf);	WriteString(buf);  END WriteInt;  PROCEDURE WriteHex(card, width : CARDINAL);  VAR    	buf : numbuf;  BEGIN	ConvertHex(card, width, buf);	WriteString(buf);  END WriteHex;  PROCEDURE WriteLn;  BEGIN    	Write(EOL)  END WriteLn;  PROCEDURE WriteOct(card, width : CARDINAL);  VAR    	buf : numbuf;  BEGIN    	ConvertOctal(card, width, buf);	WriteString(buf);  END WriteOct;  PROCEDURE WriteString(str : ARRAY OF CHAR);  VAR    	nbytes : CARDINAL;  BEGIN    	nbytes := 0;    	WHILE (nbytes <= HIGH(str)) AND (str[nbytes] # 0C) DO		Write(str[nbytes]);		INC(nbytes)    	END;  END WriteString;BEGIN	(* InOut initialization *)	CurrIn := Streams.InputStream;	CurrOut := Streams.OutputStream;	unread := FALSE;END InOut.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人国产一区二区三区精品| 欧美sm极限捆绑bd| 精品乱码亚洲一区二区不卡| 国产精品久久三| 老司机精品视频一区二区三区| 99精品视频在线观看免费| 欧美精品一区二区在线播放| 午夜精品久久久久久久蜜桃app| 99视频在线精品| 久久精品人人做| 久久精品国产精品亚洲红杏 | 一区二区三区欧美| 国产福利91精品| 精品精品欲导航| 日本亚洲天堂网| 91.xcao| 亚洲国产精品视频| 在线观看一区二区视频| 亚洲欧美一区二区视频| 国产盗摄一区二区三区| 精品国产1区二区| 青娱乐精品视频| 日韩一区二区三免费高清| 五月婷婷久久综合| 在线成人免费观看| 日韩精品欧美成人高清一区二区| 色婷婷精品大视频在线蜜桃视频| 国产精品国模大尺度视频| 成人免费毛片嘿嘿连载视频| 国产三级欧美三级| 成人av小说网| 亚洲码国产岛国毛片在线| 色婷婷av一区二区三区gif| 最新不卡av在线| 在线亚洲一区二区| 一区二区三区四区不卡在线 | 在线综合亚洲欧美在线视频| 婷婷久久综合九色国产成人| 欧美肥大bbwbbw高潮| 蜜臀av一级做a爰片久久| 精品国产精品一区二区夜夜嗨| 久热成人在线视频| 久久精品视频一区二区三区| 99麻豆久久久国产精品免费 | 中文字幕在线播放不卡一区| 99re热视频精品| 午夜精品久久久久久久久久久| 欧美一区二区三区男人的天堂| 极品少妇xxxx精品少妇| 国产欧美一区二区精品婷婷 | 91免费国产在线观看| 亚洲综合色噜噜狠狠| 日韩欧美电影在线| va亚洲va日韩不卡在线观看| 夜夜嗨av一区二区三区中文字幕| 欧美精品日日鲁夜夜添| 国产最新精品精品你懂的| 国产精品成人一区二区艾草| 欧美日韩亚洲综合在线 | 精品国产91久久久久久久妲己 | 不卡影院免费观看| 亚洲高清免费在线| 久久综合久久综合久久综合| 91小视频在线免费看| 日韩精品高清不卡| 国产精品久久久久久久久久免费看| 欧美在线999| 国产精品一二三区在线| 亚洲一区二区三区在线播放| 精品国产精品网麻豆系列| 91电影在线观看| 福利电影一区二区三区| 婷婷综合另类小说色区| 中文字幕二三区不卡| 91精品麻豆日日躁夜夜躁| 成人精品视频.| 老司机精品视频在线| 亚洲黄一区二区三区| 久久久国产精品麻豆 | 91在线观看污| 精品在线观看免费| 日韩黄色小视频| 一区二区三区四区视频精品免费| 欧美大片国产精品| 欧美日韩视频在线第一区| 91尤物视频在线观看| 91精品国产综合久久香蕉麻豆| 亚洲成人激情综合网| 国产午夜亚洲精品午夜鲁丝片 | 国产成人夜色高潮福利影视| 天天操天天综合网| 亚洲女人小视频在线观看| 久久精品免费在线观看| 欧美一区二区福利在线| 欧美色窝79yyyycom| 成人av网站在线| 国产不卡免费视频| 国产高清成人在线| 国产一区二区在线看| 麻豆国产欧美日韩综合精品二区| 亚洲小说春色综合另类电影| 亚洲免费在线看| 综合在线观看色| 国产精品久久久久久久久搜平片 | 日本一区二区成人| 欧美精品一区二区三区蜜桃| 日韩免费看的电影| 91精品国产色综合久久不卡电影| 欧美日韩成人在线| 911国产精品| 日韩欧美色综合| 精品精品国产高清a毛片牛牛| 日韩一区二区三区免费看| 日韩欧美国产综合在线一区二区三区 | 国产在线麻豆精品观看| 国内成人自拍视频| 国产精品小仙女| av中文字幕亚洲| 色婷婷av久久久久久久| 欧美日韩亚洲高清一区二区| 欧美日韩五月天| 日韩精品中文字幕一区 | 日韩精品一卡二卡三卡四卡无卡| 亚洲h在线观看| 免费在线欧美视频| 国产主播一区二区| 成人午夜激情片| 色94色欧美sute亚洲线路一久 | 午夜精品福利一区二区三区av| 午夜久久久久久久久久一区二区| 免播放器亚洲一区| 国产精品综合二区| 91在线porny国产在线看| 欧洲色大大久久| 日韩午夜在线观看视频| 久久精品日韩一区二区三区| 亚洲欧美区自拍先锋| 午夜国产不卡在线观看视频| 国产真实乱偷精品视频免| av在线一区二区三区| 欧美日韩免费观看一区二区三区 | 亚洲视频在线一区二区| 亚洲国产精品麻豆| 国产精品一区二区久激情瑜伽| va亚洲va日韩不卡在线观看| 欧美日韩精品欧美日韩精品| 久久在线观看免费| 亚洲精品国久久99热| 老司机精品视频一区二区三区| 成人中文字幕合集| 日韩三级在线免费观看| 国产精品久久午夜夜伦鲁鲁| 日韩av电影天堂| 成人av在线看| 欧美一区二区三区的| 国产精品麻豆久久久| 日本 国产 欧美色综合| 9久草视频在线视频精品| 91精品国产91久久久久久一区二区 | 中文字幕一区二区三区精华液| 五月综合激情网| 91麻豆产精品久久久久久| 日韩精品一区二区三区在线播放| 亚洲人成网站影音先锋播放| 激情综合色播五月| 欧美在线不卡视频| 日韩一区欧美一区| 国产福利一区二区三区在线视频| 7777精品伊人久久久大香线蕉超级流畅| 国产人久久人人人人爽| 麻豆91免费观看| 欧美日韩视频在线第一区| 日本一区二区三区四区在线视频| 日韩国产欧美在线观看| 一本到三区不卡视频| 欧美经典三级视频一区二区三区| 麻豆精品国产91久久久久久| 欧美日韩一级视频| 亚洲一区二区三区四区不卡| 不卡一区在线观看| 久久噜噜亚洲综合| 久久国产精品色婷婷| 6080日韩午夜伦伦午夜伦| 亚洲黄色免费电影| 91免费看`日韩一区二区| 国产精品久久久一本精品| 成人晚上爱看视频| 久久久精品日韩欧美| 国产精品资源在线看| 精品国免费一区二区三区| 毛片基地黄久久久久久天堂| 欧美一级国产精品| 日韩vs国产vs欧美| 日韩免费成人网| 精品一区二区三区久久| 精品剧情v国产在线观看在线| 日韩电影网1区2区| 欧美刺激脚交jootjob| 国内精品久久久久影院薰衣草 | 亚洲成人av免费|