/*==LICENSE==*

CyanWorlds.com Engine - MMOG client, server and tools
Copyright (C) 2011  Cyan Worlds, Inc.

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.

You can contact Cyan Worlds, Inc. by email legal@cyan.com
 or by snail mail at:
      Cyan Worlds, Inc.
      14617 N Newport Hwy
      Mead, WA   99021

*==LICENSE==*/
#include "../plResMgr/plResManager.h"
#include "../pfPython/plPythonFileMod.h"
#include "../plGImage/plFontCache.h"
#include "../plPhysX/plSimulationMgr.h"
#include "../plAvatar/plAvatarMgr.h"

#include "plPageOptimizer.h"
#include "../plFile/plFileUtils.h"

int main(int argc, char* argv[])
{
	if (argc != 2)
	{
		printf("plPageOptimizer: wrong number of arguments");
		return 1;
	}

	printf("Optimizing %s...", plFileUtils::GetFileName(argv[1]));

	plFontCache* fontCache;
#ifndef _DEBUG
	try
	{
#endif
		plResManager* resMgr = TRACKED_NEW plResManager;
		hsgResMgr::Init(resMgr);

		// Setup all the crap that needs to be around to load
		plSimulationMgr::Init();
		fontCache = TRACKED_NEW plFontCache;
		plPythonFileMod::SetAtConvertTime();
#ifndef _DEBUG
	} catch (...)
	{
		printf(" ***crashed on init");
		return 2;
	}
#endif

#ifndef _DEBUG
	try
#endif
	{
		plPageOptimizer optimizer(argv[1]);
		optimizer.Optimize();
	}
#ifndef _DEBUG
	catch (...)
	{
		printf(" ***crashed on optimizing");
		return 2;
	}
#endif

#ifndef _DEBUG
	try
	{
#endif
		// Deinit the crap
		fontCache->UnRegisterAs(kFontCache_KEY);
		fontCache = nil;
		plSimulationMgr::Shutdown();

		// Reading in objects may have generated dirty state which we're obviously
		// not sending out. Clear it so that we don't have leaked keys before the
		// ResMgr goes away.
		std::vector<plSynchedObject::StateDefn> carryOvers;
		plSynchedObject::ClearDirtyState(carryOvers);

		hsgResMgr::Shutdown();
#ifndef _DEBUG
	} catch (...)
	{
		printf(" ***crashed on shutdown");
		return 2;
	}
#endif

	return 0;
}