//! Issue/PR exporter for GitHub. //! //! # dumplingh as а library //! //! ## Data flow //! //! ```plaintext //! Options::parse() //! |> list_{pull_requests,issues}() //! |> save_{to_file,data}() //! ``` //! //! ## Example //! //! ``` //! # use dumplingh::ops::{save_to_file, list_pull_requests}; //! # use std::env::temp_dir; //! # use std::fs; //! # /* //! let out_path = "pulls.json"; //! # */ //! # let mut out_path = temp_dir().join("dumplingh-doctest"); //! # fs::create_dir_all(&out_path).unwrap(); //! # out_path.push("pulls.json"); //! let repo = "nabijaczleweli/cargo-update".parse().unwrap(); //! let pulls = list_pull_requests(&repo, None).unwrap(); //! save_to_file(out_path, &pulls, false, "pull requests").unwrap(); //! ``` //! //! # dumplingh as аn executable //! //! This is just a very short synopsis of //! [the manpage](https://cdn.rawgit.com/nabijaczleweli/dumplingh/man/dumplingh.1.html), //! so consult that for more data. //! //! ## OPTIONS //! //! | Option | Description | //! |--------------------------------------|--------------------------------------------------------------------------| //! | <REPO_SLUG> | Repository to export issues and PRs for in the form `/`. | //! | --issues <ISSUES_FILE> | File to export issues to, or `./-issues.json` by default. | //! | --pulls <PULLS_FILE> | File to export pull requests to, or `./-pulls.json` by default. | //! | --labels <LABELS_FILE> | File to export labels to, or `./-labels.json` by default. | //! | --milestones <MILESTONES_FILE> | File to export milestones to, or `./-milestones.json` by default. | //! | --projects <PROJECTS_FILE> | File to export projects to, or `./-projects.json` by default. | //! | --comments <COMMENTS_DIR> | Directory to export comments to, or `./-comments` by default. | //! | --auth [AUTH_TOKEN] | GitHub OAuth2 token, required for projects. | //! | --no-issues | Don't export issues. | //! | --no-pulls | Don't export pull requests. | //! | --no-labels | Don't export labels. | //! | --no-milestones | Don't export milestones. | //! | --no-projects | Don't export projects. | //! | --no-comments | Don't export comments. | //! | --force | Override existing files. | //! | --compact | Don't pretty-print exported JSON. | #[macro_use] extern crate lazy_static; extern crate serde_json; extern crate reqwest; extern crate serde; #[macro_use] extern crate clap; mod error; mod options; pub mod ops; pub mod util; pub use self::error::Error; pub use self::options::Options;