//
// ${project trunk_name} - ${project trunk_description}
// Copyright (C) ${date %Y} ${copyright-owner}
//
// 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 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
// General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//

#ifndef ${id ${upcase $fn}}
#define ${id ${upcase $fn}}

#include <${dirname_rel $fn}.h>

/**
  * The ${id ${trim_dir ${trim_ext $fn}}} class is used to represent
  * #fillmein
  */
class ${id ${trim_dir ${trim_ext $fn}}}:
    public ${id ${trim_dir ${dirname_rel $fn}}}
{
public:
    typedef boost::shared_ptr<${id ${trim_dir ${trim_ext $fn}}}> pointer;

    /**
      * The destructor.
      */
    virtual ~${id ${trim_dir ${trim_ext $fn}}}();

private:
    /**
      * The default constructor.
      * It is private on purpose, use a #create class method instead.
      */
    ${id ${trim_dir ${trim_ext $fn}}}();

public:
    /**
      * The create class method is used to create new dynamically
      * allocated instances of this class.
      */
    static pointer create(void);

private:
    /**
      * The fubar instance variable is used to remember
      * #fillmein
      */
    int fubar;

private:
    /**
      * The copy constructor.
      * It is private on purpose, use a #create class method instead.
      *
      * @param rhs
      *     The right hand side of the initialisation.
      */
    ${id ${trim_dir ${trim_ext $fn}}}(const ${id ${trim_dir ${trim_ext
        $fn}}} &rhs);

public:
    /**
      * The create class method is used to create new dynamically
      * allocated instances of this class.
      *
      * @param rhs
      *     The right hand side of the initialisation.
      */
    static pointer create(const ${id ${trim_dir ${trim_ext $fn}}} &rhs);

public:
    /**
      * The assignment operator.
      *
      * @param rhs
      *     The right hand side of the initialisation.
      */
    ${id ${trim_dir ${trim_ext $fn}}} &operator=(const ${id ${trim_dir
        ${trim_ext $fn}}} &rhs);
};

#endif // ${id ${upcase $fn}}
