Merge pull request #725 from thiblahute/gir_subproject_deps
gnome: Handle internal dependencies to generate gir filespull/737/head
commit
fc33f714fd
12 changed files with 480 additions and 29 deletions
@ -0,0 +1,124 @@ |
|||||||
|
#include "meson-subsample.h" |
||||||
|
|
||||||
|
struct _MesonSubSample |
||||||
|
{ |
||||||
|
MesonSample parent_instance; |
||||||
|
|
||||||
|
gchar *msg; |
||||||
|
}; |
||||||
|
|
||||||
|
G_DEFINE_TYPE (MesonSubSample, meson_sub_sample, MESON_TYPE_SAMPLE) |
||||||
|
|
||||||
|
enum { |
||||||
|
PROP_0, |
||||||
|
PROP_MSG, |
||||||
|
LAST_PROP |
||||||
|
}; |
||||||
|
|
||||||
|
static GParamSpec *gParamSpecs [LAST_PROP]; |
||||||
|
|
||||||
|
/**
|
||||||
|
* meson_sub_sample_new: |
||||||
|
* @msg: The message to set. |
||||||
|
* |
||||||
|
* Allocates a new #MesonSubSample. |
||||||
|
* |
||||||
|
* Returns: (transfer full): a #MesonSubSample. |
||||||
|
*/ |
||||||
|
MesonSubSample * |
||||||
|
meson_sub_sample_new (const gchar *msg) |
||||||
|
{ |
||||||
|
g_return_val_if_fail (msg != NULL, NULL); |
||||||
|
|
||||||
|
return g_object_new (MESON_TYPE_SUB_SAMPLE, |
||||||
|
"message", msg, |
||||||
|
NULL); |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sub_sample_finalize (GObject *object) |
||||||
|
{ |
||||||
|
MesonSubSample *self = (MesonSubSample *)object; |
||||||
|
|
||||||
|
g_clear_pointer (&self->msg, g_free); |
||||||
|
|
||||||
|
G_OBJECT_CLASS (meson_sub_sample_parent_class)->finalize (object); |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sub_sample_get_property (GObject *object, |
||||||
|
guint prop_id, |
||||||
|
GValue *value, |
||||||
|
GParamSpec *pspec) |
||||||
|
{ |
||||||
|
MesonSubSample *self = MESON_SUB_SAMPLE (object); |
||||||
|
|
||||||
|
switch (prop_id) |
||||||
|
{ |
||||||
|
case PROP_MSG: |
||||||
|
g_value_set_string (value, self->msg); |
||||||
|
break; |
||||||
|
default: |
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sub_sample_set_property (GObject *object, |
||||||
|
guint prop_id, |
||||||
|
const GValue *value, |
||||||
|
GParamSpec *pspec) |
||||||
|
{ |
||||||
|
MesonSubSample *self = MESON_SUB_SAMPLE (object); |
||||||
|
|
||||||
|
switch (prop_id) |
||||||
|
{ |
||||||
|
case PROP_MSG: |
||||||
|
self->msg = g_value_dup_string (value); |
||||||
|
break; |
||||||
|
default: |
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sub_sample_class_init (MesonSubSampleClass *klass) |
||||||
|
{ |
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass); |
||||||
|
|
||||||
|
object_class->finalize = meson_sub_sample_finalize; |
||||||
|
object_class->get_property = meson_sub_sample_get_property; |
||||||
|
object_class->set_property = meson_sub_sample_set_property; |
||||||
|
|
||||||
|
gParamSpecs [PROP_MSG] = |
||||||
|
g_param_spec_string ("message", |
||||||
|
"Message", |
||||||
|
"The message to print.", |
||||||
|
NULL, |
||||||
|
(G_PARAM_READWRITE | |
||||||
|
G_PARAM_CONSTRUCT_ONLY | |
||||||
|
G_PARAM_STATIC_STRINGS)); |
||||||
|
|
||||||
|
g_object_class_install_properties (object_class, LAST_PROP, gParamSpecs); |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sub_sample_init (MesonSubSample *self) |
||||||
|
{ |
||||||
|
} |
||||||
|
|
||||||
|
/**
|
||||||
|
* meson_sub_sample_print_message: |
||||||
|
* @self: a #MesonSubSample. |
||||||
|
* |
||||||
|
* Prints the message. |
||||||
|
* |
||||||
|
* Returns: Nothing. |
||||||
|
*/ |
||||||
|
void |
||||||
|
meson_sub_sample_print_message (MesonSubSample *self) |
||||||
|
{ |
||||||
|
g_return_if_fail (MESON_IS_SUB_SAMPLE (self)); |
||||||
|
|
||||||
|
g_print ("Message: %s\n", self->msg); |
||||||
|
} |
@ -0,0 +1,21 @@ |
|||||||
|
#ifndef MESON_SUB_SAMPLE_H |
||||||
|
#define MESON_SUB_SAMPLE_H |
||||||
|
|
||||||
|
#if !defined (MESON_TEST) |
||||||
|
#error "MESON_TEST not defined." |
||||||
|
#endif |
||||||
|
|
||||||
|
#include <glib-object.h> |
||||||
|
#include <meson-sample.h> |
||||||
|
|
||||||
|
G_BEGIN_DECLS |
||||||
|
|
||||||
|
#define MESON_TYPE_SUB_SAMPLE (meson_sub_sample_get_type()) |
||||||
|
|
||||||
|
G_DECLARE_FINAL_TYPE (MesonSubSample, meson_sub_sample, MESON, SUB_SAMPLE, MesonSample) |
||||||
|
|
||||||
|
MesonSubSample *meson_sub_sample_new (const gchar *msg); |
||||||
|
|
||||||
|
G_END_DECLS |
||||||
|
|
||||||
|
#endif /* MESON_SUB_SAMPLE_H */ |
@ -0,0 +1,35 @@ |
|||||||
|
libsources = ['meson-subsample.c', 'meson-subsample.h'] |
||||||
|
|
||||||
|
girsubproject = shared_library( |
||||||
|
'girsubproject', |
||||||
|
sources : libsources, |
||||||
|
dependencies : [gobj, meson_gir], |
||||||
|
install : true |
||||||
|
) |
||||||
|
|
||||||
|
girexe = executable( |
||||||
|
'girprog', |
||||||
|
sources : 'prog.c', |
||||||
|
dependencies : [gobj, meson_gir], |
||||||
|
link_with : girsubproject |
||||||
|
) |
||||||
|
|
||||||
|
gnome.generate_gir( |
||||||
|
girsubproject, |
||||||
|
sources : libsources, |
||||||
|
dependencies : [gobj, meson_gir], |
||||||
|
nsversion : '1.0', |
||||||
|
namespace : 'MesonSub', |
||||||
|
symbol_prefix : 'meson_sub_', |
||||||
|
identifier_prefix : 'MesonSub', |
||||||
|
includes : ['GObject-2.0', 'Meson-1.0'], |
||||||
|
install : true |
||||||
|
) |
||||||
|
|
||||||
|
message('TEST: ' + girsubproject.outdir()) |
||||||
|
|
||||||
|
test('gobject introspection/subproject/c', girexe) |
||||||
|
test('gobject introspection/subproject/py', find_program('prog.py'), |
||||||
|
env : ['GI_TYPELIB_PATH=' + girsubproject.outdir() + ':subprojects/mesongir', |
||||||
|
'LD_LIBRARY_PATH=' + girsubproject.outdir() + ':subprojects/mesongir', |
||||||
|
]) |
@ -0,0 +1,12 @@ |
|||||||
|
#include "meson-subsample.h" |
||||||
|
|
||||||
|
gint |
||||||
|
main (gint argc, |
||||||
|
gchar *argv[]) |
||||||
|
{ |
||||||
|
MesonSample * i = (MesonSample*) meson_sub_sample_new ("Hello, sub/meson/c!"); |
||||||
|
meson_sample_print_message (i); |
||||||
|
g_object_unref (i); |
||||||
|
|
||||||
|
return 0; |
||||||
|
} |
@ -0,0 +1,6 @@ |
|||||||
|
#!/usr/bin/env python3 |
||||||
|
from gi.repository import MesonSub |
||||||
|
|
||||||
|
if __name__ == "__main__": |
||||||
|
s = MesonSub.Sample.new("Hello, sub/meson/py!") |
||||||
|
s.print_message() |
@ -0,0 +1,6 @@ |
|||||||
|
usr/lib/girepository-1.0/Meson-1.0.typelib |
||||||
|
usr/lib/girepository-1.0/MesonSub-1.0.typelib |
||||||
|
usr/share/gir-1.0/Meson-1.0.gir |
||||||
|
usr/share/gir-1.0/MesonSub-1.0.gir |
||||||
|
usr/lib/libgirsubproject.so |
||||||
|
usr/lib/libgirlib.so |
@ -0,0 +1,10 @@ |
|||||||
|
project('gobject-introspection-with-subproject', 'c') |
||||||
|
|
||||||
|
gnome = import('gnome') |
||||||
|
gobj = dependency('gobject-2.0') |
||||||
|
|
||||||
|
add_global_arguments('-DMESON_TEST', language : 'c') |
||||||
|
meson_gir = dependency('meson-gir', fallback : ['mesongir', 'meson_gir']) |
||||||
|
|
||||||
|
subdir('gir') |
||||||
|
|
@ -0,0 +1,127 @@ |
|||||||
|
#include "meson-sample.h" |
||||||
|
|
||||||
|
typedef struct _MesonSamplePrivate |
||||||
|
{ |
||||||
|
gchar *msg; |
||||||
|
} MesonSamplePrivate; |
||||||
|
|
||||||
|
|
||||||
|
G_DEFINE_TYPE_WITH_PRIVATE (MesonSample, meson_sample, G_TYPE_OBJECT) |
||||||
|
|
||||||
|
enum { |
||||||
|
PROP_0, |
||||||
|
PROP_MSG, |
||||||
|
LAST_PROP |
||||||
|
}; |
||||||
|
|
||||||
|
static GParamSpec *gParamSpecs [LAST_PROP]; |
||||||
|
|
||||||
|
/**
|
||||||
|
* meson_sample_new: |
||||||
|
* @msg: The message to set. |
||||||
|
* |
||||||
|
* Allocates a new #MesonSample. |
||||||
|
* |
||||||
|
* Returns: (transfer full): a #MesonSample. |
||||||
|
*/ |
||||||
|
MesonSample * |
||||||
|
meson_sample_new (const gchar *msg) |
||||||
|
{ |
||||||
|
g_return_val_if_fail (msg != NULL, NULL); |
||||||
|
|
||||||
|
return g_object_new (MESON_TYPE_SAMPLE, |
||||||
|
"message", msg, |
||||||
|
NULL); |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sample_finalize (GObject *object) |
||||||
|
{ |
||||||
|
MesonSamplePrivate *priv = meson_sample_get_instance_private ((MesonSample *) object); |
||||||
|
|
||||||
|
g_clear_pointer (&priv->msg, g_free); |
||||||
|
|
||||||
|
G_OBJECT_CLASS (meson_sample_parent_class)->finalize (object); |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sample_get_property (GObject *object, |
||||||
|
guint prop_id, |
||||||
|
GValue *value, |
||||||
|
GParamSpec *pspec) |
||||||
|
{ |
||||||
|
MesonSamplePrivate *priv = meson_sample_get_instance_private ((MesonSample *) object); |
||||||
|
|
||||||
|
switch (prop_id) |
||||||
|
{ |
||||||
|
case PROP_MSG: |
||||||
|
g_value_set_string (value, priv->msg); |
||||||
|
break; |
||||||
|
default: |
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sample_set_property (GObject *object, |
||||||
|
guint prop_id, |
||||||
|
const GValue *value, |
||||||
|
GParamSpec *pspec) |
||||||
|
{ |
||||||
|
MesonSamplePrivate *priv = meson_sample_get_instance_private ((MesonSample *) object); |
||||||
|
|
||||||
|
switch (prop_id) |
||||||
|
{ |
||||||
|
case PROP_MSG: |
||||||
|
priv->msg = g_value_dup_string (value); |
||||||
|
break; |
||||||
|
default: |
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sample_class_init (MesonSampleClass *klass) |
||||||
|
{ |
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass); |
||||||
|
|
||||||
|
object_class->finalize = meson_sample_finalize; |
||||||
|
object_class->get_property = meson_sample_get_property; |
||||||
|
object_class->set_property = meson_sample_set_property; |
||||||
|
|
||||||
|
gParamSpecs [PROP_MSG] = |
||||||
|
g_param_spec_string ("message", |
||||||
|
"Message", |
||||||
|
"The message to print.", |
||||||
|
NULL, |
||||||
|
(G_PARAM_READWRITE | |
||||||
|
G_PARAM_CONSTRUCT_ONLY | |
||||||
|
G_PARAM_STATIC_STRINGS)); |
||||||
|
|
||||||
|
g_object_class_install_properties (object_class, LAST_PROP, gParamSpecs); |
||||||
|
} |
||||||
|
|
||||||
|
static void |
||||||
|
meson_sample_init (MesonSample *self) |
||||||
|
{ |
||||||
|
} |
||||||
|
|
||||||
|
/**
|
||||||
|
* meson_sample_print_message: |
||||||
|
* @self: a #MesonSample. |
||||||
|
* |
||||||
|
* Prints the message. |
||||||
|
* |
||||||
|
* Returns: Nothing. |
||||||
|
*/ |
||||||
|
void |
||||||
|
meson_sample_print_message (MesonSample *self) |
||||||
|
{ |
||||||
|
MesonSamplePrivate *priv; |
||||||
|
|
||||||
|
g_return_if_fail (MESON_IS_SAMPLE (self)); |
||||||
|
|
||||||
|
priv = meson_sample_get_instance_private (self); |
||||||
|
|
||||||
|
g_print ("Message: %s\n", priv->msg); |
||||||
|
} |
@ -0,0 +1,26 @@ |
|||||||
|
#ifndef MESON_SAMPLE_H |
||||||
|
#define MESON_SAMPLE_H |
||||||
|
|
||||||
|
#if !defined (MESON_TEST) |
||||||
|
#error "MESON_TEST not defined." |
||||||
|
#endif |
||||||
|
|
||||||
|
#include <glib-object.h> |
||||||
|
|
||||||
|
G_BEGIN_DECLS |
||||||
|
|
||||||
|
#define MESON_TYPE_SAMPLE (meson_sample_get_type()) |
||||||
|
|
||||||
|
G_DECLARE_DERIVABLE_TYPE (MesonSample, meson_sample, MESON, SAMPLE, GObject) |
||||||
|
|
||||||
|
struct _MesonSampleClass { |
||||||
|
GObjectClass parent_class; |
||||||
|
}; |
||||||
|
|
||||||
|
|
||||||
|
MesonSample *meson_sample_new (const gchar *msg); |
||||||
|
void meson_sample_print_message (MesonSample *self); |
||||||
|
|
||||||
|
G_END_DECLS |
||||||
|
|
||||||
|
#endif /* MESON_SAMPLE_H */ |
@ -0,0 +1,31 @@ |
|||||||
|
project('gobject-introspection-subproject', 'c') |
||||||
|
|
||||||
|
gnome = import('gnome') |
||||||
|
gobj = dependency('gobject-2.0') |
||||||
|
|
||||||
|
libsources = ['meson-sample.c', 'meson-sample.h'] |
||||||
|
|
||||||
|
girlib = shared_library( |
||||||
|
'girlib', |
||||||
|
sources : libsources, |
||||||
|
dependencies : gobj, |
||||||
|
install : true |
||||||
|
) |
||||||
|
|
||||||
|
girtarget = gnome.generate_gir( |
||||||
|
girlib, |
||||||
|
sources : libsources, |
||||||
|
nsversion : '1.0', |
||||||
|
namespace : 'Meson', |
||||||
|
symbol_prefix : 'meson_', |
||||||
|
identifier_prefix : 'Meson', |
||||||
|
includes : ['GObject-2.0'], |
||||||
|
install : true |
||||||
|
) |
||||||
|
|
||||||
|
meson_gir = declare_dependency(link_with : girlib, |
||||||
|
include_directories : [include_directories('.')], |
||||||
|
dependencies : [gobj], |
||||||
|
# Everything that uses libgst needs this built to compile |
||||||
|
sources : girtarget, |
||||||
|
) |
Loading…
Reference in new issue