size.c

来自「这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易」· C语言 代码 · 共 71 行

C
71
字号
#include "e.h"#include <ctype.h>void setsize(char *p)	/* set size as found in p */{	nszstack++;	szstack[nszstack] = 0;		/* assume relative */	if (*p == '+') {		ps += atoi(p+1);		if (szstack[nszstack-1] != 0)	/* propagate absolute size */			szstack[nszstack] = ps;	} else if (*p == '-') {		ps -= atoi(p+1);		if (szstack[nszstack-1] != 0)			szstack[nszstack] = ps;	} else if (isdigit(*p)) {		if (szstack[nszstack-1] == 0)			printf(".nr %d \\n(.s\n", 99-nszstack);		else			printf(".nr %d %d\n", 99-nszstack, ps);		szstack[nszstack] = ps = atoi(p);	} else {		ERROR "illegal size %s ignored", p WARNING;	}	dprintf(".\tsetsize %s; ps = %d\n", p, ps);}void size(int p1, int p2){		/* old size in p1, new in ps */	yyval = p2;	dprintf(".\tS%d <- \\s%d %d \\s%d; b=%g, h=%g\n", 		yyval, ps, p2, p1, ebase[yyval], eht[yyval]);	if (szstack[nszstack] != 0) {		printf(".ds %d %s\\*(%d\\s\\n(%d\n", yyval, ABSPS(ps), p2, 99-nszstack);	} else		printf(".ds %d %s\\*(%d%s\n", yyval, DPS(p1,ps), p2, DPS(ps,p1));	nszstack--;	ps = p1;}void globsize(void){	char temp[20];	getstr(temp, sizeof(temp));	if (temp[0] == '+') {		gsize += atoi(temp+1);		if (szstack[0] != 0)			szstack[0] = gsize;	} else if (temp[0] == '-') {		gsize -= atoi(temp+1);		if (szstack[0] != 0)			szstack[0] = gsize;	} else  if (isdigit(temp[0])) {		gsize = atoi(temp);		szstack[0] = gsize;		printf(".nr 99 \\n(.s\n");	} else {		ERROR "illegal gsize %s ignored", temp WARNING;	}	yyval = eqnreg = 0;	ps = gsize;	if (gsize < 12 && !dps_set)		/* sub and sup size change */		deltaps = gsize / 3;	else if (gsize < 20)		deltaps = gsize / 4;	else		deltaps = gsize / 5;}

⌨️ 快捷键说明

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