
    Pib5                     V    d Z ddlmZ ddlmZ ddlmZmZmZ dgZ	 G d d          Z
dS )a   
The [`Resource`][rdflib.resource.Resource] class wraps a
[`Graph`][rdflib.graph.Graph]
and a resource reference (i.e. a [`URIRef`][rdflib.term.URIRef] or
[`BNode`][rdflib.term.BNode]) to support a resource-oriented way of
working with a graph.

It contains methods directly corresponding to those methods of the Graph
interface that relate to reading and writing data. The difference is that a
Resource also binds a resource identifier, making it possible to work without
tracking both the graph and a current subject. This makes for a "resource
oriented" style, as compared to the triple orientation of the Graph API.

Resulting generators are also wrapped so that any resource reference values
([`URIRef`][rdflib.term.URIRef] and [`BNode`][rdflib.term.BNode]) are in turn
wrapped as Resources. (Note that this behaviour differs from the corresponding
methods in [`Graph`][rdflib.graph.Graph], where no such conversion takes place.)


## Basic Usage Scenario

Start by importing things we need and define some namespaces:

```python
>>> from rdflib import *
>>> FOAF = Namespace("http://xmlns.com/foaf/0.1/")
>>> CV = Namespace("http://purl.org/captsolo/resume-rdf/0.2/cv#")

```

Load some RDF data:

```python
>>> graph = Graph().parse(format='n3', data='''
... @prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
... @prefix xsd: <http://www.w3.org/2001/XMLSchema#>.
... @prefix foaf: <http://xmlns.com/foaf/0.1/> .
... @prefix cv: <http://purl.org/captsolo/resume-rdf/0.2/cv#> .
...
... @base <http://example.org/> .
...
... </person/some1#self> a foaf:Person;
...     rdfs:comment "Just a Python & RDF hacker."@en;
...     foaf:depiction </images/person/some1.jpg>;
...     foaf:homepage <http://example.net/>;
...     foaf:name "Some Body" .
...
... </images/person/some1.jpg> a foaf:Image;
...     rdfs:label "some 1"@en;
...     rdfs:comment "Just an image"@en;
...     foaf:thumbnail </images/person/some1-thumb.jpg> .
...
... </images/person/some1-thumb.jpg> a foaf:Image .
...
... [] a cv:CV;
...     cv:aboutPerson </person/some1#self>;
...     cv:hasWorkHistory [ cv:employedIn </#company>;
...             cv:startDate "2009-09-04"^^xsd:date ] .
... ''')

```

Create a Resource:

```python
>>> person = Resource(
...     graph, URIRef("http://example.org/person/some1#self"))

```

Retrieve some basic facts:

```python
>>> person.identifier
rdflib.term.URIRef('http://example.org/person/some1#self')

>>> person.value(FOAF.name)
rdflib.term.Literal('Some Body')

>>> person.value(RDFS.comment)
rdflib.term.Literal('Just a Python & RDF hacker.', lang='en')

```

Resources can be sliced (like graphs, but the subject is fixed):

```python
>>> for name in person[FOAF.name]:
...     print(name)
Some Body
>>> person[FOAF.name : Literal("Some Body")]
True

```

Resources as unicode are represented by their identifiers as unicode:

```python
>>> %(unicode)s(person)  #doctest: +SKIP
'Resource(http://example.org/person/some1#self'

```

Resource references are also Resources, so you can easily get e.g. a qname
for the type of a resource, like:

```python
>>> person.value(RDF.type).qname()
'foaf:Person'

```

Or for the predicates of a resource:

```python
>>> sorted(
...     p.qname() for p in person.predicates()
... )  #doctest: +NORMALIZE_WHITESPACE +SKIP
['foaf:depiction', 'foaf:homepage',
 'foaf:name', 'rdf:type', 'rdfs:comment']

```

Follow relations and get more data from their Resources as well:

```python
>>> for pic in person.objects(FOAF.depiction):
...     print(pic.identifier)
...     print(pic.value(RDF.type).qname())
...     print(pic.value(FOAF.thumbnail).identifier)
http://example.org/images/person/some1.jpg
foaf:Image
http://example.org/images/person/some1-thumb.jpg

```

```python
>>> for cv in person.subjects(CV.aboutPerson):
...     work = list(cv.objects(CV.hasWorkHistory))[0]
...     print(work.value(CV.employedIn).identifier)
...     print(work.value(CV.startDate))
http://example.org/#company
2009-09-04

```

It's just as easy to work with the predicates of a resource:

```python
>>> for s, p in person.subject_predicates():
...     print(s.value(RDF.type).qname())
...     print(p.qname())
...     for s, o in p.subject_objects():
...         print(s.value(RDF.type).qname())
...         print(o.value(RDF.type).qname())
cv:CV
cv:aboutPerson
cv:CV
foaf:Person

```

This is useful for e.g. inspection:

```python
>>> thumb_ref = URIRef("http://example.org/images/person/some1-thumb.jpg")
>>> thumb = Resource(graph, thumb_ref)
>>> for p, o in thumb.predicate_objects():
...     print(p.qname())
...     print(o.qname())
rdf:type
foaf:Image

```

## Schema Example

With this artificial schema data:

```python
>>> graph = Graph().parse(format='n3', data='''
... @prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
... @prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
... @prefix owl: <http://www.w3.org/2002/07/owl#> .
... @prefix v: <http://example.org/def/v#> .
...
... v:Artifact a owl:Class .
...
... v:Document a owl:Class;
...     rdfs:subClassOf v:Artifact .
...
... v:Paper a owl:Class;
...     rdfs:subClassOf v:Document .
...
... v:Choice owl:oneOf (v:One v:Other) .
...
... v:Stuff a rdf:Seq; rdf:_1 v:One; rdf:_2 v:Other .
...
... ''')

```

From this class:

```python
>>> artifact = Resource(graph, URIRef("http://example.org/def/v#Artifact"))

```

we can get at subclasses:

```python
>>> subclasses = list(artifact.transitive_subjects(RDFS.subClassOf))
>>> [c.qname() for c in subclasses]
['v:Artifact', 'v:Document', 'v:Paper']

```

and superclasses from the last subclass:

```python
>>> [c.qname() for c in subclasses[-1].transitive_objects(RDFS.subClassOf)]
['v:Paper', 'v:Document', 'v:Artifact']

```

Get items from the Choice:

```python
>>> choice = Resource(graph, URIRef("http://example.org/def/v#Choice"))
>>> [it.qname() for it in choice.value(OWL.oneOf).items()]
['v:One', 'v:Other']

```

On add, other resources are auto-unboxed:

```python
>>> paper = Resource(graph, URIRef("http://example.org/def/v#Paper"))
>>> paper.add(RDFS.subClassOf, artifact)
>>> artifact in paper.objects(RDFS.subClassOf) # checks Resource instance
True
>>> (paper._identifier, RDFS.subClassOf, artifact._identifier) in graph
True

```

## Technical Details

Comparison is based on graph and identifier:

```python
>>> g1 = Graph()
>>> t1 = Resource(g1, URIRef("http://example.org/thing"))
>>> t2 = Resource(g1, URIRef("http://example.org/thing"))
>>> t3 = Resource(g1, URIRef("http://example.org/other"))
>>> t4 = Resource(Graph(), URIRef("http://example.org/other"))

>>> t1 is t2
False

>>> t1 == t2
True
>>> t1 != t2
False

>>> t1 == t3
False
>>> t1 != t3
True

>>> t3 != t4
True

>>> t3 < t1 and t1 > t3
True
>>> t1 >= t1 and t1 >= t3
True
>>> t1 <= t1 and t3 <= t1
True

>>> t1 < t1 or t1 < t3 or t3 > t1 or t3 > t3
False

```

Hash is computed from graph and identifier:

```python
>>> g1 = Graph()
>>> t1 = Resource(g1, URIRef("http://example.org/thing"))

>>> hash(t1) == hash(Resource(g1, URIRef("http://example.org/thing")))
True

>>> hash(t1) == hash(Resource(Graph(), t1.identifier))
False
>>> hash(t1) == hash(Resource(Graph(), URIRef("http://example.org/thing")))
False

```

The Resource class is suitable as a base class for mapper toolkits. For
example, consider this utility for accessing RDF properties via qname-like
attributes:

```python
>>> class Item(Resource):
...
...     def __getattr__(self, p):
...         return list(self.objects(self._to_ref(*p.split('_', 1))))
...
...     def _to_ref(self, pfx, name):
...         return URIRef(self._graph.store.namespace(pfx) + name)

```

It works as follows:

```python
>>> graph = Graph().parse(format='n3', data='''
... @prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
... @prefix foaf: <http://xmlns.com/foaf/0.1/> .
...
... @base <http://example.org/> .
... </person/some1#self>
...     foaf:name "Some Body";
...     foaf:depiction </images/person/some1.jpg> .
... </images/person/some1.jpg> rdfs:comment "Just an image"@en .
... ''')

>>> person = Item(graph, URIRef("http://example.org/person/some1#self"))

>>> print(person.foaf_name[0])
Some Body

```

The mechanism for wrapping references as resources cooperates with subclasses.
Therefore, accessing referenced resources automatically creates new `Item`
objects:

```python
>>> isinstance(person.foaf_depiction[0], Item)
True

>>> print(person.foaf_depiction[0].rdfs_comment[0])
Just an image

```
    )RDF)Path)BNodeNodeURIRefResourcec                   $   e Zd ZdZd Zed             Zed             Zd Zd Z	d Z
d Zd	 Zd
 Zd Zd Zd Zd'dZd Zd'dZd'dZd'dZd Zd Zd Zej        dddfdZd Zd'dZd'dZd Zd Zd Z d Z!d  Z"d! Z#d" Z$d# Z%d$ Z&d% Z'd& Z(dS )(r   z>A Resource is a wrapper for a graph and a resource identifier.c                 "    || _         || _        d S N_graph_identifier)selfgraphsubjects      c/home/jaya/work/projects/VOICE-AGENT/VIET/agent-env/lib/python3.11/site-packages/rdflib/resource.py__init__zResource.__init__k  s    "    c                     | j         S r   )r   r   s    r   r   zResource.grapho  s
    {r   c                     | j         S r   r   r   s    r   
identifierzResource.identifiers  s    r   c                 ~    t          t                    t          | j                  z  t          | j                  z  S r   )hashr   r   r   r   s    r   __hash__zResource.__hash__w  s-    H~~T[ 1 11D9I4J4JJJr   c                 l    t          |t                    o| j        |j        k    o| j        |j        k    S r   )
isinstancer   r   r   r   others     r   __eq__zResource.__eq__z  s8    uh'' 6u|+6 E$55	
r   c                     | |k     S r    r   s     r   __ne__zResource.__ne__  s    5=  r   c                 P    t          |t                    r| j        |j        k     S dS )NF)r   r   r   r   s     r   __lt__zResource.__lt__  s*    eX&& 	#e&7775r   c                     | |k     p| |k     S r   r#   r   s     r   __gt__zResource.__gt__  s    5L1DEM22r   c                     | |k     p| |k    S r   r#   r   s     r   __le__zResource.__le__  s    e|,tu},r   c                     | |k      S r   r#   r   s     r   __ge__zResource.__ge__  s    %<r   c                 *    t          | j                  S r   )strr   r   s    r   __unicode__zResource.__unicode__  s    4#$$$r   c                     t          |t                    r|j        }| j                            | j        ||f           d S r   )r   r   r   r   addr   pos      r   r1   zResource.add  ?    a"" 	A)1a011111r   Nc                     t          |t                    r|j        }| j                            | j        ||f           d S r   )r   r   r   r   remover2   s      r   r7   zResource.remove  sA    a"" 	AD,a344444r   c                     t          |t                    r|j        }| j                            | j        ||f           d S r   )r   r   r   r   setr2   s      r   r9   zResource.set  r5   r   c                 h    |                      | j                            || j                            S r   )
_resourcesr   subjectsr   r   	predicates     r   r<   zResource.subjects  s)    t{33It?OPPQQQr   c                     t          |t                    r|j        }|                     | j                            | j        |                    S r   )r   r   r   r;   r   
predicates)r   r4   s     r   r@   zResource.predicates  sB    a"" 	At{55d6FJJKKKr   c                 h    |                      | j                            | j        |                    S r   )r;   r   objectsr   r=   s     r   rB   zResource.objects  s)    t{2243CYOOPPPr   c                 f    |                      | j                            | j                            S r   )_resource_pairsr   subject_predicatesr   r   s    r   rE   zResource.subject_predicates  s)    ##DK$B$B4CS$T$TUUUr   c                 f    |                      | j                            | j                            S r   )rD   r   subject_objectsr   r   s    r   rG   zResource.subject_objects  s)    ##DK$?$?@P$Q$QRRRr   c                 f    |                      | j                            | j                            S r   )rD   r   predicate_objectsr   r   s    r   rI   zResource.predicate_objects  s)    ##DK$A$A$BR$S$STTTr   Tc           	          t          |t                    r|j        }|                     | j                            | j        ||||                    S r   )r   r   r   _castr   value)r   r3   r4   defaultanys        r   rL   zResource.value  sH    a"" 	Azz$+++D,<aGSQQRRRr   c                 f    |                      | j                            | j                            S r   )r;   r   itemsr   r   s    r   rP   zResource.items  s'    t{001ABBCCCr   c                 j    |                      | j                            | j        ||                    S r   )r;   r   transitive_objectsr   r   r>   remembers      r   rR   zResource.transitive_objects  s2    K**4+;YQQ
 
 	
r   c                 j    |                      | j                            || j        |                    S r   )r;   r   transitive_subjectsr   rS   s      r   rV   zResource.transitive_subjects  s2    K++It7GRR
 
 	
r   c                 @    | j                             | j                  S r   )r   qnamer   r   s    r   rX   zResource.qname  s    {  !1222r   c              #   r   K   |D ]1\  }}|                      |          |                      |          fV  2d S r   rK   )r   pairss1s2s       r   rD   zResource._resource_pairs  sK       	1 	1FB**R..$**R..00000	1 	1r   c              #      K   |D ]F\  }}}|                      |          |                      |          |                      |          fV  Gd S r   rZ   )r   triplessr3   r4   s        r   _resource_tripleszResource._resource_triples  sY       	> 	>GAq!**Q--A

1=====	> 	>r   c              #   B   K   |D ]}|                      |          V  d S r   rZ   )r   nodesnodes      r   r;   zResource._resources  s:       	# 	#D**T""""""	# 	#r   c                 h    t          |t          t          f          r|                     |          S |S r   )r   r   r   _new)r   rd   s     r   rK   zResource._cast  s-    dUFO,, 	99T??"Kr   c                 l    |                      | j                            | j        d d f                    S r   )ra   r   r_   r   r   s    r   __iter__zResource.__iter__  s6    %%K$ =>>
 
 	
r   c                 :   t          |t                    r|j        rt          d          |j        |j        }}t          |t                    r|j        }t          |t                    r|j        }|||                                 S || 	                    |          S || 
                    |          S | j        ||f| j        v S t          |t          t          f          r| 
                    |          S t          d|dt          |          d          )NzSResources fix the subject for slicing, and can only be sliced by predicate/object. zTYou can only index a resource by a single rdflib term, a slice of rdflib terms, not z ())r   slicestep	TypeErrorstartstopr   r   rI   r@   rB   r   r   r   r   type)r   itemr3   r4   s       r   __getitem__zResource.__getitem__  s%   dE"" 	y i   :tyqA!X&& "M!X&& "MyQY--///q)))||A&A.$+==tTl++ 	<<%%%)44d%  r   c                 2    |                      ||           d S r   )r9   )r   rq   rL   s      r   __setitem__zResource.__setitem__  s    ur   c                 >     t          |           | j        |          S r   )rp   r   )r   r   s     r   rf   zResource._new  s    tDzz$+w///r   c                     d| j         z  S )NzResource(%s)r   r   s    r   __str__zResource.__str__  s     000r   c                 (    d| j         d| j        dS )Nz	Resource(,rj   r   r   s    r   __repr__zResource.__repr__  s     $(KKK1A1A1ABBr   r   ))__name__
__module____qualname____doc__r   propertyr   r   r   r!   r$   r&   r(   r*   r,   r/   r1   r7   r9   r<   r@   rB   rE   rG   rI   r   rL   rP   rR   rV   rX   rD   ra   r;   rK   rh   rr   rt   rf   rw   rz   r#   r   r   r   r   h  s       HH# # #   X     X K K K
 
 
! ! !  3 3 3- - -     % % %2 2 25 5 5 52 2 2R R R RL L L LQ Q Q QV V VS S SU U U i44 S S S SD D D
 
 
 


 
 
 

3 3 31 1 1> > ># # #  
 
 

  6  0 0 01 1 1C C C C Cr   N)r~   rdflib.namespacer   rdflib.pathsr   rdflib.termr   r   r   __all__r   r#   r   r   <module>r      s   ^ ^@ !                 + + + + + + + + + +,gC gC gC gC gC gC gC gC gC gCr   