1libcaca-migrating(3caca) libcaca libcaca-migrating(3caca)
2
3
4
6 libcaca-migrating - Migrating from libcaca 0.x to the 1.0 API This
7 section will guide you through the migration of a libcaca 0.x
8 application to the latest API version.
9
11 The most important change in the 1.0 API of libcaca is the object-
12 oriented design. See these two examples for a rough idea of what
13 changed:
14
15 #include <caca.h>
16
17 /* libcaca program - 0.x API */
18 int main(void)
19 {
20 /* Initialise libcaca */
21 caca_init();
22 /* Set window title */
23 caca_set_window_title("Window");
24 /* Choose drawing colours */
25 caca_set_color(CACA_COLOR_BLACK,
26 CACA_COLOR_WHITE);
27 /* Draw a string at (0, 0) */
28 caca_putstr(0, 0, "Hello world!");
29 /* Refresh display */
30 caca_refresh();
31 /* Wait for a key press event */
32 caca_wait_event(CACA_EVENT_KEY_PRESS);
33 /* Clean up library */
34 caca_end();
35
36 return 0;
37 }
38
39 #include <caca.h>
40
41 /* libcaca program - 1.0 API */
42 int main(void)
43 {
44 /* Initialise libcaca */
45 caca_canvas_t *cv;
46 caca_display_t *dp;
47 dp = caca_create_display(NULL);
48 cv = caca_get_canvas(dp);
49 /* Set window title */
50 caca_set_display_title(dp, "Window");
51 /* Choose drawing colours */
52 caca_set_color_ansi(cv, CACA_BLACK,
53 CACA_WHITE);
54 /* Draw a string at (0, 0) */
55 caca_put_str(cv, 0, 0, "Hello world!");
56 /* Refresh display */
57 caca_refresh_display();
58 /* Wait for a key press event */
59 caca_get_event(dp, CACA_EVENT_KEY_PRESS,
60 NULL, -1);
61 /* Clean up library */
62 caca_free_display(dp);
63
64 return 0;
65 }
66
67
68 Note the following important things:
69
70 • Most functions now take an object handle as their first argument.
71
73 You have two ways to migrate your application to use libcaca 1.x:
74
75 • Port your code using the function equivalence list. This is the
76 preferred way because new functions are thread safe and offer much
77 more features to both the programmer and the end user.
78
79 • Use the legacy compatibility layer.
80
81 Using the compatibility layer is as easy as adding the following three
82 lines:
83
84 #include <caca.h>
85
86 /* libcaca program - 0.x API */
87 ...
88
89 #include <caca.h>
90 #ifdef CACA_API_VERSION_1
91 # include <caca0.h>
92 #endif
93
94 /* libcaca program - 0.x API */
95 ...
96
97
98 The modified code is guaranteed to build both with libcaca 0.x and
99 libcaca 1.0.
100
102 Basic functions
103 • caca_init(): use caca_create_canvas() to create a libcaca canvas,
104 followed by caca_create_display() to attach a libcaca display to it.
105 Alternatively, caca_create_display() with a NULL argument will create
106 a canvas automatically.
107
108 • caca_set_delay(): use caca_set_display_time().
109
110 • caca_get_feature(): deprecated.
111
112 • caca_set_feature(): deprecated, see caca_set_dither_antialias(),
113 caca_set_dither_color() and caca_set_dither_mode() instead.
114
115 • caca_get_feature_name(): deprecated, see caca_get_dither_mode_list(),
116 caca_get_dither_antialias_list() and caca_get_dither_color_list()
117 instead.
118
119 • caca_get_rendertime(): use caca_get_display_time().
120
121 • caca_get_width(): use caca_get_canvas_width().
122
123 • caca_get_height(): use caca_get_canvas_height().
124
125 • caca_set_window_title(): use caca_set_display_title().
126
127 • caca_get_window_width(): use caca_get_display_width().
128
129 • caca_get_window_height(): use caca_get_display_height().
130
131 • caca_refresh(): use caca_refresh_display().
132
133 • caca_end(): use caca_free_display() to detach the libcaca display,
134 followed by caca_free_canvas() to free the underlying libcaca canvas.
135 Alternatively, if the canvas was created by caca_create_display(), it
136 will be automatically destroyed by caca_free_display().
137
138 Event handling
139 • caca_get_event(): unchanged, but the event information retrieval
140 changed a lot.
141
142 • caca_wait_event(): use caca_get_event() with a timeout argument of
143 -1.
144
145 • caca_get_mouse_x(): unchanged.
146
147 • caca_get_mouse_y(): unchanged.
148
149 Character printing
150 • caca_set_color(): use caca_set_color_ansi() or caca_set_color_argb().
151
152 • caca_get_fg_color(): use caca_get_attr().
153
154 • caca_get_bg_color(): use caca_get_attr().
155
156 • caca_get_color_name(): this function is now deprecated due to major
157 uselessness.
158
159 • caca_putchar(): use caca_put_char().
160
161 • caca_putstr(): use caca_put_str().
162
163 • caca_printf(): unchanged.
164
165 • caca_clear(): use caca_clear_canvas().
166
167 Primitives drawing
168 These functions are almost unchanged, except for Unicode support and
169 the fact that they now act on a given canvas.
170
171 • caca_draw_line(): unchanged.
172
173 • caca_draw_polyline(): unchanged.
174
175 • caca_draw_thin_line(): unchanged.
176
177 • caca_draw_thin_polyline(): unchanged.
178
179 • caca_draw_circle(): unchanged.
180
181 • caca_draw_ellipse(): unchanged.
182
183 • caca_draw_thin_ellipse(): unchanged.
184
185 • caca_fill_ellipse(): unchanged.
186
187 • caca_draw_box(): unchanged, but the argument meaning changed (width
188 and height instead of corner coordinates).
189
190 • caca_draw_thin_box(): use caca_draw_thin_box() or
191 caca_draw_cp437_box(), also the argument meaning changed (width and
192 height instead of corner coordinates).
193
194 • caca_fill_box(): unchanged, but the argument meaning changed (width
195 and height instead of corner coordinates).
196
197 • caca_draw_triangle(): unchanged.
198
199 • caca_draw_thin_triangle(): unchanged.
200
201 • caca_fill_triangle(): unchanged.
202
203 Mathematical functions
204 • caca_rand(): unchanged, but the second argument is different, make
205 sure you take that into account.
206
207 • caca_sqrt(): this function is now deprecated, use your system's
208 sqrt() call instead.
209
210 Sprite handling
211 The newly introduced canvases can have several frames. Sprites are
212 hence completely deprecated.
213
214 • caca_load_sprite(): use caca_import_file().
215
216 • caca_get_sprite_frames(): use caca_get_frame_count().
217
218 • caca_get_sprite_width(): use caca_get_canvas_width().
219
220 • caca_get_sprite_height(): use caca_get_canvas_height().
221
222 • caca_get_sprite_dx(): use caca_get_canvas_handle_x().
223
224 • caca_get_sprite_dy(): use caca_get_canvas_handle_y().
225
226 • caca_draw_sprite(): use caca_set_frame() and caca_blit().
227
228 • caca_free_sprite(): use caca_free_canvas().
229
230 Bitmap handling
231 Bitmaps have been renamed to dithers, because these objects do not in
232 fact store any pixels, they just have information on how bitmaps will
233 be dithered.
234
235 • caca_create_bitmap(): use caca_create_dither().
236
237 • caca_set_bitmap_palette(): use caca_set_dither_palette().
238
239 • caca_draw_bitmap(): use caca_dither_bitmap().
240
241 • caca_free_bitmap(): use caca_free_dither().
242
244 The caca-config utility is deprecated in favour of the standard pkg-
245 config interface:
246
247 gcc -c foobar.c -o foobar.o `pkg-config --cflags caca`
248 gcc foobar.o -o foobar `pkg-config --libs caca`
249
250 caca-config is still provided as a convenience tool but may be removed
251 in the future.
252
253
254
255Version 0.99.beta20 Thu Jul 21 2022 libcaca-migrating(3caca)