Crates.io | sitemap |
lib.rs | sitemap |
version | 0.4.1 |
source | src |
created_at | 2017-01-03 11:46:02.389423 |
updated_at | 2020-11-03 01:07:10.076829 |
description | Sitemap parser (reader) and writer |
homepage | |
repository | https://github.com/svmk/rust-sitemap |
max_upload_size | |
id | 7902 |
size | 37,708 |
sitemap is an library for Rust programming language.
sitemap uses Cargo, so just add a dependency section in your project's manifest:
[dependencies]
sitemap = "0.4"
sitemap::reader::SiteMapReader
requires a Read
instance to read from. When a proper stream-based encoding library is available, it is likely that sitemap will be switched to use whatever character stream structure this library would provide, but currently it is a Read
.
Using SiteMapReader
is very straightforward. Just provide a Read
instance to obtain an iterator over events:
use sitemap::reader::{SiteMapReader,SiteMapEntity};
use std::fs::File;
fn main() {
let mut urls = Vec::new();
let mut sitemaps = Vec::new();
let mut errors = Vec::new();
let file = File::open("sitemap.xml").expect("Unable to open file.");
let parser = SiteMapReader::new(file);
for entity in parser {
match entity {
SiteMapEntity::Url(url_entry) => {
urls.push(url_entry);
},
SiteMapEntity::SiteMap(sitemap_entry) => {
sitemaps.push(sitemap_entry);
},
SiteMapEntity::Err(error) => {
errors.push(error);
},
}
}
println!("urls = {:?}",urls);
println!("sitemaps = {:?}",sitemaps);
println!("errors = {:?}",errors);
}
use sitemap::writer::SiteMapWriter;
use sitemap::structs::UrlEntry;
use std::io::stdout;
fn main() {
let mut output = stdout();
let sitemap_writer = SiteMapWriter::new(&mut output);
let mut urlwriter = sitemap_writer.start_urlset().expect("Unable to write urlset");
urlwriter.url("http://github.com").expect("Unable to write url");
urlwriter.url(UrlEntry::builder().loc("http://google.com")).expect("Unable to write url");
urlwriter.url(UrlEntry::builder().loc("http://yandex.ru").build().unwrap()).expect("Unable to write url");
urlwriter.end().expect("Unable to write close tags");
}
Highest priority first, approximately.
All known issues are present on GitHub issue tracker: http://github.com/svmk/sitemap/issues. Feel free to post any found problems there.
This library is licensed under MIT license.