This file is indexed.

/usr/include/claw/arguments_table.hpp is in libclaw-application-dev 1.7.4-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
/*
  CLAW - a C++ Library Absolutely Wonderful

  CLAW is a free library without any particular aim but being useful to 
  anyone.

  Copyright (C) 2005-2011 Julien Jorge

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either
  version 2.1 of the License, or (at your option) any later version.

  This library 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
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with this library; if not, write to the Free Software
  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

  contact: julien.jorge@gamned.org
*/
/**
 * \file arguments_table.hpp
 * \brief A class to manage the arguments of your program, with automatic
 *        management of short/long arguments and help message.
 * \author Julien Jorge
 */
#ifndef __CLAW_ARGUMENTS_TABLE_HPP__
#define __CLAW_ARGUMENTS_TABLE_HPP__

#include <claw/arguments.hpp>

namespace claw
{
  /**
   * \brief A class to manage the arguments of your program, with automatic
   *        management of short/long arguments and help message.
   *
   * \remark None of those methods is allowed to use claw::logger because when
   *         we are processing the arguments, we are at the really begining of
   *         the program and claw::logger is probably not initialised.
   *
   * \author Julien Jorge
   */
  class arguments_table
  {
  private:
    /**
     * \brief This class manage the description of an argument.
     * \author Julien Jorge.
     */
    class argument_attributes
    {
    public:
      argument_attributes( const std::string& name,
                           const std::string& second_name,
                           const std::string& help_message, bool optional,
                           const std::string& value_type );

      bool operator<( const argument_attributes& that ) const;

      std::string format_short_help() const;
      std::string format_long_help() const;

      const std::string& get_name() const;
      const std::string& get_second_name() const;

      bool is_optional() const;

    private:
      /** \brief The principal name of the argument. */
      const std::string m_name;

      /** \brief The second name of the argument. */
      const std::string m_second_name;

      /** \brief Message describing the argument. */
      const std::string m_help_message;

      /** \brief Tell if the argument is optional. */
      const bool m_optional;

      /** \brief The type of the value needed by this argument. */
      const std::string m_value_type;

    }; // class argument_attributes

  public:
    explicit arguments_table( const std::string& prog_name );
    arguments_table( int& argc, char** &argv );

    void add( const std::string& short_name, const std::string& long_name,
              const std::string& help_msg = "", bool optional = false,
              const std::string& val_name = "" );
    void add_long( const std::string& long_name,
                   const std::string& help_msg = "", bool optional = false,
                   const std::string& val_name = "" );
    void add_short( const std::string& short_name,
                    const std::string& help_msg = "", bool optional = false,
                    const std::string& val_name = "" );
    
    void parse( int& argc, char** &argv );
    void help( const std::string& free_args = "" ) const;
    
    bool required_fields_are_set() const;
    bool has_value( const std::string& arg_name ) const;
    bool only_integer_values( const std::string& arg_name ) const;
    bool only_real_values( const std::string& arg_name ) const;

    const std::string& get_program_name() const;

    bool get_bool( const std::string& arg_name ) const;
    int get_integer( const std::string& arg_name ) const;
    double get_real( const std::string& arg_name ) const;
    const std::string& get_string( const std::string& arg_name ) const;

    std::list<int> get_all_of_integer( const std::string& arg_name ) const;
    std::list<double> get_all_of_real( const std::string& arg_name ) const;
    std::list<std::string>
    get_all_of_string( const std::string& arg_name ) const;

    void add_argument( const std::string& arg );

  private:
    void get_argument_names( const std::string& arg_name,
                             std::string& short_name,
                             std::string& long_name ) const;

  private:
    /** \brief The class that will store arguments values. */
    arguments m_arguments;

    /** \brief The arguments with a short version. */
    math::ordered_set<argument_attributes> m_short_arguments;

    /** \brief The arguments with a long version. */
    math::ordered_set<argument_attributes> m_long_arguments;

  }; // class arguments_table
} // namespace claw

#endif // __CLAW_ARGUMENTS_TABLE_HPP__