summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--dive.h4
-rw-r--r--main.c16
2 files changed, 20 insertions, 0 deletions
diff --git a/dive.h b/dive.h
index e202279af..1a61a4a45 100644
--- a/dive.h
+++ b/dive.h
@@ -439,4 +439,8 @@ extern const char *subsurface_default_filename(void);
#define FRACTION(n,x) ((unsigned)(n)/(x)),((unsigned)(n)%(x))
+#ifdef DEBUGFILE
+extern char *debugfilename;
+extern FILE *debugfile;
+#endif
#endif /* DIVE_H */
diff --git a/main.c b/main.c
index d3bd44335..95f63713d 100644
--- a/main.c
+++ b/main.c
@@ -7,6 +7,11 @@
#include "dive.h"
#include "divelist.h"
+#ifdef DEBUGFILE
+char *debugfilename;
+FILE *debugfile;
+#endif
+
struct units output_units;
/* random helper functions, used here or elsewhere */
@@ -222,6 +227,13 @@ int main(int argc, char **argv)
init_ui(&argc, &argv);
+#ifdef DEBUGFILE
+ debugfilename = (char *)subsurface_default_filename();
+ strncpy(debugfilename + strlen(debugfilename) - 3, "log", 3);
+ if (g_mkdir_with_parents(g_path_get_dirname(debugfilename), 0664) != 0 ||
+ (debugfile = g_fopen(debugfilename, "w")) == NULL)
+ printf("oh boy, can't create debugfile");
+#endif
for (i = 1; i < argc; i++) {
const char *a = argv[i];
@@ -256,5 +268,9 @@ int main(int argc, char **argv)
parse_xml_exit();
+#ifdef DEBUGFILE
+ if (debugfile)
+ fclose(debugfile);
+#endif
return 0;
}