This file is indexed.

/usr/share/qt5/doc/qtassistant/qtassistant-simpletextviewer-example.html is in qttools5-doc-html 5.9.5-0ubuntu1.

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
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html>
<html lang="en">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- simpletextviewer.qdoc -->
  <title>Simple Text Viewer Example | Qt Assistant Manual</title>
  <link rel="stylesheet" type="text/css" href="style/offline-simple.css" />
  <script type="text/javascript">
    document.getElementsByTagName("link").item(0).setAttribute("href", "style/offline.css");
    // loading style sheet breaks anchors that were jumped to before
    // so force jumping to anchor again
    setTimeout(function() {
        var anchor = location.hash;
        // need to jump to different anchor first (e.g. none)
        location.hash = "#";
        setTimeout(function() {
            location.hash = anchor;
        }, 0);
    }, 0);
  </script>
</head>
<body>
<div class="header" id="qtdocheader">
  <div class="main">
    <div class="main-rounded">
      <div class="navigationbar">
        <table><tr>
<td >Qt 5.9</td><td ><a href="qtassistant-index.html">Qt Assistant Manual</a></td><td ><a href="examples-qtassistant.html">Qt Assistant Examples</a></td><td >Simple Text Viewer Example</td></tr></table><table class="buildversion"><tr>
<td id="buildversion" width="100%" align="right">Qt 5.9.5 Reference Documentation</td>
        </tr></table>
      </div>
    </div>
<div class="content">
<div class="line">
<div class="content mainContent">
<div class="sidebar">
<div class="toc">
<h3><a name="toc">Contents</a></h3>
<ul>
<li class="level1"><a href="#creating-documentation-and-customizing-qt-assistant">Creating Documentation and Customizing <i>Qt Assistant</i></a></li>
<li class="level2"><a href="#organizing-documentation-for-qt-assistant">Organizing Documentation for <i>Qt Assistant</i></a></li>
<li class="level2"><a href="#customizing-qt-assistant">Customizing <i>Qt Assistant</i></a></li>
<li class="level1"><a href="#controlling-qt-assistant-via-the-assistant-class">Controlling <i>Qt Assistant</i> via the Assistant Class</a></li>
<li class="level1"><a href="#mainwindow-class">MainWindow Class</a></li>
<li class="level1"><a href="#findfiledialog-class">FindFileDialog Class</a></li>
<li class="level1"><a href="#summary">Summary</a></li>
</ul>
</div>
<div class="sidebar-content" id="sidebar-content"></div></div>
<h1 class="title">Simple Text Viewer Example</h1>
<span class="subtitle"></span>
<!-- $$$simpletextviewer-description -->
<div class="descr"> <a name="details"></a>
<p class="centerAlign"><img src="images/simpletextviewer-example.png" alt="" /></p><p>This example shows how to use <i>Qt Assistant</i> as a customized help viewer in a custom application. This is done in two stages. Firstly, documentation is created and <i>Qt Assistant</i> is customized; secondly, the functionality to launch and control <i>Qt Assistant</i> is added to the application.</p>
<p>The Simple Text Viewer application lets the user select and view existing files. The application provides its own custom documentation that is available from the <b>Help</b> menu in the main window's menu bar or by clicking the <b>Help</b> button in the application's find file dialog.</p>
<p>The example consists of four classes:</p>
<ul>
<li><code>Assistant</code> provides functionality to launch <i>Qt Assistant</i>.</li>
<li><code>MainWindow</code> is the main application window.</li>
<li><code>FindFileDialog</code> allows the user to search for files using wildcard matching.</li>
<li><code>TextEdit</code> provides a rich text browser that makes sure that images referenced in HTML documents are displayed properly.</li>
</ul>
<p><b>Note: </b>We will only comment on the parts of the implementation that are relevant to the main issue, that is making Qt Assistant act as a customized help viewer for our Simple Text Viewer application.</p><a name="creating-documentation-and-customizing-qt-assistant"></a>
<h2 id="creating-documentation-and-customizing-qt-assistant">Creating Documentation and Customizing <i>Qt Assistant</i></h2>
<p>How to create the actual documentation in the form of HTML pages is not in the scope of this example. In general, HTML pages can either be written by hand or generated with the help of documentation tools like qdoc or Doxygen. For the purposes of this example we assume that the HTML files have already been created. So, the only thing that remains to be done is to tell <i>Qt Assistant</i> how to structure and display the help information.</p>
<a name="organizing-documentation-for-qt-assistant"></a>
<h3 >Organizing Documentation for <i>Qt Assistant</i></h3>
<p>Plain HTML files only contain text or documentation about specific topics, but they usually include no information about how several HTML documents relate to each other or in which order they are supposed to be read. What is missing is a table of contents along with an index to access certain help contents quickly, without having to browse through a lot of documents in order to find a piece of information.</p>
<p>To organize the documentation and make it available for <i>Qt Assistant</i>, we have to create a Qt help project (.qhp) file. The first and most important part of the project file is the definition of the namespace. The namespace has to be unique and will be the first part of the page URL in <i>Qt Assistant</i>. In addition, we have to set a virtual folder which acts as a common folder for documentation sets. This means, that two documentation sets identified by two different namespaces can cross reference HTML files since those files are in one big virtual folder. However, for this example, we'll only have one documentation set available, so the virtual folder name and functionality are not important.</p>
<pre class="cpp">

  <span class="operator">&lt;</span><span class="operator">?</span>xml version<span class="operator">=</span><span class="string">&quot;1.0&quot;</span> encoding<span class="operator">=</span><span class="string">&quot;UTF-8&quot;</span><span class="operator">?</span><span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="type">QtHelpProject</span> version<span class="operator">=</span><span class="string">&quot;1.0&quot;</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span><span class="keyword">namespace</span><span class="operator">&gt;</span>org<span class="operator">.</span>qt<span class="operator">-</span>project<span class="operator">.</span>examples<span class="operator">.</span>simpletextviewer<span class="operator">&lt;</span><span class="operator">/</span><span class="keyword">namespace</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>virtualFolder<span class="operator">&gt;</span>doc<span class="operator">&lt;</span><span class="operator">/</span>virtualFolder<span class="operator">&gt;</span>

</pre>
<p>The next step is to define the filter section. A filter section contains the table of contents, indices and a complete list of all documentation files, and can have any number of filter attributes assigned to it. A filter attribute is an ordinary string which can be freely chosen. Later in <i>Qt Assistant</i>, users can then define a custom filter referencing those attributes. If the attributes of a filter section match the attributes of the custom filter the documentation will be shown, otherwise <i>Qt Assistant</i> will hide the documentation.</p>
<p>Again, since we'll only have one documentation set, we do not need the filtering functionality of <i>Qt Assistant</i> and can therefore skip the filter attributes.</p>
<p>Now, we build up the table of contents. An item in the table is defined by the <code>section</code> tag which contains the attributes for the item title as well as link to the actual page. Section tags can be nested infinitely, but for practical reasons it is not recommended to nest them deeper than three or four levels. For our example we want to use the following outline for the table of contents:</p>
<ul>
<li>Simple Text Viewer<ul>
<li>Find File<ul>
<li>File Dialog</li>
<li>Wildcard Matching</li>
<li>Browse</li>
</ul>
</li>
<li>Open File</li>
</ul>
</li>
</ul>
<p>In the help project file, the outline is represented by:</p>
<pre class="cpp">

  <span class="operator">&lt;</span>filterSection<span class="operator">&gt;</span>
    <span class="operator">&lt;</span>toc<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>section title<span class="operator">=</span><span class="string">&quot;Simple Text Viewer&quot;</span> ref<span class="operator">=</span><span class="string">&quot;index.html&quot;</span><span class="operator">&gt;</span>
        <span class="operator">&lt;</span>section title<span class="operator">=</span><span class="string">&quot;Find File&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./findfile.html&quot;</span><span class="operator">&gt;</span>
          <span class="operator">&lt;</span>section title<span class="operator">=</span><span class="string">&quot;File Dialog&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./filedialog.html&quot;</span><span class="operator">&gt;</span><span class="operator">&lt;</span><span class="operator">/</span>section<span class="operator">&gt;</span>
          <span class="operator">&lt;</span>section title<span class="operator">=</span><span class="string">&quot;Wildcard Matching&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./wildcardmatching.html&quot;</span><span class="operator">&gt;</span><span class="operator">&lt;</span><span class="operator">/</span>section<span class="operator">&gt;</span>
          <span class="operator">&lt;</span>section title<span class="operator">=</span><span class="string">&quot;Browse&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./browse.html&quot;</span><span class="operator">&gt;</span><span class="operator">&lt;</span><span class="operator">/</span>section<span class="operator">&gt;</span>
        <span class="operator">&lt;</span><span class="operator">/</span>section<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>section title<span class="operator">=</span><span class="string">&quot;Open File&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./openfile.html&quot;</span><span class="operator">&gt;</span><span class="operator">&lt;</span><span class="operator">/</span>section<span class="operator">&gt;</span>
      <span class="operator">&lt;</span><span class="operator">/</span>section<span class="operator">&gt;</span>
    <span class="operator">&lt;</span><span class="operator">/</span>toc<span class="operator">&gt;</span>

</pre>
<p>After the table of contents is defined, we will list all index keywords:</p>
<pre class="cpp">

  <span class="operator">&lt;</span>keywords<span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Display&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./index.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Rich text&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./index.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Plain text&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./index.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Find&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./findfile.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;File menu&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./findfile.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;File name&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./filedialog.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;File dialog&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./filedialog.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;File globbing&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./wildcardmatching.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Wildcard matching&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./wildcardmatching.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Wildcard syntax&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./wildcardmatching.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Browse&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./browse.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Directory&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./browse.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Open&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./openfile.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
    <span class="operator">&lt;</span>keyword name<span class="operator">=</span><span class="string">&quot;Select&quot;</span> ref<span class="operator">=</span><span class="string">&quot;./openfile.html&quot;</span><span class="operator">/</span><span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="operator">/</span>keywords<span class="operator">&gt;</span>

</pre>
<p>As the last step, we have to list all files making up the documentation. An important point to note here is that all files have to listed, including image files, and even stylesheets if they are used.</p>
<pre class="cpp">

      <span class="operator">&lt;</span>files<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>browse<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>filedialog<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>findfile<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>index<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>intro<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>openfile<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>wildcardmatching<span class="operator">.</span>html<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>images<span class="operator">/</span>browse<span class="operator">.</span>png<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
        <span class="operator">&lt;</span>file<span class="operator">&gt;</span>images<span class="comment">/*.png&lt;/file&gt;
      &lt;/files&gt;
    &lt;/filterSection&gt;
  &lt;/QtHelpProject&gt;
  </span>

</pre>
<p>The help project file is now finished. If you want to see the resulting documentation in <i>Qt Assistant</i>, you have to generate a Qt compressed help file out of it and register it with the default help collection of <i>Qt Assistant</i>.</p>
<pre class="cpp">

  qhelpgenerator simpletextviewer<span class="operator">.</span>qhp <span class="operator">-</span>o simpletextviewer<span class="operator">.</span>qch
  assistant <span class="operator">-</span><span class="keyword">register</span> simpletextviewer<span class="operator">.</span>qch

</pre>
<p>If you start <i>Qt Assistant</i> now, you'll see the Simple Text Viewer documentation beside the Qt documentation. This is OK for testing purposes, but for the final version we want to only have the Simple Text Viewer documentation in <i>Qt Assistant</i>.</p>
<a name="customizing-qt-assistant"></a>
<h3 >Customizing <i>Qt Assistant</i></h3>
<p>The easiest way to make <i>Qt Assistant</i> only display the Simple Text Viewer documentation is to create our own help collection file. A collection file is stored in a binary format, similar to the compressed help file, and generated from a help collection project file (*.qhcp). With the help of a collection file, we can customize the appearance and even some functionality offered by <i>Qt Assistant</i>.</p>
<p>At first, we change the window title and icon. Instead of showing &quot;<i>Qt Assistant</i>&quot; it will show &quot;Simple Text Viewer&quot;, so it is much clearer for the user that the help viewer actually belongs to our application.</p>
<pre class="cpp">

  <span class="operator">&lt;</span><span class="operator">?</span>xml version<span class="operator">=</span><span class="string">&quot;1.0&quot;</span> encoding<span class="operator">=</span><span class="string">&quot;UTF-8&quot;</span><span class="operator">?</span><span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="type">QHelpCollectionProject</span> version<span class="operator">=</span><span class="string">&quot;1.0&quot;</span><span class="operator">&gt;</span>
  <span class="operator">&lt;</span>assistant<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>title<span class="operator">&gt;</span>Simple Text Viewer<span class="operator">&lt;</span><span class="operator">/</span>title<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>applicationIcon<span class="operator">&gt;</span>images<span class="operator">/</span>handbook<span class="operator">.</span>png<span class="operator">&lt;</span><span class="operator">/</span>applicationIcon<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>cacheDirectory<span class="operator">&gt;</span><span class="type">QtProject</span><span class="operator">/</span>SimpleTextViewer<span class="operator">&lt;</span><span class="operator">/</span>cacheDirectory<span class="operator">&gt;</span>

</pre>
<p>The <code>cacheDirectory</code> tag specifies a subdirectory of the users data directory (see the <a href="assistant-custom-help-viewer.html#qt-help-collection-files">Qt Help Collection Files</a>) where the cache file for the full text search or the settings file will be stored.</p>
<p>After this, we set the page displayed by <i>Qt Assistant</i> when launched for the very first time in its new configuration. The URL consists of the namespace and virtual folder defined in the Qt help project file, followed by the actual page file name.</p>
<pre class="cpp">

  <span class="operator">&lt;</span>startPage<span class="operator">&gt;</span>qthelp:<span class="comment">//org.qt-project.examples.simpletextviewer/doc/index.html&lt;/startPage&gt;</span>

</pre>
<p>Next, we alter the name of the &quot;About&quot; menu item to &quot;About Simple Text Viewer&quot;. The contents of the <b>About</b> dialog are also changed by specifying a file where the about text or icon is taken from.</p>
<pre class="cpp">

  <span class="operator">&lt;</span>aboutMenuText<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>text<span class="operator">&gt;</span>About Simple Text Viewer<span class="operator">&lt;</span><span class="operator">/</span>text<span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="operator">/</span>aboutMenuText<span class="operator">&gt;</span>
  <span class="operator">&lt;</span>aboutDialog<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>file<span class="operator">&gt;</span>about<span class="operator">.</span>txt<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>icon<span class="operator">&gt;</span>images<span class="operator">/</span>icon<span class="operator">.</span>png<span class="operator">&lt;</span><span class="operator">/</span>icon<span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="operator">/</span>aboutDialog<span class="operator">&gt;</span>

</pre>
<p><i>Qt Assistant</i> offers the possibility to add or remove documentation via its preferences dialog. This functionality is helpful when using <i>Qt Assistant</i> as the central help viewer for more applications, but in our case we want to actually prevent the user from removing the documentation. So, we hide the <b>Documentation</b> tab in the <b>Preferences</b> dialog.</p>
<p>Since the address bar is not really relevant in such a small documentation set we switch it off as well. By having just one filter section, without any filter attributes, we can also disable the filter functionality of <i>Qt Assistant</i>, which means that the filter page and the filter toolbar will not be available.</p>
<pre class="cpp">

      <span class="operator">&lt;</span>enableDocumentationManager<span class="operator">&gt;</span><span class="keyword">false</span><span class="operator">&lt;</span><span class="operator">/</span>enableDocumentationManager<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>enableAddressBar<span class="operator">&gt;</span><span class="keyword">false</span><span class="operator">&lt;</span><span class="operator">/</span>enableAddressBar<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>enableFilterFunctionality<span class="operator">&gt;</span><span class="keyword">false</span><span class="operator">&lt;</span><span class="operator">/</span>enableFilterFunctionality<span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="operator">/</span>assistant<span class="operator">&gt;</span>

</pre>
<p>For testing purposes, we already generated the compressed help file and registered it with <i>Qt Assistant</i>'s default help collection. With the following lines we achieve the same result. The only and important difference is that we register the compressed help file, not in the default collection, but in our own collection file.</p>
<pre class="cpp">

    <span class="operator">&lt;</span>docFiles<span class="operator">&gt;</span>
      <span class="operator">&lt;</span>generate<span class="operator">&gt;</span>
          <span class="operator">&lt;</span>file<span class="operator">&gt;</span>
              <span class="operator">&lt;</span>input<span class="operator">&gt;</span>simpletextviewer<span class="operator">.</span>qhp<span class="operator">&lt;</span><span class="operator">/</span>input<span class="operator">&gt;</span>
              <span class="operator">&lt;</span>output<span class="operator">&gt;</span>simpletextviewer<span class="operator">.</span>qch<span class="operator">&lt;</span><span class="operator">/</span>output<span class="operator">&gt;</span>
              <span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
          <span class="operator">&lt;</span><span class="operator">/</span>generate<span class="operator">&gt;</span>
      <span class="operator">&lt;</span><span class="keyword">register</span><span class="operator">&gt;</span>
          <span class="operator">&lt;</span>file<span class="operator">&gt;</span>simpletextviewer<span class="operator">.</span>qch<span class="operator">&lt;</span><span class="operator">/</span>file<span class="operator">&gt;</span>
          <span class="operator">&lt;</span><span class="operator">/</span><span class="keyword">register</span><span class="operator">&gt;</span>
      <span class="operator">&lt;</span><span class="operator">/</span>docFiles<span class="operator">&gt;</span>
  <span class="operator">&lt;</span><span class="operator">/</span><span class="type">QHelpCollectionProject</span><span class="operator">&gt;</span>

</pre>
<p>As the last step, we have to generate the binary collection file out of the help collection project file. This is done by running the <code>qcollectiongenerator</code> tool.</p>
<pre class="cpp">

  qcollectiongenerator simpletextviewer<span class="operator">.</span>qhcp <span class="operator">-</span>o simpletextviewer<span class="operator">.</span>qhc

</pre>
<p>To test all our customizations made to <i>Qt Assistant</i>, we add the collection file name to the command line:</p>
<pre class="cpp">

  assistant <span class="operator">-</span>collectionFile simpletextviewer<span class="operator">.</span>qhc

</pre>
<a name="controlling-qt-assistant-via-the-assistant-class"></a>
<h2 id="controlling-qt-assistant-via-the-assistant-class">Controlling <i>Qt Assistant</i> via the Assistant Class</h2>
<p>We will first take a look at how to start and operate <i>Qt Assistant</i> from a remote application. For that purpose, we create a class called <code>Assistant</code>.</p>
<p>This class provides a public function that is used to show pages of the documentation, and one private helper function to make sure that <i>Qt Assistant</i> is up and running.</p>
<p>Launching <i>Qt Assistant</i> is done in the function <code>startAssistant()</code> by simply creating and starting a QProcess. If the process is already running, the function returns immediately. Otherwise, the process has to be set up and started.</p>
<pre class="cpp">

  bool Assistant<span class="operator">::</span>startAssistant()
  {
      <span class="keyword">if</span> (<span class="operator">!</span>proc)
          proc <span class="operator">=</span> <span class="keyword">new</span> <span class="type">QProcess</span>();

      <span class="keyword">if</span> (proc<span class="operator">-</span><span class="operator">&gt;</span>state() <span class="operator">!</span><span class="operator">=</span> <span class="type">QProcess</span><span class="operator">::</span>Running) {
          <span class="type">QString</span> app <span class="operator">=</span> <span class="type">QLibraryInfo</span><span class="operator">::</span>location(<span class="type">QLibraryInfo</span><span class="operator">::</span>BinariesPath) <span class="operator">+</span> <span class="type">QDir</span><span class="operator">::</span>separator();
  <span class="preprocessor">#if !defined(Q_OS_MAC)</span>
          app <span class="operator">+</span><span class="operator">=</span> QLatin1String(<span class="string">&quot;assistant&quot;</span>);
  <span class="preprocessor">#else</span>
          app <span class="operator">+</span><span class="operator">=</span> QLatin1String(<span class="string">&quot;Assistant.app/Contents/MacOS/Assistant&quot;</span>);
  <span class="preprocessor">#endif</span>

          <span class="type">QStringList</span> args;
          args <span class="operator">&lt;</span><span class="operator">&lt;</span> QLatin1String(<span class="string">&quot;-collectionFile&quot;</span>)
              <span class="operator">&lt;</span><span class="operator">&lt;</span> <span class="type">QLibraryInfo</span><span class="operator">::</span>location(<span class="type">QLibraryInfo</span><span class="operator">::</span>ExamplesPath)
              <span class="operator">+</span> QLatin1String(<span class="string">&quot;/assistant/simpletextviewer/documentation/simpletextviewer.qhc&quot;</span>)
              <span class="operator">&lt;</span><span class="operator">&lt;</span> QLatin1String(<span class="string">&quot;-enableRemoteControl&quot;</span>);

          proc<span class="operator">-</span><span class="operator">&gt;</span>start(app<span class="operator">,</span> args);

          <span class="keyword">if</span> (<span class="operator">!</span>proc<span class="operator">-</span><span class="operator">&gt;</span>waitForStarted()) {
              <span class="type">QMessageBox</span><span class="operator">::</span>critical(nullptr<span class="operator">,</span>
                                    tr(<span class="string">&quot;Simple Text Viewer&quot;</span>)<span class="operator">,</span>
                                    tr(<span class="string">&quot;Unable to launch Qt Assistant (%1)&quot;</span>)<span class="operator">.</span>arg(app));
              <span class="keyword">return</span> <span class="keyword">false</span>;
          }
      }
      <span class="keyword">return</span> <span class="keyword">true</span>;
  }

</pre>
<p>To start the process we need the executable name of <i>Qt Assistant</i> as well as the command line arguments for running <i>Qt Assistant</i> in a customized mode. The executable name is a little bit tricky since it depends on the platform, but fortunately it is only different on macOS.</p>
<p>The displayed documentation can be altered using the <code>-collectionFile</code> command line argument when launching <i>Qt Assistant</i>. When started without any options, <i>Qt Assistant</i> displays a default set of documentation. When Qt is installed, the default documentation set in <i>Qt Assistant</i> contains the Qt reference documentation as well as the tools that come with Qt, such as Qt Designer and <code>qmake</code>.</p>
<p>In our example, we replace the default documentation set with our custom documentation by passing our application-specific collection file to the process's command line options.</p>
<p>As the last argument, we add <code>-enableRemoteControl</code>, which makes <i>Qt Assistant</i> listen to its <code>stdin</code> channel for commands, such as those to display a certain page in the documentation. Then we start the process and wait until it is actually running. If, for some reason <i>Qt Assistant</i> cannot be started, <code>startAssistant()</code> will return false.</p>
<p>The implementation for <code>showDocumentation()</code> is now straightforward. Firstly, we ensure that <i>Qt Assistant</i> is running, then we send the request to display the <i>page</i> via the <code>stdin</code> channel of the process. It is very important here that the command is terminated by an end of line token to flush the channel.</p>
<pre class="cpp">

  <span class="type">void</span> Assistant<span class="operator">::</span>showDocumentation(<span class="keyword">const</span> <span class="type">QString</span> <span class="operator">&amp;</span>page)
  {
      <span class="keyword">if</span> (<span class="operator">!</span>startAssistant())
          <span class="keyword">return</span>;

      <span class="type">QByteArray</span> ba(<span class="string">&quot;SetSource &quot;</span>);
      ba<span class="operator">.</span>append(<span class="string">&quot;qthelp://org.qt-project.examples.simpletextviewer/doc/&quot;</span>);

      proc<span class="operator">-</span><span class="operator">&gt;</span>write(ba <span class="operator">+</span> page<span class="operator">.</span>toLocal8Bit() <span class="operator">+</span> <span class="char">'\n'</span>);
  }

</pre>
<p>Finally, we make sure that <i>Qt Assistant</i> is terminated properly in the case that the application is shut down. The destructor of QProcess kills the process, meaning that the application has no possibility to do things like save user settings, which would result in corrupted settings files. To avoid this, we ask <i>Qt Assistant</i> to terminate in the destructor of the <code>Assistant</code> class.</p>
<pre class="cpp">

  Assistant<span class="operator">::</span><span class="operator">~</span>Assistant()
  {
      <span class="keyword">if</span> (proc <span class="operator">&amp;</span><span class="operator">&amp;</span> proc<span class="operator">-</span><span class="operator">&gt;</span>state() <span class="operator">=</span><span class="operator">=</span> <span class="type">QProcess</span><span class="operator">::</span>Running) {
          proc<span class="operator">-</span><span class="operator">&gt;</span>terminate();
          proc<span class="operator">-</span><span class="operator">&gt;</span>waitForFinished(<span class="number">3000</span>);
      }
      <span class="keyword">delete</span> proc;
  }

</pre>
<a name="mainwindow-class"></a>
<h2 id="mainwindow-class">MainWindow Class</h2>
<p class="centerAlign"><img src="images/simpletextviewer-mainwindow.png" alt="" /></p><p>The <code>MainWindow</code> class provides the main application window with two menus: the <b>File</b> menu lets the user open and view an existing file, while the <b>Help</b> menu provides information about the application and about Qt, and lets the user open <i>Qt Assistant</i> to display the application's documentation.</p>
<p>To be able to access the help functionality, we initialize the <code>Assistant</code> object in the <code>MainWindow</code>'s constructor.</p>
<pre class="cpp">

  MainWindow<span class="operator">::</span>MainWindow()
  {
      assistant <span class="operator">=</span> <span class="keyword">new</span> Assistant;
      ...
  }

</pre>
<p>Then we create all the actions for the Simple Text Viewer application. Of special interest is the <code>assistantAct</code> action accessible via the <b>F1</b> shortcut or the <b>Help</b> &gt; <b>Help Contents</b> menu item. This action is connected to the <code>showDocumentation()</code> slot of the <code>MainWindow</code> class.</p>
<pre class="cpp">

  <span class="type">void</span> MainWindow<span class="operator">::</span>createActions()
  {
      assistantAct <span class="operator">=</span> <span class="keyword">new</span> <span class="type">QAction</span>(tr(<span class="string">&quot;Help Contents&quot;</span>)<span class="operator">,</span> <span class="keyword">this</span>);
      assistantAct<span class="operator">-</span><span class="operator">&gt;</span>setShortcut(<span class="type">QKeySequence</span><span class="operator">::</span>HelpContents);
      connect(assistantAct<span class="operator">,</span> SIGNAL(triggered())<span class="operator">,</span> <span class="keyword">this</span><span class="operator">,</span> SLOT(showDocumentation()));
      ...
  }

</pre>
<p>In the <code>showDocumentation()</code> slot, we call the <code>showDocumentation()</code> function of the <code>Assistant</code> class with the URL of home page of the documentation.</p>
<pre class="cpp">

  <span class="type">void</span> MainWindow<span class="operator">::</span>showDocumentation()
  {
      assistant<span class="operator">-</span><span class="operator">&gt;</span>showDocumentation(<span class="string">&quot;index.html&quot;</span>);
  }

</pre>
<p>Finally, we must reimplement the protected QWidget::closeEvent() event handler to ensure that the application's <i>Qt Assistant</i> instance is properly closed before we terminate the application.</p>
<pre class="cpp">

  <span class="type">void</span> MainWindow<span class="operator">::</span>closeEvent(<span class="type">QCloseEvent</span> <span class="operator">*</span>)
  {
      <span class="keyword">delete</span> assistant;
  }

</pre>
<a name="findfiledialog-class"></a>
<h2 id="findfiledialog-class">FindFileDialog Class</h2>
<p class="centerAlign"><img src="images/simpletextviewer-findfiledialog.png" alt="" /></p><p>The Simple Text Viewer application provides a find file dialog allowing the user to search for files using wildcard matching. The search is performed within the specified directory, and the user is given an option to browse the existing file system to find the relevant directory.</p>
<p>In the constructor we save the references to the <code>Assistant</code> and <code>QTextEdit</code> objects passed as arguments. The <code>Assistant</code> object will be used in the <code>FindFileDialog</code>'s <code>help()</code> slot, as we will see shortly, while the QTextEdit will be used in the dialog's <code>openFile()</code> slot to display the chosen file.</p>
<pre class="cpp">

  FindFileDialog<span class="operator">::</span>FindFileDialog(TextEdit <span class="operator">*</span>editor<span class="operator">,</span> Assistant <span class="operator">*</span>assistant)
      : <span class="type">QDialog</span>(editor)
  {
      currentAssistant <span class="operator">=</span> assistant;
      currentEditor <span class="operator">=</span> editor;
      ...
  }

</pre>
<p>The most relevant member to observe in the <code>FindFileDialog</code> class is the private <code>help()</code> slot. The slot is connected to the dialog's <b>Help</b> button, and brings the current <i>Qt Assistant</i> instance to the foreground with the documentation for the dialog by calling <code>Assistant</code>'s <code>showDocumentation()</code> function.</p>
<pre class="cpp">

  <span class="type">void</span> FindFileDialog<span class="operator">::</span>help()
  {
      currentAssistant<span class="operator">-</span><span class="operator">&gt;</span>showDocumentation(<span class="string">&quot;filedialog.html&quot;</span>);
  }

</pre>
<a name="summary"></a>
<h2 id="summary">Summary</h2>
<p>In order to make <i>Qt Assistant</i> act as a customized help tool for your application, you must provide your application with a process that controls <i>Qt Assistant</i> in addition to a custom help collection file including Qt compressed help files.</p>
<p>For more information about the options and settings available to applications that use <i>Qt Assistant</i> as a custom help viewer, see <a href="assistant-custom-help-viewer.html">Customizing Qt Assistant</a>.</p>
<p>Files:</p>
<ul>
<li><a href="qtassistant-simpletextviewer-assistant-cpp.html">simpletextviewer/assistant.cpp</a></li>
<li><a href="qtassistant-simpletextviewer-assistant-h.html">simpletextviewer/assistant.h</a></li>
<li><a href="qtassistant-simpletextviewer-findfiledialog-cpp.html">simpletextviewer/findfiledialog.cpp</a></li>
<li><a href="qtassistant-simpletextviewer-findfiledialog-h.html">simpletextviewer/findfiledialog.h</a></li>
<li><a href="qtassistant-simpletextviewer-mainwindow-cpp.html">simpletextviewer/mainwindow.cpp</a></li>
<li><a href="qtassistant-simpletextviewer-mainwindow-h.html">simpletextviewer/mainwindow.h</a></li>
<li><a href="qtassistant-simpletextviewer-textedit-cpp.html">simpletextviewer/textedit.cpp</a></li>
<li><a href="qtassistant-simpletextviewer-textedit-h.html">simpletextviewer/textedit.h</a></li>
<li><a href="qtassistant-simpletextviewer-documentation-simpletextviewer-qhcp.html">simpletextviewer/documentation/simpletextviewer.qhcp</a></li>
<li><a href="qtassistant-simpletextviewer-documentation-simpletextviewer-qhp.html">simpletextviewer/documentation/simpletextviewer.qhp</a></li>
<li><a href="qtassistant-simpletextviewer-main-cpp.html">simpletextviewer/main.cpp</a></li>
<li><a href="qtassistant-simpletextviewer-simpletextviewer-pro.html">simpletextviewer/simpletextviewer.pro</a></li>
</ul>
</div>
<!-- @@@simpletextviewer -->
        </div>
       </div>
   </div>
   </div>
</div>
<div class="footer">
   <p>
   <acronym title="Copyright">&copy;</acronym> 2017 The Qt Company Ltd.
   Documentation contributions included herein are the copyrights of
   their respective owners.<br>    The documentation provided herein is licensed under the terms of the    <a href="http://www.gnu.org/licenses/fdl.html">GNU Free Documentation    License version 1.3</a> as published by the Free Software Foundation.<br>    Qt and respective logos are trademarks of The Qt Company Ltd.     in Finland and/or other countries worldwide. All other trademarks are property
   of their respective owners. </p>
</div>
</body>
</html>