v50 Steam/Premium information for editors
- v50 information can now be added to pages in the main namespace. v0.47 information can still be found in the DF2014 namespace. See here for more details on the new versioning policy.
- Use this page to report any issues related to the migration.
This notice may be cached—the current version can be found here.
User:Quietust/rawextract.php
< User:Quietust
Jump to navigation
Jump to search
Revision as of 16:25, 14 February 2012 by Quietust (talk | contribs) (moved User:Quietust/beastextract.php to User:Quietust/beastextract 31.php: this one works for version 0.31.xx)
<? function decompress ($sig, $file) { $out = tmpfile(); // write 'uncompressed' header fwrite($out, pack('VV', $sig, 0)); while (1) { $len = readLong($file); if (feof($file)) break; $skip = readShort($file); $block = fread($file, $len - 2); fwrite($out, gzinflate($block)); } rewind($out); fclose($file); return $out; } function readLong ($file) { $x = fread($file, 4); $pck = @unpack('Vdata', $x); return $pck['data']; } function readShort ($file) { $x = fread($file, 2); $pck = @unpack('vdata', $x); return $pck['data']; } $dir = ''; if ($argc > 1) $dir = $argv[1] .'\\'; $raw = @fopen($dir.'world.dat', 'rb'); if ($raw) { $sig = readLong($raw); $comp = readLong($raw); if ($comp == 1) $raw = decompress($sig, $raw); elseif ($comp > 0) die("world.dat file is corrupted!"); fseek($raw, 0x92, SEEK_SET); $len = readShort($raw); $world = fread($raw, $len); echo "Extracting raws for randomly generated creatures of $world:\n\n"; } else { $raw = @fopen($dir.'world.sav', 'rb'); if (!$raw) die("Could not open world.dat or world.sav!"); $sig = readLong($raw); $comp = readLong($raw); if ($comp == 1) $raw = decompress($sig, $raw); elseif ($comp > 0) die("world.sav file is corrupted!"); fseek($raw, 0x5E, SEEK_SET); $len = readShort($raw); $name = fread($raw, $len); $len = readShort($raw); $world = fread($raw, $len); echo "Extracting raws for randomly generated creatures of $world:\n\n"; $skip = readLong($raw); } $numCreatures = readLong($raw); for ($i = 0; $i < $numCreatures; $i++) { $data = ''; $file = "creature_$i"; $numLines = readLong($raw); for ($j = 0; $j < $numLines; $j++) { $len = readShort($raw); $str = fread($raw, $len); $data .= "$str\r\n"; if (preg_match('/\[CREATURE:(.*?)\]/', $str, $x)) $file = $x[1]; } echo "$file...\n"; file_put_contents($file .'.txt', $data); } echo "done!\n"; ?>