| #include "os.h" | |
| #include <mp.h> | |
| #include "dat.h" | |
| /* return neg, 0, pos as abs(b1)-abs(b2) is neg, 0, pos */ | |
| int | |
| mpmagcmp(mpint *b1, mpint *b2) | |
| { | |
| int i; | |
| i = b1->top - b2->top; | |
| if(i) | |
| return i; | |
| return mpveccmp(b1->p, b1->top, b2->p, b2->top); | |
| } | |
| /* return neg, 0, pos as b1-b2 is neg, 0, pos */ | |
| int | |
| mpcmp(mpint *b1, mpint *b2) | |
| { | |
| if(b1->sign != b2->sign) | |
| return b1->sign - b2->sign; | |
| if(b1->sign < 0) | |
| return mpmagcmp(b2, b1); | |
| else | |
| return mpmagcmp(b1, b2); | |
| } |