#include #include bool beq(long a, long b) { return a == b; } bool blt(long a, long b) { return a < b; } bool bgt(long a, long b) { return a > b; } bool ble(long a, long b) { return a <= b; } bool bge(long a, long b) { return a >= b; } bool neq(long a, long b) { return a == b; } #pragma native(neq) bool nlt(long a, long b) { return a < b; } #pragma native(nlt) bool ngt(long a, long b) { return a > b; } #pragma native(ngt) bool nle(long a, long b) { return a <= b; } #pragma native(nle) bool nge(long a, long b) { return a >= b; } #pragma native(nge) bool beqz(long a) { return a == 0; } bool bltz(long a) { return a < 0; } bool bgtz(long a) { return a > 0; } bool blez(long a) { return a <= 0; } bool bgez(long a) { return a >= 0; } bool neqz(long a) { return a == 0; } #pragma native(neqz) bool nltz(long a) { return a < 0; } #pragma native(nltz) bool ngtz(long a) { return a > 0; } #pragma native(ngtz) bool nlez(long a) { return a <= 0; } #pragma native(nlez) bool ngez(long a) { return a >= 0; } #pragma native(ngez) bool beq1(long a) { return a == 1; } bool blt1(long a) { return a < 1; } bool bgt1(long a) { return a > 1; } bool ble1(long a) { return a <= 1; } bool bge1(long a) { return a >= 1; } bool neq1(long a) { return a == 1; } #pragma native(neq1) bool nlt1(long a) { return a < 1; } #pragma native(nlt1) bool ngt1(long a) { return a > 1; } #pragma native(ngt1) bool nle1(long a) { return a <= 1; } #pragma native(nle1) bool nge1(long a) { return a >= 1; } #pragma native(nge1) void cmp(long a, long b) { bool beqf = beq(a, b), bltf = blt(a, b), bgtf = bgt(a, b), blef = ble(a, b), bgef = bge(a, b); bool neqf = neq(a, b), nltf = nlt(a, b), ngtf = ngt(a, b), nlef = nle(a, b), ngef = nge(a, b); printf("BYTE %ld, %ld : EQ %d LT %d GT %d\r", a, b, beqf, bltf, bgtf); printf("NATIVE %ld, %ld : EQ %d LT %d GT %d\r", a, b, neqf, nltf, ngtf); assert(beqf == neqf); assert(bltf == nltf); assert(bgtf == ngtf); assert(blef == nlef); assert(bgef == ngef); } void cmpz(long a) { bool beqf = beqz(a), bltf = bltz(a), bgtf = bgtz(a), blef = blez(a), bgef = bgez(a); bool neqf = neqz(a), nltf = nltz(a), ngtf = ngtz(a), nlef = nlez(a), ngef = ngez(a); printf("BYTE %ld, 0 : EQ %d LT %d GT %d\r", a, beqf, bltf, bgtf); printf("NATIVE %ld, 0 : EQ %d LT %d GT %d\r", a, neqf, nltf, ngtf); assert(beqf == neqf); assert(bltf == nltf); assert(bgtf == ngtf); assert(blef == nlef); assert(bgef == ngef); } void cmp1(long a) { bool beqf = beq1(a), bltf = blt1(a), bgtf = bgt1(a), blef = ble1(a), bgef = bge1(a); bool neqf = neq1(a), nltf = nlt1(a), ngtf = ngt1(a), nlef = nle1(a), ngef = nge1(a); printf("BYTE %ld, 1 : EQ %d LT %d GT %d LE %d GE %d\r", a, beqf, bltf, bgtf, blef, bgef); printf("NATIVE %ld, 1 : EQ %d LT %d GT %d LE %d GE %d\r", a, neqf, nltf, ngtf, nlef, ngef); assert(beqf == neqf); assert(bltf == nltf); assert(bgtf == ngtf); assert(blef == nlef); assert(bgef == ngef); } int main(void) { cmp( 0, 1); cmp( 0, -1); cmp( 1, 0); cmp(-1, 0); cmp(1, 1); cmp(1, 2); cmp(2, 1); cmp(-1, -1); cmp(-1, -2); cmp(-2, -1); cmp( 1, -1); cmp( 1, -2); cmp( 2, -1); cmp(-1, 1); cmp(-1, 2); cmp(-2, 1); cmp( 0, 10000); cmp( 0, -10000); cmp( 10000, 0); cmp(-10000, 0); cmp(10000, 10000); cmp(10000, 20000); cmp(20000, 10000); cmp(-10000, -10000); cmp(-10000, -20000); cmp(-20000, -10000); cmp( 10000, -10000); cmp( 10000, -20000); cmp( 20000, -10000); cmp(-10000, 10000); cmp(-10000, 20000); cmp(-20000, 10000); cmp( 10000000L, -10000000L); cmp( 10000000L, -20000000L); cmp( 20000000L, -10000000L); cmp(-10000000L, 10000000L); cmp(-10000000L, 20000000L); cmp(-20000000L, 10000000L); cmp( 0, 1024); cmp( 0, -1024); cmp( 1024, 0); cmp(-1024, 0); cmp(1024, 1024); cmp(1024, 1025); cmp(1025, 1024); cmp(-1024, -1024); cmp(-1024, -1025); cmp(-1025, -1024); cmp( 1024, -1024); cmp( 1024, -1025); cmp( 1025, -1024); cmp(-1024, 1024); cmp(-1024, 1025); cmp(-1025, 1024); cmpz(0); cmpz(1); cmpz(255); cmpz(256); cmpz(10000); cmpz(20000); cmpz(-1); cmpz(-255); cmpz(-256); cmpz(-10000); cmpz(-20000); cmp1(0); cmp1(1); cmp1(2); cmp1(3); cmp1(255); cmp1(256); cmp1(10000); cmp1(20000); cmp1(-1); cmp1(-2); cmp1(-3); cmp1(-255); cmp1(-256); cmp1(-10000); cmp1(-20000); return 0; }