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 | | |
65 | | |
66 | | |
67 | | |
68 | | |
69 | | |
70 | | |
71 | | |
72 | | |
73 | | |
74 | | |
75 | | |
76 | | |
77 | | |
78 | | |
79 | | |
80 | | |
81 | | |
82 | | |
83 | | |
84 | | |
85 | | |
86 | | |
87 | | |
88 | | |
89 | | |
90 | | |
91 | | |
92 | | |
93 | | |
94 | | |
95 | | |
96 | | |
97 | | |
98 | | |
99 | | |
100 | | |
101 | | |
102 | | |
103 | | |
104 | | |
105 | | |
106 | | |
107 | | |
108 | | |
109 | | |
110 | | |
111 | | |
112 | | |
113 | | |
114 | | |
115 | | |
116 | | |
117 | | |
118 | | |
119 | | |
120 | | |
121 | | |
122 | | |
123 | | |
124 | | |
125 | | |
126 | | |
127 | | |
128 | | |
129 | | |
130 | | |
131 | | |
132 | | |
133 | | |
134 | | |
135 | | |
136 | | |
137 | | |
138 | | |
139 | | |
140 | | |
141 | | |
142 | | |
143 | | |
144 | | |
145 | | |
146 | | |
147 | | |
148 | | |
149 | | |
150 | | |
151 | | |
152 | | |
153 | | |
154 | | |
155 | | |
156 | | |
157 | | |
158 | | |
159 | | |
160 | | |
161 | | |
162 | | |
163 | | |
164 | | |
165 | | |
166 | | |
167 | | |
168 | | |
169 | | |
170 | | |
171 | | |
172 | | |
173 | | |
174 | | |
175 | | |
176 | | |
177 | | |
178 | | |
179 | | |
180 | | |
181 | | |
182 | | |
183 | | |
184 | | |
185 | | |
186 | | |
187 | | |
188 | | |
189 | | |
190 | | |
191 | | |
192 | | |
193 | | |
194 | | |
195 | | |
196 | | |
197 | | |
198 | | |
199 | | |
200 | | |
201 | | |
202 | | |
203 | | |
204 | | |
205 | | |
206 | | |
207 | | |
208 | | |
209 | | |
210 | | |
211 | | |
212 | | |
213 | | |
214 | | |
215 | | |
216 | | |
217 | | |
218 | | |
219 | | |
| test_any([[# 1 "-" | | | #7 "testsuite.in.in" | object img1=Image.PNM.decode("P1\n5 5\n0 1 1 1 1\n1 0 1 1 1\n1 1 0 1 1\n1 1 1 0 1\n1 1 1 1 0"); | object img2=Image.PNM.decode("P4\n5 5\nx¸Øèð"); | if (img1!=img2) return ( "differ\n" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #13 "testsuite.in.in" | if ("hejsan, hoppsan" != MIME.decode_base64("aGVqc2FuLCBob3Bwc2Fu\n")) | return ( "differ" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #18 "testsuite.in.in" | object img1=Image.GIF.decode(MIME.decode_base64("R0lGODlhBQAFAIAAAAAAAP///ywAAAAABQAFAAACCAxwEWrY8BwoADs=")); | object img2=Image.PNM.decode("P4\n5 5\nx\00èØèð"); | if (img1!=img2) return ( "differ\n" ); | return "ok"; | | | ]], "ok") | test_any([[# 1 "-" | | | #27 "testsuite.in.in" | object img=Image.image(); | if (!img || | img->xsize() || | img->ysize()) return ( "have size" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #34 "testsuite.in.in" | object img=Image.image(100,100); | if (!img || | img->xsize()!=100 || | img->ysize()!=100) return ( "wrong size" ); | if (img!=0) return ( "wrong color" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #42 "testsuite.in.in" | int x=1; while ((x<<1)>0) x=(x<<1)+1; | if (!catch { Image.image(x,2); }) return ( x+"x2 permitted" ); | if (!catch { Image.image(x/32768,65537); }) return ( (x/32768)+"x65537 permitted" ); | if (!catch { Image.image(x/(32768*3),65537); }) return ( (x/(32768*3))+"x65537 permitted" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #49 "testsuite.in.in" | object img=Image.image(1000,1000,17,42,96); | if (!img || | img->xsize()!=1000 || | img->ysize()!=1000) return ( "wrong size" ); | if (img!=({17,42,96})) return ( "wrong color" ); | return "ok"; | | | ]], "ok") | test_any([[# 1 "-" | | | #60 "testsuite.in.in" | object img=Image.image(10,10); | img=img->test(); | if (equal(img->max(),({0,0,0}))) return ( "failed" ); | img->setpixel(2,2,0,255,0); | if (img==img->invert()) return ( "failed" ); | return "ok"; | | | ]], "ok") | test_any([[# 1 "-" | | | #71 "testsuite.in.in" | object img=Image.image(100,100)->test(); | if (img!=img->copy()) return ( "differ" ); | if (img->copy(25,25,75,75)!=img->copy(25,25,75,75)) return ( "subregion differ" ); | if (img->copy(25,25,75,75)==img) return ( "subregion doesn't differ" ); | img->setpixel(2,2,0,255,0); | if (img->copy()==img->invert()->copy()) return ( "copy of other doesn't differ" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #80 "testsuite.in.in" | object img=Image.image(100,100)->test(); | if (img->clear()==img) return ( "doesn't differ" ); | if (img->clear(0,0,0)!=0) return ( "wrong color (black)" ); | if (img->clear(1,255,0)!=({1,255,0})) return ( "wrong color (color)" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #87 "testsuite.in.in" | object img=Image.image(100,100)->test(); | if (img!=img->clone()) return ( "differ" ); | img->setpixel(2,2,0,255,0); | if (img->clone()==img->invert()->clone()) return ( "clone of other doesn't differ" ); | return "ok"; | | | ]], "ok") | test_any([[# 1 "-" | | | #97 "testsuite.in.in" | array a=({0,0,0}); | array b=copy_value(a); b[0]=17; b[1]=42; b[2]=128; | if (!equal( ({0,0,0}), a)) return ( "differ (1)" ); | if (!equal( ({17,42,128}), b)) return ( "differ (2)" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #104 "testsuite.in.in" | if (!equal( ({0,0,0}), | Image.image(10,10,0,0,0)->max() )) | return ( "erranous (1)" ); | if (!equal( ({17,42,36}), | Image.image(10,10,17,42,36)->max() )) | return ( "erranous (2)" ); | if (!equal( ({17,42,36}), | Image.image(10,10,0,0,0) | ->setpixel(5,5,17,42,36)->max() )) | return ( "erranous (3)" ); | if (!equal( ({17,42,36}), | Image.image(10,10,0,0,0) | ->setpixel(2,2,1,2,3) | ->setpixel(3,3,17,42,36) | ->setpixel(4,4,3,2,1) | ->max())) | return ( "erranous (4)" ); | return "ok"; | | | ]], "ok") | test_any([[# 1 "-" | | | #127 "testsuite.in.in" | object img=Image.image(10,10,255,0,0); | if (!equal(img->getpixel(5,5),({255,0,0}))) return ( "getpixel erranous" ); | img->setpixel(5,5,1,2,3); | if (!equal(img->getpixel(5,5),({1,2,3}))) return ( "failed" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #134 "testsuite.in.in" | object img=Image.image(10,10,255,0,0); | img->setpixel(5,5,0,255,0,127); | if (!equal(img->getpixel(5,5),({127,128,0}))) return ( "failed" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #140 "testsuite.in.in" | object img=Image.image(100,100,0,0,0); | foreach (({40,50,60}),int z) | { | img->line(50-z,0,50,50,255,255,255); | img->line(50-z,100,50,50,255,255,255); | img->line(0,50-z,50,50,255,255,255); | img->line(100,50-z,50,50,255,255,255); | } | object img1=Image.GIF.decode(MIME.decode_base64( | "R0lGODlhZABkAIAAAAAAAP///ywAAAAAZABkAAAC/wxwCGaq/l6UktZ6Mdat9sdsmziOpWl6WPMp\r\nYZrCcTxLLfLdi07Tve9brFQeXjB4RIKGQ5tQqYRGccTN7TWdZlPXWNeo1Wq7zqoLLBYjyWZXUa1W\r\ns526Kzoeby5H2L37npfn5kcUEGDY1icoqEe10qL4dMbIaFXW9pcIWBkFacknOTjJWenZaHWoSSpo\r\narO50yr0uvrpeBmkmDNLe1s3FhqayquUc0osLLozjEuIs4va+8xZfJt3SO28bIKdzNjXgaxdNTcd\r\nDi4dB+6qbT4qbhu73J79rt7Mjnwubt9dn99Pip+yd48GhVvF4h5BEPYOlrIFbOEbRw6tQUTH6xpF\r\njP9N9En0ISyhN3gfj1FkRbKkSVkcqQhUiSthRWYsWpZMxQDdC5swcUaksROmtxC7ggodKovmwKMP\r\nNQKNxJTVtTs+o9KaygWq1aEzYfHcuq2iU7D4IHUlG9DcV7RP3bElqPUtO7k36X5ca9fL2byl9vKV\r\nivfvo8CCXREu7CwuYjFEFwdM6rjpz8i/FFOO+eTwX5Ga+XK+nO4kaMaiR3cSOdn0NlGd6fJrLfe1\r\namKsZ2O+aBsoIdhoufEm6zu3l93Cwzb7bTUe8qjKi9eCmFp4c+fr7i0XSi767OzXe2LqrpI7dbfQ\r\noUs3pn20L0y511c7zx488+fjFaaHz74+D/lH99cJR2+efqD890ABADs=")); | if (img!=img1) return ( "differ" ); | return "ok"; | | ]], "ok") | test_any([[# 1 "-" | | | #154 "testsuite.in.in" | object img=Image.image(100,100,0,0,0); | img->line(40,0,0,40); | if (!equal( ({0,0,0}), img->max() )) return ( "differ (reset)" ); | img->line(10,10,20,20,128,13,42); | if (!equal( ({128,13,42}), img->max() )) return ( "differ (direct)" ); | img->setcolor(200,19,99); | img->line(30,20,20,30); | if (!equal( ({200,19,99}), img->max() )) return ( "differ (setcolor)" ); | return "ok"; | | | ]], "ok") | | |
|