2013-01-09 18:22:22 +00:00
|
|
|
/* Copyright 2013 MultiMC Contributors
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PATHUTILS_H
|
|
|
|
#define PATHUTILS_H
|
|
|
|
|
|
|
|
#include <QString>
|
|
|
|
|
2013-02-21 01:10:09 +00:00
|
|
|
#include "libutil_config.h"
|
2013-01-09 18:22:22 +00:00
|
|
|
|
2013-02-26 22:47:39 +00:00
|
|
|
LIBUTIL_EXPORT QString PathCombine(QString path1, QString path2);
|
|
|
|
LIBUTIL_EXPORT QString PathCombine(QString path1, QString path2, QString path3);
|
2013-02-21 01:10:09 +00:00
|
|
|
|
2013-02-26 22:47:39 +00:00
|
|
|
LIBUTIL_EXPORT QString AbsolutePath(QString path);
|
2013-01-09 18:22:22 +00:00
|
|
|
|
2013-10-28 19:55:12 +00:00
|
|
|
/**
|
|
|
|
* Normalize path
|
|
|
|
*
|
|
|
|
* Any paths inside the current directory will be normalized to relative paths (to current)
|
|
|
|
* Other paths will be made absolute
|
|
|
|
*
|
|
|
|
* Returns false if the path logic somehow filed (and normalizedPath in invalid)
|
|
|
|
*/
|
|
|
|
QString NormalizePath(QString path);
|
|
|
|
|
2013-04-22 22:15:18 +00:00
|
|
|
LIBUTIL_EXPORT QString RemoveInvalidFilenameChars(QString string, QChar replaceWith = '-');
|
|
|
|
|
|
|
|
LIBUTIL_EXPORT QString DirNameFromString(QString string, QString inDir = ".");
|
|
|
|
|
2013-08-24 01:09:46 +00:00
|
|
|
/**
|
|
|
|
* Creates all the folders in a path for the specified path
|
|
|
|
* last segment of the path is treated as a file name and is ignored!
|
|
|
|
*/
|
|
|
|
LIBUTIL_EXPORT bool ensureFilePathExists(QString filenamepath);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates all the folders in a path for the specified path
|
|
|
|
* last segment of the path is treated as a folder name and is created!
|
|
|
|
*/
|
|
|
|
LIBUTIL_EXPORT bool ensureFolderPathExists(QString filenamepath);
|
2013-08-05 01:29:50 +00:00
|
|
|
|
2013-08-14 06:13:41 +00:00
|
|
|
LIBUTIL_EXPORT bool copyPath(QString src, QString dst);
|
|
|
|
|
2013-08-18 18:52:17 +00:00
|
|
|
/// Opens the given file in the default application.
|
|
|
|
LIBUTIL_EXPORT void openFileInDefaultProgram ( QString filename );
|
|
|
|
|
|
|
|
/// Opens the given directory in the default application.
|
|
|
|
LIBUTIL_EXPORT void openDirInDefaultProgram ( QString dirpath, bool ensureExists = false );
|
2013-08-14 06:13:41 +00:00
|
|
|
|
2013-01-09 18:22:22 +00:00
|
|
|
#endif // PATHUTILS_H
|