Sfoglia il codice sorgente

Removed whitespace & duplicate label in runserver.bat (#8385)

Akkarinage 11 mesi fa
parent
commit
39644a980f
8 ha cambiato i file con 361 aggiunte e 364 eliminazioni
  1. 12 12
      tools/check-doc.pl
  2. 253 254
      tools/config.pl
  3. 54 54
      tools/convert_emotions.py
  4. 7 7
      tools/convert_monstermode.pl
  5. 2 2
      tools/convert_sql.pl
  6. 5 7
      tools/runserver.bat
  7. 1 1
      tools/stackdump
  8. 27 27
      tools/update.pl

+ 12 - 12
tools/check-doc.pl

@@ -32,8 +32,8 @@ sub GetArgs {
     'target=s'	=> \$sTarget,	 #Target (wich files to run-cmd into)
     'leftover=i' => \$sLeftOverChk, #should we chk if all doc are linked to a src ?
     'help!' => \$sHelp,
-    ) or $sHelp=1; #display help if invalid option	
-	
+    ) or $sHelp=1; #display help if invalid option
+
     if( $sHelp ) {
 	print "Incorrect option specified, available options are:\n"
 	    ."\t --atcf filename => file (specify atcommand doc to use)\n"
@@ -96,7 +96,7 @@ sub Script_GetCmd {
 	my @aSct_src = ("../src/map/script.cpp","../src/custom/script_def.inc");
 	my @aDef_sct = ();
 	foreach my $sSct_srcf (@aSct_src){
-		unless(open FILE_SRC, "<$sSct_srcf") { 
+		unless(open FILE_SRC, "<$sSct_srcf") {
 			print "Couldn't open file '$sSct_srcf'.\n";
 			next;
 		}
@@ -139,16 +139,16 @@ sub Script_Chk { my ($raDef_sct) = @_;
 				@line = split('\(',$line[0]);
 				@line = split('\<',$line[0]);
 				$line[0] =~ s/\(|\{|\*|\r|\s|\;|\)|\"|\,//g; #todo please harmonize command definition for easier parse
-				
-				next if($line[0] eq "Name" || $line[0] eq "" || $line[0] eq "function" 
+
+				next if($line[0] eq "Name" || $line[0] eq "" || $line[0] eq "function"
 				|| $line[0] eq "if" || $line[0] eq "while" || $line[0] eq "do"  || $line[0] eq "for" ); #exception list
-				
+
 				push(@aDoc_sct,$line[0]);
 			}
 		}
 		close FILE_DOC;
 	}
-	
+
 	$raMiss_sct = Chk($raDef_sct,\@aDoc_sct); #check missing documentation
 	if(scalar(@$raMiss_sct)){
 		print "Missing script documentation for function :{\n";
@@ -158,7 +158,7 @@ sub Script_Chk { my ($raDef_sct) = @_;
 		print "}\n\n";
 	}
 	else { print "All script commands in src are documented, no issues found.\n"; }
-	
+
 	if($sLeftOverChk){
 		my $raLeftover_sct = Chk(\@aDoc_sct,$raDef_sct); #we just inverse the chk for leftover
 		if(scalar(@$raLeftover_sct)){
@@ -185,7 +185,7 @@ sub Atc_GetCmd {
 			if($_ =~ /ACMD_DEF|ACMD_DEF2|ACMD_DEFR|ACMD_DEF2R/){
 				$_ =~ s/\s+$//; #Remove trailing spaces.
 				$_ =~ s/^\s+//; #Remove leading spaces.
-				
+
 				if($_ =~ /^ACMD_DEF2|^ACMD_DEF2R/){
 					my @line = split('"',$_);
 					push(@aDef_act,$line[1]);
@@ -207,7 +207,7 @@ sub Atc_Chk {  my ($raDef_act) = @_;
 	my @aAct_docf = ($sAtcf,$sInc_atcf);
 	my @aDoc_act = ();
 	my $raMiss_act;
-	
+
 	foreach my $sAct_docf (@aAct_docf){
 		unless(open FILE_DOC, "$sAct_docf"){
 			print "Couldn't open file '$sAct_docf'.\n";
@@ -226,7 +226,7 @@ sub Atc_Chk {  my ($raDef_act) = @_;
 		}
 		close FILE_DOC;
 	}
-	
+
 	$raMiss_act = Chk($raDef_act,\@aDoc_act); #check missing documentation
 	if(scalar(@$raMiss_act)){
 		print "Missing atcommand documentation for function :{\n";
@@ -236,7 +236,7 @@ sub Atc_Chk {  my ($raDef_act) = @_;
 		print "}\n\n";
 	}
 	else { print "All atcommands in src are documented, no issues found.\n"; }
-	
+
 	if($sLeftOverChk){
 		my $raLeftover_sct = Chk(\@aDoc_act,$raDef_act); #we just inverse the chk for leftover
 		if(scalar(@$raLeftover_sct)){

+ 253 - 254
tools/config.pl

@@ -16,30 +16,30 @@ use rA_Common;
 use LWP::Simple;
 
 use constant {
-    SERV_UID => "Serv_userid",
-    SERV_PW => "Serv_userpass",
-    LOGIN_PRIV_IP => "login_priv_ip",
+	SERV_UID => "Serv_userid",
+	SERV_PW => "Serv_userpass",
+	LOGIN_PRIV_IP => "login_priv_ip",
 	CHAR_PRIV_IP => "char_priv_ip",
-    SERV_WAN_IP => "Serv_wan_ip",
-    MAP_PORT => "Map_port",
-    CHAR_PORT => "Char_port",
-    LOGIN_PORT => "Login_port",
-    MD5_ENABLE => "enable_MD5",
-    PINCODE_ENABLE => "enable_pincode",
-    SQL_HOST => "SQL_host",
-    SQL_PORT => "SQL_port",
-    SQL_UID => "SQL_userid",
-    SQL_PW => "SQL_userpass",
-    SQL_MAIN_DB => "SQL_maindb",
-    SQL_LOG_DB => ,"SQL_logdb",
-
-    MAP_CONF_FILE => "map_conf.txt",
-    CHAR_CONF_FILE => "char_conf.txt",
-    LOGIN_CONF_FILE => "login_conf.txt",
-    INTER_CONF_FILE => "inter_conf.txt",
-    DESD_CONF_FILE => ".tmp-desd_conf.yml",
-    MIN_PORT => 2000, #below are usually reserved for system
-    MAX_PORT => 65535,
+	SERV_WAN_IP => "Serv_wan_ip",
+	MAP_PORT => "Map_port",
+	CHAR_PORT => "Char_port",
+	LOGIN_PORT => "Login_port",
+	MD5_ENABLE => "enable_MD5",
+	PINCODE_ENABLE => "enable_pincode",
+	SQL_HOST => "SQL_host",
+	SQL_PORT => "SQL_port",
+	SQL_UID => "SQL_userid",
+	SQL_PW => "SQL_userpass",
+	SQL_MAIN_DB => "SQL_maindb",
+	SQL_LOG_DB => ,"SQL_logdb",
+
+	MAP_CONF_FILE => "map_conf.txt",
+	CHAR_CONF_FILE => "char_conf.txt",
+	LOGIN_CONF_FILE => "login_conf.txt",
+	INTER_CONF_FILE => "inter_conf.txt",
+	DESD_CONF_FILE => ".tmp-desd_conf.yml",
+	MIN_PORT => 2000, #below are usually reserved for system
+	MAX_PORT => 65535,
 };
 # setup default options
 my $sDsdFile    = DESD_CONF_FILE;
@@ -53,46 +53,46 @@ GetArgs();
 Main();
 
 sub GetArgs {
-    GetOptions(
-    'f=s' => \$sDsdFile, #give desired conf file
-    'auto=i' => \$sAutoyes,   #Force (auto-yes)
-    'C=i'	=> \$sClean,	 #Clean (like force but remove before adding)
-    'target=s'	=> \$sTarget,	 #Target (which setup to run)
-    'Force=i'	=> \$sForce,	 #Force (bypass verification)
-    'OS=s'	=> \$sOS, #OS (specify the OS you wish to use)
-    'help!' => \$sHelp,
-    ) or $sHelp=1; #display help if invalid option
-    my $sValidTarget = "All|Conf|DB|Inst|Dump";
-    
-	
-    if( $sHelp ) {
+	GetOptions(
+	'f=s' => \$sDsdFile, #give desired conf file
+	'auto=i' => \$sAutoyes,   #Force (auto-yes)
+	'C=i'	=> \$sClean,	 #Clean (like force but remove before adding)
+	'target=s'	=> \$sTarget,	 #Target (which setup to run)
+	'Force=i'	=> \$sForce,	 #Force (bypass verification)
+	'OS=s'	=> \$sOS, #OS (specify the OS you wish to use)
+	'help!' => \$sHelp,
+	) or $sHelp=1; #display help if invalid option
+	my $sValidTarget = "All|Conf|DB|Inst|Dump";
+
+
+	if( $sHelp ) {
 	print "Incorrect option specified. Available options are:\n"
-	    ."\t --f filename => file (specify desiredconf to use)\n"
-	    ."\t --auto => auto-yes to question? \n"
-	    ."\t --C => Clean (remove file, db, user before adding new)\n"
-	    ."\t --target => target (specify which setup to run [$sValidTarget])\n"
-	    ."\t --Force => Force (bypass verification)\n"
-	    ."\t --OS => (specify the OS you wish to use and avoid check)";
+		."\t --f filename => file (specify desiredconf to use)\n"
+		."\t --auto => auto-yes to question? \n"
+		."\t --C => Clean (remove file, db, user before adding new)\n"
+		."\t --target => target (specify which setup to run [$sValidTarget])\n"
+		."\t --Force => Force (bypass verification)\n"
+		."\t --OS => (specify the OS you wish to use and avoid check)";
 	exit;
-    }
-    unless($sTarget =~ /$sValidTarget/i){
+	}
+	unless($sTarget =~ /$sValidTarget/i){
 	print "Incorrect target specified. Available targets are:\n"
-	    ."\t --target => target (specify which setup to run [(default)$sValidTarget])\n";
+		."\t --target => target (specify which setup to run [(default)$sValidTarget])\n";
 	exit;
-    }
-    if($sDsdFile ne DESD_CONF_FILE && !(-e -r $sDsdFile)){
+	}
+	if($sDsdFile ne DESD_CONF_FILE && !(-e -r $sDsdFile)){
 	print "File '$sDsdFile' could not be read or does not exist.\n";
 	exit;
-    }
+	}
 }
 
 sub Main {
-    my($filename, $dir, $suffix) = fileparse($0);
-    chdir $dir; #put ourself like was called in tools
-    print "Running rAthena's configuration tool...\n";
-    #default conf
-    my $pubip = GetPublicIP();
-    my %hDefConf = (    SERV_UID => "s1",
+	my($filename, $dir, $suffix) = fileparse($0);
+	chdir $dir; #put ourself like was called in tools
+	print "Running rAthena's configuration tool...\n";
+	#default conf
+	my $pubip = GetPublicIP();
+	my %hDefConf = (    SERV_UID => "s1",
 			SERV_PW => "p1",
 			SERV_WAN_IP => $pubip || "localhost",
 			LOGIN_PRIV_IP => "localhost",
@@ -109,7 +109,6 @@ sub Main {
 			SQL_MAIN_DB => "ragnarok",
 			SQL_LOG_DB => ,"ragnarok",
 			);
-			
 
 	my $sBasedir = getcwd; #for setupdb
 	if($sTarget =~ /All|Inst/i){ InstallSoft(); }
@@ -121,7 +120,7 @@ sub Main {
 }
 
 
-sub EnableCoredump { 
+sub EnableCoredump {
 	print "\n== Enabling Coredumps ==\n";
 	my $sCurfile = "~/.bashrc";
 	my @lines = ();
@@ -130,7 +129,7 @@ sub EnableCoredump {
 	foreach(<PIPE>){
 		if($_ =~ /ulimit -c unlimited/){
 			$sJump = 1; #already in here nothing to do
-			last; 
+			last;
 		}
 		push(@lines,$_) if /ulimit/;
 	}
@@ -174,7 +173,7 @@ sub EnableCoredump {
 			."Are you sure you want to continue? [y/n] \n";
 		$sJump=2 if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i);
 	}
-    unless($sJump==2){
+	unless($sJump==2){
 		system('sudo su root -c "echo \"echo kernel.core_uses_pid = 1 >> /etc/sysctl.conf\" | sudo bash"');
 		system('sudo su root -c "echo \"echo kernel.core_pattern = /tmp/core-%e-%s-%u-%g-%p-%t >> /etc/sysctl.conf\" | sudo bash"');
 		system('sudo su root -c "echo \"echo fs.suid_dumpable = 1 >> /etc/sysctl.conf\" | sudo bash"');
@@ -203,7 +202,7 @@ sub GetOS {
 	}
 	else {
 		my @aSupportedOS = ("Debian","Ubuntu","Fedora","CentOs","FreeBSD");
-		my $sOSregex = join("|",@aSupportedOS); 
+		my $sOSregex = join("|",@aSupportedOS);
 		until($sOS =~ /$sOSregex/i){
 			print "Please enter your OS [$sOSregex] or enter 'quit' to exit.\n";
 			$sOS = <>; chomp($sOS);
@@ -214,11 +213,11 @@ sub GetOS {
 }
 
 sub InstallSoft {
-    print "\n== Installing Software ==\n";
-    print "NOTE: This auto-install feature is experimental. Package names vary in different distributions and versions, so they may be incorrect.\n";
-    $sOS = GetOS() unless $sOS;
-    if($sOS eq "quit"){ print "Skipping software installation...\n"; return; }
-    elsif($sOS =~ /Ubuntu|Debian/i) { #tested on ubuntu 12.10,13.10
+	print "\n== Installing Software ==\n";
+	print "NOTE: This auto-install feature is experimental. Package names vary in different distributions and versions, so they may be incorrect.\n";
+	$sOS = GetOS() unless $sOS;
+	if($sOS eq "quit"){ print "Skipping software installation...\n"; return; }
+	elsif($sOS =~ /Ubuntu|Debian/i) { #tested on ubuntu 12.10,13.10
 	my @aListSoft = ("gcc","gdb","zlibc","zlib1g-dev","make","git","mysql-client","mysql-server","mysql-common","libmysqlclient-dev","phpmyadmin","libpcre3-dev");
 	print "Going to install: @aListSoft\n";
 	system("sudo apt-get install @aListSoft");
@@ -227,77 +226,77 @@ sub InstallSoft {
 	my @aListSoft = ("gcc","gdb","zlib","zlib-devel","make","git","mariadb-server","mariadb","mariadb-devel","phpmyadmin","pcre-devel");
 #	my @aListSoft = ("gcc","gdb","zlib","zlib-devel","make","git","mysql-server","mysql-devel","phpmyadmin","pcre-devel");
 	system("sudo yum install @aListSoft");
-    }
-    elsif($sOS =~ /FreeBSD/i){ #tested on FreeBSD 9.01
+	}
+	elsif($sOS =~ /FreeBSD/i){ #tested on FreeBSD 9.01
 	system("portsnap fetch extract && portsnap update"); #fetch port lib and extract
 	my @aDevel = ("binutils","git","autoconf","pcre","gmake","gdb");
 	foreach(@aDevel){
-	    system("cd /usr/ports/devel/$_ && make install clean"); #install devels
+		system("cd /usr/ports/devel/$_ && make install clean"); #install devels
 	}
 #	system("cd /usr/ports/lang/gcc46 && make install"); #gcc4.6 use latest ? 4.8 ?
 	system("cd /usr/ports/databases/mysql55-server && make install clean");
 	#other utils ?
 	system("cd /usr/ports/www/wget && make install clean");
 	system("cd /usr/ports/archivers/unrar && make install clean");
-    }
+	}
 }
 
 sub ConfigConf { my ($rhDefConf) = @_;
-    print "\n== Setting Configurations ==\n";
-    my $rhUserConf;
-    while(1) {
+	print "\n== Setting Configurations ==\n";
+	my $rhUserConf;
+	while(1) {
 	$rhUserConf = GetDesiredConf($rhDefConf);
 	print "SetupConf using conf: \n";
 	ShowConfig($rhUserConf);
 	last if($sForce || AutoCheckConf($rhUserConf));
-    }
-    ApplySetupConf($rhUserConf);
+	}
+	ApplySetupConf($rhUserConf);
 }
 
 sub ConfigDB { my ($rhDefConf) = @_;
-    print "\n== Setting Up Databases ==\n";
-    my $rhUserConf;
-    while(1) {
+	print "\n== Setting Up Databases ==\n";
+	my $rhUserConf;
+	while(1) {
 		$rhUserConf = GetDesiredConf($rhDefConf);
 		print "SetupDb using conf: \n";
 		ShowConfig($rhUserConf);
 		last if($sForce || AutoCheckConf($rhUserConf));
-    }
-    ApplySetupDB($rhUserConf);
+	}
+	ApplySetupDB($rhUserConf);
 }
 
 #conf function
 sub ApplySetupConf { my ($rhConfig) = @_;
-    print "\nApplying configurations...\n";
-    my @aTargetfile = (MAP_CONF_FILE,CHAR_CONF_FILE,LOGIN_CONF_FILE,INTER_CONF_FILE);
-    my $sConfDir = "conf";
-    my $sUserConfDir = "import";
-
-    die "'$sConfDir' doesn't seem to exist or couldn't be read/written" unless(-d -r -w "../$sConfDir");
-    chdir "../$sConfDir";
-    print "Saving tmp user-conf.\n";
-    YAML::XS::DumpFile(DESD_CONF_FILE,$rhConfig);
-    unless(-d "$sUserConfDir") {
+	print "\nApplying configurations...\n";
+	my @aTargetfile = (MAP_CONF_FILE,CHAR_CONF_FILE,LOGIN_CONF_FILE,INTER_CONF_FILE);
+	my $sConfDir = "conf";
+	my $sUserConfDir = "import";
+
+	die "'$sConfDir' doesn't seem to exist or couldn't be read/written" unless(-d -r -w "../$sConfDir");
+	chdir "../$sConfDir";
+	print "Saving tmp user-conf.\n";
+	YAML::XS::DumpFile(DESD_CONF_FILE,$rhConfig);
+	unless(-d "$sUserConfDir") {
 	print "Directory 'conf/import' doesn't exist. Create it? [y/n] (will be generated by compilation otherwise) \n";
 	if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) { die "Cannot apply configurations without 'import' folder, exiting...\n"; }
 	mkdir "$sUserConfDir";
-    }
-    chdir $sUserConfDir;
+	}
+	chdir $sUserConfDir;
 
-    if($sClean){ unlink @aTargetfile; } #deleting file before applying conf if clean
-    opendir(DIR, ".") or die $!;
-    my @aDirfile = grep { /\.txt/ && -f "$_"  } readdir(DIR);
-    close DIR;
-    print "Current file in directory '@aDirfile' is target '@aTargetfile'.\n";
+	if($sClean){ unlink @aTargetfile; } #deleting file before applying conf if clean
+	opendir(DIR, ".") or die $!;
+	my @aDirfile = grep { /\.txt/ && -f "$_"  } readdir(DIR);
+	close DIR;
+	print "Current file in directory '@aDirfile' is target '@aTargetfile'.\n";
 
-    foreach my $sCurfile(@aTargetfile) {
+	foreach my $sCurfile(@aTargetfile) {
 	print "Checking if target file '$sCurfile' exists... ";
 	if(-e -r $sCurfile) {
-	    print "Yes. Overwrite it? [y/n] \n";
-	    if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) {
+		print "Yes. Overwrite it? [y/n] \n";
+		if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) {
 		print "Only overwrite option currently supported. File skipped...\n\n";
 		next;
-	    }
+		}
 	}
 	else { print "No.\n" };
 
@@ -306,206 +305,206 @@ sub ApplySetupConf { my ($rhConfig) = @_;
 	elsif($sCurfile eq CHAR_CONF_FILE) { ApplyCharConf($rhConfig,$sCurfile); }
 	elsif($sCurfile eq LOGIN_CONF_FILE) { ApplyLoginConf($rhConfig,$sCurfile); }
 	elsif($sCurfile eq INTER_CONF_FILE) { ApplyInterConf($rhConfig,$sCurfile); }
-    }
+	}
 }
 
 sub ApplyMapConf { my ($rhUserConf,$sCurfile) = @_;
-    open FILE, "> $sCurfile" || die "Couldn't open or create file '$sCurfile'.\n";
-    print FILE "userid: " . $$rhUserConf{SERV_UID}."\n";
-    print FILE "passwd: " . $$rhUserConf{SERV_PW}."\n\n";
-
-    print FILE "map_ip: " . $$rhUserConf{SERV_WAN_IP}."\n";
-    print FILE "map_port: " . $$rhUserConf{MAP_PORT}."\n";    
-    print FILE "char_ip: " . $$rhUserConf{CHAR_PRIV_IP}."\n";
-    print FILE "char_port: " . $$rhUserConf{CHAR_PORT}."\n";
+	open FILE, "> $sCurfile" || die "Couldn't open or create file '$sCurfile'.\n";
+	print FILE "userid: " . $$rhUserConf{SERV_UID}."\n";
+	print FILE "passwd: " . $$rhUserConf{SERV_PW}."\n\n";
+
+	print FILE "map_ip: " . $$rhUserConf{SERV_WAN_IP}."\n";
+	print FILE "map_port: " . $$rhUserConf{MAP_PORT}."\n";
+	print FILE "char_ip: " . $$rhUserConf{CHAR_PRIV_IP}."\n";
+	print FILE "char_port: " . $$rhUserConf{CHAR_PORT}."\n";
 }
 
 sub ApplyCharConf { my ($rhUserConf,$sCurfile) = @_;
-    open FILE, "> $sCurfile" || die "Couldn't open file '$sCurfile'.\n";
-    print FILE "userid: " . $$rhUserConf{SERV_UID}."\n";
-    print FILE "passwd: " . $$rhUserConf{SERV_PW}."\n\n";
-	
-    print FILE "char_ip: " . $$rhUserConf{SERV_WAN_IP}."\n";
-    print FILE "char_port: " . $$rhUserConf{CHAR_PORT}."\n";
-    print FILE "login_ip: " . $$rhUserConf{LOGIN_PRIV_IP}."\n";
-    print FILE "login_port: " . $$rhUserConf{LOGIN_PORT}."\n";
-    
-    print FILE "pincode_enabled: " . $$rhUserConf{PINCODE_ENABLE}."\n";
+	open FILE, "> $sCurfile" || die "Couldn't open file '$sCurfile'.\n";
+	print FILE "userid: " . $$rhUserConf{SERV_UID}."\n";
+	print FILE "passwd: " . $$rhUserConf{SERV_PW}."\n\n";
+
+	print FILE "char_ip: " . $$rhUserConf{SERV_WAN_IP}."\n";
+	print FILE "char_port: " . $$rhUserConf{CHAR_PORT}."\n";
+	print FILE "login_ip: " . $$rhUserConf{LOGIN_PRIV_IP}."\n";
+	print FILE "login_port: " . $$rhUserConf{LOGIN_PORT}."\n";
+
+	print FILE "pincode_enabled: " . $$rhUserConf{PINCODE_ENABLE}."\n";
 }
 
 sub ApplyLoginConf { my ($rhUserConf,$sCurfile) = @_;
-    open FILE, "> $sCurfile" || die "Couldn't open file '$sCurfile'.\n";
-    print FILE "login_port: " . $$rhUserConf{LOGIN_PORT}."\n";
-    print FILE "use_MD5_passwords: " . $$rhUserConf{MD5_ENABLE}."\n";
+	open FILE, "> $sCurfile" || die "Couldn't open file '$sCurfile'.\n";
+	print FILE "login_port: " . $$rhUserConf{LOGIN_PORT}."\n";
+	print FILE "use_MD5_passwords: " . $$rhUserConf{MD5_ENABLE}."\n";
 }
 
 sub ApplyInterConf { my ($rhUserConf,$sCurfile) = @_;
-    open FILE, "> $sCurfile" || die "Couldn't open file '$sCurfile'.\n";
-
-    print FILE "login_server_ip: " . $$rhUserConf{SQL_HOST}."\n";
-    print FILE "login_server_port: " . $$rhUserConf{SQL_PORT}."\n";
-    print FILE "login_server_id: " . $$rhUserConf{SQL_UID}."\n";
-    print FILE "login_server_pw: " . $$rhUserConf{SQL_PW}."\n";
-    print FILE "login_server_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
-
-    print FILE "ipban_db_ip: " . $$rhUserConf{SQL_HOST}."\n";
-    print FILE "ipban_db_port: " . $$rhUserConf{SQL_PORT}."\n";
-    print FILE "ipban_db_id: " . $$rhUserConf{SQL_UID}."\n";
-    print FILE "ipban_db_pw: " . $$rhUserConf{SQL_PW}."\n";
-    print FILE "ipban_db_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
-
-    print FILE "char_server_ip: " . $$rhUserConf{SQL_HOST}."\n";
-    print FILE "char_server_port: " . $$rhUserConf{SQL_PORT}."\n";
-    print FILE "char_server_id: " . $$rhUserConf{SQL_UID}."\n";
-    print FILE "char_server_pw: " . $$rhUserConf{SQL_PW}."\n";
-    print FILE "char_server_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
-
-    print FILE "map_server_ip: " . $$rhUserConf{SQL_HOST}."\n";
-    print FILE "map_server_port: " . $$rhUserConf{SQL_PORT}."\n";
-    print FILE "map_server_id: " . $$rhUserConf{SQL_UID}."\n";
-    print FILE "map_server_pw: " . $$rhUserConf{SQL_PW}."\n";
-    print FILE "map_server_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
-
-    print FILE "log_db_ip: " . $$rhUserConf{SQL_HOST} ."\n";
-    print FILE "log_db_port: " . $$rhUserConf{SQL_PORT}."\n";
-    print FILE "log_db_id: " . $$rhUserConf{SQL_UID}."\n";
-    print FILE "log_db_pw: " . $$rhUserConf{SQL_PW}."\n";
-    print FILE "log_db_db: " . $$rhUserConf{SQL_LOG_DB}."\n\n";
+	open FILE, "> $sCurfile" || die "Couldn't open file '$sCurfile'.\n";
+
+	print FILE "login_server_ip: " . $$rhUserConf{SQL_HOST}."\n";
+	print FILE "login_server_port: " . $$rhUserConf{SQL_PORT}."\n";
+	print FILE "login_server_id: " . $$rhUserConf{SQL_UID}."\n";
+	print FILE "login_server_pw: " . $$rhUserConf{SQL_PW}."\n";
+	print FILE "login_server_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
+
+	print FILE "ipban_db_ip: " . $$rhUserConf{SQL_HOST}."\n";
+	print FILE "ipban_db_port: " . $$rhUserConf{SQL_PORT}."\n";
+	print FILE "ipban_db_id: " . $$rhUserConf{SQL_UID}."\n";
+	print FILE "ipban_db_pw: " . $$rhUserConf{SQL_PW}."\n";
+	print FILE "ipban_db_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
+
+	print FILE "char_server_ip: " . $$rhUserConf{SQL_HOST}."\n";
+	print FILE "char_server_port: " . $$rhUserConf{SQL_PORT}."\n";
+	print FILE "char_server_id: " . $$rhUserConf{SQL_UID}."\n";
+	print FILE "char_server_pw: " . $$rhUserConf{SQL_PW}."\n";
+	print FILE "char_server_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
+
+	print FILE "map_server_ip: " . $$rhUserConf{SQL_HOST}."\n";
+	print FILE "map_server_port: " . $$rhUserConf{SQL_PORT}."\n";
+	print FILE "map_server_id: " . $$rhUserConf{SQL_UID}."\n";
+	print FILE "map_server_pw: " . $$rhUserConf{SQL_PW}."\n";
+	print FILE "map_server_db: " . $$rhUserConf{SQL_MAIN_DB}."\n\n";
+
+	print FILE "log_db_ip: " . $$rhUserConf{SQL_HOST} ."\n";
+	print FILE "log_db_port: " . $$rhUserConf{SQL_PORT}."\n";
+	print FILE "log_db_id: " . $$rhUserConf{SQL_UID}."\n";
+	print FILE "log_db_pw: " . $$rhUserConf{SQL_PW}."\n";
+	print FILE "log_db_db: " . $$rhUserConf{SQL_LOG_DB}."\n\n";
 }
 
 sub AutoCheckConf { my ($rhConfig) = @_;
-    print "\n== Auto-Check Configuration ==\n";
+	print "\n== Auto-Check Configuration ==\n";
 	print "NOTE: You can use option --force=1 to bypass this.\n";
-    foreach my $sKeys (keys %$rhConfig){
+	foreach my $sKeys (keys %$rhConfig){
 	my $sVal = $$rhConfig{$sKeys};
 	if($sKeys =~ /PORT/) { #chek if valid port
-	    if(($sVal<MIN_PORT) && ($sVal>MAX_PORT)) {
+		if(($sVal<MIN_PORT) && ($sVal>MAX_PORT)) {
 		warn "Invalid port specified for $sKeys => $sVal. Port must be in [".MIN_PORT.":".MAX_PORT."].\n";
 		return 0;
-	    }
-	    elsif(!($sKeys =~ /SQL/) && CheckUsedPort($sVal)) { #skip SQL service
+		}
+		elsif(!($sKeys =~ /SQL/) && CheckUsedPort($sVal)) { #skip SQL service
 		warn "Port '$sVal' seems to already be in use by your system.\n";
 		return 0;
-	    }
-	    elsif(CheckDupPort($rhConfig,$sKeys)) {
+		}
+		elsif(CheckDupPort($rhConfig,$sKeys)) {
 		warn "Port '$sVal' seems to already be used by another key in config.\n";
 		return 0;
-	    }
+		}
 	}
 	elsif($sKeys =~ /IP|HOST/){ #chek if ip valid, can we reach it ? trough SYN ACK
-	    my $p = Net::Ping->new("syn");
-	    my $sTest = $p->ping($sVal);
-	    $p->close();
-	    unless($sTest) {
+		my $p = Net::Ping->new("syn");
+		my $sTest = $p->ping($sVal);
+		$p->close();
+		unless($sTest) {
 		print "Invalid IP/Host, ping couldn't reach $sKeys => $sVal.\n";
 		print "(NOTE: ICMP may just be unallowed.)\n";
 		return 0;
-	    }
+		}
 	}
-    }
-    return 1;
+	}
+	return 1;
 }
 
 sub CheckDupPort { my ($rhConfig,$sChkKeys) = @_;
-    my $sChkport = $$rhConfig{$sChkKeys};
-    foreach my $sKeys (keys %$rhConfig){
+	my $sChkport = $$rhConfig{$sChkKeys};
+	foreach my $sKeys (keys %$rhConfig){
 		next if($sKeys eq $sChkKeys); #skip ourself
 		my $sVal = $$rhConfig{$sKeys};
 		return 1 if($sChkport eq $sVal);
-    }
-    return 0;
+	}
+	return 0;
 }
 
 
 
 #Db function
 sub ApplySetupDB { my($rhConfig) = @_;
-    my $sDbH; #db handle
-    my $sHost = $$rhConfig{SQL_HOST};
-    my $sPort = $$rhConfig{SQL_PORT};
-    my $sDsn = "dbi:mysql::$sHost:$sPort"; #don't try to auto connect to db
-    $$rhConfig{"Dsn"} = $sDsn;
-
-    $sDbH = RootCo($rhConfig);
-    CreateDB($sDbH,$rhConfig); #create db if not exist
-    $sDbH = CreateUser($sDbH,$rhConfig); #loged as user now
-    LoadSqlFile($sDbH,$rhConfig); #Load .sql file into db
-    CreateServUser($sDbH,$rhConfig);
-    print "Database setup successful.\n";
+	my $sDbH; #db handle
+	my $sHost = $$rhConfig{SQL_HOST};
+	my $sPort = $$rhConfig{SQL_PORT};
+	my $sDsn = "dbi:mysql::$sHost:$sPort"; #don't try to auto connect to db
+	$$rhConfig{"Dsn"} = $sDsn;
+
+	$sDbH = RootCo($rhConfig);
+	CreateDB($sDbH,$rhConfig); #create db if not exist
+	$sDbH = CreateUser($sDbH,$rhConfig); #loged as user now
+	LoadSqlFile($sDbH,$rhConfig); #Load .sql file into db
+	CreateServUser($sDbH,$rhConfig);
+	print "Database setup successful.\n";
 }
 
 
 
 sub CreateDB { my($sDbH,$rhConfig) = @_;
-    print "\n== Creating Databases ==\n";
-    my $sDBn = $$rhConfig{SQL_MAIN_DB};
-    my $sLogDBn = $$rhConfig{SQL_LOG_DB};
-    my @aQuery = ("create database IF NOT EXISTS $sDBn;","create database IF NOT EXISTS $sLogDBn;");
-    if($sClean){ #deleting database if clean
+	print "\n== Creating Databases ==\n";
+	my $sDBn = $$rhConfig{SQL_MAIN_DB};
+	my $sLogDBn = $$rhConfig{SQL_LOG_DB};
+	my @aQuery = ("create database IF NOT EXISTS $sDBn;","create database IF NOT EXISTS $sLogDBn;");
+	if($sClean){ #deleting database if clean
 	unshift(@aQuery,"drop database IF EXISTS $sDBn;");
 	unshift(@aQuery,"drop database IF EXISTS $sLogDBn;");
-    }
-    else {
+	}
+	else {
 	my $sRes = $sDbH->selectcol_arrayref('show databases');
 	foreach my $db (@$sRes){ #relevant later for import
-	    if($db eq "$sDBn") { ValidateDBMerge($db); } #may exit here
-	    elsif ($db eq "$sLogDBn") { ValidateDBMerge($db); } #may exit here
+		if($db eq "$sDBn") { ValidateDBMerge($db); } #may exit here
+		elsif ($db eq "$sLogDBn") { ValidateDBMerge($db); } #may exit here
 	}
-    }
-    ExeQuery($sDbH,@aQuery);
+	}
+	ExeQuery($sDbH,@aQuery);
 }
 
 sub ValidateDBMerge { my($sDBn) = @_;
-    warn "Database '$sDBn' seems to already exist.\n";
-    warn "Do you wish to continue loading data from the existing database? [y/n] \n";
-    if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) {
+	warn "Database '$sDBn' seems to already exist.\n";
+	warn "Do you wish to continue loading data from the existing database? [y/n] \n";
+	if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) {
 	print "Exiting setup, please try again with another dbname or manually...\n";
 	exit;
-    }
+	}
 }
 
 sub CreateUser { my($sDbH,$rhConfig) = @_;
-    print "\n== Creating User ==\n";
-    my $sDsn = $$rhConfig{"Dsn"};
-    print "My dsn = $sDsn \n";
-    my $sHost = $$rhConfig{SQL_HOST};
-    my $sPw = $$rhConfig{SQL_PW};
-    my $sUser = $$rhConfig{SQL_UID};
-    my $sDBn = $$rhConfig{SQL_MAIN_DB};
-    my $sLogDBn = $$rhConfig{SQL_LOG_DB};
-
-    my @aQuery= ("GRANT ALL PRIVILEGES ON $sDBn.* TO $sUser\@'$sHost' IDENTIFIED BY '$sPw' WITH GRANT OPTION", #maindb
-		 "GRANT ALL PRIVILEGES ON $sLogDBn.* TO $sUser\@'$sHost' IDENTIFIED BY '$sPw' WITH GRANT OPTION"); #logdb
-    my $sUserDbh = DBI->connect($sDsn, $sUser, $sPw,  {"PrintError" => 0}); #try connect with user
-
-    if($sUserDbh && !$sClean) {
+	print "\n== Creating User ==\n";
+	my $sDsn = $$rhConfig{"Dsn"};
+	print "My dsn = $sDsn \n";
+	my $sHost = $$rhConfig{SQL_HOST};
+	my $sPw = $$rhConfig{SQL_PW};
+	my $sUser = $$rhConfig{SQL_UID};
+	my $sDBn = $$rhConfig{SQL_MAIN_DB};
+	my $sLogDBn = $$rhConfig{SQL_LOG_DB};
+
+	my @aQuery= ("GRANT ALL PRIVILEGES ON $sDBn.* TO $sUser\@'$sHost' IDENTIFIED BY '$sPw' WITH GRANT OPTION", #maindb
+		"GRANT ALL PRIVILEGES ON $sLogDBn.* TO $sUser\@'$sHost' IDENTIFIED BY '$sPw' WITH GRANT OPTION"); #logdb
+	my $sUserDbh = DBI->connect($sDsn, $sUser, $sPw,  {"PrintError" => 0}); #try connect with user
+
+	if($sUserDbh && !$sClean) {
 	print "User '$sUser' seems to already exist, skipping creation...\n"
-	    ."(Please check if you have correct privileges set for database '$sDBn'.)\n";
-    }
-    else { #create user only if not exist (or mode clean)
+		."(Please check if you have correct privileges set for database '$sDBn'.)\n";
+	}
+	else { #create user only if not exist (or mode clean)
 	if($sClean && $sUser ne "root"){ unshift(@aQuery,"DELETE FROM mysql.user WHERE User = '$sUser';"); }
 	print "Creating user $sUser for databases '$sDBn' and '$sLogDBn' on '$sHost'.\n";
 	ExeQuery($sDbH,@aQuery);
 	$sUserDbh = DBI->connect($sDsn, $sUser, $sPw);
-    }
-    return $sUserDbh; #drop old co and connect with user now
+	}
+	return $sUserDbh; #drop old co and connect with user now
 }
 
 sub LoadSqlFile { my($sDbH,$rhConfig) = @_;
-    print "\n== Loading SQL Files ==\n";
-    my $sDBn = $$rhConfig{SQL_MAIN_DB};
-    my $sLogDBn = $$rhConfig{SQL_LOG_DB};
+	print "\n== Loading SQL Files ==\n";
+	my $sDBn = $$rhConfig{SQL_MAIN_DB};
+	my $sLogDBn = $$rhConfig{SQL_LOG_DB};
 
-    my $sSqldir = "sql-files";
-    my @aMainFiles = ("main.sql"); #add other file to load for main db here
-    my @aLogFiles = ("logs.sql"); #add other file to load for log db here
+	my $sSqldir = "sql-files";
+	my @aMainFiles = ("main.sql"); #add other file to load for main db here
+	my @aLogFiles = ("logs.sql"); #add other file to load for log db here
 
-    die "$sSqldir doesn't seem to exist or couldn't be read." unless(-d -r "../$sSqldir");
-    chdir "../$sSqldir";
-    print "Checking if target files exist:\n\tMain: [@aMainFiles]\n\tLog: [@aLogFiles]\n";
+	die "$sSqldir doesn't seem to exist or couldn't be read." unless(-d -r "../$sSqldir");
+	chdir "../$sSqldir";
+	print "Checking if target files exist:\n\tMain: [@aMainFiles]\n\tLog: [@aLogFiles]\n";
 
-    CheckAndLoadSQL(\@aMainFiles,$rhConfig,$sDBn);
-    CheckAndLoadSQL(\@aLogFiles,$rhConfig,$sLogDBn);
+	CheckAndLoadSQL(\@aMainFiles,$rhConfig,$sDBn);
+	CheckAndLoadSQL(\@aLogFiles,$rhConfig,$sLogDBn);
 
 #    my $raMainQuerys = CheckAndAddQuery(\@aMainFiles,$rhConfig);
 #    my $raLogQuerys = CheckAndAddQuery(\@aLogFiles,$rhConfig);
@@ -531,43 +530,43 @@ sub LoadSqlFile { my($sDbH,$rhConfig) = @_;
 #}
 
 sub CreateServUser { my($sDbH,$rhConfig) = @_;
-    my $sUid = $$rhConfig{SERV_UID};
-    my $sUpw = $$rhConfig{SERV_PW};
-    my $sMD5 = $$rhConfig{MD5_ENABLE};
-    my $sDBn = $$rhConfig{SQL_MAIN_DB};
-    my @aQuery = ("use $sDBn;","DELETE FROM login WHERE sex='S';");
-    if($sMD5){ push(@aQuery,"INSERT INTO login(account_id, userid, user_pass, sex) values(1,'$sUid',MD5('$sUpw'),'S');"); }
-    else { push(@aQuery,"INSERT INTO login(account_id, userid, user_pass, sex) values(1,'$sUid','$sUpw','S');"); }
-    ExeQuery($sDbH,@aQuery);
+	my $sUid = $$rhConfig{SERV_UID};
+	my $sUpw = $$rhConfig{SERV_PW};
+	my $sMD5 = $$rhConfig{MD5_ENABLE};
+	my $sDBn = $$rhConfig{SQL_MAIN_DB};
+	my @aQuery = ("use $sDBn;","DELETE FROM login WHERE sex='S';");
+	if($sMD5){ push(@aQuery,"INSERT INTO login(account_id, userid, user_pass, sex) values(1,'$sUid',MD5('$sUpw'),'S');"); }
+	else { push(@aQuery,"INSERT INTO login(account_id, userid, user_pass, sex) values(1,'$sUid','$sUpw','S');"); }
+	ExeQuery($sDbH,@aQuery);
 }
 
 sub GetDesiredConf { my ($rhDefConf) = @_;
-    print "Please enter desired configuration.\n";
-    my $rhUserConf;
-    my $sDesdConfFile = $sDsdFile;
-    #if default search in conf otherwise get specified name with cwd
-    if($sDsdFile eq DESD_CONF_FILE) { $sDesdConfFile = "../conf/".$sDsdFile; }
-
-    print "Checking if there is a DesiredConf file...\n";
-    if(-e -r $sDesdConfFile) {
+	print "Please enter desired configuration.\n";
+	my $rhUserConf;
+	my $sDesdConfFile = $sDsdFile;
+	#if default search in conf otherwise get specified name with cwd
+	if($sDsdFile eq DESD_CONF_FILE) { $sDesdConfFile = "../conf/".$sDsdFile; }
+
+	print "Checking if there is a DesiredConf file...\n";
+	if(-e -r $sDesdConfFile) {
 	print "Found DesiredConf.\n";
 	$rhUserConf = YAML::XS::LoadFile($sDesdConfFile);
 	if(!($rhUserConf)){
-	    print "DesiredConf is invalid or empty. Please check the file, and relaunch setup or enter Config.\n";
-	    $rhUserConf=GetValidateConf($rhDefConf);
+		print "DesiredConf is invalid or empty. Please check the file, and relaunch setup or enter Config.\n";
+		$rhUserConf=GetValidateConf($rhDefConf);
 	}
 	else {
-	    ShowConfig($rhUserConf);
-	    print "Would you like to apply these settings? [y/n] ";
-	    if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) {  #no take user entry
+		ShowConfig($rhUserConf);
+		print "Would you like to apply these settings? [y/n] ";
+		if(GetValidAnwser("y|o|n",$sAutoyes) =~ /n/i) {  #no take user entry
 		print "DesiredConf not applied. Please enter config.\n";
 		$rhUserConf=GetValidateConf($rhDefConf);
-	    }
+		}
+	}
 	}
-    }
-    else { #no files take user entry
+	else { #no files take user entry
 	print "No DesiredConf found. Please enter config.\n";
 	$rhUserConf=GetValidateConf($rhDefConf);
-    }
-    return $rhUserConf;
+	}
+	return $rhUserConf;
 }

+ 54 - 54
tools/convert_emotions.py

@@ -113,13 +113,13 @@ emotion_dict_old = collections.OrderedDict([
 ])
 """
 def parse_emotion_dict(filepath):
-    ret_list = []
-    with fileinput.FileInput(filepath) as fiFile:
-        for line in fiFile:
-            found = re.search('"(E_[A-Z_0-9]+)"\s*,\s*(ET_[A-Z_0-9]+)\s*', line)
-            if found:
-                ret_list.append((found.group(1), found.group(2)))
-    return ret_list
+	ret_list = []
+	with fileinput.FileInput(filepath) as fiFile:
+		for line in fiFile:
+			found = re.search('"(E_[A-Z_0-9]+)"\s*,\s*(ET_[A-Z_0-9]+)\s*', line)
+			if found:
+				ret_list.append((found.group(1), found.group(2)))
+	return ret_list
 
 emotion_dict = collections.OrderedDict(parse_emotion_dict(parse_dict_file))
 
@@ -128,59 +128,59 @@ pattern_oldconst = re.compile(r'\b(' + '|'.join(emotion_dict.keys()) + r')\b', r
 pattern_value = re.compile(r'\b(' + '|'.join(["emotion\s+%d+"%i for i in range(len(emotion_array))]) + r')\b', re.IGNORECASE)
 
 def revert_to_backup(filename):
-   os.rename(filename+BACKUP_EXT, filename)
-   
+	os.rename(filename+BACKUP_EXT, filename)
+
 def apply_substitutions(new_line, is_script):
-    remove_backup = True # only keep backup if the original file changed
-    rpl_cnt = 0
-    # E_GASP -> ET_SURPRISE
-    new_line, rpl_cnt = pattern_oldconst.subn(lambda x: emotion_dict[x.group().upper()], new_line)
-    remove_backup = False if rpl_cnt > 0 else remove_backup
-    if is_script: # script only replacements
-        # 0 -> ET_SURPRISE
-        new_line, rpl_cnt = pattern_value.subn(lambda x: 'emotion '+emotion_array[int(x.group().split()[-1])], new_line)
-        remove_backup = False if rpl_cnt > 0 else remove_backup
-        # emotion e,0,"Record player#e152a01"; -> emotion e, getnpcid(0,"Record player#e152a01");
-        new_line, rpl_cnt = re.subn(r"emotion\s+([^,]+)\s*,\s*0\s*,\s*([^;]+);",
-                           "emotion \g<1>, getnpcid(0, \g<2>);", new_line)
-        remove_backup = False if rpl_cnt > 0 else remove_backup
-        # emotion e,1; -> emotion e, playerattached();
-        new_line, rpl_cnt = re.subn(r"emotion\s+([^,]+)\s*,\s*1\s*;",
-                           "emotion \g<1>, playerattached();", new_line)
-        remove_backup = False if rpl_cnt > 0 else remove_backup
-        # unitemote <id>,<emotion>; -> emotion <emotion>, <id>;
-        new_line, rpl_cnt = re.subn(r"unitemote\s+([^,]+)\s*,\s*([^,;]+)\s*;",
-                           "emotion \g<2>, \g<1>;", new_line)
-        remove_backup = False if rpl_cnt > 0 else remove_backup
+	remove_backup = True # only keep backup if the original file changed
+	rpl_cnt = 0
+	# E_GASP -> ET_SURPRISE
+	new_line, rpl_cnt = pattern_oldconst.subn(lambda x: emotion_dict[x.group().upper()], new_line)
+	remove_backup = False if rpl_cnt > 0 else remove_backup
+	if is_script: # script only replacements
+		# 0 -> ET_SURPRISE
+		new_line, rpl_cnt = pattern_value.subn(lambda x: 'emotion '+emotion_array[int(x.group().split()[-1])], new_line)
+		remove_backup = False if rpl_cnt > 0 else remove_backup
+		# emotion e,0,"Record player#e152a01"; -> emotion e, getnpcid(0,"Record player#e152a01");
+		new_line, rpl_cnt = re.subn(r"emotion\s+([^,]+)\s*,\s*0\s*,\s*([^;]+);",
+						"emotion \g<1>, getnpcid(0, \g<2>);", new_line)
+		remove_backup = False if rpl_cnt > 0 else remove_backup
+		# emotion e,1; -> emotion e, playerattached();
+		new_line, rpl_cnt = re.subn(r"emotion\s+([^,]+)\s*,\s*1\s*;",
+						"emotion \g<1>, playerattached();", new_line)
+		remove_backup = False if rpl_cnt > 0 else remove_backup
+		# unitemote <id>,<emotion>; -> emotion <emotion>, <id>;
+		new_line, rpl_cnt = re.subn(r"unitemote\s+([^,]+)\s*,\s*([^,;]+)\s*;",
+						"emotion \g<2>, \g<1>;", new_line)
+		remove_backup = False if rpl_cnt > 0 else remove_backup
 
-    return new_line, remove_backup
+	return new_line, remove_backup
 
 def replace_emoticons_in_file(filename):
-    is_script = True if any([filename.endswith(script_ext) for script_ext in script_file_extensions]) else False
-    remove_backup = True
-    with fileinput.FileInput(filename, inplace=True, backup=BACKUP_EXT) as fiFile:
-        try:
-            for line in fiFile:
-                new_line, rm_backup = apply_substitutions(line, is_script)
-                if not rm_backup:
-                    remove_backup = False
-                print(new_line, end='')
-            if remove_backup:
-                os.remove(filename+BACKUP_EXT)
-        except UnicodeDecodeError:
-            # Encoding error, reapply the backup
-            revert_to_backup(filename)
+	is_script = True if any([filename.endswith(script_ext) for script_ext in script_file_extensions]) else False
+	remove_backup = True
+	with fileinput.FileInput(filename, inplace=True, backup=BACKUP_EXT) as fiFile:
+		try:
+			for line in fiFile:
+				new_line, rm_backup = apply_substitutions(line, is_script)
+				if not rm_backup:
+					remove_backup = False
+				print(new_line, end='')
+			if remove_backup:
+				os.remove(filename+BACKUP_EXT)
+		except UnicodeDecodeError:
+			# Encoding error, reapply the backup
+			revert_to_backup(filename)
 
 
 fileiter = (os.path.join(root, f)
-    for conv_folder in convert_folders 
-    for root, _, files in os.walk(conv_folder)
-    for f in files
-    if any([f.endswith(wl) for wl in wl_file_extensions])
-    if not any([bl in f for bl in bl_files])
-    )
+	for conv_folder in convert_folders
+	for root, _, files in os.walk(conv_folder)
+	for f in files
+	if any([f.endswith(wl) for wl in wl_file_extensions])
+	if not any([bl in f for bl in bl_files])
+	)
 
 for f in fileiter:
-    print("Updating file", f)
-    replace_emoticons_in_file(f)
-    
+	print("Updating file", f)
+	replace_emoticons_in_file(f)
+

+ 7 - 7
tools/convert_monstermode.pl

@@ -1,7 +1,7 @@
 #!/usr/bin/perl
 # rAthena Monster Mode Converter
 # Upgrades monster's mode to the new structure.
-# 
+#
 
 use strict;
 use warnings;
@@ -102,15 +102,15 @@ sub Main {
 			next;
 		}
 		unless(open FHOUT,">$sFileouttmp"){
-		   print "ERROR: Can't write or locate $aFileout[$sI].\n";
-		   next;
+			print "ERROR: Can't write or locate $aFileout[$sI].\n";
+			next;
 		}
 		$sI++;
 		while (<FHIN>){
 			if( $_ =~ /^\s*$/) {  #ignore empty line
-				print FHOUT $_; 
-				next;  
-			} 
+				print FHOUT $_;
+				next;
+			}
 			my @champ = split(",",$_);
 			my $sDoconvertion=0; #should this comment be converted
 			if( $_ =~ /^\/\// ) { # // line
@@ -121,7 +121,7 @@ sub Main {
 				}
 				if($sDoconvertion==0) {
 					print FHOUT $_;
-					next; 
+					next;
 				}
 			}
 			if(scalar(@champ>0)){

+ 2 - 2
tools/convert_sql.pl

@@ -85,7 +85,7 @@ sub ConvertFile { my($sFilein,$sFileout,$sType)=@_;
 	print "Starting ConvertFile with: \n\t filein=$sFilein \n\t fileout=$sFileout \n";
 	open FHIN,"$sFilein" or die "ERROR: Can't read or locate $sFilein.\n";
 	open $sFHout,">$sFileout" or die "ERROR: Can't write $sFileout.\n";
-	
+
 	printf $sFHout ("%s\n",$create_table);
 	while(my $ligne=<FHIN>) {
 		my $sWasCom = 0;
@@ -176,7 +176,7 @@ sub escape { my ($str,$sregex,$sreplace) = @_;
 
 sub BuildDataForType{ my($sTarget,$sType) = @_;
 	print "Starting BuildDataForType with: \n\t Target=$sTarget, Type=$sType \n";
-	
+
 	if($sType =~ /mob_skill/i) { #Same format for Pre-Renewal and Renewal.
 		$db = $sTable;
 		if($sTarget =~ /Pre/i){

+ 5 - 7
tools/runserver.bat

@@ -27,8 +27,6 @@ if "%target%" == "status" (
  call :Watch
 ) else if "%target%" == "stop" (
  call :Stop
-) else if "%target%" == "stop" (
- call :Stop
 ) else if "%target%" == "start" (
  call :Start
 )
@@ -69,7 +67,7 @@ call :getCharStatus
 call :getWebStatus
 call :getMapStatus
 
-if "%login_running%" == "false" ( echo "login_serv is not running" 
+if "%login_running%" == "false" ( echo "login_serv is not running"
 ) else echo "login_serv is running pid=%LoginServPID%"
 if "%char_running%" == "false" ( echo "char_serv is not running"
 ) else echo "char_serv is running pid=%CharServPID%"
@@ -111,13 +109,13 @@ REM start sub targets
 :startLogin
 call :getLoginStatus
 if "%login_running%" == "false" ( start cmd /k logserv.bat %restart_mode%
-) else echo "Login serv is already running pid=%LoginServPID%" 
+) else echo "Login serv is already running pid=%LoginServPID%"
 goto :EOF
 
 :startChar
 call :getCharStatus
 if "%char_running%" == "false" ( start cmd /k charserv.bat %restart_mode%
-) else echo "Char serv is already running, pid=%CharServPID%" 
+) else echo "Char serv is already running, pid=%CharServPID%"
 goto :EOF
 
 :startWeb
@@ -129,8 +127,8 @@ goto :EOF
 :startMap
 call :getMapStatus
 if "%map_running%" == "false" ( start cmd /k mapserv.bat %restart_mode%
-) else echo "Map serv is already running, pid=%MapServPID%" 
-goto :EOF  
+) else echo "Map serv is already running, pid=%MapServPID%"
+goto :EOF
 
 REM status sub targets
 

+ 1 - 1
tools/stackdump

@@ -57,7 +57,7 @@ fi
 # Finally dump the backtrace
 # If number is given, Sig-plugin format. otherwise, standard stackdump format
 if [ $# -gt 2 ]; then
-	awk '$2 ~ /[0-9a-eA-E]\]$/{print $2}' $STACK | tr -d \[\] | addr2line -f -e $SERVER 
+	awk '$2 ~ /[0-9a-eA-E]\]$/{print $2}' $STACK | tr -d \[\] | addr2line -f -e $SERVER
 else
 	awk '/^[0-9]/{print $2}' $STACK | addr2line -f -e $SERVER
 fi

+ 27 - 27
tools/update.pl

@@ -51,7 +51,7 @@ sub GetArgs {
 	'target=s'	=> \$sTarget,	 #Target (which setup to run)
 	'help!' => \$sHelp,
 	) or $sHelp=1; #display help if invalid option
-	
+
 	if( $sHelp ) {
 	print "Incorrect option specified. Available options:\n"
 	    ."\t --target => target (specify which check to ignore [$sValidTarget])\n";
@@ -59,7 +59,7 @@ sub GetArgs {
 	}
 	if(!$sTarget || !($sTarget =~ /$sValidTarget/i)){
 		print "Incorrect target specified. Available targets:\n"
-			."\t --target => target (specify which check to ignore [(default)$sValidTarget])\n 
+			."\t --target => target (specify which check to ignore [(default)$sValidTarget])\n
 			(NOTE: restart is compiling dependent.)\n";
 		exit;
     }
@@ -68,7 +68,7 @@ sub GetArgs {
 sub Main {
 	my $sCurdir = getcwd;
 	chdir "..";
-	
+
 	UpdateSQL($sCurdir,1,\%hFileState);
 	if($sTarget =~ "All|Upd") { GitUpdate($sCurdir); }
 	if($sTarget =~ "All|DB") { UpdateSQL($sCurdir,0,\%hFileState); }
@@ -77,8 +77,8 @@ sub Main {
 
 sub GetSqlFileInDir { my($sDir) = @_;
 	opendir (DIR, $sDir) or die $!;
-	my @aFiles 
-		= grep { 
+	my @aFiles
+		= grep {
 		/^(?!\.)/      # not begins with a period
 		&& /\.sql$/      # finish by .sql
 		&& -f "$sDir/$_"   # and is a file
@@ -98,7 +98,7 @@ sub UpdateSQL  { my($sBaseDir,$sInit,$rhFileState) = @_;
 		print "Reading file status...\n";
 		$rhFileState = YAML::XS::LoadFile("sql-files/".STATE_FILE);
 	}
-	
+
 	if($sTarget =~ "All|MapDB") {
 			chdir "sql-files";
 			print "Getting Map SQL Db file...\n";
@@ -119,17 +119,17 @@ sub UpdateSQL  { my($sBaseDir,$sInit,$rhFileState) = @_;
 			}
 			chdir "..";
 	}
-	
+
 	chdir "sql-files/upgrades";
 	my $raFiles = GetSqlFileInDir("./");
-	
+
 	foreach my $sFile (@$raFiles){
 		#print "Cur file = $sFile \n";
 		if($sInit==1){
 			if(exists $$rhFileState{$sFile} && $$rhFileState{$sFile}{"status"} == ST_DONE ){
 				next;
 			}
-			
+
 			if( $sFile =~ /_opt_/){
 				$$rhFileState{$sFile}{"status"} = ST_SK;
 			} else {
@@ -144,42 +144,42 @@ sub UpdateSQL  { my($sBaseDir,$sInit,$rhFileState) = @_;
 		#		#if it's done or skipped don't do it, if it's old but updated do it
 				next if ( $sT eq ST_OLD or $sT eq ST_DONE or $sLastMode == (stat ($sFile))[9] );
 			}
-			
-			if( $sFile =~ /_log.sql$/) { 
+
+			if( $sFile =~ /_log.sql$/) {
 				print "Found log file '$sFile'.\n";
 				push(@aLogDBFiles,$sFile);
 			}
-			else { 
+			else {
 				print "Found char file '$sFile'.\n";
 				push(@aCharDBFiles,$sFile);
 			}
 			$$rhFileState{$sFile}{"status"} = "done"; #  the query will be applied so mark it so
-			
+
 		# This part is for distributed DB, not supported yet
 		# proposed nomenclature [lighta] : update_date_{opt_}(map|chr|acc|log).sql
 		# (e.g : update_20141218_opt_map.sql or update_20141218_acc.sql
-		
-		#	if( $sFile =~ /_map.sql$/) { 
+
+		#	if( $sFile =~ /_map.sql$/) {
 		#		print "Found log file = $sFile \n";
 		#		push(@aMapDBFiles,$sFile);
-		#		
+		#
 		#	}
-		#	elsif( $sFile =~ /_acc.sql$/) { 
+		#	elsif( $sFile =~ /_acc.sql$/) {
 		#		print "Found log file = $sFile \n";
 		#		push(@aLoginDBFiles,$sFile);
-		#		
+		#
 		#	}
-		#	elsif( $sFile =~ /_chr.sql$/) { 
+		#	elsif( $sFile =~ /_chr.sql$/) {
 		#		print "Found log file = $sFile \n";
 		#		push(@aCharDBFiles,$sFile);
-		#		
+		#
 		#	}
 		}
 	}
 	if($sInit==0){ #apply update
 		return;
-		if( scalar(@aCharDBFiles)==0 and  scalar(@aLogDBFiles)==0 
-			and  scalar(@aMapDBFiles)==0 and  scalar(@aLoginDBFiles)==0
+		if( scalar(@aCharDBFiles)==0 and scalar(@aLogDBFiles)==0 
+			and  scalar(@aMapDBFiles)==0 and scalar(@aLoginDBFiles)==0
 		){
 			print "No SQL update to perform.\n";
 		}
@@ -194,7 +194,7 @@ sub UpdateSQL  { my($sBaseDir,$sInit,$rhFileState) = @_;
 			else {
 				$rhUserConf=\%hDefConf; #we assume it's set correctly
 			}
-			
+
 			CheckAndLoadSQL(\@aMapDBFiles,$rhUserConf,$$rhUserConf{SQL_MAP_DB});
 			CheckAndLoadSQL(\@aCharDBFiles,$rhUserConf,$$rhUserConf{SQL_MAIN_DB});
 			#CheckAndLoadSQL(\@aLoginDBFiles,$rhUserConf,$$rhUserConf{SQL_ACC_DB});
@@ -228,7 +228,7 @@ sub GitUpdate { my($sBaseDir) = @_;
 	my $sGit = Git::Repository->new(
 		work_tree => "$sBaseDir/..",
 	);
-	
+
 	my $sIsOrigin = CheckRemote($sGit);
 	if($sIsOrigin==0){
 		print "Saving current working tree...\n";
@@ -252,10 +252,10 @@ sub GitUpdate { my($sBaseDir) = @_;
 sub CheckRemote { my($sGit) = @_;
 	my $sRaOrigin=0;
 	my $sRaUpstream=0;
-	
+
 	print "Checking remotes\n";
-	my @aRemotes = $sGit->run("remote" => "-v");	
-	
+	my @aRemotes = $sGit->run("remote" => "-v");
+
 	#print "My Remotes are\n";
 	foreach my $sCurRem (@aRemotes){
 		my @aCol = split(' ',$sCurRem);