debug-manager: use g_spawn_sync() instead of fork() and waitpid()
[anjuta.git] / plugins / git / git-branch-delete-command.c
blobddb1e11a37562bb2ad9c7fc1fb89ebe08acf4d7e
1 /* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 4; tab-width: 4 -*- */
2 /*
3 * anjuta
4 * Copyright (C) James Liggett 2008 <jrliggett@cox.net>
5 *
6 * anjuta is free software.
7 *
8 * You may redistribute it and/or modify it under the terms of the
9 * GNU General Public License, as published by the Free Software
10 * Foundation; either version 2 of the License, or (at your option)
11 * any later version.
13 * anjuta is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16 * See the GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with anjuta. If not, write to:
20 * The Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor
22 * Boston, MA 02110-1301, USA.
25 #include "git-branch-delete-command.h"
27 struct _GitBranchDeleteCommandPriv
29 GList *branches;
30 gboolean remote;
31 gboolean require_merged;
34 G_DEFINE_TYPE (GitBranchDeleteCommand, git_branch_delete_command, GIT_TYPE_COMMAND);
36 static void
37 git_branch_delete_command_init (GitBranchDeleteCommand *self)
39 self->priv = g_new0 (GitBranchDeleteCommandPriv, 1);
42 static void
43 git_branch_delete_command_finalize (GObject *object)
45 GitBranchDeleteCommand *self;
47 self = GIT_BRANCH_DELETE_COMMAND (object);
49 anjuta_util_glist_strings_free (self->priv->branches);
50 g_free (self->priv);
52 G_OBJECT_CLASS (git_branch_delete_command_parent_class)->finalize (object);
55 static guint
56 git_branch_delete_command_run (AnjutaCommand *command)
58 GitBranchDeleteCommand *self;
60 self = GIT_BRANCH_DELETE_COMMAND (command);
62 git_command_add_arg (GIT_COMMAND (command), "branch");
64 if (self->priv->remote)
65 git_command_add_arg (GIT_COMMAND (command), "-r");
67 if (self->priv->require_merged)
68 git_command_add_arg (GIT_COMMAND (command), "-d");
69 else
70 git_command_add_arg (GIT_COMMAND (command), "-D");
72 git_command_add_list_to_args (GIT_COMMAND (command), self->priv->branches);
74 return 0;
77 static void
78 git_branch_delete_command_class_init (GitBranchDeleteCommandClass *klass)
80 GObjectClass* object_class = G_OBJECT_CLASS (klass);
81 GitCommandClass* parent_class = GIT_COMMAND_CLASS (klass);
82 AnjutaCommandClass* command_class = ANJUTA_COMMAND_CLASS (klass);
84 object_class->finalize = git_branch_delete_command_finalize;
85 parent_class->output_handler = git_command_send_output_to_info;
86 command_class->run = git_branch_delete_command_run;
90 GitBranchDeleteCommand *
91 git_branch_delete_command_new (const gchar *working_directory,
92 GList *branches,
93 gboolean remote,
94 gboolean require_merged)
96 GitBranchDeleteCommand *self;
98 self = g_object_new (GIT_TYPE_BRANCH_DELETE_COMMAND,
99 "working-directory", working_directory,
100 "single-line-output", TRUE,
101 NULL);
103 self->priv->branches = git_command_copy_string_list (branches);
104 self->priv->remote = remote;
105 self->priv->require_merged = require_merged;
107 return self;