summaryrefslogtreecommitdiff
path: root/mysys
diff options
context:
space:
mode:
authorunknown <jani@a193-229-222-105.elisa-laajakaista.fi>2005-05-18 20:10:17 +0300
committerunknown <jani@a193-229-222-105.elisa-laajakaista.fi>2005-05-18 20:10:17 +0300
commit48ce8aebd5800c605d6ff040f50bcf1fc12e6538 (patch)
treee57ae27a7201529c3dae9ffc542a5cae155f4f12 /mysys
parent40772cccb3fcf9c87ba12159a0eaff3ea039a93f (diff)
downloadmariadb-git-48ce8aebd5800c605d6ff040f50bcf1fc12e6538.tar.gz
New file default_modify.c. Fixed a typo on mysqld.cc
Changed name of function my_correct_default_file to modify_defaults_file. Improved function and fixed some bugs in it. include/my_sys.h: Changed function name. include/mysql_com.h: New function, modify_defaults_file() libmysql/Makefile.shared: New file, default_modify.lo libmysql/libmysql.def: New function, modify_defaults_file() and fixed version number. libmysqld/libmysqld.def: New function, modify_defaults_file() mysys/Makefile.am: New file, default_modify.c mysys/default.c: Removed function from default.c. New, corresponding one is in default_modify.c, name is modify_defaults_file. server-tools/instance-manager/commands.cc: Changed function name. sql/mysqld.cc: Fixed typo.
Diffstat (limited to 'mysys')
-rw-r--r--mysys/Makefile.am3
-rw-r--r--mysys/default.c135
-rw-r--r--mysys/default_modify.c164
3 files changed, 166 insertions, 136 deletions
diff --git a/mysys/Makefile.am b/mysys/Makefile.am
index db8aa10bf1a..40743e36c29 100644
--- a/mysys/Makefile.am
+++ b/mysys/Makefile.am
@@ -48,7 +48,8 @@ libmysys_a_SOURCES = my_init.c my_getwd.c mf_getdate.c my_mmap.c \
my_chsize.c my_lread.c my_lwrite.c my_clock.c \
my_quick.c my_lockmem.c my_static.c \
my_sync.c my_getopt.c my_mkdir.c \
- default.c my_compress.c checksum.c raid.cc \
+ default_modify.c default.c \
+ my_compress.c checksum.c raid.cc \
my_net.c my_semaphore.c my_port.c my_sleep.c \
charset.c charset-def.c my_bitmap.c my_bit.c md5.c \
my_gethostbyname.c rijndael.c my_aes.c sha1.c \
diff --git a/mysys/default.c b/mysys/default.c
index ee7cbeb1530..a9f3f4092ef 100644
--- a/mysys/default.c
+++ b/mysys/default.c
@@ -81,141 +81,6 @@ static void init_default_directories();
static char *remove_end_comment(char *ptr);
-/*
- Add/remove option to the option file section.
-
- SYNOPSYS
- my_correct_defaults_file()
- file_location The location of configuration file to edit
- option option to look for
- option_value The value of the option we would like to set
- section_name the name of the section
- remove_option This is true if we want to remove the option.
- False otherwise.
- IMPLEMENTATION
- We open the option file first, then read the file line-by-line,
- looking for the section we need. At the same time we put these lines
- into a buffer. Then we look for the option within this section and
- change/remove it. In the end we get a buffer with modified version of the
- file. Then we write it to the file, truncate it if needed and close it.
-
- RETURN
- 0 - ok
- 1 - some error has occured. Probably due to the lack of resourses
- -1 - cannot open the file
-*/
-
-int my_correct_defaults_file(const char *file_location, const char *option,
- const char *option_value,
- const char *section_name, int remove_option)
-{
- FILE *cnf_file;
- struct stat file_stat;
- char linebuff[512], *ptr;
- uint optlen;
- uint len;
- char *file_buffer;
- uint position= 0;
- int is_found= FALSE;
- DBUG_ENTER("my_correct_defaults_file");
-
- optlen= strlen(option);
-
- if (!(cnf_file= my_fopen(file_location, O_RDWR, MYF(0))))
- goto err_fopen;
-
- /* my_fstat doesn't use the flag parameter */
- if (my_fstat(fileno(cnf_file), &file_stat, MYF(0)))
- goto err;
-
- /*
- Reserve space to read the contents of the file and some more
- for the option we want ot add.
- */
- file_buffer= (char*) my_malloc(sizeof(char)*
- (file_stat.st_size + /* current file size */
- optlen + /* option name len */
- 2 + /* reserve space for newline */
- 1 + /* reserve for '=' char */
- strlen(option_value)), /* option value len */
- MYF(MY_WME));
-
- if (!file_buffer)
- goto malloc_err;
- while (fgets(linebuff, sizeof(linebuff), cnf_file))
- {
- len= strlen(linebuff);
-
- /* if the section is found traverse it */
- if (is_found)
- {
- /* skip the old value of the option we are changing */
- if (strncmp(linebuff, option, optlen))
- {
- /* copy all other lines */
- strmake(file_buffer + position, linebuff, len);
- position+= len;
- }
- }
- else
- {
- strmake(file_buffer + position, linebuff, len);
- position+= len;
- }
-
-
- /* looking for appropriate section */
- for (ptr= linebuff ; my_isspace(&my_charset_latin1,*ptr) ; ptr++)
- {}
-
- if (*ptr == '[')
- {
- /* copy the line to the buffer */
- if (!strncmp(++ptr, section_name, strlen(section_name)))
- {
- is_found= TRUE;
- /* add option */
- if (!remove_option)
- {
- strmake(file_buffer + position, option, optlen);
- position+= optlen;
- if (*option_value)
- {
- *(file_buffer + position++)= '=';
- strmake(file_buffer + position, option_value,
- strlen(option_value));
- position+= strlen(option_value);
- }
- /* add a newline */
- strcat(file_buffer + position, NEWLINE);
- position+= strlen(NEWLINE);
- }
- }
- else
- is_found= FALSE; /* mark that this section is of no interest to us */
- }
-
- }
-
- if (my_chsize(fileno(cnf_file), position, 0, MYF(MY_WME)) ||
- my_fseek(cnf_file, 0, MY_SEEK_SET, MYF(0)) ||
- my_fwrite(cnf_file, file_buffer, position, MYF(MY_NABP)) ||
- my_fclose(cnf_file, MYF(MY_WME)))
- goto err;
-
- my_free(file_buffer, MYF(0));
-
- DBUG_RETURN(0);
-
-err:
- my_free(file_buffer, MYF(0));
-malloc_err:
- my_fclose(cnf_file, MYF(0));
- DBUG_RETURN(1); /* out of resources */
-err_fopen:
- DBUG_RETURN(-1); /* cannot access the option file */
-}
-
/*
Process config files in default directories.
diff --git a/mysys/default_modify.c b/mysys/default_modify.c
new file mode 100644
index 00000000000..c0589f54132
--- /dev/null
+++ b/mysys/default_modify.c
@@ -0,0 +1,164 @@
+/*
+ Add/remove option to the option file section.
+
+ SYNOPSYS
+ modify_defaults_file()
+ file_location The location of configuration file to edit
+ option option to look for
+ option value The value of the option we would like to set
+ section_name the name of the section
+ remove_option This is true if we want to remove the option.
+ False otherwise.
+ IMPLEMENTATION
+ We open the option file first, then read the file line-by-line,
+ looking for the section we need. At the same time we put these lines
+ into a buffer. Then we look for the option within this section and
+ change/remove it. In the end we get a buffer with modified version of the
+ file. Then we write it to the file, truncate it if needed and close it.
+
+ RETURN
+ 0 - ok
+ 1 - some error has occured. Probably due to the lack of resourses
+ 2 - cannot open the file
+*/
+
+#include "my_global.h"
+#include "mysys_priv.h"
+#include "m_string.h"
+#include <my_dir.h>
+
+#define BUFF_SIZE 1024
+
+#ifdef __WIN__
+#define NEWLINE "\r\n"
+#define NEWLINE_LEN 2
+#else
+#define NEWLINE "\n"
+#define NEWLINE_LEN 1
+#endif
+
+uint modify_defaults_file(const char *file_location, const char *option,
+ const char *option_value,
+ const char *section_name, int remove_option)
+{
+ FILE *cnf_file;
+ struct stat file_stat;
+ char linebuff[BUFF_SIZE], tmp[BUFF_SIZE], *tmp_ptr, *src_ptr, *dst_ptr,
+ *file_buffer;
+ uint optlen, optval_len, sect_len;
+ my_bool in_section= FALSE;
+ DBUG_ENTER("modify_defaults_file");
+
+ optlen= strlen(option);
+ optval_len= strlen(option_value);
+ sect_len= strlen(section_name);
+
+ if (!(cnf_file= my_fopen(file_location, O_RDWR | O_BINARY, MYF(0))))
+ DBUG_RETURN(2);
+
+ /* my_fstat doesn't use the flag parameter */
+ if (my_fstat(fileno(cnf_file), &file_stat, MYF(0)))
+ goto err;
+
+ /*
+ Reserve space to read the contents of the file and some more
+ for the option we want to add.
+ */
+ if (!(file_buffer= (char*) my_malloc(sizeof(char)*
+ (file_stat.st_size +
+ /* option name len */
+ optlen +
+ /* reserve space for newline */
+ NEWLINE_LEN +
+ /* reserve for '=' char */
+ 1 +
+ /* option value len */
+ optval_len), MYF(MY_WME))))
+ goto malloc_err;
+
+ for (dst_ptr= file_buffer, tmp_ptr= 0;
+ fgets(linebuff, BUFF_SIZE, cnf_file); )
+ {
+ /* Skip over whitespaces */
+ for (src_ptr= linebuff; my_isspace(&my_charset_latin1, *src_ptr);
+ src_ptr++)
+ {}
+
+ if (in_section && !strncmp(src_ptr, option, optlen) &&
+ (*(src_ptr + optlen) == '=' ||
+ my_isspace(&my_charset_latin1, *(src_ptr + optlen)) ||
+ *(src_ptr + optlen) == '\0'))
+ {
+ /* The option under modifying was found in this section. Apply new. */
+ if (!remove_option)
+ dst_ptr= strmov(dst_ptr, tmp);
+ tmp_ptr= 0; /* To mark that we have already applied this */
+ }
+ else
+ {
+ /* If going to new group and we have option to apply, do it now */
+ if (tmp_ptr && *src_ptr == '[')
+ {
+ dst_ptr= strmov(dst_ptr, tmp);
+ tmp_ptr= 0;
+ }
+ dst_ptr= strmov(dst_ptr, linebuff);
+ }
+ /* Look for a section */
+ if (*src_ptr == '[')
+ {
+ /* Copy the line to the buffer */
+ if (!strncmp(++src_ptr, section_name, sect_len))
+ {
+ src_ptr+= sect_len;
+ /* Skip over whitespaces. They are allowed after section name */
+ for (; my_isspace(&my_charset_latin1, *src_ptr); src_ptr++)
+ {}
+
+ if (*src_ptr != ']')
+ continue; /* Missing closing parenthesis. Assume this was no group */
+
+ in_section= TRUE;
+ /* add option */
+ if (!remove_option)
+ {
+ tmp_ptr= strmov(tmp, option);
+ if (*option_value)
+ {
+ *tmp_ptr++= '=';
+ tmp_ptr= strmov(tmp_ptr, option_value);
+ }
+ /* add a newline */
+ strmov(tmp_ptr, NEWLINE);
+ }
+ }
+ else
+ in_section= FALSE; /* mark that this section is of no interest to us */
+ }
+ }
+ /* File ended. New option still remains to apply at the end */
+ if (tmp_ptr)
+ {
+ if (*(dst_ptr - 1) != '\n')
+ *dst_ptr++= '\n';
+ dst_ptr= strmov(dst_ptr, tmp);
+ }
+
+ if (my_chsize(fileno(cnf_file), (my_off_t) (dst_ptr - file_buffer), 0,
+ MYF(MY_WME)) ||
+ my_fseek(cnf_file, 0, MY_SEEK_SET, MYF(0)) ||
+ my_fwrite(cnf_file, file_buffer, (uint) (dst_ptr - file_buffer),
+ MYF(MY_NABP)) ||
+ my_fclose(cnf_file, MYF(MY_WME)))
+ goto err;
+
+ my_free(file_buffer, MYF(0));
+
+ DBUG_RETURN(0);
+
+err:
+ my_free(file_buffer, MYF(0));
+malloc_err:
+ my_fclose(cnf_file, MYF(0));
+ DBUG_RETURN(1); /* out of resources */
+}