[gnome-builder/wip/slaf/beautifier: 2/2] beautifier plugin: add clang-format support
- From: Sébastien Lafargue <slafargue src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/slaf/beautifier: 2/2] beautifier plugin: add clang-format support
- Date: Sat, 3 Dec 2016 12:17:06 +0000 (UTC)
commit e2954c7854f8741d60cac8dafc6f1385af0725b1
Author: Sebastien Lafargue <slafargue gnome org>
Date: Thu Dec 1 22:55:14 2016 +0100
beautifier plugin: add clang-format support
.beautifier/c/clang-format.cfg | 58 ++++++++++++++++++++
.beautifier/c/config.ini | 5 ++
plugins/beautifier/gb-beautifier-config.c | 7 +--
plugins/beautifier/gb-beautifier-config.h | 1 +
plugins/beautifier/gb-beautifier-process.c | 82 +++++++++++++++++++++++++++-
5 files changed, 148 insertions(+), 5 deletions(-)
---
diff --git a/.beautifier/c/clang-format.cfg b/.beautifier/c/clang-format.cfg
new file mode 100644
index 0000000..3f2972f
--- /dev/null
+++ b/.beautifier/c/clang-format.cfg
@@ -0,0 +1,58 @@
+---
+# C format
+Language: Cpp
+
+AlignAfterOpenBracket: Align
+AlignConsecutiveAssignments: false
+AlignConsecutiveDeclarations: false
+AlignEscapedNewlinesLeft: false
+AlignOperands: true
+AlignTrailingComments: false
+AllowAllParametersOfDeclarationOnNextLine: true
+AllowShortBlocksOnASingleLine: false
+AllowShortCaseLabelsOnASingleLine: true
+AllowShortFunctionsOnASingleLine: None
+AllowShortIfStatementsOnASingleLine: false
+AllowShortLoopsOnASingleLine: false
+AlwaysBreakAfterReturnType: All
+AlwaysBreakBeforeMultilineStrings: true
+BinPackArguments: true
+BinPackParameters: false
+BreakBeforeBinaryOperators: None
+BreakBeforeBraces: GNU
+BreakBeforeTernaryOperators: false
+ColumnLimit: 120
+CommentPragmas: '^ IWYU pragma:'
+ContinuationIndentWidth: 2
+DerivePointerAlignment: false
+DisableFormat: false
+ExperimentalAutoDetectBinPacking: false
+IndentCaseLabels: false
+IndentWidth: 2
+IndentWrappedFunctionNames: false
+KeepEmptyLinesAtTheStartOfBlocks: false
+MacroBlockBegin: ''
+MacroBlockEnd: ''
+MaxEmptyLinesToKeep: 2
+PenaltyBreakBeforeFirstCallParameter: 19
+PenaltyBreakComment: 300
+PenaltyBreakFirstLessLess: 120
+PenaltyBreakString: 1000
+PenaltyExcessCharacter: 1000000
+PointerAlignment: Right
+ReflowComments: false
+SortIncludes: false
+SpaceAfterCStyleCast: false
+SpaceBeforeAssignmentOperators: true
+SpaceBeforeParens: Always
+SpaceInEmptyParentheses: false
+SpacesBeforeTrailingComments: 1
+SpacesInContainerLiterals: true
+SpacesInCStyleCastParentheses: false
+SpacesInParentheses: false
+SpacesInSquareBrackets: false
+Standard: Cpp11
+TabWidth: 4
+UseTab: Never
+...
+
diff --git a/.beautifier/c/config.ini b/.beautifier/c/config.ini
index ed2abca..22f9bf3 100644
--- a/.beautifier/c/config.ini
+++ b/.beautifier/c/config.ini
@@ -9,3 +9,8 @@ default = gnome-builder.cfg
command = uncrustify
name = GNOME Builder project
+
+[clang-format.cfg]
+
+command = clang-format
+name = GNOME Builder project clang-format
diff --git a/plugins/beautifier/gb-beautifier-config.c b/plugins/beautifier/gb-beautifier-config.c
index c8f627d..d2c5d48 100644
--- a/plugins/beautifier/gb-beautifier-config.c
+++ b/plugins/beautifier/gb-beautifier-config.c
@@ -155,10 +155,9 @@ add_entries_from_config_ini_file (GbBeautifierWorkbenchAddin *self,
g_autofree gchar *file_path = NULL;
if (0 == g_strcmp0 (command, "uncrustify"))
- {
- g_clear_pointer (&command, g_free);
- entry.command = GB_BEAUTIFIER_CONFIG_COMMAND_UNCRUSTIFY;
- }
+ entry.command = GB_BEAUTIFIER_CONFIG_COMMAND_UNCRUSTIFY;
+ else if (0 == g_strcmp0 (command, "clang-format"))
+ entry.command = GB_BEAUTIFIER_CONFIG_COMMAND_CLANG_FORMAT;
else
goto fail;
diff --git a/plugins/beautifier/gb-beautifier-config.h b/plugins/beautifier/gb-beautifier-config.h
index 12b7a99..94d8cfe 100644
--- a/plugins/beautifier/gb-beautifier-config.h
+++ b/plugins/beautifier/gb-beautifier-config.h
@@ -27,6 +27,7 @@ G_BEGIN_DECLS
typedef enum
{
+ GB_BEAUTIFIER_CONFIG_COMMAND_CLANG_FORMAT,
GB_BEAUTIFIER_CONFIG_COMMAND_UNCRUSTIFY,
} GbBeautifierConfigCommand;
diff --git a/plugins/beautifier/gb-beautifier-process.c b/plugins/beautifier/gb-beautifier-process.c
index 76233ab..2c7dace 100644
--- a/plugins/beautifier/gb-beautifier-process.c
+++ b/plugins/beautifier/gb-beautifier-process.c
@@ -34,6 +34,9 @@ typedef struct
GbBeautifierConfigCommand command;
GFile *src_file;
GFile *config_file;
+ GFile *tmp_workdir_file;
+ GFile *tmp_src_file;
+ GFile *tmp_config_file;
gchar *lang_id;
gchar *text;
} ProcessState;
@@ -52,8 +55,16 @@ process_state_free (gpointer data)
gb_beautifier_helper_remove_tmp_file (state->self, state->src_file);
g_clear_object (&state->src_file);
-
g_clear_object (&state->config_file);
+
+ g_file_delete (state->tmp_config_file, NULL, NULL);
+ g_file_delete (state->tmp_src_file, NULL, NULL);
+ g_file_delete (state->tmp_workdir_file, NULL, NULL);
+
+ g_clear_object (&state->tmp_workdir_file);
+ g_clear_object (&state->tmp_config_file);
+ g_clear_object (&state->tmp_src_file);
+
g_free (state->lang_id);
g_free (state->text);
@@ -98,6 +109,73 @@ gb_beautifier_process_create_for_uncrustify (GbBeautifierWorkbenchAddin *self,
return subprocess;
}
+static GSubprocess *
+gb_beautifier_process_create_for_clang_format (GbBeautifierWorkbenchAddin *self,
+ ProcessState *state,
+ GError *error)
+{
+ g_autoptr(GSubprocessLauncher) launcher = NULL;
+ GSubprocess *subprocess = NULL;
+ GPtrArray *args;
+ gchar *config_path;
+ gchar *src_path;
+ g_autofree gchar *tmp_workdir = NULL;
+ g_autofree gchar *tmp_config_path = NULL;
+ g_autofree gchar *tmp_src_path = NULL;
+
+ g_assert (GB_IS_BEAUTIFIER_WORKBENCH_ADDIN (self));
+ g_assert (state != NULL);
+
+ config_path = g_file_get_path (state->config_file);
+ src_path = g_file_get_path (state->src_file);
+
+ g_assert (!ide_str_empty0 (config_path));
+ g_assert (!ide_str_empty0 (src_path));
+ g_assert (!ide_str_empty0 (state->lang_id));
+
+ if (NULL == (tmp_workdir = g_dir_make_tmp ("gnome-builder-beautify-XXXXXX",
+ &error)))
+ return NULL;
+
+ state->tmp_workdir_file = g_file_new_for_path (tmp_workdir);
+ tmp_config_path = g_build_filename (tmp_workdir,
+ ".clang-format",
+ NULL);
+ state->tmp_config_file = g_file_new_for_path (tmp_config_path);
+ if (!g_file_copy (state->config_file,
+ state->tmp_config_file,
+ G_FILE_COPY_OVERWRITE,
+ NULL, NULL, NULL,
+ &error))
+ return NULL;
+
+ tmp_src_path = g_build_filename (tmp_workdir,
+ "src_file",
+ NULL);
+ state->tmp_src_file = g_file_new_for_path (tmp_src_path);
+ if (!g_file_copy (state->src_file,
+ state->tmp_src_file,
+ G_FILE_COPY_OVERWRITE,
+ NULL, NULL, NULL,
+ &error))
+ return NULL;
+
+ args = g_ptr_array_new ();
+ g_ptr_array_add (args, "clang-format");
+ g_ptr_array_add (args, "-style=file");
+ g_ptr_array_add (args, tmp_src_path);
+ g_ptr_array_add (args, NULL);
+
+ launcher = g_subprocess_launcher_new (G_SUBPROCESS_FLAGS_STDOUT_PIPE | G_SUBPROCESS_FLAGS_STDERR_PIPE);
+ g_subprocess_launcher_set_cwd (launcher, tmp_workdir);
+ subprocess = g_subprocess_launcher_spawnv (launcher,
+ (const gchar * const *)args->pdata,
+ &error);
+
+ g_ptr_array_free (args, TRUE);
+ return subprocess;
+}
+
static void
process_communicate_utf8_cb (GObject *object,
GAsyncResult *result,
@@ -175,6 +253,8 @@ create_tmp_file_cb (GObject *object,
if (state->command == GB_BEAUTIFIER_CONFIG_COMMAND_UNCRUSTIFY)
process = gb_beautifier_process_create_for_uncrustify (self, state, error);
+ else if (state->command == GB_BEAUTIFIER_CONFIG_COMMAND_CLANG_FORMAT)
+ process = gb_beautifier_process_create_for_clang_format (self, state, error);
else
g_assert_not_reached ();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]