 04cfe17b2b
			
		
	
	
		04cfe17b2b
		
			
		
	
	
	
	
		
			
			* Combines item_avail, item_buyingstore, item_delay, item_flag, item_nouse, item_stack, and item_trade databases into one. * General cleanups and optimizations. * Includes CSV2YAML conversion tool. * Includes YAML2SQL conversion tool. * Adjusts dummy_item from being created by malloc and now creates it by make_shared. * Item combos are now stored as a STL. Thanks to @Lemongrass3110, @Atemo, and @cydh! Co-authored-by: Lemongrass3110 <lemongrass@kstp.at>
		
			
				
	
	
		
			298 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			298 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/perl
 | |
| 
 | |
| # Mob Database:
 | |
| #     --i=../db/pre-re/mob_db.txt --o=../sql-files/mob_db.sql --t=pre --m=mob --table=mob_db
 | |
| #     --i=../db/re/mob_db.txt --o=../sql-files/mob_db_re.sql --t=re --m=mob --table=mob_db_re
 | |
| #
 | |
| # Mob Skill Database:
 | |
| #     --i=../db/pre-re/mob_skill_db.txt --o=../sql-files/mob_skill_db.sql --t=pre --m=mob_skill --table=mob_skill_db
 | |
| #     --i=../db/re/mob_skill_db.txt --o=../sql-files/mob_skill_db_re.sql --t=re --m=mob_skill --table=mob_skill_db_re
 | |
| #
 | |
| # List of options:
 | |
| #   convert_sql.pl --help
 | |
| 
 | |
| use strict;
 | |
| use warnings;
 | |
| use Getopt::Long;
 | |
| use File::Basename;
 | |
| 
 | |
| my $sFilein = "";
 | |
| my $sFileout = "";
 | |
| my $sTarget = "";
 | |
| my $sType = "";
 | |
| my $sHelp = 0;
 | |
| my $sTable = "";
 | |
| 
 | |
| my $db;
 | |
| my $nb_columns;
 | |
| my @str_col = (); #Use basic escape.
 | |
| my @str_col2 = (); #Use second escape (currently for scripts).
 | |
| my $line_format;
 | |
| my $create_table;
 | |
| my @defaults = ();
 | |
| 
 | |
| Main();
 | |
| 
 | |
| sub GetArgs {
 | |
| 	GetOptions(
 | |
| 	'i=s' => \$sFilein, #Output file name.
 | |
| 	'o=s' => \$sFileout, #Input file name.
 | |
| 	't=s' => \$sTarget, #Renewal setting: pre-re, re.
 | |
| 	'm=s' => \$sType, #Database: mob, mob_skill.
 | |
| 	'table=s' => \$sTable, #Table name.
 | |
| 	'help!' => \$sHelp,
 | |
| 	) or $sHelp=1; #Display help if invalid options are supplied.
 | |
| 	my $sValidTarget = "re|pre";
 | |
| 	my $sValidType = "mob|mob_skill";
 | |
| 
 | |
| 	if( $sHelp ) {
 | |
| 		print "Incorrect option specified. Available options:\n"
 | |
| 			."\t --o=filename => Output file name. \n"
 | |
| 			."\t --i=filename => Input file name. \n"
 | |
| 			."\t --table=tablename => Table name to create. \n"
 | |
| 			."\t --t=target => Specify target ([$sValidTarget]). \n"
 | |
| 			."\t --m=type => Specify type ([$sValidType]). \n";
 | |
| 		exit;
 | |
| 	}
 | |
| 	unless($sFilein or $sFileout){
 | |
| 		print "ERROR: Filename_in and Filename_out are required to continue.\n";
 | |
| 		exit;
 | |
| 	}
 | |
| 	unless($sTarget =~ /$sValidTarget/i){
 | |
| 		print "ERROR: Incorrect target specified. Available targets:\n"
 | |
| 			."\t --t => Target (specify which kind of table_struct to build [$sValidTarget]).\n";
 | |
| 		exit;
 | |
| 	}
 | |
| 	unless($sType =~ /$sValidType/i){
 | |
| 		print "ERROR: Incorrect type specified. Available types:\n"
 | |
| 			."\t --m => Type (specify which data entry to use [$sValidType]).\n";
 | |
| 		exit;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| sub Main {
 | |
| 	GetArgs();
 | |
| 	my($filename, $dir, $suffix) = fileparse($0);
 | |
| 	chdir $dir; #put ourself like was called in tool folder
 | |
| 	BuildDataForType($sTarget,$sType);
 | |
| 	ConvertFile($sFilein,$sFileout,$sType);
 | |
| 	print "Conversion ended.\n";
 | |
| }
 | |
| 
 | |
| sub ConvertFile { my($sFilein,$sFileout,$sType)=@_;
 | |
| 	my $sFHout;
 | |
| 	my %hAEgisName = ();
 | |
| 	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;
 | |
| 		if ($ligne =~ /^\s*$/ ) {
 | |
| 				print $sFHout "\n";
 | |
| 				next;
 | |
| 		}
 | |
| 		if ($ligne =~ /[^\r\n]+/) {
 | |
| 			$ligne = $&;
 | |
| 			if ($ligne =~ /^\/\//) {
 | |
| 				printf $sFHout ("#");
 | |
| 				$ligne = substr($ligne, 2);
 | |
| 				$sWasCom = 1;
 | |
| 			}
 | |
| 			my @champ = ();
 | |
| 			if ($sType =~ /mob_skill/i ) {
 | |
| 				if ($ligne =~ $line_format ) { @champ = ($1,$2,$3,$4,$5,$6,$7,$8,$9,$10,$11,$12,$13,$14,$15,$16,$17,$18,$19); }
 | |
| 			}
 | |
| 			elsif ($sType =~ /mob/i) { @champ = split(",",$ligne); }
 | |
| 			if ($#champ != $nb_columns - 1) { #Can't parse, it's a real comment.
 | |
| 				printf $sFHout ("%s\n", $ligne);
 | |
| 			} else {
 | |
| 				printf $sFHout ("REPLACE INTO `%s` VALUES (", $db);
 | |
| 				for (my $i=0; $i<$#champ; $i++) {
 | |
| 					printField($sFHout,$champ[$i],",",$i);
 | |
| 				}
 | |
| 				printField($sFHout,$champ[$#champ],");\n",$#champ);
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	print $sFHout "\n";
 | |
| }
 | |
| 
 | |
| sub printField { my ($sFHout,$str, $suffix, $idCol) = @_;
 | |
| 	# Remove first { and last } .
 | |
| 	if ($str =~ /{.*}/) {
 | |
| 		$str = substr($&,1,-1);
 | |
| 	}
 | |
| 	# If nothing, put NULL.
 | |
| 	if ($str eq "") {
 | |
| 		my $sDef;
 | |
| 		if(scalar(@defaults)) { $sDef = $defaults[$idCol]; } #Use default in array.
 | |
| 		else { $sDef = "NULL" unless($sDef); } #Let SQL handle the default.
 | |
| 		print $sFHout "$sDef$suffix";
 | |
| 	} else {
 | |
| 		my $flag = 0;
 | |
| 		# Search if it's a string column?
 | |
| 		foreach my $col (@str_col) {
 | |
| 			if ($col == $idCol) {
 | |
| 				$flag |= 1;
 | |
| 				last;
 | |
| 			}
 | |
| 		}
 | |
| 		foreach my $col (@str_col2) {
 | |
| 			if ($col == $idCol) {
 | |
| 				$flag |= 2;
 | |
| 				last;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if ($flag & 3) {
 | |
| 			# String column, so escape , remove trailing and add '' .
 | |
| 			my $string;
 | |
| 			$string = escape($str,"'","\\'") if($flag & 1) ;
 | |
| 			$string =~ s/\s+$//; #Remove trailing spaces.
 | |
| 			$string =~ s/^\s+//; #Remove leading spaces.
 | |
| 			$string = escape($string,'\\\"','\\\\\"') if($flag & 2) ;
 | |
| 			printf $sFHout ("'%s'%s", $string, $suffix);
 | |
| 		} else {
 | |
| 			# Not a string column.
 | |
| 			printf $sFHout ("%s%s", $str,$suffix);
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| sub escape { my ($str,$sregex,$sreplace) = @_;
 | |
| 	my @str_splitted = split($sregex, $str);
 | |
| 	my $result = "";
 | |
| 	for (my $i=0; $i<=$#str_splitted; $i++) {
 | |
| 		if ($i == 0) {
 | |
| 			$result = $str_splitted[0];
 | |
| 		} else {
 | |
| 			$result = $result.$sreplace.$str_splitted[$i];
 | |
| 		}
 | |
| 	}
 | |
| 	return $result
 | |
| }
 | |
| 
 | |
| 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){
 | |
| 			$db = "mob_skill_db" unless($db);
 | |
| 		}else{
 | |
| 			$db = "mob_skill_db_re" unless($db);
 | |
| 		}
 | |
| 		$nb_columns = 19;
 | |
| 		@str_col = (1,2,8,9,10,11,17,18);
 | |
| 		$line_format = "([^\,]*),"x($nb_columns-1)."([^\,]*)";
 | |
| 		$create_table =
 | |
| "#
 | |
| # Table structure for table `$db`
 | |
| #
 | |
| 
 | |
| DROP TABLE IF EXISTS `$db`;
 | |
| CREATE TABLE IF NOT EXISTS `$db` (
 | |
|   `MOB_ID` smallint(6) NOT NULL,
 | |
|   `INFO` text NOT NULL,
 | |
|   `STATE` text NOT NULL,
 | |
|   `SKILL_ID` smallint(6) NOT NULL,
 | |
|   `SKILL_LV` tinyint(4) NOT NULL,
 | |
|   `RATE` smallint(4) NOT NULL,
 | |
|   `CASTTIME` mediumint(9) NOT NULL,
 | |
|   `DELAY` int(9) NOT NULL,
 | |
|   `CANCELABLE` text NOT NULL,
 | |
|   `TARGET` text NOT NULL,
 | |
|   `CONDITION` text NOT NULL,
 | |
|   `CONDITION_VALUE` text,
 | |
|   `VAL1` mediumint(9) DEFAULT NULL,
 | |
|   `VAL2` mediumint(9) DEFAULT NULL,
 | |
|   `VAL3` mediumint(9) DEFAULT NULL,
 | |
|   `VAL4` mediumint(9) DEFAULT NULL,
 | |
|   `VAL5` mediumint(9) DEFAULT NULL,
 | |
|   `EMOTION` text,
 | |
|   `CHAT` text
 | |
| ) ENGINE=MyISAM;
 | |
| ";
 | |
| 	}
 | |
| 	elsif($sType =~ /mob/i) { #Same format for Pre-Renewal and Renewal.
 | |
| 		$db = $sTable;
 | |
| 		if($sTarget =~ /Pre/i){
 | |
| 			$db = "mob_db" unless($db);
 | |
| 		}else{
 | |
| 			$db = "mob_db_re" unless($db);
 | |
| 		}
 | |
| 		$nb_columns = 57;
 | |
| 		@str_col = (1,2,3);
 | |
| 		$line_format = "([^\,]*),"x($nb_columns-1);
 | |
| 		$create_table =
 | |
| "#
 | |
| # Table structure for table `$db`
 | |
| #
 | |
| 
 | |
| DROP TABLE IF EXISTS `$db`;
 | |
| CREATE TABLE `$db` (
 | |
|   `ID` mediumint(9) unsigned NOT NULL default '0',
 | |
|   `Sprite` text NOT NULL,
 | |
|   `kName` text NOT NULL,
 | |
|   `iName` text NOT NULL,
 | |
|   `LV` tinyint(6) unsigned NOT NULL default '0',
 | |
|   `HP` int(9) unsigned NOT NULL default '0',
 | |
|   `SP` mediumint(9) unsigned NOT NULL default '0',
 | |
|   `EXP` mediumint(9) unsigned NOT NULL default '0',
 | |
|   `JEXP` mediumint(9) unsigned NOT NULL default '0',
 | |
|   `Range1` tinyint(4) unsigned NOT NULL default '0',
 | |
|   `ATK1` smallint(6) unsigned NOT NULL default '0',
 | |
|   `ATK2` smallint(6) unsigned NOT NULL default '0',
 | |
|   `DEF` smallint(6) unsigned NOT NULL default '0',
 | |
|   `MDEF` smallint(6) unsigned NOT NULL default '0',
 | |
|   `STR` smallint(6) unsigned NOT NULL default '0',
 | |
|   `AGI` smallint(6) unsigned NOT NULL default '0',
 | |
|   `VIT` smallint(6) unsigned NOT NULL default '0',
 | |
|   `INT` smallint(6) unsigned NOT NULL default '0',
 | |
|   `DEX` smallint(6) unsigned NOT NULL default '0',
 | |
|   `LUK` smallint(6) unsigned NOT NULL default '0',
 | |
|   `Range2` tinyint(4) unsigned NOT NULL default '0',
 | |
|   `Range3` tinyint(4) unsigned NOT NULL default '0',
 | |
|   `Scale` tinyint(4) unsigned NOT NULL default '0',
 | |
|   `Race` tinyint(4) unsigned NOT NULL default '0',
 | |
|   `Element` tinyint(4) unsigned NOT NULL default '0',
 | |
|   `Mode` int(11) unsigned NOT NULL default '0',
 | |
|   `Speed` smallint(6) unsigned NOT NULL default '0',
 | |
|   `aDelay` smallint(6) unsigned NOT NULL default '0',
 | |
|   `aMotion` smallint(6) unsigned NOT NULL default '0',
 | |
|   `dMotion` smallint(6) unsigned NOT NULL default '0',
 | |
|   `MEXP` mediumint(9) unsigned NOT NULL default '0',
 | |
|   `MVP1id` int(10) unsigned NOT NULL default '0',
 | |
|   `MVP1per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `MVP2id` int(10) unsigned NOT NULL default '0',
 | |
|   `MVP2per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `MVP3id` int(10) unsigned NOT NULL default '0',
 | |
|   `MVP3per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop1id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop1per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop2id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop2per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop3id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop3per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop4id` int(10)) unsigned NOT NULL default '0',
 | |
|   `Drop4per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop5id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop5per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop6id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop6per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop7id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop7per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop8id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop8per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `Drop9id` int(10) unsigned NOT NULL default '0',
 | |
|   `Drop9per` smallint(9) unsigned NOT NULL default '0',
 | |
|   `DropCardid` int(10) unsigned NOT NULL default '0',
 | |
|   `DropCardper` smallint(9) unsigned NOT NULL default '0',
 | |
|   PRIMARY KEY  (`ID`)
 | |
| ) ENGINE=MyISAM;
 | |
| ";
 | |
| 	}
 | |
| }
 |