
    i\                      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;m<Z<m=Z= e rddl>m?Z? ddl@mAZAmBZBmCZCmDZDmEZE dZF	 ddlGZGdZFdZI ej                  eK      ZLdZMdZNi ZOdePd<   dZQddZR ed      ZSddZTdd ZU G d! d"ej                        ZW G d# d$eWeX      ZY G d% d&eY      ZZ G d' d(eZ      Z[ G d) d*e[      Z\ G d+ d,e\      Z]dd-Z^ G d. d/eZ      Z_ G d0 d1eY      Z`dd2Zadd3Zbdd4Zc	 	 	 	 dd5Zddd6Zedd7Zfdd8Zgdd9Zhdd:Zidd;Zjdd<Zkdd=Zldd>Zmdd?Zndd@ZoddAZpddBZqddCZrddDZsdEZtdFZu e[eudGz         Zv e[eudHz         Zw e[etdIz         Zx e[etdJz         Zy e[etdKz         Zz e[etdLz         Z{ e[etdMz         Z| e[etdNz         Z} e[etdOz         Z~ e[etdPz         Z e[etdQz         Z e[etdRz         Z e[etdSz         Z e[etdTz         Z e[etdUz         Z e[etdVz         Z e[dW      Z e[etdXz         Z e[etdYz         Z e[etdZz         Z e[etd[z         Ze~e}e| e[etdLz          e[etd\z          e[etd]z          e[etd^z          e[etd_z          e[etd`z          e[etdaz          e[etdbz          e[etdcz          e[etddz          e[etdez          e[etdfz          e[etdgz         fZdhePdi<   e~ee|e}efZdhePdj<    e[etdLz         e|e}fZdhePdk<   eeefZdhePdl<   eefZdhePdm<   eez   ZdhePdn<   edo edp ej"                  j$                  j&                  dq iZdrePds<   exevew e[etdJz          e[etdKz         fZdhePdt<    e)dueXv      Z	 	 	 	 	 	 	 	 	 	 ddwZ	 	 	 	 	 	 ddxZeXdyfede|ffedz effede~ffe4de~ffed{ e}ffed| effed} effed~ effe6d effed effej"                  j$                  j&                  edevffedeffgZdePd<   eG7ej;                  ej"                  j$                  j<                  ecewff        ee      Zeefd feefd feXefefeefefeXefefeefefgZdePd<    ee      Zi dd e[etdSz         e9 e[etdRz         e: e[etdZz         e< e[etd[z         e= e[etdQz         e8 e[etdTz         e; e[etdUz         e; e[etdVz         e; e[etdYz         ee e[etdIz         d e[etdJz         d e[etdKz         d e[etdz         d e[etdPz         ef e[etdNz         e e[etdOz         e4i  e[etdaz         e4 e[etd^z         e4 e[etd`z         e4 e[etd_z         e4 e[etd]z         e e[etdfz         e4 e[etdbz         e4 e[etdcz         e e[etdez         e e[etd\z         e e[etdgz         e e[etddz         e e[etdLz         e e[etdMz         e e[etdXz         e e[etdz         deveaZdePd<   eGebeew<   evewfZdhePd<   nevfZ e[etdPz         ei e[etdaz         er e[etd`z         ep e[etd_z         es e[etdbz         eq e[etd]z         ej e[etdcz         el e[etd\z         en e[etdez         ek e[etdfz         eh e[etdgz         em e[etddz         eoiZdePd<   i ZdePd<   ejQ                  e       ddZ	 	 	 	 	 	 ddZ e)de!v      ZddZddZ	 	 	 d	 	 	 	 	 	 	 	 	 	 	 ddZ G d deY      Z ee      ZdePd<   ejQ                  e_dede[de`di       	 	 	 	 	 	 ddZy# eH$ r dZGY w xY w)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:

* :class:`Blank Nodes <rdflib.term.BNode>`
* :class:`URI References <rdflib.term.URIRef>`
* :class:`Literals <rdflib.term.Literal>` (which consist of a literal value,datatype and language tag)

Those that extend the RDF model into N3:

* :class:`Formulae <rdflib.graph.QuotedGraph>`
* :class:`Universal Quantifications (Variables) <rdflib.term.Variable>`

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parse_xsd_gyearparse_xsd_gyearmonth)NamespaceManager)AlternativePathInvPathNegatedPathPathSequencePathFTzhttps://rdflib.github.ioz/.well-known/genid/z/.well-known/genid/rdflib/zDict[str, BNode]skolemsz
<>" {}|\^`c                &    t         D ]  }|| v s y y)NFT)_invalid_uri_chars)urics     :C:\Projects\mas-dev\.venv\Lib\site-packages\rdflib/term.pyr   r   k   s    8       z^[a-zA-Z]+(?:-[a-zA-Z0-9]+)*$c                >    t        t        j                  |             S N)bool_lang_tag_regexmatch)tags    r?   _is_valid_langtagrG   u   s    %%c*++r@   c                    t        | t              rt        | d      d}}nt        | }}	  ||       y# t        $ r Y yw xY w)z[
    Verify that the provided value can be converted into a Python
    unicode object.
    decodeutf-8FT)
isinstancebytesgetattrstrUnicodeError)valuecoding_funcparams      r?   _is_valid_unicoderS   y   sM    
 %$UH5wU %UE   s   2 	>>c                  <    e Zd ZdZdZej                  ddd       Zy)r   z
    A Node in the Graph.
     Nc                     y rB   rU   selfnamespace_managers     r?   n3zNode.n3   s    ORr@   rB   rY   zOptional[NamespaceManager]returnrN   )__name__
__module____qualname____doc__	__slots__abcabstractmethodrZ   rU   r@   r?   r   r      s"     IR Rr@   r   c                  ~    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y)r	   zg
    See http://www.w3.org/2002/07/rdf-identifer-terminology/
    regarding choice of terminology.
    rU   c                .    t         j                  | |      S rB   )rN   __new__clsrP   s     r?   rf   zIdentifier.__new__   s    {{3&&r@   c                $    | j                  |      S )zNA "semantic"/interpreted equality function,
        by default, same as __eq____eq__rX   others     r?   eqzIdentifier.eq        {{5!!r@   c                $    | j                  |      S )zOA "semantic"/interpreted not equal function,
        by default, same as __ne__)__ne__rl   s     r?   neqzIdentifier.neq   ro   r@   c                &    | j                  |       S rB   rj   rl   s     r?   rq   zIdentifier.__ne__   s    ;;u%%%r@   c                ^    t        |       t        |      u rt        |       t        |      k(  S y)a  
        Equality for Nodes.

        >>> 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)typerN   rl   s     r?   rk   zIdentifier.__eq__   s*    ( :e$t9E
**r@   c                    |yt        |       t        |      u rt        |       t        |      kD  S t        |t              r%t        t        |          t        t        |         kD  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

        Tru   rN   rK   r   	_ORDERINGNotImplementedrl   s     r?   __gt__zIdentifier.__gt__   s\     =$Z4;&t9s5z))t$T$Z(9T%[+AAAr@   c                    |yt        |       t        |      u rt        |       t        |      k  S t        |t              r%t        t        |          t        t        |         k  S t
        S NFrw   rl   s     r?   __lt__zIdentifier.__lt__   sZ    =$Z4;&t9s5z))t$T$Z(9T%[+AAAr@   c                4    | j                  |      }|ry| |k(  S NT)r}   rX   rm   rs      r?   __le__zIdentifier.__le__        KKu}r@   c                4    | j                  |      }|ry| |k(  S r   )rz   r   s      r?   __ge__zIdentifier.__ge__   r   r@   c                H    t        |       j                  t        |            S rB   )rN   
startswith)rX   prefixstartends       r?   r   zIdentifier.startswith   s    4y##CK00r@   N)rP   rN   r\   r	   rm   r   r\   rC   )..)r   rN   r\   rC   )r]   r^   r_   r`   ra   rf   rn   rr   rq   rk   rz   r}   r   r   r   rN   __hash__rU   r@   r?   r	   r	      sK    
 I'"
"
&2(1 ||Hr@   r	   c                  .    e Zd ZdZdZddZdd	dZd
dZy)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   c                    t        |       fS rB   rN   rX   s    r?   __getnewargs__zIdentifiedNode.__getnewargs__  s    D	|r@   Nc                    t               rB   )NotImplementedErrorrW   s     r?   rZ   zIdentifiedNode.n3
  s    !##r@   c                    t        |       S rB   r   r   s    r?   toPythonzIdentifiedNode.toPython  s    4yr@   )r\   z
Tuple[str]rB   r[   r\   rN   )r]   r^   r_   r`   ra   r   rZ   r   rU   r@   r?   r   r      s     I$r@   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y)r
   a  
    RDF 1.1's IRI Section https://www.w3.org/TR/rdf11-concepts/#section-IRIs

    .. note:: 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__Nc                :   |7|j                  d      }t        ||d      }|r|j                  d      s|dz  }t        |      st        j	                  | d       	 t
        j                  | |      }|S # t        $ r t
        j                  | |d      }Y |S w xY w)N#r+   )allow_fragmentszE does not look like a valid URI, trying to serialize this will break.rJ   )endswithr'   r   loggerwarningrN   rf   UnicodeDecodeError)rh   rP   baseends_in_hashrts        r?   rf   zURIRef.__new__%  s     >>#.LD%;E~~c*SLEU#NN'^_	2S%(B 	 " 	2S%1B		2s   A6 6 BBc                h    t        |       st        d|  d      |r|j                  |       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 (``<, >, ", {, }, |, \, `, ^``)

        :param 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normalizeUrirW   s     r?   rZ   z	URIRef.n3:  sP     T"D6  E  F  $11$77tfA;r@   c                @    d| v rt        |       \  }}t        |      S | S )Nr   )r&   r
   )rX   urlfrags      r?   defragzURIRef.defragN  s%    $;!$IC#;Kr@   c                ,    t        |       j                  S )z
        Return the URL Fragment

        >>> 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.fragmentU  s     ~&&&r@   c                &    t         t        |       ffS rB   )r
   rN   r   s    r?   
__reduce__zURIRef.__reduce__a  s    T%%r@   c                    | j                   t        u rd}n| j                   j                  }| dt        j	                  |        dS )Nzrdflib.term.URIRef())	__class__r
   r]   rN   __repr__rX   clsNames     r?   r   zURIRef.__repr__d  s?    >>V#*Gnn--G!CLL./q11r@   c                <    | j                  t        |       |z         S rB   r   rN   rl   s     r?   __add__zURIRef.__add__l      ~~c$i%/00r@   c                <    | j                  |t        |       z         S rB   r   rl   s     r?   __radd__zURIRef.__radd__o  s    ~~ec$i/00r@   c                <    | j                  t        |       |z        S rB   r   rl   s     r?   __mod__zURIRef.__mod__r  r   r@   c                   t        | t              r2t        |        }t        |j                  t        t              d       S t        | t              r)|  }|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.

        .. versionadded:: 4.0
        NrP   r   z> is not a skolem URI)
rK   RDFLibGenidr(   r   pathlenrdflib_skolem_genidGenidr:   r   )rX   
parsed_uribnode_idretvals       r?   de_skolemizezURIRef.de_skolemizeu  s     dK(!TF,Jzs3F/G/IJKKe$H7"x(($*!av%:;<<r@   rB   )rP   rN   r   Optional[str]r\   r
   r[   )r\   r
   r   )r\   zTuple[Type[URIRef], Tuple[str]])r\   r   )r]   r^   r_   r`   ra   __annotations__rf   rZ   r   propertyr   r   r   r   r   r   r   rU   r@   r?   r
   r
     sg    
 IDD++,,FF*( 	' 	'&2111=r@   r
   c                  "    e Zd ZdZedd       Zy)r   rU   c                    t        | t              st        |       } t        |       }|j                  j	                  t
              }|dk7  ryy)Nr   FT)rK   rN   r(   r   rfindskolem_genidr=   r   gen_ids      r?   _is_external_skolemzGenid._is_external_skolem  s?    #s#c(Cc]
&&|4Q;r@   Nr=   r   r\   rC   )r]   r^   r_   ra   staticmethodr   rU   r@   r?   r   r     s    I r@   r   c                  "    e Zd ZdZedd       Zy)r   rU   c                    t        | t              st        |       } t        |       }|j                  dk7  s|j                  dk7  s|j
                  dk7  ry|j                  j                  t              }|dk7  ryy)N Fr   T)	rK   rN   r(   paramsqueryr   r   r   r   r   s      r?   _is_rdflib_skolemzRDFLibGenid._is_rdflib_skolem  sm    #s#c(Cc]
#2%""b(&&':;Q;r@   Nr   )r]   r^   r_   ra   r   r   rU   r@   r?   r   r     s    I r@   r   c                      y)NNrU   rU   r@   r?   
_unique_idr     s     r@   c                  l    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
y)r   ai  
    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   Nc                    |Q|4t        |      r |       }n|}t        |t              rt        |      }n|}nt	               j
                  }|| z   }n	 t        j                  | |      S )zE
        # only store implementations should pass in a value
        )callablerK   r   nextr)   hexr	   rf   )rh   rP   _sn_gen_prefix	sn_resultnode_ids         r?   rf   zBNode.__new__  sp     = "G$7>yI 'Ii7"9oG'G'++ 	*E  !!#u--r@   c                    d| z   S )Nz_:rU   rW   s     r?   rZ   zBNode.n3  s    d{r@   c                &    t         t        |       ffS rB   )r   rN   r   s    r?   r   zBNode.__reduce__  s    D	|$$r@   c                    | j                   t        u rd}n| j                   j                  }| dt        j	                  |        dS )Nzrdflib.term.BNoder   r   )r   r   r]   rN   r   r   s     r?   r   zBNode.__repr__  s?    >>U")Gnn--G!CLL./q11r@   c                h    |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

        .. versionadded:: 4.0
        )_SKOLEM_DEFAULT_AUTHORITYr   rN   r
   r'   )rX   	authoritybasepathskolems       r?   	skolemizezBNode.skolemize  s:     1I*HCI%gi011r@   )rP   r   r   z-Optional[Union[Callable[[], str], Generator]]r   rN   r\   r   rB   r[   )r\   zTuple[Type[BNode], Tuple[str]]r   NN)r   r   r   r   r\   r
   )r]   r^   r_   r`   ra   r   rf   rZ   r   r   r   rU   r@   r?   r   r     sz    $ I  $AE!|	#.#. ?#. 	#.
 
#.J%2 JN2&29F2	2r@   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d,dZed-d       Z	ed.d       Z
ed/d       Zed0d       Z	 	 d1dZd2dZd3dZd4dZd4dZd5dZd,dZd,dZd,dZd,dZd6dZd6dZd6dZd6dZd6d Zd7d!Zd6d"Zd6d#Zd6d$Zd8d9d%Z 	 	 d:	 	 	 	 	 d;d&Z!d<d'Z"d<d(Z#d.d)Z$y)=r   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.:

    >>> from rdflib.namespace import XSD

    >>> Literal('01') != Literal('1')  # clear - strings differ
    True

    but with data-type they get normalized:

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

    unless disabled:

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


    Value based comparison is possible:

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

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

    >>> 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.

    >>> 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):

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


    r   _valuer   	_languageOptional[URIRef]	_datatypeOptional[bool]
_ill_typed)r   r   r   r   Nc                P   |dk(  rd }||nt         j                  }||t        d      |#t        |      st	        dt        |       d      |t        |      }d }d }t        |t              r8|xs |j                  }|t        ||      }n|j                  }|j                  }nt        |t
              st        |t              rnt        ||      }|=|t        v r5t        |      }t        j!                  |t"              } |||      }	|xs |	 }|i|rgt%        ||      \  }
}|
Vt'        |
      rK|
}nH|}t%        ||      \  }
}|d n
t        |      }t         j(                  j+                  ||      }|
|
}|d }t        |t              r|j-                  d      }|t.        t0        fv rt3        |      }|t0        fv rt5        |      }	 t
        j7                  | |      }||_        ||_        ||_        ||_         |S # t8        $ r t
        j7                  | |d      }Y @w xY w)Nr   zmA 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!rJ   )!rdflibNORMALIZE_LITERALS	TypeErrorrG   
ValueErrorrN   r
   rK   r   language_castLexicalToPythondatatyperP   rL   _toPythonMapping_check_well_formed_typesget_well_formed_by_value_castPythonToLiteralrS   util	_coalescerI   _XSD_NORMALISED_STRING
_XSD_TOKEN_normalise_XSD_STRING_strip_and_collapse_whitespacerf   r   r   r   r   r   )rh   lexical_or_valuelangr  	normalizerP   	ill_typeddt_uricheckerwell_formedr   r   insts                r?   rf   zLiteral.__new__v  sa    2:D!*!6IF<U<U	 4O 
 $5d$;qT+IJKKh'H$(	&0 4+44D#,-=xH+44(..(#.*=Mu2U ))98DE#4D(D "(!1266v?TU%&6>%:k/	 Y$8$I!	%*;F*C'-$ %E 45Ex PFI ) 1vi7HI{{,,XyAH!#) #&./66w?.
;;45EF
}$=>NO	?KK-=>D !# " 	?;;s$4g>D	?s   H  H%$H%c                v    | j                   ,t        | j                   | j                  | j                        S | S )a8  
        Returns a new literal with a normalised lexical representation
        of this literal
        >>> 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
        >>> Literal("a", datatype=XSD.integer, normalize=False)
        rdflib.term.Literal('a', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

        )r  r  )rP   r   r  r  r   s    r?   r  zLiteral.normalize  s.     ::!4::DMMRRKr@   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     r@   c                    | j                   S rB   )r   r   s    r?   rP   zLiteral.value  s    {{r@   c                    | j                   S rB   )r   r   s    r?   r  zLiteral.language      ~~r@   c                    | j                   S rB   )r   r   s    r?   r  zLiteral.datatype  r  r@   c                R    t         t        |       | j                  | j                  ffS rB   )r   rN   r  r  r   s    r?   r   zLiteral.__reduce__  s'     Yt}}5
 	
r@   c                H    d t        | j                  | j                        fS )N)r  r  )dictr  r  r   s    r?   __getstate__zLiteral.__getstate__  s    dDMMDMMJKKr@   c                6    |\  }}|d   | _         |d   | _        y )Nr  r  )r   r   )rX   arg_ds       r?   __setstate__zLiteral.__setstate__  s!    1::r@   c                   || S t        |t              st        |      }| j                  t        t        fv rN|j                  t
        v r<| j                         }|j                         }||z   }t        || j                        S | j                  t        k(  r{|j                  t
        v ri| j                         }|j                         }t        j                  t        ddd      |      |z   }t        |j                         | j                        S | j                  t        v r|j                  t        vsa| j                  t        vr|j                  t        v s=| j                  t
        v rb|j                  t
        vs| j                  |j                  k7  r7t        dt        |j                         dt        | j                               | j                  |j                  k(  rAt        | j                         |j                         z   | j                  | j                        S | j                  t         v r|j                  t         v rut        t#        t%        t#        | j                               t#        |j                               z   d      dj'                  d      j'                  d	            t(              S 	 t        j+                  | |      }| j                  t.        v r| j                  }	nt0        }	t        || j                  |	      S # t        $ r$ t        | j,                        t        |      z   }Y iw xY w)
a  
        >>> 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'))
        r    r+   z!Cannot add a Literal of datatype z to a Literal of datatype    f0.)rK   r   r  _XSD_DATETIME	_XSD_DATE_TIME_DELTA_TYPESr   	_XSD_TIMEr   combiner   r   _ALL_DATE_AND_TIME_TYPESr  rN   r  _NUMERIC_LITERAL_TYPESr   roundrstrip_XSD_DECIMALr   rP   _STRING_LITERAL_TYPES_XSD_STRING)
rX   valdate1duration
differenceselfvvalvsdtsnew_datatypes
             r?   r   zLiteral.__add__	  s   * ;K #w'#,C MMmY77 11+/==?E36<<>H)J:>> ]]i'CLL<M,M--/E/2||~D""4a#3U;dBC388:>>
 !99LL(@@ %==LL$<< !22\\)::5 3C4E3FF`adeiereras`tu 
 ==CLL(#,,.0$--$--  MM33 66WT]]_58OOQSTUVW__f &	 	/KKc*
 }} 55#}}  +1dmmlCC  /

Oc#h./s   L *MMc                N   || S t        |t              st        |      }t        | d      st        d      t        |d      st        d      | j                  t
        t        fv rN|j                  t        v r<| j                         }|j                         }||z
  }t        || j                        S | j                  t        k(  r{|j                  t        v ri| j                         }|j                         }t        j                  t        ddd      |      |z
  }t        |j                         | j                        S | j                  |j                  k(  r| j                  t        k(  rt        j                  t        j                         | j                               }t        j                  t        j                         |j                               }t        ||z
  t              S t        | j                         |j                         z
  | j                   | j                  t
        t        t        fv rt              S | j                        S | j                  t"        v r|j                  t"        v rut        t%        t'        t%        | j                               t%        |j                               z
  d      dj)                  d	      j)                  d
            t*              S t        dt-        |j                         dt-        | j                               )aQ  
        >>> from rdflib.namespace import XSD
        >>> 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'))
        >>> Literal("1.1") - 1.0 # doctest: +IGNORE_EXCEPTION_DETAIL
        Traceback (most recent call last):
        ...
        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'))
        >>> from rdflib.namespace import XSD
        >>> 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'))

        r  zCMinuend Literal must have Numeric, Date, Datetime or Time datatype.zFSubtrahend Literal must have Numeric, Date, Datetime or Time datatype.r)  r*  r+   r+  r,  r-  r.  z&Cannot subtract a Literal of datatype z from a Literal of datatype )rK   r   rM   r  r  r/  r0  r1  r   r2  r   r3  r   r   today_XSD_DURATIONr  r5  r   r6  r7  r8  rN   )	rX   r;  r<  r=  r>  r?  r@  rA  vdts	            r?   __sub__zLiteral.__sub__q  s   B ;K #w'#,CtZ(U  j)X 
 MMmY77 11+/==?E36<<>H)J:>> ]]i'CLL<M,M--/E/2||~D""4a#3U;dBC388:>> ==CLL(}}	)&&tzz|T]]_E&&tzz|S\\^DsSy=AAMMOclln4MM  ==]Iy,QQ &	  "]]  MM33 66WT]]_58OOQSTUVW__f &	 	 8S\\9J8KKghklplylyhzg{| r@   c                `    | j                   t        | j                         S t        |       dk7  S )zc
        Is the Literal "True"
        This is used for if statements, bool(literal), etc.
        r   )rP   rC   r   r   s    r?   __bool__zLiteral.__bool__  s+    
 ::!

##4yA~r@   c                    t        | j                  t        t        t        f      r#t        | j                  j                               S t        d|       )a  
        >>> (- Literal(1))
        rdflib.term.Literal('-1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))
        >>> (- Literal(10.5))
        rdflib.term.Literal('-10.5', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#double'))
        >>> 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'))

        >>> (- Literal("1"))
        Traceback (most recent call last):
          File "<stdin>", line 1, in <module>
        TypeError: Not a number; rdflib.term.Literal('1')
        >>>
        Not a number; )rK   rP   intr*   floatr   r   r  r   s    r?   r   zLiteral.__neg__  sC    " djj3	5"9:4::--/00nTH566r@   c                    t        | j                  t        t        t        f      r#t        | j                  j                               S t        d|       )a  
        >>> (+ Literal(1))
        rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))
        >>> (+ Literal(-1))
        rdflib.term.Literal('-1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))
        >>> 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'))

        >>> (+ Literal("1"))
        Traceback (most recent call last):
          File "<stdin>", line 1, in <module>
        TypeError: Not a number; rdflib.term.Literal('1')
        rL  )rK   rP   rM  r*   rN  r   __pos__r  r   s    r?   rP  zLiteral.__pos__  sC     djj3	5"9:4::--/00nTH566r@   c                    t        | j                  t        t        t        f      r#t        | j                  j                               S t        d|       )a  
        >>> abs(Literal(-1))
        rdflib.term.Literal('1', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

        >>> 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'))

        >>> abs(Literal("1"))
        Traceback (most recent call last):
          File "<stdin>", line 1, in <module>
        TypeError: Not a number; rdflib.term.Literal('1')
        rL  )rK   rP   rM  r*   rN  r   __abs__r  r   s    r?   rR  zLiteral.__abs__  sC     djj3	5"9:4::--/00nTH566r@   c                    t        | j                  t        t        t        f      r#t        | j                  j                               S t        d|       )a   
        >>> ~(Literal(-1))
        rdflib.term.Literal('0', datatype=rdflib.term.URIRef('http://www.w3.org/2001/XMLSchema#integer'))

        >>> 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'))

        Not working:

        >>> ~(Literal("1"))
        Traceback (most recent call last):
          File "<stdin>", line 1, in <module>
        TypeError: Not a number; rdflib.term.Literal('1')
        rL  )rK   rP   rM  r*   rN  r   r   r  r   s    r?   r   zLiteral.__invert__  sC      djj3	5"9:4::00233nTH566r@   c                   |yt        |t              r@| j                  t        v r[|j                  t        v rI| j                  s=|j                  s1| j
                  %|j
                  | j
                  |j
                  kD  S t        j                  j                  | j                  t              }t        j                  j                  |j                  t              }||k7  rt        j                  rt        S ||kD  S | j                  |j                  k7  r3| j                  sy|j                  sy| j                  |j                  kD  S | j
                  |j
                  vt        | j
                        t        v rAt        t        | j
                           } || j
                         ||j
                        kD  S 	 | j
                  |j
                  kD  S t!        |       t!        |      k7  rt!        |       t!        |      kD  S | j                  |j                  k7  r3| j                  y|j                  y| j                  |j                  kD  S yt        |t"              ryt        S # t        $ r Y w xY w)a-  

        This implements ordering for Literals,
        the other comparison methods delegate here

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

        In short, Literals with compatible data-types are ordered in value
        space, i.e.
        >>> from rdflib import XSD

        >>> Literal(1) > Literal(2) # int/int
        False
        >>> Literal(2.0) > Literal(1) # double/int
        True
        >>> from decimal import Decimal
        >>> Literal(Decimal("3.3")) > Literal(2.0) # decimal/double
        True
        >>> Literal(Decimal("3.3")) < Literal(4.0) # decimal/double
        True
        >>> Literal('b') > Literal('a') # plain lit/plain lit
        True
        >>> Literal('b') > Literal('a', datatype=XSD.string) # plain lit/xsd:str
        True

        Incompatible datatype mismatches ordered by DT

        >>> Literal(1) > Literal("2") # int>string
        False

        Langtagged literals by lang tag
        >>> Literal("a", lang="en") > Literal("a", lang="fr")
        False
        TdefaultF)rK   r   r  r5  r  rP   r   r  r  r:  DAWG_LITERAL_COLLATIONry   r  ru   _TOTAL_ORDER_CASTERSr  rN   r   )rX   rm   dtselfdtothercasters        r?   rz   zLiteral.__gt__5  s   H =eW%
 MM%;;*@@..5??ZZ+0GzzEKK// [[**4==+*NFkk++ENNK+PG 00))!G++}}.}} ==5>>99zz%%++*A

#';;1$tzz2BCF!$**-u{{0CCC::33 4yCJ&4y3u:-- }}.==( ^^+==5>>99t$!!+ ! s   I, ,	I87I8c                    |yt        |t              r'	 | j                  |       xr | j                  |       S t        |t              ryt
        S # t        $ r	 t
        cY S w xY wr|   )rK   r   rz   rn   r  ry   r   rl   s     r?   r}   zLiteral.__lt__  sg    =eW%&;;u--Ddggen2DD eT"  &%%&s   %A A$#A$c                x    | j                  |      }|ry	 | j                  |      S # t        $ r	 t        cY S w xY w)z
        >>> 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	"775>! 	"!!	"   ' 99c                x    | j                  |      }|ry	 | j                  |      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	"775>! 	"!!	"r^  c                   t        |t              r| j                  K|j                  ?| j                  t        vs|j                  t        vr| j                  |j                  k7  ryy| j                  t        k(  r+|j                  s|j                  t        k(  r| j                  sy| j
                  xs dj                         |j
                  xs dj                         k7  ryy)zo
        Helper method to decide which things are meaningful to
        rich-compare with this literal
        Fr   T)rK   r   r  XSDToPythonr:  r  lowerrl   s     r?   _comparable_tozLiteral._comparable_to  s    
 eW%}}(U^^-G MM4~~[8 }}6$  4U^^NNk1$--  MM'R..0U^^5Ir4P4P4RR r@   c                    t         j                  |       }| j                  r&|t        | j                  j	                               z  }| j
                  |t        | j
                        z  }|S )a  
        >>> from rdflib.namespace import XSD
        >>> a = {Literal('1', datatype=XSD.integer):'one'}
        >>> Literal('1', datatype=XSD.double) in a
        False


        "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)

        )rN   r   r   hashrb  r   )rX   ress     r?   r   zLiteral.__hash__  sW    < ll4 >>4,,.//C>>%4''C
r@   c                <   | |u ry|yt        |t              r| j                  |j                  k(  xri | j                  r| j                  j	                         nd|j                  r|j                  j	                         ndk(  xr t
        j                  | |      S y)a  
        Literals are only equal to other literals.

        "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)

        >>> 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)rK   r   r   r   rb  rN   rk   rl   s     r?   rk   zLiteral.__eq__  s    H 5==eW%%//1 ,/3~~T^^))+4/4EOO))+DJ, JJtU+	 r@   c                   t        |t              r}| j                  t        v r|j                  t        v r| j                  s}|j                  sq| j
                  e|j
                  Y| j
                  %|j
                  | j
                  |j
                  k(  S t        j                  | |      ryt        d|  d|       | j                  xs dj                         |j                  xs dj                         k7  ryt        j                  j                  | j                  t              }t        j                  j                  |j                  t              }|t        k(  r|t        k(  rt        j                  | |      S |t        v r\|t        v rT| j                  durF|j                  dur8| j
                  ,|j
                   t!        | j
                  |j
                        S ||k7  r6t        j"                  r%t        d| j                   d|j                         y| j
                  %|j
                  | j
                  |j
                  k(  S t        j                  | |      ry| j                  t        k(  ryt        d|  d|       t        |t$              ryt        |t              r@| j                  y| j                  t        k(  s| j                  t        |       |k(  S tF        S t        |t&        t(        t*        f      r'| j                  t        v r| j
                  |k(  S tF        S t        |t,        t.        t0        f      r2| j                  t2        t4        t6        fv r| j
                  |k(  S tF        S t        |t8        t:        f      r2| j                  t<        t>        t@        fv r| j
                  |k(  S tF        S t        |tB              r"| j                  tD        k(  r| j
                  |k(  S tF        S )aw  
        Compare the value of this literal with something else

        Either, with the value of another literal
        comparisons are then done in literal "value space",
        and according to the rules of XSD subtype-substitution/type-promotion

        OR, with a python object:

        basestring objects can be compared with plain-literals,
        or those with datatype xsd:string

        bool objects with xsd:boolean

        a int, long or float with numeric xsd types

        isodate date,time,datetime objects with xsd:date,xsd:time or xsd:datetime

        Any other operations returns NotImplemented

        TzII cannot know that these two lexical forms do not map to the same value: z and r   FrU  z4I don't know how to compare literals with datatypes )$rK   r   r  r5  r  rP   rN   rk   r  r  rb  r   r  r  r:  _XML_COMPARABLE_isEqualXMLNoderW  r   rM  r*   rN  r   r   r   r/  r0  r2  r   r,   rF  _XSD_DAYTIMEDURATION_XSD_YEARMONTHDURATIONrC   _XSD_BOOLEANry   )rX   rm   rY  rZ  s       r?   rn   z
Literal.eq8  se   , eW%
 MM%;;*@@..5??ZZ+0G::)ekk.E::44zz$.##''+fE%: 
 #**,1E20L0L0NN[[**4==+*NFkk++ENNK+PG$K)?zz$.. ?*w//I ..,5??$3NZZ+0G&tzz5;;?? 00#Nt}}o]bchcqcqbrs  ! zz%%++*AzzU[[00::dE*==K/   "V51  t$s# }}(}}+t}}/D4yE))( % Y67}} 66zzU**   h56}}	9 EEzzU**  	845}}$&! 
 zzU** 	 t$}},zzU**r@   c                &    | j                  |       S rB   )rn   rl   s     r?   rr   zLiteral.neq  s    775>!!r@   c                ^    |r| j                  |j                        S | j                         S )aZ  
        Returns a representation in the N3 format.

        Examples::

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

        Strings with newlines or triple-quotes::

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

            >>> Literal("''\'").n3()
            '"\'\'\'"'

            >>> Literal('"""').n3()
            '"\\"\\"\\""'

        Language::

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

        Datatypes::

            >>> 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)::

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

        Custom datatype::

            >>> 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:

            >>> from rdflib import Graph
            >>> Literal(1).n3(Graph().namespace_manager)
            '"1"^^xsd:integer'
        )qname_callback)_literal_n3r   rW   s     r?   rZ   z
Literal.n3  s2    j ##3D3Q3Q#RR##%%r@   c                   |r| j                   t        v r| j                  | j                   t        v rI	 t	        |       }t        j                  |      st        j                  |      r| j                  d|      S 	 | 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|  j                         S |  S | j                         }| j                   }d}||r ||      }|sd| d	}|t        v rj	 t	        |       }t        j                  |      r"|j!                  d
d      j!                  dd      }t        j                  |      r|j!                  dd      }| j&                  }|r| d| S |r| d| S |S # t        $ r | j                  d|      cY S w xY w# t        $ r t#        j$                  d|        Y dw xY w)a_  
        Using plain literal (shorthand) output::
            >>> 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:
            >>> 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::

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

        NFz\.?0*eer.  Ez.0r   r   infINFInfinitynanNaNzSerializing weird numerical @z^^)r  _PLAIN_LITERAL_TYPESrP   _NUMERIC_INF_NAN_LITERAL_TYPESrN  mathisinfisnanrq  r  _XSD_DOUBLEr   r8  rm  rb  _quote_encodereplacewarningswarnr  )	rX   	use_plainrp  vrB  encodedr  	quoted_dtr  s	            r?   rq  zLiteral._literal_n3  s   b *>>zz% ==$BBG!$K::a=DJJqM#'#3#3E>#JJ -: ==K/y#%+aBB]]l2&A!|1AT	H]]l2"V??,,"V$))+==	*84	zO	99KdAzz!} #*//%"?"G"G&# zz!}")//%"? ==Yaz**Yb,,Nc & G#//~FFGL " K MM$@"IJKs%   AF; 2A)G ;GG!H ?H c                D   d| v rX| j                  dd      }d| v r|j                  dd      }|d   dk(  r|d   dk7  r|d d dz   dz   }d	|j                  d
d      z  S d| j                  dd      j                  dd      j                  dd      j                  d
d      z  S )N
\z\\z"""z\"\"\"r   z"""%s"""z\rz"%s"z\nz\")r  )rX   r  s     r?   r  zLiteral._quote_encode^  s     4<ll40G}!//%=r{c!gbkT&9!#2,-3 e <<<DLLu5==dFKSSUgdE"# #r@   c                   t         j                  |       g}| j                  '|j                  dt	        | j                        z          | j
                  '|j                  dt	        | j
                        z          | j                  t        k(  rd}n| j                  j                  }| ddj                  |       dS )Nzlang=z	datatype=zrdflib.term.Literalr   z, r   )
rN   r   r  appendreprr  r   r   r]   join)rX   argsr   s      r?   r   zLiteral.__repr__y  s    T"#==$KK$t}}"556==$KKd4==&99:>>W$+Gnn--G!DIIdO,A..r@   c                6    | j                   | j                   S | S )zV
        Returns an appropriate python datatype derived from this RDF Literal
        r   r   s    r?   r   zLiteral.toPython  s    
 ::!::r@   )NNN)
r  r   r  r   r  r   r  r   r\   r   )r\   r   )r\   r   )r\   r   )r\   r   )r\   r   )r\   zDTuple[Type[Literal], Tuple[str, Union[str, None], Union[str, None]]])r\   z(Tuple[None, Dict[str, Union[str, None]]])r$  zTuple[Any, Dict[str, Any]]r\   None)r;  r   r\   r   )r\   rC   r   )r\   rM  rB   r[   )FN)r  rC   rp  z+Optional[Callable[[URIRef], Optional[str]]]r\   rN   r   )%r]   r^   r_   r`   r   ra   rf   r  r   r  rP   r  r  r   r"  r'  r   rH  rJ  r   rP  rR  r   rz   r}   r   r   rc  r   rk   rn   rr   rZ   rq  r  r   r   rU   r@   r?   r   r     s{   Yv KBI
 #"&$(UU U  	U
 "U 
Un& 
 
      
	M
L'
fDPfP7,7(7&7,b"H""B$L1fzx"8&x  FJkk Dk 
	kZ#6
/r@   r   c                    t         j                  j                  j                  d|  d      }|j	                          |S )Nz<rdflibtoplevelelement>z</rdflibtoplevelelement>)xmldomminidomparseStringr  )	xmlstringr   s     r?   	_parseXMLr    s:    WW__((
!),DEF Mr@   c                0   t        j                  t         j                  j                  d      d      }	 |j	                  |       }|j                          |S # t         j
                  j                  $ r}t        j                  d|        |d}~ww xY w)a\  
    Parse the lexical form of an HTML literal into a document fragment
    using the ``dom`` from html5rdf tree builder.

    :param lexical_form: The lexical form of the HTML literal.
    :return: 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  )lexical_formparserresultrs  s       r?   _parse_htmlr    s       ""11%8F393G3G3U M	 ** ,QC01s   A B6BBc                4    t        j                  | d      }|S )z
    Serialize a document fragment representing an HTML literal into
    its lexical form.

    :param value: A document fragment representing an HTML literal.
    :return: The lexical form of the HTML literal.
    r  )r  )r  	serialize)rP   r  s     r?   _write_htmlr    s     E2FMr@   c                |   t        | t        j                  j                  j                        rIt        j                  j                  j                         }|xj                  | j                  z  c_        |} | j                  d      }|j                  d      r|dd  }|j                  d      r|dd }|dk(  rd}|S )	NrJ   s&   <?xml version="1.0" encoding="utf-8"?>&   s   <rdflibtoplevelelement>   is   <rdflibtoplevelelement/>r@   )	rK   r  r  r  DocumentFragmentDocument
childNodestoxmlr   )xmlnoder&  rB  s      r?   	_writeXMLr    s     '377??;;<GGOO$$&	***gA 	||=>bcF||./bI''Hr@   c                X    t        | t              r| j                         } t        |       S rB   )rK   rN   encoder   r   s    r?   
_unhexlifyr    s"    %Ur@   c                    g d}g d}| j                         }||v ry||vrt        j                  d| dt               y)   
    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)r-  false   0   falseTzParsing weird boolean, z does not map to True or False)categoryF)rb  r  r  UserWarning)rP   true_accepted_valuesfalse_accepted_values	new_values       r?   _parseBooleanr    sQ     8:I((--%eY.LM 	
 r@   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   lexicalrP   s     r?   r	  r	    s     r@   c                P    t        |       dkD  xr t        |t              xr |dk\  S )zG
    xsd:unsignedInteger and xsd:unsignedLong must not be negative
    r   )r   rK   r*   r  s     r?   _well_formed_unsignedlongr    s(     w<!K
5) <K!Kr@   c                
    | dv S )r  )r  r  r  r  r  r  r-  r  rU   r  s     r?   _well_formed_booleanr    s     PPPr@   c                f    t        |       dkD  xr" t        |t              xr d|cxk  xr dk  S 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   rK   rM  r  s     r?   _well_formed_intr    s@     	Gq 	1uc"	1E/Z/ 0r@   c                f    t        |       dkD  xr" t        |t              xr d|cxk  xr dk  S c S )zG
    xsd:unsignedInt has a 32bit value of between 0 and 4294967295
    r   l    r  r  s     r?   _well_formed_unsignedintr    s4     w<!U
5# 6UA<T*<TU<TUr@   c                f    t        |       dkD  xr" t        |t              xr d|cxk  xr dk  S 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    s4     w<!U
5# 6UFe<Tu<TU<TUr@   c                f    t        |       dkD  xr" t        |t              xr d|cxk  xr dk  S c S )zD
    xsd:unsignedShort has a 16bit value of between 0 and 65535
    r   i  r  r  s     r?   _well_formed_unsignedshortr     s4     w<!P
5# 6PA<O%<OP<OPr@   c                f    t        |       dkD  xr" t        |t              xr d|cxk  xr dk  S 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  '  s4     w<!Q
5# 6QDE<PS<PQ<PQr@   c                f    t        |       dkD  xr" t        |t              xr d|cxk  xr dk  S c S )z@
    xsd:unsignedByte has a 8bit value of between 0 and 255
    r      r  r  s     r?   _well_formed_unsignedbyter  0  s4     w<!N
5# 6NA<M#<MN<MNr@   c                0    t        |t              xr |dk\  S Nr   rK   rM  r  s     r?   !_well_formed_non_negative_integerr  7      eS!0eqj0r@   c                0    t        |t              xr |dkD  S r  r  r  s     r?   _well_formed_positive_integerr  ;      eS!/eai/r@   c                0    t        |t              xr |dk  S r  r  r  s     r?   !_well_formed_non_positive_integerr  ?  r  r@   c                0    t        |t              xr |dk  S r  r  r  s     r?   _well_formed_negative_integerr  C  r  r@   z!http://www.w3.org/2001/XMLSchema#z+http://www.w3.org/1999/02/22-rdf-syntax-ns#
XMLLiteralHTMLstringnormalizedStringtokenrN  doubledecimalintegerbooleandateTimer   r   r=  dayTimeDurationyearMonthDurationz&http://www.w3.org/2002/07/owl#rationalbase64Binary	hexBinarygYear
gYearMonthbyterM  longnegativeIntegernonNegativeIntegernonPositiveIntegerpositiveIntegershortunsignedByteunsignedIntunsignedLongunsignedShortzTuple[URIRef, ...]r5  r{  r|  _DATE_AND_TIME_TYPESr1  r4  c                `    | j                   d uxr | j                   j                  |       d u| fS rB   tzinfo	utcoffsetr   s    r?   <lambda>r    s/    D NU\\%;%;E%B$%Nr@   c                `    | j                   d uxr | j                   j                  d       d u| fS rB   r	  r   s    r?   r  r    s/    D MU\\%;%;D%A%Mr@   c                "    | j                         S rB   )r  r   s    r?   r  r    s
    EKKMr@   z%Dict[Type[Any], Callable[[Any], Any]]rX  r9  _StrT)boundc                .    |
 ||       |fS || |fS | d fS rB   rU   )objpTypecastFuncdTypes       r?   _py2literalr    s3     }e##		EzDyr@   c                    t         D ]*  \  \  }}}t        | |      s||k(  st        | |||      c S  t        D ]$  \  }\  }}t        | |      s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)_SpecificPythonToXSDRulesrK   r  _GenericPythonToXSDRules)r  r  r  r  r  s        r?   r
  r
    sv     %> c5!ex&7sE8U;; %> %=  %c5!sE8U;; %= 9r@   r   c                4    t        |       j                         S rB   )rN   rb  is    r?   r  r    s    c!fllnr@   c                
    | dS )Nr,  rU   r  s    r?   r  r    s
    Aa5r@   c                "    | j                         S rB   	isoformatr  s    r?   r  r    s
    !++-r@   c                "    | j                         S rB   r  r  s    r?   r  r    
    akkmr@   c                "    | j                         S rB   r  r  s    r?   r  r    r"  r@   c                    t        |       S rB   r-   r  s    r?   r  r    s
    ,Q/r@   c                    t        |       S rB   r%  r  s    r?   r  r    s
    -a0r@   zZList[Tuple[Type[Any], Tuple[Optional[Callable[[Any], Union[str, bytes]]], Optional[str]]]]r  c                B    | j                  d      j                  d      S )Nz%Y   strftimezfillr;  s    r?   r  r    s    S\\$%7%=%=a%@r@   c                B    | j                  d      j                  d      S )Nz%Y-%m   r)  r,  s    r?   r  r    s    #,,w*?*E*Ea*Hr@   zPList[Tuple[Tuple[Type[Any], str], Optional[Callable[[Any], Union[str, bytes]]]]]r  r  anyURIz3Dict[Optional[str], Optional[Callable[[str], Any]]]ra  ri  z6Dict[URIRef, Callable[[Union[str, bytes], Any], bool]]r  r  c                    t         j                          t         j                  t               t        j                          t        j                  t               t        j                          t        j                  t               y)z;
    Reset lexical<->value space binding for `Literal`
    N)	r  clearupdatera  r  extend _OriginalGenericPythonToXSDRulesr  !_OriginalSpecificPythonToXSDRulesrU   r@   r?   _reset_bindingsr6  Q  sT     K(""$##$DE##%$$%FGr@   c                    	 t         |   }|		  ||       S 	 t        |       S # t        $ r Y yw xY w# t        $ r  t        j	                  d| d| d       Y yw xY w# t        $ r t        | d      cY S w xY w)z~
    Map 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_inforJ   )r  KeyErrorr   r   r   rN   r   )r  r  	conv_funcs      r?   r  r  _  s    $X.	
 	 W%%	)w<-    	NNLXJVbclbmn  
 	 " 	) w((		)s,   	" 1 
A 	..&AAA54A5_AnyTc                    t        | t              r2| j                  dd      j                  dd      j                  dd      S | S )z~
    Replaces 	, 
,  (#x9 (tab), #xA (linefeed), and #xD (carriage return)) with space without any whitespace collapsing
    	 r  r  )rK   rN   r  r  s    r?   r  r    sE     "C(  ''c2::4EMMdTWXXr@   c                p    t        | t              r%t        j                  dd| j	                               S | S )Nz +r>  )rK   rN   rer   stripr?  s    r?   r  r    s2    "C( vvdC!1!7!7!9::r@   c                    |r| t        d      | t        v rt        j                  d|  d       ||}|t        | <   |rt        j                  || f|f       yt        j                  ||| ff       y)a  
    register a new datatype<->pythontype binding

    :param constructor: an optional function for converting lexical forms
                        into a Python instances, if not given the pythontype
                        is used directly

    :param lexicalizer: an optional function for converting python objects to
                        lexical form, if not given object.__str__ is used

    :param 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  
pythontypeconstructorlexicalizerdatatype_specifics        r?   r   r     s    * X-KLL##H:-LMN !,X!((:x*@+)NO ''k85L(MNr@   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	y)r   zo
    A Variable - this is used for querying, or in Formula aware
    graphs, where Variables can be stored
    rU   c                z    t        |      dk(  rt        d      |d   dk(  r|dd  }t        j                  | |      S )Nr   z7Attempted to create variable with empty string as name!?r+   )r   r   rN   rf   rg   s     r?   rf   zVariable.__new__  s@    u:?UVV8s?!"IE{{3&&r@   c                    | j                   t        u rd}n| j                   j                  }| dt        j	                  |        dS )Nzrdflib.term.Variabler   r   )r   r   r]   rN   r   r   s     r?   r   zVariable.__repr__  s?    >>X%,Gnn--G!CLL./q11r@   c                    d| z   S NrJ  rU   r   s    r?   r   zVariable.toPython      Tzr@   Nc                    d| z   S rM  rU   rW   s     r?   rZ   zVariable.n3  rN  r@   c                &    t         t        |       ffS rB   )r   rN   r   s    r?   r   zVariable.__reduce__  s    3t9,''r@   )rP   rN   r\   r   r   rB   r[   )r\   z!Tuple[Type[Variable], Tuple[str]])
r]   r^   r_   r`   ra   rf   r   r   rZ   r   rU   r@   r?   r   r     s'    
 I'2(r@   r   zDict[Type[Node], int]rx   
         (   c                 
    ddl m}  fd} y j                  j                  k7  ry j                  |j                  |j                  fv r |       S  j                  |j
                  k(  rTt        r`t         t        j                  j                  j                        sJ t        t        j                  j                  j                        sJ  j                  j                  k(  r j                  j                  k(  sy j                  j                         D cg c]  }|d   dk7  r| }}j                  j                         D cg c]  }|d   dk7  r| }}t!        |      t!        |      k7  ry|D ]9  }||v r2 j#                  |d   |d         j#                  |d   |d         k(  r9 y  |       S  j                  |j$                  |j&                  |j(                  |j*                  fv rTt        r4t         t        j                  j                  j,                  t        j                  j                  j.                  t        j                  j                  j0                  t        j                  j                  j2                  f      sJ t        t        j                  j                  j,                  t        j                  j                  j.                  t        j                  j                  j0                  t        j                  j                  j2                  f      sJ  j4                  j4                  k(  S  j                  |j6                  k(  rt        r`t         t        j                  j                  j8                        sJ t        t        j                  j                  j8                        sJ  j4                  j4                  k(  xr  j:                  j:                  k(  S  j                  |j<                  k(  r j>                  j>                  k(  S  j                  |j@                  k(  rt        r`t         t        j                  j                  jB                        sJ t        t        j                  j                  jB                        sJ  jD                  jD                  k(  xr  jF                  jF                  k(  S tI        d j                         c c}w c c}w )Nr   )r   c                     t        j                        t        j                        k7  ryt        d j                  j                        D ]  \  } }t        | |      r y y)NFc                
    | |fS rB   rU   )xys     r?   r  z2_isEqualXMLNode.<locals>.recurse.<locals>.<lambda>	  s    1vr@   T)r   r  maprj  )ncocnoderm   s     r?   recursez _isEqualXMLNode.<locals>.recurse
	  sY     t3u'7'7#88-t@P@PQFB"2r* R r@   Fzhttp://www.w3.org/2000/xmlns/r+   z*I dont know how to compare XML Node type: )%xml.dom.minidomr   nodeTypeDOCUMENT_NODEDOCUMENT_FRAGMENT_NODEELEMENT_NODEr   rK   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   )r]  rm   XMLNoder^  kn_keyso_keyss   ``     r?   rj  rj    s   < 0  |u}}}&}}..0N0NOOy	'..	.dCGGOO$;$;<<<eSWW__%<%<=== LLEMM)d.?.?5CUCU.U __++-
-t66 - 	 
 %%,,.
.t66 . 	 

 v;#f+%AV''!ad3u7K7KAaDRSTURV7WW  y	""	 
 GGOO((GGOO++GGOO00GGOO,,	   GGOO((GGOO++GGOO00GGOO,,	   yyEJJ&&	'==	=dCGGOO$I$IJJJeSWW__%J%JKKKyyEJJ&F4;;%,,+FF	'--	-~~00	'44	4dCGGOO$@$@AAAeSWW__%A%ABBB}}.R4==ENN3RR DT]]OTUUI


s   (TT)r=   rN   r\   rC   )rF   rN   r\   rC   )rP   Union[str, bytes]r\   rC   r   )r  rN   r\   zxml.dom.minidom.Document)r  rN   r\    xml.dom.minidom.DocumentFragment)rP   r  r\   rL   )r  zAUnion[xml.dom.minidom.Document, xml.dom.minidom.DocumentFragment]r\   rL   )rP   zUnion[str, bytes, Literal]r\   rL   )r  r  rP   r   r\   rC   )
r  r   r  r   r  zOptional[Callable[[Any], Any]]r  zOptional[_StrT]r\   zTuple[Any, Optional[_StrT]])r  r   r  r   r\   zTuple[Any, Optional[str]])r\   r  )r  r  r  r   r\   r   )r  r;  r\   r;  )NNF)r  rN   rD  z	Type[Any]rE  zOptional[Callable[[str], Any]]rF  z,Optional[Callable[[Any], Union[str, bytes]]]rG  rC   r\   r  )r]    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]rm   r  r\   rC   )r`   
__future__r   rb   rA  	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   r2   r3   	namespacer4   pathsr5   r6   r7   r8   r9   _HAS_HTML5RDFr  ImportErrorr   	getLoggerr]   r   r   r   r:   r   r<   r   rD   rG   rS   ABCr   rN   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_HTMLLITERALr:  r  r  
_XSD_FLOATr  r8  _XSD_INTEGERrm  r/  r0  r2  rF  rk  rl  _OWL_RATIONAL_XSD_B64BINARY_XSD_HEXBINARY
_XSD_GYEAR_XSD_GYEARMONTHr5  r{  r|  r  r1  r4  r  r  r  rX  r9  r  r  r
  rN  rC   rM  r  r  r  listr4  rL   r  r5  ra  ri  r  r  r2  r6  r  r;  r  r  r   r   rx   rj  rU   r@   r?   <module>r     s  . # 
 	 
     ' ' # 4 4       6 5    #	 	 	 +PPM 7 			8	$$2 	  #  9:,$S377 Ses ePZ &x=^ x=vF % (
U2N U2pyj yx#,	N
(&	LQ
VVQRO1010
 /8L01(V+, X()+= => Hw&'
Hw&'
X()h*+h*+h*+x*,-8f$%	8f$%	x*,-h)::; +> >? ?@>12;./Hw&'
L01 
8g
8f
8e
8f
8''(
8**+
8**+
8''(
8g
8n$%
8m#$
8n$%
8o%&!. * * , (  8g6  2  , (  ) % 
 0DFW/W , W  
 	 
 GGOO9? ;   
8(()
8g- )  	s#	 - 	
 !	%B 	,
T; 	$l344
|$%!<01'78	#Y/0	#Y/0/?@02FGHWW__	?;<m$%   $  ##		)	)K9I+JK $((@#A  
 J@A
OHI	>G$^g&	>I&^i(   	 %))B$C !#D$#D
8fz#D 8f~#D 8g	#D
 8l"#%9#D 8j !>#D 8j !#5#D 8''(*<#D 8))*,>#D 8k!"J#D 8h#D 8(()4#D 8g#D 8j !4#D 8i -#D  8i '!#D" 8i )##D$ 8**+Y%#D& 8fy'#D( 8**+Y)#D* 8''()+#D, 8ec-#D. 8n$%y/#D0 8''()1#D2 8g3#D4 8m#$c5#D6 8fs7#D8 8o%&9#D: 8n$%s;#D< 8g=#D> 8h?#D@ 8n$%yA#DB 8hC#DD YE#D@ #J  %0K !+:<L*MO'M&(O 8i "6
8**+-N
8**+-N
8''(*G
8''(*G
8e.
8g 2
8f0
8m#$&>
8n$%'@
8o%&(B
8n$%'@T P  IK E J    $H$)$)*:$)$)N 	s# 37@D#!O!O!O 0!O >	!O
 !O 
!OH(z (J $/s#3	  3 	  %Xr62wC DKVKVKV6 
7KV[D  Hs   ]/ /]:9]: