
    Pie                      U d Z ddlmZ ddlZddlZddlmZ g dZddlZddl	Z	ddl
Z
ddlZddlmZmZ ddlmZmZ ddlmZ dd	lmZmZmZmZ dd
lmZ ddlmZmZ ddlmZ ddlm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(m)Z)m*Z* ddl+m,Z,m-Z-m.Z. ddl/m0Z0 ddl1Z1ddl2Z1ddl3m4Z4 ddl5m6Z6m7Z7m8Z8m9Z9m:Z:m;Z; e rddl<m=Z= ddl>m?Z?m@Z@mAZAmBZBmCZC dZD	 ddlEZEdZDn# eF$ r dZEY nw xY wdZG ejH        eI          ZJdZKdZLi ZMdeNd<   dZOdd!ZP ed"          ZQdd$ZRdd'ZS G d( d)ejT                  ZU G d* d+eUeV          ZW G d, d-eW          ZX G d. d/eX          ZY G d0 d1eY          ZZ G d2 d3eZ          Z[dd4Z\ G d5 d6eX          Z] G d7 d8eW          Z^dd;Z_dd>Z`dd@ZaddCZbddEZcddFZdddIZeddJZfddKZgddLZhddMZiddNZjddOZkddPZlddQZmddRZnddSZoddTZpddUZqdVZrdWZs eYesdXz             Zt eYesdYz             Zu eYerdZz             Zv eYerd[z             Zw eYerd\z             Zx eYerd]z             Zy eYerd^z             Zz eYerd_z             Z{ eYerd`z             Z| eYerdaz             Z} eYerdbz             Z~ eYerdcz             Z eYerddz             Z eYerdez             Z eYerdfz             Z eYerdgz             Z eYdh          Z eYerdiz             Z eYerdjz             Z eYerdkz             Z eYerdlz             Ze|e{ez eYerd]z              eYerdmz              eYerdnz              eYerdoz              eYerdpz              eYerdqz              eYerdrz              eYerdsz              eYerdtz              eYerduz              eYerdvz              eYerdwz              eYerdxz             fZdyeNdz<   e|e}eze{efZdyeNd{<    eYerd]z             eze{fZdyeNd|<   e~eefZdyeNd}<   eefZdyeNd~<   eez   ZdyeNd<   ed ed ej        j        j        d iZdeNd<   eveteu eYerd[z              eYerd\z             fZdyeNd<    e)deV          ZddZddZeVdfedezffed e}ffede|ffe4de|ffed e{ffed e~ffed effed effe6d effed effej        j        j        ebetffedeffgZdeNd<   eE(e                    ej        j        j        eaeuff            ee          Zeefd feefd feVefefeefefeVefefeefefgZdeNd<    ee          Zi dd eYerddz             e9 eYerdcz             e: eYerdbz             e8 eYerdez             e; eYerdfz             e; eYerdgz             e; eYerdjz             ec eYerdZz             d eYerd[z             d eYerd\z             d eYerdz             d eYerdaz             ed eYerd_z             e eYerd`z             e4 eYerdrz             e4 eYerdoz             e4 eYerdqz             e4 eYerdpz             e4 eYerdnz             e eYerdwz             e4 eYerdsz             e4 eYerdtz             e eYerdvz             e eYerdmz             e eYerdxz             e eYerduz             e eYerd]z             e eYerd^z             e eYerdiz             e eYerdz             dete_iZdeNd<   eEe`eeu<   eteufZdyeNd<   netfZ eYerdaz             eg eYerdrz             ep eYerdqz             en eYerdpz             eq eYerdsz             eo eYerdnz             eh eYerdtz             ej eYerdmz             el eYerdvz             ei eYerdwz             ef eYerdxz             ek eYerduz             emiZdeNd<   i ZdeNd<   e                    e           ddZddZ e)de!          ZddZddZ	 	 	 dddZ G d deW          Z ee          ZdeNd<   e                    e]dedeYde^di           ddńZdS )a  
This module defines the different types of terms. Terms are the kinds of
objects that can appear in a quoted/asserted triple. This includes those
that are core to RDF:

* [Blank Nodes][rdflib.term.BNode] - Blank Nodes
* [URI References][rdflib.term.URIRef] - URI References
* [Literals][rdflib.term.Literal] - Literals (which consist of a literal value, datatype and language tag)

Those that extend the RDF model into N3:

* [`QuotedGraph`][rdflib.graph.QuotedGraph] - Formulae
* [`Variable`][rdflib.term.Variable] - Universal Quantifications (Variables)

And those that are primarily for matching against 'Nodes' in the
underlying Graph:

* REGEX Expressions
* Date Ranges
* Numerical Ranges
    )annotationsN)Fraction)	bind_is_valid_uriNodeIdentifiedNode
IdentifierURIRefBNodeLiteralVariable)	b64decode	b64encode)hexlify	unhexlify)defaultdict)datedatetimetime	timedelta)Decimal)compilesub)GeneratorType)TYPE_CHECKINGAnyCallableDict	GeneratorListOptionalTupleTypeTypeVarUnion)	urldefragurljoinurlparse)uuid4)	long_type   )Durationduration_isoformatparse_datetime
parse_timeparse_xsd_dateparse_xsd_duration)NamespaceManager)AlternativePathInvPathNegatedPathPathSequencePathFTzhttps://rdflib.github.ioz/.well-known/genid/z/.well-known/genid/rdflib/zDict[str, BNode]skolemsz
<>" {}|\^`uristrreturnboolc                (    t           D ]	}|| v r dS 
dS )NFT)_invalid_uri_chars)r9   cs     _/home/jaya/work/projects/VOICE-AGENT/VIET/agent-env/lib/python3.11/site-packages/rdflib/term.pyr   r   h   s+      8855 4    z^[a-zA-Z]+(?:-[a-zA-Z0-9]+)*$tagc                P    t          t                              |                     S N)r<   _lang_tag_regexmatch)rB   s    r@   _is_valid_langtagrG   r   s    %%c**+++rA   valueUnion[str, bytes]c                    t          | t                    rt          | d          d}}n	t          | }}	  ||           n# t          $ r Y dS w xY wdS )z[
    Verify that the provided value can be converted into a Python
    unicode object.
    decodeutf-8FT)
isinstancebytesgetattrr:   UnicodeError)rH   coding_funcparams      r@   _is_valid_unicoderS   v   ss    
 % ($UH55wU %UE   uu4s   ? 
AAc                  :    e Zd ZdZdZej        d	d
d            ZdS )r   zA Node in the Graph. Nnamespace_managerOptional[NamespaceManager]r;   r:   c                    d S rD   rU   selfrV   s     r@   n3zNode.n3   s    ORsrA   rD   rV   rW   r;   r:   )__name__
__module____qualname____doc__	__slots__abcabstractmethodr[   rU   rA   r@   r   r      s8        IRRRR RRRrA   r   c                  v    e Zd ZdZdZddZdd
ZddZddZddZ	ddZ
ddZddZddZdddZej        ZdS )r	   z]See http://www.w3.org/2002/07/rdf-identifer-terminology/
    regarding choice of terminology.rU   rH   r:   c                8    t                               | |          S rD   )r:   __new__clsrH   s     r@   rf   zIdentifier.__new__   s    {{3&&&rA   otherr   r;   r<   c                ,    |                      |          S )zNA "semantic"/interpreted equality function,
        by default, same as __eq____eq__rZ   ri   s     r@   eqzIdentifier.eq        {{5!!!rA   c                ,    |                      |          S )zOA "semantic"/interpreted not equal function,
        by default, same as __ne__)__ne__rm   s     r@   neqzIdentifier.neq   ro   rA   c                .    |                      |           S rD   rk   rm   s     r@   rq   zIdentifier.__ne__   s    ;;u%%%%rA   c                    t          |           t          |          u r t          |           t          |          k    S dS )a  Equality for Nodes.

        ```python
        >>> BNode("foo")==None
        False
        >>> BNode("foo")==URIRef("foo")
        False
        >>> URIRef("foo")==BNode("foo")
        False
        >>> BNode("foo")!=URIRef("foo")
        True
        >>> URIRef("foo")!=BNode("foo")
        True
        >>> Variable('a')!=URIRef('a')
        True
        >>> Variable('a')!=Variable('a')
        False

        ```
        F)typer:   rm   s     r@   rl   zIdentifier.__eq__   s7    , ::e$$t99E

**5rA   c                *   |dS t          |           t          |          u r t          |           t          |          k    S t          |t                    r6t          t          |                    t          t          |                   k    S t
          S )a  This implements ordering for Nodes.

        This tries to implement this:
        http://www.w3.org/TR/sparql11-query/#modOrderBy

        Variables are not included in the SPARQL list, but
        they are greater than BNodes and smaller than everything else
        NTru   r:   rM   r   	_ORDERINGNotImplementedrm   s     r@   __gt__zIdentifier.__gt__   sv     =4$ZZ4;;&&t99s5zz))t$$ 	BT$ZZ(9T%[[+AAArA   c                *   |dS t          |           t          |          u r t          |           t          |          k     S t          |t                    r6t          t          |                    t          t          |                   k     S t
          S NFrw   rm   s     r@   __lt__zIdentifier.__lt__   st    =5$ZZ4;;&&t99s5zz))t$$ 	BT$ZZ(9T%[[+AAArA   c                @    |                      |          }|rdS | |k    S NT)r}   rZ   ri   rs      r@   __le__zIdentifier.__le__   *    KK 	4u}rA   c                @    |                      |          }|rdS | |k    S r   )rz   r   s      r@   __ge__zIdentifier.__ge__   r   rA   .prefixc                `    t          |                               t          |                    S rD   )r:   
startswith)rZ   r   startends       r@   r   zIdentifier.startswith   s"    4yy##CKK000rA   NrH   r:   ri   r   r;   r<   )..)r   r:   r;   r<   )r]   r^   r_   r`   ra   rf   rn   rr   rq   rl   rz   r}   r   r   r   r:   __hash__rU   rA   r@   r	   r	      s        ( ( I' ' ' '" " " "
" " " "
& & & &   6   $         1 1 1 1 1 |HHHrA   r	   c                  0    e Zd ZdZdZddZddd
ZddZdS )r   a
  
    An abstract class, primarily defined to identify Nodes that are not Literals.

    The name "Identified Node" is not explicitly defined in the RDF specification, but can be drawn from this section: https://www.w3.org/TR/rdf-concepts/#section-URI-Vocabulary
    rU   r;   
Tuple[str]c                "    t          |           fS rD   r:   rZ   s    r@   __getnewargs__zIdentifiedNode.__getnewargs__   s    D		|rA   NrV   rW   r:   c                    t                      rD   )NotImplementedErrorrY   s     r@   r[   zIdentifiedNode.n3  s    !###rA   c                     t          |           S rD   r   r   s    r@   toPythonzIdentifiedNode.toPython  s    4yyrA   )r;   r   rD   r\   r;   r:   )r]   r^   r_   r`   ra   r   r[   r   rU   rA   r@   r   r      sf          I   $ $ $ $ $     rA   r   c                      e Zd ZU dZdZded<   ded<   ded<   d	ed
<   dd dZdd!dZd"dZe	d#d            Z
d$dZd#dZd"dZd"dZd"dZd%dZdS )&r
   a  [RDF 1.1's IRI Section](https://www.w3.org/TR/rdf11-concepts/#section-IRIs)

    !!! info "Terminology"
        Documentation on RDF outside of RDFLib uses the term IRI or URI whereas this class is called URIRef. This is because it was made when the first version of the RDF specification was current, and it used the term *URIRef*, see [RDF 1.0 URIRef](http://www.w3.org/TR/rdf-concepts/#section-Graph-URIref)

    An IRI (Internationalized Resource Identifier) within an RDF graph is a Unicode string that conforms to the syntax defined in RFC 3987.

    IRIs in the RDF abstract syntax MUST be absolute, and MAY contain a fragment identifier.

    IRIs are a generalization of URIs [RFC3986] that permits a wider range of Unicode characters.
    rU   z8Callable[[URIRef, Union[URIRef, Path]], AlternativePath]__or__zCallable[[URIRef], InvPath]
__invert__zCallable[[URIRef], NegatedPath]__neg__z5Callable[[URIRef, Union[URIRef, Path]], SequencePath]__truediv__NrH   r:   baseOptional[str]c                z   |C|                     d          }t          ||d          }|r|                     d          s|dz  }t          |          st                              | d           	 t
                              | |          }n,# t          $ r t
                              | |d          }Y nw xY w|S )N#r+   )allow_fragmentszE does not look like a valid URI, trying to serialize this will break.rL   )endswithr'   r   loggerwarningr:   rf   UnicodeDecodeError)rh   rH   r   ends_in_hashrts        r@   rf   zURIRef.__new__  s     >>#..LD%;;;E !~~c** !SLEU## 	NN___  	2S%((BB! 	2 	2 	2S%11BBB	2 	s   3B &B87B8rV   rW   r;   c                    t          |           st          d|  d          |r|                    |           S d|  dS )a  This will do a limited check for valid URIs,
        essentially just making sure that the string includes no illegal
        characters (`<, >, ", {, }, |, \, `, ^`)

        Args:
            namespace_manager: if not None, will be used to make up a prefixed name
        "zk" does not look like a valid URI, I cannot serialize this as N3/Turtle. Perhaps you wanted to urlencode it?<>)r   	ExceptionnormalizeUrirY   s     r@   r[   z	URIRef.n33  sl     T"" 	 FD  F  F  F    	$11$777t;;;rA   c                P    d| v r!t          |           \  }}t          |          S | S )Nr   )r&   r
   )rZ   urlfrags      r@   defragzURIRef.defragF  s+    $;;!$IC#;;KrA   c                *    t          |           j        S )zReturn the URL Fragment

        ```python
        >>> URIRef("http://example.com/some/path/#some-fragment").fragment
        'some-fragment'
        >>> URIRef("http://example.com/some/path/").fragment
        ''

        ```
        )r(   fragmentr   s    r@   r   zURIRef.fragmentM  s     ~~&&rA   Tuple[Type[URIRef], Tuple[str]]c                0    t           t          |           ffS rD   )r
   r:   r   s    r@   
__reduce__zURIRef.__reduce__[  s    T%%rA   c                |    | j         t          u rd}n| j         j        }| dt                              |            dS )Nzrdflib.term.URIRef())	__class__r
   r]   r:   __repr__rZ   clsNames     r@   r   zURIRef.__repr__^  sC    >V##*GGn-G11CLL..1111rA   c                L    |                      t          |           |z             S rD   r   r:   rm   s     r@   __add__zURIRef.__add__f      ~~c$ii%/000rA   c                L    |                      |t          |           z             S rD   r   rm   s     r@   __radd__zURIRef.__radd__i  s    ~~ec$ii/000rA   c                L    |                      t          |           |z            S rD   r   rm   s     r@   __mod__zURIRef.__mod__l  r   rA   r   c                `   t          | t                    r?t          |            }t          |j        t          t                    d                   S t          | t                    r3|  }|t          v rt          |         S t                      }|t          |<   |S t          d|  d          )a  Create a Blank Node from a skolem URI, in accordance
        with http://www.w3.org/TR/rdf11-concepts/#section-skolemization.
        This function accepts only rdflib type skolemization, to provide
        a round-tripping within the system.

        Added in version 4.0
        NrH   r   z> is not a skolem URI)
rM   RDFLibGenidr(   r   pathlenrdflib_skolem_genidGenidr8   r   )rZ   
parsed_uribnode_idretvals       r@   de_skolemizezURIRef.de_skolemizeo  s     dK(( 	=!T),,Jzs3F/G/G/I/IJKKKKe$$ 		=yH7""x(($*!;;;;<<<rA   rD   )rH   r:   r   r   r\   )r;   r
   r   )r;   r   )r;   r   )r]   r^   r_   r`   ra   __annotations__rf   r[   r   propertyr   r   r   r   r   r   r   rU   rA   r@   r
   r
   
  s5        
 
 IDDDD++++,,,,FFFF    *    &    ' ' ' X'& & & &2 2 2 21 1 1 11 1 1 11 1 1 1= = = = = =rA   r
   c                  *    e Zd ZdZedd            ZdS )	r   rU   r9   r   r;   r<   c                    t          | t                    st          |           } t          |           }|j                            t
                    }|dk    rdS dS )Nr   FT)rM   r:   r(   r   rfindskolem_genidr9   r   gen_ids      r@   _is_external_skolemzGenid._is_external_skolem  sR    #s## 	c((Cc]]
&&|44Q;;5trA   Nr9   r   r;   r<   )r]   r^   r_   ra   staticmethodr   rU   rA   r@   r   r     s7        I   \  rA   r   c                  *    e Zd ZdZedd            ZdS )	r   rU   r9   r   r;   r<   c                    t          | t                    st          |           } t          |           }|j        dk    s|j        dk    s|j        dk    rdS |j                            t                    }|dk    rdS dS )N Fr   T)	rM   r:   r(   paramsqueryr   r   r   r   r   s      r@   _is_rdflib_skolemzRDFLibGenid._is_rdflib_skolem  s    #s## 	c((Cc]]
##2%%"b((5&&':;;Q;;5trA   Nr   )r]   r^   r_   ra   r   r   rU   rA   r@   r   r     s7        I   \  rA   r   c                     dS )NNrU   rU   rA   r@   
_unique_idr     s	     3rA   c                  \    e Zd ZdZdZdd e            fdd
ZdddZddZddZ		 dddZ
dS )r   ag  
    RDF 1.1's Blank Nodes Section: https://www.w3.org/TR/rdf11-concepts/#section-blank-nodes

    Blank Nodes are local identifiers for unnamed nodes in RDF graphs that are used in
    some concrete RDF syntaxes or RDF store implementations. They are always locally
    scoped to the file or RDF store, and are not persistent or portable identifiers for
    blank nodes. The identifiers for Blank Nodes are not part of the RDF abstract
    syntax, but are entirely dependent on particular concrete syntax or implementation
    (such as Turtle, JSON-LD).

    ---

    RDFLib's `BNode` class makes unique IDs for all the Blank Nodes in a Graph but you
    should *never* expect, or reply on, BNodes' IDs to match across graphs, or even for
    multiple copies of the same graph, if they are regenerated from some non-RDFLib
    source, such as loading from RDF data.
    rU   NrH   r   _sn_gen-Optional[Union[Callable[[], str], Generator]]_prefixr:   c                    |`|Dt          |          r |            }n|}t          |t                    rt          |          }n|}nt	                      j        }|| z   }n	 t                              | |          S )zE
        # only store implementations should pass in a value
        )callablerM   r   nextr)   hexr	   rf   )rh   rH   r   r   	sn_resultnode_ids         r@   rf   zBNode.__new__  s     = "G$$ (7>wyyII 'Ii77 ("9ooGG'GG''+ l*EE  !!#u---rA   rV   rW   r;   c                    d| z   S )Nz_:rU   rY   s     r@   r[   zBNode.n3  s    d{rA   Tuple[Type[BNode], Tuple[str]]c                0    t           t          |           ffS rD   )r   r:   r   s    r@   r   zBNode.__reduce__  s    D		|$$rA   c                |    | j         t          u rd}n| j         j        }| dt                              |            dS )Nzrdflib.term.BNoder   r   )r   r   r]   r:   r   r   s     r@   r   zBNode.__repr__  sC    >U"")GGn-G11CLL..1111rA   	authoritybasepathr
   c                    |t           }|t          }|t          |           z   }t          t	          ||                    S )zCreate a URIRef "skolem" representation of the BNode, in accordance
        with http://www.w3.org/TR/rdf11-concepts/#section-skolemization

        Added in version 4.0
        )_SKOLEM_DEFAULT_AUTHORITYr   r:   r
   r'   )rZ   r   r   skolems       r@   	skolemizezBNode.skolemize  sB     1I*HCII%gi00111rA   )rH   r   r   r   r   r:   rD   r\   )r;   r   r   NN)r   r   r   r   r;   r
   )r]   r^   r_   r`   ra   r   rf   r[   r   r   r   rU   rA   r@   r   r     s         $ I  $AE!z||	#. #. #. #. #.J    % % % %2 2 2 2 JN2 2 2 2 2 2 2rA   r   c                     e Zd ZU dZded<   ded<   ded<   ded	<   d
Z	 	 	 d?d@dZdAdZedBd            Z	edCd            Z
edDd            ZedEd            ZdFdZdGdZdHdZdId ZdId!ZdJd#ZdAd$ZdAd%ZdAd&ZdAd'ZdKd)ZdKd*ZdKd+ZdKd,ZdKd-ZdLd/ZdKd0ZdKd1ZdKd2ZdMdNd6Z 	 	 dOdPd;Z!dQd<Z"dQd=Z#dCd>Z$dS )Rr   a  

    RDF 1.1's Literals Section: http://www.w3.org/TR/rdf-concepts/#section-Graph-Literal

    Literals are used for values such as strings, numbers, and dates.

    A literal in an RDF graph consists of two or three elements:

    * a lexical form, being a Unicode string, which SHOULD be in Normal Form C
    * a datatype IRI, being an IRI identifying a datatype that determines how the lexical form maps to a literal value, and
    * if and only if the datatype IRI is `http://www.w3.org/1999/02/22-rdf-syntax-ns#langString`, a non-empty language tag. The language tag MUST be well-formed according to section 2.2.9 of `Tags for identifying languages <http://tools.ietf.org/html/bcp47>`_.

    A literal is a language-tagged string if the third element is present. Lexical representations of language tags MAY be converted to lower case. The value space of language tags is always in lower case.

    ---

    For valid XSD datatypes, the lexical form is optionally normalized
    at construction time. Default behaviour is set by `rdflib.NORMALIZE_LITERALS`
    and can be overridden by the normalize parameter to `__new__`

    Equality and hashing of Literals are done based on the lexical form, i.e.:

    ```python
    >>> from rdflib.namespace import XSD
    >>> Literal('01') != Literal('1')  # clear - strings differ
    True

    ```

    but with data-type they get normalized:

    ```python
    >>> Literal('01', datatype=XSD.integer) != Literal('1', datatype=XSD.integer)
    False

    ```

    unless disabled:

    ```python
    >>> Literal('01', datatype=XSD.integer, normalize=False) != Literal('1', datatype=XSD.integer)
    True

    ```

    Value based comparison is possible:

    ```python
    >>> Literal('01', datatype=XSD.integer).eq(Literal('1', datatype=XSD.float))
    True

    ```

    The eq method also provides limited support for basic python types:

    ```python
    >>> Literal(1).eq(1) # fine - int compatible with xsd:integer
    True
    >>> Literal('a').eq('b') # fine - str compatible with plain-lit
    False
    >>> Literal('a', datatype=XSD.string).eq('a') # fine - str compatible with xsd:string
    True
    >>> Literal('a').eq(1) # not fine, int incompatible with plain-lit
    NotImplemented

    ```

    Greater-than/less-than ordering comparisons are also done in value
    space, when compatible datatypes are used.  Incompatible datatypes
    are ordered by DT, or by lang-tag.  For other nodes the ordering
    is None < BNode < URIRef < Literal

    Any comparison with non-rdflib Node are "NotImplemented"
    In PY3 this is an error.

    ```python
    >>> from rdflib import Literal, XSD
    >>> lit2006 = Literal('2006-01-01',datatype=XSD.date)
    >>> lit2006.toPython()
    datetime.date(2006, 1, 1)
    >>> lit2006 < Literal('2007-01-01',datatype=XSD.date)
    True
    >>> Literal(datetime.utcnow()).datatype
    rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#dateTime')
    >>> Literal(1) > Literal(2) # by value
    False
    >>> Literal(1) > Literal(2.0) # by value
    False
    >>> Literal('1') > Literal(1) # by DT
    True
    >>> Literal('1') < Literal('1') # by lexical form
    False
    >>> Literal('a', lang='en') > Literal('a', lang='fr') # by lang-tag
    False
    >>> Literal(1) > URIRef('foo') # by node-type
    True

    ```

    The > < operators will eat this NotImplemented and throw a TypeError (py3k):

    ```python
    >>> Literal(1).__gt__(2.0)
    NotImplemented

    ```
    r   _valuer   	_languageOptional[URIRef]	_datatypeOptional[bool]
_ill_typed)r   r   r   r  Nlexical_or_valuelangdatatype	normalizec                   |dk    rd}||nt           j        }||t          d          |/t          |          s t	          dt          |           d          |t          |          }d}d}t          |t                    r-|p|j	        }|t          ||          }n|j        }|j        }n t          |t
                    st          |t                    rt          ||          }|I|t          v r@t          |          }t                              |t"                    } |||          }	|p|	 }|(|r&t%          ||          \  }
}|
t'          |
          r|
}nP|}t%          ||          \  }
}|dnt          |          }t           j                            ||          }|
|
}|d}t          |t                    r|                    d          }|t.          t0          fv rt3          |          }|t0          fv rt5          |          }	 t
                              | |          }n,# t8          $ r t
                              | |d          }Y nw xY w||_        ||_        ||_        ||_         |S )zCreate a new Literal instance.r   NzmA Literal can only have one of lang or datatype, per http://www.w3.org/TR/rdf-concepts/#section-Graph-Literal'z' is not a valid language tag!rL   )!rdflibNORMALIZE_LITERALS	TypeErrorrG   
ValueErrorr:   r
   rM   r   language_castLexicalToPythonr  rH   rN   _toPythonMapping_check_well_formed_typesget_well_formed_by_value_castPythonToLiteralrS   util	_coalescerK   _XSD_NORMALISED_STRING
_XSD_TOKEN_normalise_XSD_STRING_strip_and_collapse_whitespacerf   r   r   r   r   r  )rh   r  r  r  r  rH   	ill_typeddt_uricheckerwell_formedr   r   insts                r@   rf   zLiteral.__new__  s    2::D!*!6IIF<U	 4O  
 $5d$;$;JTJJJKKKh''H$(	&00 &	 4+4D#,-=xHH+4(.(#.. 	*=Mu2U2U 	 ))98DDE#4D(D(D "(!1!1266v?TUU%g&6>>%:k/	 Y $8$I$I!	%*;F*C*C%'-$ %E 45Ex P PFI ) 1vi7H7HI{,,XyAAH!#) #&.. 	@/66w??.
;;;45EFF
}$$=>NOO	?;;s$455DD! 	? 	? 	?;;s$4g>>DDD	? !#s   H3 3&IIr;   c                V    | j         !t          | j         | j        | j                  S | S )aw  
        Returns a new literal with a normalised lexical representation
        of this literal

        ```python
        >>> from rdflib import XSD
        >>> Literal("01", datatype=XSD.integer, normalize=False).normalize()
        rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

        ```

        Illegal lexical forms for the datatype given are simply passed on

        ```python
        >>> Literal("a", datatype=XSD.integer, normalize=False)
        rdflib.term.Literal('a', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

        ```
        N)r  r  )rH   r   r  r  r   s    r@   r  zLiteral.normalize  s,    * :!4:DMRRRRKrA   c                    | j         S )a  
        For `recognized datatype IRIs
        <https://www.w3.org/TR/rdf11-concepts/#dfn-recognized-datatype-iris>`_,
        this value will be `True` if the literal is ill formed, otherwise it
        will be `False`. `Literal.value` (i.e. the `literal value <https://www.w3.org/TR/rdf11-concepts/#dfn-literal-value>`_) should always be defined if this property is `False`, but should not be considered reliable if this property is `True`.

        If the literal's datatype is `None` or not in the set of `recognized datatype IRIs
        <https://www.w3.org/TR/rdf11-concepts/#dfn-recognized-datatype-iris>`_ this value will be `None`.
        )r  r   s    r@   r  zLiteral.ill_typed  s     rA   c                    | j         S rD   )r   r   s    r@   rH   zLiteral.value   s
    {rA   c                    | j         S rD   )r   r   s    r@   r  zLiteral.language  
    ~rA   c                    | j         S rD   )r   r   s    r@   r  zLiteral.datatype  r"  rA   DTuple[Type[Literal], Tuple[str, Union[str, None], Union[str, None]]]c                H    t           t          |           | j        | j        ffS rD   )r   r:   r  r  r   s    r@   r   zLiteral.__reduce__  s%     YYt}5
 	
rA   (Tuple[None, Dict[str, Union[str, None]]]c                <    d t          | j        | j                  fS )N)r  r  )dictr  r  r   s    r@   __getstate__zLiteral.__getstate__  s    dDMDMJJJKKrA   argTuple[Any, Dict[str, Any]]Nonec                D    |\  }}|d         | _         |d         | _        d S )Nr  r  )r   r   )rZ   r*  _ds       r@   __setstate__zLiteral.__setstate__  s%    1::rA   valc                   || S t          |t                    st          |          }| j        t          t          fv rQ|j        t
          v rC|                                 }|                                }||z   }t          || j                  S | j        t          k    r|j        t
          v rw|                                 }|                                }t          j	        t          ddd          |          |z   }t          |                                | j                  S | j        t          v r|j        t          vsH| j        t          vr|j        t          v s,| j        t
          v rW|j        t
          vs| j        |j        k    r9t          dt          |j                   dt          | j                             | j        |j        k    rCt          |                                 |                                z   | j        | j                  S | j        t           v r|j        t           v rt          t#          t%          t#          |                                           t#          |                                          z   d          d                    d	                              d
                    t(                    S 	 t                              | |          }n4# t          $ r' t          | j                  t          |          z   }Y nw xY w| j        t.          v r| j        }	nt0          }	t          || j        |	          S )a  
        ```python
        >>> from rdflib.namespace import XSD
        >>> Literal(1) + 1
        rdflib.term.Literal('2', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))
        >>> Literal("1") + "1"
        rdflib.term.Literal('11')

        # Handling dateTime/date/time based operations in Literals
        >>> a = Literal('2006-01-01T20:50:00', datatype=XSD.dateTime)
        >>> b = Literal('P31D', datatype=XSD.duration)
        >>> (a + b)
        rdflib.term.Literal('2006-02-01T20:50:00', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#dateTime'))
        >>> from rdflib.namespace import XSD
        >>> a = Literal('2006-07-01T20:52:00', datatype=XSD.dateTime)
        >>> b = Literal('P122DT15H58M', datatype=XSD.duration)
        >>> (a + b)
        rdflib.term.Literal('2006-11-01T12:50:00', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#dateTime'))

        ```
        Nr    r+   z!Cannot add a Literal of datatype z to a Literal of datatype    f0.)rM   r   r  _XSD_DATETIME	_XSD_DATE_TIME_DELTA_TYPESr   	_XSD_TIMEr   combiner   r   _ALL_DATE_AND_TIME_TYPESr
  r:   r  _NUMERIC_LITERAL_TYPESr   roundrstrip_XSD_DECIMALr   rH   _STRING_LITERAL_TYPES_XSD_STRING)
rZ   r1  date1duration
differenceselfvvalvsdtsnew_datatypes
             r@   r   zLiteral.__add__  s   0 ;K #w'' 	#,,C MmY777 111+/==??E36<<>>H)J:>>>> ]i''CL<M,M,M--//E/2||~~D"4a#3#3U;;dBC388::>>>>
 !999L(@@@ %===L$<<< !222\):::55 uC4E4Euuadeierasasuu  
 =CL((#,,..0$-$-    M333 666WT]]__558O8OOQSTTXX__ f   &	 	 	 	/KKc** / / /
OOc#hh./ } 555#}  +1dmlCCCCs   K' '.LLc                   || S t          |t                    st          |          }t          | d          st          d          t          |d          st          d          | j        t
          t          fv rQ|j        t          v rC|                                 }|                                }||z
  }t          || j                  S | j        t          k    r|j        t          v rw|                                 }|                                }t          j        t          ddd          |          |z
  }t          |                                | j                  S | j        |j        k    r| j        t          k    rt          j        t          j                    |                                           }t          j        t          j                    |                                          }t          ||z
  t                    S t          |                                 |                                z
  | j        | j        t
          t          t          fv rt          n| j                  S | j        t"          v r|j        t"          v rt          t%          t'          t%          |                                           t%          |                                          z
  d          d	                    d
                              d                    t*                    S t          dt-          |j                   dt-          | j                             )a  Implements subtraction between Literals or between a Literal and a Python object.

        Example:
            ```python
            from rdflib.namespace import XSD

            # Basic numeric subtraction
            Literal(2) - 1
            # rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            Literal(1.1) - 1.0
            # rdflib.term.Literal('0.10000000000000009', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#double'))

            Literal(1.1) - 1
            # rdflib.term.Literal('0.1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#decimal'))

            Literal(1.1, datatype=XSD.float) - Literal(1.0, datatype=XSD.float)
            # rdflib.term.Literal('0.10000000000000009', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#float'))

            # This will raise a TypeError
            Literal("1.1") - 1.0
            # TypeError: Not a number; rdflib.term.Literal('1.1')

            Literal(1.1, datatype=XSD.integer) - Literal(1.0, datatype=XSD.integer)
            # rdflib.term.Literal('0.10000000000000009', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # Handling dateTime/date/time based operations in Literals
            a = Literal('2006-01-01T20:50:00', datatype=XSD.dateTime)
            b = Literal('2006-02-01T20:50:00', datatype=XSD.dateTime)
            (b - a)
            # rdflib.term.Literal('P31D', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#duration'))

            a = Literal('2006-07-01T20:52:00', datatype=XSD.dateTime)
            b = Literal('2006-11-01T12:50:00', datatype=XSD.dateTime)
            (a - b)
            # rdflib.term.Literal('-P122DT15H58M', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#duration'))
            (b - a)
            # rdflib.term.Literal('P122DT15H58M', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#duration'))
            ```
        Nr  zCMinuend Literal must have Numeric, Date, Datetime or Time datatype.zFSubtrahend Literal must have Numeric, Date, Datetime or Time datatype.r3  r4  r+   r5  r6  r7  r8  z&Cannot subtract a Literal of datatype z from a Literal of datatype )rM   r   rO   r
  r  r9  r:  r;  r   r<  r   r=  r   r   today_XSD_DURATIONr  r?  r   r@  rA  rB  r:   )	rZ   r1  rE  rF  rG  rH  rI  rJ  vdts	            r@   __sub__zLiteral.__sub__  s   T ;K #w'' 	#,,CtZ(( 	U   j)) 	X  
 MmY777 111+/==??E36<<>>H)J:>>>> ]i''CL<M,M,M--//E/2||~~D"4a#3#3U;;dBC388::>>>> =CL((}	))&tz||T]]__EE&tz||S\\^^DDsSy=AAAAMMOOcllnn4M  =]Iy,QQQ &!]    M333 666WT]]__558O8OOQSTTXX__ f   &	 	 	 	 |S\9J9J||hklplyhzhz||  rA   r<   c                ^    | j         t          | j                   S t          |           dk    S )zhDetermines the truth value of the Literal.

        Used for if statements, bool(literal), etc.
        Nr   )rH   r<   r   r   s    r@   __bool__zLiteral.__bool__  s,    
 :!
###4yyA~rA   c                    t          | j        t          t          t          f          r&t          | j                                                  S t          d|           )af  Implements unary negation for Literals with numeric values.

        Example:
            ```python
            # Negating an integer Literal
            -Literal(1)
            # rdflib.term.Literal('-1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # Negating a float Literal
            -Literal(10.5)
            # rdflib.term.Literal('-10.5', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#double'))

            # Using a string with a datatype
            from rdflib.namespace import XSD
            -Literal("1", datatype=XSD.integer)
            # rdflib.term.Literal('-1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # This will raise a TypeError
            -Literal("1")
            # TypeError: Not a number; rdflib.term.Literal('1')
            ```
        Not a number; )rM   rH   intr*   floatr   r   r
  r   s    r@   r   zLiteral.__neg__  sR    0 dj3	5"9:: 	74:--//0005T55666rA   c                    t          | j        t          t          t          f          r&t          | j                                                  S t          d|           )a  Implements unary plus operation for Literals with numeric values.

        Example:
            ```python
            # Applying unary plus to an integer Literal
            +Literal(1)
            # rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # Applying unary plus to a negative integer Literal
            +Literal(-1)
            # rdflib.term.Literal('-1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # Using a string with a datatype
            from rdflib.namespace import XSD
            +Literal("-1", datatype=XSD.integer)
            # rdflib.term.Literal('-1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # This will raise a TypeError
            +Literal("1")
            # TypeError: Not a number; rdflib.term.Literal('1')
            ```
        rU  )rM   rH   rV  r*   rW  r   __pos__r
  r   s    r@   rY  zLiteral.__pos__  sR    . dj3	5"9:: 	74:--//0005T55666rA   c                    t          | j        t          t          t          f          r&t          | j                                                  S t          d|           )a  Implements absolute value operation for Literals with numeric values.

        Example:
            ```python
            # Absolute value of a negative integer Literal
            abs(Literal(-1))
            # rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # Using a string with a datatype
            from rdflib.namespace import XSD
            abs(Literal("-1", datatype=XSD.integer))
            # rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # This will raise a TypeError
            abs(Literal("1"))
            # TypeError: Not a number; rdflib.term.Literal('1')
            ```
        rU  )rM   rH   rV  r*   rW  r   __abs__r
  r   s    r@   r[  zLiteral.__abs__:  sR    & dj3	5"9:: 	74:--//0005T55666rA   c                    t          | j        t          t          t          f          r&t          | j                                                  S t          d|           )a  Implements bitwise NOT operation for Literals with numeric values.

        Example:
            ```python
            # Bitwise NOT of a negative integer Literal
            ~(Literal(-1))
            # rdflib.term.Literal('0', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # Using a string with a datatype
            from rdflib.namespace import XSD
            ~(Literal("-1", datatype=XSD.integer))
            # rdflib.term.Literal('0', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

            # This will raise a TypeError
            ~(Literal("1"))
            # TypeError: Not a number; rdflib.term.Literal('1')
            ```
        rU  )rM   rH   rV  r*   rW  r   r   r
  r   s    r@   r   zLiteral.__invert__R  sR    & dj3	5"9:: 	74:00223335T55666rA   ri   c                N   |dS t          |t                    r| j        t          v r:|j        t          v r,| j        s%|j        s| j        |j        | j        |j        k    S t          j                            | j        t                    }t          j                            |j        t                    }||k    rt          j
        rt          S ||k    S | j        |j        k    r"| j        sdS |j        sdS | j        |j        k    S | j        |j        }t          | j                  t          v rAt          t          | j                           } || j                   ||j                  k    S 	 | j        |j        k    S # t          $ r Y nw xY wt!          |           t!          |          k    r t!          |           t!          |          k    S | j        |j        k    r"| j        dS |j        dS | j        |j        k    S dS t          |t"                    rdS t          S )aJ  Implements the greater-than comparison for Literals.

        This is the base method for ordering comparisons - other comparison methods delegate here.

        Implements the ordering rules described in http://www.w3.org/TR/sparql11-query/#modOrderBy

        In summary:
        1. Literals with compatible data-types are ordered in value space
        2. Incompatible datatypes are ordered by their datatype URIs
        3. Literals with language tags are ordered by their language tags
        4. Plain literals come before xsd:string literals
        5. In the node order: None < BNode < URIRef < Literal

        Example:
            ```python
            from rdflib import XSD
            from decimal import Decimal

            # Comparing numeric literals in value space
            Literal(1) > Literal(2)  # int/int
            # False

            Literal(2.0) > Literal(1)  # double/int
            # True

            Literal(Decimal("3.3")) > Literal(2.0)  # decimal/double
            # True

            Literal(Decimal("3.3")) < Literal(4.0)  # decimal/double
            # True

            # Comparing string literals
            Literal('b') > Literal('a')  # plain lit/plain lit
            # True

            Literal('b') > Literal('a', datatype=XSD.string)  # plain lit/xsd:str
            # True

            # Incompatible datatypes ordered by DT
            Literal(1) > Literal("2")  # int>string
            # False

            # Langtagged literals ordered by lang tag
            Literal("a", lang="en") > Literal("a", lang="fr")
            # False
            ```
        NTdefaultF)rM   r   r  r?  r  rH   r  r  r  rD  DAWG_LITERAL_COLLATIONry   r  ru   _TOTAL_ORDER_CASTERSr
  r:   r   )rZ   ri   dtselfdtothercasters        r@   rz   zLiteral.__gt__k  s.   ` =4eW%% <	"
 M%;;;*@@@. A38? A Z+0GzEK// [**4=+*NNFk++ENK+PPG  0 ,))!G++}..} : 5 :4=5>99z%%+*A
##';;;1$tz2B2BCF!6$*--u{0C0CCC:33    D 4yyCJJ&&4yy3u::-- }..=( 5^+4=5>995t$$ 	"4!!s   5F 
FFc                    |dS t          |t                    rD	 |                     |           o|                     |           S # t          $ r
 t
          cY S w xY wt          |t                    rdS t
          S r|   )rM   r   rz   rn   r
  ry   r   rm   s     r@   r}   zLiteral.__lt__  s    =5eW%% 	&&;;u---Ddggenn2DD & & &%%%%&eT"" 	5s   +A AAc                    |                      |          }|rdS 	 |                     |          S # t          $ r
 t          cY S w xY w)a%  Less than or equal operator for Literals.

        Example:
            ```python
            from rdflib.namespace import XSD
            Literal('2007-01-01T10:00:00', datatype=XSD.dateTime) <= Literal('2007-01-01T10:00:00', datatype=XSD.dateTime)
            # True
            ```
        T)r}   rn   r
  ry   r   s      r@   r   zLiteral.__le__  s^     KK 	4	"775>>! 	" 	" 	"!!!!	"   0 AAc                    |                      |          }|rdS 	 |                     |          S # t          $ r
 t          cY S w xY wr   )rz   rn   r
  ry   r   s      r@   r   zLiteral.__ge__  s\    KK 	4	"775>>! 	" 	" 	"!!!!	"rg  c                ~   t          |t                    r| j        6|j        /| j        t          vs|j        t          vr| j        |j        k    rdS nj| j        t          k    r|j        s|j        t          k    r	| j        sdS | j        pd                                |j        pd                                k    rdS dS )zVHelper method to decide which things are meaningful to rich-compare with this literal.NFr   T)rM   r   r  XSDToPythonrD  r  lowerrm   s     r@   _comparable_tozLiteral._comparable_to  s    eW%% 	!}(U^-G M44~[88 }66$u 44U^4Nk11$-1 5 M'R..00U^5Ir4P4P4R4RRR 5trA   rV  c                    t                               |           }| j        r)|t          | j                                                  z  }| j        |t          | j                  z  }|S )an  Hash function for Literals to enable their use as dictionary keys.

        Example:
            ```python
            from rdflib.namespace import XSD
            a = {Literal('1', datatype=XSD.integer):'one'}
            Literal('1', datatype=XSD.double) in a
            # False
            ```

        Notes:
            "Called for the key object for dictionary operations,
            and by the built-in function hash(). Should return
            a 32-bit integer usable as a hash value for
            dictionary operations. The only required property
            is that objects which compare equal have the same
            hash value; it is advised to somehow mix together
            (e.g., using exclusive or) the hash values for the
            components of the object that also play a part in
            comparison of objects." -- 3.4.1 Basic customization (Python)

            "Two literals are equal if and only if all of the following hold:
            * The strings of the two lexical forms compare equal, character by character.
            * Either both or neither have language tags.
            * The language tags, if any, compare equal.
            * Either both or neither have datatype URIs.
            * The two datatype URIs, if any, compare equal, character by character."
            -- 6.5.1 Literal Equality (RDF: Concepts and Abstract Syntax)
        )r:   r   r   hashrk  r   )rZ   ress     r@   r   zLiteral.__hash__!  s`    > ll4  > 	04,,..///C>%4'''C
rA   c                &   | |u rdS |dS t          |t                    rq| j        |j        k    o`| j        r| j                                        nd|j        r|j                                        ndk    ot
                              | |          S dS )a  Equality operator for Literals.

        Literals are only equal to other literals.

        Notes:
            "Two literals are equal if and only if all of the following hold:
            * The strings of the two lexical forms compare equal, character by character.
            * Either both or neither have language tags.
            * The language tags, if any, compare equal.
            * Either both or neither have datatype URIs.
            * The two datatype URIs, if any, compare equal, character by character."
            -- 6.5.1 Literal Equality (RDF: Concepts and Abstract Syntax)

        Example:
            ```python
            Literal("1", datatype=URIRef("foo")) == Literal("1", datatype=URIRef("foo"))
            # True
            Literal("1", datatype=URIRef("foo")) == Literal("1", datatype=URIRef("foo2"))
            # False

            Literal("1", datatype=URIRef("foo")) == Literal("2", datatype=URIRef("foo"))
            # False
            Literal("1", datatype=URIRef("foo")) == "asdf"
            # False

            from rdflib import XSD
            Literal('2007-01-01', datatype=XSD.date) == Literal('2007-01-01', datatype=XSD.date)
            # True
            Literal('2007-01-01', datatype=XSD.date) == date(2007, 1, 1)
            # False

            Literal("one", lang="en") == Literal("one", lang="en")
            # True
            Literal("hast", lang='en') == Literal("hast", lang='de')
            # False

            Literal("1", datatype=XSD.integer) == Literal(1)
            # True
            Literal("1", datatype=XSD.integer) == Literal("01", datatype=XSD.integer)
            # True
            ```
        TNF)rM   r   r   r   rk  r:   rl   rm   s     r@   rl   zLiteral.__eq__H  s    V 5==4=5eW%% 	%/1 ,/3~GT^))+++4/4HEO))+++DJ, JJtU++	 urA   c                @   t          |t                    r*| j        t          v rz|j        t          v rl| j        se|j        s^| j        W|j        P| j        |j        | j        |j        k    S t                              | |          rdS t          d|  d|           | j	        pd
                                |j	        pd
                                k    rdS t          j                            | j        t                    }t          j                            |j        t                    }|t          k    r&|t          k    rt                              | |          S |t          v rC|t          v r:| j        dur1|j        dur(| j        !|j        t!          | j        |j                  S ||k    r-t          j        rt          d| j         d|j                   dS | j        |j        | j        |j        k    S t                              | |          rdS | j        t          k    rdS t          d|  d|           t          |t$                    rdS t          |t                    r4| j	        dS | j        t          k    s| j        t          |           |k    S nt          |t&          t(          t*          f          r| j        t          v r| j        |k    S nt          |t,          t.          t0          f          r'| j        t2          t4          t6          fv r| j        |k    S nst          |t8          t:          f          r'| j        t<          t>          t@          fv r| j        |k    S n0t          |tB                    r| j        tD          k    r| j        |k    S tF          S )	a  Compare the value of this literal with something else.

        This comparison can be done in two ways:

        1. With the value of another literal - comparisons are then done in literal "value space"
            according to the rules of XSD subtype-substitution/type-promotion

        2. With a Python object:
           * string objects can be compared with plain-literals or those with datatype xsd:string
           * bool objects with xsd:boolean
           * int, long or float with numeric xsd types
           * date, time, datetime objects with xsd:date, xsd:time, xsd:datetime

        Any other operations returns NotImplemented.
        NTzII cannot know that these two lexical forms do not map to the same value: z and r   Fr^  z4I don't know how to compare literals with datatypes )$rM   r   r  r?  r  rH   r:   rl   r
  r  rk  r  r  r  rD  _XML_COMPARABLE_isEqualXMLNoder`  r   rV  r*   rW  r   r   r   r9  r:  r<  r   r,   rO  _XSD_DAYTIMEDURATION_XSD_YEARMONTHDURATIONr<   _XSD_BOOLEANry   )rZ   ri   rb  rc  s       r@   rn   z
Literal.eq  s     eW%% b	+
 M%;;;*@@@. A38? A Z+0G:)ek.E:44zz$.. $#t#:'+: :27: :  
 #**,,1E20L0L0N0NNNu[**4=+*NNFk++ENK+PPG$$K)?)?zz$... ?**w//I/I .,,5?$3N3NZ+0G&tz5;???  0 !#st}sschcqss   !5 z%%+*AzU[00::dE**  4=K// 5  1"1 1).1 1   t$$ 	+5s## 	+ }(u}++t}/D4yyE)) 0E Y677 	+} 666zU** 7h566 	+}	9 EEEzU** F	8455 
	+}$&!  
 zU** t$$ 	+},,zU**rA   c                .    |                      |           S rD   )rn   rm   s     r@   rr   zLiteral.neq  s    775>>!!rA   rV   rW   r:   c                d    |r|                      |j                  S |                                  S )a  Returns a representation in the N3 format.

        ```python
        >>> Literal("foo").n3()
        '"foo"'

        ```

        Strings with newlines or triple-quotes:

        ```python
        >>> Literal("foo\nbar").n3()
        '"""foo\nbar"""'
        >>> Literal("''\'").n3()
        '"\'\'\'"'
        >>> Literal('"""').n3()
        '"\\"\\"\\""'

        ```

        Language:

        ```python
        >>> Literal("hello", lang="en").n3()
        '"hello"@en'

        ```

        Datatypes:

        ```python
        >>> Literal(1).n3()
        '"1"^^<http://www.w3.org/2001/XMLSchema#integer>'
        >>> Literal(1.0).n3()
        '"1.0"^^<http://www.w3.org/2001/XMLSchema#double>'
        >>> Literal(True).n3()
        '"true"^^<http://www.w3.org/2001/XMLSchema#boolean>'

        ```

        Datatype and language isn't allowed (datatype takes precedence):

        ```python
        >>> Literal(1, lang="en").n3()
        '"1"^^<http://www.w3.org/2001/XMLSchema#integer>'

        ```

        Custom datatype:

        ```python
        >>> footype = URIRef("http://example.org/ns#foo")
        >>> Literal("1", datatype=footype).n3()
        '"1"^^<http://example.org/ns#foo>'

        ```

        Passing a namespace-manager will use it to abbreviate datatype URIs:

        ```python
        >>> from rdflib import Graph
        >>> Literal(1).n3(Graph().namespace_manager)
        '"1"^^xsd:integer'

        ```
        )qname_callback)_literal_n3r   rY   s     r@   r[   z
Literal.n3  s:    F  	&##3D3Q#RRR##%%%rA   F	use_plainry  +Optional[Callable[[URIRef], Optional[str]]]c                (   |r| j         t          v r	| j        | j         t          v ru	 t	          |           }t          j        |          st          j        |          r|                     d|          S n&# t          $ r |                     d|          cY S w xY w| j         t          k    r t          ddt	          |           d          S | j         t          k    r|  }d|vrd|vr	d|vr|dz  }|S | j         t          k    r|                                  S |  S |                                 }| j         }d}||r ||          }|sd| d	}|t          v r	 t	          |           }t          j        |          r*|                    d
d                              dd          }t          j        |          r|                    dd          }n'# t          $ r t#          j        d|            Y nw xY w| j        }|r| d| S |r| d| S |S )a{  Internal method for N3 serialization with more options.

        Args:
            use_plain: Whether to use plain literal (shorthand) output
            qname_callback: Function to convert URIs to prefixed names

        Example:
            Using plain literal (shorthand) output:

            ```python
            >>> from rdflib.namespace import XSD

            >>> Literal(1)._literal_n3(use_plain=True)
            '1'

            >>> Literal(1.0)._literal_n3(use_plain=True)
            '1e+00'

            >>> Literal(1.0, datatype=XSD.decimal)._literal_n3(use_plain=True)
            '1.0'

            >>> Literal(1.0, datatype=XSD.float)._literal_n3(use_plain=True)
            '"1.0"^^<http://www.w3.org/2001/XMLSchema#float>'

            >>> Literal("foo", datatype=XSD.string)._literal_n3(use_plain=True)
            '"foo"^^<http://www.w3.org/2001/XMLSchema#string>'

            >>> Literal(True)._literal_n3(use_plain=True)
            'true'

            >>> Literal(False)._literal_n3(use_plain=True)
            'false'

            >>> Literal(1.91)._literal_n3(use_plain=True)
            '1.91e+00'

            ```

            Only limited precision available for floats:

            ```python
            >>> Literal(0.123456789)._literal_n3(use_plain=True)
            '1.234568e-01'

            >>> Literal('0.123456789', datatype=XSD.decimal)._literal_n3(use_plain=True)
            '0.123456789'

            ```

            Using callback for datatype QNames:

            ```python
            >>> Literal(1)._literal_n3(qname_callback=lambda uri: "xsd:integer")
            '"1"^^xsd:integer'

            ```
        NFz\.?0*eer8  Ez.0r   r   infINFInfinitynanNaNzSerializing weird numerical @z^^)r  _PLAIN_LITERAL_TYPESrH   _NUMERIC_INF_NAN_LITERAL_TYPESrW  mathisinfisnanrz  r  _XSD_DOUBLEr   rB  rv  rk  _quote_encodereplacewarningswarnr  )	rZ   r{  ry  vrK  encodedr  	quoted_dtr  s	            r@   rz  zLiteral._literal_n3C  s   |  	%*>>>z% =$BBBG!$KK:a== KDJqMM K#'#3#3E>#J#JJK% G G G#//~FFFFFG =K//y#%++/A/ABBB]l22	A!||1AT	H]l22"9??,,,"9$))++=	 5*N844	 ,+OOO	999KdAz!}}  #*//%"?"?"G"G&# # z!}} @")//%"?"?! K K K M"I"I"IJJJJJK
 = 	***** 	,,,,,Ns%   AA8 8 BBA7G !G65G6c                   d| v rq|                      dd          }d| v r|                     dd          }|d         dk    r|d         dk    r|d d         dz   dz   }d	|                     d
d          z  S d|                      dd                               dd                               dd                               d
d          z  S )N
\z\\z"""z\"\"\"r   z"""%s"""z\rz"%s"z\nz\")r  )rZ   r  s     r@   r  zLiteral._quote_encode  s     4<<ll400G}}!//%==r{c!!gbkT&9&9!#2#,-3 e < <<<DLLu55==dFKKSSU gdE""# #rA   c                p   t                               |           g}| j        *|                    dt	          | j                  z              | j        *|                    dt	          | j                  z              | j        t          k    rd}n| j        j        }| dd	                    |           dS )Nzlang=z	datatype=zrdflib.term.Literalr   z, r   )
r:   r   r  appendreprr  r   r   r]   join)rZ   argsr   s      r@   r   zLiteral.__repr__  s    T""#=$KK$t}"5"55666=$KKd4=&9&99:::>W$$+GGn-G..DIIdOO....rA   c                "    | j         | j         S | S )zV
        Returns an appropriate python datatype derived from this RDF Literal
        r   r   s    r@   r   zLiteral.toPython  s    
 :!:rA   )NNN)r  r   r  r   r  r   r  r   )r;   r   )r;   r   )r;   r   )r;   r   )r;   r   )r;   r$  )r;   r&  )r*  r+  r;   r,  )r1  r   r;   r   )r;   r<   r   )r;   rV  rD   r\   )FN)r{  r<   ry  r|  r;   r:   r   )%r]   r^   r_   r`   r   ra   rf   r  r   r  rH   r  r  r   r)  r0  r   rQ  rS  r   rY  r[  r   rz   r}   r   r   rl  r   rl   rn   rr   r[   rz  r  r   r   rU   rA   r@   r   r     s1        j jX KKKBI
 #"&$(V V V V Vp   4 
 
 
 X
    X    X    X
 
 
 
L L L L' ' ' '
iD iD iD iDVo o o ob   7 7 7 7:7 7 7 787 7 7 707 7 7 72n" n" n" n"`   " " " "$" " " "   <% % % %N8 8 8 8tt t t tl" " " "F& F& F& F& F&T  FJx x x x xt# # # #6
/ 
/ 
/ 
/     rA   r   	xmlstringxml.dom.minidom.Documentc                ~    t           j        j                            d|  d          }|                                 |S )Nz<rdflibtoplevelelement>z</rdflibtoplevelelement>)xmldomminidomparseStringr  )r  r   s     r@   	_parseXMLr    sB    W_((E)EEE F MrA   lexical_form xml.dom.minidom.DocumentFragmentc                8   t          j        t           j                            d          d          }	 |                    |           }n;# t           j        j        $ r$}t                              d|            |d}~ww xY w|	                                 |S )ai  
    Parse the lexical form of an HTML literal into a document fragment
    using the `dom` from html5rdf tree builder.

    Args:
        lexical_form: The lexical form of the HTML literal.

    Returns:
        A document fragment representing the HTML literal.

    Raises:
        html5rdf.html5parser.ParseError: If the lexical form is not valid HTML.
    r  T)treestrictzFailed to parse HTML: N)
html5rdf
HTMLParsertreebuildersgetTreeBuilderparseFragmenthtml5parser
ParseErrorr   infor  )r  parserresultr~  s       r@   _parse_htmlr    s      "11%88  F393G3G3U3U*   0Q00111 Ms   A BA>>BrN   c                2    t          j        | d          }|S )z
    Serialize a document fragment representing an HTML literal into
    its lexical form.

    Args:
        value: A document fragment representing an HTML literal.

    Returns:
        The lexical form of the HTML literal.
    r  )r  )r  	serialize)rH   r  s     r@   _write_htmlr    s     E222FMrA   xmlnodeAUnion[xml.dom.minidom.Document, xml.dom.minidom.DocumentFragment]c                x   t          | t          j        j        j                  r:t          j        j                                        }|xj        | j        z  c_        |} |                     d          }|                    d          r
|dd          }|                    d          r
|dd         }|dk    rd}|S )	NrL   s&   <?xml version="1.0" encoding="utf-8"?>&   s   <rdflibtoplevelelement>   is   <rdflibtoplevelelement/>rA   )	rM   r  r  r  DocumentFragmentDocument
childNodestoxmlr   )r  r/  rK  s      r@   	_writeXMLr    s     '37?;<< GO$$&&	**gA 	||=>> bccF||.// bfI'''HrA   Union[str, bytes, Literal]c                r    t          | t                    r|                                 } t          |           S rD   )rM   r:   encoder   r   s    r@   
_unhexlifyr  3  s/    % UrA   c                    g d}g d}|                                  }||v rdS ||vrt          j        d| dt                     dS )   
    Boolean is a datatype with value space {true,false},
    lexical space {"true", "false","1","0"} and
    lexical-to-value mapping {"true"→true, "false"→false, "1"→true, "0"→false}.
    )1true   1   true)r7  false   0   falseTzParsing weird boolean, z does not map to True or False)categoryF)rk  r  r  UserWarning)rH   true_accepted_valuesfalse_accepted_values	new_values       r@   _parseBooleanr  :  sw     877:::I(((t---MeMMM 	
 	
 	
 	
 5rA   lexicalr   c                
    |duS )aN  
    This function is used as the fallback for detecting ill-typed/ill-formed
    literals and operates on the asumption that if a value (i.e.
    `Literal.value`) could be determined for a Literal then it is not
    ill-typed/ill-formed.

    This function will be called with `Literal.lexical` and `Literal.value` as arguments.
    NrU   r  rH   s     r@   r  r  M  s     rA   c                ^    t          |           dk    ot          |t                    o|dk    S )zG
    xsd:unsignedInteger and xsd:unsignedLong must not be negative
    r   )r   rM   r*   r  s     r@   _well_formed_unsignedlongr  Y  s-     w<<!K
5) < <K!KrA   c                
    | dv S )r  )r  r  r  r  r  r  r7  r  rU   r  s     r@   _well_formed_booleanr  `  s     PPPrA   c                r    t          |           dk    o$t          |t                    od|cxk    odk    nc S )z
    The value space of xs:int is the set of common single size integers (32 bits),
    i.e., the integers between -2147483648 and 2147483647,
    its lexical space allows any number of insignificant leading zeros.
    r   i   ir   rM   rV  r  s     r@   _well_formed_intr  i  sM     	Gq 	1uc""	1E////Z////rA   c                r    t          |           dk    o$t          |t                    od|cxk    odk    nc S )zG
    xsd:unsignedInt has a 32bit value of between 0 and 4294967295
    r   l    r  r  s     r@   _well_formed_unsignedintr  v  sE     w<<!U
5# 6 6UA<T<T<T<T*<T<T<T<TUrA   c                r    t          |           dk    o$t          |t                    od|cxk    odk    nc S )z
    The value space of xs:short is the set of common short integers (16 bits),
    i.e., the integers between -32768 and 32767,
    its lexical space allows any number of insignificant leading zeros.
    r   i i  r  r  s     r@   _well_formed_shortr  }  sE     w<<!U
5# 6 6UFe<T<T<T<Tu<T<T<T<TUrA   c                r    t          |           dk    o$t          |t                    od|cxk    odk    nc S )zD
    xsd:unsignedShort has a 16bit value of between 0 and 65535
    r   i  r  r  s     r@   _well_formed_unsignedshortr    sE     w<<!P
5# 6 6PA<O<O<O<O%<O<O<O<OPrA   c                r    t          |           dk    o$t          |t                    od|cxk    odk    nc S )z
    The value space of xs:byte is the set of common single byte integers (8 bits),
    i.e., the integers between -128 and 127,
    its lexical space allows any number of insignificant leading zeros.
    r   i   r  r  s     r@   _well_formed_byter    sE     w<<!Q
5# 6 6QDE<P<P<P<PS<P<P<P<PQrA   c                r    t          |           dk    o$t          |t                    od|cxk    odk    nc S )z@
    xsd:unsignedByte has a 8bit value of between 0 and 255
    r      r  r  s     r@   _well_formed_unsignedbyter    sE     w<<!N
5# 6 6NA<M<M<M<M#<M<M<M<MNrA   c                8    t          |t                    o|dk    S Nr   rM   rV  r  s     r@   !_well_formed_non_negative_integerr        eS!!0eqj0rA   c                8    t          |t                    o|dk    S r  r  r  s     r@   _well_formed_positive_integerr        eS!!/eai/rA   c                8    t          |t                    o|dk    S r  r  r  s     r@   !_well_formed_non_positive_integerr    r  rA   c                8    t          |t                    o|dk     S r  r  r  s     r@   _well_formed_negative_integerr    r  rA   z!http://www.w3.org/2001/XMLSchema#z+http://www.w3.org/1999/02/22-rdf-syntax-ns#
XMLLiteralHTMLstringnormalizedStringtokenrW  doubledecimalintegerbooleandateTimer   r   rF  dayTimeDurationyearMonthDurationz&http://www.w3.org/2002/07/owl#rationalbase64Binary	hexBinarygYear
gYearMonthbyterV  longnegativeIntegernonNegativeIntegernonPositiveIntegerpositiveIntegershortunsignedByteunsignedIntunsignedLongunsignedShortzTuple[URIRef, ...]r?  r  r  _DATE_AND_TIME_TYPESr;  r>  c                P    | j         d uo| j                             |           d u| fS rD   tzinfo	utcoffsetr   s    r@   <lambda>r    s0    D NU\%;%;E%B%B$%N rA   c                P    | j         d uo| j                             d           d u| fS rD   r  r   s    r@   r  r  	  s0    D MU\%;%;D%A%A%M rA   c                *    |                                  S rD   )r  r   s    r@   r  r    s    EKKMM rA   z%Dict[Type[Any], Callable[[Any], Any]]ra  rC  _StrT)boundobjpTypecastFuncOptional[Callable[[Any], Any]]dTypeOptional[_StrT]Tuple[Any, Optional[_StrT]]c                4    | ||           |fS || |fS | d fS rD   rU   )r  r  r   r"  s       r@   _py2literalr&    s7     x}}e##		EzDyrA   r  r   Tuple[Any, Optional[str]]c                    t           D ]2\  \  }}}t          | |          r||k    rt          | |||          c S 3t          D ],\  }\  }}t          | |          rt          | |||          c S -| dfS )z
    Casts a tuple of a python type and a special datatype URI to a tuple of the lexical value and a
    datatype URI (or None)
    N)_SpecificPythonToXSDRulesrM   r&  _GenericPythonToXSDRules)r  r  r  r"  r   s        r@   r  r  +  s     %> < < c5!! 	<ex&7&7sE8U;;;;;$< < <  %c5!! 	<sE8U;;;;;	<9rA   r   c                D    t          |                                           S rD   )r:   rk  is    r@   r  r  N  s    c!ffllnn rA   c                
    | dS )Nr6  rU   r,  s    r@   r  r  Q  s
    A rA   c                *    |                                  S rD   	isoformatr,  s    r@   r  r  R  s    !++-- rA   c                *    |                                  S rD   r0  r,  s    r@   r  r  S      akkmm rA   c                *    |                                  S rD   r0  r,  s    r@   r  r  T  r3  rA   c                     t          |           S rD   r-   r,  s    r@   r  r  U  s    ,Q// rA   c                     t          |           S rD   r6  r,  s    r@   r  r  V  s    -a00 rA   zZList[Tuple[Type[Any], Tuple[Optional[Callable[[Any], Union[str, bytes]]], Optional[str]]]]r*  c                R    |                      d                              d          S )Nz%Y   strftimezfillr1  s    r@   r  r  l  s     S\\$%7%7%=%=a%@%@ rA   c                R    |                      d                              d          S )Nz%Y-%m   r:  r=  s    r@   r  r  m  s     #,,w*?*?*E*Ea*H*H rA   zPList[Tuple[Tuple[Type[Any], str], Optional[Callable[[Any], Union[str, bytes]]]]]r)  r  anyURIz3Dict[Optional[str], Optional[Callable[[str], Any]]]rj  rr  z6Dict[URIRef, Callable[[Union[str, bytes], Any], bool]]r  r  r,  c                 V   t                                            t                               t                     t                                           t                              t                     t                                           t                              t                     dS )z2Reset lexical<->value space binding for `Literal`.N)	r  clearupdaterj  r*  extend _OriginalGenericPythonToXSDRulesr)  !_OriginalSpecificPythonToXSDRulesrU   rA   r@   _reset_bindingsrG    s|    K(((""$$$##$DEEE##%%%$$%FGGGGGrA   r   c                $   	 t           |         }n# t          $ r Y dS w xY w|?	  ||           S # t          $ r& t                              d| d| d           Y dS w xY w	 t          |           S # t          $ r t          | d          cY S w xY w)zMap a lexical form to the value-space for the given datatype.

    Returns:
        A python object for the value or `None`
    Nz:Failed to convert Literal lexical form to value. Datatype=z, Converter=T)exc_inforL   )r  KeyErrorr   r   r   r:   r   )r  r  	conv_funcs      r@   r  r    s    $X.		   tt 	 9W%%% 	 	 	NNnXnnclnn    
 44		)w<<! 	) 	) 	) w(((((		)s-    

/ ,AA#A2 2BB_AnyTr  c                    t          | t                    r>|                     dd                              dd                              dd          S | S )zxReplaces \t, \n, \r (#x9 (tab), #xA (linefeed), and #xD (carriage return)) with space without any whitespace collapsing.	 r  r  )rM   r:   r  r  s    r@   r  r    sU    "C(( Y  ''c22::4EEMMdTWXXXrA   c                    t          | t                    r(t          j        dd|                                           S | S )Nz +rO  )rM   r:   rer   striprP  s    r@   r  r    s>    "C(( ; vdC!1!7!7!9!9:::rA   
pythontype	Type[Any]constructorOptional[Callable[[str], Any]]lexicalizer,Optional[Callable[[Any], Union[str, bytes]]]datatype_specificc                   |r| t          d          | t          v rt                              d|  d           ||}|t          | <   |r t                              || f|f           dS t                              ||| ff           dS )a6  
    register a new datatype<->pythontype binding

    Args:
        constructor: An optional function for converting lexical forms
            into a Python instances, if not given the pythontype
            is used directly
        lexicalizer: An optional function for converting python objects to
            lexical form, if not given object.__str__ is used
        datatype_specific: Makes the lexicalizer function be accessible
            from the pair (pythontype, datatype) if set to True
            or from the pythontype otherwise. False by default
    Nz1No datatype given for a datatype-specific bindingz
datatype 'z' was already bound. Rebinding.)r   r  r   r   r)  r  r*  )r  rT  rV  rX  rZ  s        r@   r   r     s    (  MX-KLLL###MHMMMNNN !,X O!((:x*@+)NOOOOO ''k85L(MNNNNNrA   c                  @    e Zd ZdZdZddZddZddZdddZddZ	d	S )r   zo
    A Variable - this is used for querying, or in Formula aware
    graphs, where Variables can be stored
    rU   rH   r:   c                    t          |          dk    rt          d          |d         dk    r
|dd          }t                              | |          S )Nr   z7Attempted to create variable with empty string as name!?r+   )r   r   r:   rf   rg   s     r@   rf   zVariable.__new__)	  sN    u::??UVVV8s??!""IE{{3&&&rA   r;   c                |    | j         t          u rd}n| j         j        }| dt                              |            dS )Nzrdflib.term.Variabler   r   )r   r   r]   r:   r   r   s     r@   r   zVariable.__repr__0	  sC    >X%%,GGn-G11CLL..1111rA   c                    d| z   S Nr^  rU   r   s    r@   r   zVariable.toPython8	      TzrA   NrV   rW   c                    d| z   S ra  rU   rY   s     r@   r[   zVariable.n3;	  rb  rA   !Tuple[Type[Variable], Tuple[str]]c                0    t           t          |           ffS rD   )r   r:   r   s    r@   r   zVariable.__reduce__>	  s    3t99,''rA   r   r   rD   r\   )r;   rd  )
r]   r^   r_   r`   ra   rf   r   r   r[   r   rU   rA   r@   r   r   !	  s         
 I' ' ' '2 2 2 2       ( ( ( ( ( (rA   r   zDict[Type[Node], int]rx   
         (   node  Union[None, xml.dom.minidom.Attr, xml.dom.minidom.Comment, xml.dom.minidom.Document, xml.dom.minidom.DocumentFragment, xml.dom.minidom.DocumentType, xml.dom.minidom.Element, xml.dom.minidom.Entity, xml.dom.minidom.Notation, xml.dom.minidom.ProcessingInstruction, xml.dom.minidom.Text]ri   c                    ddl m}  fd} dS  j        j        k    rdS  j        |j        |j        fv r
 |            S  j        |j        k    r9t          rLt           t          j	        j
        j                  sJ t          t          j	        j
        j                  sJ  j        j        k    r j        j        k    sdS d  j                                        D             }d j                                        D             }t!          |          t!          |          k    rdS |D ]O}||v rF                     |d         |d                                       |d         |d                   k    s dS P |            S  j        |j        |j        |j        |j        fv rt          rt           t          j	        j
        j        t          j	        j
        j        t          j	        j
        j        t          j	        j
        j        f          sJ t          t          j	        j
        j        t          j	        j
        j        t          j	        j
        j        t          j	        j
        j        f          sJ  j        j        k    S  j        |j        k    rst          rLt           t          j	        j
        j                  sJ t          t          j	        j
        j                  sJ  j        j        k    o j        j        k    S  j        |j        k    r j        j        k    S  j        |j         k    rst          rLt           t          j	        j
        j!                  sJ t          t          j	        j
        j!                  sJ  j"        j"        k    o j#        j#        k    S tI          d j                   )	Nr   )r   c                     t          j                  t          j                  k    rdS t          d j        j                  D ]\  } }t          | |          s dS dS )NFc                
    | |fS rD   rU   )xys     r@   r  z2_isEqualXMLNode.<locals>.recurse.<locals>.<lambda>t	  s
    1v rA   T)r   r  maprs  )ncocrj  ri   s     r@   recursez _isEqualXMLNode.<locals>.recursej	  sw     t3u'7#8#8885--t@PQQ 	 	FB"2r** uu trA   Fc                *    g | ]}|d          dk    |S r   zhttp://www.w3.org/2000/xmlns/rU   .0ks     r@   
<listcomp>z#_isEqualXMLNode.<locals>.<listcomp>	  2     
 
 
t666 666rA   c                *    g | ]}|d          dk    |S rv  rU   rw  s     r@   rz  z#_isEqualXMLNode.<locals>.<listcomp>	  r{  rA   r+   z*I dont know how to compare XML Node type: )%xml.dom.minidomr   nodeTypeDOCUMENT_NODEDOCUMENT_FRAGMENT_NODEELEMENT_NODEr   rM   r  r  r  ElementtagNamenamespaceURI
attributeskeysNSr   getAttributeNS	TEXT_NODECOMMENT_NODECDATA_SECTION_NODENOTATION_NODETextCommentCDATASectionNotationdataPROCESSING_INSTRUCTION_NODEProcessingInstructiontargetENTITY_NODE	nodeValueDOCUMENT_TYPE_NODEDocumentTypepublicIdsystemIdr   )rj  ri   XMLNodert  n_keyso_keysry  s   ``     r@   rs  rs  J	  s   < 0/////       |u}u}&&u}.0NOOOwyy	'.	.	. 	>dCGO$;<<<<<eSW_%<===== LEM))d.?5CU.U.U5
 
_++--
 
 


 
%,,..
 
 

 v;;#f++%%5 	 	AV''!ad33u7K7KAaDRSTURV7W7WWWuu X wyy	"	 
 
  	GO(GO+GO0GO,	     GO(GO+GO0GO,	     yEJ&&	'=	=	= 	LdCGO$IJJJJJeSW_%JKKKKKyEJ&F4;%,+FF	'-	-	-~00	'4	4	4 	CdCGO$@AAAAAeSW_%ABBBBB}.R4=EN3RR TT]TTUUUrA   )r9   r:   r;   r<   )rB   r:   r;   r<   )rH   rI   r;   r<   r   )r  r:   r;   r  )r  r:   r;   r  )rH   r  r;   rN   )r  r  r;   rN   )rH   r  r;   rN   )r  rI   rH   r   r;   r<   )
r  r   r  r   r   r!  r"  r#  r;   r$  )r  r   r  r   r;   r'  )r;   r,  )r  rI   r  r   r;   r   )r  rL  r;   rL  )NNF)r  r:   rT  rU  rV  rW  rX  rY  rZ  r<   r;   r,  )rj  rk  ri   rk  r;   r<   )r`   
__future__r   rb   rR  	fractionsr   __all__loggingr  r  r}  r  base64r   r   binasciir   r   collectionsr   r   r   r   r   r  r   r   r   typesr   typingr   r   r   r   r   r    r!   r"   r#   r$   r%   urllib.parser&   r'   r(   uuidr)   r  rdflib.utilrdflib.compatr*   xsd_datetimer,   r-   r.   r/   r0   r1   	namespacer2   pathsr3   r4   r5   r6   r7   _HAS_HTML5RDFr  ImportErrorr   	getLoggerr]   r   r   r   r8   r   r>   r   rE   rG   rS   ABCr   r:   r	   r   r
   r   r   r   r   r   r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  _XSD_PFX_RDF_PFX_RDF_XMLLITERAL_RDF_HTMLLITERALrD  r  r  
_XSD_FLOATr  rB  _XSD_INTEGERrv  r9  r:  r<  rO  rt  ru  _OWL_RATIONAL_XSD_B64BINARY_XSD_HEXBINARY
_XSD_GYEAR_XSD_GYEARMONTHr?  r  r  r  r;  r>  r  r  r  ra  rC  r  r&  r  rW  r<   rV  r*  r  r  listrE  rN   r)  rF  rj  rr  r  r  rC  rG  r  rL  r  r  r   r   rx   rs  rU   rA   r@   <module>r     s{    , # " " " " " 



 				      
 
 
        ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' # # # # # # 4 4 4 4 4 4 4 4 4 4 4 4                                              6 5 5 5 5 5 5 5 5 5            # # # # # #                 Q++++++PPPPPPPPPPPPPPOOOMM   HHH 7 		8	$	$$2      #     '9::, , , ,   $S S S S S37 S S Sc c c c cs c c cL    Z   &y= y= y= y= y=^ y= y= y=x    F       %   (
 
 
 
U2 U2 U2 U2 U2N U2 U2 U2p^ ^ ^ ^ ^j ^ ^ ^B'      4      (      &	 	 	 	L L L LQ Q Q Q
 
 
 
V V V VV V V VQ Q Q QR R R RO O O O1 1 1 10 0 0 01 1 1 10 0 0 0
 /8&L0116(V+,, fX())+= =>> VHw&''
VHw&''
fX())vh*++vh*++vh*++x*,--F8f$%%	F8f$%%	x*,--vh)::;; +> >?? ?@@>122;.//VHw&''
&L011 
F8g
F8f
F8e
F8f
F8''((
F8**++
F8**++
F8''((
F8g
F8n$%%
F8m#$$
F8n$%%
F8o%&&!.     * ,      F8g6      ,      )     
 0DFW/W  W W W W   
 	  
 GO99?       
F8(())
F8g-      	s###      B 	,
T; 	$$l344
|$%!!<01''78	##Y/0	##Y/0//?@002FGHW_	?;<m$%     $  ##		)K9I+JK   $(4(@#A#A  
 J@@A
OHHI	>G$^g&	>I&^i(  	 	 	 	 %)D)B$C$C !!D$!D
F8fz!D F8f~!D F8j !!>	!D
 F8j !!#5!D F8''((*<!D F8))**,>!D F8k!""J!D F8h!D F8(())4!D F8g!D F8j !!4!D F8i  -!D F8i  '!D F8i  )!D  F8**++Y!!D" F8fy#!D$ F8**++Y
F8''(()
F8ec
F8n$%%y
F8''(()
F8g
F8m#$$c
F8fs
F8o%&&
F8n$%%s
F8g
F8h
F8n$%%y
F8hYA!D !D ! ! ! !F  %0K !+:<L*MOMMMMM&(O F8i  "6
F8**++-N
F8**++-N
F8''((*G
F8''((*G
F8e.
F8g 2
F8f0
F8m#$$&>
F8n$%%'@
F8o%&&(B
F8n$%%'@T      IK  J J J J    $ $ $	H 	H 	H 	H%) %) %) %)P 	s###       37@D# O  O  O  O  OF( ( ( ( (z ( ( (J $/;s#3#3	 3 3 3 3 	  %Xr62wC D D DKV KV KV KV KV KVs   C
 
CC