This file is indexed.

/usr/lib/python2.7/dist-packages/python2_pythondialog-3.3.0.egg-info is in python-dialog 3.3.0-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
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
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
Metadata-Version: 1.1
Name: python2-pythondialog
Version: 3.3.0
Summary: A Python interface to the UNIX dialog utility and mostly-compatible programs (Python 2 backport)
Home-page: http://pythondialog.sourceforge.net/
Author: Florent Rougon
Author-email: f.rougon@free.fr
License: UNKNOWN
Download-URL: http://sourceforge.net/projects/pythondialog/files/pythondialog/3.3.0/python2-pythondialog-3.3.0.tar.bz2
Description: ===============================================================================
        Python wrapper for the UNIX "dialog" utility
        ===============================================================================
        Easy writing of graphical interfaces for terminal-based applications
        -------------------------------------------------------------------------------
        
        WARNING
        -------
        
        This version is a backport of pythondialog to Python 2. Unless you
        *really* have to use Python 2, you should go to the `pythondialog home
        page`_ and download the reference implementation which, at the time of
        this writing (May 2015) and for the forseeable future, is targeted
        at Python 3.
        
        .. _pythondialog home page: http://pythondialog.sourceforge.net/
        
        This version is only here to help users who are somehow forced to still
        use Python 2, even though Python 3.0 was released on December 3, 2008.
        It may be the last update for Python 2. In addition, the reference
        implementation is less likely to have bugs.
        
        Before using this backport, be sure to read the `Backport-specific
        notes`_ below.
        
        
        Overview
        --------
        
        pythondialog is a Python wrapper for the UNIX dialog_ utility
        originally written by Savio Lam and later rewritten by Thomas E. Dickey.
        Its purpose is to provide an easy to use, pythonic and as complete as
        possible interface to dialog_ from Python code.
        
        .. _dialog: http://invisible-island.net/dialog/dialog.html
        
        pythondialog is free software, licensed under the GNU LGPL (GNU Lesser
        General Public License). Its home page is located at:
        
          http://pythondialog.sourceforge.net/
        
        and contains a `short example`_, screenshots_, a `summary of the recent
        changes`_, links to the `documentation`_, the `Git repository`_, the
        `mailing list`_, the `issue tracker`_, etc.
        
        .. _short example:  http://pythondialog.sourceforge.net/#example
        .. _screenshots:    http://pythondialog.sourceforge.net/gallery.html
        .. _summary of the recent changes:
                            http://pythondialog.sourceforge.net/news.html
        .. _documentation:  http://pythondialog.sourceforge.net/doc/
        .. _Git repository: https://sourceforge.net/p/pythondialog/code/
        .. _mailing list:   https://sourceforge.net/p/pythondialog/mailman/
        .. _issue tracker:  https://sourceforge.net/p/pythondialog/_list/tickets
        
        If you want to get a quick idea of what this module allows one to do,
        you can download a release tarball and run ``demo.py``::
        
          PYTHONPATH=. python2 examples/demo.py
        
        Notes:
        
          - the preceding command uses ``python2`` because we want to use the
            Python 2 backport of pythondialog;
          - depending on your system, you may have to replace ``python2`` with
            ``python`` or ``python2.7``, for instance.
        
        
        What is pythondialog good for? What are its limitations?
        --------------------------------------------------------
        
        As you might infer from the name, dialog is a high-level program that
        generates dialog boxes. So is pythondialog. They allow you to build nice
        interfaces quickly and easily, but you don't have full control over the
        widgets, nor can you create new widgets without modifying dialog itself.
        If you need to do low-level stuff, you should have a look at ncurses or
        slang instead. For sophisticated text-mode interfaces, the `Urwid Python
        library`_ looks rather interesting, too.
        
        .. _Urwid Python library: http://excess.org/urwid/
        
        
        Requirements
        ------------
        
        * This backport of pythondialog requires Python 2.6 or later in the 2.x
          series. It has been tested with Python 2.7.
        
        * The reference implementation supports more recent versions of the
          Python interpreter. Please visit the `pythondialog home page`_ for
          more information.
        
        * Apart from that, pythondialog requires the dialog_ program (or a
          drop-in replacement for dialog). You can download dialog from:
        
            http://invisible-island.net/dialog/dialog.html
        
          Note that some features of pythondialog may require recent versions of
          dialog.
        
        
        Quick installation instructions
        -------------------------------
        
        If you have a working `pip <https://pypi.python.org/pypi/pip>`_ setup,
        you should be able to install this backport of pythondialog with::
        
          pip install python2-pythondialog
        
        When doing so, make sure that your ``pip`` executable runs with the
        Python 2 installation you want to install the backport for.
        
        For more detailed instructions, you can read the ``INSTALL`` file from a
        release tarball. You may also want to consult the `pip documentation
        <https://pip.pypa.io/>`_.
        
        
        Backport-specific notes
        -----------------------
        
        * The pythondialog documentation is written for the reference
          implementation (Python 3 at the time of this writing). To be on the
          safe side when using the Python 2 backport, you should use Unicode
          strings every time you pass “string data” to pythondialog, and you
          will get Unicode strings in return. Indeed, these correspond directly
          to Python 3 strings, and modern versions of pythondialog (>= 2.12) are
          all based on this type of string.
        
          The pythondialog documentation consistently uses the term “string” (as
          opposed to “Unicode string”) because it has been written for Python 3,
          but **you should definitely use Unicode strings when using the
          Python 2 backport**. Many things happen to work with byte strings, but
          in most cases, this is pure coincidence; others fail, and won't be
          fixed. This is not a bug.
        
          The easiest way to use Unicode strings everywhere (or almost
          everywhere) in Python 2.x with x >= 6, consists in using::
        
            from __future__ import unicode_literals
        
          at the beginning of your Python files. This method has the additional
          benefit of preparing your transition to Python 3.
        
        * Don't use ``str()`` in Python 2 on objects such as pythondialog
          exceptions or ``dialog.DialogBackendVersion`` instances; use
          ``unicode()`` instead, which is the Python 2 equivalent of the
          Python 3 ``str()`` built-in. Of course, using ``repr()`` on any
          pythondialog object should return a byte string when run under
          Python 2, because this is how the ``repr()`` API works in Python 2.
          The same holds true for ``str()``, but this one is not supported by
          the Python 2 backport of pythondialog: it is superseded, as already
          explained, by the much more powerful ``unicode()``.
        
        * Before taking potentially expensive decisions, you should realize that
          Unicode support is *much*, much better in Python 3 than in Python 2,
          even though the basic types are largely the same (Unicode string in
          Python 2, native string in Python 3). In Python 3, native strings
          (simply called “strings” in the Python documentation) are natural and
          ubiquitous. They can be read and written from/to the standard I/O
          streams with sane encoding defaults. ``str()`` and ``repr()`` return
          native strings, as do all standard library calls whenever expected
          (i.e., when the return value is text, as opposed to binary data).
          Python 3 strings are both powerful and easy to use.
        
          By contrast, in Python 2, you always have to be very careful about
          what you manipulate: byte strings or Unicode strings. Most library
          calls in your code are a potential source of bug. Usually, this kind
          of bug only pops up when user data or input introduces non-ASCII
          characters in a byte string that is then either combined with an
          Unicode string, or used in a context where the expected encoding is
          different. This means that some users get annoyed by “crappy”
          software, while the responsible developers are often not aware of any
          problem---until a bug report is filed, if ever.
        
          Want to use ``traceback.format_exc()`` for instance? What does it
          return, byte string or Unicode string? Experiment. Answer: byte
          string. Then, how does it deal with, e.g., accented characters in an
          ``OSError`` exception message? Experiment. Answer: it outputs the
          ``repr()`` representation of an Unicode string that uses backslash
          escapes for the non-ASCII characters, all of this inside the returned
          byte string. Conclusion: the messages seen by users will be very ugly
          and more or less undecipherable for many of them. Does it behave this
          way in all cases? Tough question. Use the source, Luke...
        
          With other library calls, you might get non-ASCII characters in a byte
          string. Then, the question would be: what encoding has been used to
          encode them, and is there a reliable way to detect it? In many cases,
          this is not documented and/or depends on parameters under user
          control, such as the locale settings. Again, you have to waste time
          figuring out the encoding, and often can't be sure whether your answer
          is correct in all cases.
        
          **Bottom line:**
        
            There are good reasons why the Python developers broke compatibility
            at such a fundamental level as string management between Python 2
            and Python 3. Getting Unicode support completely right in Python 2
            may require more work than porting your code to Python 3. Besides,
            future maintainance and evolutions of your program will definitely
            be easier once it is written in Python 3. Think about it.
        
        
        Documentation
        -------------
        
        **Important:** be sure to read the `Backport-specific notes`_ above.
        
        The pythondialog Manual
        ^^^^^^^^^^^^^^^^^^^^^^^
        
        The pythondialog Manual is written in `reStructuredText`_ format for the
        `Sphinx`_ documentation generator. The HTML documentation for the latest
        version of pythondialog as rendered by Sphinx should be available at:
        
          http://pythondialog.sourceforge.net/doc/
        
        .. _pythondialog Manual: http://pythondialog.sourceforge.net/doc/
        .. _reStructuredText: http://docutils.sourceforge.net/rst.html
        .. _Sphinx: http://sphinx-doc.org/
        .. _LaTeX: http://latex-project.org/
        .. _Make: http://www.gnu.org/software/make/
        
        The sources for the pythondialog Manual are located in the ``doc``
        top-level directory of the pythondialog distribution, but the
        documentation build process pulls many parts from dialog.py, mainly
        docstrings.
        
        **Note:**
        
          Currently, generation of the pythondialog Manual with `Sphinx`_ has
          only been tested, and is only supported with the reference
          implementation, on Python 3. As a consequence, the package containing
          this file may be fine to read or grep through the ``.rst`` files;
          however, if compilation of said ``.rst`` files with `Sphinx`_ doesn't
          work, it is currently not considered a bug---simply download the
          reference implementation if you want to do that.
        
        To generate the documentation yourself from dialog.py and the sources in
        the ``doc`` directory, first make sure you have `Sphinx`_ and `Make`_
        installed. Then, you can go to the ``doc`` directory and type, for
        instance::
        
          make html
        
        You will then find the output in the ``_build/html`` subdirectory of
        ``doc``. `Sphinx`_ can build the documentation in many other formats.
        For instance, if you have `LaTeX`_ installed, you can generate the
        pythondialog Manual in PDF format using::
        
          make latexpdf
        
        You can run ``make`` from the ``doc`` directory to see a list of the
        available formats. Run ``make clean`` to clean up after the
        documentation build process.
        
        For those who have installed `Sphinx`_ but not `Make`_, it is still
        possible to build the documentation with a command such as::
        
          sphinx-build -b html . _build/html
        
        run from the ``doc`` directory. Please refer to `sphinx-build`_ for more
        details.
        
        .. _sphinx-build: http://sphinx-doc.org/invocation.html
        
        
        Reading the docstrings from an interactive Python interpreter
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
        
        If you have already installed pythondialog, you may consult its
        docstrings in an interactive Python interpreter this way::
        
           >>> import dialog; help(dialog)
        
        but only parts of the documentation are available using this method, and
        the result is much less convenient to use than the `pythondialog
        Manual`_ as generated by `Sphinx`_.
        
        
        Enabling Deprecation Warnings
        -----------------------------
        
        There are a few places in ``dialog.py`` that send a
        ``DeprecationWarning`` to warn developers about obsolete features.
        However, because of:
        
          - the dialog output to the terminal;
          - the fact that such warnings are silenced by default since Python 2.7
            and 3.2;
        
        you have to do two things in order to see them:
        
          - redirect the standard error stream to a file;
          - enable the warnings for the Python interpreter.
        
        For instance, to see the warnings produced when running the demo, you
        can do::
        
          PYTHONPATH=. python2 -Wd examples/demo.py 2>/path/to/file
        
        and examine ``/path/to/file``. This can also help you to find files that
        are still open when your program exits.
        
        **Note:**
        
          If your program is terminated by an unhandled exception while stderr
          is redirected as in the preceding command, you won't see the traceback
          until you examine the file stderr was redirected to. This can be
          disturbing, as your program may exit with no apparent reason in such
          conditions.
        
        For more explanations and other methods to enable deprecation warnings,
        please refer to:
        
          http://docs.python.org/2/whatsnew/2.7.html
        
        
        Troubleshooting
        ---------------
        
        If you have a problem with a pythondialog call, you should read its
        documentation and the dialog(1) manual page. If this is not enough, you
        can enable logging of shell command-line equivalents of all dialog calls
        made by your program with a simple call to ``Dialog.setup_debug()``,
        first available in pythondialog 2.12 (the ``expand_file_opt`` parameter
        may be useful in versions 3.3 and later). An example of this can be
        found in ``demo.py`` from the ``examples`` directory.
        
        As of version 2.12, you can also enable this debugging facility for
        ``demo.py`` by calling it with the ``--debug`` flag (possibly combined
        with ``--debug-expand-file-opt`` in pythondialog 3.3 and later, cf.
        ``demo.py --help``).
        
        
        Using Xdialog instead of dialog
        -------------------------------
        
        As far as I can tell, `Xdialog`_ has not been ported to `GTK+`_ version
        2 or later. It is not in `Debian`_ stable nor unstable (June 23, 2013).
        It is not installed on my system (because of the GTK+ 1.2 dependency),
        and according to the Xdialog-specific patches I received from Peter
        Åstrand in 2004, was not a drop-in replacement for `dialog`_ (in
        particular, Xdialog seemed to want to talk to the caller through stdout
        instead of stderr, grrrrr!).
        
        .. _Xdialog: http://xdialog.free.fr/
        .. _GTK+: http://www.gtk.org/
        .. _Debian: http://www.debian.org/
        
        All this to say that, even though I didn't remove the options to use
        another backend than dialog, nor did I remove the handful of little,
        non-invasive modifications that help pythondialog work better with
        `Xdialog`_, I don't really support the latter. I test everything with
        dialog, and nothing with Xdialog.
        
        That being said, here is the *old* text of this section (from 2004), in
        case you are still interested:
        
          Starting with 2.06, there is an "Xdialog" compatibility mode that you
          can use if you want pythondialog to run the graphical Xdialog program
          (which *should* be found under http://xdialog.free.fr/) instead of
          dialog (text-mode, based on the ncurses library).
        
          The primary supported platform is still dialog, but as long as only
          small modifications are enough to make pythondialog work with Xdialog,
          I am willing to support Xdialog if people are interested in it (which
          turned out to be the case for Xdialog).
        
          The demo.py from pythondialog 2.06 has been tested with Xdialog 2.0.6
          and found to work well (barring Xdialog's annoying behaviour with the
          file selection dialog box).
        
        
        Whiptail, anyone?
        -----------------
        
        Well, pythondialog seems not to work very well with whiptail. The reason
        is that whiptail is not compatible with dialog anymore. Although you can
        tell pythondialog the program you want it to invoke, only programs that
        are mostly dialog-compatible are supported.
        
        
        History
        -------
        
        pythondialog was originally written by Robb Shecter. Sultanbek Tezadov
        added some features to it (mainly the first gauge implementation, I
        guess). Florent Rougon rewrote most parts of the program to make it more
        robust and flexible so that it can give access to most features of the
        dialog program. Peter Åstrand took over maintainership between 2004 and
        2009, with particular care for the `Xdialog`_ support. Florent Rougon
        took over maintainership again starting from 2009...
        
        .. 
          # Local Variables:
          # coding: utf-8
          # fill-column: 72
          # End:
        
Keywords: dialog,ncurses,Xdialog,text-mode interface,terminal
Platform: Unix
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.6
Classifier: Programming Language :: Python :: 2.7
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Console :: Curses
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: GNU Library or Lesser General Public License (LGPL)
Classifier: Operating System :: Unix
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Software Development :: User Interfaces
Classifier: Topic :: Software Development :: Widget Sets