X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ffile_system.cpp;h=266da812f6be7a712190976a22d4533e2507eaa7;hb=8ea989626785c9a386bf4aef1b44fd201b677a08;hp=826d4b75326b5b74f24e433a4a53a7edd0abd01e;hpb=eb40ead9684fd22440c6deeaaf5c3408eead208a;p=supertux.git diff --git a/src/file_system.cpp b/src/file_system.cpp index 826d4b753..266da812f 100644 --- a/src/file_system.cpp +++ b/src/file_system.cpp @@ -1,10 +1,29 @@ +// $Id$ +// +// SuperTux +// Copyright (C) 2006 Matthias Braun +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// 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 General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + #include +#include "log.hpp" #include "file_system.hpp" #include #include -#include #include namespace FileSystem @@ -13,9 +32,9 @@ namespace FileSystem std::string dirname(const std::string& filename) { std::string::size_type p = filename.find_last_of('/'); - if(p == std::string::npos) + if(p == std::string::npos) return ""; - + return filename.substr(0, p+1); } @@ -25,7 +44,16 @@ std::string basename(const std::string& filename) if(p == std::string::npos) return filename; - return filename.substr(p, filename.size()-p); + return filename.substr(p+1, filename.size()-p-1); +} + +std::string strip_extension(const std::string& filename) +{ + std::string::size_type p = filename.find_last_of('.'); + if(p == std::string::npos) + return filename; + + return filename.substr(0, p); } std::string normalize(const std::string& filename) @@ -48,14 +76,15 @@ std::string normalize(const std::string& filename) size_t len = p - pstart; if(len == 0) break; - + std::string pathelem(pstart, p-pstart); if(pathelem == ".") continue; - + if(pathelem == "..") { if(path_stack.empty()) { - std::cout << "Invalid '..' in path '" << filename << "'.\n"; + + log_warning << "Invalid '..' in path '" << filename << "'" << std::endl; // push it into the result path so that the users sees his error... path_stack.push_back(pathelem); } else { @@ -79,4 +108,3 @@ std::string normalize(const std::string& filename) } } -