diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ld-lua.c | 172 |
1 files changed, 129 insertions, 43 deletions
diff --git a/src/ld-lua.c b/src/ld-lua.c index 67b9435..4cab71c 100644 --- a/src/ld-lua.c +++ b/src/ld-lua.c @@ -77,6 +77,7 @@ struct _LdLuaDrawData { LdLuaSymbol *symbol; cairo_t *cr; + unsigned save_count; }; static void ld_lua_finalize (GObject *gobject); @@ -91,16 +92,26 @@ static int process_registration (lua_State *L); static gchar *get_translation (lua_State *L, int index); static gboolean read_symbol_area (lua_State *L, int index, LdSymbolArea *area); -static void push_cairo_object (lua_State *L, cairo_t *cr); +static void push_cairo_object (lua_State *L, LdLuaDrawData *draw_data); static gdouble get_cairo_scale (cairo_t *cr); +static int ld_lua_cairo_save (lua_State *L); +static int ld_lua_cairo_restore (lua_State *L); static int ld_lua_cairo_get_line_width (lua_State *L); static int ld_lua_cairo_set_line_width (lua_State *L); static int ld_lua_cairo_move_to (lua_State *L); static int ld_lua_cairo_line_to (lua_State *L); +static int ld_lua_cairo_curve_to (lua_State *L); +static int ld_lua_cairo_arc (lua_State *L); +static int ld_lua_cairo_arc_negative (lua_State *L); +static int ld_lua_cairo_new_path (lua_State *L); +static int ld_lua_cairo_new_sub_path (lua_State *L); +static int ld_lua_cairo_close_path (lua_State *L); static int ld_lua_cairo_stroke (lua_State *L); static int ld_lua_cairo_stroke_preserve (lua_State *L); static int ld_lua_cairo_fill (lua_State *L); static int ld_lua_cairo_fill_preserve (lua_State *L); +static int ld_lua_cairo_clip (lua_State *L); +static int ld_lua_cairo_clip_preserve (lua_State *L); static luaL_Reg ld_lua_logdiag_lib[] = @@ -111,14 +122,24 @@ static luaL_Reg ld_lua_logdiag_lib[] = static luaL_Reg ld_lua_cairo_table[] = { + {"save", ld_lua_cairo_save}, + {"restore", ld_lua_cairo_restore}, {"get_line_width", ld_lua_cairo_get_line_width}, {"set_line_width", ld_lua_cairo_set_line_width}, {"move_to", ld_lua_cairo_move_to}, {"line_to", ld_lua_cairo_line_to}, + {"curve_to", ld_lua_cairo_curve_to}, + {"arc", ld_lua_cairo_arc}, + {"arc_negative", ld_lua_cairo_arc_negative}, + {"new_path", ld_lua_cairo_new_path}, + {"new_sub_path", ld_lua_cairo_new_sub_path}, + {"close_path", ld_lua_cairo_close_path}, {"stroke", ld_lua_cairo_stroke}, {"stroke_preserve", ld_lua_cairo_stroke_preserve}, {"fill", ld_lua_cairo_fill}, {"fill_preserve", ld_lua_cairo_fill_preserve}, + {"clip", ld_lua_cairo_clip}, + {"clip_preserve", ld_lua_cairo_clip_preserve}, {NULL, NULL} }; @@ -304,12 +325,16 @@ ld_lua_private_draw (LdLua *self, LdLuaSymbol *symbol, cairo_t *cr) data.symbol = symbol; data.cr = cr; + data.save_count = 0; if (lua_cpcall (self->priv->L, ld_lua_private_draw_cb, &data)) { g_warning ("Lua error: %s", lua_tostring (self->priv->L, -1)); lua_pop (self->priv->L, 1); } + + while (data.save_count--) + cairo_restore (cr); } static int @@ -329,7 +354,7 @@ ld_lua_private_draw_cb (lua_State *L) luaL_checktype (L, -1, LUA_TFUNCTION); /* Call the function do draw the symbol. */ - push_cairo_object (L, data->cr); + push_cairo_object (L, data); lua_pcall (L, 1, 0, 0); return 0; } @@ -541,7 +566,7 @@ read_symbol_area (lua_State *L, int index, LdSymbolArea *area) /* ===== Cairo ============================================================= */ static void -push_cairo_object (lua_State *L, cairo_t *cr) +push_cairo_object (lua_State *L, LdLuaDrawData *draw_data) { luaL_Reg *fn; @@ -556,7 +581,7 @@ push_cairo_object (lua_State *L, cairo_t *cr) */ for (fn = ld_lua_cairo_table; fn->name; fn++) { - lua_pushlightuserdata (L, cr); + lua_pushlightuserdata (L, draw_data); lua_pushcclosure (L, fn->func, 1); lua_setfield (L, -2, fn->name); } @@ -571,98 +596,159 @@ get_cairo_scale (cairo_t *cr) return dx; } -/* TODO: More functions. Possibly put it into another file - * and generate it automatically. - */ +#define LD_LUA_CAIRO_TRIVIAL(name) \ +static int \ +ld_lua_cairo_ ## name (lua_State *L) \ +{ \ + LdLuaDrawData *data; \ + data = lua_touserdata (L, lua_upvalueindex (1)); \ + cairo_ ## name (data->cr); \ + return 0; \ +} + +LD_LUA_CAIRO_TRIVIAL (new_path) +LD_LUA_CAIRO_TRIVIAL (new_sub_path) +LD_LUA_CAIRO_TRIVIAL (close_path) + +LD_LUA_CAIRO_TRIVIAL (stroke) +LD_LUA_CAIRO_TRIVIAL (stroke_preserve) +LD_LUA_CAIRO_TRIVIAL (fill) +LD_LUA_CAIRO_TRIVIAL (fill_preserve) +LD_LUA_CAIRO_TRIVIAL (clip) +LD_LUA_CAIRO_TRIVIAL (clip_preserve) + +static int +ld_lua_cairo_save (lua_State *L) +{ + LdLuaDrawData *data; + + data = lua_touserdata (L, lua_upvalueindex (1)); + if (data->save_count + 1) + { + data->save_count++; + cairo_save (data->cr); + } + return 0; +} + +static int +ld_lua_cairo_restore (lua_State *L) +{ + LdLuaDrawData *data; + + data = lua_touserdata (L, lua_upvalueindex (1)); + if (data->save_count) + { + data->save_count--; + cairo_restore (data->cr); + } + return 0; +} + static int ld_lua_cairo_get_line_width (lua_State *L) { - cairo_t *cr; + LdLuaDrawData *data; - cr = lua_touserdata (L, lua_upvalueindex (1)); - lua_pushnumber (L, cairo_get_line_width (cr) * get_cairo_scale (cr)); + data = lua_touserdata (L, lua_upvalueindex (1)); + lua_pushnumber (L, cairo_get_line_width (data->cr) + * get_cairo_scale (data->cr)); return 1; } static int ld_lua_cairo_set_line_width (lua_State *L) { - cairo_t *cr; - lua_Number width; + LdLuaDrawData *data; - cr = lua_touserdata (L, lua_upvalueindex (1)); - width = luaL_checknumber (L, 1); - cairo_set_line_width (cr, width / get_cairo_scale (cr)); + data = lua_touserdata (L, lua_upvalueindex (1)); + cairo_set_line_width (data->cr, luaL_checknumber (L, 1) + / get_cairo_scale (data->cr)); return 0; } static int ld_lua_cairo_move_to (lua_State *L) { - cairo_t *cr; + LdLuaDrawData *data; lua_Number x, y; - cr = lua_touserdata (L, lua_upvalueindex (1)); + data = lua_touserdata (L, lua_upvalueindex (1)); x = luaL_checknumber (L, 1); y = luaL_checknumber (L, 2); - cairo_move_to (cr, x, y); + cairo_move_to (data->cr, x, y); return 0; } static int ld_lua_cairo_line_to (lua_State *L) { - cairo_t *cr; + LdLuaDrawData *data; lua_Number x, y; - cr = lua_touserdata (L, lua_upvalueindex (1)); + data = lua_touserdata (L, lua_upvalueindex (1)); + x = luaL_checknumber (L, 1); y = luaL_checknumber (L, 2); - cairo_line_to (cr, x, y); + + cairo_line_to (data->cr, x, y); return 0; } static int -ld_lua_cairo_stroke (lua_State *L) +ld_lua_cairo_curve_to (lua_State *L) { - cairo_t *cr; + LdLuaDrawData *data; + lua_Number x1, y1, x2, y2, x3, y3; - cr = lua_touserdata (L, lua_upvalueindex (1)); - cairo_stroke (cr); - return 0; -} + data = lua_touserdata (L, lua_upvalueindex (1)); -static int -ld_lua_cairo_stroke_preserve (lua_State *L) -{ - cairo_t *cr; + x1 = luaL_checknumber (L, 1); + y1 = luaL_checknumber (L, 2); + x2 = luaL_checknumber (L, 3); + y2 = luaL_checknumber (L, 4); + x3 = luaL_checknumber (L, 5); + y3 = luaL_checknumber (L, 6); - cr = lua_touserdata (L, lua_upvalueindex (1)); - cairo_stroke_preserve (cr); + cairo_curve_to (data->cr, x1, y1, x2, y2, x3, y3); return 0; } static int -ld_lua_cairo_fill (lua_State *L) +ld_lua_cairo_arc (lua_State *L) { - cairo_t *cr; + LdLuaDrawData *data; + lua_Number xc, yc, radius, angle1, angle2; + + data = lua_touserdata (L, lua_upvalueindex (1)); + + xc = luaL_checknumber (L, 1); + yc = luaL_checknumber (L, 2); + radius = luaL_checknumber (L, 3); + angle1 = luaL_checknumber (L, 4); + angle2 = luaL_checknumber (L, 5); - cr = lua_touserdata (L, lua_upvalueindex (1)); - cairo_fill (cr); + cairo_arc (data->cr, xc, yc, radius, angle1, angle2); return 0; } static int -ld_lua_cairo_fill_preserve (lua_State *L) +ld_lua_cairo_arc_negative (lua_State *L) { - cairo_t *cr; + LdLuaDrawData *data; + lua_Number xc, yc, radius, angle1, angle2; - cr = lua_touserdata (L, lua_upvalueindex (1)); - cairo_fill_preserve (cr); - return 0; -} + data = lua_touserdata (L, lua_upvalueindex (1)); + xc = luaL_checknumber (L, 1); + yc = luaL_checknumber (L, 2); + radius = luaL_checknumber (L, 3); + angle1 = luaL_checknumber (L, 4); + angle2 = luaL_checknumber (L, 5); + cairo_arc_negative (data->cr, xc, yc, radius, angle1, angle2); + return 0; +} |