X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Frb_evas.c;h=5ed1ceecc83887b6c3b8b0f7ed94c04856c1e336;hb=afe425bcbc30d5caa38bfed5c4e629f96fd62bcf;hp=fb02482920b5b937204ac25f0d771795336f4812;hpb=8efd0235a6bb26710fd89dd07a5fdb55cafde247;p=ruby-evas.git diff --git a/src/rb_evas.c b/src/rb_evas.c index fb02482..5ed1cee 100644 --- a/src/rb_evas.c +++ b/src/rb_evas.c @@ -1,5 +1,5 @@ /* - * $Id: rb_evas.c 49 2004-08-01 10:17:39Z tilman $ + * $Id: rb_evas.c 149 2004-11-27 18:47:46Z tilman $ * * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de) * @@ -52,11 +52,18 @@ VALUE TO_EVAS (VALUE parent, Evas *e) return self; } +/* :nodoc: */ static VALUE c_inspect (VALUE self) { INSPECT (self, RbEvas); } +/* + * call-seq: + * e.render => nil + * + * Forces a re-render of the Evas. + */ static VALUE c_render (VALUE self) { GET_OBJ (self, RbEvas, e); @@ -75,6 +82,12 @@ static VALUE c_font_path_clear (VALUE self) return Qnil; } +/* + * call-seq: + * e.font_path_append(path) => nil + * + * Appends a path to the font path for e. + */ static VALUE c_font_path_append (VALUE self, VALUE path) { GET_OBJ (self, RbEvas, e); @@ -86,6 +99,12 @@ static VALUE c_font_path_append (VALUE self, VALUE path) return Qnil; } +/* + * call-seq: + * e.font_path_prepend(path) => nil + * + * Prepends a path to the font path for e. + */ static VALUE c_font_path_prepend (VALUE self, VALUE path) { GET_OBJ (self, RbEvas, e); @@ -97,6 +116,12 @@ static VALUE c_font_path_prepend (VALUE self, VALUE path) return Qnil; } +/* + * call-seq: + * e.font_path => array + * + * Returns the font path for e. + */ static VALUE c_font_path_get (VALUE self) { VALUE ary; @@ -114,7 +139,12 @@ static VALUE c_font_path_get (VALUE self) return ary; } - +/* + * call-seq: + * e.font_cache => fixnum + * + * Returns the size of the font cache for e. + */ static VALUE c_font_cache_get (VALUE self) { GET_OBJ (self, RbEvas, e); @@ -122,6 +152,12 @@ static VALUE c_font_cache_get (VALUE self) return INT2FIX (evas_font_cache_get (e->real)); } +/* + * call-seq: + * e.font_cache(fixnum) + * + * Sets the size of the font cache for e. + */ static VALUE c_font_cache_set (VALUE self, VALUE val) { GET_OBJ (self, RbEvas, e); @@ -133,6 +169,12 @@ static VALUE c_font_cache_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * e.font_cache_reload => nil + * + * Flushes the font cache for e. + */ static VALUE c_font_cache_flush (VALUE self) { GET_OBJ (self, RbEvas, e); @@ -142,6 +184,12 @@ static VALUE c_font_cache_flush (VALUE self) return Qnil; } +/* + * call-seq: + * e.image_cache => fixnum + * + * Returns the size of the image cache for e. + */ static VALUE c_image_cache_get (VALUE self) { GET_OBJ (self, RbEvas, e); @@ -149,6 +197,12 @@ static VALUE c_image_cache_get (VALUE self) return INT2FIX (evas_image_cache_get (e->real)); } +/* + * call-seq: + * e.image_cache(fixnum) + * + * Sets the size of the image cache for e. + */ static VALUE c_image_cache_set (VALUE self, VALUE val) { GET_OBJ (self, RbEvas, e); @@ -160,6 +214,12 @@ static VALUE c_image_cache_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * e.image_cache_reload => nil + * + * Flushes the image cache for e. + */ static VALUE c_image_cache_reload (VALUE self) { GET_OBJ (self, RbEvas, e); @@ -169,6 +229,12 @@ static VALUE c_image_cache_reload (VALUE self) return Qnil; } +/* + * call-seq: + * e.image_cache_flush => nil + * + * Flushes the image cache for e. + */ static VALUE c_image_cache_flush (VALUE self) { GET_OBJ (self, RbEvas, e); @@ -178,46 +244,51 @@ static VALUE c_image_cache_flush (VALUE self) return Qnil; } +/* + * call-seq: + * e.top => evasobject + * + * Returns the Evas::EvasObject at the top of e. + */ static VALUE c_top_get (VALUE self) { Evas_Object *o; - void *obj; GET_OBJ (self, RbEvas, e); if (!(o = evas_object_top_get (e->real))) return Qnil; - if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) { - rb_raise (rb_eException, "EvasObject Ruby object key missing"); - return Qnil; - } - - return (VALUE) obj; + return TO_EVAS_OBJECT (o); } +/* + * call-seq: + * e.bottom => evasobject + * + * Returns the Evas::EvasObject at the bottom of e. + */ static VALUE c_bottom_get (VALUE self) { Evas_Object *o; - void *obj; GET_OBJ (self, RbEvas, e); if (!(o = evas_object_bottom_get (e->real))) return Qnil; - if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) { - rb_raise (rb_eException, "EvasObject Ruby object key missing"); - return Qnil; - } - - return (VALUE) obj; + return TO_EVAS_OBJECT (o); } +/* + * call-seq: + * e.find_object(name) => evasobject + * + * Returns the Evas::EvasObject with the name name. + */ static VALUE c_find_object (VALUE self, VALUE name) { Evas_Object *o; - void *obj; GET_OBJ (self, RbEvas, e); @@ -226,12 +297,18 @@ static VALUE c_find_object (VALUE self, VALUE name) if (!(o = evas_object_name_find (e->real, StringValuePtr (name)))) return Qnil; - if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) { - rb_raise (rb_eException, "EvasObject Ruby object key missing"); - return Qnil; - } + return TO_EVAS_OBJECT (o); +} + +static VALUE c_output_size_get (VALUE self) +{ + int w = 0, h = 0; + + GET_OBJ (self, RbEvas, e); + + evas_output_size_get (e->real, &w, &h); - return (VALUE) obj; + return rb_ary_new3 (2, INT2FIX (w), INT2FIX (h)); } void Init_Evas (void) @@ -260,4 +337,5 @@ void Init_Evas (void) rb_define_method (cEvas, "top", c_top_get, 0); rb_define_method (cEvas, "bottom", c_bottom_get, 0); rb_define_method (cEvas, "find_object", c_find_object, 1); + rb_define_method (cEvas, "output_size", c_output_size_get, 0); }