This file is indexed.

/usr/include/Wt/Ext/TabWidget is in libwtext-dev 3.3.0-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
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
// This may look like C code, but it's really -*- C++ -*-
/*
 * Copyright (C) 2008 Emweb bvba, Kessel-Lo, Belgium.
 *
 * See the LICENSE file for terms of use.
 */
#ifndef EXT_TABWIDGET_H_
#define EXT_TABWIDGET_H_

#include <Wt/WJavaScript>
#include <Wt/Ext/Panel>

namespace Wt {
  namespace Ext {

/*! \class TabWidget Wt/Ext/TabWidget Wt/Ext/TabWidget
 *  \brief A widget that organizes contents in tab panes
 *
 * This widget has an API that is similar to the WTabWidget.
 *
 * Unlike WTabWidget, each tab is actually represented by a Panel, and
 * methods are provided to add a panel directly (see addTab(Panel
 * *)). The panel titles are then used as the tab labels.
 *
 * The widget inherits from Panel, and uses a WDefaultLayout
 * to contain the tab panels. Adding panels to the layout is
 * equivalent to adding tabs to the tab widget.
 *
 * \image html ExtTabWidget-1.png "Example of a TabWidget"
 *
 * \ingroup ext
 */
class WT_EXT_API TabWidget : public Panel
{
public:
  /*! \brief Create a new TabWidget
   */
  TabWidget(WContainerWidget *parent = 0);

  /*! \brief Add a new tab, with <i>child</i> as content, and the given label.
   *
   * This is implemented by creating a panel for the widget, and setting the
   * panel title to be the label.
   *
   * \sa addTab(Panel *), removeTab(int), widget(int)
   */
  void addTab(WWidget *child, const WString& label);

  /*! \brief Add a new tab panel.
   *
   * The panel title is used as the tab label.
   *
   * \sa addTab(WWidget *, const WString&)
   */
  void addTab(Panel *panel);

  /*! \brief Remove a tab.
   *
   * \sa addTab(Panel *), addTab(WWidget *, const WString&)
   * \sa indexOf(WWidget *)
   */
  void removeTab(int index);

  /*! \brief Return the number of tabs.
   */
  int count() const;

  /*! \brief Return t the panel at the given tab <i>index</i>.
   *
   * \sa widget(int)
   */
  Panel *panel(int index) const;

  /*! \brief Return the content widget at the given tab <i>index</i>.
   *
   * \sa panel(int)
   */
  WWidget *widget(int index) const;

  /*! \brief Return the index of the given widget/panel.
   *
   * If the widget was not added to this tab widget, then -1 is returned.
   */
  int indexOf(WWidget *widget) const;

  /*! \brief Activate the tab at <i>index</i>.
   *
   * \sa setCurrentWidget(WWidget *), currentIndex()
   * \sa currentChanged() signal
   */
  void setCurrentIndex(int index);

  /*! \brief Return the index of the activated tab.
   *
   * \sa setCurrentIndex(int)
   */
  int currentIndex() const;

  /*! \brief Activate the tab showing the given <i>widget</i>
   *
   * This is equivalent to setCurrentIndex(indexOf(<i>widget</i>))
   * \sa currentWidget(), setCurrentIndex(int)
   */
  void setCurrentWidget(WWidget *widget);

  /*! \brief Return the widget of the activated tab.
   *
   * \sa setCurrentWidget(WWidget *), currentIndex()
   */
  WWidget *currentWidget() const;

  /*! \brief Enable or disable a tab.
   *
   * Enables or disables the tab at <i>index</i>. A disabled tab cannot be
   * activated.
   */
  void setTabEnabled(int index, bool enable);

  /*! \brief Returns if a tab is enabled.
   */
  bool isTabEnabled(int index) const;

  /*! \brief Hide or show a tab.
   *
   * Hides are shows the tab at <i>index</i>.
   */
  void setTabHidden(int index, bool hidden);

  /*! \brief Return if a tab is hidden.
   */
  bool isTabHidden(int index) const;

  /*! \brief Change the label for a tab.
   *
   * This is equivalent to panel(<i>index</i>)->setTitle(<i>label</i>);
   *
   * \sa tabText(int)
   */
  void setTabText(int index, const WString& label);

  /*! \brief Return the label for a tab.
   *
   * \sa setTabText(int, const WString&)
   */
  const WString& tabText(int index) const;

  /*! \brief Set the tooltip for a tab.
   *
   * The tooltip is shown when the user hovers over the label.
   *
   * <b>This seems currently broken in extjs 2.0.</b>
   */
  void setTabToolTip(int index, const WString& tip);

  /*! \brief Return the tooltip for a tab.
   */
  const WString tabToolTip(int index) const;

  virtual void refresh();

  /*! \brief %Signal emitted when the user activates a tab.
   *
   * The index of the newly activated tab is passed as an argument.
   */
  Signal<int>& currentChanged() { return currentChanged_; }

protected:
  virtual void updateExt();
  virtual void createConfig(std::ostream& config);
  virtual std::string extClassName() const;

  virtual void removeChild(WWidget *child);

private:
  Signal<int>  currentChanged_;
  JSignal<int> jCurrentChanged_;
  std::vector<Panel *> panels_;
  int currentIndex_;
  
  virtual std::string createJS(DomElement *inContainer);

  void onTabChange(int index);
};

  }
}

#endif // EXT_TABWIDGET_H_