mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-11 09:18:20 +03:00
core: Drop 'compose' builtin
We'll just add this functionality to commit.
This commit is contained in:
parent
0e8149eb83
commit
188621f0b2
@ -25,7 +25,6 @@ ostree_SOURCES = src/ostree/main.c \
|
||||
src/ostree/ot-builtin-checkout.c \
|
||||
src/ostree/ot-builtin-checksum.c \
|
||||
src/ostree/ot-builtin-commit.c \
|
||||
src/ostree/ot-builtin-compose.c \
|
||||
src/ostree/ot-builtin-diff.c \
|
||||
src/ostree/ot-builtin-fsck.c \
|
||||
src/ostree/ot-builtin-init.c \
|
||||
|
@ -36,7 +36,6 @@ static OstreeBuiltin builtins[] = {
|
||||
{ "diff", ostree_builtin_diff, 0 },
|
||||
{ "init", ostree_builtin_init, 0 },
|
||||
{ "commit", ostree_builtin_commit, 0 },
|
||||
{ "compose", ostree_builtin_compose, 0 },
|
||||
{ "local-clone", ostree_builtin_local_clone, 0 },
|
||||
{ "log", ostree_builtin_log, 0 },
|
||||
{ "ls", ostree_builtin_ls, 0 },
|
||||
|
@ -1,282 +0,0 @@
|
||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*-
|
||||
*
|
||||
* Copyright (C) 2011 Colin Walters <walters@verbum.org>
|
||||
*
|
||||
* 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.
|
||||
*
|
||||
* Author: Colin Walters <walters@verbum.org>
|
||||
*/
|
||||
|
||||
#include "config.h"
|
||||
|
||||
#include "ot-builtins.h"
|
||||
#include "ostree.h"
|
||||
|
||||
#include <glib/gi18n.h>
|
||||
|
||||
static char *subject;
|
||||
static char *body;
|
||||
static char *branch;
|
||||
static char *from_file_path;
|
||||
|
||||
static GOptionEntry options[] = {
|
||||
{ "subject", 's', 0, G_OPTION_ARG_STRING, &subject, "One line subject", "subject" },
|
||||
{ "body", 'm', 0, G_OPTION_ARG_STRING, &body, "Full description", "body" },
|
||||
{ "branch", 'b', 0, G_OPTION_ARG_STRING, &branch, "Branch", "branch" },
|
||||
{ "from-file", 'F', 0, G_OPTION_ARG_STRING, &from_file_path, "Take list of branches to compose from FILE", "FILE" },
|
||||
{ NULL }
|
||||
};
|
||||
|
||||
static gboolean
|
||||
add_branch (OstreeRepo *repo,
|
||||
OstreeMutableTree *mtree,
|
||||
const char *branch_path,
|
||||
GVariantBuilder *metadata_builder,
|
||||
GError **error)
|
||||
{
|
||||
gboolean ret = FALSE;
|
||||
const char *branch_rev;
|
||||
const char *branch_name;
|
||||
const char *path;
|
||||
ot_lobj GFile *branchf = NULL;
|
||||
ot_lobj GFile *subdir = NULL;
|
||||
char **components = NULL;
|
||||
|
||||
components = g_strsplit (branch_path, ":", 2);
|
||||
|
||||
if (g_strv_length (components) != 2)
|
||||
{
|
||||
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||
"Invalid compose specification '%s'; missing ':'",
|
||||
branch_path);
|
||||
goto out;
|
||||
}
|
||||
branch_name = components[0];
|
||||
path = components[1];
|
||||
|
||||
if (!ostree_repo_read_commit (repo, branch_name, &branchf, NULL, error))
|
||||
goto out;
|
||||
|
||||
branch_rev = ostree_repo_file_get_commit ((OstreeRepoFile*)branchf);
|
||||
subdir = g_file_resolve_relative_path (branchf, path);
|
||||
|
||||
if (!ostree_repo_stage_directory_to_mtree (repo, subdir, mtree, NULL,
|
||||
NULL, error))
|
||||
{
|
||||
g_prefix_error (error, "Error composing %s: ", branch_path);
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (metadata_builder)
|
||||
g_variant_builder_add (metadata_builder, "(ss)", branch_path, branch_rev);
|
||||
|
||||
ret = TRUE;
|
||||
out:
|
||||
g_strfreev (components);
|
||||
return ret;
|
||||
}
|
||||
|
||||
gboolean
|
||||
ostree_builtin_compose (int argc, char **argv, GFile *repo_path, GError **error)
|
||||
{
|
||||
GOptionContext *context;
|
||||
gboolean ret = FALSE;
|
||||
GCancellable *cancellable = NULL;
|
||||
int i;
|
||||
gboolean skip_commit = FALSE;
|
||||
gboolean in_transaction = FALSE;
|
||||
ot_lobj OstreeRepo *repo = NULL;
|
||||
ot_lfree char *parent = NULL;
|
||||
ot_lobj GFile *destf = NULL;
|
||||
ot_lhash GHashTable *seen_branches = NULL;
|
||||
ot_lvariant GVariant *parent_commit = NULL;
|
||||
ot_lvariant GVariant *parent_commit_metadata = NULL;
|
||||
ot_lvariant GVariant *parent_commit_compose = NULL;
|
||||
ot_lvariant GVariant *commit_metadata = NULL;
|
||||
ot_lfree char *contents_checksum = NULL;
|
||||
ot_lfree char *commit_checksum = NULL;
|
||||
ot_lobj GFile *metadata_f = NULL;
|
||||
ot_lobj GFile *from_file = NULL;
|
||||
ot_lfree char *from_file_contents = NULL;
|
||||
gboolean compose_metadata_builder_initialized = FALSE;
|
||||
GVariantBuilder compose_metadata_builder;
|
||||
gboolean commit_metadata_builder_initialized = FALSE;
|
||||
GVariantBuilder commit_metadata_builder;
|
||||
GVariantIter *parent_commit_compose_iter = NULL;
|
||||
char **from_file_args = NULL;
|
||||
OstreeMutableTree *mtree = NULL;
|
||||
|
||||
context = g_option_context_new ("BRANCH1 BRANCH2 ... - Merge multiple commits into a single commit tree");
|
||||
g_option_context_add_main_entries (context, options, NULL);
|
||||
|
||||
if (!g_option_context_parse (context, &argc, &argv, error))
|
||||
goto out;
|
||||
|
||||
repo = ostree_repo_new (repo_path);
|
||||
if (!ostree_repo_check (repo, error))
|
||||
goto out;
|
||||
|
||||
if (!branch)
|
||||
{
|
||||
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||
"A branch must be specified with --branch");
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!subject)
|
||||
{
|
||||
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||
"A subject must be specified with --subject");
|
||||
goto out;
|
||||
}
|
||||
|
||||
compose_metadata_builder_initialized = TRUE;
|
||||
g_variant_builder_init (&compose_metadata_builder, G_VARIANT_TYPE ("a(ss)"));
|
||||
|
||||
if (!ostree_repo_resolve_rev (repo, branch, TRUE, &parent, error))
|
||||
goto out;
|
||||
|
||||
if (parent)
|
||||
{
|
||||
if (!ostree_repo_load_variant (repo, OSTREE_OBJECT_TYPE_COMMIT,
|
||||
parent, &parent_commit, error))
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!ostree_repo_prepare_transaction (repo, cancellable, error))
|
||||
goto out;
|
||||
|
||||
in_transaction = TRUE;
|
||||
|
||||
mtree = ostree_mutable_tree_new ();
|
||||
|
||||
if (from_file_path)
|
||||
{
|
||||
char **iter;
|
||||
|
||||
from_file = ot_gfile_new_for_path (from_file_path);
|
||||
if (!ot_gfile_load_contents_utf8 (from_file,
|
||||
&from_file_contents, NULL, NULL, error))
|
||||
goto out;
|
||||
|
||||
from_file_args = g_strsplit_set (from_file_contents, "\n", -1);
|
||||
|
||||
for (iter = from_file_args; *iter && **iter; iter++)
|
||||
{
|
||||
const char *src_branch = *iter;
|
||||
|
||||
if (seen_branches && g_hash_table_lookup (seen_branches, src_branch))
|
||||
continue;
|
||||
|
||||
if (!add_branch (repo, mtree, src_branch,
|
||||
&compose_metadata_builder,
|
||||
error))
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
|
||||
for (i = 1; i < argc; i++)
|
||||
{
|
||||
const char *src_branch = argv[i];
|
||||
|
||||
if (seen_branches && g_hash_table_lookup (seen_branches, src_branch))
|
||||
continue;
|
||||
|
||||
if (!add_branch (repo, mtree, src_branch,
|
||||
&compose_metadata_builder,
|
||||
error))
|
||||
goto out;
|
||||
}
|
||||
|
||||
commit_metadata_builder_initialized = TRUE;
|
||||
g_variant_builder_init (&commit_metadata_builder, G_VARIANT_TYPE ("a{sv}"));
|
||||
|
||||
g_variant_builder_add (&commit_metadata_builder, "{sv}",
|
||||
"ostree-compose", g_variant_builder_end (&compose_metadata_builder));
|
||||
commit_metadata = g_variant_builder_end (&commit_metadata_builder);
|
||||
g_variant_ref_sink (commit_metadata);
|
||||
|
||||
if (!ostree_repo_stage_mtree (repo, mtree, &contents_checksum, cancellable, error))
|
||||
goto out;
|
||||
|
||||
if (parent_commit)
|
||||
{
|
||||
const char *parent_contents_checksum;
|
||||
const char *parent_metadata_checksum;
|
||||
|
||||
g_variant_get_child (parent_commit, 6, "&s", &parent_contents_checksum);
|
||||
g_variant_get_child (parent_commit, 7, "&s", &parent_metadata_checksum);
|
||||
|
||||
if (strcmp (contents_checksum, parent_contents_checksum) == 0
|
||||
&& strcmp (ostree_mutable_tree_get_metadata_checksum (mtree),
|
||||
parent_metadata_checksum) == 0)
|
||||
skip_commit = TRUE;
|
||||
}
|
||||
|
||||
if (!skip_commit)
|
||||
{
|
||||
const char *root_metadata = ostree_mutable_tree_get_metadata_checksum (mtree);
|
||||
|
||||
if (!root_metadata)
|
||||
{
|
||||
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||
"Can't commit an empty tree");
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!ostree_repo_stage_commit (repo, branch, parent, subject, body, commit_metadata,
|
||||
contents_checksum,
|
||||
root_metadata,
|
||||
&commit_checksum, cancellable, error))
|
||||
goto out;
|
||||
|
||||
if (!ostree_repo_commit_transaction (repo, cancellable, error))
|
||||
goto out;
|
||||
|
||||
in_transaction = FALSE;
|
||||
|
||||
if (!ostree_repo_write_ref (repo, NULL, branch, commit_checksum, error))
|
||||
goto out;
|
||||
|
||||
g_print ("%s\n", commit_checksum);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!ostree_repo_abort_transaction (repo, cancellable, error))
|
||||
goto out;
|
||||
|
||||
in_transaction = FALSE;
|
||||
|
||||
g_print ("%s\n", parent);
|
||||
}
|
||||
|
||||
ret = TRUE;
|
||||
out:
|
||||
if (in_transaction)
|
||||
{
|
||||
(void) ostree_repo_abort_transaction (repo, cancellable, NULL);
|
||||
}
|
||||
if (compose_metadata_builder_initialized)
|
||||
g_variant_builder_clear (&compose_metadata_builder);
|
||||
if (commit_metadata_builder_initialized)
|
||||
g_variant_builder_clear (&commit_metadata_builder);
|
||||
if (context)
|
||||
g_option_context_free (context);
|
||||
if (parent_commit_compose_iter)
|
||||
g_variant_iter_free (parent_commit_compose_iter);
|
||||
g_strfreev (from_file_args);
|
||||
return ret;
|
||||
}
|
@ -31,7 +31,6 @@ gboolean ostree_builtin_cat (int argc, char **argv, GFile *repo_path, GError **e
|
||||
gboolean ostree_builtin_checkout (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
gboolean ostree_builtin_checksum (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
gboolean ostree_builtin_commit (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
gboolean ostree_builtin_compose (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
gboolean ostree_builtin_diff (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
gboolean ostree_builtin_init (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
gboolean ostree_builtin_local_clone (int argc, char **argv, GFile *repo_path, GError **error);
|
||||
|
@ -1,95 +0,0 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
# Copyright (C) 2011 Colin Walters <walters@verbum.org>
|
||||
#
|
||||
# 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.
|
||||
|
||||
set -e
|
||||
|
||||
echo "1..6"
|
||||
|
||||
. libtest.sh
|
||||
|
||||
setup_test_repository "regular"
|
||||
|
||||
$OSTREE checkout test2 checkout-test2
|
||||
|
||||
cd "${test_tmpdir}"
|
||||
mkdir -p artifact-libfoo/runtime
|
||||
cd artifact-libfoo/runtime
|
||||
mkdir -p usr/lib/
|
||||
echo 'an ELF file' > usr/lib/libfoo.so
|
||||
mkdir -p usr/share
|
||||
echo 'some data' > usr/share/foo.data
|
||||
cd ..
|
||||
mkdir devel
|
||||
cd devel
|
||||
mkdir -p usr/include
|
||||
echo 'a header' > usr/include/foo.h
|
||||
mkdir -p usr/share/doc
|
||||
echo 'some documentation' > usr/share/doc/foo.txt
|
||||
|
||||
cd ..
|
||||
$OSTREE commit -b artifact-libfoo -s 'Build 12345 of libfoo'
|
||||
|
||||
cd "${test_tmpdir}"
|
||||
mkdir -p artifact-barapp/runtime
|
||||
cd artifact-barapp/runtime
|
||||
mkdir -p usr/bin
|
||||
echo 'another ELF file' > usr/bin/bar
|
||||
cd ..
|
||||
$OSTREE commit -b artifact-barapp -s 'Build 42 of barapp'
|
||||
|
||||
echo 'ok artifacts committed'
|
||||
|
||||
cd "${test_tmpdir}"
|
||||
$OSTREE compose -s "compose 1" -b some-compose artifact-libfoo:/runtime artifact-libfoo:/devel artifact-barapp:/runtime
|
||||
echo 'ok compose'
|
||||
|
||||
$OSTREE checkout some-compose some-compose-checkout
|
||||
cd some-compose-checkout
|
||||
assert_file_has_content ./usr/bin/bar 'another ELF file'
|
||||
assert_file_has_content ./usr/share/doc/foo.txt 'some documentation'
|
||||
find | md5sum > ../some-compose-md5
|
||||
assert_file_has_content ../some-compose-md5 9038703e43d2ff2745fb7dd844de65c8
|
||||
|
||||
echo 'ok compose content'
|
||||
|
||||
cd "${test_tmpdir}"
|
||||
rm -rf some-compose-checkout some-compose-metadata
|
||||
cd "${test_tmpdir}"/artifact-barapp/runtime
|
||||
echo 'updated bar ELF file' > usr/bin/bar
|
||||
cd ..
|
||||
$OSTREE commit -b artifact-barapp -s 'Build 43 of barapp'
|
||||
$OSTREE compose -s "compose 2" -b some-compose artifact-libfoo:/runtime artifact-libfoo:/devel artifact-barapp:/runtime
|
||||
echo 'ok compose update commit'
|
||||
|
||||
cd "${test_tmpdir}"
|
||||
$OSTREE checkout some-compose some-compose-checkout
|
||||
cd some-compose-checkout
|
||||
assert_file_has_content ./usr/bin/bar 'updated bar ELF file'
|
||||
echo 'ok compose update contents'
|
||||
|
||||
cd "${test_tmpdir}"
|
||||
echo artifact-libfoo:/runtime > compose-contents.txt
|
||||
echo artifact-libfoo:/devel >> compose-contents.txt
|
||||
echo artifact-barapp:/runtime >> compose-contents.txt
|
||||
$OSTREE compose -b some-compose-from-file -s 'from file' -F compose-contents.txt
|
||||
rm -rf some-compose-checkout
|
||||
$OSTREE checkout some-compose-from-file some-compose-checkout
|
||||
cd some-compose-checkout
|
||||
assert_file_has_content ./usr/bin/bar 'updated bar ELF file'
|
||||
echo 'ok recompose from file'
|
Loading…
Reference in New Issue
Block a user