encode_longlong.c
来自「OTP是开放电信平台的简称」· C语言 代码 · 共 103 行
C
103 行
/* ``The contents of this file are subject to the Erlang Public License, * Version 1.1, (the "License"); you may not use this file except in * compliance with the License. You should have received a copy of the * Erlang Public License along with this software. If not, it can be * retrieved via the world wide web at http://www.erlang.org/. * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See * the License for the specific language governing rights and limitations * under the License. * * The Initial Developer of the Original Code is Ericsson Utvecklings AB. * Portions created by Ericsson are Copyright 1999, Ericsson Utvecklings * AB. All Rights Reserved.'' * * $Id$ */#include "eidef.h"#include "eiext.h"#include "putget.h"#include "ei_x_encode.h"#define abs(p) (((p)<0) ? -(p) : p)/* long -> erl_integer *//* note that this is the only place where data is stored Little Endian *//* * For some 64 bit operations on some operating systems code * compiled with GNU cc depends on "libgcc" for some 64 bit * operations missing in hardware (or because of gcc bugs). * If user code was linked together with the ei lib * using other linkers than GNU ld this may cause problems. * We moved ei_x_encode_longlong() here from "ei_x_encode.c" * to limit this problem to users that actually use the ei * longlong operations, not all ei_x users. */int ei_x_encode_longlong(ei_x_buff* x, EI_LONGLONG n){ int i = x->index; ei_encode_longlong(NULL, &i, n); if (!x_fix_buff(x, i)) return -1; return ei_encode_longlong(x->buff, &x->index, n);}#ifdef EI_64BITint ei_encode_long(char *buf, int *index, long p){ return ei_encode_longlong(buf, index, p);}#endifint ei_encode_longlong(char *buf, int *index, EI_LONGLONG p){ char *s = buf + *index; char *s0 = s; if ((p < 256) && (p >= 0)) { if (!buf) s += 2; else { put8(s,ERL_SMALL_INTEGER_EXT); put8(s,(p & 0xff)); } } else if ((p <= ERL_MAX) && (p >= ERL_MIN)) { /* FIXME: Non optimal, could use (p <= LONG_MAX) && (p >= LONG_MIN) and skip next case */ if (!buf) s += 5; else { put8(s,ERL_INTEGER_EXT); put32be(s,p); } } else { /* We know 28-64 bits needed, i.e four to eight bytes */ EI_ULONGLONG up = abs(p); /* FIXME name uabs(x) not to confuse with abs */ if (buf) { char *arityp; int arity = 0; put8(s,ERL_SMALL_BIG_EXT); arityp = s++; /* fill in later */ put8(s, p < 0); /* save sign separately */ while (up) { *s++ = up & 0xff; /* take lowest byte */ up >>= 8; /* shift unsigned */ arity++; } put8(arityp,arity); } else { s += 3; /* Type, arity and sign */ while (up) { s++; /* take lowest byte */ up >>= 8; /* shift unsigned */ } } } *index += s-s0; return 0; }
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?