1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*!
* ![core](https://img.shields.io/badge/RDFtk-core-BD1B89?logo=)
* This crate provides an implementation of the RDF abstract syntax along with a `Resource` type
* that provides a builder-like experience for models.
*
* From [RDF 1.1 Concepts and Abstract Syntax](https://www.w3.org/TR/rdf11-concepts/);
*
* > The core structure of the abstract syntax is a set of triples, each consisting of a subject, a
* > predicate and an object. A set of such triples is called an RDF graph. An RDF graph can be
* > visualized as a node and directed-arc diagram, in which each triple is represented as a
* > node-arc-node link.
* >
* > ![rdf-graph](https://raw.githubusercontent.com/johnstonskj/rust-rdftk/master/rdftk_core/doc/rdf-graph.svg)
* >
* > There can be three kinds of nodes in an RDF graph: IRIs, literals, and blank nodes.
*
* In this library the triple, or statement, as well as subject, predicate, and object types are
* in the module [`statement`](statement/index.html). Literal's as objects are supported in the
* [`literal`](literal/index.html) module. Traits that describe graphs are provided by the
* [`graph`](graph/index.html) module.
*
* Additional features are provided such as support for data sets (module [`model.data_set`](model.data_set/index.html))
* as well as support for extensions to the core RDF abstract model such as
* [RDF-star](https://w3c.github.io/rdf-star/cg-spec/editors_draft.html).
*
* # Example
*
* ```rust
* use rdftk_core::model::statement::{ObjectNode, Statement, StatementList, SubjectNode};
* use rdftk_core::simple;
* use rdftk_iri::IRI;
* use std::rc::Rc;
* use std::str::FromStr;
*
* let mut statements: StatementList = Default::default();
* let factory = simple::statement::statement_factory();
* let literal = simple::literal::literal_factory();
*
* statements.push(factory.statement(
*     factory.named_subject(IRI::from_str("http://en.wikipedia.org/wiki/Tony_Benn").unwrap().into()),
*     IRI::from_str("http://purl.org/dc/elements/1.1/title").unwrap().into(),
*     factory.literal_object(literal.string("Tony Benn")),
* ).unwrap());
* ```
*
*/

#![warn(
    // ---------- Stylistic
    future_incompatible,
    nonstandard_style,
    rust_2018_idioms,
    trivial_casts,
    trivial_numeric_casts,
    // ---------- Public
    missing_debug_implementations,
    missing_docs,
    unreachable_pub,
    // ---------- Unsafe
    unsafe_code,
    // ---------- Unused
    unused_extern_crates,
    unused_import_braces,
    unused_qualifications,
    unused_results,
)]

#[macro_use]
extern crate error_chain;

#[macro_use]
extern crate lazy_static;

#[macro_use]
extern crate pest_derive;

// ------------------------------------------------------------------------------------------------
// Modules
// ------------------------------------------------------------------------------------------------

#[macro_use]
pub mod error;

pub mod model;

pub mod simple;