Glib::ParamSpec - encapsulates metadate needed to specify parameters
Glib::ParamSpec encapsulates the metadata required to specify
parameters. You will see these most often when creating new Glib::Object
types; see Glib::Type->register
and
Glib::Object::Subclass.
Parameter specifications allow you to provide limits for validation as well as nicknames and blurbs to document the parameters. Blurbs show up in reference documentation such as this page or the gtk+ C API reference; i'm not really sure where the nicknames get used. The Perl bindings for the most part ignore the difference between dashes and underscores in the paramspec names, which typically find use as the actual keys for object parameters.
It's worth noting that Glib offers various sizes of integer and floating point values, while Perl really only deals with full integers and double precision floating point values. The size distinction is important for the underlying C libraries.
Glib::ParamSpec
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(integer)
$maximum
(integer)
$default_value
(integer)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(unsigned)
$maximum
(unsigned)
$default_value
(unsigned)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$default_value
(boolean)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$package
(string) name of the class, derived from
Glib::Boxed, of the objects this property will hold.
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(integer)
$maximum
(integer)
$default_value
(integer)
$flags
(Glib::ParamFlags)
(This is the C level g_param_value_set_default
function.)
Note that on a Glib::Param::Unichar
the return is a
single-char string. This is the same as the constructor
Glib::ParamSpec->unichar
, but it's not the same as
Glib::Object
get_property
/
set_property
, so an ord()
conversion is needed
if passing the default value to a unichar set_property
.
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(double)
$maximum
(double)
$default_value
(double)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$enum_type
(string)
$default_value
(scalar)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$flags_type
(string)
$default_value
(scalar)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(double)
$maximum
(double)
$default_value
(double)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$is_a_type
(string or undef) The name of a class
whose subtypes are allowed as values of the property. Use
undef
to allow any type.
$flags
(Glib::ParamFlags)
Since: glib 2.10
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(integer)
$maximum
(integer)
$default_value
(integer)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(64 bit integer)
$maximum
(64 bit integer)
$default_value
(64 bit integer)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(integer)
$maximum
(integer)
$default_value
(integer)
$flags
(Glib::ParamFlags)
Dashes in the name are converted to underscores.
$name
(string)
$nick
(string)
$blurb
(string)
$package
(string) name of the class, derived from
Glib::Object, of the objects this property will hold.
$flags
(Glib::ParamFlags)
$name
(string)
$overridden
(Glib::ParamSpec)
Since: glib 2.4
$name
(string)
$nick
(string)
$blurb
(string)
$package
(string) name of the class, derived from
Glib::ParamSpec, of the objects this property will hold.
$flags
(Glib::ParamFlags)
Since: glib 2.4
$name
(string)
$nick
(string)
$blurb
(string)
$flags
(Glib::ParamFlags)
ParamSpec to be used for any generic perl scalar, including references to complex objects.
Currently Gtk2::Builder
cannot set object properties of
this type (there's no hooks for property value parsing, as of Gtk 2.20),
so prefer the builtin types if buildable support for an object matters.
A boxed
of Glib::Strv
can give an array of
strings. A signal handler callback can do most of what a coderef
might.
$name
(string)
$nick
(string)
$blurb
(string)
$default_value
(string or undef)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(unsigned)
$maximum
(unsigned)
$default_value
(unsigned)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(unsigned)
$maximum
(unsigned)
$default_value
(unsigned)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(64 bit unsigned)
$maximum
(64 bit unsigned)
$default_value
(64 bit unsigned)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$minimum
(unsigned)
$maximum
(unsigned)
$default_value
(unsigned)
$flags
(Glib::ParamFlags)
$name
(string)
$nick
(string)
$blurb
(string)
$default_value
(character)
$flags
(Glib::ParamFlags)
$value
(scalar)
In scalar context return true if $value
must be modified
to be valid for $paramspec
, or false if it's valid already.
In array context return also a new value which is $value
made valid.
$value
must be the right type for
$paramspec
(with usual stringizing, numizing, etc).
value_validate
checks the further restrictions such as
minimum and maximum for a numeric type or allowed characters in a
string. The made valid return is then for instance clamped to the
min/max, or offending chars replaced by a substitutor.
$value1
(scalar)
$value2
(scalar)
Compares value1 with value2 according to pspec, and returns -1, 0 or +1, if value1 is found to be less than, equal to or greater than value2, respectively.
'readable' / 'G_PARAM_READABLE'
'writable' / 'G_PARAM_WRITABLE'
'construct' / 'G_PARAM_CONSTRUCT'
'construct-only' / 'G_PARAM_CONSTRUCT_ONLY'
'lax-validation' / 'G_PARAM_LAX_VALIDATION'
'private' / 'G_PARAM_PRIVATE'
'static-name' / 'G_PARAM_STATIC_NAME'
'static-nick' / 'G_PARAM_STATIC_NICK'
'static-blurb' / 'G_PARAM_STATIC_BLURB'
'explicit-notify' / 'G_PARAM_EXPLICIT_NOTIFY'
'deprecated' / 'G_PARAM_DEPRECATED'
Glib
Copyright (C) 2003-2011 by the gtk2-perl team.
This software is licensed under the LGPL. See Glib for a full notice.