mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-17 02:45:33 +08:00
refs #614, move utility functions into own class so I can resuse them better
This commit is contained in:
50
src/blackmisc/simulation/aircraftmodelutils.cpp
Normal file
50
src/blackmisc/simulation/aircraftmodelutils.cpp
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
/* Copyright (C) 2016
|
||||||
|
* swift project Community / Contributors
|
||||||
|
*
|
||||||
|
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
|
||||||
|
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
|
||||||
|
* including this file, may be copied, modified, propagated, or distributed except according to the terms
|
||||||
|
* contained in the LICENSE file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "aircraftmodelutils.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace BlackMisc
|
||||||
|
{
|
||||||
|
namespace Simulation
|
||||||
|
{
|
||||||
|
bool CAircraftModelUtilities::mergeWithDbData(CAircraftModelList &modelToBeModified, const CAircraftModelList &dbModels, bool force)
|
||||||
|
{
|
||||||
|
if (dbModels.isEmpty() || modelToBeModified.isEmpty()) { return false; }
|
||||||
|
for (CAircraftModel &simModel : modelToBeModified)
|
||||||
|
{
|
||||||
|
if (!force && simModel.hasValidDbKey()) { continue; } // already done
|
||||||
|
CAircraftModel dbModel(dbModels.findFirstByModelStringOrDefault(simModel.getModelString()));
|
||||||
|
if (!dbModel.hasValidDbKey())
|
||||||
|
{
|
||||||
|
continue; // not found
|
||||||
|
}
|
||||||
|
dbModel.updateMissingParts(simModel, false);
|
||||||
|
simModel = dbModel;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CAircraftModelUtilities::mergeWithVPilotData(CAircraftModelList &modelToBeModified, const CAircraftModelList &vPilotModels, bool force)
|
||||||
|
{
|
||||||
|
if (vPilotModels.isEmpty() || modelToBeModified.isEmpty()) { return false; }
|
||||||
|
for (CAircraftModel &simModel : modelToBeModified)
|
||||||
|
{
|
||||||
|
if (!force && simModel.hasValidAircraftAndAirlineDesignator()) { continue; } // already done
|
||||||
|
CAircraftModel vPilotModel(vPilotModels.findFirstByModelStringOrDefault(simModel.getModelString()));
|
||||||
|
if (!vPilotModel.hasValidDbKey())
|
||||||
|
{
|
||||||
|
continue; // not found
|
||||||
|
}
|
||||||
|
simModel.updateMissingParts(vPilotModel, false);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
} // ns
|
||||||
|
} // ns
|
||||||
38
src/blackmisc/simulation/aircraftmodelutils.h
Normal file
38
src/blackmisc/simulation/aircraftmodelutils.h
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
/* Copyright (C) 2016
|
||||||
|
* swift project Community / Contributors
|
||||||
|
*
|
||||||
|
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
|
||||||
|
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
|
||||||
|
* including this file, may be copied, modified, propagated, or distributed except according to the terms
|
||||||
|
* contained in the LICENSE file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//! \file
|
||||||
|
|
||||||
|
#ifndef BLACKMISC_SIMULATION_AIRCRAFTMODELUTILS_H
|
||||||
|
#define BLACKMISC_SIMULATION_AIRCRAFTMODELUTILS_H
|
||||||
|
|
||||||
|
#include "blackmisc/blackmiscexport.h"
|
||||||
|
#include "blackmisc/simulation/aircraftmodellist.h"
|
||||||
|
|
||||||
|
namespace BlackMisc
|
||||||
|
{
|
||||||
|
namespace Simulation
|
||||||
|
{
|
||||||
|
//! Utilities for aircraft models
|
||||||
|
class BLACKMISC_EXPORT CAircraftModelUtilities
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
//! No constructor
|
||||||
|
CAircraftModelUtilities() = delete;
|
||||||
|
|
||||||
|
//! Merge with DB data if possible
|
||||||
|
static bool mergeWithDbData(BlackMisc::Simulation::CAircraftModelList &modelToBeModified, const BlackMisc::Simulation::CAircraftModelList &dbModels, bool force = false);
|
||||||
|
|
||||||
|
//! Merge with vPilot data if possible
|
||||||
|
static bool mergeWithVPilotData(BlackMisc::Simulation::CAircraftModelList &modelToBeModified, const BlackMisc::Simulation::CAircraftModelList &vPilotModels, bool force = false);
|
||||||
|
};
|
||||||
|
} //namespace
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
#endif //guard
|
||||||
Reference in New Issue
Block a user