This file is indexed.

/usr/include/hfst/parsers/ConflictResolvingLeftArrowRule.h is in libhfst-dev 3.13.0~r3461-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
//! @file ConflictResolvingLeftArrowRuleRule.h
//!
//! @brief Holds one <=-type twol rule, whose center is a single symbol pair.
//!
//! @author Miikka Silfverberg

//  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 3 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, see <http://www.gnu.org/licenses/>.

#ifndef CONFLICT_RESOLVING_LEFT_ARROW_RULE_H_
#define CONFLICT_RESOLVING_LEFT_ARROW_RULE_H_

#ifdef HAVE_CONFIG_H
#  include <config.h>
#endif

#include "LeftArrowRule.h"
#include "../string_src/string_manipulation.h"

class LeftArrowRuleContainer;

class ConflictResolvingLeftArrowRule : public LeftArrowRule
{
 protected:
  std::string input_symbol;
 public:
  //! @brief Inititalize.
  ConflictResolvingLeftArrowRule(const std::string &name,
                 const SymbolPair &center,
                 const OtherSymbolTransducerVector &contexts);

  //! @brief Return true if @a another conflicts @a this.
  //!
  //! Return true if the input symbols of the centers of @a another and
  //! @this are equal, the output symbols differ, and the contexts of @a
  //! another and @a this have a non-empty intersection.
  //!
  //! If a conflict exists, store the conflicting string in v.
  bool conflicts_this(const ConflictResolvingLeftArrowRule &another,
              StringVector &v);

  //! Return @a true, if the context of @a another is a sub language of
  //! the context of @a this.
  bool resolvable_conflict(const ConflictResolvingLeftArrowRule &another);

  //! @brief Resolve the conflict between @a this and @a another by subtracting
  //! the context of @a another fromt the @a context of @a this.
  void resolve_conflict(const ConflictResolvingLeftArrowRule &another);

  friend class LeftArrowRuleContainer;
};

#endif // CONFLICT_RESOLVING_LEFT_ARROW_RULE_H_