⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 paramstorer.h

📁 ROBOCUP 仿真3D server 源码
💻 H
字号:
/* -*- mode: c++; c-basic-offset: 4; indent-tabs-mode: nil -*-   this file is part of rcssserver3D   Fri May 9 2003   Copyright (C) 2002,2003 Koblenz University   Copyright (C) 2003 RoboCup Soccer Server 3D Maintenance Group   $Id: paramstorer.h,v 1.3 2004/02/12 14:07:23 fruit Exp $   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; version 2 of the License.   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., 675 Mass Ave, Cambridge, MA 02139, USA.*/#ifndef OXYGEN_PARAMSTORER_H__#define OXYGEN_PARAMSTORER_H__#include "paramreader.h"#include <spades/ParamReader.hpp>namespace oxygen{/** This class implements the spades::ParamReader::ParamStorer    interface. It's purpose is to enable the user to set ruby    variables using the command line.    A note about the implementation: ParamStorer uses the ParamReader    class to do the real parsing. This has the following reason.    In order to access the ScriptServer to modify ruby variables the    ParamStorer must be a ZeitGeist class. This involves that the    corresponding class object holds a shared pointer to every    instance of this class.    However spades is not aware of these shared pointers and destructs    a registered ParamStorer instance using delete without notifying    the shared pointers. This would result in dangling references.    In order to play well with spades this class is not derived from    Zeitgeist::object. In order to access the ScriptServer this class    uses the ParamReader instance.*/class ParamStorer : public spades::ParamReader::ParamStorer{public:    ParamStorer(oxygen::ParamReader* paramReader) :        spades::ParamReader::ParamStorer(), mParamReader(paramReader) {}    virtual int readArgsFrom(const std::string& /*key*/, const char* /*fileid*/,                             const char* /*path*/, std::istream& /*is*/,                             bool /*have_argument*/)    {        // we read nothing from any files        return RR_None;    }    virtual void print(std::ostream& /*o*/) const    {        // no output    }    // returns the number of args processed    // otherwise see the RR_ values above    virtual int readCmdLineArgs(const std::string& key,                                int argc, const char* const* argv);protected:    /** The ParamReader we use to do the parsing */    oxygen::ParamReader* mParamReader;};} // namespace oxygen#endif // OXYGEN_PARAMSTORER_H__

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -