diff options
Diffstat (limited to 'builder/builder-manifest.c')
-rw-r--r-- | builder/builder-manifest.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/builder/builder-manifest.c b/builder/builder-manifest.c index 8145d7d..645d1c6 100644 --- a/builder/builder-manifest.c +++ b/builder/builder-manifest.c @@ -1617,6 +1617,7 @@ builder_manifest_finish (BuilderManifest *self, g_autofree char *extension_contents = NULL; g_autoptr(GFileEnumerator) dir_enum = NULL; g_autoptr(GFileOutputStream) output = NULL; + gboolean found_locale = FALSE; GFileInfo *next; metadata_file = g_file_get_child (app_dir, "metadata"); @@ -1662,10 +1663,28 @@ builder_manifest_finish (BuilderManifest *self, G_FILE_CREATE_REPLACE_DESTINATION, NULL, NULL, error)) return FALSE; + found_locale = TRUE; } } + + if (found_locale) + { + g_autoptr(GFile) metadata_locale_file = NULL; + g_autofree char *metadata_contents = NULL; + + metadata_locale_file = g_file_get_child (app_dir, "metadata.locale"); + metadata_contents = g_strdup_printf("[Runtime]\n" + "name=%s.Locale\n", self->id); + if (!g_file_replace_contents (metadata_locale_file, + metadata_contents, strlen (metadata_contents), + NULL, FALSE, + G_FILE_CREATE_REPLACE_DESTINATION, + NULL, NULL, error)) + return FALSE; + } } + if (g_file_query_exists (debuginfo_dir, NULL)) { g_autoptr(GFile) metadata_file = NULL; @@ -1886,6 +1905,7 @@ builder_manifest_create_platform (BuilderManifest *self, g_autoptr(GFileOutputStream) output = NULL; g_autoptr(GFile) locale_parent_dir = NULL; GFileInfo *next; + gboolean found_locale = FALSE; metadata_file = g_file_get_child (app_dir, "metadata.platform"); @@ -1931,8 +1951,27 @@ builder_manifest_create_platform (BuilderManifest *self, G_FILE_CREATE_REPLACE_DESTINATION, NULL, NULL, error)) return FALSE; + + found_locale = TRUE; } } + + if (found_locale) + { + g_autoptr(GFile) metadata_locale_file = NULL; + g_autofree char *metadata_contents = NULL; + + metadata_locale_file = g_file_get_child (app_dir, "metadata.platform.locale"); + metadata_contents = g_strdup_printf("[Runtime]\n" + "name=%s.Locale\n", self->id_platform); + if (!g_file_replace_contents (metadata_locale_file, + metadata_contents, strlen (metadata_contents), + NULL, FALSE, + G_FILE_CREATE_REPLACE_DESTINATION, + NULL, NULL, error)) + return FALSE; + + } } if (!builder_cache_commit (cache, "Created platform", error)) |