2 * Copyright 2011-2016 by Emese Revfy <re.emese@gmail.com>
3 * Licensed under the GPL v2, or (at your option) v3
6 * https://github.com/ephox-gcc-plugins/cyclomatic_complexity
8 * http://en.wikipedia.org/wiki/Cyclomatic_complexity
9 * The complexity M is then defined as:
13 * E = the number of edges of the graph
14 * N = the number of nodes of the graph
15 * P = the number of connected components (exit nodes).
18 * $ make clean; make run
21 #include "gcc-common.h"
23 int plugin_is_GPL_compatible
;
25 static struct plugin_info cyc_complexity_plugin_info
= {
26 .version
= "20160225",
27 .help
= "Cyclomatic Complexity\n",
30 static unsigned int cyc_complexity_execute(void)
33 expanded_location xloc
;
36 complexity
= n_edges_for_fn(cfun
) - n_basic_blocks_for_fn(cfun
) + 2;
38 xloc
= expand_location(DECL_SOURCE_LOCATION(current_function_decl
));
39 fprintf(stderr
, "Cyclomatic Complexity %d %s:%s\n", complexity
,
40 xloc
.file
, DECL_NAME_POINTER(current_function_decl
));
45 #define PASS_NAME cyc_complexity
48 #define TODO_FLAGS_FINISH TODO_dump_func
50 #include "gcc-generate-gimple-pass.h"
52 int plugin_init(struct plugin_name_args
*plugin_info
, struct plugin_gcc_version
*version
)
54 const char * const plugin_name
= plugin_info
->base_name
;
55 struct register_pass_info cyc_complexity_pass_info
;
57 cyc_complexity_pass_info
.pass
= make_cyc_complexity_pass();
58 cyc_complexity_pass_info
.reference_pass_name
= "ssa";
59 cyc_complexity_pass_info
.ref_pass_instance_number
= 1;
60 cyc_complexity_pass_info
.pos_op
= PASS_POS_INSERT_AFTER
;
62 if (!plugin_default_version_check(version
, &gcc_version
)) {
63 error(G_("incompatible gcc/plugin versions"));
67 register_callback(plugin_name
, PLUGIN_INFO
, NULL
,
68 &cyc_complexity_plugin_info
);
69 register_callback(plugin_name
, PLUGIN_PASS_MANAGER_SETUP
, NULL
,
70 &cyc_complexity_pass_info
);