Gjsify LogoGjsify Logo

#GParamSpec is an object structure that encapsulates the metadata required to specify parameters, such as e.g. #GObject properties.

Parameter names # {#canonical-parameter-names}

A property name consists of one or more segments consisting of ASCII letters and digits, separated by either the - or _ character. The first character of a property name must be a letter. These are the same rules as for signal naming (see g_signal_new()).

When creating and looking up a #GParamSpec, either separator can be used, but they cannot be mixed. Using - is considerably more efficient, and is the ‘canonical form’. Using _ is discouraged.

Hierarchy

Index

Constructors

Properties

#GParamFlags flags for this parameter

field
g_type_instance: TypeInstance

private #GTypeInstance portion

field
name: string

name of this parameter: always an interned string

field
owner_type: GType<unknown>

#GType type that uses (introduces) this parameter

field
value_type: GType<unknown>

the #GValue type for this parameter

field
name: string

Methods

  • get_blurb(): string
  • get_default_value(): any
  • Gets the default value of pspec as a pointer to a #GValue.

    The #GValue will remain valid for the life of pspec.

    Returns any

  • get_name(): string
  • Get the name of a #GParamSpec.

    The name is always an "interned" string (as per g_intern_string()). This allows for pointer-value comparisons.

    Returns string

  • get_name_quark(): number
  • get_nick(): string
  • get_qdata(quark: number): object
  • Gets back user data pointers stored via g_param_spec_set_qdata().

    Parameters

    • quark: number

      a #GQuark, naming the user data pointer

    Returns object

  • If the paramspec redirects operations to another paramspec, returns that paramspec. Redirect is used typically for providing a new implementation of a property in a derived type while preserving all the properties from the parent type. Redirection is established by creating a property of type #GParamSpecOverride. See g_object_class_override_property() for an example of the use of this capability.

    Returns ParamSpec

  • set_qdata(quark: number, data: object): void
  • Sets an opaque, named pointer on a #GParamSpec. The name is specified through a #GQuark (retrieved e.g. via g_quark_from_static_string()), and the pointer can be gotten back from the pspec with g_param_spec_get_qdata(). Setting a previously set user data pointer, overrides (frees) the old pointer set, using %NULL as pointer essentially removes the data stored.

    Parameters

    • quark: number

      a #GQuark, naming the user data pointer

    • data: object

      an opaque user data pointer

    Returns void

  • sink(): void
  • The initial reference count of a newly created #GParamSpec is 1, even though no one has explicitly called g_param_spec_ref() on it yet. So the initial reference count is flagged as "floating", until someone calls g_param_spec_ref (pspec); g_param_spec_sink (pspec); in sequence on it, taking over the initial reference count (thus ending up with a pspec that has a reference count of 1 still, but is not flagged "floating" anymore).

    Returns void

  • steal_qdata(quark: number): object
  • Gets back user data pointers stored via g_param_spec_set_qdata() and removes the data from pspec without invoking its destroy() function (if any was set). Usually, calling this function is only required to update user data pointers with a destroy notifier.

    Parameters

    • quark: number

      a #GQuark, naming the user data pointer

    Returns object

  • vfunc_finalize(): void
  • vfunc_value_set_default(value: any): void
  • vfunc_value_validate(value: any): boolean
  • vfunc_values_cmp(value1: any, value2: any): number
  • is_valid_name(name: string): boolean
  • Validate a property name for a #GParamSpec. This can be useful for dynamically-generated properties which need to be validated at run-time before actually trying to create them.

    See [canonical parameter names][canonical-parameter-names] for details of the rules for valid names.

    Parameters

    • name: string

      the canonical name of the property

    Returns boolean

Legend

  • Module
  • Object literal
  • Variable
  • Function
  • Function with type parameter
  • Index signature
  • Type alias
  • Type alias with type parameter
  • Enumeration
  • Enumeration member
  • Property
  • Method
  • Interface
  • Interface with type parameter
  • Constructor
  • Property
  • Method
  • Index signature
  • Class
  • Class with type parameter
  • Constructor
  • Property
  • Method
  • Accessor
  • Index signature
  • Inherited constructor
  • Inherited property
  • Inherited method
  • Inherited accessor
  • Protected property
  • Protected method
  • Protected accessor
  • Private property
  • Private method
  • Private accessor
  • Static property
  • Static method