-
Notifications
You must be signed in to change notification settings - Fork 5
/
expose.c
64 lines (56 loc) · 1.18 KB
/
expose.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
* $Id: expose.c,v 1.5 2008/07/15 07:40:54 bnv Exp $
* $Log: expose.c,v $
* Revision 1.5 2008/07/15 07:40:54 bnv
* #include changed from <> to ""
*
* Revision 1.4 2002/06/11 12:37:15 bnv
* Added: CDECL
*
* Revision 1.3 2001/06/25 18:49:48 bnv
* Header changed to Id
*
* Revision 1.2 1999/11/26 09:56:55 bnv
* Changed: Formatting
*
* Revision 1.1 1998/07/02 17:18:00 bnv
* Initial Version
*
*/
#include "lstring.h"
/* ----------------- expose ---------------- */
void __CDECL
Lexpose(const PLstr to, const PLstr A, const PLstr B) {
double ar, r;
long bi;
bool minusA;
bool minusB;
ar = Lrdreal(A);
bi = Lrdint(B);
if (ar < 0) {
if (ODD(bi))
minusA = TRUE;
else
minusA = FALSE;
ar = -ar;
} else
minusA = FALSE;
if (bi < 0) {
minusB = TRUE;
bi = -bi;
} else
minusB = FALSE;
r = 1;
while (bi != 0) {
if (ODD(bi)) r *= ar;
ar *= ar;
bi /= 2;
}
if (minusA) r = -r;
if (minusB)
LREAL(*to) = 1 / r;
else
LREAL(*to) = r;
LTYPE(*to) = LREAL_TY;
LLEN(*to) = sizeof(double);
} /* Lexpose */