changed log directory to $HOME/.local/share/varnam/ibus-engine/logs
[varnamproject:pskiranns-libvarnam-ibus.git] / common / engine-util.c~
1 /**
2   The MIT License (MIT)
3
4   Copyright (c) Navaneeth K.N
5
6   Permission is hereby granted, free of charge, to any person obtaining a copy
7   of this software and associated documentation files (the "Software"), to deal
8   in the Software without restriction, including without limitation the rights
9   to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10   copies of the Software, and to permit persons to whom the Software is
11   furnished to do so, subject to the following conditions:
12
13   The above copyright notice and this permission notice shall be included in
14   all copies or substantial portions of the Software.
15
16   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17   IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18   FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19   AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20   LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21   OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22   THE SOFTWARE.
23 **/
24
25 #include <stdio.h>
26 #include <glib.h>
27 #include "engine-util.h"
28
29 static gchar *langCode = NULL;
30 static gchar *componentName = NULL;
31 static FILE *logfile = NULL;
32 static void
33 glib_log_handler (const gchar *logDomain, GLogLevelFlags logLevel, const gchar *message, gpointer data)
34 {
35   GString *logs;
36
37   if (logfile == NULL) {
38     logs = g_string_new (g_get_user_data_dir ());
39     if (logs == NULL)
40       return;
41
42     g_string_append (logs, "/varnam/ibus-engine/logs");
43     if (g_mkdir_with_parents (logs->str, 0755) == -1) {
44       g_printerr ("Failed to create logs directory: %s. Logging to file will be disabled\n", logs->str);
45     }
46
47     g_string_append_printf (logs, "/%s-logs-%s.txt", componentName, langCode);
48     logfile = fopen (logs->str, "a");
49     if (logfile == NULL) {
50       g_printerr ("Failed to create logs: %s. Logging to file will be disabled\n", logs->str);
51       g_string_free (logs, TRUE);
52       return;
53     }
54     g_string_free (logs, TRUE);
55   }
56
57   fprintf (logfile, "%s %s", logDomain, message);
58   fflush (logfile);
59   g_print ("%s %s", logDomain, message);
60 }
61
62 void
63 enable_logging (gchar *cname, gchar *lcode)
64 {
65   componentName = cname;
66   langCode = lcode;
67   g_log_set_default_handler (glib_log_handler, NULL);
68 }
69
70 GString*
71 ibus_varnam_engine_get_config_dir()
72 {
73   GString *configDir;
74   configDir = g_string_new (g_get_user_config_dir ());
75   g_string_append (configDir, "/varnam/ibus-engine");
76   if (g_mkdir_with_parents (configDir->str, 0755) == -1) {
77     g_printerr ("Failed to create config directory: %s\n", configDir->str);
78   }
79
80   return configDir;
81 }
82
83 GString*
84 ibus_varnam_engine_get_data_dir()
85 {
86   GString *dataDir;
87   dataDir = g_string_new (g_get_user_data_dir ());
88   g_string_append (dataDir, "/varnam/suggestions");
89   if (g_mkdir_with_parents (dataDir->str, 0755) == -1) {
90     g_printerr ("Failed to create config directory: %s\n", dataDir->str);
91   }
92
93   return dataDir;
94 }
95
96 void
97 ibus_varnam_engine_persist_key_file (GKeyFile *keyFile, GString *filePath)
98 {
99  gchar *keyFileContents;
100  FILE *f = NULL;
101  f = fopen (filePath->str, "w");
102  if (f == NULL) {
103    g_printerr ("Failed to persist key file to: %s\n", filePath->str);
104  }
105  else {
106    keyFileContents = g_key_file_to_data (keyFile, NULL, NULL);
107    fprintf (f, "%s", keyFileContents);
108    fclose (f);
109    g_free (keyFileContents);
110  }
111 }
112