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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
14
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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
****************************************************************************/
38
#include "drizzled/internal/my_sys.h"
39
#include "drizzled/internal/m_string.h"
40
#include "drizzled/charset_info.h"
36
#include "mysys_priv.h"
37
#include <mystrings/m_string.h>
38
#include <mystrings/m_ctype.h>
39
#include <mysys/my_dir.h>
41
40
#include <drizzled/configmake.h>
42
#include <drizzled/gettext.h>
44
#include "drizzled/cached_directory.h"
46
#ifdef HAVE_SYS_STAT_H
47
# include <sys/stat.h>
60
44
const char *my_defaults_file=0;
61
45
const char *my_defaults_group_suffix=0;
175
159
/* Handle --defaults-group-suffix= */
177
161
const char **extra_groups;
178
const size_t instance_len= strlen(my_defaults_group_suffix);
162
const uint32_t instance_len= strlen(my_defaults_group_suffix);
179
163
struct handle_option_ctx *ctx= (struct handle_option_ctx*) func_ctx;
181
165
TYPELIB *group= ctx->group;
183
167
if (!(extra_groups=
184
(const char**)ctx->alloc->alloc_root(
168
(const char**)alloc_root(ctx->alloc,
185
169
(2*group->count+1)*sizeof(char*))))
188
172
for (i= 0; i < group->count; i++)
191
175
extra_groups[i]= group->type_names[i]; /** copy group */
193
177
len= strlen(extra_groups[i]);
194
if (!(ptr= (char *)ctx->alloc->alloc_root( len+instance_len+1)))
178
if (!(ptr= (char *)alloc_root(ctx->alloc, len+instance_len+1)))
197
181
extra_groups[i+group->count]= ptr;
290
274
if (find_type((char *)group_name, ctx->group, 3))
292
if (!(tmp= (char *)ctx->alloc->alloc_root(strlen(option) + 1)))
276
if (!(tmp= (char *)alloc_root(ctx->alloc, strlen(option) + 1)))
294
278
if (insert_dynamic(ctx->args, (unsigned char*) &tmp))
324
308
int org_argc= argc, prev_argc= 0;
325
309
*defaults= *extra_defaults= *group_suffix= 0;
327
const std::string DEFAULTS_FILE("--defaults-file=");
328
const std::string DEFAULTS_EXTRA_FILE("--defaults-extra-file=");
329
const std::string DEFAULTS_GROUP_SUFFIX("--defaults-group-suffix=");
331
311
while (argc >= 2 && argc != prev_argc)
333
313
/* Skip program name or previously handled argument */
335
315
prev_argc= argc; /* To check if we found */
336
if (!*defaults && (strncmp(*argv,
337
DEFAULTS_FILE.c_str(),
338
DEFAULTS_FILE.size()) == 0))
316
if (!*defaults && is_prefix(*argv,"--defaults-file="))
340
*defaults= *argv + DEFAULTS_FILE.size();
318
*defaults= *argv + sizeof("--defaults-file=")-1;
344
if (!*extra_defaults && (strncmp(*argv,
345
DEFAULTS_EXTRA_FILE.c_str(),
346
DEFAULTS_EXTRA_FILE.size()) == 0))
322
if (!*extra_defaults && is_prefix(*argv,"--defaults-extra-file="))
348
*extra_defaults= *argv + DEFAULTS_EXTRA_FILE.size();
324
*extra_defaults= *argv + sizeof("--defaults-extra-file=")-1;
352
if (!*group_suffix && (strncmp(*argv,
353
DEFAULTS_GROUP_SUFFIX.c_str(),
354
DEFAULTS_GROUP_SUFFIX.size()) == 0))
328
if (!*group_suffix && is_prefix(*argv, "--defaults-group-suffix="))
357
*group_suffix= *argv + DEFAULTS_GROUP_SUFFIX.size();
330
*group_suffix= *argv + sizeof("--defaults-group-suffix=")-1;
400
373
DYNAMIC_ARRAY args;
375
bool found_print_defaults= 0;
402
376
uint32_t args_used= 0;
404
memory::Root alloc(512);
406
380
struct handle_option_ctx ctx;
408
382
init_default_directories();
383
init_alloc_root(&alloc,512,0);
410
385
Check if the user doesn't want any default option processing
411
386
--no-defaults is always the first option
415
390
/* remove the --no-defaults argument and return only the other arguments */
417
if (!(ptr=(char*) alloc.alloc_root(sizeof(alloc)+ (*argc + 1)*sizeof(char*))))
392
if (!(ptr=(char*) alloc_root(&alloc,sizeof(alloc)+
393
(*argc + 1)*sizeof(char*))))
419
395
res= (char**) (ptr+sizeof(alloc));
420
memset(res,0,(*argc + 1));
421
396
res[0]= **argv; /* Copy program name */
422
for (i=2 ; i < (uint32_t) *argc ; i++)
397
for (i=2 ; i < (uint) *argc ; i++)
423
398
res[i-1]=argv[0][i];
424
399
res[i-1]=0; /* End pointer */
427
*(memory::Root*) ptr= alloc; /* Save alloc root for free */
402
*(MEM_ROOT*) ptr= alloc; /* Save alloc root for free */
448
423
Here error contains <> 0 only if we have a fully specified conf_file
449
424
or a forced default file
451
if (!(ptr=(char*) alloc.alloc_root(sizeof(alloc)+ (args.elements + *argc +1) *sizeof(char*))))
426
if (!(ptr=(char*) alloc_root(&alloc,sizeof(alloc)+
427
(args.elements + *argc +1) *sizeof(char*))))
453
429
res= (char**) (ptr+sizeof(alloc));
463
439
Check if we wan't to see the new argument list
464
440
This options must always be the last of the default options
442
if (*argc >= 2 && !strcmp(argv[0][1],"--print-defaults"))
444
found_print_defaults=1;
445
--*argc; ++*argv; /* skip argument */
467
449
memcpy(res+1+args.elements, *argv + 1, (*argc-1)*sizeof(char*));
468
450
res[args.elements+ *argc]=0; /* last null */
470
(*argc)+=int(args.elements);
471
*argv= static_cast<char**>(res);
472
*(memory::Root*) ptr= alloc; /* Save alloc root for free */
452
(*argc)+=args.elements;
454
*(MEM_ROOT*) ptr= alloc; /* Save alloc root for free */
473
455
delete_dynamic(&args);
456
if (found_print_defaults)
459
printf("%s would have been started with the following arguments:\n",
461
for (i=1 ; i < *argc ; i++)
462
printf("%s ", (*argv)[i]);
632
if (!(fp= fopen(name, "r")))
626
if (!(fp= my_fopen(name, O_RDONLY, MYF(0))))
633
627
return 1; /* Ignore wrong files */
635
memset(buff,0,sizeof(buff));
636
629
while (fgets(buff, sizeof(buff) - 1, fp))
673
666
ptr, name, line)))
676
CachedDirectory dir_cache(ptr);
678
if (dir_cache.fail())
682
* Since clients still use this code, we use fprintf here.
683
* This fprintf needs to be turned into errmsg_printf
684
* as soon as the client programs no longer use mysys
685
* and can use the pluggable error message system.
687
fprintf(stderr, _("error: could not open directory: %s\n"), ptr);
669
if (!(search_dir= my_dir(ptr, MYF(MY_WME))))
691
CachedDirectory::Entries files= dir_cache.getEntries();
692
CachedDirectory::Entries::iterator file_iter= files.begin();
694
while (file_iter != files.end())
672
for (i= 0; i < (uint) search_dir->number_off_files; i++)
696
CachedDirectory::Entry *entry= *file_iter;
697
ext= fn_ext(entry->filename.c_str());
674
search_file= search_dir->dir_entry + i;
675
ext= fn_ext(search_file->name);
699
677
/* check extension */
700
678
for (tmp_ext= (char**) f_extensions; *tmp_ext; tmp_ext++)
702
680
if (!strcmp(ext, *tmp_ext))
704
fn_format(tmp, entry->filename.c_str(), ptr, "",
705
MY_UNPACK_FILENAME | MY_SAFE_PATH);
707
search_default_file_with_ext(opt_handler, handler_ctx, "", "",
708
tmp, recursion_level + 1);
686
fn_format(tmp, search_file->name, ptr, "",
687
MY_UNPACK_FILENAME | MY_SAFE_PATH);
689
search_default_file_with_ext(opt_handler, handler_ctx, "", "", tmp,
690
recursion_level + 1);
694
my_dirend(search_dir);
715
696
else if ((!strncmp(ptr, include_keyword, sizeof(include_keyword) - 1)) &&
716
697
my_isspace(&my_charset_utf8_general_ci, ptr[sizeof(include_keyword)-1]))
741
722
for ( ; my_isspace(&my_charset_utf8_general_ci,end[-1]) ; end--) ;
744
strncpy(curr_gr, ptr, min((size_t) (end-ptr)+1, sizeof(curr_gr)-1));
745
curr_gr[min((size_t)(end-ptr)+1, sizeof(curr_gr)-1)] = '\0';
725
strncpy(curr_gr, ptr, cmin((size_t) (end-ptr)+1, sizeof(curr_gr)-1));
726
curr_gr[cmin((size_t)(end-ptr)+1, sizeof(curr_gr)-1)] = '\0';
747
728
/* signal that a new group is found */
748
729
opt_handler(handler_ctx, curr_gr, NULL);
761
742
end= remove_end_comment(ptr);
762
743
if ((value= strchr(ptr, '=')))
763
744
end= value; /* Option without argument */
764
for ( ; my_isspace(&my_charset_utf8_general_ci,end[-1]) || end[-1]== '\n'; end--) ;
745
for ( ; my_isspace(&my_charset_utf8_general_ci,end[-1]) ; end--) ;
767
748
strncpy(strcpy(option,"--")+2,ptr,strlen(ptr)+1);
938
915
puts("\nThe following options may be given as the first argument:\n\
939
--no-defaults Don't read default options from any options file\n\
940
--defaults-file=# Only read default options from the given file #\n\
941
--defaults-extra-file=# Read this file after the global files are read");
916
--print-defaults Print the program argument list and exit\n\
917
--no-defaults Don't read default options from any options file\n\
918
--defaults-file=# Only read default options from the given file #\n\
919
--defaults-extra-file=# Read this file after the global files are read");