[gegl/meta-json: 2/3] meta-json: Add initial json operation module
- From: Jon Nordby <jonnor src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gegl/meta-json: 2/3] meta-json: Add initial json operation module
- Date: Sun, 28 Dec 2014 00:08:26 +0000 (UTC)
commit b153e92e4c46767013bb7ebfab64fb553e23811f
Author: Jon Nordby <jononor gmail com>
Date: Sun Dec 28 01:03:49 2014 +0100
meta-json: Add initial json operation module
operations/core/json.c | 240 ++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 240 insertions(+), 0 deletions(-)
---
diff --git a/operations/core/json.c b/operations/core/json.c
new file mode 100644
index 0000000..5c81ea7
--- /dev/null
+++ b/operations/core/json.c
@@ -0,0 +1,240 @@
+/* This file is part of GEGL
+ *
+ * GEGL is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * GEGL is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with GEGL; if not, see <http://www.gnu.org/licenses/>.
+ *
+ * Copyright 2014 Jon Nordby <jononor gmail com>
+ */
+
+/*
+GeglOperationMetaJson : GeglOperationMeta
+ Base class for all ops, paramatrizable to the specific json data
+ Keeps the parsed json structure in memory as class_data
+ on class_init() registers GOBject properties for exposed ports
+ on attach() instantiates the nodes in subgraph, and connects them
+
+GeglModuleJson :
+ on register(), walks directories in GEGL_PATH
+ for each .json file found, registers
+
+Internal operations
+ operations/json/something.json
+Installed to, and loaded at runtime from
+ $(GEGL_PATH)/myop.json
+
+dropshadow a good initial testcase?
+*/
+
+/* JsonOp: Meta-operation base class for ops defined by .json file */
+#include <operation/gegl-operation-meta.h>
+struct _JsonOp
+{
+ GeglOperationMetaJons parent_instance;
+};
+
+typedef struct
+{
+ GeglOperationMetaJsonClass parent_class;
+} JsonOpClass;
+
+
+// FIXME: needed?
+/*
+GType
+json_op_get_type (void)
+{
+ return json_op_type_id;
+}
+*/
+
+static void
+json_op_class_init (gpointer klass, gpointer class_data)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+ // TODO: store the class data, so it can be accessed
+
+/*
+ object_class->set_property = set_property;
+ object_class->get_property = get_property;
+ object_class->constructor = gegl_chant_constructor;
+*/
+
+/* TODO: go over exported ports and create properties for them
+
+#define gegl_chant_int(name, nick, min, max, def, blurb) \
+ g_object_class_install_property (object_class, PROP_##name, \
+ g_param_spec_int (#name, nick, blurb, \
+ min, max, def, \
+ (GParamFlags) ( \
+ G_PARAM_READWRITE | \
+ G_PARAM_CONSTRUCT | \
+ GEGL_PARAM_PAD_INPUT)));
+*/
+}
+
+static void
+json_op_class_finalize (GeglChantClass *self)
+{
+}
+
+
+static void
+json_op_init (GeglChant *self)
+{
+
+}
+
+static GType
+json_op_register_type (GTypeModule *type_module, const gchar *name, gpointer klass_data)
+{
+ const GTypeInfo g_define_type_info =
+ {
+ sizeof (JsonOpClass),
+ (GBaseInitFunc) NULL,
+ (GBaseFinalizeFunc) NULL,
+ (GClassInitFunc) json_op_class_init,
+ (GClassFinalizeFunc) json_op_class_finalize,
+ klass_data,
+ sizeof (JsonOp),
+ 0, /* n_preallocs */
+ (GInstanceInitFunc) json_op_init,
+ NULL /* value_table */
+ };
+
+ return g_type_module_register_type (type_module, GEGL_TYPE_OPERATION_META_JSON, name,
+ &g_define_type_info, (GTypeFlags) flags);
+}
+
+
+static GType
+json_op_register_type_for_file (GTypeModule *type_module, const gchar *filepath)
+{
+ // TODO: parse json, pass to register_type
+ gpointer class_data = NULL;
+ // FIXME: unhardoce name, look up in json structure
+ json_op_register_type(type_module, "dropshadow_json", class_data);
+}
+
+/*
+static void
+graph_load_json(Graph *self, JsonParser *parser) {
+
+ JsonNode *rootnode = json_parser_get_root(parser);
+ g_assert(JSON_NODE_HOLDS_OBJECT(rootnode));
+ JsonObject *root = json_node_get_object(rootnode);
+
+ // Processes
+ JsonObject *processes = json_object_get_object_member(root, "processes");
+ g_assert(processes);
+
+ GList *process_names = json_object_get_members(processes);
+ for (int i=0; i<g_list_length(process_names); i++) {
+ const gchar *name = g_list_nth_data(process_names, i);
+ JsonObject *proc = json_object_get_object_member(processes, name);
+ const gchar *component = json_object_get_string_member(proc, "component");
+ graph_add_node(self, name, component);
+ }
+
+ //g_free(process_names); crashes??
+
+ // Connections
+ JsonArray *connections = json_object_get_array_member(root, "connections");
+ g_assert(connections);
+ for (int i=0; i<json_array_get_length(connections); i++) {
+ JsonObject *conn = json_array_get_object_element(connections, i);
+
+ JsonObject *tgt = json_object_get_object_member(conn, "tgt");
+ const gchar *tgt_proc = json_object_get_string_member(tgt, "process");
+ const gchar *tgt_port = json_object_get_string_member(tgt, "port");
+
+ JsonNode *srcnode = json_object_get_member(conn, "src");
+ if (srcnode) {
+ // Connection
+ JsonObject *src = json_object_get_object_member(conn, "src");
+ const gchar *src_proc = json_object_get_string_member(src, "process");
+ const gchar *src_port = json_object_get_string_member(src, "port");
+
+ graph_add_edge(self, src_proc, src_port, tgt_proc, tgt_port);
+ } else {
+ // IIP
+ JsonNode *datanode = json_object_get_member(conn, "data");
+ GValue value = G_VALUE_INIT;
+ g_assert(JSON_NODE_HOLDS_VALUE(datanode));
+ json_node_get_value(datanode, &value);
+
+ graph_add_iip(self, tgt_proc, tgt_port, &value);
+ g_value_unset(&value);
+ }
+ }
+
+ // Exported ports
+ if (json_object_has_member(root, "inports")) {
+ JsonObject *inports = json_object_get_object_member(root, "inports");
+ GList *inport_names = json_object_get_members(inports);
+ for (int i=0; i<g_list_length(inport_names); i++) {
+ const gchar *name = g_list_nth_data(inport_names, i);
+ JsonObject *conn = json_object_get_object_member(inports, name);
+ const gchar *proc = json_object_get_string_member(conn, "process");
+ const gchar *port = json_object_get_string_member(conn, "port");
+ graph_add_port(self, GraphInPort, name, proc, port);
+ }
+ }
+
+ if (json_object_has_member(root, "outports")) {
+ JsonObject *outports = json_object_get_object_member(root, "outports");
+ GList *outport_names = json_object_get_members(outports);
+ for (int i=0; i<g_list_length(outport_names); i++) {
+ const gchar *name = g_list_nth_data(outport_names, i);
+ JsonObject *conn = json_object_get_object_member(outports, name);
+ const gchar *proc = json_object_get_string_member(conn, "process");
+ const gchar *port = json_object_get_string_member(conn, "port");
+ graph_add_port(self, GraphOutPort, name, proc, port);
+ }
+ }
+}
+*/
+
+/* JSON operation enumeration */
+#define JSON_OP_DIR "/home/jon/contrib/code/imgflo-server/runtime/dependencies/gegl/operations/json
+static void
+json_register_operations(GTypeModule *module)
+{
+ // FIXME: unhardcode, follow GEGL_PATH properly
+ json_op_register_type_for_file (module, JSON_OP_DIR "/dropshadow.json");
+}
+
+
+/*** Module registration ***/
+static const GeglModuleInfo modinfo =
+{
+ GEGL_MODULE_ABI_VERSION
+};
+
+/* prototypes added to silence warnings from gcc for -Wmissing-prototypes*/
+gboolean gegl_module_register (GTypeModule *module);
+const GeglModuleInfo * gegl_module_query (GTypeModule *module);
+
+G_MODULE_EXPORT const GeglModuleInfo *
+gegl_module_query (GTypeModule *module)
+{
+ return &modinfo;
+}
+
+G_MODULE_EXPORT gboolean
+gegl_module_register (GTypeModule *module)
+{
+ json_register_operations (module);
+
+ return TRUE;
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]