this is a big one! im putting stats in here just cuz!
[mikachu/openbox.git] / parser / parse.h
similarity index 72%
rename from openbox/parse.h
rename to parser/parse.h
index 199e810..948bf4b 100644 (file)
@@ -1,8 +1,6 @@
 #ifndef __parse_h
 #define __parse_h
 
-#include "action.h"
-
 #include <libxml/parser.h>
 #include <glib.h>
 
@@ -11,13 +9,22 @@ typedef void (*ParseCallback)(xmlDocPtr doc, xmlNodePtr node, void *data);
 void parse_startup();
 void parse_shutdown();
 
-void parse_register(const char *tag, ParseCallback func, void *data);
+/* Loads Openbox's rc, from $HOME or $PREFIX as a fallback */
+gboolean parse_load_rc(xmlDocPtr *doc, xmlNodePtr *root);
 
-void parse_config();
+/* callbacks - must call parse_startup to use these */
 
+void parse_register(const char *tag, ParseCallback func, void *data);
 void parse_tree(xmlDocPtr doc, xmlNodePtr node, void *nothing);
 
 
+/* open/close */
+
+gboolean parse_load(const char *path, const char *rootname,
+                    xmlDocPtr *doc, xmlNodePtr *root);
+void parse_close(xmlDocPtr doc);
+
+
 /* helpers */
 
 xmlNodePtr parse_find_node(const char *tag, xmlNodePtr node);
@@ -33,6 +40,4 @@ gboolean parse_attr_contains(const char *val, xmlNodePtr node,
 gboolean parse_attr_string(const char *name, xmlNodePtr node, char **value);
 gboolean parse_attr_int(const char *name, xmlNodePtr node, int *value);
 
-Action *parse_action(xmlDocPtr doc, xmlNodePtr node);
-
 #endif