mirror of
				https://github.com/YACReader/yacreader
				synced 2025-10-26 13:54:23 -04:00 
			
		
		
		
	comprobaciones de versi?n de la DB implementadas.
Versi?n 5.0 RC1.
This commit is contained in:
		| @ -128,6 +128,14 @@ void CreateLibraryDialog::close() | ||||
| 	accept->setEnabled(true); | ||||
| 	QDialog::close(); | ||||
| } | ||||
|  | ||||
| void CreateLibraryDialog::setDataAndStart(QString name, QString path) | ||||
| { | ||||
| 	this->path->setText(path); | ||||
| 	this->nameEdit->setText(name); | ||||
| 	show(); | ||||
| 	create(); | ||||
| } | ||||
| //----------------------------------------------------------------------------- | ||||
| // UpdateLibraryDialog | ||||
| //----------------------------------------------------------------------------- | ||||
|  | ||||
| @ -30,6 +30,7 @@ | ||||
| 		void findPath(); | ||||
| 		void showCurrentFile(QString file); | ||||
| 		void close(); | ||||
| 		void setDataAndStart(QString name, QString paht); | ||||
| 	signals: | ||||
| 		void createLibrary(QString source, QString target, QString name); | ||||
| 		void cancelCreate(); | ||||
|  | ||||
| @ -494,14 +494,24 @@ QString DataBaseManagement::checkValidDB(const QString & fullPath) | ||||
| 		version.exec(); | ||||
| 		if(version.next()) | ||||
| 		{ | ||||
| 			db.close(); | ||||
| 			QSqlDatabase::removeDatabase(fullPath); | ||||
| 			return version.record().value("version").toString(); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			db.close(); | ||||
| 			QSqlDatabase::removeDatabase(fullPath); | ||||
| 			return ""; | ||||
| 		} | ||||
|  | ||||
| 	} | ||||
| 	else | ||||
| 	return ""; | ||||
| 	{ | ||||
| 		db.close(); | ||||
| 		QSqlDatabase::removeDatabase(fullPath); | ||||
| 		return ""; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| int DataBaseManagement::compareVersions(const QString & v1, const QString v2) | ||||
|  | ||||
| @ -41,8 +41,13 @@ void LibraryCreator::processLibrary(const QString & source, const QString & targ | ||||
| { | ||||
| 	_source = source; | ||||
| 	_target = target; | ||||
| 	if(!(QFile(target+"/library.ydb").exists())) //TODO, no sirve s<>lo con realizar el update, hay que validar la base de datos y determinar si existe "/covers" | ||||
| 	//if(!(QFile(target+"/library.ydb").exists())) //TODO, no sirve s<>lo con realizar el update, hay que validar la base de datos y determinar si existe "/covers" | ||||
| 	if(DataBaseManagement::checkValidDB(target+"/library.ydb")=="") | ||||
| 	{ | ||||
| 		//se limpia el directorio ./yacreaderlibrary | ||||
| 		delTree(target); | ||||
| 		_mode = CREATOR; | ||||
| 	} | ||||
| 	else | ||||
| 		_mode = UPDATER; | ||||
| } | ||||
|  | ||||
| @ -600,43 +600,43 @@ void LibraryWindow::createConnections() | ||||
|  | ||||
| void LibraryWindow::loadLibrary(const QString & name) | ||||
| { | ||||
| 	if(libraries.size()>0) | ||||
| 	if(libraries.size()>0)  //si hay bibliotecas... | ||||
| 	{	 | ||||
| 		QString path=libraries.value(name)+"/.yacreaderlibrary"; | ||||
| 		QDir d; //TODO change this by static methods (utils class?? with delTree for example) | ||||
| 		QString dbVersion; | ||||
| 		if(d.exists(path) && (dbVersion = DataBaseManagement::checkValidDB(path+"/library.ydb")) != "") | ||||
| 		if(d.exists(path) && (dbVersion = DataBaseManagement::checkValidDB(path+"/library.ydb")) != "") //si existe en disco la biblioteca seleccionada, y es v<>lida.. | ||||
| 		{ | ||||
| 			int comparation; | ||||
| 			if((comparation = DataBaseManagement::compareVersions(dbVersion,VERSION)) == 0) | ||||
| 			if((comparation = DataBaseManagement::compareVersions(dbVersion,VERSION)) == 0) //en caso de que la versi<73>n se igual que la actual | ||||
| 			{ | ||||
| 			index = 0; | ||||
| 			sm->clear(); | ||||
| 			//foldersView->setModel(NULL); //TODO comprobar pq no sirve con usar simplemente las se<73>ales beforeReset y reset | ||||
| 			//comicView->setModel(NULL); | ||||
| 				index = 0; | ||||
| 				sm->clear(); | ||||
| 				//foldersView->setModel(NULL); //TODO comprobar pq no sirve con usar simplemente las se<73>ales beforeReset y reset | ||||
| 				//comicView->setModel(NULL); | ||||
|  | ||||
| 			dm->setupModelData(path); | ||||
| 			foldersView->setModel(dm); | ||||
| 			 | ||||
| 			d.setCurrent(libraries.value(name)); | ||||
| 			d.setFilter(QDir::AllDirs | QDir::Files | QDir::Hidden | QDir::NoSymLinks | QDir::NoDotAndDotDot); | ||||
| 			if(d.count()<=1) //librer<65>a de s<>lo lectura | ||||
| 			{ | ||||
| 				//QMessageBox::critical(NULL,QString::number(d.count()),QString::number(d.count())); | ||||
| 				disableActions(); | ||||
| 				importedCovers = true; | ||||
| 			} | ||||
| 			else //librer<65>a normal abierta | ||||
| 			{ | ||||
| 				enableActions(); | ||||
| 				importedCovers = false; | ||||
| 			} | ||||
| 			enableLibraryActions(); | ||||
| 				dm->setupModelData(path); | ||||
| 				foldersView->setModel(dm); | ||||
|  | ||||
| 			loadCovers(QModelIndex()); | ||||
| 				d.setCurrent(libraries.value(name)); | ||||
| 				d.setFilter(QDir::AllDirs | QDir::Files | QDir::Hidden | QDir::NoSymLinks | QDir::NoDotAndDotDot); | ||||
| 				if(d.count()<=1) //librer<65>a de s<>lo lectura | ||||
| 				{ | ||||
| 					//QMessageBox::critical(NULL,QString::number(d.count()),QString::number(d.count())); | ||||
| 					disableActions(); | ||||
| 					importedCovers = true; | ||||
| 				} | ||||
| 				else //librer<65>a normal abierta | ||||
| 				{ | ||||
| 					enableActions(); | ||||
| 					importedCovers = false; | ||||
| 				} | ||||
| 				enableLibraryActions(); | ||||
|  | ||||
| 			//includeComicsCheckBox->setCheckState(Qt::Unchecked); | ||||
| 			foldersFilter->clear(); | ||||
| 				loadCovers(QModelIndex()); | ||||
|  | ||||
| 				//includeComicsCheckBox->setCheckState(Qt::Unchecked); | ||||
| 				foldersFilter->clear(); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| @ -675,14 +675,31 @@ void LibraryWindow::loadLibrary(const QString & name) | ||||
| 			comicFlow->clear(); | ||||
| 			disableAllActions();//TODO comprobar que se deben deshabilitar | ||||
|  | ||||
| 			QString currentLibrary = selectedLibrary->currentText(); | ||||
| 			if(QMessageBox::question(this,tr("Library not available"),tr("Library ")+currentLibrary+tr(" is no longer available. Do you want to remove it?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes) | ||||
| 			//si la librer<65>a no existe en disco, se ofrece al usuario la posibiliad de eliminarla | ||||
| 			if(!d.exists(path)) | ||||
| 			{ | ||||
| 				deleteCurrentLibrary(); | ||||
| 				QString currentLibrary = selectedLibrary->currentText(); | ||||
| 				if(QMessageBox::question(this,tr("Library not available"),tr("Library ")+currentLibrary+tr(" is no longer available. Do you want to remove it?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes) | ||||
| 				{ | ||||
| 					deleteCurrentLibrary(); | ||||
| 				} | ||||
| 			} | ||||
| 			else//si existe el path, puede ser que la librer<65>a sea alguna versi<73>n pre-5.0 <20> que est<73> corrupta | ||||
| 			{ | ||||
| 				QString currentLibrary = selectedLibrary->currentText(); | ||||
| 				QString path = libraries.value(selectedLibrary->currentText()); | ||||
| 				if(QMessageBox::question(this,tr("Old library or corrupted"),tr("Library ")+currentLibrary+tr(" is corrupted or has been created with an older version of YACReaderLibrary. It must be created again. Do you want to create the library now?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes) | ||||
| 				{ | ||||
| 					QDir d(path+"/.yacreaderlibrary"); | ||||
| 					delTree(d); | ||||
| 					d.rmdir(path+"/.yacreaderlibrary"); | ||||
| 					createLibraryDialog->setDataAndStart(currentLibrary,path); | ||||
| 					//create(path,path+"/.yacreaderlibrary",currentLibrary); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
| 	else //en caso de que no exista ninguna biblioteca se desactivan los botones pertinentes | ||||
| 	{ | ||||
| 		disableAllActions(); | ||||
| 	} | ||||
|  | ||||
		Reference in New Issue
	
	Block a user