⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 log.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
#include "dat.h"voidlogbufproc(Logbuf *lb){	char *s;	int n;	Req *r;	while(lb->wait && lb->rp != lb->wp){		r = lb->wait;		lb->wait = r->aux;		if(lb->wait == nil)			lb->waitlast = &lb->wait;		r->aux = nil;		if(r->ifcall.count < 5){			respond(r, "factotum: read request count too short");			continue;		}		s = lb->msg[lb->rp];		lb->msg[lb->rp] = nil;		if(++lb->rp == nelem(lb->msg))			lb->rp = 0;		n = r->ifcall.count;		if(n < strlen(s)+1+1){			memmove(r->ofcall.data, s, n-5);			n -= 5;			r->ofcall.data[n] = '\0';			/* look for first byte of UTF-8 sequence by skipping continuation bytes */			while(n>0 && (r->ofcall.data[--n]&0xC0)==0x80)				;			strcpy(r->ofcall.data+n, "...\n");		}else{			strcpy(r->ofcall.data, s);			strcat(r->ofcall.data, "\n");		}		r->ofcall.count = strlen(r->ofcall.data);		free(s);		respond(r, nil);	}}voidlogbufread(Logbuf *lb, Req *r){	if(lb->waitlast == nil)		lb->waitlast = &lb->wait;	*(lb->waitlast) = r;	lb->waitlast = &r->aux;	r->aux = nil;	logbufproc(lb);}voidlogbufflush(Logbuf *lb, Req *r){	Req **l;	for(l=&lb->wait; *l; l=&(*l)->aux){		if(*l == r){			*l = r->aux;			r->aux = nil;			if(*l == nil)				lb->waitlast = l;			respond(r, "interrupted");			break;		}	}}voidlogbufappend(Logbuf *lb, char *buf){	if(debug)		fprint(2, "%s\n", buf);	if(lb->msg[lb->wp])		free(lb->msg[lb->wp]);	lb->msg[lb->wp] = estrdup9p(buf);	if(++lb->wp == nelem(lb->msg))		lb->wp = 0;	logbufproc(lb);}Logbuf logbuf;voidlogread(Req *r){	logbufread(&logbuf, r);}voidlogflush(Req *r){	logbufflush(&logbuf, r);}voidflog(char *fmt, ...){	char buf[1024];	va_list arg;	va_start(arg, fmt);	vseprint(buf, buf+sizeof buf, fmt, arg);	va_end(arg);	logbufappend(&logbuf, buf);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -