X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FLogger%2FFileTarget.cc;h=c6f758f83b9790879a58c2f64c4805ba29abcd88;hb=HEAD;hp=e4bf38fd4540620ef41e7d0a09ede620f048ba05;hpb=21be434729b552e31b856b2f42fc978062d0dd55;p=senf.git diff --git a/senf/Utils/Logger/FileTarget.cc b/senf/Utils/Logger/FileTarget.cc index e4bf38f..c6f758f 100644 --- a/senf/Utils/Logger/FileTarget.cc +++ b/senf/Utils/Logger/FileTarget.cc @@ -2,23 +2,28 @@ // // Copyright (C) 2007 // Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY -// Stefan Bund // -// 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. +// The contents of this file are subject to the Fraunhofer FOKUS Public License +// Version 1.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://senf.berlios.de/license.html // -// 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. +// The Fraunhofer FOKUS Public License Version 1.0 is based on, +// but modifies the Mozilla Public License Version 1.1. +// See the full license text for the amendments. // -// 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. +// Software distributed under the License is distributed on an "AS IS" basis, +// WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License +// for the specific language governing rights and limitations under the License. +// +// The Original Code is Fraunhofer FOKUS code. +// +// The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. +// (registered association), Hansastraße 27 c, 80686 Munich, Germany. +// All Rights Reserved. +// +// Contributor(s): +// Stefan Bund /** \file \brief FileTarget non-inline non-template implementation */ @@ -27,42 +32,48 @@ //#include "FileTarget.ih" // Custom includes -#include -#include +#include +#include +#include #include +#include //#include "FileTarget.mpp" #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// namespace { - + std::string getNodename(std::string const & filename, std::string const & nodename) { if (! nodename.empty()) return nodename; +#if BOOST_VERSION >= 104600 + return boost::filesystem::path(filename).leaf().string(); +#else return boost::filesystem::path(filename).leaf(); +#endif } } prefix_ senf::log::FileTarget::FileTarget(std::string const & filename, std::string const & nodename) - : ofstream_t (filename.c_str(), std::ofstream::app), - IOStreamTarget (getNodename(filename, nodename), ofstream_t::member), + : ofstream_t (filename.c_str(), std::ofstream::app), + IOStreamTarget (getNodename(filename, nodename), ofstream_t::member), file_ (filename) { - namespace fty = senf::console::factory; + namespace fty = console::factory; if (! ofstream_t::member) SENF_THROW_SYSTEM_EXCEPTION("logfile open") << ": " << filename; consoleDir() .add( "reopen", - fty::Command(this, SENF_MEMFNP(void, FileTarget, reopen, ())) + fty::Command(SENF_MEMBINDFNP(void, FileTarget, reopen, ())) .doc("Reopen logfile") ); consoleDir() - .add("reopen", - fty::Command(this, SENF_MEMFNP(void, FileTarget, reopen, (std::string const &))) + .add("reopen", + fty::Command(SENF_MEMBINDFNP(void, FileTarget, reopen, (std::string const &))) .arg("filename","new filename") .overloadDoc("Reopen logfile under new name") ); consoleDir() @@ -94,8 +105,8 @@ prefix_ std::string const & senf::log::FileTarget::filename() prefix_ senf::log::FileTarget::RegisterConsole::RegisterConsole() { - namespace kw = senf::console::kw; - namespace fty = senf::console::factory; + namespace kw = console::kw; + namespace fty = console::factory; detail::TargetRegistry::instance().consoleDir() .add("file-target", fty::Command(&RegisterConsole::create) @@ -118,7 +129,7 @@ prefix_ senf::log::FileTarget::RegisterConsole::RegisterConsole() } prefix_ boost::shared_ptr -senf::log::FileTarget::RegisterConsole::create(std::string const & filename, +senf::log::FileTarget::RegisterConsole::create(std::string const & filename, std::string const & nodename) { std::auto_ptr tp (new FileTarget(filename, nodename)); @@ -127,7 +138,7 @@ senf::log::FileTarget::RegisterConsole::create(std::string const & filename, return target.consoleDir().node().thisptr(); } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_ //#include "FileTarget.mpp"