2005-05-18 19:10:17 +02:00
|
|
|
/*
|
|
|
|
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
|
|
|
|
|
2005-06-09 20:50:22 +02:00
|
|
|
static char *add_option(char *dst, const char *option_value,
|
|
|
|
const char *option, int remove_option);
|
|
|
|
|
2005-05-19 12:02:12 +02:00
|
|
|
int modify_defaults_file(const char *file_location, const char *option,
|
|
|
|
const char *option_value,
|
|
|
|
const char *section_name, int remove_option)
|
2005-05-18 19:10:17 +02:00
|
|
|
{
|
|
|
|
FILE *cnf_file;
|
2005-05-21 23:23:39 +02:00
|
|
|
MY_STAT file_stat;
|
2005-06-09 20:50:22 +02:00
|
|
|
char linebuff[BUFF_SIZE], *src_ptr, *dst_ptr, *file_buffer;
|
|
|
|
uint optlen, optval_len, sect_len, nr_newlines= 0;
|
|
|
|
my_bool in_section= FALSE, opt_applied= 0;
|
2005-05-18 19:10:17 +02:00
|
|
|
DBUG_ENTER("modify_defaults_file");
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2005-06-09 20:50:22 +02:00
|
|
|
optlen= strlen(option);
|
|
|
|
optval_len= strlen(option_value);
|
|
|
|
|
2005-05-18 19:10:17 +02:00
|
|
|
/*
|
|
|
|
Reserve space to read the contents of the file and some more
|
|
|
|
for the option we want to add.
|
|
|
|
*/
|
2005-06-09 20:50:22 +02:00
|
|
|
if (!(file_buffer= (char*) my_malloc(sizeof(char) *
|
|
|
|
(file_stat.st_size +
|
2005-05-18 19:10:17 +02:00
|
|
|
/* option name len */
|
|
|
|
optlen +
|
|
|
|
/* reserve space for newline */
|
|
|
|
NEWLINE_LEN +
|
|
|
|
/* reserve for '=' char */
|
|
|
|
1 +
|
|
|
|
/* option value len */
|
2005-06-09 20:50:22 +02:00
|
|
|
optval_len +
|
|
|
|
/* The ending zero plus some safety */
|
|
|
|
FN_REFLEN), MYF(MY_WME))))
|
2005-05-18 19:10:17 +02:00
|
|
|
goto malloc_err;
|
|
|
|
|
2005-06-09 20:50:22 +02:00
|
|
|
sect_len= strlen(section_name);
|
|
|
|
|
|
|
|
for (dst_ptr= file_buffer; fgets(linebuff, BUFF_SIZE, cnf_file); )
|
2005-05-18 19:10:17 +02:00
|
|
|
{
|
|
|
|
/* Skip over whitespaces */
|
|
|
|
for (src_ptr= linebuff; my_isspace(&my_charset_latin1, *src_ptr);
|
|
|
|
src_ptr++)
|
|
|
|
{}
|
|
|
|
|
2005-06-09 20:50:22 +02:00
|
|
|
if (!*src_ptr) /* Empty line */
|
|
|
|
{
|
|
|
|
nr_newlines++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!opt_applied && in_section && !strncmp(src_ptr, option, optlen) &&
|
2005-05-18 19:10:17 +02:00
|
|
|
(*(src_ptr + optlen) == '=' ||
|
|
|
|
my_isspace(&my_charset_latin1, *(src_ptr + optlen)) ||
|
|
|
|
*(src_ptr + optlen) == '\0'))
|
|
|
|
{
|
2005-06-09 20:50:22 +02:00
|
|
|
dst_ptr= add_option(dst_ptr, option_value, option, remove_option);
|
|
|
|
opt_applied= 1;
|
2005-05-18 19:10:17 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* If going to new group and we have option to apply, do it now */
|
2005-06-09 20:50:22 +02:00
|
|
|
if (in_section && !opt_applied && *src_ptr == '[')
|
2005-05-18 19:10:17 +02:00
|
|
|
{
|
2005-06-09 20:50:22 +02:00
|
|
|
dst_ptr= add_option(dst_ptr, option_value, option, remove_option);
|
|
|
|
|
2005-05-18 19:10:17 +02:00
|
|
|
}
|
2005-06-09 20:50:22 +02:00
|
|
|
for (; nr_newlines; nr_newlines--)
|
|
|
|
dst_ptr= strmov(dst_ptr, NEWLINE);
|
2005-05-18 19:10:17 +02:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
in_section= FALSE; /* mark that this section is of no interest to us */
|
|
|
|
}
|
|
|
|
}
|
2005-06-09 20:50:22 +02:00
|
|
|
/* File ended. */
|
|
|
|
if (!opt_applied && !remove_option && in_section)
|
2005-05-18 19:10:17 +02:00
|
|
|
{
|
2005-06-09 20:50:22 +02:00
|
|
|
/* New option still remains to apply at the end */
|
2005-05-18 19:10:17 +02:00
|
|
|
if (*(dst_ptr - 1) != '\n')
|
2005-06-09 20:50:22 +02:00
|
|
|
dst_ptr= strmov(dst_ptr, NEWLINE);
|
|
|
|
dst_ptr= add_option(dst_ptr, option_value, option, remove_option);
|
|
|
|
opt_applied= 1;
|
2005-05-18 19:10:17 +02:00
|
|
|
}
|
2005-06-09 20:50:22 +02:00
|
|
|
for (; nr_newlines; nr_newlines--)
|
|
|
|
dst_ptr= strmov(dst_ptr, NEWLINE);
|
2005-05-18 19:10:17 +02:00
|
|
|
|
2005-06-09 20:50:22 +02:00
|
|
|
if (opt_applied)
|
|
|
|
{
|
|
|
|
/* Don't write the file if there are no changes to be made */
|
|
|
|
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)))
|
|
|
|
goto err;
|
|
|
|
}
|
|
|
|
if (my_fclose(cnf_file, MYF(MY_WME)))
|
|
|
|
goto err;
|
2005-05-18 19:10:17 +02:00
|
|
|
|
|
|
|
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 */
|
|
|
|
}
|
2005-06-09 20:50:22 +02:00
|
|
|
|
|
|
|
|
|
|
|
static char *add_option(char *dst, const char *option_value,
|
|
|
|
const char *option, int remove_option)
|
|
|
|
{
|
|
|
|
if (!remove_option)
|
|
|
|
{
|
|
|
|
dst= strmov(dst, option);
|
|
|
|
if (*option_value)
|
|
|
|
{
|
|
|
|
*dst++= '=';
|
|
|
|
dst= strmov(dst, option_value);
|
|
|
|
}
|
|
|
|
/* add a newline */
|
|
|
|
dst= strmov(dst, NEWLINE);
|
|
|
|
}
|
|
|
|
return dst;
|
|
|
|
}
|