[glibmm] generate_extra_defs.cc: Write signal flags to .defs files
- From: Kjell Ahlstedt <kjellahl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glibmm] generate_extra_defs.cc: Write signal flags to .defs files
- Date: Tue, 12 Sep 2017 14:56:39 +0000 (UTC)
commit 987009fba6a88ca93abf52091cc2aba564d63471
Author: Kjell Ahlstedt <kjellahlstedt gmail com>
Date: Tue Sep 12 16:53:47 2017 +0200
generate_extra_defs.cc: Write signal flags to .defs files
Bug 785895
tools/extra_defs_gen/generate_extra_defs.cc | 48 +++++++++++++++++----------
1 files changed, 30 insertions(+), 18 deletions(-)
---
diff --git a/tools/extra_defs_gen/generate_extra_defs.cc b/tools/extra_defs_gen/generate_extra_defs.cc
index 21adf48..23300c8 100644
--- a/tools/extra_defs_gen/generate_extra_defs.cc
+++ b/tools/extra_defs_gen/generate_extra_defs.cc
@@ -21,6 +21,21 @@
#include <regex>
#include <sstream>
+namespace
+{
+void add_signal_flag_if(std::string& strFlags, const char* strFlag,
+ const GSignalQuery& signalQuery, GSignalFlags flag)
+{
+ if (signalQuery.signal_flags & flag)
+ {
+ if (!strFlags.empty())
+ strFlags += ", ";
+ strFlags += strFlag;
+ }
+}
+
+} // anonymous namespace
+
std::string
get_property_with_node_name(
GParamSpec* pParamSpec, const std::string& strObjectName, const std::string& strNodeName)
@@ -260,24 +275,21 @@ get_signals(GType gtype, GTypeIsAPointerFunc is_a_pointer_func)
// G_SIGNAL_TYPE_STATIC_SCOPE;
strResult += " (return-type \"" + strReturnTypeName + "\")\n";
- // When:
- {
- bool bWhenFirst = (signalQuery.signal_flags & G_SIGNAL_RUN_FIRST) == G_SIGNAL_RUN_FIRST;
- bool bWhenLast = (signalQuery.signal_flags & G_SIGNAL_RUN_LAST) == G_SIGNAL_RUN_LAST;
-
- std::string strWhen = "unknown";
-
- if (bWhenFirst && bWhenLast)
- strWhen = "both";
- else if (bWhenFirst)
- strWhen = "first";
- else if (bWhenLast)
- strWhen = "last";
-
- strResult += " (when \"" + strWhen + "\")\n";
- }
- bool bDeprecated = (signalQuery.signal_flags & G_SIGNAL_DEPRECATED) == G_SIGNAL_DEPRECATED;
- if (bDeprecated)
+ // Flags:
+ std::string strFlags;
+ add_signal_flag_if(strFlags, "Run First", signalQuery, G_SIGNAL_RUN_FIRST);
+ add_signal_flag_if(strFlags, "Run Last", signalQuery, G_SIGNAL_RUN_LAST);
+ add_signal_flag_if(strFlags, "Run Cleanup", signalQuery, G_SIGNAL_RUN_CLEANUP);
+ add_signal_flag_if(strFlags, "No Recurse", signalQuery, G_SIGNAL_NO_RECURSE);
+ add_signal_flag_if(strFlags, "Action", signalQuery, G_SIGNAL_ACTION);
+ add_signal_flag_if(strFlags, "No Hooks", signalQuery, G_SIGNAL_NO_HOOKS);
+ add_signal_flag_if(strFlags, "Must Collect", signalQuery, G_SIGNAL_MUST_COLLECT);
+ strResult += " (flags \"" + strFlags + "\")\n";
+
+ if (signalQuery.signal_flags & G_SIGNAL_DETAILED)
+ strResult += " (detailed #t)\n"; // Default: not detailed
+
+ if (signalQuery.signal_flags & G_SIGNAL_DEPRECATED)
strResult += " (deprecated #t)\n"; // Default: not deprecated
// Loop through the list of parameters:
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]