/* *openPilot Log - A FOSS Pilot Logbook Application *Copyright (C) 2020 Felix Turowsky * *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 . */ #include "aircraft.h" // Debug Makro #define DEB(expr) \ qDebug() << __PRETTY_FUNCTION__ << "\t" << expr Aircraft::Aircraft(int tail_id) { //retreive database layout const auto dbContent = DbInfo(); auto table = QLatin1String("tails"); //Check database for row id QString statement = "SELECT COUNT(*) FROM " + table + " WHERE _rowid_=" + QString::number(tail_id); QSqlQuery q(statement); q.next(); int rows = q.value(0).toInt(); if (rows == 0) { DEB("No Entry found for row id: " << tail_id ); position.second = 0; } else { DEB("Retreiving data for row id: " << tail_id); QString statement = "SELECT * FROM " + table + " WHERE _rowid_=" + QString::number(tail_id); DEB("Executing SQL..."); DEB(statement); QSqlQuery q(statement); q.exec(); q.next(); for (int i = 0; i < dbContent.format.value(table).length(); i++) { data.insert(dbContent.format.value(table)[i], q.value(i).toString()); } QString error = q.lastError().text(); if (error.length() > 2) { DEB("Error: " << q.lastError().text()); position.second = 0; position.first = "invalid"; } else { position.second = tail_id; position.first = "tails"; } } }