This file is indexed.

/usr/include/claw/automaton.hpp is in libclaw-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 automaton.hpp
 * \brief A basic automaton structure.
 * \author Julien Jorge
 */
#ifndef __CLAW_AUTOMATON_HPP__
#define __CLAW_AUTOMATON_HPP__

#include <map>
#include <vector>
#include <claw/avl.hpp>

namespace claw
{
  //***************************** automate ************************************

    /**
     * \brief Basic automaton structure.
     *
     * An automaton is a quintuplet (A, E, I ,F, T) where
     * - A is the set of symbols,
     * - E is the set of states,
     * - I is the set of initial states,
     * - F is the set of finalstates,
     * - T is the set of transitions (labeled edges)
     *
     * \b Template \b parameters
     * - \a State The type of the states.
     * - \a Edge The type of the symbols in the alphabet.
     */
  template<class State, class Edge, class StateComp = std::less<State>,
           class EdgeComp = std::less<Edge> >
  class automaton
  {
  public:
    /** \brief The type of the states. */
    typedef State state_type;

    /** \brief The type of the symbols on the edges. */
    typedef Edge edge_type;

    /** \brief The type of the operator used to compare states. */
    typedef StateComp state_compare;

    /** \brief The type of the operator used to compare edge symbols. */
    typedef EdgeComp  edge_compare;

    /** \brief The neighbours list associates states to edge symbols.*/
    typedef std::multimap<edge_type, state_type, edge_compare> neighbours_list;

    /** \brief Each state is given a set of reachable states with a neighbours
	list. */
    typedef std::map<state_type, neighbours_list, state_compare> adjacent_list;

    /** \brief The return type of the methods returning states. */
    typedef std::vector<state_type> result_state_list;

    /** \brief The return type of the methods returning edges. */
    typedef std::vector<edge_type> result_edge_list;

  public:
    void add_edge( const state_type& s1, const state_type& s2,
                   const edge_type& e );
    void remove_edge( const state_type& s1, const state_type& s2,
                      const edge_type& e );

    void add_state( const state_type& s );
    void add_initial_state( const state_type& s );
    void add_final_state( const state_type& s );

    bool state_exists( const state_type& s ) const;
    bool state_is_final( const state_type& s ) const;
    bool state_is_initial( const state_type& s ) const;

    void states( result_state_list& v ) const;
    void final_states( result_state_list& v ) const;
    void initial_states( result_state_list& v ) const;
    void alphabet( result_edge_list& v ) const;

    template<class InputIterator>
    bool match(InputIterator first, InputIterator last) const;

    unsigned int states_count() const;

    void reachables( const state_type& s, const edge_type& e,
                     result_state_list& l ) const;
    void reachables( const state_type& s,
                     result_state_list& l ) const;

    void edges( const state_type& s1, const state_type& s2,
                result_edge_list& l ) const;
    void edges( const state_type& s1, const edge_type& edge,
                result_edge_list& l ) const;

  private:
    template<class InputIterator>
    bool match_aux(const state_type& s, InputIterator first,
                   InputIterator last) const;

  private:
    /** \brief The predicate used to compare states. */
    static state_compare s_state_compare;

    /** \brief The set of symbols in the alphabet. */
    avl<edge_type, edge_compare> m_alphabet;

    /** \brief The set of initial states. */
    avl<state_type, state_compare> m_initial_states;

    /** \brief The set of final states. */
    avl<state_type, state_compare> m_final_states;

    /** \brief The adjacency list (the set of transitions). */
    adjacent_list m_states;
  }; // automaton

} // namespace claw

#include <claw/impl/automaton.tpp>

#endif // __CLAW_AUTOMATON_HPP__