12
12
You should have received a copy of the GNU General Public License
13
13
along with this program; if not, write to the Free Software
14
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
14
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
16
16
/****************************************************************************
17
17
Add all options from files named "group".cnf from the default_directories
33
33
--print-defaults ; Print the modified command line and exit
34
34
****************************************************************************/
36
#include "mysys_priv.h"
37
#include <mystrings/m_string.h>
38
#include <mystrings/m_ctype.h>
39
#include <mysys/my_dir.h>
38
#include <drizzled/internal/my_sys.h>
39
#include <drizzled/internal/m_string.h>
40
#include <drizzled/charset_info.h>
41
#include <drizzled/typelib.h>
42
#include <drizzled/configmake.h>
43
#include <drizzled/gettext.h>
45
#include <drizzled/cached_directory.h>
47
#ifdef HAVE_SYS_STAT_H
48
# include <sys/stat.h>
43
61
const char *my_defaults_file=0;
44
62
const char *my_defaults_group_suffix=0;
140
158
(char **) &my_defaults_group_suffix);
142
160
if (! my_defaults_group_suffix)
143
my_defaults_group_suffix= getenv(STRINGIFY_ARG(DEFAULT_GROUP_SUFFIX_ENV));
161
my_defaults_group_suffix= getenv("DRIZZLE_GROUP_SUFFIX");
145
163
if (forced_extra_defaults)
146
164
my_defaults_extra_file= (char *) forced_extra_defaults;
148
166
if (forced_default_file)
149
167
my_defaults_file= forced_default_file;
158
176
/* Handle --defaults-group-suffix= */
160
178
const char **extra_groups;
161
const uint32_t instance_len= strlen(my_defaults_group_suffix);
179
const size_t instance_len= strlen(my_defaults_group_suffix);
162
180
struct handle_option_ctx *ctx= (struct handle_option_ctx*) func_ctx;
164
182
TYPELIB *group= ctx->group;
167
(const char**)alloc_root(ctx->alloc,
185
(const char**)ctx->alloc->alloc_root(
168
186
(2*group->count+1)*sizeof(char*))))
171
189
for (i= 0; i < group->count; i++)
174
192
extra_groups[i]= group->type_names[i]; /** copy group */
176
194
len= strlen(extra_groups[i]);
177
if (!(ptr= (char *)alloc_root(ctx->alloc, len+instance_len+1)))
195
if (!(ptr= (char *)ctx->alloc->alloc_root( len+instance_len+1)))
180
198
extra_groups[i+group->count]= ptr;
182
200
/** Construct new group */
183
201
memcpy(ptr, extra_groups[i], len);
184
202
memcpy(ptr+len, my_defaults_group_suffix, instance_len+1);
187
205
group->count*= 2;
188
206
group->type_names= extra_groups;
189
207
group->type_names[group->count]= 0;
192
210
if (forced_default_file)
194
212
if ((error= search_default_file_with_ext(func, func_ctx, "", "",
273
if (find_type((char *)group_name, ctx->group, 3))
291
if (ctx->group->find_type(const_cast<char*>(group_name), 3))
275
if (!(tmp= (char *)alloc_root(ctx->alloc, strlen(option) + 1)))
293
if (!(tmp= (char *)ctx->alloc->alloc_root(strlen(option) + 1)))
277
295
if (insert_dynamic(ctx->args, (unsigned char*) &tmp))
307
325
int org_argc= argc, prev_argc= 0;
308
326
*defaults= *extra_defaults= *group_suffix= 0;
328
const std::string DEFAULTS_FILE("--defaults-file=");
329
const std::string DEFAULTS_EXTRA_FILE("--defaults-extra-file=");
330
const std::string DEFAULTS_GROUP_SUFFIX("--defaults-group-suffix=");
310
332
while (argc >= 2 && argc != prev_argc)
312
334
/* Skip program name or previously handled argument */
314
336
prev_argc= argc; /* To check if we found */
315
if (!*defaults && is_prefix(*argv,"--defaults-file="))
337
if (!*defaults && (strncmp(*argv,
338
DEFAULTS_FILE.c_str(),
339
DEFAULTS_FILE.size()) == 0))
317
*defaults= *argv + sizeof("--defaults-file=")-1;
341
*defaults= *argv + DEFAULTS_FILE.size();
321
if (!*extra_defaults && is_prefix(*argv,"--defaults-extra-file="))
345
if (!*extra_defaults && (strncmp(*argv,
346
DEFAULTS_EXTRA_FILE.c_str(),
347
DEFAULTS_EXTRA_FILE.size()) == 0))
323
*extra_defaults= *argv + sizeof("--defaults-extra-file=")-1;
349
*extra_defaults= *argv + DEFAULTS_EXTRA_FILE.size();
327
if (!*group_suffix && is_prefix(*argv, "--defaults-group-suffix="))
353
if (!*group_suffix && (strncmp(*argv,
354
DEFAULTS_GROUP_SUFFIX.c_str(),
355
DEFAULTS_GROUP_SUFFIX.size()) == 0))
329
*group_suffix= *argv + sizeof("--defaults-group-suffix=")-1;
358
*group_suffix= *argv + DEFAULTS_GROUP_SUFFIX.size();
372
401
DYNAMIC_ARRAY args;
374
bool found_print_defaults= 0;
375
403
uint32_t args_used= 0;
405
memory::Root alloc(512);
379
407
struct handle_option_ctx ctx;
381
409
init_default_directories();
382
init_alloc_root(&alloc,512,0);
384
411
Check if the user doesn't want any default option processing
385
412
--no-defaults is always the first option
389
416
/* remove the --no-defaults argument and return only the other arguments */
391
if (!(ptr=(char*) alloc_root(&alloc,sizeof(alloc)+
392
(*argc + 1)*sizeof(char*))))
418
if (!(ptr=(char*) alloc.alloc_root(sizeof(alloc)+ (*argc + 1)*sizeof(char*))))
394
420
res= (char**) (ptr+sizeof(alloc));
421
memset(res,0,(*argc + 1));
395
422
res[0]= **argv; /* Copy program name */
396
for (i=2 ; i < (uint) *argc ; i++)
423
for (i=2 ; i < (uint32_t) *argc ; i++)
397
424
res[i-1]=argv[0][i];
398
425
res[i-1]=0; /* End pointer */
401
*(MEM_ROOT*) ptr= alloc; /* Save alloc root for free */
428
*(memory::Root*) ptr= alloc; /* Save alloc root for free */
422
449
Here error contains <> 0 only if we have a fully specified conf_file
423
450
or a forced default file
425
if (!(ptr=(char*) alloc_root(&alloc,sizeof(alloc)+
426
(args.elements + *argc +1) *sizeof(char*))))
452
if (!(ptr=(char*) alloc.alloc_root(sizeof(alloc)+ (args.elements + *argc +1) *sizeof(char*))))
428
454
res= (char**) (ptr+sizeof(alloc));
438
464
Check if we wan't to see the new argument list
439
465
This options must always be the last of the default options
441
if (*argc >= 2 && !strcmp(argv[0][1],"--print-defaults"))
443
found_print_defaults=1;
444
--*argc; ++*argv; /* skip argument */
448
468
memcpy(res+1+args.elements, *argv + 1, (*argc-1)*sizeof(char*));
449
469
res[args.elements+ *argc]=0; /* last null */
451
(*argc)+=args.elements;
453
*(MEM_ROOT*) ptr= alloc; /* Save alloc root for free */
471
(*argc)+=int(args.elements);
472
*argv= static_cast<char**>(res);
473
*(memory::Root*) ptr= alloc; /* Save alloc root for free */
454
474
delete_dynamic(&args);
455
if (found_print_defaults)
458
printf("%s would have been started with the following arguments:\n",
460
for (i=1 ; i < *argc ; i++)
461
printf("%s ", (*argv)[i]);
557
568
search_default_file_with_ext()
558
569
opt_handler Option handler function. It is used to process
559
570
every separate option.
560
handler_ctx Pointer to the structure to store actual
571
handler_ctx Pointer to the structure to store actual
561
572
parameters of the function.
562
573
dir directory to read
563
574
ext Extension for configuration file
598
606
end=convert_dirname(name, dir, NULL);
599
607
if (dir[0] == FN_HOMELIB) /* Add . to filenames in home */
601
strxmov(end,config_file,ext,NULL);
609
sprintf(end,"%s%s",config_file,ext);
613
621
Ignore world-writable regular files.
614
622
This is mainly done to protect us to not read a file created by
615
the mysqld server, but the check is still valid in most context.
623
the mysqld server, but the check is still valid in most context.
617
625
if ((stat_info.st_mode & S_IWOTH) &&
618
626
(stat_info.st_mode & S_IFMT) == S_IFREG)
625
if (!(fp= my_fopen(name, O_RDONLY, MYF(0))))
633
if (!(fp= fopen(name, "r")))
626
634
return 1; /* Ignore wrong files */
636
memset(buff,0,sizeof(buff));
628
637
while (fgets(buff, sizeof(buff) - 1, fp))
641
650
if (recursion_level >= max_recursion_level)
643
for (end= ptr + strlen(ptr) - 1;
652
for (end= ptr + strlen(ptr) - 1;
644
653
my_isspace(&my_charset_utf8_general_ci, *(end - 1));
665
674
ptr, name, line)))
668
if (!(search_dir= my_dir(ptr, MYF(MY_WME))))
677
CachedDirectory dir_cache(ptr);
679
if (dir_cache.fail())
683
* Since clients still use this code, we use fprintf here.
684
* This fprintf needs to be turned into errmsg_printf
685
* as soon as the client programs no longer use mysys
686
* and can use the pluggable error message system.
688
fprintf(stderr, _("error: could not open directory: %s\n"), ptr);
671
for (i= 0; i < (uint) search_dir->number_off_files; i++)
692
CachedDirectory::Entries files= dir_cache.getEntries();
693
CachedDirectory::Entries::iterator file_iter= files.begin();
695
while (file_iter != files.end())
673
search_file= search_dir->dir_entry + i;
674
ext= fn_ext(search_file->name);
697
CachedDirectory::Entry *entry= *file_iter;
698
ext= fn_ext(entry->filename.c_str());
676
700
/* check extension */
677
701
for (tmp_ext= (char**) f_extensions; *tmp_ext; tmp_ext++)
679
703
if (!strcmp(ext, *tmp_ext))
685
fn_format(tmp, search_file->name, ptr, "",
686
MY_UNPACK_FILENAME | MY_SAFE_PATH);
688
search_default_file_with_ext(opt_handler, handler_ctx, "", "", tmp,
689
recursion_level + 1);
705
fn_format(tmp, entry->filename.c_str(), ptr, "",
706
MY_UNPACK_FILENAME | MY_SAFE_PATH);
708
search_default_file_with_ext(opt_handler, handler_ctx, "", "",
709
tmp, recursion_level + 1);
693
my_dirend(search_dir);
695
716
else if ((!strncmp(ptr, include_keyword, sizeof(include_keyword) - 1)) &&
696
717
my_isspace(&my_charset_utf8_general_ci, ptr[sizeof(include_keyword)-1]))
721
742
for ( ; my_isspace(&my_charset_utf8_general_ci,end[-1]) ; end--) ;
724
strncpy(curr_gr, ptr, cmin((size_t) (end-ptr)+1, sizeof(curr_gr)-1));
725
curr_gr[cmin((size_t)(end-ptr)+1, sizeof(curr_gr)-1)] = '\0';
745
strncpy(curr_gr, ptr, min((size_t) (end-ptr)+1, sizeof(curr_gr)-1));
746
curr_gr[min((size_t)(end-ptr)+1, sizeof(curr_gr)-1)] = '\0';
727
748
/* signal that a new group is found */
728
749
opt_handler(handler_ctx, curr_gr, NULL);
741
762
end= remove_end_comment(ptr);
742
763
if ((value= strchr(ptr, '=')))
743
764
end= value; /* Option without argument */
744
for ( ; my_isspace(&my_charset_utf8_general_ci,end[-1]) ; end--) ;
765
for ( ; my_isspace(&my_charset_utf8_general_ci,end[-1]) || end[-1]== '\n'; end--) ;
747
768
strncpy(strcpy(option,"--")+2,ptr,strlen(ptr)+1);
755
776
for (value++ ; my_isspace(&my_charset_utf8_general_ci,*value); value++) ;
756
777
value_end= strchr(value, '\0');
758
We don't have to test for value_end >= value as we know there is
779
We don't have to test for value_end >= value as we know there is
761
782
for ( ; my_isspace(&my_charset_utf8_general_ci,value_end[-1]) ; value_end--) ;
762
783
if (value_end < value) /* Empty string */
765
786
/* remove quotes around argument */
766
787
if ((*value == '\"' || *value == '\'') && /* First char is quote */
773
ptr= my_stpncpy(strcpy(option,"--")+2,ptr,(size_t) (end-ptr));
795
memset(option,0,2+(size_t)(end-ptr)+1);
796
ptr= strncpy(strcpy(option,"--")+2,ptr,(size_t) (end-ptr));
776
801
for ( ; value != value_end; value++)
880
906
end= convert_dirname(name, pos, NULL);
881
907
if (name[0] == FN_HOMELIB) /* Add . to filenames in home */
883
strxmov(end, conf_file, *ext, " ", NULL);
909
sprintf(end,"%s%s ",conf_file, *ext);
884
910
fputs(name,stdout);
913
939
puts("\nThe following options may be given as the first argument:\n\
914
--print-defaults Print the program argument list and exit\n\
915
--no-defaults Don't read default options from any options file\n\
916
--defaults-file=# Only read default options from the given file #\n\
917
--defaults-extra-file=# Read this file after the global files are read");
940
--no-defaults Don't read default options from any options file\n\
941
--defaults-file=# Only read default options from the given file #\n\
942
--defaults-extra-file=# Read this file after the global files are read");
921
946
This extra complexity is to avoid declaring 'rc' if it won't be
924
#define ADD_DIRECTORY(DIR) (void) array_append_string_unique((DIR), default_directories, \
925
array_elements(default_directories))
927
#define ADD_COMMON_DIRECTORIES() \
930
if ((env= getenv(STRINGIFY_ARG(DEFAULT_HOME_ENV)))) \
931
ADD_DIRECTORY(env); \
932
/* Placeholder for --defaults-extra-file=<path> */ \
949
static void add_directory(const char* dir)
951
array_append_string_unique(dir, default_directories, array_elements(default_directories));
954
static void add_common_directories()
956
const char *env= getenv("DRIZZLE_HOME");
959
// Placeholder for --defaults-extra-file=<path>
938
964
Initialize default directories for Unix
949
975
static void init_default_directories(void)
951
977
memset(default_directories, 0, sizeof(default_directories));
952
ADD_DIRECTORY("/etc/");
953
ADD_DIRECTORY("/etc/drizzle/");
954
#if defined(DEFAULT_SYSCONFDIR)
955
ADD_DIRECTORY(DEFAULT_SYSCONFDIR);
957
ADD_COMMON_DIRECTORIES();
978
add_directory("/etc/");
979
add_directory("/etc/drizzle/");
980
add_directory(SYSCONFDIR);
981
add_common_directories();
985
} /* namespace internal */
986
} /* namespace drizzled */