forked from Mirrors/flatpak-builder
builder: Add platform-extensions
parent
6d2aa7b29e
commit
472405ff7f
|
@ -58,6 +58,7 @@ struct BuilderManifest {
|
|||
gboolean build_runtime;
|
||||
gboolean writable_sdk;
|
||||
char **sdk_extensions;
|
||||
char **platform_extensions;
|
||||
char *command;
|
||||
BuilderOptions *build_options;
|
||||
GList *modules;
|
||||
|
@ -92,6 +93,7 @@ enum {
|
|||
PROP_BUILD_RUNTIME,
|
||||
PROP_WRITABLE_SDK,
|
||||
PROP_SDK_EXTENSIONS,
|
||||
PROP_PLATFORM_EXTENSIONS,
|
||||
PROP_FINISH_ARGS,
|
||||
PROP_RENAME_DESKTOP_FILE,
|
||||
PROP_RENAME_APPDATA_FILE,
|
||||
|
@ -216,6 +218,10 @@ builder_manifest_get_property (GObject *object,
|
|||
g_value_set_boxed (value, self->sdk_extensions);
|
||||
break;
|
||||
|
||||
case PROP_PLATFORM_EXTENSIONS:
|
||||
g_value_set_boxed (value, self->platform_extensions);
|
||||
break;
|
||||
|
||||
case PROP_COPY_ICON:
|
||||
g_value_set_boolean (value, self->copy_icon);
|
||||
break;
|
||||
|
@ -354,6 +360,12 @@ builder_manifest_set_property (GObject *object,
|
|||
g_strfreev (tmp);
|
||||
break;
|
||||
|
||||
case PROP_PLATFORM_EXTENSIONS:
|
||||
tmp = self->platform_extensions;
|
||||
self->platform_extensions = g_strdupv (g_value_get_boxed (value));
|
||||
g_strfreev (tmp);
|
||||
break;
|
||||
|
||||
case PROP_COPY_ICON:
|
||||
self->copy_icon = g_value_get_boolean (value);
|
||||
break;
|
||||
|
@ -529,6 +541,13 @@ builder_manifest_class_init (BuilderManifestClass *klass)
|
|||
"",
|
||||
G_TYPE_STRV,
|
||||
G_PARAM_READWRITE));
|
||||
g_object_class_install_property (object_class,
|
||||
PROP_PLATFORM_EXTENSIONS,
|
||||
g_param_spec_boxed ("platform-extensions",
|
||||
"",
|
||||
"",
|
||||
G_TYPE_STRV,
|
||||
G_PARAM_READWRITE));
|
||||
g_object_class_install_property (object_class,
|
||||
PROP_RENAME_DESKTOP_FILE,
|
||||
g_param_spec_string ("rename-desktop-file",
|
||||
|
@ -714,7 +733,7 @@ builder_manifest_init_app_dir (BuilderManifest *self,
|
|||
{
|
||||
GFile *app_dir = builder_context_get_app_dir (context);
|
||||
g_autoptr(GSubprocess) subp = NULL;
|
||||
GPtrArray *args;
|
||||
g_autoptr(GPtrArray) args = NULL;
|
||||
int i;
|
||||
|
||||
if (self->id == NULL)
|
||||
|
@ -850,6 +869,7 @@ builder_manifest_checksum_for_platform (BuilderManifest *self,
|
|||
builder_cache_checksum_str (cache, self->id_platform);
|
||||
builder_cache_checksum_str (cache, self->metadata);
|
||||
builder_cache_checksum_strv (cache, self->cleanup_platform);
|
||||
builder_cache_checksum_strv (cache, self->platform_extensions);
|
||||
}
|
||||
|
||||
gboolean
|
||||
|
@ -1449,26 +1469,38 @@ builder_manifest_create_platform (BuilderManifest *self,
|
|||
GList *l;
|
||||
g_autoptr(GFile) platform_dir = NULL;
|
||||
g_autoptr(GSubprocess) subp = NULL;
|
||||
g_autofree char *app_dir_path = g_file_get_path (app_dir);
|
||||
g_autoptr(GPtrArray) args = NULL;
|
||||
|
||||
g_print ("Creating platform based on %s\n", self->runtime);
|
||||
|
||||
platform_dir = g_file_get_child (app_dir, "platform");
|
||||
|
||||
args = g_ptr_array_new_with_free_func (g_free);
|
||||
|
||||
g_ptr_array_add (args, g_strdup ("xdg-app"));
|
||||
g_ptr_array_add (args, g_strdup ("build-init"));
|
||||
g_ptr_array_add (args, g_strdup ("--update"));
|
||||
g_ptr_array_add (args, g_strdup ("--writable-sdk"));
|
||||
g_ptr_array_add (args, g_strdup ("--sdk-dir=platform"));
|
||||
|
||||
for (i = 0; self->platform_extensions != NULL && self->platform_extensions[i] != NULL; i++)
|
||||
{
|
||||
const char *ext = self->platform_extensions[i];
|
||||
g_ptr_array_add (args, g_strdup_printf ("--sdk-extension=%s", ext));
|
||||
}
|
||||
|
||||
g_ptr_array_add (args, g_file_get_path (app_dir));
|
||||
g_ptr_array_add (args, g_strdup (self->id));
|
||||
g_ptr_array_add (args, g_strdup (self->runtime));
|
||||
g_ptr_array_add (args, g_strdup (self->runtime));
|
||||
g_ptr_array_add (args, g_strdup (builder_manifest_get_runtime_version (self)));
|
||||
|
||||
g_ptr_array_add (args, NULL);
|
||||
|
||||
subp =
|
||||
g_subprocess_new (G_SUBPROCESS_FLAGS_NONE,
|
||||
error,
|
||||
"xdg-app",
|
||||
"build-init",
|
||||
"--update",
|
||||
"--writable-sdk",
|
||||
"--sdk-dir=platform",
|
||||
app_dir_path,
|
||||
self->id,
|
||||
self->runtime,
|
||||
self->runtime,
|
||||
builder_manifest_get_runtime_version (self),
|
||||
NULL);
|
||||
g_subprocess_newv ((const gchar * const *) args->pdata,
|
||||
G_SUBPROCESS_FLAGS_NONE,
|
||||
error);
|
||||
|
||||
if (subp == NULL ||
|
||||
!g_subprocess_wait_check (subp, NULL, error))
|
||||
|
|
|
@ -147,6 +147,10 @@
|
|||
<term><option>sdk-extensions</option></term>
|
||||
<listitem><para>Install these extra sdk extensions in /usr</para></listitem>
|
||||
</varlistentry>
|
||||
<varlistentry>
|
||||
<term><option>platform-extensions</option></term>
|
||||
<listitem><para>Install these extra sdk extensions when creating the platform</para></listitem>
|
||||
</varlistentry>
|
||||
<varlistentry>
|
||||
<term><option>build-options</option></term>
|
||||
<listitem><para>object specifying the build environment. See below for details.</para></listitem>
|
||||
|
|
Loading…
Reference in New Issue