Merge pull request #1872 from akortunov/extended_logging

Use new logging system
pull/540/head
Bret Curtis 6 years ago committed by GitHub
commit dcd381049c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -5,8 +5,8 @@
#include <QLocalSocket> #include <QLocalSocket>
#include <QMessageBox> #include <QMessageBox>
#include <components/debug/debuglog.hpp>
#include <components/fallback/validate.hpp> #include <components/fallback/validate.hpp>
#include <components/nifosg/nifloader.hpp> #include <components/nifosg/nifloader.hpp>
#include "model/doc/document.hpp" #include "model/doc/document.hpp"
@ -294,7 +294,7 @@ bool CS::Editor::makeIPCServer()
mLock = boost::interprocess::file_lock(mPid.string().c_str()); mLock = boost::interprocess::file_lock(mPid.string().c_str());
if(!mLock.try_lock()) if(!mLock.try_lock())
{ {
std::cerr << "OpenCS already running." << std::endl; Log(Debug::Error) << "Error: OpenMW-CS is already running.";
return false; return false;
} }
@ -317,17 +317,17 @@ bool CS::Editor::makeIPCServer()
if(boost::filesystem::exists(fullPath.toUtf8().constData())) if(boost::filesystem::exists(fullPath.toUtf8().constData()))
{ {
// TODO: compare pid of the current process with that in the file // TODO: compare pid of the current process with that in the file
std::cout << "Detected unclean shutdown." << std::endl; Log(Debug::Info) << "Detected unclean shutdown.";
// delete the stale file // delete the stale file
if(remove(fullPath.toUtf8().constData())) if(remove(fullPath.toUtf8().constData()))
std::cerr << "ERROR removing stale connection file" << std::endl; Log(Debug::Error) << "Error: can not remove stale connection file.";
} }
} }
} }
catch(const std::exception& e) catch(const std::exception& e)
{ {
std::cerr << "ERROR " << e.what() << std::endl; Log(Debug::Error) << "Error: " << e.what();
return false; return false;
} }

@ -1,7 +1,6 @@
#include "editor.hpp" #include "editor.hpp"
#include <exception> #include <exception>
#include <iostream>
#include <string> #include <string>
#include <QApplication> #include <QApplication>
@ -31,7 +30,7 @@ class Application : public QApplication
} }
catch (const std::exception& exception) catch (const std::exception& exception)
{ {
std::cerr << "An exception has been caught: " << exception.what() << std::endl; Log(Debug::Error) << "An exception has been caught: " << exception.what();
} }
return false; return false;

@ -2,7 +2,6 @@
#include <cassert> #include <cassert>
#include <fstream> #include <fstream>
#include <iostream>
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include <boost/filesystem/fstream.hpp> #include <boost/filesystem/fstream.hpp>
@ -13,6 +12,8 @@
#include <components/files/configurationmanager.hpp> #include <components/files/configurationmanager.hpp>
#endif #endif
#include <components/debug/debuglog.hpp>
void CSMDoc::Document::addGmsts() void CSMDoc::Document::addGmsts()
{ {
for (size_t i=0; i < CSMWorld::DefaultGmsts::FloatCount; ++i) for (size_t i=0; i < CSMWorld::DefaultGmsts::FloatCount; ++i)
@ -435,7 +436,7 @@ void CSMDoc::Document::modificationStateChanged (bool clean)
void CSMDoc::Document::reportMessage (const CSMDoc::Message& message, int type) void CSMDoc::Document::reportMessage (const CSMDoc::Message& message, int type)
{ {
/// \todo find a better way to get these messages to the user. /// \todo find a better way to get these messages to the user.
std::cout << message.mMessage << std::endl; Log(Debug::Info) << message.mMessage;
} }
void CSMDoc::Document::operationDone2 (int type, bool failed) void CSMDoc::Document::operationDone2 (int type, bool failed)

@ -1,8 +1,8 @@
#include "refcollection.hpp" #include "refcollection.hpp"
#include <sstream> #include <sstream>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <components/esm/loadcell.hpp> #include <components/esm/loadcell.hpp>
@ -58,10 +58,10 @@ void CSMWorld::RefCollection::load (ESM::ESMReader& reader, int cellIndex, bool
// message // message
if (index.first != mref.mTarget[0] || index.second != mref.mTarget[1]) if (index.first != mref.mTarget[0] || index.second != mref.mTarget[1])
{ {
std::cerr << "The Position of moved ref " Log(Debug::Warning) << "Warning: the Position of moved ref "
<< ref.mRefID << " does not match the target cell" << std::endl; << ref.mRefID << " does not match the target cell";
std::cerr << "Position: #" << index.first << " " << index.second Log(Debug::Warning) << "Position: #" << index.first << " " << index.second
<<", Target #"<< mref.mTarget[0] << " " << mref.mTarget[1] << std::endl; <<", Target #"<< mref.mTarget[0] << " " << mref.mTarget[1];
stream.clear(); stream.clear();
stream << "#" << mref.mTarget[0] << " " << mref.mTarget[1]; stream << "#" << mref.mTarget[0] << " " << mref.mTarget[1];

@ -1,7 +1,6 @@
#include "object.hpp" #include "object.hpp"
#include <stdexcept> #include <stdexcept>
#include <iostream>
#include <osg/Depth> #include <osg/Depth>
#include <osg/Group> #include <osg/Group>
@ -24,6 +23,7 @@
#include "../../model/world/cellcoordinates.hpp" #include "../../model/world/cellcoordinates.hpp"
#include "../../model/prefs/state.hpp" #include "../../model/prefs/state.hpp"
#include <components/debug/debuglog.hpp>
#include <components/resource/scenemanager.hpp> #include <components/resource/scenemanager.hpp>
#include <components/sceneutil/lightutil.hpp> #include <components/sceneutil/lightutil.hpp>
#include <components/sceneutil/lightmanager.hpp> #include <components/sceneutil/lightmanager.hpp>
@ -133,7 +133,7 @@ void CSVRender::Object::update()
catch (std::exception& e) catch (std::exception& e)
{ {
// TODO: use error marker mesh // TODO: use error marker mesh
std::cerr << e.what() << std::endl; Log(Debug::Error) << e.what();
} }
} }

@ -10,6 +10,8 @@
#include <SDL.h> #include <SDL.h>
#include <components/debug/debuglog.hpp>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
@ -61,7 +63,7 @@ namespace
void checkSDLError(int ret) void checkSDLError(int ret)
{ {
if (ret != 0) if (ret != 0)
std::cerr << "SDL error: " << SDL_GetError() << std::endl; Log(Debug::Error) << "SDL error: " << SDL_GetError();
} }
} }
@ -189,7 +191,7 @@ bool OMW::Engine::frame(float frametime)
} }
catch (const std::exception& e) catch (const std::exception& e)
{ {
std::cerr << "Error in frame: " << e.what() << std::endl; Log(Debug::Error) << "Error in frame: " << e.what();
} }
return true; return true;
} }
@ -364,7 +366,7 @@ void OMW::Engine::createWindow(Settings::Manager& settings)
// Try with a lower AA // Try with a lower AA
if (antialiasing > 0) if (antialiasing > 0)
{ {
std::cout << "Note: " << antialiasing << "x antialiasing not supported, trying " << antialiasing/2 << std::endl; Log(Debug::Warning) << "Warning: " << antialiasing << "x antialiasing not supported, trying " << antialiasing/2;
antialiasing /= 2; antialiasing /= 2;
Settings::Manager::setInt("antialiasing", "Video", antialiasing); Settings::Manager::setInt("antialiasing", "Video", antialiasing);
checkSDLError(SDL_GL_SetAttribute(SDL_GL_MULTISAMPLESAMPLES, antialiasing)); checkSDLError(SDL_GL_SetAttribute(SDL_GL_MULTISAMPLESAMPLES, antialiasing));
@ -373,7 +375,7 @@ void OMW::Engine::createWindow(Settings::Manager& settings)
else else
{ {
std::stringstream error; std::stringstream error;
error << "Failed to create SDL window: " << SDL_GetError() << std::endl; error << "Failed to create SDL window: " << SDL_GetError();
throw std::runtime_error(error.str()); throw std::runtime_error(error.str());
} }
} }
@ -420,16 +422,16 @@ void OMW::Engine::setWindowIcon()
std::string windowIcon = (mResDir / "mygui" / "openmw.png").string(); std::string windowIcon = (mResDir / "mygui" / "openmw.png").string();
windowIconStream.open(windowIcon, std::ios_base::in | std::ios_base::binary); windowIconStream.open(windowIcon, std::ios_base::in | std::ios_base::binary);
if (windowIconStream.fail()) if (windowIconStream.fail())
std::cerr << "Error: Failed to open " << windowIcon << std::endl; Log(Debug::Error) << "Error: Failed to open " << windowIcon;
osgDB::ReaderWriter* reader = osgDB::Registry::instance()->getReaderWriterForExtension("png"); osgDB::ReaderWriter* reader = osgDB::Registry::instance()->getReaderWriterForExtension("png");
if (!reader) if (!reader)
{ {
std::cerr << "Error: Failed to read window icon, no png readerwriter found" << std::endl; Log(Debug::Error) << "Error: Failed to read window icon, no png readerwriter found";
return; return;
} }
osgDB::ReaderWriter::ReadResult result = reader->readImage(windowIconStream); osgDB::ReaderWriter::ReadResult result = reader->readImage(windowIconStream);
if (!result.success()) if (!result.success())
std::cerr << "Error: Failed to read " << windowIcon << ": " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Failed to read " << windowIcon << ": " << result.message() << " code " << result.status();
else else
{ {
osg::ref_ptr<osg::Image> image = result.getImage(); osg::ref_ptr<osg::Image> image = result.getImage();
@ -564,21 +566,19 @@ void OMW::Engine::prepareEngine (Settings::Manager & settings)
{ {
std::pair<int, int> result = mEnvironment.getScriptManager()->compileAll(); std::pair<int, int> result = mEnvironment.getScriptManager()->compileAll();
if (result.first) if (result.first)
std::cout Log(Debug::Info)
<< "compiled " << result.second << " of " << result.first << " scripts (" << "compiled " << result.second << " of " << result.first << " scripts ("
<< 100*static_cast<double> (result.second)/result.first << 100*static_cast<double> (result.second)/result.first
<< "%)" << "%)";
<< std::endl;
} }
if (mCompileAllDialogue) if (mCompileAllDialogue)
{ {
std::pair<int, int> result = MWDialogue::ScriptTest::compileAll(&mExtensions, mWarningsMode); std::pair<int, int> result = MWDialogue::ScriptTest::compileAll(&mExtensions, mWarningsMode);
if (result.first) if (result.first)
std::cout Log(Debug::Info)
<< "compiled " << result.second << " of " << result.first << " dialogue script/actor combinations a(" << "compiled " << result.second << " of " << result.first << " dialogue script/actor combinations a("
<< 100*static_cast<double> (result.second)/result.first << 100*static_cast<double> (result.second)/result.first
<< "%)" << "%)";
<< std::endl;
} }
} }
@ -614,14 +614,14 @@ public:
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension(mScreenshotFormat); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension(mScreenshotFormat);
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Can't write screenshot, no '" << mScreenshotFormat << "' readerwriter found" << std::endl; Log(Debug::Error) << "Error: Can't write screenshot, no '" << mScreenshotFormat << "' readerwriter found";
return; return;
} }
osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(image, outStream); osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(image, outStream);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Can't write screenshot: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Can't write screenshot: " << result.message() << " code " << result.status();
} }
} }
@ -636,7 +636,7 @@ void OMW::Engine::go()
{ {
assert (!mContentFiles.empty()); assert (!mContentFiles.empty());
std::cout << "OSG version: " << osgGetVersion() << std::endl; Log(Debug::Info) << "OSG version: " << osgGetVersion();
// Load settings // Load settings
Settings::Manager settings; Settings::Manager settings;
@ -738,7 +738,7 @@ void OMW::Engine::go()
// Save user settings // Save user settings
settings.saveUser(settingspath); settings.saveUser(settingspath);
std::cout << "Quitting peacefully." << std::endl; Log(Debug::Info) << "Quitting peacefully.";
} }
void OMW::Engine::setCompileAll (bool all) void OMW::Engine::setCompileAll (bool all)

@ -1,5 +1,3 @@
#include <iostream>
#include <components/version/version.hpp> #include <components/version/version.hpp>
#include <components/files/configurationmanager.hpp> #include <components/files/configurationmanager.hpp>
#include <components/files/escape.hpp> #include <components/files/escape.hpp>
@ -202,8 +200,8 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
StringsVector content = variables["content"].as<Files::EscapeStringVector>().toStdStringVector(); StringsVector content = variables["content"].as<Files::EscapeStringVector>().toStdStringVector();
if (content.empty()) if (content.empty())
{ {
std::cout << "No content file given (esm/esp, nor omwgame/omwaddon). Aborting..." << std::endl; Log(Debug::Error) << "No content file given (esm/esp, nor omwgame/omwaddon). Aborting...";
return false; return false;
} }
StringsVector::const_iterator it(content.begin()); StringsVector::const_iterator it(content.begin());
@ -217,7 +215,7 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
engine.setCell(variables["start"].as<Files::EscapeHashString>().toStdString()); engine.setCell(variables["start"].as<Files::EscapeHashString>().toStdString());
engine.setSkipMenu (variables["skip-menu"].as<bool>(), variables["new-game"].as<bool>()); engine.setSkipMenu (variables["skip-menu"].as<bool>(), variables["new-game"].as<bool>());
if (!variables["skip-menu"].as<bool>() && variables["new-game"].as<bool>()) if (!variables["skip-menu"].as<bool>() && variables["new-game"].as<bool>())
std::cerr << "Warning: new-game used without skip-menu -> ignoring it" << std::endl; Log(Debug::Warning) << "Warning: new-game used without skip-menu -> ignoring it";
// scripts // scripts
engine.setCompileAll(variables["script-all"].as<bool>()); engine.setCompileAll(variables["script-all"].as<bool>());

@ -1,7 +1,7 @@
#include "creature.hpp" #include "creature.hpp"
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/debug/debuglog.hpp>
#include <components/esm/loadcrea.hpp> #include <components/esm/loadcrea.hpp>
#include <components/esm/creaturestate.hpp> #include <components/esm/creaturestate.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
@ -146,7 +146,7 @@ namespace MWClass
if (const ESM::Spell* spell = MWBase::Environment::get().getWorld()->getStore().get<ESM::Spell>().search(*iter)) if (const ESM::Spell* spell = MWBase::Environment::get().getWorld()->getStore().get<ESM::Spell>().search(*iter))
data->mCreatureStats.getSpells().add (spell); data->mCreatureStats.getSpells().add (spell);
else /// \todo add option to make this a fatal error message pop-up, but default to warning for vanilla compatibility else /// \todo add option to make this a fatal error message pop-up, but default to warning for vanilla compatibility
std::cerr << "Warning: ignoring nonexistent spell '" << *iter << "' on creature '" << ref->mBase->mId << "'" << std::endl; Log(Debug::Warning) << "Warning: ignoring nonexistent spell '" << *iter << "' on creature '" << ref->mBase->mId << "'";
} }
// inventory // inventory

@ -4,6 +4,7 @@
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/debug/debuglog.hpp>
#include <components/esm/loadmgef.hpp> #include <components/esm/loadmgef.hpp>
#include <components/esm/loadnpc.hpp> #include <components/esm/loadnpc.hpp>
#include <components/esm/npcstate.hpp> #include <components/esm/npcstate.hpp>
@ -365,7 +366,7 @@ namespace MWClass
if (const ESM::Spell* spell = MWBase::Environment::get().getWorld()->getStore().get<ESM::Spell>().search(*iter)) if (const ESM::Spell* spell = MWBase::Environment::get().getWorld()->getStore().get<ESM::Spell>().search(*iter))
data->mNpcStats.getSpells().add (spell); data->mNpcStats.getSpells().add (spell);
else else
std::cerr << "Warning: ignoring nonexistent race power '" << *iter << "' on NPC '" << ref->mBase->mId << "'" << std::endl; Log(Debug::Warning) << "Warning: ignoring nonexistent race power '" << *iter << "' on NPC '" << ref->mBase->mId << "'";
} }
if (!ref->mBase->mFaction.empty()) if (!ref->mBase->mFaction.empty())
@ -395,7 +396,7 @@ namespace MWClass
else else
{ {
/// \todo add option to make this a fatal error message pop-up, but default to warning for vanilla compatibility /// \todo add option to make this a fatal error message pop-up, but default to warning for vanilla compatibility
std::cerr << "Warning: ignoring nonexistent spell '" << *iter << "' on NPC '" << ref->mBase->mId << "'" << std::endl; Log(Debug::Warning) << "Warning: ignoring nonexistent spell '" << *iter << "' on NPC '" << ref->mBase->mId << "'";
} }
} }

@ -5,7 +5,8 @@
#include <algorithm> #include <algorithm>
#include <iterator> #include <iterator>
#include <list> #include <list>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/esm/loaddial.hpp> #include <components/esm/loaddial.hpp>
#include <components/esm/loadinfo.hpp> #include <components/esm/loadinfo.hpp>
@ -203,16 +204,14 @@ namespace MWDialogue
} }
catch (const std::exception& error) catch (const std::exception& error)
{ {
std::cerr << std::string ("Dialogue error: An exception has been thrown: ") + error.what() << std::endl; Log(Debug::Error) << std::string ("Dialogue error: An exception has been thrown: ") + error.what();
success = false; success = false;
} }
if (!success) if (!success)
{ {
std::cerr Log(Debug::Warning)
<< "Warning: compiling failed (dialogue script)" << std::endl << "Warning: compiling failed (dialogue script)\n" << cmd << "\n\n";
<< cmd
<< std::endl << std::endl;
} }
return success; return success;
@ -232,7 +231,7 @@ namespace MWDialogue
} }
catch (const std::exception& error) catch (const std::exception& error)
{ {
std::cerr << std::string ("Dialogue error: An exception has been thrown: ") + error.what() << std::endl; Log(Debug::Error) << std::string ("Dialogue error: An exception has been thrown: ") + error.what();
} }
} }
} }

@ -1,7 +1,5 @@
#include "scripttest.hpp" #include "scripttest.hpp"
#include <iostream>
#include "../mwworld/manualref.hpp" #include "../mwworld/manualref.hpp"
#include "../mwworld/esmstore.hpp" #include "../mwworld/esmstore.hpp"
#include "../mwworld/class.hpp" #include "../mwworld/class.hpp"
@ -12,6 +10,7 @@
#include "../mwscript/compilercontext.hpp" #include "../mwscript/compilercontext.hpp"
#include <components/debug/debuglog.hpp>
#include <components/compiler/exception.hpp> #include <components/compiler/exception.hpp>
#include <components/compiler/streamerrorhandler.hpp> #include <components/compiler/streamerrorhandler.hpp>
#include <components/compiler/scanner.hpp> #include <components/compiler/scanner.hpp>
@ -80,16 +79,14 @@ void test(const MWWorld::Ptr& actor, int &compiled, int &total, const Compiler::
} }
catch (const std::exception& error) catch (const std::exception& error)
{ {
std::cerr << std::string ("Dialogue error: An exception has been thrown: ") + error.what() << std::endl; Log(Debug::Error) << std::string ("Dialogue error: An exception has been thrown: ") + error.what();
success = false; success = false;
} }
if (!success) if (!success)
{ {
std::cerr Log(Debug::Warning)
<< "compiling failed (dialogue script)" << std::endl << "compiling failed (dialogue script)\n" << info->mResultScript << "\n\n";
<< info->mResultScript
<< std::endl << std::endl;
} }
} }
} }

@ -1,5 +1,6 @@
#include "charactercreation.hpp" #include "charactercreation.hpp"
#include <components/debug/debuglog.hpp>
#include <components/fallback/fallback.hpp> #include <components/fallback/fallback.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
@ -284,7 +285,7 @@ namespace MWGui
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error: Failed to create chargen window: " << e.what() << std::endl; Log(Debug::Error) << "Error: Failed to create chargen window: " << e.what();
} }
} }
@ -602,7 +603,7 @@ namespace MWGui
mGenerateClass = "Mage"; mGenerateClass = "Mage";
else else
{ {
std::cout << "Failed to deduce class from chosen answers in generate class dialog" << std::endl; Log(Debug::Warning) << "Failed to deduce class from chosen answers in generate class dialog.";
mGenerateClass = "Thief"; mGenerateClass = "Thief";
} }
} }

@ -12,6 +12,8 @@
#include "../mwworld/esmstore.hpp" #include "../mwworld/esmstore.hpp"
#include <components/debug/debuglog.hpp>
#include "tooltips.hpp" #include "tooltips.hpp"
namespace namespace
@ -924,7 +926,7 @@ namespace MWGui
std::string classImage = std::string("textures\\levelup\\") + classId + ".dds"; std::string classImage = std::string("textures\\levelup\\") + classId + ".dds";
if (!MWBase::Environment::get().getWindowManager()->textureExists(classImage)) if (!MWBase::Environment::get().getWindowManager()->textureExists(classImage))
{ {
std::cout << "No class image for " << classId << ", falling back to default" << std::endl; Log(Debug::Warning) << "No class image for " << classId << ", falling back to default";
classImage = "textures\\levelup\\warrior.dds"; classImage = "textures\\levelup\\warrior.dds";
} }
imageBox->setImageTexture(classImage); imageBox->setImageTexture(classImage);

@ -6,6 +6,7 @@
#include <MyGUI_ScrollBar.h> #include <MyGUI_ScrollBar.h>
#include <MyGUI_Button.h> #include <MyGUI_Button.h>
#include <components/debug/debuglog.hpp>
#include <components/widgets/list.hpp> #include <components/widgets/list.hpp>
#include <components/translation/translation.hpp> #include <components/translation/translation.hpp>
@ -411,7 +412,7 @@ namespace MWGui
{ {
if (!actor.getClass().isActor()) if (!actor.getClass().isActor())
{ {
std::cerr << "Warning: can not talk with non-actor object." << std::endl; Log(Debug::Warning) << "Warning: can not talk with non-actor object.";
return; return;
} }

@ -13,6 +13,7 @@
#include <boost/algorithm/string/replace.hpp> #include <boost/algorithm/string/replace.hpp>
#include <boost/algorithm/string/predicate.hpp> #include <boost/algorithm/string/predicate.hpp>
#include <components/debug/debuglog.hpp>
#include <components/interpreter/defines.hpp> #include <components/interpreter/defines.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
@ -300,7 +301,7 @@ namespace MWGui
if (!exists) if (!exists)
{ {
std::cerr << "Warning: Could not find \"" << src << "\" referenced by an <img> tag." << std::endl; Log(Debug::Warning) << "Warning: Could not find \"" << src << "\" referenced by an <img> tag.";
break; break;
} }

@ -10,9 +10,8 @@
#include <MyGUI_TextBox.h> #include <MyGUI_TextBox.h>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/debug/debuglog.hpp>
#include <components/myguiplatform/myguitexture.hpp> #include <components/myguiplatform/myguitexture.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
@ -94,7 +93,7 @@ namespace MWGui
++found; ++found;
} }
if (mSplashScreens.empty()) if (mSplashScreens.empty())
std::cerr << "No splash screens found!" << std::endl; Log(Debug::Warning) << "Warning: no splash screens found!";
} }
void LoadingScreen::setLabel(const std::string &label, bool important) void LoadingScreen::setLabel(const std::string &label, bool important)

@ -5,6 +5,7 @@
#include <MyGUI_RenderManager.h> #include <MyGUI_RenderManager.h>
#include <MyGUI_Button.h> #include <MyGUI_Button.h>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
@ -125,7 +126,7 @@ namespace MWGui
{ {
if (mInterMessageBoxe != NULL) if (mInterMessageBoxe != NULL)
{ {
std::cerr << "Warning: replacing an interactive message box that was not answered yet" << std::endl; Log(Debug::Warning) << "Warning: replacing an interactive message box that was not answered yet";
mInterMessageBoxe->setVisible(false); mInterMessageBoxe->setVisible(false);
delete mInterMessageBoxe; delete mInterMessageBoxe;
mInterMessageBoxe = NULL; mInterMessageBoxe = NULL;

@ -6,6 +6,7 @@
#include <osg/Texture2D> #include <osg/Texture2D>
#include <components/debug/debuglog.hpp>
#include <components/myguiplatform/myguitexture.hpp> #include <components/myguiplatform/myguitexture.hpp>
#include "../mwworld/esmstore.hpp" #include "../mwworld/esmstore.hpp"
@ -340,7 +341,7 @@ namespace MWGui
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error creating preview: " << e.what() << std::endl; Log(Debug::Error) << "Error creating preview: " << e.what();
} }
} }

@ -12,6 +12,8 @@
#include <osgDB/ReadFile> #include <osgDB/ReadFile>
#include <osg/Texture2D> #include <osg/Texture2D>
#include <components/debug/debuglog.hpp>
#include <components/myguiplatform/myguitexture.hpp> #include <components/myguiplatform/myguitexture.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
@ -438,14 +440,14 @@ namespace MWGui
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("jpg"); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("jpg");
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Can't open savegame screenshot, no jpg readerwriter found" << std::endl; Log(Debug::Error) << "Error: Can't open savegame screenshot, no jpg readerwriter found";
return; return;
} }
osgDB::ReaderWriter::ReadResult result = readerwriter->readImage(instream); osgDB::ReaderWriter::ReadResult result = readerwriter->readImage(instream);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Failed to read savegame screenshot: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Failed to read savegame screenshot: " << result.message() << " code " << result.status();
return; return;
} }

@ -12,6 +12,7 @@
#include <SDL_video.h> #include <SDL_video.h>
#include <components/debug/debuglog.hpp>
#include <components/widgets/sharedstatebutton.hpp> #include <components/widgets/sharedstatebutton.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
@ -31,7 +32,8 @@ namespace
if (val == "linear") return "Trilinear"; if (val == "linear") return "Trilinear";
if (val == "nearest") return "Bilinear"; if (val == "nearest") return "Bilinear";
if (val != "none") if (val != "none")
std::cerr<< "Warning: Invalid texture mipmap option: "<<val <<std::endl; Log(Debug::Warning) << "Warning: Invalid texture mipmap option: "<< val;
return "Other"; return "Other";
} }
@ -398,7 +400,7 @@ namespace MWGui
else if(pos == 1) else if(pos == 1)
Settings::Manager::setString("texture mipmap", "General", "linear"); Settings::Manager::setString("texture mipmap", "General", "linear");
else else
std::cerr<< "Unexpected option pos "<<pos <<std::endl; Log(Debug::Warning) << "Unexpected option pos " << pos;
apply(); apply();
} }

@ -1,9 +1,7 @@
#include "sortfilteritemmodel.hpp" #include "sortfilteritemmodel.hpp"
#include <iostream>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <components/debug/debuglog.hpp>
#include <components/esm/loadalch.hpp> #include <components/esm/loadalch.hpp>
#include <components/esm/loadappa.hpp> #include <components/esm/loadappa.hpp>
#include <components/esm/loadarmo.hpp> #include <components/esm/loadarmo.hpp>
@ -245,7 +243,7 @@ namespace MWGui
const ESM::Enchantment* ench = MWBase::Environment::get().getWorld()->getStore().get<ESM::Enchantment>().search(enchId); const ESM::Enchantment* ench = MWBase::Environment::get().getWorld()->getStore().get<ESM::Enchantment>().search(enchId);
if (!ench) if (!ench)
{ {
std::cerr << "Warning: Can't find enchantment '" << enchId << "' on item " << base.getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Warning: Can't find enchantment '" << enchId << "' on item " << base.getCellRef().getRefId();
return false; return false;
} }

@ -1,6 +1,6 @@
#include "spellmodel.hpp" #include "spellmodel.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
#include "../mwbase/world.hpp" #include "../mwbase/world.hpp"
@ -94,7 +94,7 @@ namespace MWGui
const ESM::Enchantment* enchant = esmStore.get<ESM::Enchantment>().search(enchantId); const ESM::Enchantment* enchant = esmStore.get<ESM::Enchantment>().search(enchantId);
if (!enchant) if (!enchant)
{ {
std::cerr << "Warning: Can't find enchantment '" << enchantId << "' on item " << item.getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Warning: Can't find enchantment '" << enchantId << "' on item " << item.getCellRef().getRefId();
continue; continue;
} }

@ -6,6 +6,7 @@
#include <osg/Texture2D> #include <osg/Texture2D>
#include <components/debug/debuglog.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
#include <components/myguiplatform/myguitexture.hpp> #include <components/myguiplatform/myguitexture.hpp>
@ -37,7 +38,7 @@ void VideoWidget::playVideo(const std::string &video)
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Failed to open video: " << e.what() << std::endl; Log(Debug::Error) << "Failed to open video: " << e.what();
return; return;
} }

@ -21,6 +21,8 @@
#include <SDL_keyboard.h> #include <SDL_keyboard.h>
#include <SDL_clipboard.h> #include <SDL_clipboard.h>
#include <components/debug/debuglog.hpp>
#include <components/sdlutil/sdlcursormanager.hpp> #include <components/sdlutil/sdlcursormanager.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
@ -1082,7 +1084,7 @@ namespace MWGui
{ {
if (!mStore) if (!mStore)
{ {
std::cerr << "Error: WindowManager::onRetrieveTag: no Store set up yet, can not replace '" << tag << "'" << std::endl; Log(Debug::Error) << "Error: WindowManager::onRetrieveTag: no Store set up yet, can not replace '" << tag << "'";
return; return;
} }
const ESM::GameSetting *setting = mStore->get<ESM::GameSetting>().find(tag); const ESM::GameSetting *setting = mStore->get<ESM::GameSetting>().find(tag);
@ -1788,7 +1790,7 @@ namespace MWGui
if (found != mCurrentModals.end()) if (found != mCurrentModals.end())
mCurrentModals.erase(found); mCurrentModals.erase(found);
else else
std::cerr << " warning: can't find modal window " << input << std::endl; Log(Debug::Warning) << "Warning: can't find modal window " << input;
} }
} }
if (mCurrentModals.empty()) if (mCurrentModals.empty())

@ -10,6 +10,7 @@
#include <SDL_version.h> #include <SDL_version.h>
#include <components/debug/debuglog.hpp>
#include <components/sdlutil/sdlinputwrapper.hpp> #include <components/sdlutil/sdlinputwrapper.hpp>
#include <components/sdlutil/sdlvideowrapper.hpp> #include <components/sdlutil/sdlvideowrapper.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
@ -120,11 +121,11 @@ namespace MWInput
SDL_ControllerDeviceEvent evt; SDL_ControllerDeviceEvent evt;
evt.which = i; evt.which = i;
controllerAdded(mFakeDeviceID, evt); controllerAdded(mFakeDeviceID, evt);
std::cout << "Detected game controller: " << SDL_GameControllerNameForIndex(i) << std::endl; Log(Debug::Info) << "Detected game controller: " << SDL_GameControllerNameForIndex(i);
} }
else else
{ {
std::cout << "Detected unusable controller: " << SDL_JoystickNameForIndex(i) << std::endl; Log(Debug::Info) << "Detected unusable controller: " << SDL_JoystickNameForIndex(i);
} }
} }

@ -8,7 +8,7 @@
#include <components/esm/loadnpc.hpp> #include <components/esm/loadnpc.hpp>
#include <components/sceneutil/positionattitudetransform.hpp> #include <components/sceneutil/positionattitudetransform.hpp>
#include <components/debug/debuglog.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
#include "../mwworld/esmstore.hpp" #include "../mwworld/esmstore.hpp"
@ -1729,7 +1729,7 @@ namespace MWMechanics
} }
else else
{ {
std::cerr<< "Warning: Actors::playAnimationGroup: Unable to find " << ptr.getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Warning: Actors::playAnimationGroup: Unable to find " << ptr.getCellRef().getRefId();
return false; return false;
} }
} }

@ -1,8 +1,8 @@
#include "aisequence.hpp" #include "aisequence.hpp"
#include <limits> #include <limits>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/esm/aisequence.hpp> #include <components/esm/aisequence.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
@ -282,7 +282,7 @@ void AiSequence::execute (const MWWorld::Ptr& actor, CharacterController& charac
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error during AiSequence::execute: " << e.what() << std::endl; Log(Debug::Error) << "Error during AiSequence::execute: " << e.what();
} }
} }
} }

@ -1,10 +1,9 @@
#include "aiwander.hpp" #include "aiwander.hpp"
#include <cfloat> #include <cfloat>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/esm/aisequence.hpp> #include <components/esm/aisequence.hpp>
#include "../mwbase/world.hpp" #include "../mwbase/world.hpp"
@ -24,8 +23,6 @@
#include "coordinateconverter.hpp" #include "coordinateconverter.hpp"
#include "actorutil.hpp" #include "actorutil.hpp"
namespace MWMechanics namespace MWMechanics
{ {
static const int COUNT_BEFORE_RESET = 10; static const int COUNT_BEFORE_RESET = 10;
@ -677,7 +674,7 @@ namespace MWMechanics
} }
else else
{ {
std::cerr<< "Error: Attempted to play out of range idle animation \""<<idleSelect<<"\" for " << actor.getCellRef().getRefId() << std::endl; Log(Debug::Verbose) << "Attempted to play out of range idle animation \"" << idleSelect << "\" for " << actor.getCellRef().getRefId();
return false; return false;
} }
} }

@ -1,8 +1,7 @@
#ifndef OPENMW_MECHANICS_LEVELLEDLIST_H #ifndef OPENMW_MECHANICS_LEVELLEDLIST_H
#define OPENMW_MECHANICS_LEVELLEDLIST_H #define OPENMW_MECHANICS_LEVELLEDLIST_H
#include <iostream> #include <components/debug/debuglog.hpp>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include "../mwworld/ptr.hpp" #include "../mwworld/ptr.hpp"
@ -63,7 +62,7 @@ namespace MWMechanics
// Vanilla doesn't fail on nonexistent items in levelled lists // Vanilla doesn't fail on nonexistent items in levelled lists
if (!MWBase::Environment::get().getWorld()->getStore().find(Misc::StringUtils::lowerCase(item))) if (!MWBase::Environment::get().getWorld()->getStore().find(Misc::StringUtils::lowerCase(item)))
{ {
std::cerr << "Warning: ignoring nonexistent item '" << item << "' in levelled list '" << levItem->mId << "'" << std::endl; Log(Debug::Warning) << "Warning: ignoring nonexistent item '" << item << "' in levelled list '" << levItem->mId << "'";
return std::string(); return std::string();
} }

@ -1,6 +1,6 @@
#include "objects.hpp" #include "objects.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
#include "../mwbase/world.hpp" #include "../mwbase/world.hpp"
@ -88,7 +88,7 @@ bool Objects::playAnimationGroup(const MWWorld::Ptr& ptr, const std::string& gro
} }
else else
{ {
std::cerr<< "Warning: Objects::playAnimationGroup: Unable to find " << ptr.getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Warning: Objects::playAnimationGroup: Unable to find " << ptr.getCellRef().getRefId();
return false; return false;
} }
} }

@ -1,6 +1,6 @@
#include "summoning.hpp" #include "summoning.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
#include "../mwbase/world.hpp" #include "../mwbase/world.hpp"
@ -76,7 +76,7 @@ namespace MWMechanics
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Failed to spawn summoned creature: " << e.what() << std::endl; Log(Debug::Error) << "Failed to spawn summoned creature: " << e.what();
// still insert into creatureMap so we don't try to spawn again every frame, that would spam the warning log // still insert into creatureMap so we don't try to spawn again every frame, that would spam the warning log
} }

@ -1,6 +1,5 @@
#include "physicssystem.hpp" #include "physicssystem.hpp"
#include <iostream>
#include <stdexcept> #include <stdexcept>
#include <osg/Group> #include <osg/Group>
@ -20,7 +19,7 @@
#include <components/nifbullet/bulletnifloader.hpp> #include <components/nifbullet/bulletnifloader.hpp>
#include <components/resource/resourcesystem.hpp> #include <components/resource/resourcesystem.hpp>
#include <components/resource/bulletshapemanager.hpp> #include <components/resource/bulletshapemanager.hpp>
#include <components/debug/debuglog.hpp>
#include <components/esm/loadgmst.hpp> #include <components/esm/loadgmst.hpp>
#include <components/sceneutil/positionattitudetransform.hpp> #include <components/sceneutil/positionattitudetransform.hpp>
#include <components/sceneutil/unrefqueue.hpp> #include <components/sceneutil/unrefqueue.hpp>
@ -638,7 +637,7 @@ namespace MWPhysics
mPtr.getRefData().getBaseNode()->accept(visitor); mPtr.getRefData().getBaseNode()->accept(visitor);
if (!visitor.mFound) if (!visitor.mFound)
{ {
std::cerr << "Error: animateCollisionShapes can't find node " << recIndex << " for " << mPtr.getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Warning: animateCollisionShapes can't find node " << recIndex << " for " << mPtr.getCellRef().getRefId();
// Remove nonexistent nodes from animated shapes map and early out // Remove nonexistent nodes from animated shapes map and early out
mShapeInstance->mAnimatedShapes.erase(recIndex); mShapeInstance->mAnimatedShapes.erase(recIndex);
@ -708,7 +707,7 @@ namespace MWPhysics
if (physFramerate > 0) if (physFramerate > 0)
{ {
mPhysicsDt = 1.f / physFramerate; mPhysicsDt = 1.f / physFramerate;
std::cerr << "Warning: physics framerate was overridden (a new value is " << physFramerate << ")." << std::endl; Log(Debug::Warning) << "Warning: using custom physics framerate (" << physFramerate << " FPS).";
} }
} }
} }

@ -12,6 +12,8 @@
#include <osgParticle/ParticleSystem> #include <osgParticle/ParticleSystem>
#include <osgParticle/ParticleProcessor> #include <osgParticle/ParticleProcessor>
#include <components/debug/debuglog.hpp>
#include <components/nifosg/nifloader.hpp> #include <components/nifosg/nifloader.hpp>
#include <components/resource/resourcesystem.hpp> #include <components/resource/resourcesystem.hpp>
@ -192,7 +194,7 @@ namespace
for (RemoveVec::iterator it = mToRemove.begin(); it != mToRemove.end(); ++it) for (RemoveVec::iterator it = mToRemove.begin(); it != mToRemove.end(); ++it)
{ {
if (!it->second->removeChild(it->first)) if (!it->second->removeChild(it->first))
std::cerr << "error removing " << it->first->getName() << std::endl; Log(Debug::Error) << "Error removing " << it->first->getName();
} }
} }
@ -612,7 +614,7 @@ namespace MWRender
NodeMap::const_iterator found = nodeMap.find(bonename); NodeMap::const_iterator found = nodeMap.find(bonename);
if (found == nodeMap.end()) if (found == nodeMap.end())
{ {
std::cerr << "Warning: addAnimSource: can't find bone '" + bonename << "' in " << baseModel << " (referenced by " << kfname << ")" << std::endl; Log(Debug::Warning) << "Warning: addAnimSource: can't find bone '" + bonename << "' in " << baseModel << " (referenced by " << kfname << ")";
continue; continue;
} }
@ -724,7 +726,7 @@ namespace MWRender
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error handling text key " << evt << ": " << e.what() << std::endl; Log(Debug::Error) << "Error handling text key " << evt << ": " << e.what();
} }
} }
} }
@ -1767,12 +1769,12 @@ namespace MWRender
PartHolder::~PartHolder() PartHolder::~PartHolder()
{ {
if (mNode.get() && !mNode->getNumParents()) if (mNode.get() && !mNode->getNumParents())
std::cerr << "Error: part has no parents " << std::endl; Log(Debug::Verbose) << "Part has no parents" ;
if (mNode.get() && mNode->getNumParents()) if (mNode.get() && mNode->getNumParents())
{ {
if (mNode->getNumParents() > 1) if (mNode->getNumParents() > 1)
std::cerr << "Error: part has multiple parents " << mNode->getNumParents() << " " << mNode.get() << std::endl; Log(Debug::Verbose) << "Part has multiple (" << mNode->getNumParents() << ") parents";
mNode->getParent(0)->removeChild(mNode); mNode->getParent(0)->removeChild(mNode);
} }
} }

@ -1,12 +1,12 @@
#include "bulletdebugdraw.hpp" #include "bulletdebugdraw.hpp"
#include <iostream>
#include <BulletCollision/CollisionDispatch/btCollisionWorld.h> #include <BulletCollision/CollisionDispatch/btCollisionWorld.h>
#include <osg/Geometry> #include <osg/Geometry>
#include <osg/Group> #include <osg/Group>
#include <components/debug/debuglog.hpp>
#include "vismask.hpp" #include "vismask.hpp"
namespace namespace
@ -91,7 +91,7 @@ void DebugDrawer::drawContactPoint(const btVector3 &PointOnB, const btVector3 &n
void DebugDrawer::reportErrorWarning(const char *warningString) void DebugDrawer::reportErrorWarning(const char *warningString)
{ {
std::cerr << warningString << std::endl; Log(Debug::Warning) << warningString;
} }
void DebugDrawer::setDebugMode(int isOn) void DebugDrawer::setDebugMode(int isOn)

@ -1,7 +1,6 @@
#include "characterpreview.hpp" #include "characterpreview.hpp"
#include <cmath> #include <cmath>
#include <iostream>
#include <osg/Material> #include <osg/Material>
#include <osg/Fog> #include <osg/Fog>
@ -14,6 +13,7 @@
#include <osgUtil/IntersectionVisitor> #include <osgUtil/IntersectionVisitor>
#include <osgUtil/LineSegmentIntersector> #include <osgUtil/LineSegmentIntersector>
#include <components/debug/debuglog.hpp>
#include <components/fallback/fallback.hpp> #include <components/fallback/fallback.hpp>
#include <components/sceneutil/lightmanager.hpp> #include <components/sceneutil/lightmanager.hpp>
@ -474,7 +474,7 @@ namespace MWRender
mCamera->addUpdateCallback(mUpdateCameraCallback); mCamera->addUpdateCallback(mUpdateCameraCallback);
} }
else else
std::cerr << "Error: Bip01 Head node not found" << std::endl; Log(Debug::Error) << "Error: Bip01 Head node not found";
} }
} }

@ -1,11 +1,9 @@
#include "creatureanimation.hpp" #include "creatureanimation.hpp"
#include <iostream>
#include <osg/MatrixTransform> #include <osg/MatrixTransform>
#include <components/esm/loadcrea.hpp> #include <components/esm/loadcrea.hpp>
#include <components/debug/debuglog.hpp>
#include <components/resource/resourcesystem.hpp> #include <components/resource/resourcesystem.hpp>
#include <components/resource/scenemanager.hpp> #include <components/resource/scenemanager.hpp>
#include <components/sceneutil/attach.hpp> #include <components/sceneutil/attach.hpp>
@ -155,7 +153,7 @@ void CreatureWeaponAnimation::updatePart(PartHolderPtr& scene, int slot)
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Can not add creature part: " << e.what() << std::endl; Log(Debug::Error) << "Can not add creature part: " << e.what();
} }
} }

@ -15,6 +15,8 @@
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
#include <components/files/memorystream.hpp> #include <components/files/memorystream.hpp>
#include <components/debug/debuglog.hpp>
#include <components/sceneutil/workqueue.hpp> #include <components/sceneutil/workqueue.hpp>
#include <components/esm/globalmap.hpp> #include <components/esm/globalmap.hpp>
@ -411,14 +413,14 @@ namespace MWRender
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("png"); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("png");
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Can't write map overlay: no png readerwriter found" << std::endl; Log(Debug::Error) << "Error: Can't write map overlay: no png readerwriter found";
return; return;
} }
osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(*mOverlayImage, ostream); osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(*mOverlayImage, ostream);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Can't write map overlay: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Warning) << "Error: Can't write map overlay: " << result.message() << " code " << result.status();
return; return;
} }
@ -463,14 +465,14 @@ namespace MWRender
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("png"); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("png");
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Can't read map overlay: no png readerwriter found" << std::endl; Log(Debug::Error) << "Error: Can't read map overlay: no png readerwriter found";
return; return;
} }
osgDB::ReaderWriter::ReadResult result = readerwriter->readImage(istream); osgDB::ReaderWriter::ReadResult result = readerwriter->readImage(istream);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Can't read map overlay: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Can't read map overlay: " << result.message() << " code " << result.status();
return; return;
} }
@ -572,7 +574,7 @@ namespace MWRender
CameraVector::iterator found = std::find(mActiveCameras.begin(), mActiveCameras.end(), camera); CameraVector::iterator found = std::find(mActiveCameras.begin(), mActiveCameras.end(), camera);
if (found == mActiveCameras.end()) if (found == mActiveCameras.end())
{ {
std::cerr << "Error: GlobalMap trying to remove an inactive camera" << std::endl; Log(Debug::Error) << "Error: GlobalMap trying to remove an inactive camera";
return; return;
} }
mActiveCameras.erase(found); mActiveCameras.erase(found);

@ -1,6 +1,5 @@
#include "localmap.hpp" #include "localmap.hpp"
#include <iostream>
#include <stdint.h> #include <stdint.h>
#include <osg/Fog> #include <osg/Fog>
@ -12,6 +11,7 @@
#include <osgDB/ReadFile> #include <osgDB/ReadFile>
#include <components/debug/debuglog.hpp>
#include <components/esm/fogstate.hpp> #include <components/esm/fogstate.hpp>
#include <components/esm/loadcell.hpp> #include <components/esm/loadcell.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
@ -320,7 +320,7 @@ void LocalMap::markForRemoval(osg::Camera *cam)
CameraVector::iterator found = std::find(mActiveCameras.begin(), mActiveCameras.end(), cam); CameraVector::iterator found = std::find(mActiveCameras.begin(), mActiveCameras.end(), cam);
if (found == mActiveCameras.end()) if (found == mActiveCameras.end())
{ {
std::cerr << "Error: trying to remove an inactive camera" << std::endl; Log(Debug::Error) << "Error: trying to remove an inactive camera";
return; return;
} }
mActiveCameras.erase(found); mActiveCameras.erase(found);
@ -492,7 +492,7 @@ void LocalMap::requestInteriorMap(const MWWorld::CellStore* cell)
// We are using the same bounds and angle as we were using when the textures were originally made. Segments should come out the same. // We are using the same bounds and angle as we were using when the textures were originally made. Segments should come out the same.
if (i >= int(fog->mFogTextures.size())) if (i >= int(fog->mFogTextures.size()))
{ {
std::cout << "Error: fog texture count mismatch" << std::endl; Log(Debug::Warning) << "Warning: fog texture count mismatch";
break; break;
} }
@ -684,7 +684,7 @@ void LocalMap::MapSegment::loadFogOfWar(const ESM::FogTexture &esm)
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("tga"); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("tga");
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Unable to load fog, can't find a tga ReaderWriter" << std::endl; Log(Debug::Error) << "Error: Unable to load fog, can't find a tga ReaderWriter" ;
return; return;
} }
@ -693,7 +693,7 @@ void LocalMap::MapSegment::loadFogOfWar(const ESM::FogTexture &esm)
osgDB::ReaderWriter::ReadResult result = readerwriter->readImage(in); osgDB::ReaderWriter::ReadResult result = readerwriter->readImage(in);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Failed to read fog: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Failed to read fog: " << result.message() << " code " << result.status();
return; return;
} }
@ -716,7 +716,7 @@ void LocalMap::MapSegment::saveFogOfWar(ESM::FogTexture &fog) const
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("tga"); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("tga");
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Unable to write fog, can't find a tga ReaderWriter" << std::endl; Log(Debug::Error) << "Error: Unable to write fog, can't find a tga ReaderWriter";
return; return;
} }
@ -725,7 +725,7 @@ void LocalMap::MapSegment::saveFogOfWar(ESM::FogTexture &fog) const
osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(*mFogOfWarImage, ostream); osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(*mFogOfWarImage, ostream);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Unable to write fog: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Unable to write fog: " << result.message() << " code " << result.status();
return; return;
} }
mFogOfWarImage->flipVertical(); mFogOfWarImage->flipVertical();

@ -7,6 +7,8 @@
#include <osgUtil/RenderBin> #include <osgUtil/RenderBin>
#include <osgUtil/CullVisitor> #include <osgUtil/CullVisitor>
#include <components/debug/debuglog.hpp>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/misc/resourcehelpers.hpp> #include <components/misc/resourcehelpers.hpp>
@ -435,7 +437,7 @@ void NpcAnimation::updateNpcBase()
if (bp) if (bp)
mHeadModel = "meshes\\" + bp->mModel; mHeadModel = "meshes\\" + bp->mModel;
else else
std::cerr << "Warning: Failed to load body part '" << mNpc->mHead << "'" << std::endl; Log(Debug::Warning) << "Warning: Failed to load body part '" << mNpc->mHead << "'";
} }
mHairModel = ""; mHairModel = "";
@ -445,7 +447,7 @@ void NpcAnimation::updateNpcBase()
if (bp) if (bp)
mHairModel = "meshes\\" + bp->mModel; mHairModel = "meshes\\" + bp->mModel;
else else
std::cerr << "Warning: Failed to load body part '" << mNpc->mHair << "'" << std::endl; Log(Debug::Warning) << "Warning: Failed to load body part '" << mNpc->mHair << "'";
} }
} }
@ -758,7 +760,7 @@ bool NpcAnimation::addOrReplaceIndividualPart(ESM::PartReferenceType type, int g
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error adding NPC part: " << e.what() << std::endl; Log(Debug::Error) << "Error adding NPC part: " << e.what();
return false; return false;
} }
@ -845,7 +847,7 @@ void NpcAnimation::addPartGroup(int group, int priority, const std::vector<ESM::
bodypart = NULL; bodypart = NULL;
} }
else if (!bodypart) else if (!bodypart)
std::cerr << "Warning: Failed to find body part '" << part->mFemale << "'" << std::endl; Log(Debug::Warning) << "Warning: Failed to find body part '" << part->mFemale << "'";
} }
if(!bodypart && !part->mMale.empty()) if(!bodypart && !part->mMale.empty())
{ {
@ -860,7 +862,7 @@ void NpcAnimation::addPartGroup(int group, int priority, const std::vector<ESM::
bodypart = NULL; bodypart = NULL;
} }
else if (!bodypart) else if (!bodypart)
std::cerr << "Warning: Failed to find body part '" << part->mMale << "'" << std::endl; Log(Debug::Warning) << "Warning: Failed to find body part '" << part->mMale << "'";
} }
if(bodypart) if(bodypart)

@ -22,6 +22,8 @@
#include <osgViewer/Viewer> #include <osgViewer/Viewer>
#include <components/debug/debuglog.hpp>
#include <components/resource/resourcesystem.hpp> #include <components/resource/resourcesystem.hpp>
#include <components/resource/imagemanager.hpp> #include <components/resource/imagemanager.hpp>
#include <components/resource/scenemanager.hpp> #include <components/resource/scenemanager.hpp>
@ -709,7 +711,7 @@ namespace MWRender
if (!found) if (!found)
{ {
std::cerr << "Wrong screenshot type: " << settingArgs[0] << "." << std::endl; Log(Debug::Warning) << "Wrong screenshot type: " << settingArgs[0] << ".";
return false; return false;
} }
} }
@ -728,7 +730,7 @@ namespace MWRender
if (mCamera->isVanityOrPreviewModeEnabled()) if (mCamera->isVanityOrPreviewModeEnabled())
{ {
std::cerr << "Spherical screenshots are not allowed in preview mode." << std::endl; Log(Debug::Warning) << "Spherical screenshots are not allowed in preview mode.";
return false; return false;
} }

@ -19,6 +19,8 @@
#include <osgUtil/IncrementalCompileOperation> #include <osgUtil/IncrementalCompileOperation>
#include <osgUtil/CullVisitor> #include <osgUtil/CullVisitor>
#include <components/debug/debuglog.hpp>
#include <components/resource/resourcesystem.hpp> #include <components/resource/resourcesystem.hpp>
#include <components/resource/imagemanager.hpp> #include <components/resource/imagemanager.hpp>
#include <components/resource/scenemanager.hpp> #include <components/resource/scenemanager.hpp>
@ -29,7 +31,6 @@
#include <components/shader/shadermanager.hpp> #include <components/shader/shadermanager.hpp>
#include <components/esm/loadcell.hpp> #include <components/esm/loadcell.hpp>
#include <components/fallback/fallback.hpp> #include <components/fallback/fallback.hpp>
@ -193,16 +194,16 @@ osg::ref_ptr<osg::Image> readPngImage (const std::string& file)
boost::filesystem::ifstream inStream; boost::filesystem::ifstream inStream;
inStream.open(file, std::ios_base::in | std::ios_base::binary); inStream.open(file, std::ios_base::in | std::ios_base::binary);
if (inStream.fail()) if (inStream.fail())
std::cerr << "Error: Failed to open " << file << std::endl; Log(Debug::Error) << "Error: Failed to open " << file;
osgDB::ReaderWriter* reader = osgDB::Registry::instance()->getReaderWriterForExtension("png"); osgDB::ReaderWriter* reader = osgDB::Registry::instance()->getReaderWriterForExtension("png");
if (!reader) if (!reader)
{ {
std::cerr << "Error: Failed to read " << file << ", no png readerwriter found" << std::endl; Log(Debug::Error) << "Error: Failed to read " << file << ", no png readerwriter found";
return osg::ref_ptr<osg::Image>(); return osg::ref_ptr<osg::Image>();
} }
osgDB::ReaderWriter::ReadResult result = reader->readImage(inStream); osgDB::ReaderWriter::ReadResult result = reader->readImage(inStream);
if (!result.success()) if (!result.success())
std::cerr << "Error: Failed to read " << file << ": " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Failed to read " << file << ": " << result.message() << " code " << result.status();
return result.getImage(); return result.getImage();
} }

@ -1,7 +1,8 @@
#include "aiextensions.hpp" #include "aiextensions.hpp"
#include <stdexcept> #include <stdexcept>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/compiler/extensions.hpp> #include <components/compiler/extensions.hpp>
#include <components/compiler/opcodes.hpp> #include <components/compiler/opcodes.hpp>
@ -50,7 +51,7 @@ namespace MWScript
MWMechanics::AiActivate activatePackage(objectID); MWMechanics::AiActivate activatePackage(objectID);
ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(activatePackage, ptr); ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(activatePackage, ptr);
std::cout << "AiActivate" << std::endl; Log(Debug::Info) << "AiActivate";
} }
}; };
@ -78,7 +79,7 @@ namespace MWScript
MWMechanics::AiTravel travelPackage(x, y, z); MWMechanics::AiTravel travelPackage(x, y, z);
ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(travelPackage, ptr); ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(travelPackage, ptr);
std::cout << "AiTravel: " << x << ", " << y << ", " << z << std::endl; Log(Debug::Info) << "AiTravel: " << x << ", " << y << ", " << z;
} }
}; };
@ -112,8 +113,7 @@ namespace MWScript
MWMechanics::AiEscort escortPackage(actorID, static_cast<int>(duration), x, y, z); MWMechanics::AiEscort escortPackage(actorID, static_cast<int>(duration), x, y, z);
ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(escortPackage, ptr); ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(escortPackage, ptr);
std::cout << "AiEscort: " << x << ", " << y << ", " << z << ", " << duration Log(Debug::Info) << "AiEscort: " << x << ", " << y << ", " << z << ", " << duration;
<< std::endl;
} }
}; };
@ -155,8 +155,7 @@ namespace MWScript
MWMechanics::AiEscort escortPackage(actorID, cellID, static_cast<int>(duration), x, y, z); MWMechanics::AiEscort escortPackage(actorID, cellID, static_cast<int>(duration), x, y, z);
ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(escortPackage, ptr); ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(escortPackage, ptr);
std::cout << "AiEscort: " << x << ", " << y << ", " << z << ", " << duration Log(Debug::Info) << "AiEscort: " << x << ", " << y << ", " << z << ", " << duration;
<< std::endl;
} }
}; };
@ -316,8 +315,7 @@ namespace MWScript
MWMechanics::AiFollow followPackage(actorID, duration, x, y ,z); MWMechanics::AiFollow followPackage(actorID, duration, x, y ,z);
ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(followPackage, ptr); ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(followPackage, ptr);
std::cout << "AiFollow: " << actorID << ", " << x << ", " << y << ", " << z << ", " << duration Log(Debug::Info) << "AiFollow: " << actorID << ", " << x << ", " << y << ", " << z << ", " << duration;
<< std::endl;
} }
}; };
@ -353,8 +351,7 @@ namespace MWScript
MWMechanics::AiFollow followPackage(actorID, cellID, duration, x, y ,z); MWMechanics::AiFollow followPackage(actorID, cellID, duration, x, y ,z);
ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(followPackage, ptr); ptr.getClass().getCreatureStats (ptr).getAiSequence().stack(followPackage, ptr);
std::cout << "AiFollow: " << actorID << ", " << x << ", " << y << ", " << z << ", " << duration Log(Debug::Info) << "AiFollow: " << actorID << ", " << x << ", " << y << ", " << z << ", " << duration;
<< std::endl;
} }
}; };

@ -6,6 +6,8 @@
#include <MyGUI_LanguageManager.h> #include <MyGUI_LanguageManager.h>
#include <components/debug/debuglog.hpp>
#include <components/compiler/extensions.hpp> #include <components/compiler/extensions.hpp>
#include <components/compiler/opcodes.hpp> #include <components/compiler/opcodes.hpp>
@ -190,8 +192,8 @@ namespace MWScript
if (it == invStore.end()) if (it == invStore.end())
{ {
it = ptr.getClass().getContainerStore (ptr).add (item, 1, ptr); it = ptr.getClass().getContainerStore (ptr).add (item, 1, ptr);
std::cerr << "Implicitly adding one " << item << " to container " Log(Debug::Warning) << "Implicitly adding one " << item << " to container "
"to fulfil requirements of Equip instruction" << std::endl; "to fulfil requirements of Equip instruction";
} }
if (ptr == MWMechanics::getPlayer()) if (ptr == MWMechanics::getPlayer())

@ -1,10 +1,8 @@
#include <iostream>
#include "dialogueextensions.hpp" #include "dialogueextensions.hpp"
#include <components/compiler/extensions.hpp> #include <components/compiler/extensions.hpp>
#include <components/compiler/opcodes.hpp> #include <components/compiler/opcodes.hpp>
#include <components/debug/debuglog.hpp>
#include <components/interpreter/interpreter.hpp> #include <components/interpreter/interpreter.hpp>
#include <components/interpreter/runtime.hpp> #include <components/interpreter/runtime.hpp>
#include <components/interpreter/opcodes.hpp> #include <components/interpreter/opcodes.hpp>
@ -139,8 +137,8 @@ namespace MWScript
if (!ptr.getClass().isActor()) if (!ptr.getClass().isActor())
{ {
const std::string error = "Warning: \"forcegreeting\" command works only for actors."; const std::string error = "Warning: \"forcegreeting\" command works only for actors.";
runtime.getContext().report (error); runtime.getContext().report(error);
std::cerr << error << std::endl; Log(Debug::Warning) << error;
return; return;
} }

@ -1,8 +1,8 @@
#include "globalscripts.hpp" #include "globalscripts.hpp"
#include <cassert> #include <cassert>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
#include <components/esm/globalscript.hpp> #include <components/esm/globalscript.hpp>
@ -113,9 +113,9 @@ namespace MWScript
} }
catch (const std::exception& exception) catch (const std::exception& exception)
{ {
std::cerr Log(Debug::Error)
<< "Failed to add start script " << *iter << " because an exception has " << "Failed to add start script " << *iter << " because an exception has "
<< "been thrown: " << exception.what() << std::endl; << "been thrown: " << exception.what();
} }
} }
} }
@ -169,10 +169,9 @@ namespace MWScript
} }
catch (const std::exception& exception) catch (const std::exception& exception)
{ {
std::cerr Log(Debug::Error)
<< "Failed to add start script " << script.mId << "Failed to add start script " << script.mId
<< " because an exception has been thrown: " << exception.what() << " because an exception has been thrown: " << exception.what();
<< std::endl;
return true; return true;
} }

@ -3,7 +3,7 @@
#include <components/esm/loadscpt.hpp> #include <components/esm/loadscpt.hpp>
#include <components/esm/variant.hpp> #include <components/esm/variant.hpp>
#include <components/esm/locals.hpp> #include <components/esm/locals.hpp>
#include <components/debug/debuglog.hpp>
#include <components/compiler/locals.hpp> #include <components/compiler/locals.hpp>
#include <components/compiler/exception.hpp> #include <components/compiler/exception.hpp>
@ -229,10 +229,10 @@ namespace MWScript
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Failed to read local variable state for script '" Log(Debug::Error) << "Failed to read local variable state for script '"
<< script << "' (legacy format): " << e.what() << script << "' (legacy format): " << e.what()
<< "\nNum shorts: " << numshorts << " / " << mShorts.size() << "\nNum shorts: " << numshorts << " / " << mShorts.size()
<< " Num longs: " << numlongs << " / " << mLongs.size() << std::endl; << " Num longs: " << numlongs << " / " << mLongs.size();
} }
} }
else else

@ -1,11 +1,12 @@
#include "scriptmanagerimp.hpp" #include "scriptmanagerimp.hpp"
#include <cassert> #include <cassert>
#include <iostream>
#include <sstream> #include <sstream>
#include <exception> #include <exception>
#include <algorithm> #include <algorithm>
#include <components/debug/debuglog.hpp>
#include <components/esm/loadscpt.hpp> #include <components/esm/loadscpt.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
@ -65,14 +66,14 @@ namespace MWScript
} }
catch (const std::exception& error) catch (const std::exception& error)
{ {
std::cerr << "Error: An exception has been thrown: " << error.what() << std::endl; Log(Debug::Error) << "Error: An exception has been thrown: " << error.what();
Success = false; Success = false;
} }
if (!Success) if (!Success)
{ {
std::cerr Log(Debug::Warning)
<< "Warning: compiling failed: " << name << std::endl; << "Warning: compiling failed: " << name;
} }
if (Success) if (Success)
@ -121,8 +122,8 @@ namespace MWScript
} }
catch (const std::exception& e) catch (const std::exception& e)
{ {
std::cerr << "Execution of script " << name << " failed:" << std::endl; Log(Debug::Error) << "Execution of script " << name << " failed:";
std::cerr << e.what() << std::endl; Log(Debug::Error) << e.what();
iter->second.first.clear(); // don't execute again. iter->second.first.clear(); // don't execute again.
} }

@ -1,6 +1,5 @@
#include "statsextensions.hpp" #include "statsextensions.hpp"
#include <iostream>
#include <cmath> #include <cmath>
#include <components/esm/loadnpc.hpp> #include <components/esm/loadnpc.hpp>
@ -9,7 +8,7 @@
#include <components/compiler/extensions.hpp> #include <components/compiler/extensions.hpp>
#include <components/compiler/opcodes.hpp> #include <components/compiler/opcodes.hpp>
#include <components/debug/debuglog.hpp>
#include <components/interpreter/interpreter.hpp> #include <components/interpreter/interpreter.hpp>
#include <components/interpreter/runtime.hpp> #include <components/interpreter/runtime.hpp>
#include <components/interpreter/opcodes.hpp> #include <components/interpreter/opcodes.hpp>
@ -246,9 +245,10 @@ namespace MWScript
if (R()(runtime, false, true).isEmpty()) if (R()(runtime, false, true).isEmpty())
{ {
std::cerr Log(Debug::Warning)
<< "Warning: Compensating for broken script in Morrowind.esm by " << "Warning: Compensating for broken script in Morrowind.esm by "
<< "ignoring remote access to dagoth_ur_1" << std::endl; << "ignoring remote access to dagoth_ur_1";
return; return;
} }
} }

@ -1,4 +1,4 @@
#include <iostream> #include <components/debug/debuglog.hpp>
#include <components/sceneutil/positionattitudetransform.hpp> #include <components/sceneutil/positionattitudetransform.hpp>
@ -317,7 +317,7 @@ namespace MWScript
{ {
std::string error = "Warning: PositionCell: unknown interior cell (" + cellID + "), moving to exterior instead"; std::string error = "Warning: PositionCell: unknown interior cell (" + cellID + "), moving to exterior instead";
runtime.getContext().report (error); runtime.getContext().report (error);
std::cerr << error << std::endl; Log(Debug::Warning) << error;
} }
} }
if(store) if(store)
@ -429,7 +429,7 @@ namespace MWScript
if(!cell) if(!cell)
{ {
runtime.getContext().report ("unknown cell (" + cellID + ")"); runtime.getContext().report ("unknown cell (" + cellID + ")");
std::cerr << "unknown cell (" << cellID << ")\n"; Log(Debug::Error) << "Error: unknown cell (" << cellID << ")";
} }
} }
if(store) if(store)

@ -3,9 +3,9 @@
#include <memory> #include <memory>
#include <stdexcept> #include <stdexcept>
#include <iostream>
#include <algorithm> #include <algorithm>
#include <components/debug/debuglog.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
namespace MWSound namespace MWSound
@ -28,7 +28,7 @@ int FFmpeg_Decoder::readPacket(void *user_data, uint8_t *buf, int buf_size)
int FFmpeg_Decoder::writePacket(void *, uint8_t *, int) int FFmpeg_Decoder::writePacket(void *, uint8_t *, int)
{ {
std::cerr<< "can't write to read-only stream" <<std::endl; Log(Debug::Error) << "can't write to read-only stream";
return -1; return -1;
} }
@ -343,7 +343,7 @@ void FFmpeg_Decoder::getInfo(int *samplerate, ChannelConfig *chans, SampleType *
char str[1024]; char str[1024];
av_get_channel_layout_string(str, sizeof(str), (*mStream)->codec->channels, av_get_channel_layout_string(str, sizeof(str), (*mStream)->codec->channels,
(*mStream)->codec->channel_layout); (*mStream)->codec->channel_layout);
std::cerr<< "Unsupported channel layout: "<<str <<std::endl; Log(Debug::Error) << "Unsupported channel layout: "<< str;
if((*mStream)->codec->channels == 1) if((*mStream)->codec->channels == 1)
{ {
@ -385,7 +385,7 @@ size_t FFmpeg_Decoder::read(char *buffer, size_t bytes)
{ {
if(!mStream) if(!mStream)
{ {
std::cerr<< "No audio stream" <<std::endl; Log(Debug::Error) << "No audio stream";
return 0; return 0;
} }
return readAVAudioData(buffer, bytes); return readAVAudioData(buffer, bytes);
@ -395,7 +395,7 @@ void FFmpeg_Decoder::readAll(std::vector<char> &output)
{ {
if(!mStream) if(!mStream)
{ {
std::cerr<< "No audio stream" <<std::endl; Log(Debug::Error) << "No audio stream";
return; return;
} }

@ -1,6 +1,5 @@
#include <algorithm> #include <algorithm>
#include <stdexcept> #include <stdexcept>
#include <iostream>
#include <cstring> #include <cstring>
#include <vector> #include <vector>
#include <memory> #include <memory>
@ -8,6 +7,7 @@
#include <stdint.h> #include <stdint.h>
#include <components/debug/debuglog.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
#include <OpenThreads/Thread> #include <OpenThreads/Thread>
@ -44,8 +44,7 @@ ALCenum checkALCError(ALCdevice *device, const char *func, int line)
{ {
ALCenum err = alcGetError(device); ALCenum err = alcGetError(device);
if(err != ALC_NO_ERROR) if(err != ALC_NO_ERROR)
std::cerr<< ">>>>>>>>> ALC error "<<alcGetString(device, err)<<" ("<<err<<") @ "<< Log(Debug::Error) << "ALC error "<< alcGetString(device, err) << " (" << err << ") @ " << func << ":" << line;
func<<":"<<line <<std::endl;
return err; return err;
} }
#define getALCError(d) checkALCError((d), __FUNCTION__, __LINE__) #define getALCError(d) checkALCError((d), __FUNCTION__, __LINE__)
@ -54,8 +53,7 @@ ALenum checkALError(const char *func, int line)
{ {
ALenum err = alGetError(); ALenum err = alGetError();
if(err != AL_NO_ERROR) if(err != AL_NO_ERROR)
std::cerr<< ">>>>>>>>> AL error "<<alGetString(err)<<" ("<<err<<") @ "<< Log(Debug::Error) << "AL error " << alGetString(err) << " (" << err << ") @ " << func << ":" << line;
func<<":"<<line <<std::endl;
return err; return err;
} }
#define getALError() checkALError(__FUNCTION__, __LINE__) #define getALError() checkALError(__FUNCTION__, __LINE__)
@ -256,8 +254,7 @@ static ALenum getALFormat(ChannelConfig chans, SampleType type)
} }
} }
std::cerr<< "Unsupported sound format ("<<getChannelConfigName(chans)<<", "<< Log(Debug::Warning) << "Unsupported sound format (" << getChannelConfigName(chans) << ", " << getSampleTypeName(type) << ")";
getSampleTypeName(type)<<")" <<std::endl;
return AL_NONE; return AL_NONE;
} }
@ -415,8 +412,9 @@ bool OpenAL_SoundStream::init(bool getLoudnessData)
mDecoder->getInfo(&mSampleRate, &chans, &type); mDecoder->getInfo(&mSampleRate, &chans, &type);
mFormat = getALFormat(chans, type); mFormat = getALFormat(chans, type);
} }
catch(std::exception &e) { catch(std::exception &e)
std::cerr<< "Failed to get stream info: "<<e.what() <<std::endl; {
Log(Debug::Error) << "Failed to get stream info: " << e.what();
return false; return false;
} }
@ -522,7 +520,7 @@ bool OpenAL_SoundStream::process()
} }
} }
catch(std::exception&) { catch(std::exception&) {
std::cout<< "Error updating stream \""<<mDecoder->getName()<<"\"" <<std::endl; Log(Debug::Error) << "Error updating stream \"" << mDecoder->getName() << "\"";
mIsFinished = true; mIsFinished = true;
} }
return !mIsFinished; return !mIsFinished;
@ -593,17 +591,18 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
{ {
deinit(); deinit();
std::cout<< "Initializing OpenAL..." <<std::endl; Log(Debug::Info) << "Initializing OpenAL...";
mDevice = alcOpenDevice(devname.c_str()); mDevice = alcOpenDevice(devname.c_str());
if(!mDevice && !devname.empty()) if(!mDevice && !devname.empty())
{ {
std::cerr<< "Failed to open \""<<devname<<"\", trying default" <<std::endl; Log(Debug::Warning) << "Failed to open \"" << devname << "\", trying default";
mDevice = alcOpenDevice(nullptr); mDevice = alcOpenDevice(nullptr);
} }
if(!mDevice) if(!mDevice)
{ {
std::cerr<< "Failed to open default audio device" <<std::endl; Log(Debug::Error) << "Failed to open default audio device";
return false; return false;
} }
@ -612,13 +611,13 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
name = alcGetString(mDevice, ALC_ALL_DEVICES_SPECIFIER); name = alcGetString(mDevice, ALC_ALL_DEVICES_SPECIFIER);
if(alcGetError(mDevice) != AL_NO_ERROR || !name) if(alcGetError(mDevice) != AL_NO_ERROR || !name)
name = alcGetString(mDevice, ALC_DEVICE_SPECIFIER); name = alcGetString(mDevice, ALC_DEVICE_SPECIFIER);
std::cout<< "Opened \""<<name<<"\"" <<std::endl; Log(Debug::Info) << "Opened \"" << name << "\"";
ALCint major=0, minor=0; ALCint major=0, minor=0;
alcGetIntegerv(mDevice, ALC_MAJOR_VERSION, 1, &major); alcGetIntegerv(mDevice, ALC_MAJOR_VERSION, 1, &major);
alcGetIntegerv(mDevice, ALC_MINOR_VERSION, 1, &minor); alcGetIntegerv(mDevice, ALC_MINOR_VERSION, 1, &minor);
std::cout<< " ALC Version: "<<major<<"."<<minor<<"\n"<< Log(Debug::Info) << " ALC Version: " << major << "." << minor <<"\n" <<
" ALC Extensions: "<<alcGetString(mDevice, ALC_EXTENSIONS) <<std::endl; " ALC Extensions: " << alcGetString(mDevice, ALC_EXTENSIONS);
ALC.EXT_EFX = alcIsExtensionPresent(mDevice, "ALC_EXT_EFX"); ALC.EXT_EFX = alcIsExtensionPresent(mDevice, "ALC_EXT_EFX");
ALC.SOFT_HRTF = alcIsExtensionPresent(mDevice, "ALC_SOFT_HRTF"); ALC.SOFT_HRTF = alcIsExtensionPresent(mDevice, "ALC_SOFT_HRTF");
@ -650,7 +649,7 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
} }
if(index < 0) if(index < 0)
std::cerr<< "Failed to find HRTF \""<<hrtfname<<"\", using default" <<std::endl; Log(Debug::Warning) << "Failed to find HRTF \"" << hrtfname << "\", using default";
else else
{ {
attrs.push_back(ALC_HRTF_ID_SOFT); attrs.push_back(ALC_HRTF_ID_SOFT);
@ -663,7 +662,7 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
mContext = alcCreateContext(mDevice, attrs.data()); mContext = alcCreateContext(mDevice, attrs.data());
if(!mContext || alcMakeContextCurrent(mContext) == ALC_FALSE) if(!mContext || alcMakeContextCurrent(mContext) == ALC_FALSE)
{ {
std::cerr<< "Failed to setup audio context: "<<alcGetString(mDevice, alcGetError(mDevice)) <<std::endl; Log(Debug::Error) << "Failed to setup audio context: "<<alcGetString(mDevice, alcGetError(mDevice));
if(mContext) if(mContext)
alcDestroyContext(mContext); alcDestroyContext(mContext);
mContext = nullptr; mContext = nullptr;
@ -672,23 +671,23 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
return false; return false;
} }
std::cout<< " Vendor: "<<alGetString(AL_VENDOR)<<"\n"<< Log(Debug::Info) << " Vendor: "<<alGetString(AL_VENDOR)<<"\n"<<
" Renderer: "<<alGetString(AL_RENDERER)<<"\n"<< " Renderer: "<<alGetString(AL_RENDERER)<<"\n"<<
" Version: "<<alGetString(AL_VERSION)<<"\n"<< " Version: "<<alGetString(AL_VERSION)<<"\n"<<
" Extensions: "<<alGetString(AL_EXTENSIONS)<<std::endl; " Extensions: "<<alGetString(AL_EXTENSIONS);
if(!ALC.SOFT_HRTF) if(!ALC.SOFT_HRTF)
std::cout<< "HRTF status unavailable" <<std::endl; Log(Debug::Warning) << "HRTF status unavailable";
else else
{ {
ALCint hrtf_state; ALCint hrtf_state;
alcGetIntegerv(mDevice, ALC_HRTF_SOFT, 1, &hrtf_state); alcGetIntegerv(mDevice, ALC_HRTF_SOFT, 1, &hrtf_state);
if(!hrtf_state) if(!hrtf_state)
std::cout<< "HRTF disabled" <<std::endl; Log(Debug::Info) << "HRTF disabled";
else else
{ {
const ALCchar *hrtf = alcGetString(mDevice, ALC_HRTF_SPECIFIER_SOFT); const ALCchar *hrtf = alcGetString(mDevice, ALC_HRTF_SPECIFIER_SOFT);
std::cout<< "Enabled HRTF "<<hrtf <<std::endl; Log(Debug::Info) << "Enabled HRTF " << hrtf;
} }
} }
@ -716,7 +715,7 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
} }
if(mFreeSources.empty()) if(mFreeSources.empty())
{ {
std::cerr<< "Could not allocate any sound sources" <<std::endl; Log(Debug::Warning) << "Could not allocate any sound sourcess";
alcMakeContextCurrent(nullptr); alcMakeContextCurrent(nullptr);
alcDestroyContext(mContext); alcDestroyContext(mContext);
mContext = nullptr; mContext = nullptr;
@ -724,7 +723,7 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
mDevice = nullptr; mDevice = nullptr;
return false; return false;
} }
std::cout<< "Allocated "<<mFreeSources.size()<<" sound sources" <<std::endl; Log(Debug::Info) << "Allocated " << mFreeSources.size() << " sound sources";
if(ALC.EXT_EFX) if(ALC.EXT_EFX)
{ {
@ -775,7 +774,7 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
alFilteri(mWaterFilter, AL_FILTER_TYPE, AL_FILTER_LOWPASS); alFilteri(mWaterFilter, AL_FILTER_TYPE, AL_FILTER_LOWPASS);
if(alGetError() == AL_NO_ERROR) if(alGetError() == AL_NO_ERROR)
{ {
std::cout<< "Low-pass filter supported" <<std::endl; Log(Debug::Info) << "Low-pass filter supported";
alFilterf(mWaterFilter, AL_LOWPASS_GAIN, 0.9f); alFilterf(mWaterFilter, AL_LOWPASS_GAIN, 0.9f);
alFilterf(mWaterFilter, AL_LOWPASS_GAINHF, 0.125f); alFilterf(mWaterFilter, AL_LOWPASS_GAINHF, 0.125f);
} }
@ -795,12 +794,12 @@ bool OpenAL_Output::init(const std::string &devname, const std::string &hrtfname
{ {
alEffecti(mDefaultEffect, AL_EFFECT_TYPE, AL_EFFECT_EAXREVERB); alEffecti(mDefaultEffect, AL_EFFECT_TYPE, AL_EFFECT_EAXREVERB);
if(alGetError() == AL_NO_ERROR) if(alGetError() == AL_NO_ERROR)
std::cout<< "EAX Reverb supported" <<std::endl; Log(Debug::Info) << "EAX Reverb supported";
else else
{ {
alEffecti(mDefaultEffect, AL_EFFECT_TYPE, AL_EFFECT_REVERB); alEffecti(mDefaultEffect, AL_EFFECT_TYPE, AL_EFFECT_REVERB);
if(alGetError() == AL_NO_ERROR) if(alGetError() == AL_NO_ERROR)
std::cout<< "Standard Reverb supported" <<std::endl; Log(Debug::Info) << "Standard Reverb supported";
} }
EFXEAXREVERBPROPERTIES props = EFX_REVERB_PRESET_GENERIC; EFXEAXREVERBPROPERTIES props = EFX_REVERB_PRESET_GENERIC;
props.flGain = 0.0f; props.flGain = 0.0f;
@ -891,7 +890,7 @@ void OpenAL_Output::setHrtf(const std::string &hrtfname, HrtfMode hrtfmode)
{ {
if(!mDevice || !ALC.SOFT_HRTF) if(!mDevice || !ALC.SOFT_HRTF)
{ {
std::cerr<< "HRTF extension not present" <<std::endl; Log(Debug::Info) << "HRTF extension not present";
return; return;
} }
@ -924,7 +923,7 @@ void OpenAL_Output::setHrtf(const std::string &hrtfname, HrtfMode hrtfmode)
} }
if(index < 0) if(index < 0)
std::cerr<< "Failed to find HRTF name \""<<hrtfname<<"\", using default" <<std::endl; Log(Debug::Warning) << "Failed to find HRTF name \"" << hrtfname << "\", using default";
else else
{ {
attrs.push_back(ALC_HRTF_ID_SOFT); attrs.push_back(ALC_HRTF_ID_SOFT);
@ -937,11 +936,11 @@ void OpenAL_Output::setHrtf(const std::string &hrtfname, HrtfMode hrtfmode)
ALCint hrtf_state; ALCint hrtf_state;
alcGetIntegerv(mDevice, ALC_HRTF_SOFT, 1, &hrtf_state); alcGetIntegerv(mDevice, ALC_HRTF_SOFT, 1, &hrtf_state);
if(!hrtf_state) if(!hrtf_state)
std::cout<< "HRTF disabled" <<std::endl; Log(Debug::Info) << "HRTF disabled";
else else
{ {
const ALCchar *hrtf = alcGetString(mDevice, ALC_HRTF_SPECIFIER_SOFT); const ALCchar *hrtf = alcGetString(mDevice, ALC_HRTF_SPECIFIER_SOFT);
std::cout<< "Enabled HRTF "<<hrtf <<std::endl; Log(Debug::Info) << "Enabled HRTF " << hrtf;
} }
} }
@ -977,7 +976,7 @@ std::pair<Sound_Handle,size_t> OpenAL_Output::loadSound(const std::string &fname
} }
catch(std::exception &e) catch(std::exception &e)
{ {
std::cerr<< "Failed to load audio from "<<fname<<": "<<e.what() <<std::endl; Log(Debug::Error) << "Failed to load audio from " << fname << ": " << e.what();
} }
if(data.empty()) if(data.empty())
@ -1139,7 +1138,7 @@ bool OpenAL_Output::playSound(Sound *sound, Sound_Handle data, float offset)
if(mFreeSources.empty()) if(mFreeSources.empty())
{ {
std::cerr<< "No free sources!" <<std::endl; Log(Debug::Warning) << "No free sources!";
return false; return false;
} }
source = mFreeSources.front(); source = mFreeSources.front();
@ -1168,7 +1167,7 @@ bool OpenAL_Output::playSound3D(Sound *sound, Sound_Handle data, float offset)
if(mFreeSources.empty()) if(mFreeSources.empty())
{ {
std::cerr<< "No free sources!" <<std::endl; Log(Debug::Warning) << "No free sources!";
return false; return false;
} }
source = mFreeSources.front(); source = mFreeSources.front();
@ -1236,13 +1235,14 @@ bool OpenAL_Output::streamSound(DecoderPtr decoder, Stream *sound)
{ {
if(mFreeSources.empty()) if(mFreeSources.empty())
{ {
std::cerr<< "No free sources!" <<std::endl; Log(Debug::Warning) << "No free sources!";
return false; return false;
} }
ALuint source = mFreeSources.front(); ALuint source = mFreeSources.front();
if(sound->getIsLooping()) if(sound->getIsLooping())
std::cout <<"Warning: cannot loop stream \""<<decoder->getName()<<"\""<< std::endl; Log(Debug::Warning) << "Warning: cannot loop stream \"" << decoder->getName() << "\"";
initCommon2D(source, sound->getPosition(), sound->getRealVolume(), sound->getPitch(), initCommon2D(source, sound->getPosition(), sound->getRealVolume(), sound->getPitch(),
false, sound->getUseEnv()); false, sound->getUseEnv());
if(getALError() != AL_NO_ERROR) if(getALError() != AL_NO_ERROR)
@ -1266,13 +1266,14 @@ bool OpenAL_Output::streamSound3D(DecoderPtr decoder, Stream *sound, bool getLou
{ {
if(mFreeSources.empty()) if(mFreeSources.empty())
{ {
std::cerr<< "No free sources!" <<std::endl; Log(Debug::Warning) << "No free sources!";
return false; return false;
} }
ALuint source = mFreeSources.front(); ALuint source = mFreeSources.front();
if(sound->getIsLooping()) if(sound->getIsLooping())
std::cout <<"Warning: cannot loop stream \""<<decoder->getName()<<"\""<< std::endl; Log(Debug::Warning) << "Warning: cannot loop stream \"" << decoder->getName() << "\"";
initCommon3D(source, sound->getPosition(), sound->getMinDistance(), sound->getMaxDistance(), initCommon3D(source, sound->getPosition(), sound->getMinDistance(), sound->getMaxDistance(),
sound->getRealVolume(), sound->getPitch(), false, sound->getUseEnv()); sound->getRealVolume(), sound->getPitch(), false, sound->getUseEnv());
if(getALError() != AL_NO_ERROR) if(getALError() != AL_NO_ERROR)

@ -1,6 +1,5 @@
#include "soundmanagerimp.hpp" #include "soundmanagerimp.hpp"
#include <iostream>
#include <algorithm> #include <algorithm>
#include <map> #include <map>
#include <numeric> #include <numeric>
@ -8,7 +7,7 @@
#include <osg/Matrixf> #include <osg/Matrixf>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/debug/debuglog.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
@ -81,7 +80,7 @@ namespace MWSound
if(!useSound) if(!useSound)
{ {
std::cout<< "Sound disabled." <<std::endl; Log(Debug::Info) << "Sound disabled.";
return; return;
} }
@ -93,23 +92,28 @@ namespace MWSound
std::string devname = Settings::Manager::getString("device", "Sound"); std::string devname = Settings::Manager::getString("device", "Sound");
if(!mOutput->init(devname, hrtfname, hrtfmode)) if(!mOutput->init(devname, hrtfname, hrtfmode))
{ {
std::cerr<< "Failed to initialize audio output, sound disabled" <<std::endl; Log(Debug::Error) << "Failed to initialize audio output, sound disabled";
return; return;
} }
std::vector<std::string> names = mOutput->enumerate(); std::vector<std::string> names = mOutput->enumerate();
std::cout <<"Enumerated output devices:\n"; std::stringstream stream;
stream << "Enumerated output devices:\n";
for(const std::string &name : names) for(const std::string &name : names)
std::cout <<" "<<name<<"\n"; stream << " " << name;
std::cout.flush();
Log(Debug::Info) << stream.str();
stream.str("");
names = mOutput->enumerateHrtf(); names = mOutput->enumerateHrtf();
if(!names.empty()) if(!names.empty())
{ {
std::cout<< "Enumerated HRTF names:\n"; stream << "Enumerated HRTF names:\n";
for(const std::string &name : names) for(const std::string &name : names)
std::cout <<" "<<name<<"\n"; stream << " " << name;
std::cout.flush();
Log(Debug::Info) << stream.str();
} }
} }
@ -221,7 +225,7 @@ namespace MWSound
do { do {
if(mUnusedBuffers.empty()) if(mUnusedBuffers.empty())
{ {
std::cerr<< "No unused sound buffers to free, using "<<mBufferCacheSize<<" bytes!" <<std::endl; Log(Debug::Warning) << "No unused sound buffers to free, using " << mBufferCacheSize << " bytes!";
break; break;
} }
Sound_Buffer *unused = mUnusedBuffers.back(); Sound_Buffer *unused = mUnusedBuffers.back();
@ -360,7 +364,7 @@ namespace MWSound
{ {
if(!mOutput->isInitialized()) if(!mOutput->isInitialized())
return; return;
std::cout <<"Playing "<<filename<< std::endl; Log(Debug::Info) << "Playing " << filename;
mLastPlayedMusic = filename; mLastPlayedMusic = filename;
stopMusic(); stopMusic();

@ -1,5 +1,7 @@
#include "statemanagerimp.hpp" #include "statemanagerimp.hpp"
#include <components/debug/debuglog.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
#include <components/esm/cellid.hpp> #include <components/esm/cellid.hpp>
@ -157,7 +159,7 @@ void MWState::StateManager::newGame (bool bypass)
std::stringstream error; std::stringstream error;
error << "Failed to start new game: " << e.what(); error << "Failed to start new game: " << e.what();
std::cerr << error.str() << std::endl; Log(Debug::Error) << error.str();
cleanup (true); cleanup (true);
MWBase::Environment::get().getWindowManager()->pushGuiMode (MWGui::GM_MainMenu); MWBase::Environment::get().getWindowManager()->pushGuiMode (MWGui::GM_MainMenu);
@ -283,7 +285,7 @@ void MWState::StateManager::saveGame (const std::string& description, const Slot
// Ensure we have written the number of records that was estimated // Ensure we have written the number of records that was estimated
if (writer.getRecordCount() != recordCount+1) // 1 extra for TES3 record if (writer.getRecordCount() != recordCount+1) // 1 extra for TES3 record
std::cerr << "Warning: number of written savegame records does not match. Estimated: " << recordCount+1 << ", written: " << writer.getRecordCount() << std::endl; Log(Debug::Warning) << "Warning: number of written savegame records does not match. Estimated: " << recordCount+1 << ", written: " << writer.getRecordCount();
writer.close(); writer.close();
@ -305,7 +307,7 @@ void MWState::StateManager::saveGame (const std::string& description, const Slot
std::stringstream error; std::stringstream error;
error << "Failed to save game: " << e.what(); error << "Failed to save game: " << e.what();
std::cerr << error.str() << std::endl; Log(Debug::Error) << error.str();
std::vector<std::string> buttons; std::vector<std::string> buttons;
buttons.push_back("#{sOk}"); buttons.push_back("#{sOk}");
@ -483,7 +485,7 @@ void MWState::StateManager::loadGame (const Character *character, const std::str
default: default:
// ignore invalid records // ignore invalid records
std::cerr << "Warning: Ignoring unknown record: " << n.toString() << std::endl; Log(Debug::Warning) << "Warning: Ignoring unknown record: " << n.toString();
reader.skipRecord(); reader.skipRecord();
} }
int progressPercent = static_cast<int>(float(reader.getFileOffset())/total*100); int progressPercent = static_cast<int>(float(reader.getFileOffset())/total*100);
@ -549,7 +551,7 @@ void MWState::StateManager::loadGame (const Character *character, const std::str
std::stringstream error; std::stringstream error;
error << "Failed to load saved game: " << e.what(); error << "Failed to load saved game: " << e.what();
std::cerr << error.str() << std::endl; Log(Debug::Error) << error.str();
cleanup (true); cleanup (true);
MWBase::Environment::get().getWindowManager()->pushGuiMode (MWGui::GM_MainMenu); MWBase::Environment::get().getWindowManager()->pushGuiMode (MWGui::GM_MainMenu);
@ -625,7 +627,7 @@ bool MWState::StateManager::verifyProfile(const ESM::SavedGame& profile) const
if (std::find(selectedContentFiles.begin(), selectedContentFiles.end(), *it) if (std::find(selectedContentFiles.begin(), selectedContentFiles.end(), *it)
== selectedContentFiles.end()) == selectedContentFiles.end())
{ {
std::cerr << "Warning: Savegame dependency " << *it << " is missing." << std::endl; Log(Debug::Warning) << "Warning: Savegame dependency " << *it << " is missing.";
notFound = true; notFound = true;
} }
} }
@ -653,7 +655,7 @@ void MWState::StateManager::writeScreenshot(std::vector<char> &imageData) const
osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("jpg"); osgDB::ReaderWriter* readerwriter = osgDB::Registry::instance()->getReaderWriterForExtension("jpg");
if (!readerwriter) if (!readerwriter)
{ {
std::cerr << "Error: Unable to write screenshot, can't find a jpg ReaderWriter" << std::endl; Log(Debug::Error) << "Error: Unable to write screenshot, can't find a jpg ReaderWriter";
return; return;
} }
@ -661,7 +663,7 @@ void MWState::StateManager::writeScreenshot(std::vector<char> &imageData) const
osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(*screenshot, ostream); osgDB::ReaderWriter::WriteResult result = readerwriter->writeImage(*screenshot, ostream);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error: Unable to write screenshot: " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error: Unable to write screenshot: " << result.message() << " code " << result.status();
return; return;
} }

@ -1,7 +1,6 @@
#include "cellpreloader.hpp" #include "cellpreloader.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include <components/resource/scenemanager.hpp> #include <components/resource/scenemanager.hpp>
#include <components/resource/resourcesystem.hpp> #include <components/resource/resourcesystem.hpp>
#include <components/resource/bulletshapemanager.hpp> #include <components/resource/bulletshapemanager.hpp>
@ -229,12 +228,12 @@ namespace MWWorld
{ {
if (!mWorkQueue) if (!mWorkQueue)
{ {
std::cerr << "Error: can't preload, no work queue set " << std::endl; Log(Debug::Error) << "Error: can't preload, no work queue set";
return; return;
} }
if (cell->getState() == CellStore::State_Unloaded) if (cell->getState() == CellStore::State_Unloaded)
{ {
std::cerr << "Error: can't preload objects for unloaded cell" << std::endl; Log(Debug::Error) << "Error: can't preload objects for unloaded cell";
return; return;
} }

@ -1,7 +1,6 @@
#include "cells.hpp" #include "cells.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
#include <components/esm/defs.hpp> #include <components/esm/defs.hpp>
@ -350,7 +349,7 @@ bool MWWorld::Cells::readRecord (ESM::ESMReader& reader, uint32_t type,
catch (...) catch (...)
{ {
// silently drop cells that don't exist anymore // silently drop cells that don't exist anymore
std::cerr << "Warning: Dropping state for cell " << state.mId.mWorldspace << " (cell no longer exists)" << std::endl; Log(Debug::Warning) << "Warning: Dropping state for cell " << state.mId.mWorldspace << " (cell no longer exists)";
reader.skipRecord(); reader.skipRecord();
return true; return true;
} }

@ -1,8 +1,9 @@
#include "cellstore.hpp" #include "cellstore.hpp"
#include <iostream>
#include <algorithm> #include <algorithm>
#include <components/debug/debuglog.hpp>
#include <components/esm/cellstate.hpp> #include <components/esm/cellstate.hpp>
#include <components/esm/cellid.hpp> #include <components/esm/cellid.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
@ -138,7 +139,7 @@ namespace
return; return;
} }
std::cerr << "Warning: Dropping reference to " << state.mRef.mRefID << " (invalid content file link)" << std::endl; Log(Debug::Warning) << "Warning: Dropping reference to " << state.mRef.mRefID << " (invalid content file link)";
return; return;
} }
@ -196,9 +197,9 @@ namespace MWWorld
} }
else else
{ {
std::cerr Log(Debug::Warning)
<< "Warning: could not resolve cell reference '" << ref.mRefID << "'" << "Warning: could not resolve cell reference '" << ref.mRefID << "'"
<< " (dropping reference)" << std::endl; << " (dropping reference)";
} }
} }
@ -497,7 +498,7 @@ namespace MWWorld
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "An error occurred listing references for cell " << getCell()->getDescription() << ": " << e.what() << std::endl; Log(Debug::Error) << "An error occurred listing references for cell " << getCell()->getDescription() << ": " << e.what();
} }
} }
@ -553,7 +554,7 @@ namespace MWWorld
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "An error occurred loading references for cell " << getCell()->getDescription() << ": " << e.what() << std::endl; Log(Debug::Error) << "An error occurred loading references for cell " << getCell()->getDescription() << ": " << e.what();
} }
} }
@ -659,11 +660,10 @@ namespace MWWorld
case ESM::REC_WEAP: mWeapons.load(ref, deleted, store); break; case ESM::REC_WEAP: mWeapons.load(ref, deleted, store); break;
case ESM::REC_BODY: mBodyParts.load(ref, deleted, store); break; case ESM::REC_BODY: mBodyParts.load(ref, deleted, store); break;
case 0: std::cerr << "Cell reference '" + ref.mRefID + "' not found!\n"; return; case 0: Log(Debug::Error) << "Cell reference '" + ref.mRefID + "' not found!"; return;
default: default:
std::cerr Log(Debug::Error) << "Error: Ignoring reference '" << ref.mRefID << "' of unhandled type";
<< "Error: Ignoring reference '" << ref.mRefID << "' of unhandled type\n";
return; return;
} }
@ -756,7 +756,7 @@ namespace MWWorld
int type = MWBase::Environment::get().getWorld()->getStore().find(cref.mRefID); int type = MWBase::Environment::get().getWorld()->getStore().find(cref.mRefID);
if (type == 0) if (type == 0)
{ {
std::cerr << "Dropping reference to '" << cref.mRefID << "' (object no longer exists)" << std::endl; Log(Debug::Warning) << "Dropping reference to '" << cref.mRefID << "' (object no longer exists)";
reader.skipHSubUntil("OBJE"); reader.skipHSubUntil("OBJE");
continue; continue;
} }
@ -892,7 +892,7 @@ namespace MWWorld
if (!visitor.mFound) if (!visitor.mFound)
{ {
std::cerr << "Warning: Dropping moved ref tag for " << refnum.mIndex << " (moved object no longer exists)" << std::endl; Log(Debug::Warning) << "Warning: Dropping moved ref tag for " << refnum.mIndex << " (moved object no longer exists)";
continue; continue;
} }
@ -902,8 +902,8 @@ namespace MWWorld
if (otherCell == NULL) if (otherCell == NULL)
{ {
std::cerr << "Warning: Dropping moved ref tag for " << movedRef->mRef.getRefId() Log(Debug::Warning) << "Warning: Dropping moved ref tag for " << movedRef->mRef.getRefId()
<< " (target cell " << movedTo.mWorldspace << " no longer exists). Reference moved back to its original location." << std::endl; << " (target cell " << movedTo.mWorldspace << " no longer exists). Reference moved back to its original location.";
// Note by dropping tag the object will automatically re-appear in its original cell, though potentially at inapproriate coordinates. // Note by dropping tag the object will automatically re-appear in its original cell, though potentially at inapproriate coordinates.
// Restore original coordinates: // Restore original coordinates:
movedRef->mData.setPosition(movedRef->mRef.getPosition()); movedRef->mData.setPosition(movedRef->mRef.getPosition());
@ -913,7 +913,7 @@ namespace MWWorld
if (otherCell == this) if (otherCell == this)
{ {
// Should never happen unless someone's tampering with files. // Should never happen unless someone's tampering with files.
std::cerr << "Found invalid moved ref, ignoring" << std::endl; Log(Debug::Warning) << "Found invalid moved ref, ignoring";
continue; continue;
} }

@ -4,6 +4,7 @@
#include <typeinfo> #include <typeinfo>
#include <stdexcept> #include <stdexcept>
#include <components/debug/debuglog.hpp>
#include <components/esm/inventorystate.hpp> #include <components/esm/inventorystate.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
@ -502,7 +503,7 @@ void MWWorld::ContainerStore::addInitialItem (const std::string& id, const std::
} }
catch (const std::exception& e) catch (const std::exception& e)
{ {
std::cerr << "Warning: MWWorld::ContainerStore::addInitialItem: " << e.what() << std::endl; Log(Debug::Warning) << "Warning: MWWorld::ContainerStore::addInitialItem: " << e.what();
} }
} }
@ -826,10 +827,10 @@ void MWWorld::ContainerStore::readState (const ESM::InventoryState& inventory)
case ESM::REC_WEAP: readEquipmentState (getState (weapons, state), thisIndex, inventory); break; case ESM::REC_WEAP: readEquipmentState (getState (weapons, state), thisIndex, inventory); break;
case ESM::REC_LIGH: readEquipmentState (getState (lights, state), thisIndex, inventory); break; case ESM::REC_LIGH: readEquipmentState (getState (lights, state), thisIndex, inventory); break;
case 0: case 0:
std::cerr << "Dropping inventory reference to '" << state.mRef.mRefID << "' (object no longer exists)" << std::endl; Log(Debug::Warning) << "Dropping inventory reference to '" << state.mRef.mRefID << "' (object no longer exists)";
break; break;
default: default:
std::cerr << "Warning: Invalid item type in inventory state, refid " << state.mRef.mRefID << std::endl; Log(Debug::Warning) << "Warning: Invalid item type in inventory state, refid " << state.mRef.mRefID;
break; break;
} }
} }

@ -2,10 +2,10 @@
#define CONTENTLOADER_HPP #define CONTENTLOADER_HPP
#include <iosfwd> #include <iosfwd>
#include <iostream>
#include <boost/filesystem/path.hpp> #include <boost/filesystem/path.hpp>
#include <MyGUI_TextIterator.h> #include <MyGUI_TextIterator.h>
#include <components/debug/debuglog.hpp>
#include "components/loadinglistener/loadinglistener.hpp" #include "components/loadinglistener/loadinglistener.hpp"
namespace MWWorld namespace MWWorld
@ -24,8 +24,8 @@ struct ContentLoader
virtual void load(const boost::filesystem::path& filepath, int& index) virtual void load(const boost::filesystem::path& filepath, int& index)
{ {
std::cout << "Loading content file " << filepath.string() << std::endl; Log(Debug::Info) << "Loading content file " << filepath.string();
mListener.setLabel(MyGUI::TextIterator::toTagsString(filepath.string())); mListener.setLabel(MyGUI::TextIterator::toTagsString(filepath.string()));
} }
protected: protected:

@ -1,12 +1,11 @@
#include "esmstore.hpp" #include "esmstore.hpp"
#include <set> #include <set>
#include <iostream>
#include <boost/filesystem/operations.hpp> #include <boost/filesystem/operations.hpp>
#include <components/debug/debuglog.hpp>
#include <components/loadinglistener/loadinglistener.hpp> #include <components/loadinglistener/loadinglistener.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
@ -84,7 +83,7 @@ void ESMStore::load(ESM::ESMReader &esm, Loading::Listener* listener)
} }
else else
{ {
std::cerr << "error: info record without dialog" << std::endl; Log(Debug::Error) << "Error: info record without dialog";
esm.skipRecord(); esm.skipRecord();
} }
} else if (n.intval == ESM::REC_MGEF) { } else if (n.intval == ESM::REC_MGEF) {
@ -170,7 +169,7 @@ void ESMStore::validate()
const ESM::Faction *fact = mFactions.search(npcFaction); const ESM::Faction *fact = mFactions.search(npcFaction);
if (!fact) if (!fact)
{ {
std::cerr << "NPC '" << npc.mId << "' (" << npc.mName << ") has nonexistent faction '" << npc.mFaction << "', ignoring it." << std::endl; Log(Debug::Verbose) << "NPC '" << npc.mId << "' (" << npc.mName << ") has nonexistent faction '" << npc.mFaction << "', ignoring it.";
npc.mFaction = ""; npc.mFaction = "";
npc.mNpdt.mRank = -1; npc.mNpdt.mRank = -1;
changed = true; changed = true;
@ -183,7 +182,7 @@ void ESMStore::validate()
const ESM::Class *cls = mClasses.search(npcClass); const ESM::Class *cls = mClasses.search(npcClass);
if (!cls) if (!cls)
{ {
std::cerr << "NPC '" << npc.mId << "' (" << npc.mName << ") has nonexistent class '" << npc.mClass << "', using '" << defaultCls << "' class as replacement." << std::endl; Log(Debug::Verbose) << "NPC '" << npc.mId << "' (" << npc.mName << ") has nonexistent class '" << npc.mClass << "', using '" << defaultCls << "' class as replacement.";
npc.mClass = defaultCls; npc.mClass = defaultCls;
changed = true; changed = true;
} }

@ -3,6 +3,7 @@
#include <iterator> #include <iterator>
#include <algorithm> #include <algorithm>
#include <components/debug/debuglog.hpp>
#include <components/esm/loadench.hpp> #include <components/esm/loadench.hpp>
#include <components/esm/inventorystate.hpp> #include <components/esm/inventorystate.hpp>
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
@ -895,7 +896,7 @@ void MWWorld::InventoryStore::updateRechargingItems()
enchantmentId); enchantmentId);
if (!enchantment) if (!enchantment)
{ {
std::cerr << "Warning: Can't find enchantment '" << enchantmentId << "' on item " << it->getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Warning: Can't find enchantment '" << enchantmentId << "' on item " << it->getCellRef().getRefId();
continue; continue;
} }

@ -1,7 +1,6 @@
#include "livecellref.hpp" #include "livecellref.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include <components/esm/objectstate.hpp> #include <components/esm/objectstate.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
@ -38,10 +37,9 @@ void MWWorld::LiveCellRefBase::loadImp (const ESM::ObjectState& state)
} }
catch (const std::exception& exception) catch (const std::exception& exception)
{ {
std::cerr Log(Debug::Error)
<< "Error: failed to load state for local script " << scriptId << "Error: failed to load state for local script " << scriptId
<< " because an exception has been thrown: " << exception.what() << " because an exception has been thrown: " << exception.what();
<< std::endl;
} }
} }
} }
@ -51,7 +49,7 @@ void MWWorld::LiveCellRefBase::loadImp (const ESM::ObjectState& state)
if (!mRef.getSoul().empty() && !MWBase::Environment::get().getWorld()->getStore().get<ESM::Creature>().search(mRef.getSoul())) if (!mRef.getSoul().empty() && !MWBase::Environment::get().getWorld()->getStore().get<ESM::Creature>().search(mRef.getSoul()))
{ {
std::cerr << "Soul '" << mRef.getSoul() << "' not found, removing the soul from soul gem" << std::endl; Log(Debug::Warning) << "Soul '" << mRef.getSoul() << "' not found, removing the soul from soul gem";
mRef.setSoul(std::string()); mRef.setSoul(std::string());
} }
} }

@ -1,14 +1,12 @@
#include "localscripts.hpp" #include "localscripts.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "esmstore.hpp" #include "esmstore.hpp"
#include "cellstore.hpp" #include "cellstore.hpp"
#include "class.hpp" #include "class.hpp"
#include "containerstore.hpp" #include "containerstore.hpp"
namespace namespace
{ {
@ -93,7 +91,7 @@ void MWWorld::LocalScripts::add (const std::string& scriptName, const Ptr& ptr)
for (std::list<std::pair<std::string, Ptr> >::iterator iter = mScripts.begin(); iter!=mScripts.end(); ++iter) for (std::list<std::pair<std::string, Ptr> >::iterator iter = mScripts.begin(); iter!=mScripts.end(); ++iter)
if (iter->second==ptr) if (iter->second==ptr)
{ {
std::cerr << "Error: tried to add local script twice for " << ptr.getCellRef().getRefId() << std::endl; Log(Debug::Warning) << "Error: tried to add local script twice for " << ptr.getCellRef().getRefId();
remove(ptr); remove(ptr);
break; break;
} }
@ -102,15 +100,15 @@ void MWWorld::LocalScripts::add (const std::string& scriptName, const Ptr& ptr)
} }
catch (const std::exception& exception) catch (const std::exception& exception)
{ {
std::cerr Log(Debug::Error)
<< "failed to add local script " << scriptName << "failed to add local script " << scriptName
<< " because an exception has been thrown: " << exception.what() << std::endl; << " because an exception has been thrown: " << exception.what();
} }
} }
else else
std::cerr Log(Debug::Warning)
<< "failed to add local script " << scriptName << "failed to add local script " << scriptName
<< " because the script does not exist." << std::endl; << " because the script does not exist.";
} }
void MWWorld::LocalScripts::addCell (CellStore *cell) void MWWorld::LocalScripts::addCell (CellStore *cell)

@ -1,7 +1,8 @@
#include "player.hpp" #include "player.hpp"
#include <stdexcept> #include <stdexcept>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
@ -364,7 +365,7 @@ namespace MWWorld
if (!player.mObject.mEnabled) if (!player.mObject.mEnabled)
{ {
std::cerr << "Warning: Savegame attempted to disable the player." << std::endl; Log(Debug::Warning) << "Warning: Savegame attempted to disable the player.";
player.mObject.mEnabled = true; player.mObject.mEnabled = true;
} }
@ -391,7 +392,7 @@ namespace MWWorld
} }
catch (...) catch (...)
{ {
std::cerr << "Warning: Player cell '" << player.mCellId.mWorldspace << "' no longer exists" << std::endl; Log(Debug::Warning) << "Warning: Player cell '" << player.mCellId.mWorldspace << "' no longer exists";
// Cell no longer exists. The loader will have to choose a default cell. // Cell no longer exists. The loader will have to choose a default cell.
mCellStore = NULL; mCellStore = NULL;
} }

@ -1,11 +1,12 @@
#include "projectilemanager.hpp" #include "projectilemanager.hpp"
#include <iomanip> #include <iomanip>
#include <iostream>
#include <osg/PositionAttitudeTransform> #include <osg/PositionAttitudeTransform>
#include <osg/ComputeBoundsVisitor> #include <osg/ComputeBoundsVisitor>
#include <components/debug/debuglog.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
#include <components/esm/projectilestate.hpp> #include <components/esm/projectilestate.hpp>
@ -647,7 +648,7 @@ namespace MWWorld
} }
catch(...) catch(...)
{ {
std::cerr << "Warning: Failed to recreate magic projectile from saved data (id \"" << state.mSpellId << "\" no longer exists?)" << std::endl; Log(Debug::Warning) << "Warning: Failed to recreate magic projectile from saved data (id \"" << state.mSpellId << "\" no longer exists?)";
return true; return true;
} }

@ -1,8 +1,8 @@
#include "scene.hpp" #include "scene.hpp"
#include <limits> #include <limits>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/loadinglistener/loadinglistener.hpp> #include <components/loadinglistener/loadinglistener.hpp>
#include <components/misc/resourcehelpers.hpp> #include <components/misc/resourcehelpers.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
@ -56,7 +56,7 @@ namespace
{ {
if (ptr.getRefData().getBaseNode() || physics.getActor(ptr)) if (ptr.getRefData().getBaseNode() || physics.getActor(ptr))
{ {
std::cerr << "Warning: Tried to add " << ptr.getCellRef().getRefId() << " to the scene twice" << std::endl; Log(Debug::Warning) << "Warning: Tried to add " << ptr.getCellRef().getRefId() << " to the scene twice";
return; return;
} }
@ -160,7 +160,7 @@ namespace
catch (const std::exception& e) catch (const std::exception& e)
{ {
std::string error ("failed to render '" + ptr.getCellRef().getRefId() + "': "); std::string error ("failed to render '" + ptr.getCellRef().getRefId() + "': ");
std::cerr << error + e.what() << std::endl; Log(Debug::Error) << error + e.what();
} }
} }
@ -232,7 +232,7 @@ namespace MWWorld
void Scene::unloadCell (CellStoreCollection::iterator iter) void Scene::unloadCell (CellStoreCollection::iterator iter)
{ {
std::cout << "Unloading cell\n"; Log(Debug::Info) << "Unloading cell " << (*iter)->getCell()->getDescription();
ListAndResetObjectsVisitor visitor; ListAndResetObjectsVisitor visitor;
(*iter)->forEach<ListAndResetObjectsVisitor>(visitor); (*iter)->forEach<ListAndResetObjectsVisitor>(visitor);
@ -270,7 +270,7 @@ namespace MWWorld
if(result.second) if(result.second)
{ {
std::cout << "Loading cell " << cell->getCell()->getDescription() << std::endl; Log(Debug::Info) << "Loading cell " << cell->getCell()->getDescription();
float verts = ESM::Land::LAND_SIZE; float verts = ESM::Land::LAND_SIZE;
float worldsize = ESM::Land::REAL_SIZE; float worldsize = ESM::Land::REAL_SIZE;
@ -546,7 +546,7 @@ namespace MWWorld
return; return;
} }
std::cout << "Changing to interior\n"; Log(Debug::Info) << "Changing to interior";
// unload // unload
CellStoreCollection::iterator active = mActiveCells.begin(); CellStoreCollection::iterator active = mActiveCells.begin();
@ -624,7 +624,7 @@ namespace MWWorld
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "failed to render '" << ptr.getCellRef().getRefId() << "': " << e.what() << std::endl; Log(Debug::Error) << "failed to render '" << ptr.getCellRef().getRefId() << "': " << e.what();
} }
} }

@ -1,5 +1,7 @@
#include "store.hpp" #include "store.hpp"
#include <components/debug/debuglog.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
@ -8,7 +10,6 @@
#include <stdexcept> #include <stdexcept>
#include <sstream> #include <sstream>
#include <iostream>
namespace namespace
{ {
@ -692,7 +693,7 @@ namespace MWWorld
if (it_lease != wipecell->mLeasedRefs.end()) if (it_lease != wipecell->mLeasedRefs.end())
wipecell->mLeasedRefs.erase(it_lease); wipecell->mLeasedRefs.erase(it_lease);
else else
std::cerr << "Error: can't find " << it->mRefNum.mIndex << " " << it->mRefNum.mContentFile << " in leasedRefs " << std::endl; Log(Debug::Error) << "Error: can't find " << it->mRefNum.mIndex << " " << it->mRefNum.mContentFile << " in leasedRefs";
} }
*itold = *it; *itold = *it;
} }

@ -3,6 +3,8 @@
#include <osg/Group> #include <osg/Group>
#include <osg/ComputeBoundsVisitor> #include <osg/ComputeBoundsVisitor>
#include <components/debug/debuglog.hpp>
#include <components/esm/esmreader.hpp> #include <components/esm/esmreader.hpp>
#include <components/esm/esmwriter.hpp> #include <components/esm/esmwriter.hpp>
#include <components/esm/cellid.hpp> #include <components/esm/cellid.hpp>
@ -1794,7 +1796,7 @@ namespace MWWorld
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error updating window manager: " << e.what() << std::endl; Log(Debug::Error) << "Error updating window manager: " << e.what();
} }
} }
@ -3075,7 +3077,7 @@ namespace MWWorld
if ( closestMarker.isEmpty() ) if ( closestMarker.isEmpty() )
{ {
std::cerr << "Failed to teleport: no closest marker found" << std::endl; Log(Debug::Warning) << "Failed to teleport: no closest marker found";
return; return;
} }
@ -3250,19 +3252,19 @@ namespace MWWorld
MWWorld::ConstPtr prisonMarker = getClosestMarker( ptr, "prisonmarker" ); MWWorld::ConstPtr prisonMarker = getClosestMarker( ptr, "prisonmarker" );
if ( prisonMarker.isEmpty() ) if ( prisonMarker.isEmpty() )
{ {
std::cerr << "Failed to confiscate items: no closest prison marker found." << std::endl; Log(Debug::Warning) << "Failed to confiscate items: no closest prison marker found.";
return; return;
} }
std::string prisonName = prisonMarker.getCellRef().getDestCell(); std::string prisonName = prisonMarker.getCellRef().getDestCell();
if ( prisonName.empty() ) if ( prisonName.empty() )
{ {
std::cerr << "Failed to confiscate items: prison marker not linked to prison interior" << std::endl; Log(Debug::Warning) << "Failed to confiscate items: prison marker not linked to prison interior";
return; return;
} }
MWWorld::CellStore *prison = getInterior( prisonName ); MWWorld::CellStore *prison = getInterior( prisonName );
if ( !prison ) if ( !prison )
{ {
std::cerr << "Failed to confiscate items: failed to load cell " << prisonName << std::endl; Log(Debug::Warning) << "Failed to confiscate items: failed to load cell " << prisonName;
return; return;
} }
@ -3272,7 +3274,7 @@ namespace MWWorld
MWBase::Environment::get().getMechanicsManager()->confiscateStolenItems(ptr, closestChest); MWBase::Environment::get().getMechanicsManager()->confiscateStolenItems(ptr, closestChest);
} }
else else
std::cerr << "Failed to confiscate items: no stolen_goods container found" << std::endl; Log(Debug::Warning) << "Failed to confiscate items: no stolen_goods container found";
} }
void World::goToJail() void World::goToJail()

@ -14,7 +14,7 @@
#include <stdbool.h> #include <stdbool.h>
#include <sys/ptrace.h> #include <sys/ptrace.h>
#include <iostream> #include <components/debug/debuglog.hpp>
#include <boost/filesystem/fstream.hpp> #include <boost/filesystem/fstream.hpp>
@ -185,7 +185,7 @@ static void gdb_info(pid_t pid)
if (close(fd) == 0) if (close(fd) == 0)
remove(respfile); remove(respfile);
else else
std::cerr << "Warning: can not close and remove file '" << respfile << "': " << std::strerror(errno) << std::endl; Log(Debug::Warning) << "Warning: can not close and remove file '" << respfile << "': " << std::strerror(errno);
} }
printf("!!! Could not create gdb command file\n"); printf("!!! Could not create gdb command file\n");
} }
@ -517,8 +517,9 @@ void crashCatcherInstall(int argc, char **argv, const std::string &crashLogPath)
int s[5] = { SIGSEGV, SIGILL, SIGFPE, SIGBUS, SIGABRT }; int s[5] = { SIGSEGV, SIGILL, SIGFPE, SIGBUS, SIGABRT };
if (crashCatcherInstallHandlers(argc, argv, 5, s, crashLogPath.c_str(), NULL) == -1) if (crashCatcherInstallHandlers(argc, argv, 5, s, crashLogPath.c_str(), NULL) == -1)
{ {
std::cerr << "Installing crash handler failed" << std::endl; Log(Debug::Warning) << "Installing crash handler failed";
} else }
std::cout << "Crash handler installed" << std::endl; else
Log(Debug::Info) << "Crash handler installed";
} }
} }

@ -2,7 +2,6 @@
#define DEBUG_LOG_H #define DEBUG_LOG_H
#include <mutex> #include <mutex>
#include <sstream>
#include <iostream> #include <iostream>
namespace Debug namespace Debug

@ -1,6 +1,6 @@
#include "cellref.hpp" #include "cellref.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
@ -48,9 +48,7 @@ void ESM::CellRef::loadId (ESMReader& esm, bool wideRefNum)
mRefID = esm.getHNOString ("NAME"); mRefID = esm.getHNOString ("NAME");
if (mRefID.empty()) if (mRefID.empty())
{ {
std::ios::fmtflags f(std::cerr.flags()); Log(Debug::Warning) << "Warning: got CellRef with empty RefId in " << esm.getName() << " 0x" << std::hex << esm.getFileOffset();
std::cerr << "Warning: got CellRef with empty RefId in " << esm.getName() << " 0x" << std::hex << esm.getFileOffset() << std::endl;
std::cerr.flags(f);
} }
} }

@ -1,6 +1,6 @@
#include "loadcrea.hpp" #include "loadcrea.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
@ -89,7 +89,7 @@ namespace ESM {
// seems to occur only in .ESS files, unsure of purpose // seems to occur only in .ESS files, unsure of purpose
int index; int index;
esm.getHT(index); esm.getHT(index);
std::cerr << "Creature::load: Unhandled INDX " << index << std::endl; Log(Debug::Warning) << "Creature::load: Unhandled INDX " << index;
break; break;
default: default:
esm.fail("Unknown subrecord"); esm.fail("Unknown subrecord");

@ -1,6 +1,6 @@
#include "loaddial.hpp" #include "loaddial.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
@ -128,7 +128,7 @@ namespace ESM
return; return;
} }
std::cerr << "Warning: Failed to insert info " << info.mId << std::endl; Log(Debug::Warning) << "Warning: Failed to insert info " << info.mId;
} }
void Dialogue::clearDeletedInfos() void Dialogue::clearDeletedInfos()

@ -1,11 +1,11 @@
#include "loadscpt.hpp" #include "loadscpt.hpp"
#include <components/debug/debuglog.hpp>
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp" #include "defs.hpp"
#include <iostream>
namespace ESM namespace ESM
{ {
unsigned int Script::sRecordId = REC_SCPT; unsigned int Script::sRecordId = REC_SCPT;
@ -45,12 +45,12 @@ namespace ESM
// an exeption, just log an error and continue. // an exeption, just log an error and continue.
std::stringstream ss; std::stringstream ss;
ss << "ESM Error: " << "String table overflow"; ss << "String table overflow";
ss << "\n File: " << esm.getName(); ss << "\n File: " << esm.getName();
ss << "\n Record: " << esm.getContext().recName.toString(); ss << "\n Record: " << esm.getContext().recName.toString();
ss << "\n Subrecord: " << "SCVR"; ss << "\n Subrecord: " << "SCVR";
ss << "\n Offset: 0x" << std::hex << esm.getFileOffset(); ss << "\n Offset: 0x" << std::hex << esm.getFileOffset();
std::cerr << ss.str() << std::endl; Log(Debug::Verbose) << ss.str();
break; break;
} }
@ -91,10 +91,10 @@ namespace ESM
if (subSize != static_cast<uint32_t>(mData.mScriptDataSize)) if (subSize != static_cast<uint32_t>(mData.mScriptDataSize))
{ {
std::stringstream ss; std::stringstream ss;
ss << "ESM Warning: Script data size defined in SCHD subrecord does not match size of SCDT subrecord"; ss << "Script data size defined in SCHD subrecord does not match size of SCDT subrecord";
ss << "\n File: " << esm.getName(); ss << "\n File: " << esm.getName();
ss << "\n Offset: 0x" << std::hex << esm.getFileOffset(); ss << "\n Offset: 0x" << std::hex << esm.getFileOffset();
std::cerr << ss.str() << std::endl; Log(Debug::Verbose) << ss.str();
} }
mScriptData.resize(subSize); mScriptData.resize(subSize);

@ -10,6 +10,7 @@
#include <boost/algorithm/string.hpp> #include <boost/algorithm/string.hpp>
#include <components/debug/debuglog.hpp>
#include <components/misc/resourcehelpers.hpp> #include <components/misc/resourcehelpers.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
@ -378,7 +379,7 @@ namespace ESMTerrain
const ESM::LandTexture* ltex = getLandTexture(id.first-1, id.second); const ESM::LandTexture* ltex = getLandTexture(id.first-1, id.second);
if (!ltex) if (!ltex)
{ {
std::cerr << "Warning: Unable to find land texture index " << id.first-1 << " in plugin " << id.second << ", using default texture instead" << std::endl; Log(Debug::Warning) << "Warning: Unable to find land texture index " << id.first-1 << " in plugin " << id.second << ", using default texture instead";
return defaultTexture; return defaultTexture;
} }

@ -1,7 +1,6 @@
#include "configurationmanager.hpp" #include "configurationmanager.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include <components/files/escape.hpp> #include <components/files/escape.hpp>
#include <boost/algorithm/string/erase.hpp> #include <boost/algorithm/string/erase.hpp>
@ -134,7 +133,7 @@ bool ConfigurationManager::loadConfig(const boost::filesystem::path& path,
if (boost::filesystem::is_regular_file(cfgFile)) if (boost::filesystem::is_regular_file(cfgFile))
{ {
if (!mSilent) if (!mSilent)
std::cout << "Loading config file: " << cfgFile.string() << "... "; Log(Debug::Info) << "Loading config file: " << cfgFile.string();
boost::filesystem::ifstream configFileStreamUnfiltered(cfgFile); boost::filesystem::ifstream configFileStreamUnfiltered(cfgFile);
boost::iostreams::filtering_istream configFileStream; boost::iostreams::filtering_istream configFileStream;
@ -145,14 +144,13 @@ bool ConfigurationManager::loadConfig(const boost::filesystem::path& path,
boost::program_options::store(boost::program_options::parse_config_file( boost::program_options::store(boost::program_options::parse_config_file(
configFileStream, description, true), variables); configFileStream, description, true), variables);
if (!mSilent)
std::cout << "done." << std::endl;
return true; return true;
} }
else else
{ {
if (!mSilent) if (!mSilent)
std::cout << "failed." << std::endl; Log(Debug::Error) << "Loading failed.";
return false; return false;
} }
} }

@ -1,9 +1,9 @@
#include "multidircollection.hpp" #include "multidircollection.hpp"
#include <iostream>
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include <components/debug/debuglog.hpp>
namespace Files namespace Files
{ {
struct NameEqual struct NameEqual
@ -46,7 +46,7 @@ namespace Files
{ {
if (!boost::filesystem::is_directory(*iter)) if (!boost::filesystem::is_directory(*iter))
{ {
std::cout << "Skipping invalid directory: " << (*iter).string() << std::endl; Log(Debug::Info) << "Skipping invalid directory: " << (*iter).string();
continue; continue;
} }

@ -14,6 +14,8 @@
#include <MyGUI_FactoryManager.h> #include <MyGUI_FactoryManager.h>
#include <MyGUI_RenderManager.h> #include <MyGUI_RenderManager.h>
#include <components/debug/debuglog.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
@ -281,7 +283,7 @@ namespace Gui
assert (image->isDataContiguous()); assert (image->isDataContiguous());
memcpy(image->data(), &textureData[0], textureData.size()); memcpy(image->data(), &textureData[0], textureData.size());
std::cout << "Writing " << resourceName + ".png" << std::endl; Log(Debug::Info) << "Writing " << resourceName + ".png";
osgDB::writeImageFile(*image, resourceName + ".png"); osgDB::writeImageFile(*image, resourceName + ".png");
} }
@ -461,7 +463,7 @@ namespace Gui
if (exportToFile) if (exportToFile)
{ {
std::cout << "Writing " << resourceName + ".xml" << std::endl; Log(Debug::Info) << "Writing " << resourceName + ".xml";
xmlDocument.createDeclaration(); xmlDocument.createDeclaration();
xmlDocument.save(resourceName + ".xml"); xmlDocument.save(resourceName + ".xml");
} }

@ -3,8 +3,8 @@
#include <sstream> #include <sstream>
#include <string> #include <string>
#include <vector> #include <vector>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
namespace Interpreter{ namespace Interpreter{
@ -191,8 +191,8 @@ namespace Interpreter{
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Error: Failed to replace escape character, with the following error: " << e.what() << std::endl; Log(Debug::Error) << "Error: Failed to replace escape character, with the following error: " << e.what();
std::cerr << "Full text below: " << std::endl << text << std::endl; Log(Debug::Error) << "Full text below:\n" << text;
} }
// Not found, or error // Not found, or error

@ -5,7 +5,7 @@
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include <boost/filesystem/fstream.hpp> #include <boost/filesystem/fstream.hpp>
#include <iostream> #include <components/debug/debuglog.hpp>
namespace osgMyGUI namespace osgMyGUI
{ {
@ -23,7 +23,7 @@ MyGUI::IDataStream *DataManager::getData(const std::string &name)
stream->open(fullpath, std::ios::binary); stream->open(fullpath, std::ios::binary);
if (stream->fail()) if (stream->fail())
{ {
std::cerr << "DataManager::getData: Failed to open '" << name << "'" << std::endl; Log(Debug::Error) << "DataManager::getData: Failed to open '" << name << "'";
return NULL; return NULL;
} }
return new MyGUI::DataFileStream(stream.release()); return new MyGUI::DataFileStream(stream.release());

@ -5,6 +5,7 @@
#include <osg/Texture2D> #include <osg/Texture2D>
#include <components/debug/debuglog.hpp>
#include <components/resource/imagemanager.hpp> #include <components/resource/imagemanager.hpp>
namespace osgMyGUI namespace osgMyGUI
@ -112,7 +113,7 @@ namespace osgMyGUI
void OSGTexture::saveToFile(const std::string &fname) void OSGTexture::saveToFile(const std::string &fname)
{ {
std::cerr << "Would save image to file " << fname << std::endl; Log(Debug::Warning) << "Would save image to file " << fname;
} }
int OSGTexture::getWidth() int OSGTexture::getWidth()

@ -5,8 +5,8 @@
#include <stdexcept> #include <stdexcept>
#include <vector> #include <vector>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/files/constrainedfilestream.hpp> #include <components/files/constrainedfilestream.hpp>
#include "record.hpp" #include "record.hpp"
@ -80,8 +80,7 @@ public:
/// Used when something goes wrong, but not catastrophically so /// Used when something goes wrong, but not catastrophically so
void warn(const std::string &msg) const override void warn(const std::string &msg) const override
{ {
std::cerr << " NIFFile Warning: " << msg <<std::endl Log(Debug::Warning) << " NIFFile Warning: " << msg << "\nFile: " << filename;
<< "File: " << filename <<std::endl;
} }
/// Open a NIF stream. The name is used for error messages. /// Open a NIF stream. The name is used for error messages.

@ -10,6 +10,8 @@
#include <BulletCollision/CollisionShapes/btScaledBvhTriangleMeshShape.h> #include <BulletCollision/CollisionShapes/btScaledBvhTriangleMeshShape.h>
#include <BulletCollision/CollisionShapes/btCompoundShape.h> #include <BulletCollision/CollisionShapes/btCompoundShape.h>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <components/nif/node.hpp> #include <components/nif/node.hpp>
@ -18,7 +20,6 @@
#include <components/nif/controller.hpp> #include <components/nif/controller.hpp>
#include <components/nif/extra.hpp> #include <components/nif/extra.hpp>
namespace namespace
{ {
@ -203,7 +204,7 @@ void BulletNifLoader::handleNode(const std::string& fileName, const Nif::Node *n
isCollisionNode = isCollisionNode || (node->recType == Nif::RC_RootCollisionNode); isCollisionNode = isCollisionNode || (node->recType == Nif::RC_RootCollisionNode);
if (node->recType == Nif::RC_RootCollisionNode && autogenerated) if (node->recType == Nif::RC_RootCollisionNode && autogenerated)
std::cerr << "Found RootCollisionNode attached to non-root node in " << fileName << ". Treat it as a common NiTriShape." << std::endl; Log(Debug::Info) << "Found RootCollisionNode attached to non-root node in " << fileName << ". Treat it as a common NiTriShape.";
// Don't collide with AvoidNode shapes // Don't collide with AvoidNode shapes
if(node->recType == Nif::RC_AvoidNode) if(node->recType == Nif::RC_AvoidNode)

@ -4,7 +4,6 @@
#include <cassert> #include <cassert>
#include <string> #include <string>
#include <set> #include <set>
#include <iostream>
#include <map> #include <map>
#include <osg/Matrixf> #include <osg/Matrixf>
@ -12,6 +11,7 @@
#include <osg/ref_ptr> #include <osg/ref_ptr>
#include <osg/Referenced> #include <osg/Referenced>
#include <components/debug/debuglog.hpp>
#include <components/nif/niffile.hpp> #include <components/nif/niffile.hpp>
#include <components/resource/bulletshape.hpp> #include <components/resource/bulletshape.hpp>
@ -41,12 +41,12 @@ public:
void warn(const std::string &msg) void warn(const std::string &msg)
{ {
std::cerr << "NIFLoader: Warn:" << msg << "\n"; Log(Debug::Warning) << "NIFLoader: Warn:" << msg;
} }
void fail(const std::string &msg) void fail(const std::string &msg)
{ {
std::cerr << "NIFLoader: Fail: "<< msg << std::endl; Log(Debug::Error) << "NIFLoader: Fail: "<< msg;
abort(); abort();
} }

@ -243,7 +243,7 @@ namespace NifOsg
callback->setFunction(std::shared_ptr<NifOsg::ControllerFunction>(new NifOsg::ControllerFunction(key))); callback->setFunction(std::shared_ptr<NifOsg::ControllerFunction>(new NifOsg::ControllerFunction(key)));
if (target.mKeyframeControllers.find(strdata->string) != target.mKeyframeControllers.end()) if (target.mKeyframeControllers.find(strdata->string) != target.mKeyframeControllers.end())
std::cerr << "Warning: controller " << strdata->string << " present more than once in " << nif->getFilename() << ", ignoring later version" << std::endl; Log(Debug::Verbose) << "Controller " << strdata->string << " present more than once in " << nif->getFilename() << ", ignoring later version";
else else
target.mKeyframeControllers[strdata->string] = callback; target.mKeyframeControllers[strdata->string] = callback;
} }
@ -357,20 +357,20 @@ namespace NifOsg
{ {
if (nifNode->recType != Nif::RC_NiTextureEffect) if (nifNode->recType != Nif::RC_NiTextureEffect)
{ {
std::cerr << "Unhandled effect " << nifNode->recName << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled effect " << nifNode->recName << " in " << mFilename;
return; return;
} }
const Nif::NiTextureEffect* textureEffect = static_cast<const Nif::NiTextureEffect*>(nifNode); const Nif::NiTextureEffect* textureEffect = static_cast<const Nif::NiTextureEffect*>(nifNode);
if (textureEffect->textureType != Nif::NiTextureEffect::Environment_Map) if (textureEffect->textureType != Nif::NiTextureEffect::Environment_Map)
{ {
std::cerr << "Unhandled NiTextureEffect type " << textureEffect->textureType << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled NiTextureEffect type " << textureEffect->textureType << " in " << mFilename;
return; return;
} }
if (textureEffect->texture.empty()) if (textureEffect->texture.empty())
{ {
std::cerr << "NiTextureEffect missing source texture in " << mFilename << std::endl; Log(Debug::Info) << "NiTextureEffect missing source texture in " << mFilename;
return; return;
} }
@ -387,7 +387,7 @@ namespace NifOsg
texGen->setMode(osg::TexGen::SPHERE_MAP); texGen->setMode(osg::TexGen::SPHERE_MAP);
break; break;
default: default:
std::cerr << "Unhandled NiTextureEffect coordGenType " << textureEffect->coordGenType << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled NiTextureEffect coordGenType " << textureEffect->coordGenType << " in " << mFilename;
return; return;
} }
@ -638,7 +638,7 @@ namespace NifOsg
else if(ctrl->recType == Nif::RC_NiGeomMorpherController) else if(ctrl->recType == Nif::RC_NiGeomMorpherController)
{} // handled in handleTriShape {} // handled in handleTriShape
else else
std::cerr << "Unhandled controller " << ctrl->recName << " on node " << nifNode->recIndex << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled controller " << ctrl->recName << " on node " << nifNode->recIndex << " in " << mFilename;
} }
} }
@ -664,7 +664,7 @@ namespace NifOsg
handleVisController(static_cast<const Nif::NiVisController*>(ctrl.getPtr()), transformNode, animflags); handleVisController(static_cast<const Nif::NiVisController*>(ctrl.getPtr()), transformNode, animflags);
} }
else else
std::cerr << "Unhandled controller " << ctrl->recName << " on node " << nifNode->recIndex << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled controller " << ctrl->recName << " on node " << nifNode->recIndex << " in " << mFilename;
} }
} }
@ -696,7 +696,7 @@ namespace NifOsg
composite->addController(osgctrl); composite->addController(osgctrl);
} }
else else
std::cerr << "Unexpected material controller " << ctrl->recType << " in " << mFilename << std::endl; Log(Debug::Info) << "Unexpected material controller " << ctrl->recType << " in " << mFilename;
} }
} }
@ -736,7 +736,7 @@ namespace NifOsg
composite->addController(callback); composite->addController(callback);
} }
else else
std::cerr << "Unexpected texture controller " << ctrl->recName << " in " << mFilename << std::endl; Log(Debug::Info) << "Unexpected texture controller " << ctrl->recName << " in " << mFilename;
} }
} }
@ -769,7 +769,7 @@ namespace NifOsg
// unused // unused
} }
else else
std::cerr << "Unhandled particle modifier " << affectors->recName << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled particle modifier " << affectors->recName << " in " << mFilename;
} }
for (; !colliders.empty(); colliders = colliders->extra) for (; !colliders.empty(); colliders = colliders->extra)
{ {
@ -784,7 +784,7 @@ namespace NifOsg
program->addOperator(new SphericalCollider(sphericalcollider)); program->addOperator(new SphericalCollider(sphericalcollider));
} }
else else
std::cerr << "Unhandled particle collider " << colliders->recName << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled particle collider " << colliders->recName << " in " << mFilename;
} }
} }
@ -881,11 +881,11 @@ namespace NifOsg
if(ctrl->recType == Nif::RC_NiParticleSystemController || ctrl->recType == Nif::RC_NiBSPArrayController) if(ctrl->recType == Nif::RC_NiParticleSystemController || ctrl->recType == Nif::RC_NiBSPArrayController)
partctrl = static_cast<Nif::NiParticleSystemController*>(ctrl.getPtr()); partctrl = static_cast<Nif::NiParticleSystemController*>(ctrl.getPtr());
else else
std::cerr << "Unhandled controller " << ctrl->recName << " on node " << nifNode->recIndex << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled controller " << ctrl->recName << " on node " << nifNode->recIndex << " in " << mFilename;
} }
if (!partctrl) if (!partctrl)
{ {
std::cerr << "No particle controller found in " << mFilename << std::endl; Log(Debug::Info) << "No particle controller found in " << mFilename;
return; return;
} }
@ -925,7 +925,7 @@ namespace NifOsg
rootNode->accept(find); rootNode->accept(find);
if (!find.mFound) if (!find.mFound)
{ {
std::cerr << "can't find emitter node, wrong node order? in " << mFilename << std::endl; Log(Debug::Info) << "can't find emitter node, wrong node order? in " << mFilename;
return; return;
} }
osg::Group* emitterNode = find.mFound; osg::Group* emitterNode = find.mFound;
@ -1121,7 +1121,7 @@ namespace NifOsg
case 9: return osg::BlendFunc::ONE_MINUS_DST_ALPHA; case 9: return osg::BlendFunc::ONE_MINUS_DST_ALPHA;
case 10: return osg::BlendFunc::SRC_ALPHA_SATURATE; case 10: return osg::BlendFunc::SRC_ALPHA_SATURATE;
default: default:
std::cerr<< "Unexpected blend mode: "<< mode << " in " << mFilename << std::endl; Log(Debug::Info) << "Unexpected blend mode: "<< mode << " in " << mFilename;
return osg::BlendFunc::SRC_ALPHA; return osg::BlendFunc::SRC_ALPHA;
} }
} }
@ -1139,7 +1139,7 @@ namespace NifOsg
case 6: return osg::AlphaFunc::GEQUAL; case 6: return osg::AlphaFunc::GEQUAL;
case 7: return osg::AlphaFunc::NEVER; case 7: return osg::AlphaFunc::NEVER;
default: default:
std::cerr << "Unexpected blend mode: " << mode << " in " << mFilename << std::endl; Log(Debug::Info) << "Unexpected blend mode: " << mode << " in " << mFilename;
return osg::AlphaFunc::LEQUAL; return osg::AlphaFunc::LEQUAL;
} }
} }
@ -1157,7 +1157,7 @@ namespace NifOsg
case 6: return osg::Stencil::GEQUAL; case 6: return osg::Stencil::GEQUAL;
case 7: return osg::Stencil::NEVER; // NifSkope says this is GL_ALWAYS, but in MW it's GL_NEVER case 7: return osg::Stencil::NEVER; // NifSkope says this is GL_ALWAYS, but in MW it's GL_NEVER
default: default:
std::cerr << "Unexpected stencil function: " << func << " in " << mFilename << std::endl; Log(Debug::Info) << "Unexpected stencil function: " << func << " in " << mFilename;
return osg::Stencil::NEVER; return osg::Stencil::NEVER;
} }
} }
@ -1173,7 +1173,7 @@ namespace NifOsg
case 4: return osg::Stencil::DECR; case 4: return osg::Stencil::DECR;
case 5: return osg::Stencil::INVERT; case 5: return osg::Stencil::INVERT;
default: default:
std::cerr << "Unexpected stencil operation: " << op << " in " << mFilename << std::endl; Log(Debug::Info) << "Unexpected stencil operation: " << op << " in " << mFilename;
return osg::Stencil::KEEP; return osg::Stencil::KEEP;
} }
} }
@ -1192,7 +1192,7 @@ namespace NifOsg
pixelformat = GL_RGBA; pixelformat = GL_RGBA;
break; break;
default: default:
std::cerr << "Unhandled internal pixel format " << pixelData->fmt << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled internal pixel format " << pixelData->fmt << " in " << mFilename;
return NULL; return NULL;
} }
@ -1210,7 +1210,7 @@ namespace NifOsg
size_t mipSize = mip.height * mip.width * pixelData->bpp / 8; size_t mipSize = mip.height * mip.width * pixelData->bpp / 8;
if (mipSize + mip.dataOffset > pixelData->data.size()) if (mipSize + mip.dataOffset > pixelData->data.size())
{ {
std::cerr << "Warning: Internal texture's mipmap data out of bounds, ignoring texture" << std::endl; Log(Debug::Info) << "Internal texture's mipmap data out of bounds, ignoring texture";
return NULL; return NULL;
} }
@ -1225,7 +1225,7 @@ namespace NifOsg
if (width <= 0 || height <= 0) if (width <= 0 || height <= 0)
{ {
std::cerr << "Warning: Internal Texture Width and height must be non zero, ignoring texture" << std::endl; Log(Debug::Info) << "Internal Texture Width and height must be non zero, ignoring texture";
return NULL; return NULL;
} }
@ -1267,12 +1267,12 @@ namespace NifOsg
{ {
// Not used by the vanilla engine. MCP (Morrowind Code Patch) adds an option to use Gloss maps: // Not used by the vanilla engine. MCP (Morrowind Code Patch) adds an option to use Gloss maps:
// "- Gloss map fix. Morrowind removed gloss map entries from model files after loading them. This stops Morrowind from removing them." // "- Gloss map fix. Morrowind removed gloss map entries from model files after loading them. This stops Morrowind from removing them."
//std::cerr << "NiTexturingProperty::GlossTexture in " << mFilename << " not currently used." << std::endl; // Log(Debug::Info) << "NiTexturingProperty::GlossTexture in " << mFilename << " not currently used.";
continue; continue;
} }
default: default:
{ {
std::cerr << "Warning: unhandled texture stage " << i << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled texture stage " << i << " in " << mFilename;
continue; continue;
} }
} }
@ -1478,7 +1478,7 @@ namespace NifOsg
break; break;
} }
default: default:
std::cerr << "Unhandled " << property->recName << " in " << mFilename << std::endl; Log(Debug::Info) << "Unhandled " << property->recName << " in " << mFilename;
break; break;
} }
} }

@ -5,6 +5,7 @@
#include <osg/MatrixTransform> #include <osg/MatrixTransform>
#include <osg/Geometry> #include <osg/Geometry>
#include <components/debug/debuglog.hpp>
#include <components/nif/controlled.hpp> #include <components/nif/controlled.hpp>
#include <components/nif/nifkey.hpp> #include <components/nif/nifkey.hpp>
#include <components/nif/data.hpp> #include <components/nif/data.hpp>
@ -284,7 +285,7 @@ void Emitter::emitParticles(double dt)
if (!visitor.mFound) if (!visitor.mFound)
{ {
std::cerr << "Error: Can't find emitter node" << randomRecIndex << std::endl; Log(Debug::Info) << "Can't find emitter node" << randomRecIndex;
return; return;
} }

@ -3,6 +3,7 @@
#include <cassert> #include <cassert>
#include <osgDB/Registry> #include <osgDB/Registry>
#include <components/debug/debuglog.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
#include "objectcache.hpp" #include "objectcache.hpp"
@ -97,7 +98,7 @@ namespace Resource
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::cerr << "Failed to open image: " << e.what() << std::endl; Log(Debug::Error) << "Failed to open image: " << e.what();
mCache->addEntryToObjectCache(normalized, mWarningImage); mCache->addEntryToObjectCache(normalized, mWarningImage);
return mWarningImage; return mWarningImage;
} }
@ -109,7 +110,7 @@ namespace Resource
osgDB::ReaderWriter* reader = osgDB::Registry::instance()->getReaderWriterForExtension(ext); osgDB::ReaderWriter* reader = osgDB::Registry::instance()->getReaderWriterForExtension(ext);
if (!reader) if (!reader)
{ {
std::cerr << "Error loading " << filename << ": no readerwriter for '" << ext << "' found" << std::endl; Log(Debug::Error) << "Error loading " << filename << ": no readerwriter for '" << ext << "' found";
mCache->addEntryToObjectCache(normalized, mWarningImage); mCache->addEntryToObjectCache(normalized, mWarningImage);
return mWarningImage; return mWarningImage;
} }
@ -117,7 +118,7 @@ namespace Resource
osgDB::ReaderWriter::ReadResult result = reader->readImage(*stream, mOptions); osgDB::ReaderWriter::ReadResult result = reader->readImage(*stream, mOptions);
if (!result.success()) if (!result.success())
{ {
std::cerr << "Error loading " << filename << ": " << result.message() << " code " << result.status() << std::endl; Log(Debug::Error) << "Error loading " << filename << ": " << result.message() << " code " << result.status();
mCache->addEntryToObjectCache(normalized, mWarningImage); mCache->addEntryToObjectCache(normalized, mWarningImage);
return mWarningImage; return mWarningImage;
} }
@ -130,7 +131,7 @@ namespace Resource
static bool uncompress = (getenv("OPENMW_DECOMPRESS_TEXTURES") != 0); static bool uncompress = (getenv("OPENMW_DECOMPRESS_TEXTURES") != 0);
if (!uncompress) if (!uncompress)
{ {
std::cerr << "Error loading " << filename << ": no S3TC texture compression support installed" << std::endl; Log(Debug::Error) << "Error loading " << filename << ": no S3TC texture compression support installed";
mCache->addEntryToObjectCache(normalized, mWarningImage); mCache->addEntryToObjectCache(normalized, mWarningImage);
return mWarningImage; return mWarningImage;
} }

@ -1,6 +1,5 @@
#include "scenemanager.hpp" #include "scenemanager.hpp"
#include <iostream>
#include <cstdlib> #include <cstdlib>
#include <osg/Node> #include <osg/Node>
@ -13,6 +12,8 @@
#include <osgDB/SharedStateManager> #include <osgDB/SharedStateManager>
#include <osgDB/Registry> #include <osgDB/Registry>
#include <components/debug/debuglog.hpp>
#include <components/nifosg/nifloader.hpp> #include <components/nifosg/nifloader.hpp>
#include <components/nif/niffile.hpp> #include <components/nif/niffile.hpp>
@ -501,7 +502,7 @@ namespace Resource
normalized = "meshes/marker_error." + std::string(sMeshTypes[i]); normalized = "meshes/marker_error." + std::string(sMeshTypes[i]);
if (mVFS->exists(normalized)) if (mVFS->exists(normalized))
{ {
std::cerr << "Failed to load '" << name << "': " << e.what() << ", using marker_error." << sMeshTypes[i] << " instead" << std::endl; Log(Debug::Error) << "Failed to load '" << name << "': " << e.what() << ", using marker_error." << sMeshTypes[i] << " instead";
Files::IStreamPtr file = mVFS->get(normalized); Files::IStreamPtr file = mVFS->get(normalized);
loaded = load(file, normalized, mImageManager, mNifFileManager); loaded = load(file, normalized, mImageManager, mNifFileManager);
break; break;
@ -658,12 +659,12 @@ namespace Resource
if(magfilter == "nearest") if(magfilter == "nearest")
mag = osg::Texture::NEAREST; mag = osg::Texture::NEAREST;
else if(magfilter != "linear") else if(magfilter != "linear")
std::cerr<< "Warning: Invalid texture mag filter: "<<magfilter <<std::endl; Log(Debug::Warning) << "Warning: Invalid texture mag filter: "<< magfilter;
if(minfilter == "nearest") if(minfilter == "nearest")
min = osg::Texture::NEAREST; min = osg::Texture::NEAREST;
else if(minfilter != "linear") else if(minfilter != "linear")
std::cerr<< "Warning: Invalid texture min filter: "<<minfilter <<std::endl; Log(Debug::Warning) << "Warning: Invalid texture min filter: "<< minfilter;
if(mipmap == "nearest") if(mipmap == "nearest")
{ {
@ -675,7 +676,7 @@ namespace Resource
else if(mipmap != "none") else if(mipmap != "none")
{ {
if(mipmap != "linear") if(mipmap != "linear")
std::cerr<< "Warning: Invalid texture mipmap: "<<mipmap <<std::endl; Log(Debug::Warning) << "Warning: Invalid texture mipmap: " << mipmap;
if(min == osg::Texture::NEAREST) if(min == osg::Texture::NEAREST)
min = osg::Texture::NEAREST_MIPMAP_LINEAR; min = osg::Texture::NEAREST_MIPMAP_LINEAR;
else if(min == osg::Texture::LINEAR) else if(min == osg::Texture::LINEAR)

@ -10,6 +10,7 @@
#include <osg/PositionAttitudeTransform> #include <osg/PositionAttitudeTransform>
#include <osg/MatrixTransform> #include <osg/MatrixTransform>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <components/sceneutil/skeleton.hpp> #include <components/sceneutil/skeleton.hpp>
@ -63,7 +64,7 @@ namespace SceneUtil
{ {
osg::ref_ptr<osg::Node> node = *it; osg::ref_ptr<osg::Node> node = *it;
if (node->getNumParents() > 1) if (node->getNumParents() > 1)
std::cerr << "Error CopyRigVisitor: node has multiple parents" << std::endl; Log(Debug::Error) << "Error CopyRigVisitor: node has multiple parents";
while (node->getNumParents()) while (node->getNumParents())
node->getParent(0)->removeChild(node); node->getParent(0)->removeChild(node);

@ -1,9 +1,10 @@
#include "riggeometry.hpp" #include "riggeometry.hpp"
#include <stdexcept> #include <stdexcept>
#include <iostream>
#include <cstdlib> #include <cstdlib>
#include <components/debug/debuglog.hpp>
#include "skeleton.hpp" #include "skeleton.hpp"
#include "util.hpp" #include "util.hpp"
@ -96,13 +97,13 @@ bool RigGeometry::initFromParentSkeleton(osg::NodeVisitor* nv)
if (!mSkeleton) if (!mSkeleton)
{ {
std::cerr << "Error: A RigGeometry did not find its parent skeleton" << std::endl; Log(Debug::Error) << "Error: A RigGeometry did not find its parent skeleton";
return false; return false;
} }
if (!mInfluenceMap) if (!mInfluenceMap)
{ {
std::cerr << "Error: No InfluenceMap set on RigGeometry" << std::endl; Log(Debug::Error) << "Error: No InfluenceMap set on RigGeometry";
return false; return false;
} }
@ -113,7 +114,7 @@ bool RigGeometry::initFromParentSkeleton(osg::NodeVisitor* nv)
Bone* bone = mSkeleton->getBone(it->first); Bone* bone = mSkeleton->getBone(it->first);
if (!bone) if (!bone)
{ {
std::cerr << "Error: RigGeometry did not find bone " << it->first << std::endl; Log(Debug::Error) << "Error: RigGeometry did not find bone " << it->first ;
continue; continue;
} }
@ -166,7 +167,7 @@ void RigGeometry::cull(osg::NodeVisitor* nv)
{ {
if (!mSkeleton) if (!mSkeleton)
{ {
std::cerr << "Error: RigGeometry rendering with no skeleton, should have been initialized by UpdateVisitor" << std::endl; Log(Debug::Error) << "Error: RigGeometry rendering with no skeleton, should have been initialized by UpdateVisitor";
// try to recover anyway, though rendering is likely to be incorrect. // try to recover anyway, though rendering is likely to be incorrect.
if (!initFromParentSkeleton(nv)) if (!initFromParentSkeleton(nv))
return; return;

@ -3,10 +3,9 @@
#include <osg/Transform> #include <osg/Transform>
#include <osg/MatrixTransform> #include <osg/MatrixTransform>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <iostream>
namespace SceneUtil namespace SceneUtil
{ {
@ -183,7 +182,7 @@ void Bone::update(const osg::Matrixf* parentMatrixInSkeletonSpace)
{ {
if (!mNode) if (!mNode)
{ {
std::cerr << "Error: Bone without node " << std::endl; Log(Debug::Error) << "Error: Bone without node";
return; return;
} }
if (parentMatrixInSkeletonSpace) if (parentMatrixInSkeletonSpace)

@ -3,8 +3,8 @@
#include <deque> #include <deque>
//#include <osg/Timer> //#include <osg/Timer>
//#include <iostream>
//#include <components/debug/debuglog.hpp>
#include <components/sceneutil/workqueue.hpp> #include <components/sceneutil/workqueue.hpp>
namespace SceneUtil namespace SceneUtil
@ -20,7 +20,7 @@ namespace SceneUtil
//osg::Timer timer; //osg::Timer timer;
//size_t objcount = mObjects.size(); //size_t objcount = mObjects.size();
mObjects.clear(); mObjects.clear();
//std::cout << "cleared " << objcount << " objects in " << timer.time_m() << std::endl; //Log(Debug::Verbose) << "cleared " << objcount << " objects in " << timer.time_m();
} }
}; };

@ -1,6 +1,6 @@
#include "workqueue.hpp" #include "workqueue.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
namespace SceneUtil namespace SceneUtil
{ {
@ -71,7 +71,7 @@ void WorkQueue::addWorkItem(osg::ref_ptr<WorkItem> item, bool front)
{ {
if (item->isDone()) if (item->isDone())
{ {
std::cerr << "Error: trying to add a work item that is already completed" << std::endl; Log(Debug::Error) << "Error: trying to add a work item that is already completed";
return; return;
} }

@ -17,6 +17,8 @@
#include <osg/Version> #include <osg/Version>
#include <osgViewer/GraphicsWindow> #include <osgViewer/GraphicsWindow>
#include <components/debug/debuglog.hpp>
#include "imagetosurface.hpp" #include "imagetosurface.hpp"
#if defined(OSG_LIBRARY_STATIC) && !defined(ANDROID) #if defined(OSG_LIBRARY_STATIC) && !defined(ANDROID)
@ -63,7 +65,7 @@ namespace CursorDecompression
if (!_gc) if (!_gc)
{ {
std::cerr << "Failed to create pbuffer, failing back to normal graphics window." << std::endl; Log(Debug::Warning) << "Failed to create pbuffer, failing back to normal graphics window.";
traits->pbuffer = false; traits->pbuffer = false;
_gc = osg::GraphicsContext::createGraphicsContext(traits.get()); _gc = osg::GraphicsContext::createGraphicsContext(traits.get());
@ -283,8 +285,8 @@ namespace SDLUtil
mCursorMap.insert(CursorMap::value_type(std::string(name), curs)); mCursorMap.insert(CursorMap::value_type(std::string(name), curs));
} catch (std::exception& e) { } catch (std::exception& e) {
std::cerr << e.what() << std::endl; Log(Debug::Warning) << e.what();
std::cerr <<"Using default cursor."<<std::endl; Log(Debug::Warning) << "Using default cursor.";
return; return;
} }
} }

@ -1,6 +1,6 @@
#include "sdlinputwrapper.hpp" #include "sdlinputwrapper.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include <osgViewer/Viewer> #include <osgViewer/Viewer>
@ -160,9 +160,7 @@ InputWrapper::InputWrapper(SDL_Window* window, osg::ref_ptr<osgViewer::Viewer> v
break; break;
default: default:
std::ios::fmtflags f(std::cerr.flags()); Log(Debug::Info) << "Unhandled SDL event of type 0x" << std::hex << evt.type;
std::cerr << "Unhandled SDL event of type 0x" << std::hex << evt.type << std::endl;
std::cerr.flags(f);
break; break;
} }
} }

@ -1,6 +1,6 @@
#include "sdlvideowrapper.hpp" #include "sdlvideowrapper.hpp"
#include <iostream> #include <components/debug/debuglog.hpp>
#include <osgViewer/Viewer> #include <osgViewer/Viewer>
@ -65,7 +65,7 @@ namespace SDLUtil
red[i] = green[i] = blue[i] = static_cast<Uint16>(value); red[i] = green[i] = blue[i] = static_cast<Uint16>(value);
} }
if (SDL_SetWindowGammaRamp(mWindow, red, green, blue) < 0) if (SDL_SetWindowGammaRamp(mWindow, red, green, blue) < 0)
std::cout << "Couldn't set gamma: " << SDL_GetError() << std::endl; Log(Debug::Warning) << "Couldn't set gamma: " << SDL_GetError();
} }
void VideoWrapper::setVideoMode(int width, int height, bool fullscreen, bool windowBorder) void VideoWrapper::setVideoMode(int width, int height, bool fullscreen, bool windowBorder)

@ -1,8 +1,8 @@
#include "settings.hpp" #include "settings.hpp"
#include <sstream> #include <sstream>
#include <iostream>
#include <components/debug/debuglog.hpp>
#include <components/misc/stringops.hpp> #include <components/misc/stringops.hpp>
#include <boost/filesystem/fstream.hpp> #include <boost/filesystem/fstream.hpp>
@ -69,7 +69,7 @@ public:
mFile = file; mFile = file;
boost::filesystem::ifstream stream; boost::filesystem::ifstream stream;
stream.open(boost::filesystem::path(file)); stream.open(boost::filesystem::path(file));
std::cout << "Loading settings file: " << file << std::endl; Log(Debug::Info) << "Loading settings file: " << file;
std::string currentCategory; std::string currentCategory;
mLine = 0; mLine = 0;
while (!stream.eof() && !stream.fail()) while (!stream.eof() && !stream.fail())
@ -186,8 +186,8 @@ public:
// Ensure that all options in the current category have been written. // Ensure that all options in the current category have been written.
for (CategorySettingStatusMap::iterator mit = written.begin(); mit != written.end(); ++mit) { for (CategorySettingStatusMap::iterator mit = written.begin(); mit != written.end(); ++mit) {
if (mit->second == false && mit->first.first == currentCategory) { if (mit->second == false && mit->first.first == currentCategory) {
std::cout << "Added new setting: [" << currentCategory << "] " Log(Debug::Verbose) << "Added new setting: [" << currentCategory << "] "
<< mit->first.second << " = " << settings[mit->first] << std::endl; << mit->first.second << " = " << settings[mit->first];
ostream << mit->first.second << " = " << settings[mit->first] << std::endl; ostream << mit->first.second << " = " << settings[mit->first] << std::endl;
mit->second = true; mit->second = true;
changed = true; changed = true;
@ -200,7 +200,7 @@ public:
// Write the (new) current category to the file. // Write the (new) current category to the file.
ostream << "[" << currentCategory << "]" << std::endl; ostream << "[" << currentCategory << "]" << std::endl;
//std::cout << "Wrote category: " << currentCategory << std::endl; // Log(Debug::Verbose) << "Wrote category: " << currentCategory;
// A setting can apparently follow the category on an input line. That's rather // A setting can apparently follow the category on an input line. That's rather
// inconvenient, since it makes it more likely to have duplicative sections, // inconvenient, since it makes it more likely to have duplicative sections,
@ -259,8 +259,8 @@ public:
finder->second = true; finder->second = true;
// Did we really change it? // Did we really change it?
if (value != settings[key]) { if (value != settings[key]) {
std::cout << "Changed setting: [" << currentCategory << "] " Log(Debug::Verbose) << "Changed setting: [" << currentCategory << "] "
<< setting << " = " << settings[key] << std::endl; << setting << " = " << settings[key];
changed = true; changed = true;
} }
// No need to write the current line, because we just emitted a replacement. // No need to write the current line, because we just emitted a replacement.
@ -276,8 +276,8 @@ public:
// the current category at the end of the file before moving on to any new categories. // the current category at the end of the file before moving on to any new categories.
for (CategorySettingStatusMap::iterator mit = written.begin(); mit != written.end(); ++mit) { for (CategorySettingStatusMap::iterator mit = written.begin(); mit != written.end(); ++mit) {
if (mit->second == false && mit->first.first == currentCategory) { if (mit->second == false && mit->first.first == currentCategory) {
std::cout << "Added new setting: [" << mit->first.first << "] " Log(Debug::Verbose) << "Added new setting: [" << mit->first.first << "] "
<< mit->first.second << " = " << settings[mit->first] << std::endl; << mit->first.second << " = " << settings[mit->first];
ostream << mit->first.second << " = " << settings[mit->first] << std::endl; ostream << mit->first.second << " = " << settings[mit->first] << std::endl;
mit->second = true; mit->second = true;
changed = true; changed = true;
@ -305,12 +305,12 @@ public:
// If the catgory has changed, write a new category header. // If the catgory has changed, write a new category header.
if (mit->first.first != currentCategory) { if (mit->first.first != currentCategory) {
currentCategory = mit->first.first; currentCategory = mit->first.first;
std::cout << "Created new setting section: " << mit->first.first << std::endl; Log(Debug::Verbose) << "Created new setting section: " << mit->first.first;
ostream << std::endl; ostream << std::endl;
ostream << "[" << currentCategory << "]" << std::endl; ostream << "[" << currentCategory << "]" << std::endl;
} }
std::cout << "Added new setting: [" << mit->first.first << "] " Log(Debug::Verbose) << "Added new setting: [" << mit->first.first << "] "
<< mit->first.second << " = " << settings[mit->first] << std::endl; << mit->first.second << " = " << settings[mit->first];
// Then write the setting. No need to mark it as written because we're done. // Then write the setting. No need to mark it as written because we're done.
ostream << mit->first.second << " = " << settings[mit->first] << std::endl; ostream << mit->first.second << " = " << settings[mit->first] << std::endl;
changed = true; changed = true;
@ -319,7 +319,7 @@ public:
// Now install the newly written file in the requested place. // Now install the newly written file in the requested place.
if (changed) { if (changed) {
std::cout << "Updating settings file: " << ipath << std::endl; Log(Debug::Info) << "Updating settings file: " << ipath;
boost::filesystem::ofstream ofstream; boost::filesystem::ofstream ofstream;
ofstream.open(ipath); ofstream.open(ipath);
ofstream << ostream.rdbuf(); ofstream << ostream.rdbuf();

@ -11,6 +11,8 @@
#include <boost/filesystem/fstream.hpp> #include <boost/filesystem/fstream.hpp>
#include <boost/algorithm/string.hpp> #include <boost/algorithm/string.hpp>
#include <components/debug/debuglog.hpp>
namespace Shader namespace Shader
{ {
@ -31,13 +33,13 @@ namespace Shader
size_t start = source.find('"', foundPos); size_t start = source.find('"', foundPos);
if (start == std::string::npos || start == source.size()-1) if (start == std::string::npos || start == source.size()-1)
{ {
std::cerr << "Invalid #include " << std::endl; Log(Debug::Error) << "Invalid #include";
return false; return false;
} }
size_t end = source.find('"', start+1); size_t end = source.find('"', start+1);
if (end == std::string::npos) if (end == std::string::npos)
{ {
std::cerr << "Invalid #include " << std::endl; Log(Debug::Error) << "Invalid #include";
return false; return false;
} }
std::string includeFilename = source.substr(start+1, end-(start+1)); std::string includeFilename = source.substr(start+1, end-(start+1));
@ -46,7 +48,7 @@ namespace Shader
includeFstream.open(includePath); includeFstream.open(includePath);
if (includeFstream.fail()) if (includeFstream.fail())
{ {
std::cerr << "Failed to open " << includePath.string() << std::endl; Log(Debug::Error) << "Failed to open " << includePath.string();
return false; return false;
} }
@ -65,7 +67,7 @@ namespace Shader
if (includedFiles.insert(includePath).second == false) if (includedFiles.insert(includePath).second == false)
{ {
std::cerr << "Detected cyclic #includes" << std::endl; Log(Debug::Error) << "Detected cyclic #includes";
return false; return false;
} }
} }
@ -81,14 +83,14 @@ namespace Shader
size_t endPos = source.find_first_of(" \n\r()[].;", foundPos); size_t endPos = source.find_first_of(" \n\r()[].;", foundPos);
if (endPos == std::string::npos) if (endPos == std::string::npos)
{ {
std::cerr << "Unexpected EOF" << std::endl; Log(Debug::Error) << "Unexpected EOF";
return false; return false;
} }
std::string define = source.substr(foundPos+1, endPos - (foundPos+1)); std::string define = source.substr(foundPos+1, endPos - (foundPos+1));
ShaderManager::DefineMap::const_iterator defineFound = defines.find(define); ShaderManager::DefineMap::const_iterator defineFound = defines.find(define);
if (defineFound == defines.end()) if (defineFound == defines.end())
{ {
std::cerr << "Undefined " << define << std::endl; Log(Debug::Error) << "Undefined " << define;
return false; return false;
} }
else else
@ -112,7 +114,7 @@ namespace Shader
stream.open(p); stream.open(p);
if (stream.fail()) if (stream.fail())
{ {
std::cerr << "Failed to open " << p.string() << std::endl; Log(Debug::Error) << "Failed to open " << p.string();
return NULL; return NULL;
} }
std::stringstream buffer; std::stringstream buffer;

@ -10,6 +10,7 @@
#include <boost/algorithm/string.hpp> #include <boost/algorithm/string.hpp>
#include <components/debug/debuglog.hpp>
#include <components/resource/imagemanager.hpp> #include <components/resource/imagemanager.hpp>
#include <components/vfs/manager.hpp> #include <components/vfs/manager.hpp>
#include <components/sceneutil/riggeometry.hpp> #include <components/sceneutil/riggeometry.hpp>
@ -147,7 +148,7 @@ namespace Shader
specularMap = texture; specularMap = texture;
} }
else else
std::cerr << "ShaderVisitor encountered unknown texture " << texture << std::endl; Log(Debug::Error) << "ShaderVisitor encountered unknown texture " << texture;
} }
} }
} }

@ -2,10 +2,11 @@
#include <vector> #include <vector>
#include <cassert> #include <cassert>
#include <iostream>
#include <iomanip> #include <iomanip>
#include <stdexcept> #include <stdexcept>
#include <components/debug/debuglog.hpp>
/* This file contains the code to translate from WINDOWS-1252 (native /* This file contains the code to translate from WINDOWS-1252 (native
charset used in English version of Morrowind) to UTF-8. The library charset used in English version of Morrowind) to UTF-8. The library
is designed to be extened to support more source encodings later, is designed to be extened to support more source encodings later,
@ -319,9 +320,7 @@ void Utf8Encoder::copyFromArray2(const char*& chp, char* &out)
} }
} }
std::ios::fmtflags f(std::cout.flags()); Log(Debug::Info) << "Could not find glyph " << std::hex << (int)ch << " " << (int)ch2 << " " << (int)ch3;
std::cout << "Could not find glyph " << std::hex << (int)ch << " " << (int)ch2 << " " << (int)ch3 << std::endl;
std::cout.flags(f);
*(out++) = ch; // Could not find glyph, just put whatever *(out++) = ch; // Could not find glyph, just put whatever
} }

@ -1,9 +1,9 @@
#include "filesystemarchive.hpp" #include "filesystemarchive.hpp"
#include <iostream>
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include <components/debug/debuglog.hpp>
namespace VFS namespace VFS
{ {
@ -41,7 +41,7 @@ namespace VFS
std::transform(proper.begin() + prefix, proper.end(), std::back_inserter(searchable), normalize_function); std::transform(proper.begin() + prefix, proper.end(), std::back_inserter(searchable), normalize_function);
if (!mIndex.insert (std::make_pair (searchable, file)).second) if (!mIndex.insert (std::make_pair (searchable, file)).second)
std::cerr << "Warning: found duplicate file for '" << proper << "', please check your file system for two files with the same name in different cases." << std::endl; Log(Debug::Warning) << "Warning: found duplicate file for '" << proper << "', please check your file system for two files with the same name in different cases.";
} }
mBuiltIndex = true; mBuiltIndex = true;

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save