Merge branch 'gdkpixbuf' of https://github.com/psychon/awesome
This commit is contained in:
commit
b2d1e8574f
|
@ -35,7 +35,7 @@ const char commands[] =
|
||||||
" '0.8.0', require('lgi.version')))\n"
|
" '0.8.0', require('lgi.version')))\n"
|
||||||
"end\n"
|
"end\n"
|
||||||
"lgi = require('lgi')\n"
|
"lgi = require('lgi')\n"
|
||||||
"assert(lgi.cairo, lgi.Pango, lgi.PangoCairo, lgi.GLib, lgi.Gio)\n"
|
"assert(lgi.cairo, lgi.Pango, lgi.PangoCairo, lgi.GLib, lgi.Gio, lgi.GdkPixbuf)\n"
|
||||||
;
|
;
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
|
|
2
draw.c
2
draw.c
|
@ -81,7 +81,7 @@ draw_surface_from_data(int width, int height, uint32_t *data)
|
||||||
* \param buf The pixbuf
|
* \param buf The pixbuf
|
||||||
* \return Number of items pushed on the lua stack.
|
* \return Number of items pushed on the lua stack.
|
||||||
*/
|
*/
|
||||||
static cairo_surface_t *
|
cairo_surface_t *
|
||||||
draw_surface_from_pixbuf(GdkPixbuf *buf)
|
draw_surface_from_pixbuf(GdkPixbuf *buf)
|
||||||
{
|
{
|
||||||
int width = gdk_pixbuf_get_width(buf);
|
int width = gdk_pixbuf_get_width(buf);
|
||||||
|
|
4
draw.h
4
draw.h
|
@ -30,6 +30,9 @@
|
||||||
#include "common/array.h"
|
#include "common/array.h"
|
||||||
#include "common/util.h"
|
#include "common/util.h"
|
||||||
|
|
||||||
|
/* Forward definition */
|
||||||
|
typedef struct _GdkPixbuf GdkPixbuf;
|
||||||
|
|
||||||
typedef struct area_t area_t;
|
typedef struct area_t area_t;
|
||||||
struct area_t
|
struct area_t
|
||||||
{
|
{
|
||||||
|
@ -57,6 +60,7 @@ DO_ARRAY(cairo_surface_t *, cairo_surface, cairo_surface_array_destroy_surface)
|
||||||
cairo_surface_t *draw_surface_from_data(int width, int height, uint32_t *data);
|
cairo_surface_t *draw_surface_from_data(int width, int height, uint32_t *data);
|
||||||
cairo_surface_t *draw_dup_image_surface(cairo_surface_t *surface);
|
cairo_surface_t *draw_dup_image_surface(cairo_surface_t *surface);
|
||||||
cairo_surface_t *draw_load_image(lua_State *L, const char *path, GError **error);
|
cairo_surface_t *draw_load_image(lua_State *L, const char *path, GError **error);
|
||||||
|
cairo_surface_t *draw_surface_from_pixbuf(GdkPixbuf *buf);
|
||||||
|
|
||||||
xcb_visualtype_t *draw_find_visual(const xcb_screen_t *s, xcb_visualid_t visual);
|
xcb_visualtype_t *draw_find_visual(const xcb_screen_t *s, xcb_visualid_t visual);
|
||||||
xcb_visualtype_t *draw_default_visual(const xcb_screen_t *s);
|
xcb_visualtype_t *draw_default_visual(const xcb_screen_t *s);
|
||||||
|
|
|
@ -8,6 +8,7 @@ local setmetatable = setmetatable
|
||||||
local type = type
|
local type = type
|
||||||
local capi = { awesome = awesome }
|
local capi = { awesome = awesome }
|
||||||
local cairo = require("lgi").cairo
|
local cairo = require("lgi").cairo
|
||||||
|
local GdkPixbuf = require("lgi").GdkPixbuf
|
||||||
local color = nil
|
local color = nil
|
||||||
local gdebug = require("gears.debug")
|
local gdebug = require("gears.debug")
|
||||||
local hierarchy = require("wibox.hierarchy")
|
local hierarchy = require("wibox.hierarchy")
|
||||||
|
@ -36,7 +37,6 @@ end
|
||||||
-- @return The loaded surface, or the replacement default
|
-- @return The loaded surface, or the replacement default
|
||||||
-- @return An error message, or nil on success
|
-- @return An error message, or nil on success
|
||||||
function surface.load_uncached_silently(_surface, default)
|
function surface.load_uncached_silently(_surface, default)
|
||||||
local file
|
|
||||||
-- On nil, return some sane default
|
-- On nil, return some sane default
|
||||||
if not _surface then
|
if not _surface then
|
||||||
return get_default(default)
|
return get_default(default)
|
||||||
|
@ -47,12 +47,11 @@ function surface.load_uncached_silently(_surface, default)
|
||||||
end
|
end
|
||||||
-- Strings are assumed to be file names and get loaded
|
-- Strings are assumed to be file names and get loaded
|
||||||
if type(_surface) == "string" then
|
if type(_surface) == "string" then
|
||||||
local err
|
local pixbuf, err = GdkPixbuf.Pixbuf.new_from_file(_surface)
|
||||||
file = _surface
|
if not pixbuf then
|
||||||
_surface, err = capi.awesome.load_image(file)
|
return get_default(default), tostring(err)
|
||||||
if not _surface then
|
|
||||||
return get_default(default), err
|
|
||||||
end
|
end
|
||||||
|
_surface = capi.awesome.pixbuf_to_surface(pixbuf._native)
|
||||||
end
|
end
|
||||||
-- Everything else gets forced into a surface
|
-- Everything else gets forced into a surface
|
||||||
return cairo.Surface(_surface, true)
|
return cairo.Surface(_surface, true)
|
||||||
|
|
22
luaa.c
22
luaa.c
|
@ -281,6 +281,23 @@ luaA_sync(lua_State *L)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Translate a GdkPixbuf to a cairo image surface..
|
||||||
|
*
|
||||||
|
* @param pixbuf The pixbuf as a light user datum.
|
||||||
|
* @return A cairo surface as light user datum.
|
||||||
|
* @function pixbuf_to_surface
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
luaA_pixbuf_to_surface(lua_State *L)
|
||||||
|
{
|
||||||
|
GdkPixbuf *pixbuf = (GdkPixbuf *) lua_touserdata(L, 1);
|
||||||
|
cairo_surface_t *surface = draw_surface_from_pixbuf(pixbuf);
|
||||||
|
|
||||||
|
/* lua has to make sure to free the ref or we have a leak */
|
||||||
|
lua_pushlightuserdata(L, surface);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/** Load an image from a given path.
|
/** Load an image from a given path.
|
||||||
*
|
*
|
||||||
* @param name The file name.
|
* @param name The file name.
|
||||||
|
@ -292,6 +309,10 @@ luaA_sync(lua_State *L)
|
||||||
static int
|
static int
|
||||||
luaA_load_image(lua_State *L)
|
luaA_load_image(lua_State *L)
|
||||||
{
|
{
|
||||||
|
/* TODO: Deprecate this function, Lua can use GdkPixbuf directly plus
|
||||||
|
* awesome.pixbuf_to_surface
|
||||||
|
*/
|
||||||
|
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
const char *filename = luaL_checkstring(L, 1);
|
const char *filename = luaL_checkstring(L, 1);
|
||||||
cairo_surface_t *surface = draw_load_image(L, filename, &error);
|
cairo_surface_t *surface = draw_load_image(L, filename, &error);
|
||||||
|
@ -776,6 +797,7 @@ luaA_init(xdgHandle* xdg, string_array_t *searchpath)
|
||||||
{ "emit_signal", luaA_awesome_emit_signal },
|
{ "emit_signal", luaA_awesome_emit_signal },
|
||||||
{ "systray", luaA_systray },
|
{ "systray", luaA_systray },
|
||||||
{ "load_image", luaA_load_image },
|
{ "load_image", luaA_load_image },
|
||||||
|
{ "pixbuf_to_surface", luaA_pixbuf_to_surface },
|
||||||
{ "set_preferred_icon_size", luaA_set_preferred_icon_size },
|
{ "set_preferred_icon_size", luaA_set_preferred_icon_size },
|
||||||
{ "register_xproperty", luaA_register_xproperty },
|
{ "register_xproperty", luaA_register_xproperty },
|
||||||
{ "set_xproperty", luaA_set_xproperty },
|
{ "set_xproperty", luaA_set_xproperty },
|
||||||
|
|
Loading…
Reference in New Issue