#ifndef T_FILEPATH_INCLUDED
#define T_FILEPATH_INCLUDED
#include "tcommon.h"
#include "texception.h"
#undef DVAPI
#undef DVVAR
#ifdef TSYSTEM_EXPORTS
#define DVAPI DV_EXPORT_API
#define DVVAR DV_EXPORT_VAR
#else
#define DVAPI DV_IMPORT_API
#define DVVAR DV_IMPORT_VAR
#endif
class QString;
//-----------------------------------------------------------------------------
/*
This is an example of how to use TFilePath and TFrameId classes.
*/
//!\include frameid_ex.cpp
//! The class TFrameId describes a frame identified by an integer number of four figures and, in case, by a character (necessary for added frames)
class DVAPI TFrameId
{
int m_frame;
char m_letter; // serve per i frame "aggiunti" del tipo pippo.0001a.tzp => f=1 c='a'
public:
enum { EMPTY_FRAME = -1, // es. pippo..tif
NO_FRAME = -2 // es. pippo.tif
};
enum FrameFormat {
FOUR_ZEROS,
NO_PAD,
UNDERSCORE_FOUR_ZEROS, //pippo_0001.tif
UNDERSCORE_NO_PAD
}; //pippo_1.tif
TFrameId(int f = EMPTY_FRAME) : m_frame(f), m_letter(0){};
TFrameId(int f, char c) : m_frame(f), m_letter(c){};
inline bool operator==(const TFrameId &f) const { return f.m_frame == m_frame && f.m_letter == m_letter; };
inline bool operator!=(const TFrameId &f) const { return (m_frame != f.m_frame || m_letter != f.m_letter); };
inline bool operator<(const TFrameId &f) const { return (m_frame < f.m_frame || (m_frame == f.m_frame && m_letter < f.m_letter)); };
inline bool operator>(const TFrameId &f) const { return f < *this; }
inline bool operator>=(const TFrameId &f) const { return !operator<(f); }
inline bool operator<=(const TFrameId &f) const { return !operator>(f); }
const TFrameId &operator++();
const TFrameId &operator--();
TFrameId &operator=(const TFrameId &f)
{
m_frame = f.m_frame;
m_letter = f.m_letter;
return *this;
};
bool isEmptyFrame() const { return m_frame == EMPTY_FRAME; };
bool isNoFrame() const { return m_frame == NO_FRAME; };
//operator string() const;
string expand(FrameFormat format = FOUR_ZEROS) const;
int getNumber() const { return m_frame; };
char getLetter() const { return m_letter; };
};
//-----------------------------------------------------------------------------
/*! \relates TFrameId*/
inline ostream &operator<<(ostream &out, const TFrameId &f)
{
if (f.isNoFrame())
out << "<noframe>";
else if (f.isEmptyFrame())
out << "''";
else
out << f.expand().c_str();
return out;
}
//-----------------------------------------------------------------------------
/*!The class TFilePath defines a file path.Its constructor creates a string according
to the platform and to certain rules.For more information see the constructor.*/
class DVAPI TFilePath
{
static bool m_underscoreFormatAllowed;
wstring m_path;
void setPath(wstring path);
public:
/*! this static method allows correct reading of levels in the form pippo_0001.tif (represented always as pippo..tif) */
static void setUnderscoreFormatAllowed(bool state) { m_underscoreFormatAllowed = state; }
/*!This constructor creates a string removing redundances ('//', './',etc.) and final slashes,
correcting (redressing) the "twisted" slashes.
Note that if the current directory is ".", it becomes "".
If the path is "<alpha>:" a slash will be added*/
explicit TFilePath(const char *path = "");
explicit TFilePath(const string &path);
explicit TFilePath(const std::wstring &path);
explicit TFilePath(const QString &path);
~TFilePath(){};
TFilePath(const TFilePath &fp) : m_path(fp.m_path) {}
TFilePath &operator=(const TFilePath &fp)
{
m_path = fp.m_path;
return *this;
}
bool operator==(const TFilePath &fp) const;
inline bool operator!=(const TFilePath &fp) const { return !(m_path == fp.m_path); }
bool operator<(const TFilePath &fp) const;
const std::wstring getWideString() const;
QString getQString() const;
/*!Returns:
a. "" if there is no filename extension
b. "." if there is a filename extension but no frame
c.".." if there are both filename extension and frame */
string getDots() const; // ritorna ""(no estensione), "."(estensione, no frame) o ".."(estensione e frame)
/*!Returns the filename extension, including leading period (.).
Returns "" if there is no filename extension.*/
string getDottedType() const; // ritorna l'estensione con il PUNTO (se non c'e' estensione ritorna "")
/*!Returns the filename extension, escluding leading period (.).
Returns "" if there is no filename extension.*/
string getUndottedType() const; // ritorna l'estensione senza PUNTO
/*!It is equal to getUndottedType():
Returns the filename extension, excluding leading period (.).
Returns "" if there is no filename extension.*/
string getType() const { return getUndottedType(); }; // ritorna l'estensione SENZA PUNTO
/*!Returns the base filename (no extension, no dots, no slash)*/
string getName() const; // noDot! noSlash!
wstring getWideName() const; // noDot! noSlash!
/*!Returns the filename (with extension, escluding in case the frame number).
ex.: TFilePath("/pippo/pluto.0001.gif").getLevelName() == "pluto..gif"
*/
string getLevelName() const; // es. TFilePath("/pippo/pluto.0001.gif").getLevelName() == "pluto..gif"
std::wstring getLevelNameW() const; // es. TFilePath("/pippo/pluto.0001.gif").getLevelName() == "pluto..gif"
/*!Returns the parent directory escluding the eventual final slash.*/
TFilePath getParentDir() const; // noSlash!;
TFrameId getFrame() const;
bool isLevelName() const; //{return getFrame() == TFrameId(TFrameId::EMPTY_FRAME);};
bool isAbsolute() const;
bool isRoot() const;
bool isEmpty() const { return m_path == L""; };
/*!Return a TFilePath with extension type.
type is a string that indicate the filename extension(ex:. bmp or .bmp)*/
TFilePath withType(const string &type) const;
/*!Return a TFilePath with filename "name".*/
TFilePath withName(const string &name) const;
/*!Return a TFilePath with filename "name". Unicode*/
TFilePath withName(const std::wstring &name) const;
/*!Return a TFilePath with parent directory "dir".*/
TFilePath withParentDir(const TFilePath &dir) const;
/*!Return a TFilePath without parent directory */
TFilePath withoutParentDir() const { return withParentDir(TFilePath()); }
/*!Return a TFilePath with frame "frame".*/
TFilePath withFrame(const TFrameId &frame, TFrameId::FrameFormat format = TFrameId::FOUR_ZEROS) const;
/*!Return a TFilePath with a frame identified by an integer number "f".*/
TFilePath withFrame(int f) const { return withFrame(TFrameId(f)); };
/*!Return a TFilePath with a frame identified by an integer and by a character*/
TFilePath withFrame(int f, char letter) const { return withFrame(TFrameId(f, letter)); };
TFilePath withFrame() const { return withFrame(TFrameId(TFrameId::EMPTY_FRAME)); };
TFilePath withNoFrame() const { return withFrame(TFrameId(TFrameId::NO_FRAME)); }; // pippo.tif
TFilePath operator+(const TFilePath &fp) const;
TFilePath &operator+=(const TFilePath &fp) /*{*this=*this+fp;return *this;}*/;
inline TFilePath operator+(const string &s) const
{
return operator+(TFilePath(s));
};
inline TFilePath &operator+=(const string &s)
{
return operator+=(TFilePath(s));
};
TFilePath &operator+=(const std::wstring &s);
TFilePath operator+(const std::wstring &s) const
{
TFilePath res(*this);
return res += s;
}
bool isAncestorOf(const TFilePath &) const;
TFilePath operator-(const TFilePath &fp) const; // TFilePath("/a/b/c.txt")-TFilePath("/a/") == TFilePath("b/c.txt");
// se fp.isAncestorOf(this) == false ritorna this
bool match(const TFilePath &fp) const; // sono uguali a meno del numero di digits del frame
// '/a/b/c.txt' => head='a' tail='b/c.txt'
void split(wstring &head, TFilePath &tail) const;
};
//-----------------------------------------------------------------------------
class TMalformedFrameException : public TException
{
public:
TMalformedFrameException(const TFilePath &fp, const wstring &msg = wstring())
: TException(fp.getWideName() + L":" + msg)
{
}
private:
TMalformedFrameException();
};
//-----------------------------------------------------------------------------
DVAPI ostream &operator<<(ostream &out, const TFilePath &path);
typedef list<TFilePath> TFilePathSet;
#endif //T_FILEPATH_INCLUDED