mq-crawler 0.5.23

Directory crawler for batch Markdown file processing
Documentation
//! Web crawler for collecting markdown content from websites.
//!
//! This crate provides functionality to crawl websites and extract markdown content.
//! It respects robots.txt, handles concurrent requests, and converts HTML to markdown
//! for batch processing with mq.
//!
//! # Features
//!
//! - Asynchronous web crawling with configurable concurrency
//! - robots.txt compliance
//! - HTML to markdown conversion
//! - Link discovery and following
//! - Crawl statistics and result tracking
//! - Support for custom HTTP headers and user agents
//! - Rate limiting and politeness delays
//!
//! # Usage
//!
//! ```rust,ignore
//! use mq_crawler::crawler::Crawler;
//! use url::Url;
//!
//! #[tokio::main]
//! async fn main() -> Result<(), Box<dyn std::error::Error>> {
//!     let start_url = Url::parse("https://your-target-site.com")?;
//!     let crawler = Crawler::new(start_url, None, 10);
//!     let result = crawler.crawl().await?;
//!     println!("Crawled {} pages", result.pages_crawled);
//!     Ok(())
//! }
//! ```
//!
//! # Crawling Behavior
//!
//! The crawler:
//! - Starts from a specified URL
//! - Follows links found on each page
//! - Respects robots.txt directives
//! - Limits depth and breadth of crawling
//! - Converts HTML pages to markdown
//! - Tracks statistics about the crawl
//!
pub mod crawler;
pub mod http_client;
pub mod robots;