/*
* Copyright 2010-2016 OpenXcom Developers.
*
* This file is part of OpenXcom.
*
* OpenXcom 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.
*
* OpenXcom 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 OpenXcom. If not, see <http://www.gnu.org/licenses/>.
*/
#include "DismantleFacilityState.h"
#include "../Engine/Game.h"
#include "../Mod/Mod.h"
#include "../Engine/LocalizedText.h"
#include "../Engine/Options.h"
#include "../Interface/TextButton.h"
#include "../Interface/Window.h"
#include "../Interface/Text.h"
#include "../Savegame/Base.h"
#include "../Savegame/BaseFacility.h"
#include "BaseView.h"
#include "../Mod/RuleBaseFacility.h"
#include "../Savegame/SavedGame.h"
namespace OpenXcom
{
/**
* Initializes all the elements in a Dismantle Facility window.
* @param game Pointer to the core game.
* @param base Pointer to the base to get info from.
* @param view Pointer to the baseview to update.
* @param fac Pointer to the facility to dismantle.
*/
DismantleFacilityState::DismantleFacilityState(Base *base, BaseView *view, BaseFacility *fac) : _base(base), _view(view), _fac(fac)
{
_screen = false;
// Create objects
_window = new Window(this, 152, 80, 20, 60);
_btnOk = new TextButton(44, 16, 36, 115);
_btnCancel = new TextButton(44, 16, 112, 115);
_txtTitle = new Text(142, 9, 25, 75);
_txtFacility = new Text(142, 9, 25, 85);
// Set palette
setInterface("dismantleFacility");
add(_window, "window", "dismantleFacility");
add(_btnOk, "button", "dismantleFacility");
add(_btnCancel, "button", "dismantleFacility");
add(_txtTitle, "text", "dismantleFacility");
add(_txtFacility, "text", "dismantleFacility");
centerAllSurfaces();
// Set up objects
_window->setBackground(_game->getMod()->getSurface("BACK13.SCR"));
_btnOk->setText(tr("STR_OK"));
_btnOk->onMouseClick((ActionHandler)&DismantleFacilityState::btnOkClick);
_btnOk->onKeyboardPress((ActionHandler)&DismantleFacilityState::btnOkClick, Options::keyOk);
_btnCancel->setText(tr("STR_CANCEL_UC"));
_btnCancel->onMouseClick((ActionHandler)&DismantleFacilityState::btnCancelClick);
_btnCancel->onKeyboardPress((ActionHandler)&DismantleFacilityState::btnCancelClick, Options::keyCancel);
_txtTitle->setAlign(ALIGN_CENTER);
_txtTitle->setText(tr("STR_DISMANTLE"));
_txtFacility->setAlign(ALIGN_CENTER);
_txtFacility->setText(tr(_fac->getRules()->getType()));
}
/**
*
*/
DismantleFacilityState::~DismantleFacilityState()
{
}
/**
* Dismantles the facility and returns
* to the previous screen.
* @param action Pointer to an action.
*/
void DismantleFacilityState::btnOkClick(Action *)
{
if (!_fac->getRules()->isLift())
{
// Give refund if this is an unstarted, queued build.
if (_fac->getBuildTime() > _fac->getRules()->getBuildTime())
{
_game->getSavedGame()->setFunds(_game->getSavedGame()->getFunds() + _fac->getRules()->getBuildCost());
}
for (std::vector<BaseFacility*>::iterator i = _base->getFacilities()->begin(); i != _base->getFacilities()->end(); ++i)
{
if (*i == _fac)
{
_base->getFacilities()->erase(i);
_view->resetSelectedFacility();
delete _fac;
if (Options::allowBuildingQueue) _view->reCalcQueuedBuildings();
break;
}
}
}
// Remove whole base if it's the access lift
else
{
for (std::vector<Base*>::iterator i = _game->getSavedGame()->getBases()->begin(); i != _game->getSavedGame()->getBases()->end(); ++i)
{
if (*i == _base)
{
_game->getSavedGame()->getBases()->erase(i);
delete _base;
break;
}
}
}
_game->popState();
}
/**
* Returns to the previous screen.
* @param action Pointer to an action.
*/
void DismantleFacilityState::btnCancelClick(Action *)
{
_game->popState();
}
}
↑ V807 Decreased performance. Consider creating a pointer to avoid using the '_fac->getRules()' expression repeatedly.
↑ V807 Decreased performance. Consider creating a pointer to avoid using the '_base->getFacilities()' expression repeatedly.
↑ V807 Decreased performance. Consider creating a pointer to avoid using the '_game->getSavedGame()->getBases()' expression repeatedly.