2009-09-10 13:14:53 -04:00
|
|
|
require_relative 'test_base'
|
2005-02-04 08:35:37 -05:00
|
|
|
require 'dl/func'
|
|
|
|
|
|
|
|
module DL
|
|
|
|
class TestFunc < TestBase
|
2009-12-06 19:49:09 -05:00
|
|
|
def test_name
|
|
|
|
f = Function.new(CFunc.new(@libc['strcpy'], TYPE_VOIDP, 'strcpy'),
|
|
|
|
[TYPE_VOIDP, TYPE_VOIDP])
|
|
|
|
assert_equal 'strcpy', f.name
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_to_i
|
|
|
|
cfunc = CFunc.new(@libc['strcpy'], TYPE_VOIDP, 'strcpy')
|
|
|
|
f = Function.new(cfunc, [TYPE_VOIDP, TYPE_VOIDP])
|
|
|
|
assert_equal cfunc.to_i, f.to_i
|
|
|
|
end
|
|
|
|
|
2010-02-02 20:23:48 -05:00
|
|
|
def test_random
|
|
|
|
f = Function.new(CFunc.new(@libc['srand'], TYPE_VOID, 'srand'),
|
|
|
|
[-TYPE_LONG])
|
|
|
|
assert_nil f.call(10)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_sinf
|
2010-05-19 05:07:27 -04:00
|
|
|
begin
|
|
|
|
f = Function.new(CFunc.new(@libm['sinf'], TYPE_FLOAT, 'sinf'),
|
|
|
|
[TYPE_FLOAT])
|
|
|
|
rescue DL::DLError
|
|
|
|
skip "libm may not have sinf()"
|
|
|
|
end
|
2010-02-02 20:23:48 -05:00
|
|
|
assert_in_delta 1.0, f.call(90 * Math::PI / 180), 0.0001
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_sin
|
|
|
|
f = Function.new(CFunc.new(@libm['sin'], TYPE_DOUBLE, 'sin'),
|
|
|
|
[TYPE_DOUBLE])
|
|
|
|
assert_in_delta 1.0, f.call(90 * Math::PI / 180), 0.0001
|
|
|
|
end
|
|
|
|
|
2005-02-04 08:35:37 -05:00
|
|
|
def test_strcpy()
|
|
|
|
f = Function.new(CFunc.new(@libc['strcpy'], TYPE_VOIDP, 'strcpy'),
|
|
|
|
[TYPE_VOIDP, TYPE_VOIDP])
|
|
|
|
buff = "000"
|
|
|
|
str = f.call(buff, "123")
|
|
|
|
assert_equal("123", buff)
|
|
|
|
assert_equal("123", str.to_s)
|
|
|
|
end
|
|
|
|
|
2010-06-25 15:43:15 -04:00
|
|
|
def test_string()
|
|
|
|
stress, GC.stress = GC.stress, true
|
|
|
|
f = Function.new(CFunc.new(@libc['strcpy'], TYPE_VOIDP, 'strcpy'),
|
|
|
|
[TYPE_VOIDP, TYPE_VOIDP])
|
|
|
|
buff = "000"
|
|
|
|
str = f.call(buff, "123")
|
|
|
|
assert_equal("123", buff)
|
|
|
|
assert_equal("123", str.to_s)
|
|
|
|
ensure
|
|
|
|
GC.stress = stress
|
|
|
|
end
|
|
|
|
|
2005-02-04 08:35:37 -05:00
|
|
|
def test_isdigit()
|
|
|
|
f = Function.new(CFunc.new(@libc['isdigit'], TYPE_INT, 'isdigit'),
|
|
|
|
[TYPE_INT])
|
2008-08-30 10:39:21 -04:00
|
|
|
r1 = f.call(?1.ord)
|
|
|
|
r2 = f.call(?2.ord)
|
|
|
|
rr = f.call(?r.ord)
|
2005-02-04 08:35:37 -05:00
|
|
|
assert_positive(r1)
|
|
|
|
assert_positive(r2)
|
|
|
|
assert_zero(rr)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_atof()
|
2008-12-29 09:54:24 -05:00
|
|
|
f = Function.new(CFunc.new(@libc['atof'], TYPE_DOUBLE, 'atof'),
|
2005-02-04 08:35:37 -05:00
|
|
|
[TYPE_VOIDP])
|
|
|
|
r = f.call("12.34")
|
|
|
|
assert_match(12.00..13.00, r)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_strtod()
|
|
|
|
f = Function.new(CFunc.new(@libc['strtod'], TYPE_DOUBLE, 'strtod'),
|
|
|
|
[TYPE_VOIDP, TYPE_VOIDP])
|
2009-11-10 17:51:24 -05:00
|
|
|
buff1 = CPtr["12.34"]
|
|
|
|
buff2 = buff1 + 4
|
2009-11-13 02:19:59 -05:00
|
|
|
r = f.call(buff1, - buff2)
|
2009-11-12 17:41:07 -05:00
|
|
|
assert_in_delta(12.34, r, 0.001)
|
2005-02-04 08:35:37 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_qsort1()
|
|
|
|
cb = Function.new(CFunc.new(0, TYPE_INT, '<callback>qsort'),
|
|
|
|
[TYPE_VOIDP, TYPE_VOIDP]){|x,y| CPtr.new(x)[0] <=> CPtr.new(y)[0]}
|
|
|
|
qsort = Function.new(CFunc.new(@libc['qsort'], TYPE_VOID, 'qsort'),
|
|
|
|
[TYPE_VOIDP, TYPE_INT, TYPE_INT, TYPE_VOIDP])
|
|
|
|
buff = "9341"
|
|
|
|
qsort.call(buff, buff.size, 1, cb)
|
|
|
|
assert_equal("1349", buff)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_qsort2()
|
|
|
|
cb = TempFunction.new(CFunc.new(0, TYPE_INT, '<callback>qsort'),
|
|
|
|
[TYPE_VOIDP, TYPE_VOIDP])
|
|
|
|
qsort = Function.new(CFunc.new(@libc['qsort'], TYPE_VOID, 'qsort'),
|
|
|
|
[TYPE_VOIDP, TYPE_INT, TYPE_INT, TYPE_VOIDP])
|
|
|
|
buff = "9341"
|
|
|
|
qsort.call(buff, buff.size, 1, cb){|x,y| CPtr.new(x)[0] <=> CPtr.new(y)[0]}
|
|
|
|
assert_equal("1349", buff)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|