GH-228 do not follow symlinks during instance copy on unix
Windows will need a more complex solution.
This commit is contained in:
		| @@ -51,7 +51,7 @@ LIBUTIL_EXPORT bool ensureFilePathExists(QString filenamepath); | |||||||
|  */ |  */ | ||||||
| LIBUTIL_EXPORT bool ensureFolderPathExists(QString filenamepath); | LIBUTIL_EXPORT bool ensureFolderPathExists(QString filenamepath); | ||||||
|  |  | ||||||
| LIBUTIL_EXPORT bool copyPath(QString src, QString dst); | LIBUTIL_EXPORT bool copyPath(QString src, QString dst, bool follow_symlinks = true); | ||||||
|  |  | ||||||
| /// Opens the given file in the default application. | /// Opens the given file in the default application. | ||||||
| LIBUTIL_EXPORT void openFileInDefaultProgram(QString filename); | LIBUTIL_EXPORT void openFileInDefaultProgram(QString filename); | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| #include <QDir> | #include <QDir> | ||||||
| #include <QDesktopServices> | #include <QDesktopServices> | ||||||
| #include <QUrl> | #include <QUrl> | ||||||
|  | #include <QDebug> | ||||||
|  |  | ||||||
| QString PathCombine(QString path1, QString path2) | QString PathCombine(QString path1, QString path2) | ||||||
| { | { | ||||||
| @@ -111,26 +112,45 @@ bool ensureFolderPathExists(QString foldernamepath) | |||||||
| 	return success; | 	return success; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool copyPath(QString src, QString dst) | bool copyPath(QString src, QString dst, bool follow_symlinks) | ||||||
| { | { | ||||||
|  | 	//NOTE always deep copy on windows. the alternatives are too messy. | ||||||
|  | 	#if defined Q_OS_WIN32 | ||||||
|  | 	follow_symlinks = true; | ||||||
|  | 	#endif | ||||||
|  |  | ||||||
| 	QDir dir(src); | 	QDir dir(src); | ||||||
| 	if (!dir.exists()) | 	if (!dir.exists()) | ||||||
| 		return false; | 		return false; | ||||||
| 	if (!ensureFolderPathExists(dst)) | 	if (!ensureFolderPathExists(dst)) | ||||||
| 		return false; | 		return false; | ||||||
|  |  | ||||||
| 	foreach(QString d, dir.entryList(QDir::Dirs | QDir::NoDotAndDotDot)) | 	bool OK = true; | ||||||
| 	{ |  | ||||||
| 		QString inner_src = src + QDir::separator() + d; |  | ||||||
| 		QString inner_dst = dst + QDir::separator() + d; |  | ||||||
| 		copyPath(inner_src, inner_dst); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	foreach(QString f, dir.entryList(QDir::Files)) | 	foreach(QString f, dir.entryList(QDir::Files | QDir::Dirs | QDir::NoDotAndDotDot | QDir::Hidden | QDir::System)) | ||||||
| 	{ | 	{ | ||||||
| 		QFile::copy(src + QDir::separator() + f, dst + QDir::separator() + f); | 		QString inner_src = src + QDir::separator() + f; | ||||||
|  | 		QString inner_dst = dst + QDir::separator() + f; | ||||||
|  | 		QFileInfo fileInfo(inner_src); | ||||||
|  | 		if(!follow_symlinks && fileInfo.isSymLink()) | ||||||
|  | 		{ | ||||||
|  | 			OK &= QFile::link(fileInfo.symLinkTarget(),inner_dst); | ||||||
|  | 		} | ||||||
|  | 		else if (fileInfo.isDir()) | ||||||
|  | 		{ | ||||||
|  | 			OK &= copyPath(inner_src, inner_dst, follow_symlinks); | ||||||
|  | 		} | ||||||
|  | 		else if (fileInfo.isFile()) | ||||||
|  | 		{ | ||||||
|  | 			OK &= QFile::copy(inner_src, inner_dst); | ||||||
|  | 		} | ||||||
|  | 		else | ||||||
|  | 		{ | ||||||
|  | 			OK = false; | ||||||
|  | 			qCritical() << "Copy ERROR: Unknown filesystem object:" << inner_src; | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 	return true; | 	return OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| void openDirInDefaultProgram(QString path, bool ensureExists) | void openDirInDefaultProgram(QString path, bool ensureExists) | ||||||
|   | |||||||
| @@ -501,7 +501,7 @@ InstanceList::copyInstance(InstancePtr &newInstance, InstancePtr &oldInstance, c | |||||||
| 	QDir rootDir(instDir); | 	QDir rootDir(instDir); | ||||||
|  |  | ||||||
| 	qDebug() << instDir.toUtf8(); | 	qDebug() << instDir.toUtf8(); | ||||||
| 	if (!copyPath(oldInstance->instanceRoot(), instDir)) | 	if (!copyPath(oldInstance->instanceRoot(), instDir, false)) | ||||||
| 	{ | 	{ | ||||||
| 		rootDir.removeRecursively(); | 		rootDir.removeRecursively(); | ||||||
| 		return InstanceList::CantCreateDir; | 		return InstanceList::CantCreateDir; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Petr Mrázek
					Petr Mrázek