2012-02-03 19:42:56 +01:00
|
|
|
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*-
|
|
|
|
|
* GObject introspection: Private headers
|
2010-05-31 22:41:45 +02:00
|
|
|
|
*
|
|
|
|
|
* Copyright (C) 2010 Johan Dahlin
|
|
|
|
|
*
|
2023-10-25 18:10:10 +02:00
|
|
|
|
* SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
|
*
|
2010-05-31 22:41:45 +02:00
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
|
*/
|
|
|
|
|
|
2023-11-07 19:23:17 +01:00
|
|
|
|
#pragma once
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
|
|
|
|
#include <glib.h>
|
|
|
|
|
|
2010-06-07 04:22:57 +02:00
|
|
|
|
#define __GIREPOSITORY_H_INSIDE__
|
|
|
|
|
|
2023-10-25 18:45:42 +02:00
|
|
|
|
#include <girepository/gibaseinfo.h>
|
|
|
|
|
#include <girepository/girepository.h>
|
|
|
|
|
#include <girepository/gitypelib.h>
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
2024-02-14 12:52:33 +01:00
|
|
|
|
#include "gitypelib-internal.h"
|
|
|
|
|
|
2023-11-28 18:24:20 +01:00
|
|
|
|
/* FIXME: For now, GIRealInfo is a compatibility define. This will eventually
|
|
|
|
|
* be removed. */
|
|
|
|
|
typedef struct _GIBaseInfo GIRealInfo;
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* We just use one structure for all of the info object
|
|
|
|
|
* types; in general, we should be reading data directly
|
|
|
|
|
* from the typelib, and not having computed data in
|
|
|
|
|
* per-type structures.
|
|
|
|
|
*/
|
2023-11-28 18:24:20 +01:00
|
|
|
|
struct _GIBaseInfo
|
2010-05-31 22:41:45 +02:00
|
|
|
|
{
|
2023-11-28 18:24:20 +01:00
|
|
|
|
/*< private >*/
|
|
|
|
|
GTypeInstance parent_instance;
|
|
|
|
|
gatomicrefcount ref_count;
|
|
|
|
|
|
2024-01-25 23:03:57 +01:00
|
|
|
|
/* @repository is never reffed, as that would lead to a refcount cycle with the repository */
|
2010-05-31 22:41:45 +02:00
|
|
|
|
GIRepository *repository;
|
2024-01-25 23:03:57 +01:00
|
|
|
|
/* @container is reffed if the GIBaseInfo is heap-allocated, but not reffed if it’s stack-allocated */
|
2010-05-31 22:41:45 +02:00
|
|
|
|
GIBaseInfo *container;
|
|
|
|
|
|
2010-08-31 22:36:06 +02:00
|
|
|
|
GITypelib *typelib;
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset;
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
2024-05-10 19:37:52 +02:00
|
|
|
|
unsigned int type_is_embedded : 1; /* Used by GITypeInfo */
|
|
|
|
|
unsigned int padding_bitfield : 31; /* For future expansion */
|
2024-01-31 16:49:38 +01:00
|
|
|
|
|
|
|
|
|
/* A copy of GIBaseInfo is exposed publicly for stack-allocated derivatives
|
|
|
|
|
* such as GITypeInfo, so its size is now ABI. */
|
|
|
|
|
void *padding[6];
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
2024-01-31 16:49:38 +01:00
|
|
|
|
G_STATIC_ASSERT (sizeof (GIBaseInfo) == sizeof (GIBaseInfoStack));
|
|
|
|
|
G_STATIC_ASSERT (G_ALIGNOF (GIBaseInfo) == G_ALIGNOF (GIBaseInfoStack));
|
|
|
|
|
|
2024-02-08 13:35:23 +01:00
|
|
|
|
/**
|
|
|
|
|
* GIInfoType:
|
|
|
|
|
* @GI_INFO_TYPE_INVALID: invalid type
|
|
|
|
|
* @GI_INFO_TYPE_FUNCTION: function, see [class@GIRepository.FunctionInfo]
|
|
|
|
|
* @GI_INFO_TYPE_CALLBACK: callback, see [class@GIRepository.FunctionInfo]
|
|
|
|
|
* @GI_INFO_TYPE_STRUCT: struct, see [class@GIRepository.StructInfo]
|
|
|
|
|
* @GI_INFO_TYPE_ENUM: enum, see [class@GIRepository.EnumInfo]
|
|
|
|
|
* @GI_INFO_TYPE_FLAGS: flags, see [class@GIRepository.EnumInfo]
|
|
|
|
|
* @GI_INFO_TYPE_OBJECT: object, see [class@GIRepository.ObjectInfo]
|
|
|
|
|
* @GI_INFO_TYPE_INTERFACE: interface, see [class@GIRepository.InterfaceInfo]
|
|
|
|
|
* @GI_INFO_TYPE_CONSTANT: constant, see [class@GIRepository.ConstantInfo]
|
|
|
|
|
* @GI_INFO_TYPE_UNION: union, see [class@GIRepository.UnionInfo]
|
|
|
|
|
* @GI_INFO_TYPE_VALUE: enum value, see [class@GIRepository.ValueInfo]
|
|
|
|
|
* @GI_INFO_TYPE_SIGNAL: signal, see [class@GIRepository.SignalInfo]
|
|
|
|
|
* @GI_INFO_TYPE_VFUNC: virtual function, see [class@GIRepository.VFuncInfo]
|
|
|
|
|
* @GI_INFO_TYPE_PROPERTY: [class@GObject.Object] property, see
|
|
|
|
|
* [class@GIRepository.PropertyInfo]
|
|
|
|
|
* @GI_INFO_TYPE_FIELD: struct or union field, see
|
|
|
|
|
* [class@GIRepository.FieldInfo]
|
|
|
|
|
* @GI_INFO_TYPE_ARG: argument of a function or callback, see
|
|
|
|
|
* [class@GIRepository.ArgInfo]
|
|
|
|
|
* @GI_INFO_TYPE_TYPE: type information, see [class@GIRepository.TypeInfo]
|
|
|
|
|
* @GI_INFO_TYPE_UNRESOLVED: unresolved type, a type which is not present in
|
|
|
|
|
* the typelib, or any of its dependencies, see
|
|
|
|
|
* [class@GIRepository.UnresolvedInfo]
|
|
|
|
|
* @GI_INFO_TYPE_CALLABLE: an abstract type representing any callable (function,
|
|
|
|
|
* callback, vfunc), see [class@GIRepository.CallableInfo]
|
|
|
|
|
* @GI_INFO_TYPE_REGISTERED_TYPE: an abstract type representing any registered
|
|
|
|
|
* type (enum, interface, object, struct, union), see
|
|
|
|
|
* [class@GIRepository.RegisteredTypeInfo]
|
|
|
|
|
*
|
|
|
|
|
* The type of a [class@GIRepository.BaseInfo] struct.
|
|
|
|
|
*
|
|
|
|
|
* See [const@GIRepository.INFO_TYPE_N_TYPES] for the total number of elements
|
|
|
|
|
* in this enum.
|
|
|
|
|
*
|
|
|
|
|
* Since: 2.80
|
|
|
|
|
*/
|
|
|
|
|
typedef enum
|
|
|
|
|
{
|
|
|
|
|
/* The values here must be kept in sync with GITypelibBlobType */
|
|
|
|
|
GI_INFO_TYPE_INVALID,
|
|
|
|
|
GI_INFO_TYPE_FUNCTION,
|
|
|
|
|
GI_INFO_TYPE_CALLBACK,
|
|
|
|
|
GI_INFO_TYPE_STRUCT,
|
2024-02-08 12:47:03 +01:00
|
|
|
|
/* 4 is skipped, it used to be BOXED, but was removed in girepository 2.80.
|
|
|
|
|
* It is still part of the binary format in GITypelibBlobType. */
|
|
|
|
|
GI_INFO_TYPE_ENUM = 5, /* 5 */
|
|
|
|
|
GI_INFO_TYPE_FLAGS = 6,
|
|
|
|
|
GI_INFO_TYPE_OBJECT = 7,
|
|
|
|
|
GI_INFO_TYPE_INTERFACE = 8,
|
|
|
|
|
GI_INFO_TYPE_CONSTANT = 9,
|
2024-02-08 13:35:23 +01:00
|
|
|
|
/* 10 is skipped, it used to be used, but was removed before girepository-2.0
|
|
|
|
|
* It is, however, part of the binary format in GITypelibBlobType */
|
|
|
|
|
GI_INFO_TYPE_UNION = 11,
|
|
|
|
|
GI_INFO_TYPE_VALUE = 12,
|
|
|
|
|
GI_INFO_TYPE_SIGNAL = 13,
|
|
|
|
|
GI_INFO_TYPE_VFUNC = 14,
|
|
|
|
|
GI_INFO_TYPE_PROPERTY = 15,
|
|
|
|
|
GI_INFO_TYPE_FIELD = 16,
|
|
|
|
|
GI_INFO_TYPE_ARG = 17,
|
|
|
|
|
GI_INFO_TYPE_TYPE = 18,
|
|
|
|
|
GI_INFO_TYPE_UNRESOLVED = 19,
|
|
|
|
|
GI_INFO_TYPE_CALLABLE = 20,
|
|
|
|
|
GI_INFO_TYPE_REGISTERED_TYPE = 21,
|
|
|
|
|
/* keep GI_INFO_TYPE_N_TYPES in sync with this */
|
|
|
|
|
} GIInfoType;
|
|
|
|
|
|
2024-02-14 12:52:33 +01:00
|
|
|
|
GIInfoType gi_typelib_blob_type_to_info_type (GITypelibBlobType blob_type);
|
|
|
|
|
|
2024-02-08 13:35:23 +01:00
|
|
|
|
/**
|
|
|
|
|
* GI_INFO_TYPE_N_TYPES:
|
|
|
|
|
*
|
|
|
|
|
* Number of entries in [enum@GIRepository.InfoType].
|
|
|
|
|
*
|
|
|
|
|
* Since: 2.80
|
|
|
|
|
*/
|
|
|
|
|
#define GI_INFO_TYPE_N_TYPES (GI_INFO_TYPE_REGISTERED_TYPE + 1)
|
|
|
|
|
|
|
|
|
|
const char * gi_info_type_to_string (GIInfoType type);
|
|
|
|
|
|
2023-11-28 18:24:20 +01:00
|
|
|
|
/* Subtypes */
|
|
|
|
|
struct _GICallableInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
2010-05-31 22:41:45 +02:00
|
|
|
|
};
|
|
|
|
|
|
2023-11-28 18:24:20 +01:00
|
|
|
|
void gi_callable_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIFunctionInfo
|
2010-05-31 22:41:45 +02:00
|
|
|
|
{
|
2024-01-17 15:42:29 +01:00
|
|
|
|
GICallableInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_function_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GICallbackInfo
|
|
|
|
|
{
|
2024-01-17 15:42:29 +01:00
|
|
|
|
GICallableInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_callback_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIRegisteredTypeInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_registered_type_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIStructInfo
|
|
|
|
|
{
|
2024-01-17 16:39:48 +01:00
|
|
|
|
GIRegisteredTypeInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_struct_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIUnionInfo
|
|
|
|
|
{
|
2024-01-17 16:39:48 +01:00
|
|
|
|
GIRegisteredTypeInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_union_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIEnumInfo
|
|
|
|
|
{
|
2024-01-17 16:39:48 +01:00
|
|
|
|
GIRegisteredTypeInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_enum_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
2024-01-17 16:02:05 +01:00
|
|
|
|
struct _GIFlagsInfo
|
|
|
|
|
{
|
|
|
|
|
GIEnumInfo parent;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_flags_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
2023-11-28 18:24:20 +01:00
|
|
|
|
struct _GIObjectInfo
|
|
|
|
|
{
|
2024-01-17 16:39:48 +01:00
|
|
|
|
GIRegisteredTypeInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_object_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIInterfaceInfo
|
|
|
|
|
{
|
2024-01-17 16:37:47 +01:00
|
|
|
|
GIRegisteredTypeInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
2023-11-28 18:24:20 +01:00
|
|
|
|
void gi_interface_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIConstantInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_constant_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIValueInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_value_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GISignalInfo
|
|
|
|
|
{
|
2024-01-17 15:42:29 +01:00
|
|
|
|
GICallableInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_signal_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIVFuncInfo
|
|
|
|
|
{
|
2024-01-17 15:42:29 +01:00
|
|
|
|
GICallableInfo parent;
|
2023-11-28 18:24:20 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_vfunc_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIPropertyInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_property_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIFieldInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void gi_field_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
2024-01-31 16:49:38 +01:00
|
|
|
|
/* GIArgInfo is stack-allocatable so it can be used with
|
|
|
|
|
* gi_callable_info_load_return_type() and gi_callable_info_load_arg(), so its
|
|
|
|
|
* definition is actually public in gitypes.h. */
|
2023-11-28 18:24:20 +01:00
|
|
|
|
|
|
|
|
|
void gi_arg_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
2024-01-31 16:49:38 +01:00
|
|
|
|
/* GITypeInfo is stack-allocatable so it can be used with
|
2024-02-05 16:13:46 +01:00
|
|
|
|
* gi_arg_info_load_type_info(), so its definition is actually public in
|
|
|
|
|
* gitypes.h. */
|
2023-11-28 18:24:20 +01:00
|
|
|
|
|
|
|
|
|
void gi_type_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
|
|
|
|
struct _GIUnresolvedInfo
|
|
|
|
|
{
|
|
|
|
|
GIBaseInfo parent;
|
2010-05-31 22:41:45 +02:00
|
|
|
|
|
2024-01-15 20:20:47 +01:00
|
|
|
|
const char *name;
|
|
|
|
|
const char *namespace;
|
2010-05-31 22:41:45 +02:00
|
|
|
|
};
|
|
|
|
|
|
2023-11-28 18:24:20 +01:00
|
|
|
|
void gi_unresolved_info_class_init (gpointer g_class,
|
|
|
|
|
gpointer class_data);
|
|
|
|
|
|
2023-11-08 16:23:31 +01:00
|
|
|
|
void gi_info_init (GIRealInfo *info,
|
2024-01-23 19:06:08 +01:00
|
|
|
|
GType type,
|
2023-11-08 16:23:31 +01:00
|
|
|
|
GIRepository *repository,
|
|
|
|
|
GIBaseInfo *container,
|
|
|
|
|
GITypelib *typelib,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset);
|
2023-11-08 16:23:31 +01:00
|
|
|
|
|
|
|
|
|
GIBaseInfo * gi_info_from_entry (GIRepository *repository,
|
|
|
|
|
GITypelib *typelib,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint16_t index);
|
2023-11-08 16:23:31 +01:00
|
|
|
|
|
|
|
|
|
GIBaseInfo * gi_info_new_full (GIInfoType type,
|
|
|
|
|
GIRepository *repository,
|
|
|
|
|
GIBaseInfo *container,
|
|
|
|
|
GITypelib *typelib,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset);
|
2023-11-08 16:23:31 +01:00
|
|
|
|
|
|
|
|
|
GITypeInfo * gi_type_info_new (GIBaseInfo *container,
|
|
|
|
|
GITypelib *typelib,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset);
|
2023-11-08 16:23:31 +01:00
|
|
|
|
|
2024-01-23 18:53:15 +01:00
|
|
|
|
void gi_type_info_init (GITypeInfo *info,
|
2023-11-08 16:23:31 +01:00
|
|
|
|
GIBaseInfo *container,
|
|
|
|
|
GITypelib *typelib,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset);
|
2023-11-08 16:23:31 +01:00
|
|
|
|
|
|
|
|
|
GIFunctionInfo * gi_base_info_find_method (GIBaseInfo *base,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset,
|
2024-01-16 01:57:09 +01:00
|
|
|
|
uint16_t n_methods,
|
2024-01-15 20:20:47 +01:00
|
|
|
|
const char *name);
|
2023-11-08 16:23:31 +01:00
|
|
|
|
|
|
|
|
|
GIVFuncInfo * gi_base_info_find_vfunc (GIRealInfo *rinfo,
|
2024-01-15 22:20:02 +01:00
|
|
|
|
uint32_t offset,
|
2024-01-16 01:57:09 +01:00
|
|
|
|
uint16_t n_vfuncs,
|
2024-01-15 20:20:47 +01:00
|
|
|
|
const char *name);
|