summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/lib-config/iconfig.h2
-rw-r--r--src/lib-config/parse.c13
-rw-r--r--src/lib-config/write.c23
3 files changed, 20 insertions, 18 deletions
diff --git a/src/lib-config/iconfig.h b/src/lib-config/iconfig.h
index 739a12c7..3d9eb931 100644
--- a/src/lib-config/iconfig.h
+++ b/src/lib-config/iconfig.h
@@ -48,7 +48,6 @@ struct _CONFIG_NODE {
struct _CONFIG_REC {
char *fname;
- int handle;
int create_mode;
int modifycounter; /* increase every time something is changed */
@@ -60,6 +59,7 @@ struct _CONFIG_REC {
GScanner *scanner;
/* while writing to configuration file.. */
+ GIOChannel *handle;
int tmp_indent_level; /* indentation position */
int tmp_last_lf; /* last character was a line feed */
};
diff --git a/src/lib-config/parse.c b/src/lib-config/parse.c
index f0446f0a..22832c07 100644
--- a/src/lib-config/parse.c
+++ b/src/lib-config/parse.c
@@ -269,20 +269,21 @@ void config_parse_init(CONFIG_REC *rec, const char *name)
int config_parse(CONFIG_REC *rec)
{
+ int fd;
+
g_return_val_if_fail(rec != NULL, -1);
g_return_val_if_fail(rec->fname != NULL, -1);
- rec->handle = open(rec->fname, O_RDONLY);
- if (rec->handle == -1)
+ fd = open(rec->fname, O_RDONLY);
+ if (fd == -1)
return config_error(rec, g_strerror(errno));
config_parse_init(rec, rec->fname);
- g_scanner_input_file(rec->scanner, rec->handle);
+ g_scanner_input_file(rec->scanner, fd);
config_parse_loop(rec, rec->mainnode, G_TOKEN_EOF);
g_scanner_destroy(rec->scanner);
- close(rec->handle);
- rec->handle = -1;
+ close(fd);
return rec->last_error == NULL ? 0 : -1;
}
@@ -310,7 +311,6 @@ CONFIG_REC *config_open(const char *fname, int create_mode)
rec = g_new0(CONFIG_REC, 1);
rec->fname = fname == NULL ? NULL : g_strdup(fname);
- rec->handle = -1;
rec->create_mode = create_mode;
rec->mainnode = g_new0(CONFIG_NODE, 1);
rec->mainnode->type = NODE_TYPE_BLOCK;
@@ -327,7 +327,6 @@ void config_close(CONFIG_REC *rec)
config_nodes_remove_all(rec);
g_free(rec->mainnode);
- if (rec->handle != -1) close(rec->handle);
g_hash_table_foreach(rec->cache, (GHFunc) g_free, NULL);
g_hash_table_destroy(rec->cache);
g_hash_table_destroy(rec->cache_nodes);
diff --git a/src/lib-config/write.c b/src/lib-config/write.c
index c5f0a617..5a06b177 100644
--- a/src/lib-config/write.c
+++ b/src/lib-config/write.c
@@ -32,7 +32,8 @@ static int config_write_indent(CONFIG_REC *rec)
int n;
for (n = 0; n < rec->tmp_indent_level/CONFIG_INDENT_SIZE; n++) {
- if (write(rec->handle, indent_block, CONFIG_INDENT_SIZE) == -1)
+ if (g_io_channel_write_chars(rec->handle, indent_block, CONFIG_INDENT_SIZE,
+ NULL, NULL) == G_IO_STATUS_ERROR)
return -1;
}
@@ -57,12 +58,14 @@ static int config_write_str(CONFIG_REC *rec, const char *str)
p = strchr(strpos, '\n');
if (p == NULL) {
- if (write(rec->handle, strpos, strlen(strpos)) == -1)
+ if (g_io_channel_write_chars(rec->handle, strpos, strlen(strpos),
+ NULL, NULL) == G_IO_STATUS_ERROR)
return -1;
strpos = "";
rec->tmp_last_lf = FALSE;
} else {
- if (write(rec->handle, strpos, (int) (p-strpos)+1) == -1)
+ if (g_io_channel_write_chars(rec->handle, strpos, (int) (p-strpos)+1,
+ NULL, NULL) == G_IO_STATUS_ERROR)
return -1;
strpos = p+1;
rec->tmp_last_lf = TRUE;
@@ -297,20 +300,20 @@ static int config_write_block(CONFIG_REC *rec, CONFIG_NODE *node, int list, int
int config_write(CONFIG_REC *rec, const char *fname, int create_mode)
{
int ret;
+ int fd;
g_return_val_if_fail(rec != NULL, -1);
g_return_val_if_fail(fname != NULL || rec->fname != NULL, -1);
g_return_val_if_fail(create_mode != -1 || rec->create_mode != -1, -1);
- if (rec->handle != -1)
- close(rec->handle);
-
- rec->handle = open(fname != NULL ? fname : rec->fname,
+ fd = open(fname != NULL ? fname : rec->fname,
O_WRONLY | O_TRUNC | O_CREAT,
create_mode != -1 ? create_mode : rec->create_mode);
- if (rec->handle == -1)
+ if (fd == -1)
return config_error(rec, g_strerror(errno));
+ rec->handle = g_io_channel_unix_new(fd);
+ g_io_channel_set_encoding(rec->handle, NULL, NULL);
rec->tmp_indent_level = 0;
rec->tmp_last_lf = TRUE;
ret = config_write_block(rec, rec->mainnode, FALSE, TRUE);
@@ -319,8 +322,8 @@ int config_write(CONFIG_REC *rec, const char *fname, int create_mode)
config_error(rec, errno == 0 ? "bug" : g_strerror(errno));
}
- close(rec->handle);
- rec->handle = -1;
+ g_io_channel_unref(rec->handle);
+ rec->handle = NULL;
return ret;
}