mirror of
https://github.com/mangosfour/server.git
synced 2025-12-13 13:37:05 +00:00
Implemented adding the alter table table statement for the last required sql update to the new sql update.
This commit is contained in:
parent
5d2595d7e7
commit
c733c0f70c
1 changed files with 70 additions and 14 deletions
|
|
@ -25,10 +25,12 @@
|
||||||
#define MAX_BUF 2048
|
#define MAX_BUF 2048
|
||||||
#define MAX_CMD 2048
|
#define MAX_CMD 2048
|
||||||
#define MAX_HASH 256
|
#define MAX_HASH 256
|
||||||
|
#define MAX_DB 256
|
||||||
|
|
||||||
// config
|
// config
|
||||||
|
|
||||||
#define NUM_REMOTES 2
|
#define NUM_REMOTES 2
|
||||||
|
#define NUM_DATABASES 3
|
||||||
|
|
||||||
char remotes[NUM_REMOTES][MAX_REMOTE] = {
|
char remotes[NUM_REMOTES][MAX_REMOTE] = {
|
||||||
"git@github.com:mangos/mangos.git",
|
"git@github.com:mangos/mangos.git",
|
||||||
|
|
@ -39,6 +41,18 @@ char remote_branch[MAX_REMOTE] = "master";
|
||||||
char rev_file[MAX_PATH] = "src/shared/revision_nr.h";
|
char rev_file[MAX_PATH] = "src/shared/revision_nr.h";
|
||||||
char sql_update_dir[MAX_PATH] = "sql/updates";
|
char sql_update_dir[MAX_PATH] = "sql/updates";
|
||||||
|
|
||||||
|
char databases[NUM_DATABASES][MAX_DB] = {
|
||||||
|
"characters",
|
||||||
|
"mangos",
|
||||||
|
"realmd"
|
||||||
|
};
|
||||||
|
|
||||||
|
char db_version_table[NUM_DATABASES][MAX_DB] = {
|
||||||
|
"character_db_version",
|
||||||
|
"db_version",
|
||||||
|
"realmd_db_version",
|
||||||
|
};
|
||||||
|
|
||||||
bool allow_replace = false;
|
bool allow_replace = false;
|
||||||
bool local = false;
|
bool local = false;
|
||||||
bool do_fetch = false;
|
bool do_fetch = false;
|
||||||
|
|
@ -48,12 +62,14 @@ bool do_sql = false;
|
||||||
|
|
||||||
char origins[NUM_REMOTES][MAX_REMOTE];
|
char origins[NUM_REMOTES][MAX_REMOTE];
|
||||||
int rev;
|
int rev;
|
||||||
|
int last_sql_rev[NUM_DATABASES] = {0,0,0};
|
||||||
|
|
||||||
char head_message[MAX_MSG];
|
char head_message[MAX_MSG];
|
||||||
char path_prefix[MAX_PATH] = "";
|
char path_prefix[MAX_PATH] = "";
|
||||||
char buffer[MAX_BUF];
|
char buffer[MAX_BUF];
|
||||||
char cmd[MAX_CMD];
|
char cmd[MAX_CMD];
|
||||||
char origin_hash[MAX_HASH];
|
char origin_hash[MAX_HASH];
|
||||||
|
char last_sql_update[NUM_DATABASES][MAX_PATH];
|
||||||
|
|
||||||
std::set<std::string> new_sql_updates;
|
std::set<std::string> new_sql_updates;
|
||||||
|
|
||||||
|
|
@ -280,14 +296,39 @@ bool find_sql_updates()
|
||||||
if(!fgets(buffer, MAX_BUF, cmd_pipe)) { pclose(cmd_pipe); return false; }
|
if(!fgets(buffer, MAX_BUF, cmd_pipe)) { pclose(cmd_pipe); return false; }
|
||||||
if(!fgets(buffer, MAX_BUF, cmd_pipe)) { pclose(cmd_pipe); return false; }
|
if(!fgets(buffer, MAX_BUF, cmd_pipe)) { pclose(cmd_pipe); return false; }
|
||||||
|
|
||||||
int nr;
|
int nr, cur_rev, i;
|
||||||
char db_table[MAX_BUF];
|
char db[MAX_BUF], table[MAX_BUF];
|
||||||
|
|
||||||
while(fgets(buffer, MAX_BUF, cmd_pipe))
|
while(fgets(buffer, MAX_BUF, cmd_pipe))
|
||||||
{
|
{
|
||||||
buffer[strnlen(buffer, MAX_BUF) - 1] = '\0';
|
buffer[strnlen(buffer, MAX_BUF) - 1] = '\0';
|
||||||
if(sscanf(buffer, "%d_%s.sql", &nr, db_table) == 2)
|
if(sscanf(buffer, "%d_%d_%[^_]_%[^.].sql", &cur_rev, &nr, db, table) == 4 ||
|
||||||
new_sql_updates.insert(buffer);
|
sscanf(buffer, "%d_%d_%[^.].sql", &cur_rev, &nr, db) == 3)
|
||||||
|
{
|
||||||
|
// find the update with the highest rev for each database
|
||||||
|
// (will be the required version for the new update)
|
||||||
|
// new updates should not have a rev number already
|
||||||
|
for(i = 0; i < NUM_DATABASES; i++)
|
||||||
|
if(cur_rev > last_sql_rev[i] &&
|
||||||
|
strncmp(db, databases[i], MAX_DB) == 0)
|
||||||
|
break;
|
||||||
|
|
||||||
|
if(i < NUM_DATABASES)
|
||||||
|
{
|
||||||
|
last_sql_rev[i] = cur_rev;
|
||||||
|
strncpy(last_sql_update[i], buffer, MAX_PATH);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(sscanf(buffer, "%d_%[^_]_%[^.].sql", &nr, db, table) == 3 ||
|
||||||
|
sscanf(buffer, "%d_%[^.].sql", &nr, db) == 2)
|
||||||
|
{
|
||||||
|
for(i = 0; i < NUM_DATABASES; i++)
|
||||||
|
if(strncmp(db, databases[i], MAX_DB) == 0) break;
|
||||||
|
if(i == NUM_DATABASES)
|
||||||
|
printf("WARNING: incorrect database name for sql update %s\n", buffer);
|
||||||
|
else
|
||||||
|
new_sql_updates.insert(buffer);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pclose(cmd_pipe);
|
pclose(cmd_pipe);
|
||||||
|
|
@ -304,7 +345,7 @@ bool find_sql_updates()
|
||||||
while(fgets(buffer, MAX_BUF, cmd_pipe))
|
while(fgets(buffer, MAX_BUF, cmd_pipe))
|
||||||
{
|
{
|
||||||
buffer[strnlen(buffer, MAX_BUF) - 1] = '\0';
|
buffer[strnlen(buffer, MAX_BUF) - 1] = '\0';
|
||||||
if(sscanf(buffer, "%d_%s.sql", &nr, db_table) == 2)
|
if(sscanf(buffer, "%d_%[^.].sql", &nr, db) == 2)
|
||||||
new_sql_updates.erase(buffer);
|
new_sql_updates.erase(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -321,13 +362,26 @@ bool find_sql_updates()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool copy_file(const char *src, const char *dst)
|
bool convert_sql_update(const char *src_file, const char *dst_file, const char *dst_name)
|
||||||
{
|
{
|
||||||
FILE * fin = fopen( src, "r" );
|
FILE * fin = fopen( src_file, "r" );
|
||||||
if(!fin) return false;
|
if(!fin) return false;
|
||||||
FILE * fout = fopen( dst, "w" );
|
FILE * fout = fopen( dst_file, "w" );
|
||||||
if(!fout) { fclose(fin); return false; }
|
if(!fout) { fclose(fin); return false; }
|
||||||
|
|
||||||
|
int cur_rev, nr, i;
|
||||||
|
char db[MAX_PATH], table[MAX_PATH];
|
||||||
|
if(sscanf(dst_name, "%d_%d_%[^_]_%[^.].sql", &cur_rev, &nr, db, table) != 4 &&
|
||||||
|
sscanf(dst_name, "%d_%d_%[^.].sql", &cur_rev, &nr, db) != 3)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for(i = 0; i < NUM_DATABASES; i++)
|
||||||
|
if(strncmp(db, databases[i], MAX_DB) == 0) break;
|
||||||
|
if(i == NUM_DATABASES) return false;
|
||||||
|
|
||||||
|
fprintf(fout, "ALTER TABLE %s CHANGE COLUMN required_%s required_%s bit;\n\n",
|
||||||
|
db_version_table[i], last_sql_update[i], dst_name);
|
||||||
|
|
||||||
char c;
|
char c;
|
||||||
while( (c = getc(fin)) != EOF )
|
while( (c = getc(fin)) != EOF )
|
||||||
putc(c, fout);
|
putc(c, fout);
|
||||||
|
|
@ -338,17 +392,19 @@ bool copy_file(const char *src, const char *dst)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool rename_sql_updates()
|
bool convert_sql_updates()
|
||||||
{
|
{
|
||||||
if(new_sql_updates.empty()) return true;
|
if(new_sql_updates.empty()) return true;
|
||||||
|
|
||||||
printf("+ renaming sql updates\n");
|
printf("+ converting sql updates\n");
|
||||||
|
|
||||||
for(std::set<std::string>::iterator itr = new_sql_updates.begin(); itr != new_sql_updates.end(); ++itr)
|
for(std::set<std::string>::iterator itr = new_sql_updates.begin(); itr != new_sql_updates.end(); ++itr)
|
||||||
{
|
{
|
||||||
char src_file[MAX_PATH], dst_file[MAX_PATH];
|
char src_file[MAX_PATH], dst_file[MAX_PATH], dst_name[MAX_PATH];
|
||||||
snprintf(src_file, MAX_PATH, "%s%s/%s", path_prefix, sql_update_dir, itr->c_str());
|
snprintf(src_file, MAX_PATH, "%s%s/%s", path_prefix, sql_update_dir, itr->c_str());
|
||||||
snprintf(dst_file, MAX_PATH, "%s%s/%d_%s", path_prefix, sql_update_dir, rev, itr->c_str());
|
snprintf(dst_name, MAX_PATH, "%d_%s", rev, itr->c_str());
|
||||||
if(!copy_file(src_file, dst_file)) return false;
|
snprintf(dst_file, MAX_PATH, "%s%s/%s", path_prefix, sql_update_dir, dst_name);
|
||||||
|
if(!convert_sql_update(src_file, dst_file, dst_name)) return false;
|
||||||
snprintf(cmd, MAX_CMD, "git add %s", dst_file);
|
snprintf(cmd, MAX_CMD, "git add %s", dst_file);
|
||||||
system(cmd);
|
system(cmd);
|
||||||
snprintf(cmd, MAX_CMD, "git rm %s", src_file);
|
snprintf(cmd, MAX_CMD, "git rm %s", src_file);
|
||||||
|
|
@ -494,7 +550,7 @@ int main(int argc, char *argv[])
|
||||||
DO( write_rev() );
|
DO( write_rev() );
|
||||||
if(do_sql)
|
if(do_sql)
|
||||||
{
|
{
|
||||||
DO( rename_sql_updates() );
|
DO( convert_sql_updates() );
|
||||||
DO( generate_sql_makefile() );
|
DO( generate_sql_makefile() );
|
||||||
}
|
}
|
||||||
DO( amend_commit() );
|
DO( amend_commit() );
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue