/* OpenMW - The completely unofficial reimplementation of Morrowind Copyright (C) 2008 Nicolay Korslund Email: < korslund@gmail.com > WWW: http://openmw.snaptoad.com/ This file (openmw.d) is part of the OpenMW package. OpenMW is distributed as free software: you can redistribute it and/or modify it under the terms of the GNU General Public License version 3, as published by the Free Software Foundation. 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 version 3 along with this program. If not, see http://www.gnu.org/licenses/ . */ module morro; import std.stdio; import std.string; import std.cstream; import std.file; import ogre.ogre; import ogre.bindings; import gui.bindings; import bullet.bullet; import scene.celldata; import scene.soundlist; import scene.gamesettings; import core.resource; import core.memory; import core.config; import monster.util.string; import monster.vm.mclass; import monster.vm.dbg; import mscripts.setup; import sound.audio; import input.events; //* import std.gc; import gcstats; void poolSize() { GCStats gc; getStats(gc); writefln("Pool size: ", comma(gc.poolsize)); writefln("Used size: ", comma(gc.usedsize)); } //*/ void main(char[][] args) { bool render = true; bool help = false; bool resetKeys = false; bool showOgreFlag = false; bool noSound = false; bool debugOut = false; // Some examples to try: // // "Abandoned Shipwreck, Upper Level"; // "Gro-Bagrat Plantation"; // "Abinabi"; // "Abebaal Egg Mine"; // "Ald-ruhn, Ald Skar Inn"; // "Koal Cave"; // "Ald-ruhn, Arobar Manor Bedrooms" // "Sud"; // "Vivec, The Lizard's Head"; // "ToddTest"; // Cells to load char[][] cells; int[] eCells; foreach(char[] a; args[1..$]) if(a == "-n") render = false; else if(a.begins("-e")) { int i = find(a,','); eCells ~= atoi(a[2..i]); eCells ~= atoi(a[i+1..$]); } else if(a == "-h") help=true; else if(a == "-rk") resetKeys = true; else if(a == "-oc") showOgreFlag = true; else if(a == "-ns") noSound = true; else if(a == "-debug") { // Enable Monster debug output dbg.dbgOut = dout; // Tell OGRE to do the same later on debugOut = true; } else cells ~= a; if(cells.length + eCells.length/2 > 1 ) { writefln("More than one cell specified, rendering disabled"); render=false; } void showHelp() { writefln("Syntax: %s [options] cell-name [cell-name]", args[0]); writefln(" Options:"); writefln(" -n Only load, do not render"); writefln(" -ex,y Load exterior cell (x,y)"); writefln(" -rk Reset key bindings to default"); writefln(" -oc Show the Ogre config dialogue"); writefln(" -ns Completely disable sound"); writefln(" -debug Print debug information"); writefln(" -h Show this help"); writefln(""); writefln("Specifying more than one cell implies -n"); } if(help) { showHelp(); return; } initializeMemoryRegions(); initMonsterScripts(); /* importSavegame("data/quiksave.ess"); importSavegame("data/Perm1hal0000.ess"); return; */ config.initialize(resetKeys); scope(exit) config.writeConfig(); // Check if the data directory exists if(!exists(config.dataDir) || !isdir(config.dataDir)) { writefln("Cannot find data directory '", config.dataDir, "' - please edit openmw.ini."); return; } // If the -oc parameter is specified, we override any config // setting. if(showOgreFlag) config.finalOgreConfig = true; if(cells.length == 0 && eCells.length == 0) if(config.defaultCell.length) cells ~= config.defaultCell; if(cells.length == 1) config.defaultCell = cells[0]; if(cells.length == 0 && eCells.length == 0) { showHelp(); return; } if(!noSound) initializeSound(); resources.initResources(); // Load all ESM and ESP files loadTESFiles(config.gameFiles); scene.gamesettings.loadGameSettings(); CellData cd = cellList.get(); foreach(char[] cName; cells) { // Release the last cell data cellList.release(cd); // Get a cell data holder and load an interior cell cd = cellList.get(); try cd.loadIntCell(cName); catch(Exception e) { writefln("\nUnable to load cell '%s'.", cName); writefln("\nDetails: %s", e); writefln(" Perhaps this cell does not exist in your Morrowind language version? Try specifying another cell name on the command line, or edit openmw.ini."); return; } } for(int i; i