installing gworkspace now with everything from svn, the initial problem seems
to be gone.
I ran the tests with --debug, and examined the test a bit, that Fred pointed me
to investigate, below is what gdb gives me, I hope it helps. Otherwise, where
else should I set a breakpoint and examine values?
Sebastian
(gdb) bt
#0 CHECK (view=0x7f020904, frame=
{origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}})
at NSView_autoresize_and_rounding.m:26
#1 0x1c0020c2 in gnustep_base_user_main (argc=1, argv=0xcfbd4ff4) at
NSView_autoresize_and_rounding.m:81
#2 0x08517267 in main (argc=1, argv=0xcfbd4ff4, env=0xcfbd4ffc) at
NSProcessInfo.m:979
#3 0x1c000c97 in ___start ()
#4 0x1c000c12 in _start ()
(gdb) print view
$1 = (class NSView *) 0x7f020904
(gdb) po view
h=-&- v=---<NSView: 0x7f020904> f={x = 10; y = 10; width = 9; height = 10}
b={x = 0; y = 0; width = 9; height = 10}
(gdb) frame 0
#0 CHECK (view=0x7f020904, frame=
{origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}})
at NSView_autoresize_and_rounding.m:26
26 printf("(1) expected frame (%g %g)+(%g %g), got (%g %g)+(%g
%g)\n",
(gdb) list
21 if (fabs(r.origin.x - frame.origin.x)>0.001
22 || fabs(r.origin.y - frame.origin.y)>0.001
23 || fabs(r.size.width - frame.size.width)>0.001
24 || fabs(r.size.height - frame.size.height)>0.001)
25 {
26 printf("(1) expected frame (%g %g)+(%g %g), got (%g %g)+(%g
%g)\n",
27 frame.origin.x, frame.origin.y,
frame.size.width, frame.size.height,
28 r.origin.x, r.origin.y, r.size.width,
r.size.height);
29
30 return 0;
(gdb) print fabs(r.origin.x - frame.origin.x)
$3 = 1006647832
(gdb) print fabs(r.origin.y - frame.origin.y)
$4 = 1006647832
(gdb) print fabs(r.size.width - frame.size.width)
$5 = 1006647832
(gdb) print fabs(r.size.height - frame.size.height)
$6 = 1006647832
(gdb) print r.origin.x
$7 = 10
(gdb) print frame.origin.x
$8 = -6.35119002e+09
(gdb) print r.origin.y
$9 = 10
(gdb) print frame.origin.y
$10 = -6.35128422e+09
(gdb) print r.size.width
$11 = 9
(gdb) print frame.size.width
$12 = 1.72846451e+38
(gdb) print r.size.height
$13 = 10
(gdb) print frame.size.height
$14 = -6.35128832e+09
(gdb)
$15 = -6.35128832e+09
(gdb) print frame
$16 = {origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}}
(gdb)
here the other failing test:
Breakpoint 5, CHECK (view=0x7f020904, frame=
{origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}})
at NSView_autoresize_and_rounding.m:26
26 printf("(1) expected frame (%g %g)+(%g %g), got (%g %g)+(%g
%g)\n",
(gdb) bt
#0 CHECK (view=0x7f020904, frame=
{origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}})
at NSView_autoresize_and_rounding.m:26
#1 0x1c003d2e in gnustep_base_user_main (argc=1, argv=0xcfbd4ff4) at
NSView_autoresize_and_rounding.m:187
#2 0x08517267 in main (argc=1, argv=0xcfbd4ff4, env=0xcfbd4ffc) at
NSProcessInfo.m:979
#3 0x1c000c97 in ___start ()
#4 0x1c000c12 in _start ()
(gdb) bt
#0 CHECK (view=0x7f020904, frame=
{origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}})
at NSView_autoresize_and_rounding.m:26
#1 0x1c003d2e in gnustep_base_user_main (argc=1, argv=0xcfbd4ff4) at
NSView_autoresize_and_rounding.m:187
#2 0x08517267 in main (argc=1, argv=0xcfbd4ff4, env=0xcfbd4ffc) at
NSProcessInfo.m:979
#3 0x1c000c97 in ___start ()
#4 0x1c000c12 in _start ()
(gdb) frame 0
#0 CHECK (view=0x7f020904, frame=
{origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}})
at NSView_autoresize_and_rounding.m:26
26 printf("(1) expected frame (%g %g)+(%g %g), got (%g %g)+(%g
%g)\n",
(gdb) list
21 if (fabs(r.origin.x - frame.origin.x)>0.001
22 || fabs(r.origin.y - frame.origin.y)>0.001
23 || fabs(r.size.width - frame.size.width)>0.001
24 || fabs(r.size.height - frame.size.height)>0.001)
25 {
26 printf("(1) expected frame (%g %g)+(%g %g), got (%g %g)+(%g
%g)\n",
27 frame.origin.x, frame.origin.y,
frame.size.width, frame.size.height,
28 r.origin.x, r.origin.y, r.size.width,
r.size.height);
29
30 return 0;
(gdb) print fabs(r.origin.x - frame.origin.x)
$17 = 1006647832
(gdb) print fabs(r.origin.y - frame.origin.y)
$18 = 1006647832
(gdb) print fabs(r.size.width - frame.size.width)
$19 = 1006647832
(gdb) print fabs(r.size.height - frame.size.height)
$20 = 1006647832
(gdb) print r.origin.x
$21 = 9
(gdb) print r.origin.y
$22 = 9
(gdb) print r.size.width
$23 = 9
(gdb) print r.size.height
$24 = 9
(gdb) print frame.origin.x
$25 = -6.35119002e+09
(gdb) print frame.origin.y
$26 = -6.35128422e+09
(gdb) print frame.size.width
$27 = 1.72846451e+38
(gdb) print frame.size.height
$28 = -6.35128832e+09
(gdb) po view
h=&&& v=&&& <NSView: 0x7f020904> f={x = 9; y = 9; width = 9; height = 9}
b={x = 0; y = 0; width = 9; height = 9}
(gdb) print frame
$29 = {origin = {x = -6.35119002e+09, y = -6.35128422e+09}, size = {width =
1.72846451e+38, height = -6.35128832e+09}}
(gdb) c
Continuing.
(1) expected frame (10 10)+(10 10), got (9 9)+(9 9)
Failed test: NSView autoresize rounding works