shithub: femtolisp

ref: 4f5436b163da902ca24743b9836309c8cc724b3f
dir: /3rd/mp/mptobe.c/

View raw version
#include "platform.h"

// convert an mpint into a big endian byte array (most significant byte first; left adjusted)
//   return number of bytes converted
//   if p == nil, allocate and result array
int
mptobe(mpint *b, uchar *p, uint n, uchar **pp)
{
	uint m;

	m = (mpsignif(b)+7)/8;
	if(m == 0)
		m++;
	if(p == nil){
		n = m;
		p = LLT_ALLOC(n);
		if(p == nil)
			sysfatal("mptobe: %r");
	} else {
		if(n < m)
			return -1;
		if(n > m)
			memset(p+m, 0, n-m);
	}
	if(pp != nil)
		*pp = p;
	mptober(b, p, m);
	return m;
}