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 + -
显示快捷键?