diff --git a/js/ui/main.js b/js/ui/main.js
index aecf5fbca..76db22016 100644
--- a/js/ui/main.js
+++ b/js/ui/main.js
@@ -218,16 +218,10 @@ function _initializeUI() {
if (screenShield) {
screenShield.lockIfWasLocked();
}
- if (LoginManager.haveSystemd() &&
- sessionMode.currentMode != 'gdm' &&
+ if (sessionMode.currentMode != 'gdm' &&
sessionMode.currentMode != 'initial-setup') {
- // Do not import globally to not depend
- // on systemd on non-systemd systems.
- let GSystem = imports.gi.GSystem;
- GSystem.log_structured_print('GNOME Shell started at ' + _startDate,
- ['MESSAGE_ID=' + GNOMESHELL_STARTED_MESSAGE_ID]);
- } else {
- log('GNOME Shell started at ' + _startDate);
+ Shell.log_structured_print('GNOME Shell started at ' + _startDate,
+ ['MESSAGE_ID=' + GNOMESHELL_STARTED_MESSAGE_ID]);
}
});
}
diff --git a/src/shell-global.c b/src/shell-global.c
index e9c60bff7..af99747bd 100644
--- a/src/shell-global.c
+++ b/src/shell-global.c
@@ -28,6 +28,12 @@
#include
#include
+#ifdef HAVE_SYSTEMD
+#include
+#include
+#include
+#endif
+
/* Memory report bits */
#ifdef HAVE_MALLINFO
#include
@@ -1298,6 +1304,52 @@ shell_global_reexec_self (ShellGlobal *global)
#endif
}
+/**
+ * shell_global_log_structured:
+ * @message: A message to print
+ * @keys: (allow-none) (array zero-terminated=1) (element-type utf8): Optional structured data
+ *
+ * Log structured data in an operating-system specific fashion. The
+ * parameter @opts should be an array of UTF-8 KEY=VALUE strings.
+ * This function does not support binary data. See
+ * http://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html
+ * or more information about fields that can be used on a systemd
+ * system.
+ *
+ */
+void
+shell_global_log_structured (const char *message,
+ const char *const *keys)
+{
+#ifdef HAVE_SYSTEMD
+ const char *const*iter;
+ char *msgkey;
+ guint i, n_opts;
+ struct iovec *iovs;
+
+ for (n_opts = 0, iter = keys; *iter; iter++, n_opts++)
+ ;
+
+ n_opts++; /* Add one for MESSAGE= */
+ iovs = g_alloca (sizeof (struct iovec) * n_opts);
+
+ for (i = 0, iter = keys; *iter; iter++, i++) {
+ iovs[i].iov_base = (char*)keys[i];
+ iovs[i].iov_len = strlen (keys[i]);
+ }
+ g_assert(i == n_opts-1);
+ msgkey = g_strconcat ("MESSAGE=", message, NULL);
+ iovs[i].iov_base = msgkey;
+ iovs[i].iov_len = strlen (msgkey);
+
+ // The code location isn't useful since we're wrapping
+ sd_journal_sendv (iovs, n_opts);
+ g_free (msgkey);
+#else
+ g_print ("%s\n", message);
+#endif
+}
+
/**
* shell_global_notify_error:
* @global: a #ShellGlobal
diff --git a/src/shell-global.h b/src/shell-global.h
index 4a03087b9..b10c5e608 100644
--- a/src/shell-global.h
+++ b/src/shell-global.h
@@ -124,6 +124,9 @@ void shell_global_init_xdnd (ShellGlobal *global);
void shell_global_reexec_self (ShellGlobal *global);
+void shell_global_log_structured (const char *message,
+ const char *const *keys);
+
const char * shell_global_get_session_mode (ShellGlobal *global);
void shell_global_set_runtime_state (ShellGlobal *global,