This file is indexed.

/usr/include/t3/widget/t3widget/textline.h is in libt3widget-dev 0.6.2-1build1.

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
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
/* Copyright (C) 2011-2012,2018 G.P. Halkes
   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License version 3, as
   published by the Free Software Foundation.

   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 T3_WIDGET_TEXTLINE_H
#define T3_WIDGET_TEXTLINE_H

#define BUFFERSIZE 64
#define BUFFERINC 16

#include <stdio.h>
#include <string>
#include <sys/types.h>
#include <t3window/window.h>

#include <t3widget/key.h>
#include <t3widget/widget_api.h>

namespace t3_widget {

class undo_t;

#define _T3_MAX_TAB 80

class text_line_factory_t;

class T3_WIDGET_API text_line_t {
 public:
  enum {
    BREAK = (1 << 0),
    PARTIAL_CHAR = (1 << 1),
    SPACECLEAR = (1 << 2),
    TAB_AS_CONTROL = (1 << 3),
    EXTEND_SELECTION = (1 << 4),
    DEBUG_LINE = (1 << 5),
    SHOW_TABS = (1 << 6)
  };

  struct T3_WIDGET_API paint_info_t {
    int start;    // Byte position of the start of the line (0 unless line wrapping is in effect)
    int leftcol;  // First cell to draw

    int max;   // Last position of the line (INT_MAX unless line wrapping is in effect)
    int size;  // Maximum number of characters to draw

    int tabsize;                           // Length of a tab, or 0 to force TAB_AS_CONTROL flag
    int flags;                             // See above for valid flags
    int selection_start;                   // Start of selected text in bytes
    int selection_end;                     // End of selected text in bytes
    int cursor;                            // Location of cursor in bytes
    t3_attr_t normal_attr, selected_attr;  // Attributes to be used for normal an selected texts
                                           // string highlighting;
  };

  struct T3_WIDGET_API break_pos_t {
    int pos;
    int flags;
  };

 private:
  std::string buffer;
  bool starts_with_combining;

 protected:
  text_line_factory_t *factory;

 private:
  static char spaces[_T3_MAX_TAB];
  static char dashes[_T3_MAX_TAB];
  static char dots[16];
  static const char *control_map;
  static const char *wrap_symbol;

  static void paint_part(t3_window_t *win, const char *paint_buffer, bool is_print, int todo,
                         t3_attr_t selection_attr);
  static int key_width(key_t key);

  t3_attr_t get_draw_attrs(int i, const text_line_t::paint_info_t *info);

  void fill_line(const char *_buffer, int length);
  bool check_boundaries(int match_start, int match_end) const;
  void update_meta_buffer(int start_pos = 0);
  char get_char_meta(int pos) const;

  void reserve(int size);
  int byte_width_from_first(int pos) const;

 public:
  text_line_t(int buffersize = BUFFERSIZE, text_line_factory_t *_factory = nullptr);
  text_line_t(const char *_buffer, text_line_factory_t *_factory = nullptr);
  text_line_t(const char *_buffer, int length, text_line_factory_t *_factory = nullptr);
  text_line_t(const std::string *str, text_line_factory_t *_factory = nullptr);
  virtual ~text_line_t();

  void set_text(const char *_buffer);
  void set_text(const char *_buffer, size_t length);
  void set_text(const std::string *str);

  void merge(text_line_t *other);
  text_line_t *break_line(int pos);
  text_line_t *cut_line(int start, int end);
  text_line_t *clone(int start, int end);
  text_line_t *break_on_nl(int *start_from);
  void insert(text_line_t *other, int pos);

  void minimize();

  int calculate_screen_width(int start, int pos, int tabsize) const;
  int calculate_line_pos(int start, int max, int pos, int tabsize) const;

  void paint_line(t3_window_t *win, const paint_info_t *info);

  break_pos_t find_next_break_pos(int start, int length, int tabsize) const;
  int get_next_word(int start) const;
  int get_previous_word(int start) const;

  bool insert_char(int pos, key_t c, undo_t *undo);
  bool overwrite_char(int pos, key_t c, undo_t *undo);
  bool delete_char(int pos, undo_t *undo);
  bool append_char(key_t c, undo_t *undo);
  bool backspace_char(int pos, undo_t *undo);

  int adjust_position(int pos, int adjust) const;

  int get_length() const;
  int width_at(int pos) const;
  bool is_print(int pos) const;
  bool is_space(int pos) const;
  bool is_alnum(int pos) const;
  bool is_bad_draw(int pos) const;

  const std::string *get_data() const;

  int get_next_word_boundary(int start) const;
  int get_previous_word_boundary(int start) const;

  static void init();

 protected:
  virtual t3_attr_t get_base_attr(int i, const paint_info_t *info);
};

class T3_WIDGET_API text_line_factory_t {
 public:
  text_line_factory_t();
  virtual ~text_line_factory_t();
  virtual text_line_t *new_text_line_t(int buffersize = BUFFERSIZE);
  virtual text_line_t *new_text_line_t(const char *_buffer);
  virtual text_line_t *new_text_line_t(const char *_buffer, int length);
  virtual text_line_t *new_text_line_t(const std::string *str);
};

T3_WIDGET_API extern text_line_factory_t default_text_line_factory;

};  // namespace
#endif