void dataconfigs::loadLevelBGO() { unsigned int i; obj_bgo sbgo; unsigned long bgo_total=0; QString bgo_ini = config_dir + "lvl_bgo.ini"; if(!QFile::exists(bgo_ini)) { addError(QString("ERROR LOADING lvl_bgo.ini: file does not exist"), PGE_LogLevel::Critical); return; } QSettings bgoset(bgo_ini, QSettings::IniFormat); bgoset.setIniCodec("UTF-8"); main_bgo.clear(); //Clear old // index_bgo.clear(); bgoset.beginGroup("background-main"); bgo_total = bgoset.value("total", "0").toInt(); total_data +=bgo_total; bgoset.endGroup(); emit progressPartNumber(1); emit progressMax(bgo_total); emit progressValue(0); emit progressTitle(QObject::tr("Loading BGOs...")); ConfStatus::total_bgo = bgo_total; main_bgo.allocateSlots(bgo_total); if(ConfStatus::total_bgo==0) { addError(QString("ERROR LOADING lvl_bgo.ini: number of items not define, or empty config"), PGE_LogLevel::Critical); return; } for(i=1; i<=bgo_total; i++) { emit progressValue(i); if( loadLevelBGO(sbgo, QString("background-"+QString::number(i)), 0, "", &bgoset) ) { sbgo.id = i; main_bgo.storeElement(i, sbgo); } if( bgoset.status() != QSettings::NoError ) { addError(QString("ERROR LOADING lvl_bgo.ini N:%1 (bgo-%2)").arg(bgoset.status()).arg(i), PGE_LogLevel::Critical); } } if((unsigned int)main_bgo.stored()<bgo_total) { addError(QString("Not all BGOs loaded! Total: %1, Loaded: %2").arg(bgo_total).arg(main_bgo.stored())); } }
void dataconfigs::loadLevelBGO() { unsigned long i; obj_bgo sbgo; unsigned long bgo_total=0; bool useDirectory=false; QString bgo_ini = getFullIniPath("lvl_bgo.ini"); if(bgo_ini.isEmpty()) return; QString nestDir = ""; QSettings setup(bgo_ini, QSettings::IniFormat); setup.setIniCodec("UTF-8"); main_bgo.clear(); //Clear old if(!openSection( &setup, "background-main")) return; bgo_total = setup.value("total", 0).toUInt(); defaultGrid.bgo = setup.value("grid", defaultGrid.bgo).toUInt(); total_data +=bgo_total; nestDir = setup.value("config-dir", "").toString(); if(!nestDir.isEmpty()) { nestDir = config_dir + nestDir; useDirectory = true; } closeSection(&setup); emit progressPartNumber(1); emit progressMax(static_cast<int>(bgo_total)); emit progressValue(0); emit progressTitle(QObject::tr("Loading BGOs...")); ConfStatus::total_bgo = static_cast<long>(bgo_total); main_bgo.allocateSlots(static_cast<int>(bgo_total)); if(ConfStatus::total_bgo==0) { addError(QString("ERROR LOADING lvl_bgo.ini: number of items not define, or empty config"), PGE_LogLevel::Critical); return; } for(i=1; i<=bgo_total; i++) { emit progressValue(static_cast<int>(i)); bool valid=false; if(useDirectory) { valid = loadLevelBGO(sbgo, "background", nullptr, QString("%1/background-%2.ini").arg(nestDir).arg(i)); } else { valid = loadLevelBGO(sbgo, QString("background-%1").arg(i), 0, "", &setup); } /***************Load image*******************/ if(valid) { QString errStr; GraphicsHelps::loadMaskedImage(bgoPath, sbgo.setup.image_n, sbgo.setup.mask_n, sbgo.image, errStr); if(!errStr.isEmpty()) { valid=false; addError(QString("BGO-%1 %2").arg(i).arg(errStr)); } } /***************Load image*end***************/ sbgo.setup.id = i; main_bgo.storeElement(static_cast<int>(i), sbgo, valid); if( setup.status() != QSettings::NoError ) { addError(QString("ERROR LOADING lvl_bgo.ini N:%1 (bgo-%2)").arg(setup.status()).arg(i), PGE_LogLevel::Critical); } } if(static_cast<unsigned long>(main_bgo.stored()) < bgo_total) { addError(QString("Not all BGOs loaded! Total: %1, Loaded: %2").arg(bgo_total).arg(main_bgo.stored())); } }
bool ConfigManager::loadLevelBGO() { unsigned int i; obj_bgo sbgo; unsigned long bgo_total = 0; bool useDirectory = false; std::string bgo_ini = config_dirSTD + "lvl_bgo.ini"; std::string nestDir = ""; if(!Files::fileExists(bgo_ini)) { const char* msg = "ERROR LOADING lvl_bgo.ini: file does not exist"; addError(msg); PGE_MsgBox msgBox(NULL, msg, PGE_MsgBox::msg_fatal); msgBox.exec(); return false; } IniProcessing bgoset(bgo_ini); lvl_bgo_indexes.clear();//Clear old bgoset.beginGroup("background-main"); bgo_total = bgoset.value("total", 0).toULongLong(); nestDir = bgoset.value("config-dir", "").toString(); if(!nestDir.empty()) { nestDir = config_dirSTD + nestDir; useDirectory = true; } bgoset.endGroup(); lvl_bgo_indexes.allocateSlots(bgo_total); for(i = 1; i <= bgo_total; i++) { if(useDirectory) { if(!loadLevelBGO(sbgo, "background", nullptr, fmt::format_ne("{0}/background-{1}.ini", nestDir, i))) return false; } else { if(!loadLevelBGO(sbgo, fmt::format_ne("background-{0}", i), nullptr, "", &bgoset)) return false; } sbgo.setup.id = i; //Store loaded config lvl_bgo_indexes.storeElement(sbgo.setup.id, sbgo); //Load custom config if possible loadCustomConfig<obj_bgo>(lvl_bgo_indexes, i, Dir_BGO, "background", "background", &loadLevelBGO); if(bgoset.lastError() != IniProcessing::ERR_OK) addError(fmt::format_ne("ERROR LOADING lvl_bgo.ini N:{0} (bgo-{1})", bgoset.lastError(), i)); } if(lvl_bgo_indexes.stored() < bgo_total) { std::string msg = fmt::format_ne("Not all BGOs loaded! Total: {0}, Loaded: {1}", bgo_total, lvl_bgo_indexes.stored()); addError(msg); PGE_MsgBox msgBox(NULL, msg, PGE_MsgBox::msg_error); msgBox.exec(); } return true; }
void dataconfigs::loadLevelBGO() { unsigned long i; obj_bgo sbgo; unsigned long bgo_total = 0; bool useDirectory = false; QString bgo_ini = getFullIniPath("lvl_bgo.ini"); if(bgo_ini.isEmpty()) return; IniProcessing setup(bgo_ini); folderLvlBgo.items.clear(); main_bgo.clear(); //Clear old if(!openSection(&setup, "background-main")) return; { setup.read("total", bgo_total, 0); setup.read("grid", defaultGrid.bgo, defaultGrid.bgo); total_data += bgo_total; setup.read("config-dir", folderLvlBgo.items, ""); setup.read("extra-settings", folderLvlBgo.extraSettings, folderLvlBgo.items); if(!folderLvlBgo.items.isEmpty()) { folderLvlBgo.items = config_dir + folderLvlBgo.items; useDirectory = true; } } closeSection(&setup); emit progressPartNumber(1); emit progressMax(static_cast<int>(bgo_total)); emit progressValue(0); emit progressTitle(QObject::tr("Loading BGOs...")); ConfStatus::total_bgo = static_cast<long>(bgo_total); main_bgo.allocateSlots(static_cast<int>(bgo_total)); if(ConfStatus::total_bgo == 0) { addError(QString("ERROR LOADING lvl_bgo.ini: number of items not define, or empty config"), PGE_LogLevel::Critical); return; } for(i = 1; i <= bgo_total; i++) { emit progressValue(static_cast<int>(i)); bool valid = false; if(useDirectory) valid = loadLevelBGO(sbgo, "background", nullptr, QString("%1/background-%2.ini").arg(folderLvlBgo.items).arg(i)); else valid = loadLevelBGO(sbgo, QString("background-%1").arg(i), 0, "", &setup); /***************Load image*******************/ if(valid) { QString errStr; GraphicsHelps::loadMaskedImage(folderLvlBgo.graphics, sbgo.setup.image_n, sbgo.setup.mask_n, sbgo.image, errStr); if(!errStr.isEmpty()) { valid = false; addError(QString("BGO-%1 %2").arg(i).arg(errStr)); } } /***************Load image*end***************/ sbgo.setup.id = i; main_bgo.storeElement(static_cast<int>(i), sbgo, valid); if(setup.lastError() != IniProcessing::ERR_OK) addError(QString("ERROR LOADING lvl_bgo.ini N:%1 (bgo-%2)").arg(setup.lastError()).arg(i), PGE_LogLevel::Critical); } if(static_cast<unsigned long>(main_bgo.stored()) < bgo_total) addError(QString("Not all BGOs loaded! Total: %1, Loaded: %2").arg(bgo_total).arg(main_bgo.stored())); }