HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //usr/lib/python3/dist-packages/sphinx/search/__pycache__/__init__.cpython-310.pyc
o

�$�a�D�@s�UdZddlZddlZddlZddlmZddlmZddlm	Z	m
Z
mZmZm
Z
mZmZmZmZddlmZddlmZddlmZmZdd	lmZdd
lmZddlmZGdd
�d
�Zddl m!Z!de"dee"fdd�Z#idd�dd�de!�dd�dd�dd�dd�d d!�d"d#�d$d%�d&d'�d(d)�d*d+�d,d-�d.d/�d0d1�d2d3�Z$ee"e
fe%d4<Gd5d6�d6�Z&e&�Z'Gd7d8�d8ej(�Z)Gd9d:�d:�Z*dS);z�
    sphinx.search
    ~~~~~~~~~~~~~

    Create a full-text search index for offline search.

    :copyright: Copyright 2007-2021 by the Sphinx team, see AUTHORS.
    :license: BSD, see LICENSE for details.
�N)�
import_module)�path)	�IO�Any�Dict�Iterable�List�Optional�Set�Tuple�Type)�nodes)�Node)�addnodes�package_dir)�BuildEnvironment)�
splitter_code)�jsdumpc@s�eZdZUdZdZeed<dZeed<e�Z	e
eed<dZeed<dZeed<dZ
e�d	�Zd
eddfdd
�Zd
eddfdd�Zdedeefdd�Zdedefdd�Zdedefdd�ZdS)�SearchLanguagea<
    This class is the base class for search natural language preprocessors.  If
    you want to add support for a new language, you should override the methods
    of this class.

    You should override `lang` class property too (e.g. 'en', 'fr' and so on).

    .. attribute:: stopwords

       This is a set of stop words of the target language.  Default `stopwords`
       is empty.  This word is used for building index and embedded in JS.

    .. attribute:: js_splitter_code

       Return splitter function of JavaScript version.  The function should be
       named as ``splitQuery``.  And it should take a string and return list of
       strings.

       .. versionadded:: 3.0

    .. attribute:: js_stemmer_code

       Return stemmer class of JavaScript version.  This class' name should be
       ``Stemmer`` and this class must have ``stemWord`` method.  This string is
       embedded as-is in searchtools.js.

       This class is used to preprocess search word which Sphinx HTML readers
       type, before searching index. Default implementation does nothing.
    N�lang�
language_name�	stopwords�js_splitter_code�js_stemmer_rawcodez�
/**
 * Dummy stemmer for languages without stemming rules.
 */
var Stemmer = function() {
  this.stemWord = function(w) {
    return w;
  }
}
z(?u)\w+�options�returncCs||_|�|�dS�N)r�init��selfr�r �8/usr/lib/python3/dist-packages/sphinx/search/__init__.py�__init__JszSearchLanguage.__init__cCsdS)zK
        Initialize the class with the options the user has given.
        Nr rr r r!rNszSearchLanguage.init�inputcCs|j�|�S)z�
        This method splits a sentence into words.  Default splitter splits input
        at white spaces, which should be enough for most languages except CJK
        languages.
        )�_word_re�findall)rr#r r r!�splitSszSearchLanguage.split�wordcCs|S)a�
        This method implements stemming algorithm of the Python version.

        Default implementation does nothing.  You should implement this if the
        language has any stemming rules.

        This class is used to preprocess search words before registering them in
        the search index.  The stemming of the Python version and the JS version
        (given in the js_stemmer_code attribute) must be compatible.
        r �rr'r r r!�stem[szSearchLanguage.stemcCsTt|�dkp)t|�dkrdt|d�kodknp(t|d�dko(||jvS)z�
        Return true if the target word should be registered in the search index.
        This method is called after stemming.
        r�iA0i�0�)�len�ordrr(r r r!�word_filterhs,��zSearchLanguage.word_filter)�__name__�
__module__�__qualname__�__doc__r�str�__annotations__r�setrr
rr�js_stemmer_code�re�compiler$rr"rrr&r)�boolr.r r r r!rs


r)�
SearchEnglish�sourcercCs4t�}|��D]}|�d�d}|�|���q|S)zs
    Parse snowball style word list like this:

    * http://snowball.tartarus.org/algorithms/finnish/stop.txt
    �|r)r5�
splitlinesr&�update)r;�result�liner r r!�parse_stop_wordys
rA�dazsphinx.search.da.SearchDanish�dezsphinx.search.de.SearchGerman�en�eszsphinx.search.es.SearchSpanish�fizsphinx.search.fi.SearchFinnish�frzsphinx.search.fr.SearchFrench�huz sphinx.search.hu.SearchHungarian�itzsphinx.search.it.SearchItalian�jazsphinx.search.ja.SearchJapanese�nlzsphinx.search.nl.SearchDutch�noz sphinx.search.no.SearchNorwegian�ptz!sphinx.search.pt.SearchPortuguese�rozsphinx.search.ro.SearchRomanian�ruzsphinx.search.ru.SearchRussian�svzsphinx.search.sv.SearchSwedish�trzsphinx.search.tr.SearchTurkish�zhzsphinx.search.zh.SearchChinese�	languagesc@sdeZdZdZdZdZdedefdd�Zdedefd	d
�Z	dede
ddfd
d�Zde
defdd�ZdS)�_JavaScriptIndexz�
    The search index as JavaScript file that calls a function
    on the documentation search object to register the index.
    zSearch.setIndex(�)�datarcCs|jt�|�|jSr)�PREFIXr�dumps�SUFFIX)rrVr r r!rX�sz_JavaScriptIndex.dumps�scCsH|t|j�t|j��}|r|�|j�r|�|j�std��t�|�S)Nzinvalid data)r,rWrY�
startswith�endswith�
ValueErrorr�loads)rrZrVr r r!r^�s
�
z_JavaScriptIndex.loads�fNcCs|�|�|��dSr)�writerX)rrVr_r r r!�dump��z_JavaScriptIndex.dumpcCs|�|���Sr)r^�read)rr_r r r!�load�sz_JavaScriptIndex.load)
r/r0r1r2rWrYrr3rXr^rrardr r r r!rT�srTcsVeZdZdZdejdeddf�fdd�Zdej	de
fd	d
�Zdeddfdd�Z
�ZS)
�
WordCollectorzG
    A special visitor that collects words for the `IndexBuilder`.
    �documentrrNcs"t��|�g|_g|_||_dSr)�superr"�found_words�found_title_wordsr)rrfr��	__class__r r!r"�s
zWordCollector.__init__�nodecCsDt|tj�r |�d�dkr |�d�}|durdS||jjkr dSdS)N�name�keywordsrTF)�
isinstancer�meta�getr)rrl�	meta_langr r r!�is_meta_keywords�s
zWordCollector.is_meta_keywordscCst|tj�r	tj�t|tj�r=d|�dd���vr:t�dd|�	��}t�dd|�}t�dd|�}|j
�|j�|��tj�t|tj
�rQ|j
�|j�|�	���dSt|tj�re|j�|j�|�	���dSt|tj�r�|�|�r�|d}dd	�|�d
�D�}|j
�|�dSdSdS)N�html�format�z(?is)<style.*?</style>z(?is)<script.*?</script>z<[^<]+?>�contentcSsg|]}|���qSr )�strip)�.0�keywordr r r!�
<listcomp>��z0WordCollector.dispatch_visit.<locals>.<listcomp>�,)ror
�comment�SkipNode�rawrqr&r7�sub�astextrh�extendr�Text�titlerirrprs)rrl�nodetextrnr r r!�dispatch_visit�s$�zWordCollector.dispatch_visit)r/r0r1r2r
rfrr"rrpr9rsrr��
__classcell__r r rjr!re�s

rec@sleZdZdZeed�Zdedede	deddf
d	d
�Z
dededdfd
d�Z
dededdfdd�Zde	eefde	eeeeeeeefffdd�Zde	dee	eeefe	eeefffdd�Zde	eeffdd�Zdefdd�Zdeeddfdd�Zdededed ejddf
d!d"�Zde	eeffd#d$�Zdeefd%d&�Zdeefd'd(�Zdefd)d*�ZdS)+�IndexBuilderzi
    Helper class that creates a search index based on the doctrees
    passed to the `feed` method.
    )r�pickle�envrr�scoringrNc	Cs�||_i|_i|_i|_i|_i|_i|_i|_t�	|�}|dur/d|vr/t�	|�
d�d�}|dur9t|�|_nt
|t�rS|�dd�\}}tt|�|�}||�|_n||�|_|rwt|d��}|����|_Wd�n1sqwYnd|_t|_dS)N�_r�.��rbrv)r��_titles�
_filenames�_mapping�_title_mapping�_stem_cache�	_objtypes�	_objnamesrSrqr&r:rror3�rsplit�getattrr�openrc�decode�js_scorer_coderr)	rr�rrr��
lang_class�module�	classname�fpr r r!r"�s2


��
zIndexBuilder.__init__�streamrucs�t|t�r
|j|}|�|�}t|t�r|�d�|jjkr!td��|d�tt	�|d��|_
tt	�|d��|_dttt
fdttttff�fdd	�}||d
�|_||d�|_dS)
zReconstruct from frozen data.�
envversionz
old format�docnames�	filenames�titles�mappingrcsJi}|��D]\}}t|t�r�|h||<q�fdd�|D�||<q|S)Ncsh|]}�|�qSr r )ry�i��index2fnr r!�	<setcomp>%r|z8IndexBuilder.load.<locals>.load_terms.<locals>.<setcomp>)�itemsro�int)r��rv�k�vr�r r!�
load_termss
z%IndexBuilder.load.<locals>.load_terms�terms�
titletermsN)ror3�formatsrd�dictrqr��versionr]�zipr�r�rrr
r�r�)rr�ru�frozenr�r r�r!rds



*	zIndexBuilder.loadcCs(t|t�r
|j|}|�|��|�dS)z"Dump the frozen index to a stream.N)ror3r�ra�freeze)rr�rur r r!ra,s

zIndexBuilder.dump�fn2indexcCs@i}|j}|j}t|jj���D]�\}}t|���D]�\}}}	}
}}|
|vr'q|dkr,qt�|�}t�|�}|�	d�\}
}}|�
|
g�}z|||	f}Wn/ty{t|�}||||	f<|j
�|	�}|rr||	t|�|��f||<n||	|	f||<Ynw||kr�d}n
||	d|kr�d}n|}|�||
||||f�qq|S)Nrr�rv�-)r�r��sortedr��domainsr��get_objectsrt�escape�
rpartition�
setdefault�KeyErrorr,�object_typesrqr3�
get_type_name�append)rr�r��otypes�onames�
domainname�domain�fullname�dispname�type�docname�anchor�prio�prefixr�rm�plist�	typeindex�otype�shortanchorr r r!r�2sF
�


���
�zIndexBuilder.get_objectscs|iif}t||j|jf�D].\}}|��D]%\}}t|�dkr-|\}|�vr,�|||<qt�fdd�|D��||<qq
|S)Nr�csg|]
}|�vr�|�qSr r )ry�fn�r�r r!r{`sz*IndexBuilder.get_terms.<locals>.<listcomp>)r�r�r�r�r,r�)rr��rvsr�r�r�r�r�r r�r!�	get_termsWs��zIndexBuilder.get_termsc
s�tt�j����\}}�fdd�|D�}dd�t|�D�}��|�\}}��|�}dd��j��D�}�j}	t	|||||||	|�j
jd�	S)z/Create a usable data structure for serializing.csg|]}�j�|��qSr )r�rq)ryr��rr r!r{fsz'IndexBuilder.freeze.<locals>.<listcomp>cSsi|]\}}||�qSr r )ryr�r_r r r!�
<dictcomp>gsz'IndexBuilder.freeze.<locals>.<dictcomp>cSs&i|]\}}||dd|d�qS)r�:r�r )ryr�r�r r r!r�ks&)	r�r�r�r��objects�objtypes�objnamesr�r�)r�r�r�r��	enumerater�r�r�r�r�r�r�)
rr�r�r�r�r��title_termsr�r�r�r r�r!r�cs

�zIndexBuilder.freezecCsd|jj|jjfS)Nz
%s (code: %s))rrr�r r r!�labelqrbzIndexBuilder.labelr�cCs|i}i}|D]}||jvr|j|||<|j|||<q||_||_|j��D]}|�|�q'|j��D]}|�|�q4dS)z-Remove data for all docnames not in the list.N)r�r�r��values�intersection_updater�)rr��
new_titles�
new_filenamesr��	wordnamesr r r!�prunets
��zIndexBuilder.pruner��filenamer��doctreecs�|�j|<|�j|<t|�j�}|�|�dtdtf�fdd�}�jj}|jD]%}||�}	||	�r=�j�	|	t
���|�q'||�rL�j�	|t
���|�q'|jD]+}||�}	||	�s`||�r`|}	|�j�
|	t
��v}
||	�r{|
s{�j�	|	t
���|�qPdS)zFeed a doctree to the index.r'rcs@z�j|WSty�j�|����j|<�j|YSwr)r�r�rr)�lower)r'r�r r!r)�s�zIndexBuilder.feed.<locals>.stemN)r�r�rer�walkr3r.rir�r�r5�addrhrqr�)rr�r�r�r��visitorr)�_filterr'�stemmed_word�already_indexedr r�r!�feed�s,



�
��zIndexBuilder.feedcCs:|jjr	|jj}n|j}|��t�t|jj��|j|d�S)N)�search_language_stemming_code�search_language_stop_words�search_scorer_tool�search_word_splitter_code)rr�get_js_stemmer_coderrXr�rr�)rrr r r!�context_for_searchtool�s
�z#IndexBuilder.context_for_searchtoolcCs"|jjrdd�d|jjfD�SgS)z8Returns a list of non-minified stemmer JS files to copy.cSsg|]
}t�tdd|��qS)�searchznon-minified-js)r�joinr)ry�fnamer r r!r{�s��z8IndexBuilder.get_js_stemmer_rawcodes.<locals>.<listcomp>�base-stemmer.js)rrr�r r r!�get_js_stemmer_rawcodes�s

�z$IndexBuilder.get_js_stemmer_rawcodescCsdSrr r�r r r!�get_js_stemmer_rawcode�sz#IndexBuilder.get_js_stemmer_rawcodecCs�|jjrNt�tdd�}tt�|d���}|��}Wd�n1s"wYtt�||jj���}|��}Wd�n1s@wYd|||jjfS|jjS)z<Returns JS code that will be inserted into language_data.js.r�zminified-jsr�Nz%s
%s
Stemmer = %sStemmer;)	rrrr�rr�rcrr6)r�js_dir�js_file�base_js�language_jsr r r!r��s
�
��z IndexBuilder.get_js_stemmer_code) r/r0r1r2rr�r�rr3rr"rrrdrar�rrr�r�r�r�rr�r
rfr�r�r�r	r�r�r r r r!r��s(�#
�2% !

r�)+r2rtr�r7�	importlibr�osr�typingrrrrrr	r
rr�docutilsr
�docutils.nodesr�sphinxrr�sphinx.environmentr�sphinx.search.jssplitterr�sphinx.utilrr�sphinx.search.enr:r3rArSr4rT�js_index�NodeVisitorrer�r r r r!�<module>sn	,\��������	�
���
�����,