c_pzasusb8.c

来自「Calc Software Package for Number Calc」· C语言 代码 · 共 95 行

C
95
字号
/* * c_pzasusb8 - print numereator as a string of USB8s * * Copyright (C) 1999-2004  Ernest Bowen * * Calc is open software; you can redistribute it and/or modify it under * the terms of the version 2.1 of the GNU Lesser General Public License * as published by the Free Software Foundation. * * Calc is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE.	 See the GNU Lesser General * Public License for more details. * * A copy of version 2.1 of the GNU Lesser General Public License is * distributed with calc under the filename COPYING-LGPL.  You should have * received a copy with calc; if not, write to Free Software Foundation, Inc. * 59 Temple Place, Suite 330, Boston, MA  02111-1307, USA. * * @(#) $Revision: 29.4 $ * @(#) $Id: c_pzasusb8.c,v 29.4 2004/02/23 14:04:01 chongo Exp $ * @(#) $Source: /usr/local/src/cmd/calc/custom/RCS/c_pzasusb8.c,v $ * * Under source code control:	1999/10/06 03:12:25 * File existed as early as:	1999 * * Share and enjoy!  :-)	http://www.isthe.com/chongo/tech/comp/calc/ */#if defined(CUSTOM)#include <stdio.h>#include "../have_const.h"#include "../value.h"#include "../custom.h"#include "../zmath.h"#include "../have_unused.h"/* * c_pzasusb8 - print numereator as a string of USB8s * * given: *    count = 1; *    vals[0]	real number; * * returns: *    null *//*ARGSUSED*/VALUEc_pzasusb8(char UNUSED *name, int UNUSED count, VALUE **vals){	VALUE result;		/* what we will return */	ZVALUE z;		/* numerator of the value */	long half_cnt;		/* number of HALFs in the numerator */	USB8 *h;		/* octet pointer */	long half_len;		/* length of a half in octets */	long i;	long j;	/*	 * arg check	 */	result.v_type = V_NULL;	if (vals[0]->v_type != V_NUM) {		math_error("Non-real argument for pzasusb8");		/*NOTREACHED*/	}	/*	 * look at the numerator	 */	z = vals[0]->v_num->num;	half_len = sizeof(HALF);	half_cnt = z.len;	/*	 * print the octets	 */	h = (USB8 *) z.v;	for (i=0; i < half_cnt; ++i) {		printf("%ld:\t", i);		for (j=0; j < half_len; ++j) {			printf("%02x", (int)(*h++));		}		putchar('\n');	}	return result;}#endif /* CUSTOM */

⌨️ 快捷键说明

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