/* Copyright (C) 2004-2005 MySQL AB This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2 of the License. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #include #include #ifndef __WIN__ #include #endif #include #ifdef __NETWARE__ #include #include #else #include #ifndef __WIN__ #include #include #else #include #include #include #endif #endif #include #include #include #include #include "my_manage.h" /* Synopsis: This function testes a exist file Arguments: mdata: path to data file_name: name of file Output: A zero value indicates that file is exist. */ bool test_sys_file(const char *mdata,const char *file_name) { struct stat file; char path_file_name[PATH_MAX]; snprintf(path_file_name, PATH_MAX, "%s/%s", mdata, file_name); return(stat(path_file_name,&file)); } /* Synopsis: This function creates a file with sql requstes for creating system data files. Arguments: mdata: path to data output_file: file name for output file test: to create system files with test data Output: A zero value indicates a success. */ bool create_system_files(const char *mdata,const char *output_file, bool test) { FILE *out; out = fopen(output_file, "w+"); if (!out) return 1; if (test_sys_file(mdata,"mysql")) { fprintf(out,"CREATE DATABASE mysql;\n"); } if (test && test_sys_file(mdata,"test")) { fprintf(out,"CREATE DATABASE test;\n"); } fprintf(out,"USE mysql;\n"); if (test_sys_file(mdata,"mysql/db.frm")) { fprintf(out, "CREATE TABLE db (" "Host char(60) binary DEFAULT '' NOT NULL," "Db char(64) binary DEFAULT '' NOT NULL," "User char(16) binary DEFAULT '' NOT NULL," "Select_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Insert_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Update_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Delete_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Create_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Drop_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Grant_priv enum('N','Y') DEFAULT 'N' NOT NULL," "References_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Index_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Alter_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Create_tmp_table_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Lock_tables_priv enum('N','Y') DEFAULT 'N' NOT NULL," "PRIMARY KEY Host (Host,Db,User)," "KEY User (User))" "engine=MyISAM " "CHARACTER SET utf8 COLLATE utf8_bin " "comment='Database privileges';\n"); if (test) { fprintf(out,"INSERT INTO db VALUES ('%%','test','','Y','Y','Y','Y'" ",'Y','Y','N','Y','Y','Y','Y','Y');\n"); fprintf(out,"INSERT INTO db VALUES ('%%','test\\_%%','','Y','Y','Y'" ",'Y','Y','Y','N','Y','Y','Y','Y','Y');\n"); } } if (test_sys_file(mdata,"mysql/host.frm")) { fprintf(out, "CREATE TABLE host (" "Host char(60) binary DEFAULT '' NOT NULL," "Db char(64) binary DEFAULT '' NOT NULL," "Select_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Insert_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Update_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Delete_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Create_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Drop_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Grant_priv enum('N','Y') DEFAULT 'N' NOT NULL," "References_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Index_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Alter_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Create_tmp_table_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Lock_tables_priv enum('N','Y') DEFAULT 'N' NOT NULL," "PRIMARY KEY Host (Host,Db))" "engine=MyISAM " "CHARACTER SET utf8 COLLATE utf8_bin " "comment='Host privileges; Merged with database privileges';\n"); } if (test_sys_file(mdata,"mysql/user.frm")) { #ifdef __WIN__ WSADATA wsa_data; #endif char hostname[FN_REFLEN]; #ifdef __WIN__ if (WSAStartup(MAKEWORD( 2, 2 ),&wsa_data)) return 1; #endif if (gethostname(hostname, FN_REFLEN)) return 1; #ifdef __WIN__ WSACleanup( ); #endif if (strchr(hostname, '.') == NULL) strcat(hostname, "%"); fprintf(out, "CREATE TABLE user (" "Host char(60) binary DEFAULT '' NOT NULL," "User char(16) binary DEFAULT '' NOT NULL," "Password char(41) binary DEFAULT '' NOT NULL," "Select_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Insert_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Update_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Delete_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Create_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Drop_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Reload_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Shutdown_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Process_priv enum('N','Y') DEFAULT 'N' NOT NULL," "File_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Grant_priv enum('N','Y') DEFAULT 'N' NOT NULL," "References_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Index_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Alter_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Show_db_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Super_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Create_tmp_table_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Lock_tables_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Execute_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Repl_slave_priv enum('N','Y') DEFAULT 'N' NOT NULL," "Repl_client_priv enum('N','Y') DEFAULT 'N' NOT NULL," "ssl_type enum('','ANY','X509', 'SPECIFIED') DEFAULT '' NOT NULL," "ssl_cipher BLOB NOT NULL," "x509_issuer BLOB NOT NULL," "x509_subject BLOB NOT NULL," "max_questions int(11) unsigned DEFAULT 0 NOT NULL," "max_updates int(11) unsigned DEFAULT 0 NOT NULL," "max_connections int(11) unsigned DEFAULT 0 NOT NULL," "PRIMARY KEY Host (Host,User)" ") engine=MyISAM " "CHARACTER SET utf8 COLLATE utf8_bin " "comment='Users and global privileges';\n"); if (test) { fprintf(out, "INSERT INTO user VALUES ('localhost','root',''" ",'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y'" ",'Y','Y','Y','Y','Y','','','','',0,0,0);\n"); fprintf(out, "INSERT INTO user VALUES ('%s','root','','Y','Y'," "'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y'," "'Y','Y','Y','Y','','','','',0,0,0);\n",hostname); fprintf(out, "REPLACE INTO user VALUES ('127.0.0.1','root',''," "'Y','Y','Y','Y','Y','Y'," "'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y'" ",'Y','','','','',0,0,0);\n"); fprintf(out,"INSERT INTO user (host,user) values ('localhost','');\n"); fprintf(out,"INSERT INTO user (host,user) values ('%s','');\n",hostname); } else { fprintf(out, "INSERT INTO user VALUES ('localhost','root',''," "'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y'," "'Y','Y','Y','Y','','','','',0,0,0);\n"); #ifndef __WIN__ fprintf(out, "INSERT INTO user VALUES ('%s','root','','Y','Y'," "'Y','Y','Y','Y','Y','Y'" "'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','',''" ",'','',0,0,0);\n",hostname); fprintf(out,"INSERT INTO user (host,user) values ('%s','');\n",hostname); fprintf(out,"INSERT INTO user (host,user) values ('localhost','');\n"); #else fprintf(out, "INSERT INTO user VALUES ('localhost','','','Y','Y','Y'" ",'Y','Y','Y','Y','Y','Y'" ",'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','',''," "'','',0,0,0);\n"); #endif } } if (test_sys_file(mdata,"mysql/func.frm")) { fprintf(out, "CREATE TABLE func (" "name char(64) binary DEFAULT '' NOT NULL," "ret tinyint(1) DEFAULT '0' NOT NULL," "dl char(128) DEFAULT '' NOT NULL," "type enum ('function','aggregate') NOT NULL," "PRIMARY KEY (name)" ") engine=MyISAM " "CHARACTER SET utf8 COLLATE utf8_bin " "comment='User defined functions';\n"); } if (test_sys_file(mdata,"mysql/tables_priv.frm")) { fprintf(out, "CREATE TABLE tables_priv (" "Host char(60) binary DEFAULT '' NOT NULL," "Db char(64) binary DEFAULT '' NOT NULL," "User char(16) binary DEFAULT '' NOT NULL," "Table_name char(64) binary DEFAULT '' NOT NULL," "Grantor char(77) DEFAULT '' NOT NULL," "Timestamp timestamp(14)," "Table_priv set('Select','Insert','Update','Delete'," "'Create','Drop','Grant','References','Index','Alter')" " DEFAULT '' NOT NULL," "Column_priv set('Select','Insert','Update','References')" " DEFAULT '' NOT NULL," "PRIMARY KEY (Host,Db,User,Table_name)," "KEY Grantor (Grantor)" ") engine=MyISAM " "CHARACTER SET utf8 COLLATE utf8_bin " "comment='Table privileges';\n"); } if (test_sys_file(mdata,"mysql/columns_priv.frm")) { fprintf(out, "CREATE TABLE columns_priv (" "Host char(60) binary DEFAULT '' NOT NULL," "Db char(64) binary DEFAULT '' NOT NULL," "User char(16) binary DEFAULT '' NOT NULL," "Table_name char(64) binary DEFAULT '' NOT NULL," "Column_name char(64) binary DEFAULT '' NOT NULL," "Timestamp timestamp(14)," "Column_priv set('Select','Insert','Update','References')" " DEFAULT '' NOT NULL," "PRIMARY KEY (Host,Db,User,Table_name,Column_name)" ") engine=MyISAM " "CHARACTER SET utf8 COLLATE utf8_bin " "comment='Column privileges';\n"); } if (test_sys_file(mdata,"mysql/help_topic.frm")) { fprintf(out, "CREATE TABLE help_topic (" "help_topic_id int unsigned not null," "name varchar(64) not null," "help_category_id smallint unsigned not null," "description text not null," "example text not null," "url varchar(128) not null," "primary key (help_topic_id)," "unique index (name)" ") engine=MyISAM " "CHARACTER SET utf8 " "comment='help topics';\n"); } if (test_sys_file(mdata,"mysql/help_category.frm")) { fprintf(out, "CREATE TABLE help_category (" "help_category_id smallint unsigned not null," "name varchar(64) not null," "parent_category_id smallint unsigned null," "url varchar(128) not null," "primary key (help_category_id)," "unique index (name)" ") engine=MyISAM " "CHARACTER SET utf8 " "comment='help categories';\n"); } if (test_sys_file(mdata,"mysql/help_keyword.frm")) { fprintf(out, "CREATE TABLE help_keyword (" "help_keyword_id int unsigned not null," "name varchar(64) not null," "primary key (help_keyword_id)," "unique index (name)" ") engine=MyISAM " "CHARACTER SET utf8 " "comment='help keywords';\n"); } if (test_sys_file(mdata,"mysql/help_relation.frm")) { fprintf(out, "CREATE TABLE help_relation (" "help_topic_id int unsigned not null references help_topic," "help_keyword_id int unsigned not null references help_keyword," "primary key (help_keyword_id, help_topic_id)" ") engine=MyISAM " "CHARACTER SET utf8 " "comment='keyword-topic relation';\n"); } if (test_sys_file(mdata,"mysql/time_zone_name.frm")) { fprintf(out, "CREATE TABLE time_zone_name (" "Name char(64) NOT NULL," "Time_zone_id int unsigned NOT NULL," "PRIMARY KEY Name (Name)" ") engine=MyISAM CHARACTER SET utf8 " "comment='Time zone names';\n"); if (test) { fprintf(out, "INSERT INTO time_zone_name (Name, Time_Zone_id) VALUES" "('MET', 1), ('UTC', 2), ('Universal', 2), " "('Europe/Moscow',3), ('leap/Europe/Moscow',4)," "('Japan', 5);\n"); } } if (test_sys_file(mdata,"mysql/time_zone.frm")) { fprintf(out, "CREATE TABLE time_zone (" "Time_zone_id int unsigned NOT NULL auto_increment," "Use_leap_seconds enum('Y','N') DEFAULT 'N' NOT NULL," "PRIMARY KEY TzId (Time_zone_id)" ") engine=MyISAM CHARACTER SET utf8 " "comment='Time zones';\n"); if (test) { fprintf(out,"INSERT INTO time_zone (Time_zone_id, Use_leap_seconds)" "VALUES (1,'N'), (2,'N'), (3,'N'), (4,'Y'), (5,'N');\n"); } } if (test_sys_file(mdata,"mysql/time_zone_transition.frm")) { fprintf(out, "CREATE TABLE time_zone_transition (" "Time_zone_id int unsigned NOT NULL," "Transition_time bigint signed NOT NULL," "Transition_type_id int unsigned NOT NULL," "PRIMARY KEY TzIdTranTime (Time_zone_id, Transition_time)" ") engine=MyISAM CHARACTER SET utf8 " "comment='Time zone transitions';\n"); if (test) { fprintf(out, "INSERT INTO time_zone_transition" "(Time_zone_id, Transition_time, Transition_type_id)" "VALUES" " (1, -1693706400, 0) ,(1, -1680483600, 1)" ",(1, -1663455600, 2) ,(1, -1650150000, 3)" ",(1, -1632006000, 2) ,(1, -1618700400, 3)" ",(1, -938905200, 2) ,(1, -857257200, 3)" ",(1, -844556400, 2) ,(1, -828226800, 3)" ",(1, -812502000, 2) ,(1, -796777200, 3)" ",(1, 228877200, 2) ,(1, 243997200, 3)" ",(1, 260326800, 2) ,(1, 276051600, 3)" ",(1, 291776400, 2) ,(1, 307501200, 3)" ",(1, 323830800, 2) ,(1, 338950800, 3)" ",(1, 354675600, 2) ,(1, 370400400, 3)" ",(1, 386125200, 2) ,(1, 401850000, 3)" ",(1, 417574800, 2) ,(1, 433299600, 3)" ",(1, 449024400, 2) ,(1, 465354000, 3)" ",(1, 481078800, 2) ,(1, 496803600, 3)" ",(1, 512528400, 2) ,(1, 528253200, 3)" ",(1, 543978000, 2) ,(1, 559702800, 3)" ",(1, 575427600, 2) ,(1, 591152400, 3)" ",(1, 606877200, 2) ,(1, 622602000, 3)" ",(1, 638326800, 2) ,(1, 654656400, 3)" ",(1, 670381200, 2) ,(1, 686106000, 3)" ",(1, 701830800, 2) ,(1, 717555600, 3)" ",(1, 733280400, 2) ,(1, 749005200, 3)" ",(1, 764730000, 2) ,(1, 780454800, 3)" ",(1, 796179600, 2) ,(1, 811904400, 3)" ",(1, 828234000, 2) ,(1, 846378000, 3)" ",(1, 859683600, 2) ,(1, 877827600, 3)" ",(1, 891133200, 2) ,(1, 909277200, 3)" ",(1, 922582800, 2) ,(1, 941331600, 3)" ",(1, 954032400, 2) ,(1, 972781200, 3)" ",(1, 985482000, 2) ,(1, 1004230800, 3)" ",(1, 1017536400, 2) ,(1, 1035680400, 3)" ",(1, 1048986000, 2) ,(1, 1067130000, 3)" ",(1, 1080435600, 2) ,(1, 1099184400, 3)" ",(1, 1111885200, 2) ,(1, 1130634000, 3)" ",(1, 1143334800, 2) ,(1, 1162083600, 3)" ",(1, 1174784400, 2) ,(1, 1193533200, 3)" ",(1, 1206838800, 2) ,(1, 1224982800, 3)" ",(1, 1238288400, 2) ,(1, 1256432400, 3)" ",(1, 1269738000, 2) ,(1, 1288486800, 3)" ",(1, 1301187600, 2) ,(1, 1319936400, 3)" ",(1, 1332637200, 2) ,(1, 1351386000, 3)" ",(1, 1364691600, 2) ,(1, 1382835600, 3)" ",(1, 1396141200, 2) ,(1, 1414285200, 3)" ",(1, 1427590800, 2) ,(1, 1445734800, 3)" ",(1, 1459040400, 2) ,(1, 1477789200, 3)" ",(1, 1490490000, 2) ,(1, 1509238800, 3)" ",(1, 1521939600, 2) ,(1, 1540688400, 3)" ",(1, 1553994000, 2) ,(1, 1572138000, 3)" ",(1, 1585443600, 2) ,(1, 1603587600, 3)" ",(1, 1616893200, 2) ,(1, 1635642000, 3)" ",(1, 1648342800, 2) ,(1, 1667091600, 3)" ",(1, 1679792400, 2) ,(1, 1698541200, 3)" ",(1, 1711846800, 2) ,(1, 1729990800, 3)" ",(1, 1743296400, 2) ,(1, 1761440400, 3)" ",(1, 1774746000, 2) ,(1, 1792890000, 3)" ",(1, 1806195600, 2) ,(1, 1824944400, 3)" ",(1, 1837645200, 2) ,(1, 1856394000, 3)" ",(1, 1869094800, 2) ,(1, 1887843600, 3)" ",(1, 1901149200, 2) ,(1, 1919293200, 3)" ",(1, 1932598800, 2) ,(1, 1950742800, 3)" ",(1, 1964048400, 2) ,(1, 1982797200, 3)" ",(1, 1995498000, 2) ,(1, 2014246800, 3)" ",(1, 2026947600, 2) ,(1, 2045696400, 3)" ",(1, 2058397200, 2) ,(1, 2077146000, 3)" ",(1, 2090451600, 2) ,(1, 2108595600, 3)" ",(1, 2121901200, 2) ,(1, 2140045200, 3)" ",(3, -1688265000, 2) ,(3, -1656819048, 1)" ",(3, -1641353448, 2) ,(3, -1627965048, 3)" ",(3, -1618716648, 1) ,(3, -1596429048, 3)" ",(3, -1593829848, 5) ,(3, -1589860800, 4)" ",(3, -1542427200, 5) ,(3, -1539493200, 6)" ",(3, -1525323600, 5) ,(3, -1522728000, 4)" ",(3, -1491188400, 7) ,(3, -1247536800, 4)" ",(3, 354920400, 5) ,(3, 370728000, 4)" ",(3, 386456400, 5) ,(3, 402264000, 4)" ",(3, 417992400, 5) ,(3, 433800000, 4)" ",(3, 449614800, 5) ,(3, 465346800, 8)" ",(3, 481071600, 9) ,(3, 496796400, 8)" ",(3, 512521200, 9) ,(3, 528246000, 8)" ",(3, 543970800, 9) ,(3, 559695600, 8)" ",(3, 575420400, 9) ,(3, 591145200, 8)" ",(3, 606870000, 9) ,(3, 622594800, 8)" ",(3, 638319600, 9) ,(3, 654649200, 8)" ",(3, 670374000, 10) ,(3, 686102400, 11)" ",(3, 695779200, 8) ,(3, 701812800, 5)" ",(3, 717534000, 4) ,(3, 733273200, 9)" ",(3, 748998000, 8) ,(3, 764722800, 9)" ",(3, 780447600, 8) ,(3, 796172400, 9)" ",(3, 811897200, 8) ,(3, 828226800, 9)" ",(3, 846370800, 8) ,(3, 859676400, 9)" ",(3, 877820400, 8) ,(3, 891126000, 9)" ",(3, 909270000, 8) ,(3, 922575600, 9)" ",(3, 941324400, 8) ,(3, 954025200, 9)" ",(3, 972774000, 8) ,(3, 985474800, 9)" ",(3, 1004223600, 8) ,(3, 1017529200, 9)" ",(3, 1035673200, 8) ,(3, 1048978800, 9)" ",(3, 1067122800, 8) ,(3, 1080428400, 9)" ",(3, 1099177200, 8) ,(3, 1111878000, 9)" ",(3, 1130626800, 8) ,(3, 1143327600, 9)" ",(3, 1162076400, 8) ,(3, 1174777200, 9)" ",(3, 1193526000, 8) ,(3, 1206831600, 9)" ",(3, 1224975600, 8) ,(3, 1238281200, 9)" ",(3, 1256425200, 8) ,(3, 1269730800, 9)" ",(3, 1288479600, 8) ,(3, 1301180400, 9)" ",(3, 1319929200, 8) ,(3, 1332630000, 9)" ",(3, 1351378800, 8) ,(3, 1364684400, 9)" ",(3, 1382828400, 8) ,(3, 1396134000, 9)" ",(3, 1414278000, 8) ,(3, 1427583600, 9)" ",(3, 1445727600, 8) ,(3, 1459033200, 9)" ",(3, 1477782000, 8) ,(3, 1490482800, 9)" ",(3, 1509231600, 8) ,(3, 1521932400, 9)" ",(3, 1540681200, 8) ,(3, 1553986800, 9)" ",(3, 1572130800, 8) ,(3, 1585436400, 9)" ",(3, 1603580400, 8) ,(3, 1616886000, 9)" ",(3, 1635634800, 8) ,(3, 1648335600, 9)" ",(3, 1667084400, 8) ,(3, 1679785200, 9)" ",(3, 1698534000, 8) ,(3, 1711839600, 9)" ",(3, 1729983600, 8) ,(3, 1743289200, 9)" ",(3, 1761433200, 8) ,(3, 1774738800, 9)" ",(3, 1792882800, 8) ,(3, 1806188400, 9)" ",(3, 1824937200, 8) ,(3, 1837638000, 9)" ",(3, 1856386800, 8) ,(3, 1869087600, 9)" ",(3, 1887836400, 8) ,(3, 1901142000, 9)" ",(3, 1919286000, 8) ,(3, 1932591600, 9)" ",(3, 1950735600, 8) ,(3, 1964041200, 9)" ",(3, 1982790000, 8) ,(3, 1995490800, 9)" ",(3, 2014239600, 8) ,(3, 2026940400, 9)" ",(3, 2045689200, 8) ,(3, 2058390000, 9)" ",(3, 2077138800, 8) ,(3, 2090444400, 9)" ",(3, 2108588400, 8) ,(3, 2121894000, 9)" ",(3, 2140038000, 8)" ",(4, -1688265000, 2) ,(4, -1656819048, 1)" ",(4, -1641353448, 2) ,(4, -1627965048, 3)" ",(4, -1618716648, 1) ,(4, -1596429048, 3)" ",(4, -1593829848, 5) ,(4, -1589860800, 4)" ",(4, -1542427200, 5) ,(4, -1539493200, 6)" ",(4, -1525323600, 5) ,(4, -1522728000, 4)" ",(4, -1491188400, 7) ,(4, -1247536800, 4)" ",(4, 354920409, 5) ,(4, 370728010, 4)" ",(4, 386456410, 5) ,(4, 402264011, 4)" ",(4, 417992411, 5) ,(4, 433800012, 4)" ",(4, 449614812, 5) ,(4, 465346812, 8)" ",(4, 481071612, 9) ,(4, 496796413, 8)" ",(4, 512521213, 9) ,(4, 528246013, 8)" ",(4, 543970813, 9) ,(4, 559695613, 8)" ",(4, 575420414, 9) ,(4, 591145214, 8)" ",(4, 606870014, 9) ,(4, 622594814, 8)" ",(4, 638319615, 9) ,(4, 654649215, 8)" ",(4, 670374016, 10) ,(4, 686102416, 11)" ",(4, 695779216, 8) ,(4, 701812816, 5)" ",(4, 717534017, 4) ,(4, 733273217, 9)" ",(4, 748998018, 8) ,(4, 764722818, 9)" ",(4, 780447619, 8) ,(4, 796172419, 9)" ",(4, 811897219, 8) ,(4, 828226820, 9)" ",(4, 846370820, 8) ,(4, 859676420, 9)" ",(4, 877820421, 8) ,(4, 891126021, 9)" ",(4, 909270021, 8) ,(4, 922575622, 9)" ",(4, 941324422, 8) ,(4, 954025222, 9)" ",(4, 972774022, 8) ,(4, 985474822, 9)" ",(4, 1004223622, 8) ,(4, 1017529222, 9)" ",(4, 1035673222, 8) ,(4, 1048978822, 9)" ",(4, 1067122822, 8) ,(4, 1080428422, 9)" ",(4, 1099177222, 8) ,(4, 1111878022, 9)" ",(4, 1130626822, 8) ,(4, 1143327622, 9)" ",(4, 1162076422, 8) ,(4, 1174777222, 9)" ",(4, 1193526022, 8) ,(4, 1206831622, 9)" ",(4, 1224975622, 8) ,(4, 1238281222, 9)" ",(4, 1256425222, 8) ,(4, 1269730822, 9)" ",(4, 1288479622, 8) ,(4, 1301180422, 9)" ",(4, 1319929222, 8) ,(4, 1332630022, 9)" ",(4, 1351378822, 8) ,(4, 1364684422, 9)" ",(4, 1382828422, 8) ,(4, 1396134022, 9)" ",(4, 1414278022, 8) ,(4, 1427583622, 9)" ",(4, 1445727622, 8) ,(4, 1459033222, 9)" ",(4, 1477782022, 8) ,(4, 1490482822, 9)" ",(4, 1509231622, 8) ,(4, 1521932422, 9)" ",(4, 1540681222, 8) ,(4, 1553986822, 9)" ",(4, 1572130822, 8) ,(4, 1585436422, 9)" ",(4, 1603580422, 8) ,(4, 1616886022, 9)" ",(4, 1635634822, 8) ,(4, 1648335622, 9)" ",(4, 1667084422, 8) ,(4, 1679785222, 9)" ",(4, 1698534022, 8) ,(4, 1711839622, 9)" ",(4, 1729983622, 8) ,(4, 1743289222, 9)" ",(4, 1761433222, 8) ,(4, 1774738822, 9)" ",(4, 1792882822, 8) ,(4, 1806188422, 9)" ",(4, 1824937222, 8) ,(4, 1837638022, 9)" ",(4, 1856386822, 8) ,(4, 1869087622, 9)" ",(4, 1887836422, 8) ,(4, 1901142022, 9)" ",(4, 1919286022, 8) ,(4, 1932591622, 9)" ",(4, 1950735622, 8) ,(4, 1964041222, 9)" ",(4, 1982790022, 8) ,(4, 1995490822, 9)" ",(4, 2014239622, 8) ,(4, 2026940422, 9)" ",(4, 2045689222, 8) ,(4, 2058390022, 9)" ",(4, 2077138822, 8) ,(4, 2090444422, 9)" ",(4, 2108588422, 8) ,(4, 2121894022, 9)" ",(4, 2140038022, 8), (5, -1009875600, 1);\n"); } } if (test_sys_file(mdata,"mysql/time_zone_transition_type.frm")) { fprintf(out, "CREATE TABLE time_zone_transition_type (" "Time_zone_id int unsigned NOT NULL," "Transition_type_id int unsigned NOT NULL," "Offset int signed DEFAULT 0 NOT NULL," "Is_DST tinyint unsigned DEFAULT 0 NOT NULL," "Abbreviation char(8) DEFAULT '' NOT NULL," "PRIMARY KEY TzIdTrTId (Time_zone_id, Transition_type_id)" ") engine=MyISAM CHARACTER SET utf8 " "comment='Time zone transition types';\n"); if (test) { fprintf(out, "INSERT INTO time_zone_transition_type (Time_zone_id," "Transition_type_id, Offset, Is_DST, Abbreviation) VALUES" "(1, 0, 7200, 1, 'MEST') ,(1, 1, 3600, 0, 'MET')" ",(1, 2, 7200, 1, 'MEST') ,(1, 3, 3600, 0, 'MET')" ",(2, 0, 0, 0, 'UTC')" ",(3, 0, 9000, 0, 'MMT') ,(3, 1, 12648, 1, 'MST')" ",(3, 2, 9048, 0, 'MMT') ,(3, 3, 16248, 1, 'MDST')" ",(3, 4, 10800, 0, 'MSK') ,(3, 5, 14400, 1, 'MSD')" ",(3, 6, 18000, 1, 'MSD') ,(3, 7, 7200, 0, 'EET')" ",(3, 8, 10800, 0, 'MSK') ,(3, 9, 14400, 1, 'MSD')" ",(3, 10, 10800, 1, 'EEST') ,(3, 11, 7200, 0, 'EET')" ",(4, 0, 9000, 0, 'MMT') ,(4, 1, 12648, 1, 'MST')" ",(4, 2, 9048, 0, 'MMT') ,(4, 3, 16248, 1, 'MDST')" ",(4, 4, 10800, 0, 'MSK') ,(4, 5, 14400, 1, 'MSD')" ",(4, 6, 18000, 1, 'MSD') ,(4, 7, 7200, 0, 'EET')" ",(4, 8, 10800, 0, 'MSK') ,(4, 9, 14400, 1, 'MSD')" ",(4, 10, 10800, 1, 'EEST') ,(4, 11, 7200, 0, 'EET')" ",(5, 0, 32400, 0, 'CJT') ,(5, 1, 32400, 0, 'JST');\n"); } } if (test_sys_file(mdata,"mysql/time_zone_leap_second.frm")) { fprintf(out, "CREATE TABLE time_zone_leap_second (" "Transition_time bigint signed NOT NULL," "Correction int signed NOT NULL," "PRIMARY KEY TranTime (Transition_time)" ") engine=MyISAM CHARACTER SET utf8 " "comment='Leap seconds information for time zones';\n"); if (test) { fprintf(out, "INSERT INTO time_zone_leap_second " "(Transition_time, Correction) VALUES " "(78796800, 1) ,(94694401, 2) ,(126230402, 3)" ",(157766403, 4) ,(189302404, 5) ,(220924805, 6)" ",(252460806, 7) ,(283996807, 8) ,(315532808, 9)" ",(362793609, 10) ,(394329610, 11) ,(425865611, 12)" ",(489024012, 13) ,(567993613, 14) ,(631152014, 15)" ",(662688015, 16) ,(709948816, 17) ,(741484817, 18)" ",(773020818, 19) ,(820454419, 20) ,(867715220, 21)" ",(915148821, 22);\n"); } } return fclose(out); }