ok

Mini Shell

Direktori : /lib/python2.7/site-packages/kitchen/text/
Upload File :
Current File : //lib/python2.7/site-packages/kitchen/text/display.pyc

�
i�:Oc�@sdZddlZddlZddlmZddlmZmZddlm	Z	d�Z
d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmdndodpdqdrdsdtdudvdwdxdydzd{d|d}d~dd�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�f�Zd%�Zd&�Z
d'd(�Zd'd)d*d+�Zd)d*d,�Zded-d-d.�Zd/�Zd0d1d1d)d*d2�Zd3�Zded-d-d)d*d4�Zd�ZdS(�s
-----------------------
Format Text for Display
-----------------------

Functions related to displaying unicode text.  Unicode characters don't all
have the same width so we need helper functions for displaying them.

.. versionadded:: 0.2 kitchen.display API 1.0.0
i����N(tb_(t
to_unicodetto_bytes(tControlCharErrorcCs�d}t|�d}|||dks>|||dkrBtSxd||kr�||d}|||dkr�|d}qE|||dkr�|d}qEtSqEWtS(s�Binary search in an interval table.

    :arg value: numeric value to search for
    :arg table: Ordered list of intervals.  This is a list of two-tuples.  The
        elements of the two-tuple define an interval's start and end points.
    :returns: If :attr:`value` is found within an interval in the :attr:`table`
        return :data:`True`.  Otherwise, :data:`False`

    This function checks whether a numeric value is present within a table
    of intervals.  It checks using a binary search algorithm, dividing the
    list of values in half and checking against the values until it determines
    whether the value is in the table.
    iii(tlentFalsetTrue(tvaluettabletminimumtmaximumtmid((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt_interval_bisearchTs(

iioi�i�i�i�i�i�i�i�i�i�iiiiiKi^ipi�i�i�i�i�i�iii0iJi�i�i�i�iiii#i%i'i)i-i	i	i<	iA	iH	iM	iQ	iT	ib	ic	i�	i�	i�	i�	i�	i�	i�	i
i
i<
iA
iB
iG
iH
iK
iM
ip
iq
i�
i�
i�
i�
i�
i�
i�
i�
i�
i�
ii<i?iAiCiMiVi�i�i�i>i@iFiHiJiMiUiVi�i�i�i�i�i�i�iA
iC
iM
i�
i�
i�
i�
i1i4i:iGiNi�i�i�i�i�i�i�iii5i7i9iqi~i�i�i�i�i�i�i�i�i�i-i0i2i6i7i9i:iXiYi�i`i�i_iii2i4iRiSirisi�i�i�i�i�i�i�i�ii
i�i i"i'i(i2i9i;iii`iui|iiii4i6i:i<iBiDikisi�i7i�i�i�i�i�i�i�i�i�i�i�i i i* i. i` ic ij io i� i� i�,i�,i�-i�-i*0i/0i�0i�0io�i|�i}�i�i�i�i�i%�i&�iĨi�i�i+�i-�iS�i��i��i��i��i��i��i��i��i��i��i�i�i�i�i �i&�i��i��i��i�i
i
i
i
i
i
i8
i:
i?
i�i�ie�ii�im�i��i��i��i��i��iB�iD�ii iii�c�Cs�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�d�dddddddddd	d
ddd
ddddddddddddddddddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmdndodpdqdrdsdtdudvdwdxdydzd{d|f�}g}t}g}x�td�d}�D]r}t||�s�tjt|��r|sD|g}t}qDq�|r�t}|j|d��|j|�q�q�W|rk|j|�|j|�ntt	j
t|��S(~seCombine Markus Kuhn's data with :mod:`unicodedata` to make combining
    char list

    :rtype: :class:`tuple` of tuples
    :returns: :class:`tuple` of intervals of :term:`code points` that are
        combining character.  Each interval is a 2-:class:`tuple` of the
        starting :term:`code point` and the ending :term:`code point` for the
        combining characters.

    In normal use, this function serves to tell how we're generating the
    combining char list.  For speed reasons, we use this to generate a static
    list and just use that later.

    Markus Kuhn's list of combining characters is more complete than what's in
    the python :mod:`unicodedata` library but the python :mod:`unicodedata` is
    synced against later versions of the unicode database

    This is used to generate the :data:`~kitchen.text.display._COMBINING`
    table.
    iioi�i�i�i�i�i�i�i�i�i�i�i�iiiiiKi^ipi�i�i�i�i�i�iii0iJi�i�i�i�i	i	i<	iA	iH	iM	iQ	iT	ib	ic	i�	i�	i�	i�	i�	i�	i�	i
i
i<
iA
iB
iG
iH
iK
iM
ip
iq
i�
i�
i�
i�
i�
i�
i�
i�
i�
i�
ii<i?iAiCiMiVi�i�i�i>i@iFiHiJiMiUiVi�i�i�i�i�i�i�iA
iC
iM
i�
i�
i�
i�
i1i4i:iGiNi�i�i�i�i�i�i�iii5i7i9iqi~i�i�i�i�i�i�i�i�i�i-i0i2i6i7i9iXiYi`i�i_iii2i4iRiSirisi�i�i�i�i�i�i�i�ii
i�i i"i'i(i2i9i;iiiii4i6i:i<iBikisi�i�i�i�i i i* i. i` ic ij io i� i� i*0i/0i�0i�0i�i�i%�i&�i�i�i�i �i#�i��i��i��i
i
i
i
i
i
i8
i:
i?
ig�ii�is�i��i��i��i��i��iB�iD�ii iii�ii��i(iio(i�i�(i�i�(i�i�(i�i�(i�i�(i�i�(i�i�(ii(ii(iKi^(ipip(i�i�(i�i�(i�i�(ii(ii(i0iJ(i�i�(i�i�(i	i	(i<	i<	(iA	iH	(iM	iM	(iQ	iT	(ib	ic	(i�	i�	(i�	i�	(i�	i�	(i�	i�	(i�	i�	(i
i
(i<
i<
(iA
iB
(iG
iH
(iK
iM
(ip
iq
(i�
i�
(i�
i�
(i�
i�
(i�
i�
(i�
i�
(i�
i�
(ii(i<i<(i?i?(iAiC(iMiM(iViV(i�i�(i�i�(i�i�(i>i@(iFiH(iJiM(iUiV(i�i�(i�i�(i�i�(i�i�(i�i�(iA
iC
(iM
iM
(i�
i�
(i�
i�
(i�
i�
(i1i1(i4i:(iGiN(i�i�(i�i�(i�i�(i�i�(ii(i5i5(i7i7(i9i9(iqi~(i�i�(i�i�(i�i�(i�i�(i�i�(i-i0(i2i2(i6i7(i9i9(iXiY(i`i�(i_i_(ii(i2i4(iRiS(iris(i�i�(i�i�(i�i�(i�i�(i�i�(ii
(i�i�(i i"(i'i((i2i2(i9i;(ii(ii(i4i4(i6i:(i<i<(iBiB(ikis(i�i�(i�i�(i i (i* i. (i` ic (ij io (i� i� (i*0i/0(i�0i�0(i�i�(i�i�(i%�i&�(i�i�(i�i�(i �i#�(i��i��(i��i��(i
i
(i
i
(i
i
(i8
i:
(i?
i?
(ig�ii�(is�i��(i��i��(i��i��(iB�iD�(ii(i i(ii�i(RtxrangeRtunicodedatat	combiningtunichrRtappendttuplet	itertoolstimap(tmarkus_kuhn_combining_5_0Rtin_intervaltintervalt	codepoint((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt_generate_combining_table�s�																																																	
cCsot�}d}dGHxO|D]G}|dkr7d}Hn|dkrJdGn|d7}d|}|GqWdGHdS(	s;Print out a new :data:`_COMBINING` table

    This will print a new :data:`_COMBINING` table in the format used in
    :file:`kitchen/text/display.py`.  It's useful for updating the
    :data:`_COMBINING` table with updated data from a new python as the format
    won't change from what's already in the file.
    is_COMBINING = (is       is
(0x%x, 0x%x),t)N(R(Rtentriestpairtentry((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt_print_combining_table$s	


tguesscCs�|dks$|dkri|dkri|dkrEttd���n|d#krUdS|d	kredSd
St|t�r|d
Sd|dko�|d
kp�|dkp�|dkp�|dkr�|dkr�|dkp�|dkr�|dkp�|dkr|dkp�|dkr|dkp�|dkr3|dkp�|dkrK|dkp�|dkrc|dkp�|dkr{|d kp�|d!ko�|d"kS($sGet the :term:`textual width` of a ucs character

    :arg ucs: integer representing a single unicode :term:`code point`
    :kwarg control_chars: specify how to deal with :term:`control characters`.
        Possible values are:

        :guess: (default) will take a guess for :term:`control character`
            widths.  Most codes will return zero width.  ``backspace``,
            ``delete``, and ``clear delete`` return -1.  ``escape`` currently
            returns -1 as well but this is not guaranteed as it's not always
            correct
        :strict: will raise :exc:`~kitchen.text.exceptions.ControlCharError`
            if a :term:`control character` is encountered

    :raises ControlCharError: if the :term:`code point` is a unicode
        :term:`control character` and :attr:`control_chars` is set to 'strict'
    :returns: :term:`textual width` of the character.

    .. note::

        It's important to remember this is :term:`textual width` and not the
        number of characters or bytes.
    i i�itstrictsQ_ucp_width does not understand how to assign a width value to control characters.ii�i����iiiii_i)#i*#i�.iϤi?0i�i��i�i��i�i�i0�io�i�i`�i�i�ii��ii��(iii�(RRRt
_COMBINING(tucst
control_chars((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt
_ucp_width<s0$sutf-8treplacecCsOt|d|d|�}ttjttjtjt|�tj|����S(s�Get the :term:`textual width` of a string

    :arg msg: :class:`unicode` string or byte :class:`str` to get the width of
    :kwarg control_chars: specify how to deal with :term:`control characters`.
        Possible values are:

        :guess: (default) will take a guess for :term:`control character`
            widths.  Most codes will return zero width.  ``backspace``,
            ``delete``, and ``clear delete`` return -1.  ``escape`` currently
            returns -1 as well but this is not guaranteed as it's not always
            correct
        :strict: will raise :exc:`kitchen.text.exceptions.ControlCharError`
            if a :term:`control character` is encountered

    :kwarg encoding: If we are given a byte :class:`str` this is used to
        decode it into :class:`unicode` string.  Any characters that are not
        decodable in this encoding will get a value dependent on the
        :attr:`errors` parameter.
    :kwarg errors: How to treat errors encoding the byte :class:`str` to
        :class:`unicode` string.  Legal values are the same as for
        :func:`kitchen.text.converters.to_unicode`.  The default value of
        ``replace`` will cause undecodable byte sequences to have a width of
        one. ``ignore`` will have a width of zero.
    :raises ControlCharError: if :attr:`msg` contains a :term:`control
        character` and :attr:`control_chars` is ``strict``.
    :returns: :term:`Textual width` of the :attr:`msg`.  This is the amount of
        space that the string will consume on a monospace display.  It's
        measured in the number of cell positions or columns it will take up on
        a monospace display.  This is **not** the number of glyphs that are in
        the string.

    .. note::

        This function can be wrong sometimes because Unicode does not specify
        a strict width value for all of the :term:`code points`.  In
        particular, we've found that some Tamil characters take up to four
        character cells but we return a lesser amount.
    tencodingterrors(	RtsumRtstarmapR$tizipRtordtrepeat(tmsgR#R&R'((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt
textual_width~sG	c
Cst|d|d|�}t|�}||kr4|St|�}||dkr]|d}nd}|}||kr~|}nt|| �}x�tr||krB|||d}||kr�Pn||||krx8||kr|tt||d��}|d8}q�W|| S|t|||!�}|}|}q�||kr|||d}||krpPn||||kr�x:||kr�tt||��}	||	}|d7}q�W|| S|t|||!�}|}|}||kr
|}Pq
q�|| Sq�W|| S(syGiven a string, return it chopped to a given :term:`textual width`

    :arg msg: :class:`unicode` string or byte :class:`str` to chop
    :arg chop: Chop :attr:`msg` if it exceeds this :term:`textual width`
    :kwarg encoding: If we are given a byte :class:`str`, this is used to
        decode it into a :class:`unicode` string.  Any characters that are not
        decodable in this encoding will be assigned a width of one.
    :kwarg errors: How to treat errors encoding the byte :class:`str` to
        :class:`unicode`.  Legal values are the same as for
        :func:`kitchen.text.converters.to_unicode`
    :rtype: :class:`unicode` string
    :returns: :class:`unicode` string of the :attr:`msg` chopped at the given
        :term:`textual width`

    This is what you want to use instead of ``%.*s``, as it does the "right"
    thing with regard to :term:`UTF-8` sequences, :term:`control characters`,
    and characters that take more than one cell position. Eg::

        >>> # Wrong: only displays 8 characters because it is operating on bytes
        >>> print "%.*s" % (10, 'café ñunru!')
        café ñun
        >>> # Properly operates on graphemes
        >>> '%s' % (textual_width_chop('café ñunru!', 10))
        café ñunru
        >>> # takes too many columns because the kanji need two cell positions
        >>> print '1234567890\n%.*s' % (10, u'一二三四五六七八九十')
        1234567890
        一二三四五六七八九十
        >>> # Properly chops at 10 columns
        >>> print '1234567890\n%s' % (textual_width_chop(u'一二三四五六七八九十', 10))
        1234567890
        一二三四五

    R&R'iii(RR.RRR$R+(
R-tchopR&R'twidthR
R	teosRt	new_width((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyttextual_width_chop�sV$
			
tcCs�t|�}|dk	r*t||�}nt|�}||krl|sN|r�dj|||g�}q�nMd||}|r�dj||||g�}ndj||||g�}|S(s
Expand a :class:`unicode` string to a specified :term:`textual width`
    or chop to same

    :arg msg: :class:`unicode` string to format
    :arg fill: pad string until the :term:`textual width` of the string is
        this length
    :kwarg chop: before doing anything else, chop the string to this length.
        Default: Don't chop the string at all
    :kwarg left: If :data:`True` (default) left justify the string and put the
        padding on the right.  If :data:`False`, pad on the left side.
    :kwarg prefix: Attach this string before the field we're filling
    :kwarg suffix: Append this string to the end of the field we're filling
    :rtype: :class:`unicode` string
    :returns: :attr:`msg` formatted to fill the specified width.  If no
        :attr:`chop` is specified, the string could exceed the fill length
        when completed.  If :attr:`prefix` or :attr:`suffix` are printable
        characters, the string could be longer than the fill width.

    .. note::

        :attr:`prefix` and :attr:`suffix` should be used for "invisible"
        characters like highlighting, color changing escape codes, etc.  The
        fill characters are appended outside of any :attr:`prefix` or
        :attr:`suffix` elements.  This allows you to only highlight
        :attr:`msg` inside of the field you're filling.

    .. warning::

        :attr:`msg`, :attr:`prefix`, and :attr:`suffix` should all be
        representable as unicode characters.  In particular, any escape
        sequences in :attr:`prefix` and :attr:`suffix` need to be convertible
        to :class:`unicode`.  If you need to use byte sequences here rather
        than unicode characters, use
        :func:`~kitchen.text.display.byte_string_textual_width_fill` instead.

    This function expands a string to fill a field of a particular
    :term:`textual width`.  Use it instead of ``%*.*s``, as it does the
    "right" thing with regard to :term:`UTF-8` sequences, :term:`control
    characters`, and characters that take more than one cell position in
    a display.  Example usage::

        >>> msg = u'一二三四五六七八九十'
        >>> # Wrong: This uses 10 characters instead of 10 cells:
        >>> u":%-*.*s:" % (10, 10, msg[:9])
        :一二三四五六七八九 :
        >>> # This uses 10 cells like we really want:
        >>> u":%s:" % (textual_width_fill(msg[:9], 10, 10))
        :一二三四五:

        >>> # Wrong: Right aligned in the field, but too many cells
        >>> u"%20.10s" % (msg)
                  一二三四五六七八九十
        >>> # Correct: Right aligned with proper number of cells
        >>> u"%s" % (textual_width_fill(msg, 20, 10, left=False))
                  一二三四五

        >>> # Wrong: Adding some escape characters to highlight the line but too many cells
        >>> u"%s%20.10s%s" % (prefix, msg, suffix)
        u'          一二三四五六七八九十'
        >>> # Correct highlight of the line
        >>> u"%s%s%s" % (prefix, display.textual_width_fill(msg, 20, 10, left=False), suffix)
        u'          一二三四五'

        >>> # Correct way to not highlight the fill
        >>> u"%s" % (display.textual_width_fill(msg, 20, 10, left=False, prefix=prefix, suffix=suffix))
        u'          一二三四五'
    uu N(RtNoneR3R.tjoin(R-tfillR/tlefttprefixtsuffixR0textra((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyttextual_width_fill4sDcGs�dj|�}tjd|�}t|�|kr7tSt|�d|krQtStt|��|krmtSt|�}||kS(stOptimize the common case when deciding which :term:`textual width` is
    larger

    :arg width: :term:`textual width` to compare against.
    :arg \*args: :class:`unicode` strings to check the total :term:`textual
        width` of
    :returns: :data:`True` if the total length of :attr:`args` are less than
        or equal to :attr:`width`.  Otherwise :data:`False`.

    We often want to know "does X fit in Y".  It takes a while to use
    :func:`textual_width` to calculate this.  However, we know that the number
    of canonically composed :class:`unicode` characters is always going to
    have 1 or 2 for the :term:`textual width` per character.  With this we can
    take the following shortcuts:

    1) If the number of canonically composed characters is more than width,
       the true :term:`textual width` cannot be less than width.
    2) If the number of canonically composed characters * 2 is less than the
       width then the :term:`textual width` must be ok.

    :term:`textual width` of a canonically composed :class:`unicode` string
    will always be greater than or equal to the the number of :class:`unicode`
    characters.  So we can first check if the number of composed
    :class:`unicode` characters is less than the asked for width.  If it is we
    can return :data:`True` immediately.  If not, then we must do a full
    :term:`textual width` lookup.
    R4tNFCi(R6Rt	normalizeRRRRR.(R0targststringt
true_width((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt_textual_width_le�siFucs��fd��t|d|d|�}t|d|d|�}t|�}t|d|d|�jd�}|j�jd�}g}|}	t}
d}d}x|D]�}
|
jd�}
||}}�|
�\}}t}|
r�|r�t}n|
r|t|
�krt}n|
rG|rG|dkrG||krGt}qGn|rr|j|	jd��|}	t}
n|t|
�kr�d}
n|
r�|
j	d�}
|}nt
||	|
�r�t}
|j|	|
�|}	q�nt}
|
jd�}|	}
|}|r|dkr|}nxn|D]f}t
||
|�rvt|
�|krv|j|
jd��|d|}
n|
|7}
|
d7}
q$W|
jd�d}	q�W|
r�|j|	jd��n|S(	sWorks like we want :func:`textwrap.wrap` to work,

    :arg text: :class:`unicode` string or byte :class:`str` to wrap
    :kwarg width: :term:`textual width` at which to wrap.  Default: 70
    :kwarg initial_indent: string to use to indent the first line.  Default:
        do not indent.
    :kwarg subsequent_indent: string to use to wrap subsequent lines.
        Default: do not indent
    :kwarg encoding: Encoding to use if :attr:`text` is a byte :class:`str`
    :kwarg errors: error handler to use if :attr:`text` is a byte :class:`str`
        and contains some undecodable characters.
    :rtype: :class:`list` of :class:`unicode` strings
    :returns: list of lines that have been text wrapped and indented.

    :func:`textwrap.wrap` from the |stdlib|_ has two drawbacks that this
    attempts to fix:

    1. It does not handle :term:`textual width`.  It only operates on bytes or
       characters which are both inadequate (due to multi-byte and double
       width characters).
    2. It malforms lists and blocks.
    cs�y|j�d}Wntk
r(dSX|j|�}|dkrN|dfS�||d�}|dps|d}|r�||d|fS|dfS(sfReturn the indent to use for this and (possibly) subsequent lines

        :arg line: :class:`unicode` line of text to process
        :rtype: tuple
        :returns: tuple of count of whitespace before getting to the start of
            this line followed by a count to the following indent if this
            block of text is an entry in a list.
        iu
-*.o•‣∘i(ii(tstript
IndexErrortfind(tlinetchartcounttnxt(t_indent_at_beg(s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyRJ�s


R&R'u
iu iu(RR.trstript
expandtabstsplitRRRRtlstripRB(ttextR0tinitial_indenttsubsequent_indentR&R'tsubsequent_indent_widthtlinestrettindentt	wrap_lasttcur_sabtcur_spc_indentRFtlast_sabtlast_spc_indenttforce_nltwordstspcstword((RJs8/usr/lib/python2.7/site-packages/kitchen/text/display.pytwrap�sp&		!

		
				

cOsdjt|||��S(sWorks like we want :func:`textwrap.fill` to work

    :arg text: :class:`unicode` string or byte :class:`str` to process
    :returns: :class:`unicode` string with each line separated by a newline

    .. seealso::

        :func:`kitchen.text.display.wrap`
            for other parameters that you can give this command.

    This function is a light wrapper around :func:`kitchen.text.display.wrap`.
    Where that function returns a :class:`list` of lines, this function
    returns one string with each line separated by a newline.
    u
(R6R_(ROR?tkwargs((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyR73sc
Cs�t|d|d|�}t|d|d|�}|dk	rZt||d|d|�}nt|�}t|�}||kr�|s�|r�dj|||g�}q�nMd||}	|r�dj||||	g�}ndj|	|||g�}|S(s%Expand a byte :class:`str` to a specified :term:`textual width` or chop
    to same

    :arg msg: byte :class:`str` encoded in :term:`UTF-8` that we want formatted
    :arg fill: pad :attr:`msg` until the :term:`textual width` is this long
    :kwarg chop: before doing anything else, chop the string to this length.
        Default: Don't chop the string at all
    :kwarg left: If :data:`True` (default) left justify the string and put the
        padding on the right.  If :data:`False`, pad on the left side.
    :kwarg prefix: Attach this byte :class:`str` before the field we're
        filling
    :kwarg suffix: Append this byte :class:`str` to the end of the field we're
        filling
    :rtype: byte :class:`str`
    :returns: :attr:`msg` formatted to fill the specified :term:`textual
        width`.  If no :attr:`chop` is specified, the string could exceed the
        fill length when completed.  If :attr:`prefix` or :attr:`suffix` are
        printable characters, the string could be longer than fill width.

    .. note::

        :attr:`prefix` and :attr:`suffix` should be used for "invisible"
        characters like highlighting, color changing escape codes, etc.  The
        fill characters are appended outside of any :attr:`prefix` or
        :attr:`suffix` elements.  This allows you to only highlight
        :attr:`msg` inside of the field you're filling.

    .. seealso::

        :func:`~kitchen.text.display.textual_width_fill`
            For example usage.  This function has only two differences.

            1. it takes byte :class:`str` for :attr:`prefix` and
               :attr:`suffix` so you can pass in arbitrary sequences of
               bytes, not just unicode characters.
            2. it returns a byte :class:`str` instead of a :class:`unicode`
               string.
    R&R'R4t N(RR5R3R.R6(
R-R7R/R8R9R:R&R'R0R;((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pytbyte_string_textual_width_fillHs(RbR7R.R3R<R_(iio(i�i�(i�i�(i�i�(i�i�(i�i�(i�i�(ii(ii(iKi^(ipip(i�i�(i�i�(i�i�(ii(ii(i0iJ(i�i�(i�i�(ii(ii#(i%i'(i)i-(i	i	(i<	i<	(iA	iH	(iM	iM	(iQ	iT	(ib	ic	(i�	i�	(i�	i�	(i�	i�	(i�	i�	(i�	i�	(i
i
(i<
i<
(iA
iB
(iG
iH
(iK
iM
(ip
iq
(i�
i�
(i�
i�
(i�
i�
(i�
i�
(i�
i�
(i�
i�
(ii(i<i<(i?i?(iAiC(iMiM(iViV(i�i�(i�i�(i�i�(i>i@(iFiH(iJiM(iUiV(i�i�(i�i�(i�i�(i�i�(i�i�(iA
iC
(iM
iM
(i�
i�
(i�
i�
(i�
i�
(i1i1(i4i:(iGiN(i�i�(i�i�(i�i�(i�i�(ii(i5i5(i7i7(i9i9(iqi~(i�i�(i�i�(i�i�(i�i�(i�i�(i-i0(i2i2(i6i7(i9i:(iXiY(i�i�(i`i�(i_i_(ii(i2i4(iRiS(iris(i�i�(i�i�(i�i�(i�i�(i�i�(ii
(i�i�(i i"(i'i((i2i2(i9i;(ii(i`i`(iui|(ii(ii(i4i4(i6i:(i<i<(iBiB(iDiD(ikis(i�i�(i7i7(i�i�(i�i�(i�i�(i�i�(i�i�(i�i�(i i (i* i. (i` ic (ij io (i� i� (i�,i�,(i�-i�-(i*0i/0(i�0i�0(io�io�(i|�i}�(i�i�(i�i�(i�i�(i%�i&�(iĨiĨ(i�i�(i+�i-�(iS�iS�(i��i��(i��i��(i��i��(i��i��(i��i��(i��i��(i��i��(i�i�(i�i�(i�i�(i �i&�(i��i��(i��i��(i�i�(i
i
(i
i
(i
i
(i8
i:
(i?
i?
(i�i�(ie�ii�(im�i��(i��i��(i��i��(iB�iD�(ii(i i(ii�(sbyte_string_textual_width_fillsfills
textual_widthstextual_width_chopstextual_width_fillswrap(t__doc__RRtkitchenRtkitchen.text.convertersRRtkitchen.text.exceptionsRRR!RRR$R.R3R5RR<RBR_R7Rbt__all__(((s8/usr/lib/python2.7/site-packages/kitchen/text/display.pyt<module>&s�(																																																													d	BSbS	+	�		;

Zerion Mini Shell 1.0