Commit 6261dafb authored by monty@donna.mysql.fi's avatar monty@donna.mysql.fi

Fixed all mysqldump output to use 'result_file'

parent f01a7fce
...@@ -73,8 +73,7 @@ static my_bool verbose=0,tFlag=0,cFlag=0,dFlag=0,quick=0, extended_insert = 0, ...@@ -73,8 +73,7 @@ static my_bool verbose=0,tFlag=0,cFlag=0,dFlag=0,quick=0, extended_insert = 0,
lock_tables=0,ignore_errors=0,flush_logs=0,replace=0, lock_tables=0,ignore_errors=0,flush_logs=0,replace=0,
ignore=0,opt_drop=0,opt_keywords=0,opt_lock=0,opt_compress=0, ignore=0,opt_drop=0,opt_keywords=0,opt_lock=0,opt_compress=0,
opt_delayed=0,create_options=0,opt_quoted=0,opt_databases=0, opt_delayed=0,create_options=0,opt_quoted=0,opt_databases=0,
opt_alldbs=0,opt_create_db=0,opt_first_slave=0, opt_alldbs=0,opt_create_db=0,opt_first_slave=0;
opt_resultfile=0;
static MYSQL mysql_connection,*sock=0; static MYSQL mysql_connection,*sock=0;
static char insert_pat[12 * 1024],*opt_password=0,*current_user=0, static char insert_pat[12 * 1024],*opt_password=0,*current_user=0,
*current_host=0,*path=0,*fields_terminated=0, *current_host=0,*path=0,*fields_terminated=0,
...@@ -86,6 +85,7 @@ static int first_error=0; ...@@ -86,6 +85,7 @@ static int first_error=0;
extern ulong net_buffer_length; extern ulong net_buffer_length;
static DYNAMIC_STRING extended_row; static DYNAMIC_STRING extended_row;
#include "sslopt-vars.h" #include "sslopt-vars.h"
FILE *result_file;
enum options {OPT_FTB=256, OPT_LTB, OPT_ENC, OPT_O_ENC, OPT_ESC, OPT_KEYWORDS, enum options {OPT_FTB=256, OPT_LTB, OPT_ENC, OPT_O_ENC, OPT_ESC, OPT_KEYWORDS,
OPT_LOCKS, OPT_DROP, OPT_OPTIMIZE, OPT_DELAYED, OPT_TABLES, OPT_LOCKS, OPT_DROP, OPT_OPTIMIZE, OPT_DELAYED, OPT_TABLES,
...@@ -289,8 +289,8 @@ static int get_options(int *argc,char ***argv) ...@@ -289,8 +289,8 @@ static int get_options(int *argc,char ***argv)
{ {
int c,option_index; int c,option_index;
my_bool tty_password=0; my_bool tty_password=0;
FILE *resultfile;
result_file=stdout;
load_defaults("my",load_default_groups,argc,argv); load_defaults("my",load_default_groups,argc,argv);
set_all_changeable_vars(changeable_vars); set_all_changeable_vars(changeable_vars);
while ((c=getopt_long(*argc,*argv, while ((c=getopt_long(*argc,*argv,
...@@ -355,13 +355,9 @@ static int get_options(int *argc,char ***argv) ...@@ -355,13 +355,9 @@ static int get_options(int *argc,char ***argv)
opt_mysql_port= (unsigned int) atoi(optarg); opt_mysql_port= (unsigned int) atoi(optarg);
break; break;
case 'r': case 'r':
if (!(resultfile = my_fopen(optarg, O_WRONLY, MYF(MY_WME)))) if (!(result_file = my_fopen(optarg, O_WRONLY | O_BINARY,
{ MYF(MY_WME))))
printf("Couldn't open result-file %s, aborting!\n", optarg);
exit(1); exit(1);
}
opt_resultfile = 1;
stdout = resultfile;
break; break;
case 'S': case 'S':
opt_mysql_unix_port= optarg; opt_mysql_unix_port= optarg;
...@@ -606,7 +602,7 @@ static uint getTableStructure(char *table, char* db) ...@@ -606,7 +602,7 @@ static uint getTableStructure(char *table, char* db)
char *strpos, *table_name; char *strpos, *table_name;
const char *delayed; const char *delayed;
char name_buff[NAME_LEN+3],table_buff[NAME_LEN+3]; char name_buff[NAME_LEN+3],table_buff[NAME_LEN+3];
FILE *sql_file = stdout; FILE *sql_file = result_file;
DBUG_ENTER("getTableStructure"); DBUG_ENTER("getTableStructure");
delayed= opt_delayed ? " DELAYED " : ""; delayed= opt_delayed ? " DELAYED " : "";
...@@ -977,14 +973,14 @@ static void dumpTable(uint numFields, char *table) ...@@ -977,14 +973,14 @@ static void dumpTable(uint numFields, char *table)
} }
else else
{ {
printf("\n#\n# Dumping data for table '%s'\n", table); fprintf(result_file,"\n#\n# Dumping data for table '%s'\n", table);
sprintf(query, "SELECT * FROM %s", quote_name(table,table_buff)); sprintf(query, "SELECT * FROM %s", quote_name(table,table_buff));
if (where) if (where)
{ {
printf("# WHERE: %s\n",where); fprintf(result_file,"# WHERE: %s\n",where);
strxmov(strend(query), " WHERE ",where,NullS); strxmov(strend(query), " WHERE ",where,NullS);
} }
fputs("#\n\n", stdout); fputs("#\n\n", result_file);
if (mysql_query(sock, query)) if (mysql_query(sock, query))
{ {
...@@ -1011,7 +1007,8 @@ static void dumpTable(uint numFields, char *table) ...@@ -1011,7 +1007,8 @@ static void dumpTable(uint numFields, char *table)
} }
if (opt_lock) if (opt_lock)
printf("LOCK TABLES %s WRITE;\n", quote_name(table,table_buff)); fprintf(result_file,"LOCK TABLES %s WRITE;\n",
quote_name(table,table_buff));
total_length=net_buffer_length; /* Force row break */ total_length=net_buffer_length; /* Force row break */
row_break=0; row_break=0;
...@@ -1024,7 +1021,7 @@ static void dumpTable(uint numFields, char *table) ...@@ -1024,7 +1021,7 @@ static void dumpTable(uint numFields, char *table)
ulong *lengths=mysql_fetch_lengths(res); ulong *lengths=mysql_fetch_lengths(res);
rownr++; rownr++;
if (!extended_insert) if (!extended_insert)
fputs(insert_pat,stdout); fputs(insert_pat,result_file);
mysql_field_seek(res,0); mysql_field_seek(res,0);
for (i = 0; i < mysql_num_fields(res); i++) for (i = 0; i < mysql_num_fields(res); i++)
...@@ -1078,17 +1075,17 @@ static void dumpTable(uint numFields, char *table) ...@@ -1078,17 +1075,17 @@ static void dumpTable(uint numFields, char *table)
else else
{ {
if (i) if (i)
putchar(','); fputc(',',result_file);
if (row[i]) if (row[i])
{ {
if (!IS_NUM_FIELD(field)) if (!IS_NUM_FIELD(field))
unescape(stdout, row[i], lengths[i]); unescape(result_file, row[i], lengths[i]);
else else
fputs(row[i],stdout); fputs(row[i],result_file);
} }
else else
{ {
fputs("NULL",stdout); fputs("NULL",result_file);
} }
} }
} }
...@@ -1101,25 +1098,25 @@ static void dumpTable(uint numFields, char *table) ...@@ -1101,25 +1098,25 @@ static void dumpTable(uint numFields, char *table)
if (total_length + row_length < net_buffer_length) if (total_length + row_length < net_buffer_length)
{ {
total_length += row_length; total_length += row_length;
putchar(','); /* Always row break */ fputc(',',result_file); /* Always row break */
fputs(extended_row.str,stdout); fputs(extended_row.str,result_file);
} }
else else
{ {
if (row_break) if (row_break)
fputs(";\n", stdout); fputs(";\n", result_file);
row_break=1; /* This is first row */ row_break=1; /* This is first row */
fputs(insert_pat,stdout); fputs(insert_pat,result_file);
fputs(extended_row.str,stdout); fputs(extended_row.str,result_file);
total_length = row_length+init_length; total_length = row_length+init_length;
} }
} }
else else
fputs(");\n", stdout); fputs(");\n", result_file);
} }
if (extended_insert && row_break) if (extended_insert && row_break)
fputs(";\n", stdout); /* If not empty table */ fputs(";\n", result_file); /* If not empty table */
fflush(stdout); fflush(result_file);
if (mysql_errno(sock)) if (mysql_errno(sock))
{ {
sprintf(query,"%s: Error %d: %s when dumping table '%s' at row: %ld\n", sprintf(query,"%s: Error %d: %s when dumping table '%s' at row: %ld\n",
...@@ -1133,7 +1130,7 @@ static void dumpTable(uint numFields, char *table) ...@@ -1133,7 +1130,7 @@ static void dumpTable(uint numFields, char *table)
return; return;
} }
if (opt_lock) if (opt_lock)
fputs("UNLOCK TABLES;\n", stdout); fputs("UNLOCK TABLES;\n", result_file);
mysql_free_result(res); mysql_free_result(res);
} }
} /* dumpTable */ } /* dumpTable */
...@@ -1209,10 +1206,11 @@ static int init_dumping(char *database) ...@@ -1209,10 +1206,11 @@ static int init_dumping(char *database)
{ {
if (opt_databases || opt_alldbs) if (opt_databases || opt_alldbs)
{ {
printf("\n#\n# Current Database: %s\n#\n", database); fprintf(result_file,"\n#\n# Current Database: %s\n#\n", database);
if (!opt_create_db) if (!opt_create_db)
printf("\nCREATE DATABASE /*!32312 IF NOT EXISTS*/ %s;\n", database); fprintf(result_file,"\nCREATE DATABASE /*!32312 IF NOT EXISTS*/ %s;\n",
printf("\nUSE %s;\n", database); database);
fprintf(result_file,"\nUSE %s;\n", database);
} }
} }
if (extended_insert) if (extended_insert)
...@@ -1344,7 +1342,7 @@ int main(int argc, char **argv) ...@@ -1344,7 +1342,7 @@ int main(int argc, char **argv)
if (dbConnect(current_host, current_user, opt_password)) if (dbConnect(current_host, current_user, opt_password))
exit(EX_MYSQLERR); exit(EX_MYSQLERR);
if (!path) if (!path)
write_heder(stdout, *argv); write_heder(result_file, *argv);
if (opt_first_slave) if (opt_first_slave)
{ {
...@@ -1380,9 +1378,9 @@ int main(int argc, char **argv) ...@@ -1380,9 +1378,9 @@ int main(int argc, char **argv)
} }
} }
dbDisconnect(current_host); dbDisconnect(current_host);
fputs("\n", stdout); fputs("\n", result_file);
if (opt_resultfile) if (result_file != stdout)
my_fclose(stdout, MYF(0)); my_fclose(result_file, MYF(0));
my_free(opt_password, MYF(MY_ALLOW_ZERO_PTR)); my_free(opt_password, MYF(MY_ALLOW_ZERO_PTR));
if (extended_insert) if (extended_insert)
dynstr_free(&extended_row); dynstr_free(&extended_row);
......
...@@ -66,7 +66,7 @@ int my_error(int nr,myf MyFlags, ...) ...@@ -66,7 +66,7 @@ int my_error(int nr,myf MyFlags, ...)
while (isdigit(*tpos) || *tpos == '.' || *tpos == '-') while (isdigit(*tpos) || *tpos == '.' || *tpos == '-')
tpos++; tpos++;
if (*tpos == 'l') /* Skipp 'l' argument */ if (*tpos == 'l') /* Skipp 'l' argument */
*tpos++; tpos++;
if (*tpos == 's') /* String parameter */ if (*tpos == 's') /* String parameter */
{ {
par = va_arg(ap, char *); par = va_arg(ap, char *);
......
...@@ -788,7 +788,7 @@ Fstat(int fd, MY_STAT *stat_area, myf MyFlags ) ...@@ -788,7 +788,7 @@ Fstat(int fd, MY_STAT *stat_area, myf MyFlags )
DBUG_PRINT("enter",("fd: %d MyFlags: %d",fd,MyFlags)); DBUG_PRINT("enter",("fd: %d MyFlags: %d",fd,MyFlags));
uint i; uint i;
int error=0; int error=0;
MY_STAT my_stat; MY_STAT status;
stat_area->st_size=0; stat_area->st_size=0;
stat_area->st_mtime=0; stat_area->st_mtime=0;
stat_area->st_atime=0; stat_area->st_atime=0;
...@@ -796,12 +796,12 @@ Fstat(int fd, MY_STAT *stat_area, myf MyFlags ) ...@@ -796,12 +796,12 @@ Fstat(int fd, MY_STAT *stat_area, myf MyFlags )
for(i=0 ; i < _raid_chunks ; i++) for(i=0 ; i < _raid_chunks ; i++)
{ {
if (my_fstat(_fd_vector[i],&my_stat,MyFlags)) if (my_fstat(_fd_vector[i],&status,MyFlags))
error=1; error=1;
stat_area->st_size+=my_stat.st_size; stat_area->st_size+=status.st_size;
set_if_bigger(stat_area->st_mtime,my_stat.st_mtime); set_if_bigger(stat_area->st_mtime,status.st_mtime);
set_if_bigger(stat_area->st_atime,my_stat.st_atime); set_if_bigger(stat_area->st_atime,status.st_atime);
set_if_bigger(stat_area->st_ctime,my_stat.st_ctime); set_if_bigger(stat_area->st_ctime,status.st_ctime);
} }
DBUG_RETURN(error); DBUG_RETURN(error);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment