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