// Ryzom - MMORPG Framework
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see .
//-------------------------------------------------------------------------------------------------
// includes
//-------------------------------------------------------------------------------------------------
#include "stdpch.h"
#include "nel/misc/path.h"
#include "nel/misc/algo.h"
#include "utils.h"
#include "file_description_container.h"
#ifdef NL_OS_WINDOWS
#include
#include
//#include
#include
#endif
//-------------------------------------------------------------------------------------------------
// namespaces
//-------------------------------------------------------------------------------------------------
using namespace std;
using namespace NLMISC;
//-------------------------------------------------------------------------------------------------
// methods CFileDescription
//-------------------------------------------------------------------------------------------------
CFileDescription::CFileDescription(const string& name,uint32 time,uint32 size)
{
FileName=name;
FileTimeStamp=time;
FileSize=size;
}
bool CFileDescription::set(const string& name)
{
FileName=name;
// if the file doesn't exist then zero out time stamp and size and return false
if (!NLMISC::CFile::fileExists(name))
{
FileTimeStamp=0;
FileSize=0;
return false;
}
// setup timestamp and size for the file
FileTimeStamp=NLMISC::CFile::getFileModificationDate(name);
FileSize=NLMISC::CFile::getFileSize(name);
return true;
}
void CFileDescription::serial(NLMISC::IStream& stream)
{
stream.serial(FileName);
stream.serial(FileTimeStamp);
stream.serial(FileSize);
}
CSString CFileDescription::toString(uint32 maxFileNameLen) const
{
return NLMISC::toString("%*s (size: %u, time stamp: %s)",maxFileNameLen,FileName.c_str(),FileSize,IDisplayer::dateToHumanString(FileTimeStamp));
}
bool CFileDescription::operator<(const CFileDescription& other) const
{
return FileName wildcards;
wildcards.push_back(theWildcard.empty()? "*": theWildcard);
addFiles(path,wildcards,recurse);
}
void CFileDescriptionContainer::addFiles(const std::string& directory, const std::vector& wildcards, bool recurse)
{
H_AUTO(fdcAddFiles)
std::string path= directory.empty()? ".": directory;
// build a list of all files in the matching directory
vector rawFileNames;
{
H_AUTO(fdcAddFilesGetPathContents)
NLMISC::CPath::getPathContent(path.c_str(),recurse,false,true,rawFileNames);
}
// extract the files that match the given wildcard and build a result vector
{
H_AUTO(fdcAddFilesTestWildcards)
for (uint32 i=rawFileNames.size();i--;)
{
uint32 j;
for (j=0;j&>(wildcards),recurse);
}
void CFileDescriptionContainer::addFiles(const CFileDescriptionContainer& other)
{
// note: the following can doubtless be done with a single tsl operation (eg +=)
// but I don't have an stl refference to hand so doing it longhand...
// make room in the file description container for the data from the other object
uint32 otherSize= other._FileDescriptions.size();
uint32 oldSize= _FileDescriptions.size();
uint32 newSize= oldSize + otherSize;
_FileDescriptions.resize(newSize);
// prepare to copy from one vector to the other
TFileDescriptions::iterator destIt = _FileDescriptions.begin()+oldSize;
TFileDescriptions::const_iterator srcIt = other._FileDescriptions.begin();
TFileDescriptions::const_iterator itEnd = other._FileDescriptions.end();
// do the copy
while (srcIt!=itEnd)
{
*destIt= *srcIt;
++srcIt;
++destIt;
}
}
void CFileDescriptionContainer::display(NLMISC::CLog* log) const
{
nlassert(log!=NULL);
// determine the length of the longest file name
uint32 longest=10;
for (uint32 i=0;i<_FileDescriptions.size();++i)
longest=max(longest,(uint32)_FileDescriptions[i].FileName.size());
// build a vector of strings to display
vector lines;
for (uint32 i=0;i<_FileDescriptions.size();++i)
lines.push_back(NLMISC::toString("%-*s %12d %s",longest,
_FileDescriptions[i].FileName.c_str(),
_FileDescriptions[i].FileSize,
IDisplayer::dateToHumanString(_FileDescriptions[i].FileTimeStamp)));
// sort the lines to make a nice alphabetical list
sort(lines.begin(),lines.end());
// display a nice banner
log->displayNL("%-*s %12s %12s",longest,"File_Name","File_Size","File_Time");
// display the file list
for (uint32 i=0;i<_FileDescriptions.size();++i)
log->displayNL(lines[i].c_str());
}
void CFileDescriptionContainer::serial(NLMISC::IStream& stream)
{
stream.serialCont(_FileDescriptions);
}
uint32 CFileDescriptionContainer::size() const
{
return _FileDescriptions.size();
}
bool CFileDescriptionContainer::empty() const
{
return _FileDescriptions.empty();
}
void CFileDescriptionContainer::clear()
{
_FileDescriptions.clear();
}
const CFileDescription& CFileDescriptionContainer::operator[](uint32 idx) const
{
return (_FileDescriptions[idx]);
}
CFileDescription& CFileDescriptionContainer::operator[](uint32 idx)
{
return (_FileDescriptions[idx]);
}
// remove the 'n'th element from a file description container
void CFileDescriptionContainer::removeFile(uint32 idx)
{
BOMB_IF(idx>=_FileDescriptions.size(),"trying to remove files beyond the end of the file description vector",return);
_FileDescriptions[idx]=_FileDescriptions.back();
_FileDescriptions.pop_back();
}
// remove the provided string if found at the beginning of FileName
void CFileDescriptionContainer::stripFilename(const std::string& header)
{
for (std::vector::iterator it=_FileDescriptions.begin(); it!=_FileDescriptions.end(); ++it)
{
it->stripFilename(header);
}
}
//-------------------------------------------------------------------------------------------------