mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-22 17:32:06 +00:00
Remove removed rustc features.
* 'crate_visibility_modifier' * 'external_doc' Closes #2205.
This commit is contained in:
parent
08e5b6dd0d
commit
5824f56c4e
@ -18,7 +18,7 @@ database_attribute = []
|
|||||||
proc-macro = true
|
proc-macro = true
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
devise = "0.2"
|
devise = "0.2.1"
|
||||||
quote = "0.6"
|
quote = "0.6"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#![feature(proc_macro_span, proc_macro_diagnostic)]
|
#![feature(proc_macro_span, proc_macro_diagnostic)]
|
||||||
#![feature(crate_visibility_modifier)]
|
|
||||||
#![recursion_limit="256"]
|
#![recursion_limit="256"]
|
||||||
|
|
||||||
//! # Rocket Contrib - Code Generation
|
//! # Rocket Contrib - Code Generation
|
||||||
@ -31,7 +30,7 @@ extern crate proc_macro;
|
|||||||
#[macro_use] extern crate quote;
|
#[macro_use] extern crate quote;
|
||||||
|
|
||||||
#[allow(unused_imports)]
|
#[allow(unused_imports)]
|
||||||
crate use devise::{syn, proc_macro2};
|
pub(crate) use devise::{syn, proc_macro2};
|
||||||
|
|
||||||
#[cfg(feature = "database_attribute")]
|
#[cfg(feature = "database_attribute")]
|
||||||
mod database;
|
mod database;
|
||||||
|
@ -63,7 +63,7 @@ pub trait Policy: Default + Send + Sync + 'static {
|
|||||||
fn header(&self) -> Header<'static>;
|
fn header(&self) -> Header<'static>;
|
||||||
}
|
}
|
||||||
|
|
||||||
crate trait SubPolicy: Send + Sync {
|
pub(crate) trait SubPolicy: Send + Sync {
|
||||||
fn name(&self) -> &'static UncasedStr;
|
fn name(&self) -> &'static UncasedStr;
|
||||||
fn header(&self) -> Header<'static>;
|
fn header(&self) -> Header<'static>;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
#![feature(crate_visibility_modifier)]
|
|
||||||
#![feature(never_type)]
|
#![feature(never_type)]
|
||||||
#![feature(doc_cfg)]
|
#![feature(doc_cfg)]
|
||||||
|
|
||||||
|
@ -5,13 +5,13 @@ use templates::{glob, Engines, TemplateInfo};
|
|||||||
|
|
||||||
use rocket::http::ContentType;
|
use rocket::http::ContentType;
|
||||||
|
|
||||||
crate struct Context {
|
pub(crate) struct Context {
|
||||||
/// The root of the template directory.
|
/// The root of the template directory.
|
||||||
crate root: PathBuf,
|
pub(crate) root: PathBuf,
|
||||||
/// Mapping from template name to its information.
|
/// Mapping from template name to its information.
|
||||||
crate templates: HashMap<String, TemplateInfo>,
|
pub(crate) templates: HashMap<String, TemplateInfo>,
|
||||||
/// Loaded template engines
|
/// Loaded template engines
|
||||||
crate engines: Engines,
|
pub(crate) engines: Engines,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Context {
|
impl Context {
|
||||||
|
@ -5,7 +5,7 @@ use templates::{TemplateInfo, serde::Serialize};
|
|||||||
#[cfg(feature = "tera_templates")] use templates::tera::Tera;
|
#[cfg(feature = "tera_templates")] use templates::tera::Tera;
|
||||||
#[cfg(feature = "handlebars_templates")] use templates::handlebars::Handlebars;
|
#[cfg(feature = "handlebars_templates")] use templates::handlebars::Handlebars;
|
||||||
|
|
||||||
crate trait Engine: Send + Sync + 'static {
|
pub(crate) trait Engine: Send + Sync + 'static {
|
||||||
const EXT: &'static str;
|
const EXT: &'static str;
|
||||||
|
|
||||||
fn init(templates: &[(&str, &TemplateInfo)]) -> Option<Self> where Self: Sized;
|
fn init(templates: &[(&str, &TemplateInfo)]) -> Option<Self> where Self: Sized;
|
||||||
@ -58,12 +58,12 @@ pub struct Engines {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Engines {
|
impl Engines {
|
||||||
crate const ENABLED_EXTENSIONS: &'static [&'static str] = &[
|
pub(crate) const ENABLED_EXTENSIONS: &'static [&'static str] = &[
|
||||||
#[cfg(feature = "tera_templates")] Tera::EXT,
|
#[cfg(feature = "tera_templates")] Tera::EXT,
|
||||||
#[cfg(feature = "handlebars_templates")] Handlebars::EXT,
|
#[cfg(feature = "handlebars_templates")] Handlebars::EXT,
|
||||||
];
|
];
|
||||||
|
|
||||||
crate fn init(templates: &HashMap<String, TemplateInfo>) -> Option<Engines> {
|
pub(crate) fn init(templates: &HashMap<String, TemplateInfo>) -> Option<Engines> {
|
||||||
fn inner<E: Engine>(templates: &HashMap<String, TemplateInfo>) -> Option<E> {
|
fn inner<E: Engine>(templates: &HashMap<String, TemplateInfo>) -> Option<E> {
|
||||||
let named_templates = templates.iter()
|
let named_templates = templates.iter()
|
||||||
.filter(|&(_, i)| i.extension == E::EXT)
|
.filter(|&(_, i)| i.extension == E::EXT)
|
||||||
@ -87,7 +87,7 @@ impl Engines {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn render<C: Serialize>(
|
pub(crate) fn render<C: Serialize>(
|
||||||
&self,
|
&self,
|
||||||
name: &str,
|
name: &str,
|
||||||
info: &TemplateInfo,
|
info: &TemplateInfo,
|
||||||
|
@ -4,7 +4,7 @@ use rocket::Rocket;
|
|||||||
use rocket::config::ConfigError;
|
use rocket::config::ConfigError;
|
||||||
use rocket::fairing::{Fairing, Info, Kind};
|
use rocket::fairing::{Fairing, Info, Kind};
|
||||||
|
|
||||||
crate use self::context::ContextManager;
|
pub(crate) use self::context::ContextManager;
|
||||||
|
|
||||||
#[cfg(not(debug_assertions))]
|
#[cfg(not(debug_assertions))]
|
||||||
mod context {
|
mod context {
|
||||||
@ -13,18 +13,18 @@ mod context {
|
|||||||
|
|
||||||
/// Wraps a Context. With `cfg(debug_assertions)` active, this structure
|
/// Wraps a Context. With `cfg(debug_assertions)` active, this structure
|
||||||
/// additionally provides a method to reload the context at runtime.
|
/// additionally provides a method to reload the context at runtime.
|
||||||
crate struct ContextManager(Context);
|
pub(crate) struct ContextManager(Context);
|
||||||
|
|
||||||
impl ContextManager {
|
impl ContextManager {
|
||||||
crate fn new(ctxt: Context) -> ContextManager {
|
pub(crate) fn new(ctxt: Context) -> ContextManager {
|
||||||
ContextManager(ctxt)
|
ContextManager(ctxt)
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn context<'a>(&'a self) -> impl Deref<Target=Context> + 'a {
|
pub(crate) fn context<'a>(&'a self) -> impl Deref<Target=Context> + 'a {
|
||||||
&self.0
|
&self.0
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn is_reloading(&self) -> bool {
|
pub(crate) fn is_reloading(&self) -> bool {
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -44,7 +44,7 @@ mod context {
|
|||||||
|
|
||||||
/// Wraps a Context. With `cfg(debug_assertions)` active, this structure
|
/// Wraps a Context. With `cfg(debug_assertions)` active, this structure
|
||||||
/// additionally provides a method to reload the context at runtime.
|
/// additionally provides a method to reload the context at runtime.
|
||||||
crate struct ContextManager {
|
pub(crate) struct ContextManager {
|
||||||
/// The current template context, inside an RwLock so it can be updated.
|
/// The current template context, inside an RwLock so it can be updated.
|
||||||
context: RwLock<Context>,
|
context: RwLock<Context>,
|
||||||
/// A filesystem watcher and the receive queue for its events.
|
/// A filesystem watcher and the receive queue for its events.
|
||||||
@ -52,7 +52,7 @@ mod context {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl ContextManager {
|
impl ContextManager {
|
||||||
crate fn new(ctxt: Context) -> ContextManager {
|
pub(crate) fn new(ctxt: Context) -> ContextManager {
|
||||||
let (tx, rx) = channel();
|
let (tx, rx) = channel();
|
||||||
let watcher = raw_watcher(tx).and_then(|mut watcher| {
|
let watcher = raw_watcher(tx).and_then(|mut watcher| {
|
||||||
watcher.watch(ctxt.root.canonicalize()?, RecursiveMode::Recursive)?;
|
watcher.watch(ctxt.root.canonicalize()?, RecursiveMode::Recursive)?;
|
||||||
@ -75,11 +75,11 @@ mod context {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn context<'a>(&'a self) -> impl Deref<Target=Context> + 'a {
|
pub(crate) fn context<'a>(&'a self) -> impl Deref<Target=Context> + 'a {
|
||||||
self.context.read().unwrap()
|
self.context.read().unwrap()
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn is_reloading(&self) -> bool {
|
pub(crate) fn is_reloading(&self) -> bool {
|
||||||
self.watcher.is_some()
|
self.watcher.is_some()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,7 +91,7 @@ mod context {
|
|||||||
/// have been changes since the last reload, all templates are
|
/// have been changes since the last reload, all templates are
|
||||||
/// reinitialized from disk and the user's customization callback is run
|
/// reinitialized from disk and the user's customization callback is run
|
||||||
/// again.
|
/// again.
|
||||||
crate fn reload_if_needed<F: Fn(&mut Engines)>(&self, custom_callback: F) {
|
pub(crate) fn reload_if_needed<F: Fn(&mut Engines)>(&self, custom_callback: F) {
|
||||||
self.watcher.as_ref().map(|w| {
|
self.watcher.as_ref().map(|w| {
|
||||||
let rx_lock = w.lock().expect("receive queue lock");
|
let rx_lock = w.lock().expect("receive queue lock");
|
||||||
let mut changed = false;
|
let mut changed = false;
|
||||||
@ -123,7 +123,7 @@ pub struct TemplateFairing {
|
|||||||
/// The user-provided customization callback, allowing the use of
|
/// The user-provided customization callback, allowing the use of
|
||||||
/// functionality specific to individual template engines. In debug mode,
|
/// functionality specific to individual template engines. In debug mode,
|
||||||
/// this callback might be run multiple times as templates are reloaded.
|
/// this callback might be run multiple times as templates are reloaded.
|
||||||
crate custom_callback: Box<dyn Fn(&mut Engines) + Send + Sync + 'static>,
|
pub(crate) custom_callback: Box<dyn Fn(&mut Engines) + Send + Sync + 'static>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Fairing for TemplateFairing {
|
impl Fairing for TemplateFairing {
|
||||||
|
@ -128,8 +128,8 @@ mod metadata;
|
|||||||
|
|
||||||
pub use self::engine::Engines;
|
pub use self::engine::Engines;
|
||||||
pub use self::metadata::Metadata;
|
pub use self::metadata::Metadata;
|
||||||
crate use self::context::Context;
|
pub(crate) use self::context::Context;
|
||||||
crate use self::fairing::ContextManager;
|
pub(crate) use self::fairing::ContextManager;
|
||||||
|
|
||||||
use self::engine::Engine;
|
use self::engine::Engine;
|
||||||
use self::fairing::TemplateFairing;
|
use self::fairing::TemplateFairing;
|
||||||
@ -208,7 +208,7 @@ pub struct Template {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct TemplateInfo {
|
pub(crate) struct TemplateInfo {
|
||||||
/// The complete path, including `template_dir`, to this template.
|
/// The complete path, including `template_dir`, to this template.
|
||||||
path: PathBuf,
|
path: PathBuf,
|
||||||
/// The extension for the engine of this template.
|
/// The extension for the engine of this template.
|
||||||
|
@ -18,7 +18,7 @@ proc-macro = true
|
|||||||
indexmap = "1.0"
|
indexmap = "1.0"
|
||||||
quote = "0.6.1"
|
quote = "0.6.1"
|
||||||
rocket_http = { version = "0.4.10", path = "../http/" }
|
rocket_http = { version = "0.4.10", path = "../http/" }
|
||||||
devise = "0.2"
|
devise = "0.2.1"
|
||||||
glob = "0.3"
|
glob = "0.3"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
|
@ -7,15 +7,15 @@ use http::uri::{UriPart, Path};
|
|||||||
use http::route::RouteSegment;
|
use http::route::RouteSegment;
|
||||||
use proc_macro_ext::{Diagnostics, StringLit, PResult, DResult};
|
use proc_macro_ext::{Diagnostics, StringLit, PResult, DResult};
|
||||||
|
|
||||||
crate use http::route::{Error, Kind, Source};
|
pub(crate) use http::route::{Error, Kind, Source};
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
crate struct Segment {
|
pub(crate) struct Segment {
|
||||||
crate span: Span,
|
pub(crate) span: Span,
|
||||||
crate kind: Kind,
|
pub(crate) kind: Kind,
|
||||||
crate source: Source,
|
pub(crate) source: Source,
|
||||||
crate name: String,
|
pub(crate) name: String,
|
||||||
crate index: Option<usize>,
|
pub(crate) index: Option<usize>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Segment {
|
impl Segment {
|
||||||
@ -115,7 +115,7 @@ fn into_diagnostic(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn parse_data_segment(segment: &str, span: Span) -> PResult<Segment> {
|
pub(crate) fn parse_data_segment(segment: &str, span: Span) -> PResult<Segment> {
|
||||||
<RouteSegment<Path>>::parse_one(segment)
|
<RouteSegment<Path>>::parse_one(segment)
|
||||||
.map(|segment| {
|
.map(|segment| {
|
||||||
let mut seg = Segment::from(segment, span);
|
let mut seg = Segment::from(segment, span);
|
||||||
@ -126,7 +126,7 @@ crate fn parse_data_segment(segment: &str, span: Span) -> PResult<Segment> {
|
|||||||
.map_err(|e| into_diagnostic(segment, segment, span, &e))
|
.map_err(|e| into_diagnostic(segment, segment, span, &e))
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn parse_segments<P: UriPart>(
|
pub(crate) fn parse_segments<P: UriPart>(
|
||||||
string: &str,
|
string: &str,
|
||||||
span: Span
|
span: Span
|
||||||
) -> DResult<Vec<Segment>> {
|
) -> DResult<Vec<Segment>> {
|
||||||
|
@ -10,7 +10,7 @@ mod uri;
|
|||||||
mod uri_parsing;
|
mod uri_parsing;
|
||||||
mod test_guide;
|
mod test_guide;
|
||||||
|
|
||||||
crate fn prefix_last_segment(path: &mut Path, prefix: &str) {
|
pub(crate) fn prefix_last_segment(path: &mut Path, prefix: &str) {
|
||||||
let mut last_seg = path.segments.last_mut().expect("syn::Path has segments");
|
let mut last_seg = path.segments.last_mut().expect("syn::Path has segments");
|
||||||
last_seg.value_mut().ident = last_seg.value().ident.prepend(prefix);
|
last_seg.value_mut().ident = last_seg.value().ident.prepend(prefix);
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@ fn entry_to_modules(pat: &LitStr) -> std::result::Result<Vec<TokenStream2>, Box<
|
|||||||
let ident = Ident::new(&name, pat.span());
|
let ident = Ident::new(&name, pat.span());
|
||||||
let full_path = Path::new(&manifest_dir).join(&path).display().to_string();
|
let full_path = Path::new(&manifest_dir).join(&path).display().to_string();
|
||||||
modules.push(quote_spanned!(pat.span() =>
|
modules.push(quote_spanned!(pat.span() =>
|
||||||
#[doc(include = #full_path)]
|
#[doc = include_str!(#full_path)]
|
||||||
struct #ident;
|
struct #ident;
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,7 @@ macro_rules! p {
|
|||||||
($n:expr, "parameter") => (p!(@go $n, "1 parameter", format!("{} parameters", $n)));
|
($n:expr, "parameter") => (p!(@go $n, "1 parameter", format!("{} parameters", $n)));
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn _uri_macro(input: TokenStream) -> Result<TokenStream> {
|
pub(crate) fn _uri_macro(input: TokenStream) -> Result<TokenStream> {
|
||||||
let input2: TokenStream2 = input.clone().into();
|
let input2: TokenStream2 = input.clone().into();
|
||||||
let mut params = syn::parse::<UriParams>(input).map_err(syn_to_diag)?;
|
let mut params = syn::parse::<UriParams>(input).map_err(syn_to_diag)?;
|
||||||
prefix_last_segment(&mut params.route_path, URI_MACRO_PREFIX);
|
prefix_last_segment(&mut params.route_path, URI_MACRO_PREFIX);
|
||||||
@ -212,7 +212,7 @@ fn build_origin(internal: &InternalUriParams) -> Origin<'static> {
|
|||||||
Origin::new(path, query).to_normalized().into_owned()
|
Origin::new(path, query).to_normalized().into_owned()
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn _uri_internal_macro(input: TokenStream) -> Result<TokenStream> {
|
pub(crate) fn _uri_internal_macro(input: TokenStream) -> Result<TokenStream> {
|
||||||
// Parse the internal invocation and the user's URI param expressions.
|
// Parse the internal invocation and the user's URI param expressions.
|
||||||
let internal = syn::parse::<InternalUriParams>(input).map_err(syn_to_diag)?;
|
let internal = syn::parse::<InternalUriParams>(input).map_err(syn_to_diag)?;
|
||||||
let (path_params, query_params) = extract_exprs(&internal)?;
|
let (path_params, query_params) = extract_exprs(&internal)?;
|
||||||
|
@ -2,13 +2,13 @@ use proc_macro::{Span, TokenStream};
|
|||||||
use devise::{*, ext::{TypeExt, Split3}};
|
use devise::{*, ext::{TypeExt, Split3}};
|
||||||
|
|
||||||
#[derive(FromMeta)]
|
#[derive(FromMeta)]
|
||||||
crate struct Form {
|
pub(crate) struct Form {
|
||||||
crate field: FormField,
|
pub(crate) field: FormField,
|
||||||
}
|
}
|
||||||
|
|
||||||
crate struct FormField {
|
pub(crate) struct FormField {
|
||||||
crate span: Span,
|
pub(crate) span: Span,
|
||||||
crate name: String
|
pub(crate) name: String
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_valid_field_name(s: &str) -> bool {
|
fn is_valid_field_name(s: &str) -> bool {
|
||||||
|
@ -8,25 +8,25 @@ use attribute::segments::{parse_segments, parse_data_segment, Segment, Kind};
|
|||||||
use proc_macro_ext::StringLit;
|
use proc_macro_ext::StringLit;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct ContentType(crate http::ContentType);
|
pub(crate) struct ContentType(pub(crate) http::ContentType);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct Status(crate http::Status);
|
pub(crate) struct Status(pub(crate) http::Status);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct MediaType(crate http::MediaType);
|
pub(crate) struct MediaType(pub(crate) http::MediaType);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct Method(crate http::Method);
|
pub(crate) struct Method(pub(crate) http::Method);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct Origin(crate http::uri::Origin<'static>);
|
pub(crate) struct Origin(pub(crate) http::uri::Origin<'static>);
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
crate struct DataSegment(crate Segment);
|
pub(crate) struct DataSegment(pub(crate) Segment);
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
crate struct Optional<T>(crate Option<T>);
|
pub(crate) struct Optional<T>(pub(crate) Option<T>);
|
||||||
|
|
||||||
impl FromMeta for StringLit {
|
impl FromMeta for StringLit {
|
||||||
fn from_meta(meta: MetaItem) -> Result<Self> {
|
fn from_meta(meta: MetaItem) -> Result<Self> {
|
||||||
@ -35,10 +35,10 @@ impl FromMeta for StringLit {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
crate struct RoutePath {
|
pub(crate) struct RoutePath {
|
||||||
crate origin: Origin,
|
pub(crate) origin: Origin,
|
||||||
crate path: Vec<Segment>,
|
pub(crate) path: Vec<Segment>,
|
||||||
crate query: Option<Vec<Segment>>,
|
pub(crate) query: Option<Vec<Segment>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FromMeta for Status {
|
impl FromMeta for Status {
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#![feature(proc_macro_diagnostic, proc_macro_span)]
|
#![feature(proc_macro_diagnostic, proc_macro_span)]
|
||||||
#![feature(crate_visibility_modifier)]
|
|
||||||
#![recursion_limit="128"]
|
#![recursion_limit="128"]
|
||||||
|
|
||||||
#![doc(html_root_url = "https://api.rocket.rs/v0.4")]
|
#![doc(html_root_url = "https://api.rocket.rs/v0.4")]
|
||||||
@ -119,14 +118,14 @@ mod syn_ext;
|
|||||||
|
|
||||||
use http::Method;
|
use http::Method;
|
||||||
use proc_macro::TokenStream;
|
use proc_macro::TokenStream;
|
||||||
crate use devise::proc_macro2;
|
pub(crate) use devise::proc_macro2;
|
||||||
|
|
||||||
crate static ROUTE_STRUCT_PREFIX: &str = "static_rocket_route_info_for_";
|
pub(crate) static ROUTE_STRUCT_PREFIX: &str = "static_rocket_route_info_for_";
|
||||||
crate static CATCH_STRUCT_PREFIX: &str = "static_rocket_catch_info_for_";
|
pub(crate) static CATCH_STRUCT_PREFIX: &str = "static_rocket_catch_info_for_";
|
||||||
crate static CATCH_FN_PREFIX: &str = "rocket_catch_fn_";
|
pub(crate) static CATCH_FN_PREFIX: &str = "rocket_catch_fn_";
|
||||||
crate static ROUTE_FN_PREFIX: &str = "rocket_route_fn_";
|
pub(crate) static ROUTE_FN_PREFIX: &str = "rocket_route_fn_";
|
||||||
crate static URI_MACRO_PREFIX: &str = "rocket_uri_macro_";
|
pub(crate) static URI_MACRO_PREFIX: &str = "rocket_uri_macro_";
|
||||||
crate static ROCKET_PARAM_PREFIX: &str = "__rocket_param_";
|
pub(crate) static ROCKET_PARAM_PREFIX: &str = "__rocket_param_";
|
||||||
|
|
||||||
macro_rules! emit {
|
macro_rules! emit {
|
||||||
($tokens:expr) => ({
|
($tokens:expr) => ({
|
||||||
|
@ -63,7 +63,7 @@ impl From<Vec<Diagnostic>> for Diagnostics {
|
|||||||
|
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
|
|
||||||
pub struct StringLit(crate String, crate Literal);
|
pub struct StringLit(pub(crate) String, pub(crate) Literal);
|
||||||
|
|
||||||
impl Deref for StringLit {
|
impl Deref for StringLit {
|
||||||
type Target = str;
|
type Target = str;
|
||||||
|
@ -27,7 +27,7 @@ indexmap = { version = "1.5.2", features = ["std"] }
|
|||||||
rustls = { version = "0.14", optional = true }
|
rustls = { version = "0.14", optional = true }
|
||||||
state = "0.4"
|
state = "0.4"
|
||||||
cookie = { version = "0.11.3", features = ["percent-encode"] }
|
cookie = { version = "0.11.3", features = ["percent-encode"] }
|
||||||
pear = "0.1"
|
pear = "0.1.5"
|
||||||
unicode-xid = "0.1"
|
unicode-xid = "0.1"
|
||||||
|
|
||||||
[dependencies.hyper-sync-rustls]
|
[dependencies.hyper-sync-rustls]
|
||||||
|
@ -162,7 +162,7 @@ impl PartialEq for AcceptParams {
|
|||||||
/// let response = Response::build().header(Accept::JSON).finalize();
|
/// let response = Response::build().header(Accept::JSON).finalize();
|
||||||
/// ```
|
/// ```
|
||||||
#[derive(Debug, Clone, PartialEq)]
|
#[derive(Debug, Clone, PartialEq)]
|
||||||
pub struct Accept(crate AcceptParams);
|
pub struct Accept(pub(crate) AcceptParams);
|
||||||
|
|
||||||
macro_rules! accept_constructor {
|
macro_rules! accept_constructor {
|
||||||
($($name:ident ($check:ident): $str:expr, $t:expr,
|
($($name:ident ($check:ident): $str:expr, $t:expr,
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
#![allow(incomplete_features)]
|
#![allow(incomplete_features)]
|
||||||
#![feature(specialization)]
|
#![feature(specialization)]
|
||||||
#![feature(proc_macro_hygiene)]
|
#![feature(proc_macro_hygiene)]
|
||||||
#![feature(crate_visibility_modifier)]
|
|
||||||
#![feature(doc_cfg)]
|
#![feature(doc_cfg)]
|
||||||
#![recursion_limit="512"]
|
#![recursion_limit="512"]
|
||||||
|
|
||||||
@ -46,7 +45,7 @@ mod header;
|
|||||||
mod accept;
|
mod accept;
|
||||||
mod raw_str;
|
mod raw_str;
|
||||||
|
|
||||||
crate mod parse;
|
pub(crate) mod parse;
|
||||||
|
|
||||||
pub mod uncased;
|
pub mod uncased;
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ enum Or<L, R> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Error<'a> {
|
impl<'a> Error<'a> {
|
||||||
crate fn from(src: &'a str, pear_error: ParseErr<RawInput<'a>>) -> Error<'a> {
|
pub(crate) fn from(src: &'a str, pear_error: ParseErr<RawInput<'a>>) -> Error<'a> {
|
||||||
let new_expected = pear_error.expected.map(|token| {
|
let new_expected = pear_error.expected.map(|token| {
|
||||||
if token.is_ascii() && !token.is_ascii_control() {
|
if token.is_ascii() && !token.is_ascii_control() {
|
||||||
Or::A(token as char)
|
Or::A(token as char)
|
||||||
|
@ -8,7 +8,7 @@ use uri::{Uri, Origin, Absolute, Authority};
|
|||||||
use parse::indexed::IndexedInput;
|
use parse::indexed::IndexedInput;
|
||||||
use self::parser::{uri, origin, authority_only, absolute_only, rocket_route_origin};
|
use self::parser::{uri, origin, authority_only, absolute_only, rocket_route_origin};
|
||||||
|
|
||||||
crate use self::tables::is_pchar;
|
pub(crate) use self::tables::is_pchar;
|
||||||
pub use self::error::Error;
|
pub use self::error::Error;
|
||||||
|
|
||||||
type RawInput<'a> = IndexedInput<'a, [u8]>;
|
type RawInput<'a> = IndexedInput<'a, [u8]>;
|
||||||
|
@ -9,7 +9,7 @@ use parse::IndexedBytes;
|
|||||||
type Result<'a, T> = ::pear::Result<T, RawInput<'a>>;
|
type Result<'a, T> = ::pear::Result<T, RawInput<'a>>;
|
||||||
|
|
||||||
#[parser]
|
#[parser]
|
||||||
crate fn uri<'a>(input: &mut RawInput<'a>) -> Result<'a, Uri<'a>> {
|
pub(crate) fn uri<'a>(input: &mut RawInput<'a>) -> Result<'a, Uri<'a>> {
|
||||||
match input.len() {
|
match input.len() {
|
||||||
0 => return Err(pear_error!("empty URI")),
|
0 => return Err(pear_error!("empty URI")),
|
||||||
1 => switch! {
|
1 => switch! {
|
||||||
@ -29,12 +29,12 @@ crate fn uri<'a>(input: &mut RawInput<'a>) -> Result<'a, Uri<'a>> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[parser]
|
#[parser]
|
||||||
crate fn origin<'a>(input: &mut RawInput<'a>) -> Result<'a, Origin<'a>> {
|
pub(crate) fn origin<'a>(input: &mut RawInput<'a>) -> Result<'a, Origin<'a>> {
|
||||||
(peek(b'/')?, path_and_query(is_pchar)?).1
|
(peek(b'/')?, path_and_query(is_pchar)?).1
|
||||||
}
|
}
|
||||||
|
|
||||||
#[parser]
|
#[parser]
|
||||||
crate fn rocket_route_origin<'a>(input: &mut RawInput<'a>) -> Result<'a, Origin<'a>> {
|
pub(crate) fn rocket_route_origin<'a>(input: &mut RawInput<'a>) -> Result<'a, Origin<'a>> {
|
||||||
(peek(b'/')?, path_and_query(is_pchar_or_rchar)?).1
|
(peek(b'/')?, path_and_query(is_pchar_or_rchar)?).1
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +128,7 @@ fn absolute<'a>(
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[parser]
|
#[parser]
|
||||||
crate fn authority_only<'a>(input: &mut RawInput<'a>) -> Result<'a, Authority<'a>> {
|
pub(crate) fn authority_only<'a>(input: &mut RawInput<'a>) -> Result<'a, Authority<'a>> {
|
||||||
if let Uri::Authority(authority) = absolute_or_authority()? {
|
if let Uri::Authority(authority) = absolute_or_authority()? {
|
||||||
Ok(authority)
|
Ok(authority)
|
||||||
} else {
|
} else {
|
||||||
@ -137,7 +137,7 @@ crate fn authority_only<'a>(input: &mut RawInput<'a>) -> Result<'a, Authority<'a
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[parser]
|
#[parser]
|
||||||
crate fn absolute_only<'a>(input: &mut RawInput<'a>) -> Result<'a, Absolute<'a>> {
|
pub(crate) fn absolute_only<'a>(input: &mut RawInput<'a>) -> Result<'a, Absolute<'a>> {
|
||||||
if let Uri::Absolute(absolute) = absolute_or_authority()? {
|
if let Uri::Absolute(absolute) = absolute_or_authority()? {
|
||||||
Ok(absolute)
|
Ok(absolute)
|
||||||
} else {
|
} else {
|
||||||
|
@ -44,7 +44,7 @@ impl<'a> IntoOwned for Absolute<'a> {
|
|||||||
|
|
||||||
impl<'a> Absolute<'a> {
|
impl<'a> Absolute<'a> {
|
||||||
#[inline]
|
#[inline]
|
||||||
crate unsafe fn raw(
|
pub(crate) unsafe fn raw(
|
||||||
source: Cow<'a, [u8]>,
|
source: Cow<'a, [u8]>,
|
||||||
scheme: Indexed<'a, [u8]>,
|
scheme: Indexed<'a, [u8]>,
|
||||||
authority: Option<Authority<'a>>,
|
authority: Option<Authority<'a>>,
|
||||||
@ -59,7 +59,7 @@ impl<'a> Absolute<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
crate fn new(
|
pub(crate) fn new(
|
||||||
scheme: &'a str,
|
scheme: &'a str,
|
||||||
authority: Option<Authority<'a>>,
|
authority: Option<Authority<'a>>,
|
||||||
origin: Option<Origin<'a>>
|
origin: Option<Origin<'a>>
|
||||||
|
@ -28,7 +28,7 @@ pub struct Authority<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
crate enum Host<T> {
|
pub(crate) enum Host<T> {
|
||||||
Bracketed(T),
|
Bracketed(T),
|
||||||
Raw(T)
|
Raw(T)
|
||||||
}
|
}
|
||||||
@ -55,7 +55,7 @@ impl<'a> IntoOwned for Authority<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Authority<'a> {
|
impl<'a> Authority<'a> {
|
||||||
crate unsafe fn raw(
|
pub(crate) unsafe fn raw(
|
||||||
source: Cow<'a, [u8]>,
|
source: Cow<'a, [u8]>,
|
||||||
user_info: Option<Indexed<'a, [u8]>>,
|
user_info: Option<Indexed<'a, [u8]>>,
|
||||||
host: Host<Indexed<'a, [u8]>>,
|
host: Host<Indexed<'a, [u8]>>,
|
||||||
@ -70,7 +70,7 @@ impl<'a> Authority<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
crate fn new(
|
pub(crate) fn new(
|
||||||
user_info: Option<&'a str>,
|
user_info: Option<&'a str>,
|
||||||
host: Host<&'a str>,
|
host: Host<&'a str>,
|
||||||
port: Option<u16>
|
port: Option<u16>
|
||||||
|
@ -8,7 +8,7 @@ use parse::uri::is_pchar;
|
|||||||
|
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone, Copy)]
|
||||||
#[allow(non_camel_case_types)]
|
#[allow(non_camel_case_types)]
|
||||||
crate struct UNSAFE_ENCODE_SET<P: UriPart>(PhantomData<P>);
|
pub(crate) struct UNSAFE_ENCODE_SET<P: UriPart>(PhantomData<P>);
|
||||||
|
|
||||||
impl<P: UriPart> Default for UNSAFE_ENCODE_SET<P> {
|
impl<P: UriPart> Default for UNSAFE_ENCODE_SET<P> {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
@ -31,7 +31,7 @@ impl EncodeSet for UNSAFE_ENCODE_SET<Query> {
|
|||||||
|
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone, Copy)]
|
||||||
#[allow(non_camel_case_types)]
|
#[allow(non_camel_case_types)]
|
||||||
crate struct ENCODE_SET<P: UriPart>(PhantomData<P>);
|
pub(crate) struct ENCODE_SET<P: UriPart>(PhantomData<P>);
|
||||||
|
|
||||||
impl EncodeSet for ENCODE_SET<Path> {
|
impl EncodeSet for ENCODE_SET<Path> {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
@ -52,7 +52,7 @@ impl EncodeSet for ENCODE_SET<Query> {
|
|||||||
|
|
||||||
#[derive(Default, Clone, Copy)]
|
#[derive(Default, Clone, Copy)]
|
||||||
#[allow(non_camel_case_types)]
|
#[allow(non_camel_case_types)]
|
||||||
crate struct DEFAULT_ENCODE_SET;
|
pub(crate) struct DEFAULT_ENCODE_SET;
|
||||||
|
|
||||||
impl EncodeSet for DEFAULT_ENCODE_SET {
|
impl EncodeSet for DEFAULT_ENCODE_SET {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
@ -62,7 +62,7 @@ impl EncodeSet for DEFAULT_ENCODE_SET {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn unsafe_percent_encode<P: UriPart>(string: &str) -> Cow<str> {
|
pub(crate) fn unsafe_percent_encode<P: UriPart>(string: &str) -> Cow<str> {
|
||||||
match P::DELIMITER {
|
match P::DELIMITER {
|
||||||
'/' => percent_encode::<UNSAFE_ENCODE_SET<Path>>(string),
|
'/' => percent_encode::<UNSAFE_ENCODE_SET<Path>>(string),
|
||||||
'&' => percent_encode::<UNSAFE_ENCODE_SET<Query>>(string),
|
'&' => percent_encode::<UNSAFE_ENCODE_SET<Query>>(string),
|
||||||
@ -70,6 +70,6 @@ crate fn unsafe_percent_encode<P: UriPart>(string: &str) -> Cow<str> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn percent_encode<S: EncodeSet + Default>(string: &str) -> Cow<str> {
|
pub(crate) fn percent_encode<S: EncodeSet + Default>(string: &str) -> Cow<str> {
|
||||||
utf8_percent_encode(string, S::default()).into()
|
utf8_percent_encode(string, S::default()).into()
|
||||||
}
|
}
|
||||||
|
@ -158,7 +158,7 @@ pub struct Formatter<'i, P: UriPart> {
|
|||||||
|
|
||||||
impl<'i, P: UriPart> Formatter<'i, P> {
|
impl<'i, P: UriPart> Formatter<'i, P> {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn new(inner: &'i mut (dyn Write + 'i)) -> Self {
|
pub(crate) fn new(inner: &'i mut (dyn Write + 'i)) -> Self {
|
||||||
Formatter {
|
Formatter {
|
||||||
inner,
|
inner,
|
||||||
prefixes: SmallVec::new(),
|
prefixes: SmallVec::new(),
|
||||||
|
@ -9,7 +9,7 @@ mod authority;
|
|||||||
mod absolute;
|
mod absolute;
|
||||||
mod segments;
|
mod segments;
|
||||||
|
|
||||||
crate mod encoding;
|
pub(crate) mod encoding;
|
||||||
|
|
||||||
pub use parse::uri::Error;
|
pub use parse::uri::Error;
|
||||||
|
|
||||||
|
@ -85,10 +85,10 @@ use state::Storage;
|
|||||||
/// ```
|
/// ```
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct Origin<'a> {
|
pub struct Origin<'a> {
|
||||||
crate source: Option<Cow<'a, str>>,
|
pub(crate) source: Option<Cow<'a, str>>,
|
||||||
crate path: IndexedStr<'a>,
|
pub(crate) path: IndexedStr<'a>,
|
||||||
crate query: Option<IndexedStr<'a>>,
|
pub(crate) query: Option<IndexedStr<'a>>,
|
||||||
crate segment_count: Storage<usize>,
|
pub(crate) segment_count: Storage<usize>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'b> PartialEq<Origin<'b>> for Origin<'a> {
|
impl<'a, 'b> PartialEq<Origin<'b>> for Origin<'a> {
|
||||||
@ -112,7 +112,7 @@ impl<'a> IntoOwned for Origin<'a> {
|
|||||||
|
|
||||||
impl<'a> Origin<'a> {
|
impl<'a> Origin<'a> {
|
||||||
#[inline]
|
#[inline]
|
||||||
crate unsafe fn raw(
|
pub(crate) unsafe fn raw(
|
||||||
source: Cow<'a, [u8]>,
|
source: Cow<'a, [u8]>,
|
||||||
path: Indexed<'a, [u8]>,
|
path: Indexed<'a, [u8]>,
|
||||||
query: Option<Indexed<'a, [u8]>>
|
query: Option<Indexed<'a, [u8]>>
|
||||||
|
@ -62,7 +62,7 @@ pub enum Uri<'a> {
|
|||||||
|
|
||||||
impl<'a> Uri<'a> {
|
impl<'a> Uri<'a> {
|
||||||
#[inline]
|
#[inline]
|
||||||
crate unsafe fn raw_absolute(
|
pub(crate) unsafe fn raw_absolute(
|
||||||
source: Cow<'a, [u8]>,
|
source: Cow<'a, [u8]>,
|
||||||
scheme: Indexed<'a, [u8]>,
|
scheme: Indexed<'a, [u8]>,
|
||||||
path: Indexed<'a, [u8]>,
|
path: Indexed<'a, [u8]>,
|
||||||
@ -212,7 +212,7 @@ impl<'a> Uri<'a> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate unsafe fn as_utf8_unchecked(input: Cow<[u8]>) -> Cow<str> {
|
pub(crate) unsafe fn as_utf8_unchecked(input: Cow<[u8]>) -> Cow<str> {
|
||||||
match input {
|
match input {
|
||||||
Cow::Borrowed(bytes) => Cow::Borrowed(::std::str::from_utf8_unchecked(bytes)),
|
Cow::Borrowed(bytes) => Cow::Borrowed(::std::str::from_utf8_unchecked(bytes)),
|
||||||
Cow::Owned(bytes) => Cow::Owned(String::from_utf8_unchecked(bytes))
|
Cow::Owned(bytes) => Cow::Owned(String::from_utf8_unchecked(bytes))
|
||||||
|
@ -34,7 +34,7 @@ state = "0.4.1"
|
|||||||
time = "0.1"
|
time = "0.1"
|
||||||
memchr = "2" # TODO: Use pear instead.
|
memchr = "2" # TODO: Use pear instead.
|
||||||
base64 = "0.13"
|
base64 = "0.13"
|
||||||
pear = "0.1"
|
pear = "0.1.5"
|
||||||
atty = "0.2"
|
atty = "0.2"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
|
@ -64,7 +64,7 @@ pub struct Catcher {
|
|||||||
pub code: u16,
|
pub code: u16,
|
||||||
/// The catcher's associated handler.
|
/// The catcher's associated handler.
|
||||||
pub handler: ErrorHandler,
|
pub handler: ErrorHandler,
|
||||||
crate is_default: bool,
|
pub(crate) is_default: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Catcher {
|
impl Catcher {
|
||||||
@ -98,7 +98,7 @@ impl Catcher {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn handle<'r>(&self, req: &'r Request) -> response::Result<'r> {
|
pub(crate) fn handle<'r>(&self, req: &'r Request) -> response::Result<'r> {
|
||||||
(self.handler)(req)
|
(self.handler)(req)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,17 +55,17 @@ pub struct Config {
|
|||||||
/// How much information to log.
|
/// How much information to log.
|
||||||
pub log_level: LoggingLevel,
|
pub log_level: LoggingLevel,
|
||||||
/// The secret key.
|
/// The secret key.
|
||||||
crate secret_key: SecretKey,
|
pub(crate) secret_key: SecretKey,
|
||||||
/// TLS configuration.
|
/// TLS configuration.
|
||||||
crate tls: Option<TlsConfig>,
|
pub(crate) tls: Option<TlsConfig>,
|
||||||
/// Streaming read size limits.
|
/// Streaming read size limits.
|
||||||
pub limits: Limits,
|
pub limits: Limits,
|
||||||
/// Extra parameters that aren't part of Rocket's core config.
|
/// Extra parameters that aren't part of Rocket's core config.
|
||||||
pub extras: HashMap<String, Value>,
|
pub extras: HashMap<String, Value>,
|
||||||
/// The path to the configuration file this config was loaded from, if any.
|
/// The path to the configuration file this config was loaded from, if any.
|
||||||
crate config_file_path: Option<PathBuf>,
|
pub(crate) config_file_path: Option<PathBuf>,
|
||||||
/// The path root-relative files will be rooted from.
|
/// The path root-relative files will be rooted from.
|
||||||
crate root_path: Option<PathBuf>,
|
pub(crate) root_path: Option<PathBuf>,
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! config_from_raw {
|
macro_rules! config_from_raw {
|
||||||
@ -198,7 +198,7 @@ impl Config {
|
|||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// Panics if randomness cannot be retrieved from the OS.
|
/// Panics if randomness cannot be retrieved from the OS.
|
||||||
crate fn default_from<P>(env: Environment, path: P) -> Result<Config>
|
pub(crate) fn default_from<P>(env: Environment, path: P) -> Result<Config>
|
||||||
where P: AsRef<Path>
|
where P: AsRef<Path>
|
||||||
{
|
{
|
||||||
let mut config = Config::default(env);
|
let mut config = Config::default(env);
|
||||||
@ -220,7 +220,7 @@ impl Config {
|
|||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// Panics if randomness cannot be retrieved from the OS.
|
/// Panics if randomness cannot be retrieved from the OS.
|
||||||
crate fn default(env: Environment) -> Config {
|
pub(crate) fn default(env: Environment) -> Config {
|
||||||
// Note: This may truncate if num_cpus::get() / 2 > u16::max. That's okay.
|
// Note: This may truncate if num_cpus::get() / 2 > u16::max. That's okay.
|
||||||
let default_workers = (num_cpus::get() * 2) as u16;
|
let default_workers = (num_cpus::get() * 2) as u16;
|
||||||
|
|
||||||
@ -288,7 +288,7 @@ impl Config {
|
|||||||
/// Constructs a `BadType` error given the entry `name`, the invalid `val`
|
/// Constructs a `BadType` error given the entry `name`, the invalid `val`
|
||||||
/// at that entry, and the `expect`ed type name.
|
/// at that entry, and the `expect`ed type name.
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn bad_type(&self,
|
pub(crate) fn bad_type(&self,
|
||||||
name: &str,
|
name: &str,
|
||||||
actual: &'static str,
|
actual: &'static str,
|
||||||
expect: &'static str) -> ConfigError {
|
expect: &'static str) -> ConfigError {
|
||||||
@ -312,7 +312,7 @@ impl Config {
|
|||||||
/// * **log**: String
|
/// * **log**: String
|
||||||
/// * **secret_key**: String (256-bit base64)
|
/// * **secret_key**: String (256-bit base64)
|
||||||
/// * **tls**: Table (`certs` (path as String), `key` (path as String))
|
/// * **tls**: Table (`certs` (path as String), `key` (path as String))
|
||||||
crate fn set_raw(&mut self, name: &str, val: &Value) -> Result<()> {
|
pub(crate) fn set_raw(&mut self, name: &str, val: &Value) -> Result<()> {
|
||||||
let (id, ok) = (|val| val, |_| Ok(()));
|
let (id, ok) = (|val| val, |_| Ok(()));
|
||||||
config_from_raw!(self, name, val,
|
config_from_raw!(self, name, val,
|
||||||
address => (str, set_address, id),
|
address => (str, set_address, id),
|
||||||
@ -684,7 +684,7 @@ impl Config {
|
|||||||
|
|
||||||
/// Retrieves the secret key from `self`.
|
/// Retrieves the secret key from `self`.
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn secret_key(&self) -> &Key {
|
pub(crate) fn secret_key(&self) -> &Key {
|
||||||
self.secret_key.inner()
|
self.secret_key.inner()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,14 +14,14 @@ pub enum SecretKey {
|
|||||||
|
|
||||||
impl SecretKey {
|
impl SecretKey {
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn inner(&self) -> &Key {
|
pub(crate) fn inner(&self) -> &Key {
|
||||||
match *self {
|
match *self {
|
||||||
SecretKey::Generated(ref key) | SecretKey::Provided(ref key) => key
|
SecretKey::Generated(ref key) | SecretKey::Provided(ref key) => key
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn is_generated(&self) -> bool {
|
pub(crate) fn is_generated(&self) -> bool {
|
||||||
match *self {
|
match *self {
|
||||||
#[cfg(feature = "private-cookies")]
|
#[cfg(feature = "private-cookies")]
|
||||||
SecretKey::Generated(_) => true,
|
SecretKey::Generated(_) => true,
|
||||||
@ -83,7 +83,7 @@ pub struct TlsConfig;
|
|||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Limits {
|
pub struct Limits {
|
||||||
// We cache this internally but don't share that fact in the API.
|
// We cache this internally but don't share that fact in the API.
|
||||||
crate forms: u64,
|
pub(crate) forms: u64,
|
||||||
extra: Vec<(String, u64)>
|
extra: Vec<(String, u64)>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,10 +21,10 @@ pub enum Environment {
|
|||||||
|
|
||||||
impl Environment {
|
impl Environment {
|
||||||
/// List of all of the possible environments.
|
/// List of all of the possible environments.
|
||||||
crate const ALL: [Environment; 3] = [Development, Staging, Production];
|
pub(crate) const ALL: [Environment; 3] = [Development, Staging, Production];
|
||||||
|
|
||||||
/// String of all valid environments.
|
/// String of all valid environments.
|
||||||
crate const VALID: &'static str = "development, staging, production";
|
pub(crate) const VALID: &'static str = "development, staging, production";
|
||||||
|
|
||||||
/// Retrieves the "active" environment as determined by the `ROCKET_ENV`
|
/// Retrieves the "active" environment as determined by the `ROCKET_ENV`
|
||||||
/// environment variable. If `ROCKET_ENV` is not set, returns `Development`
|
/// environment variable. If `ROCKET_ENV` is not set, returns `Development`
|
||||||
|
@ -214,7 +214,7 @@ pub use self::environment::Environment;
|
|||||||
pub use self::config::Config;
|
pub use self::config::Config;
|
||||||
pub use self::builder::ConfigBuilder;
|
pub use self::builder::ConfigBuilder;
|
||||||
pub use logger::LoggingLevel;
|
pub use logger::LoggingLevel;
|
||||||
crate use self::toml_ext::LoggedValue;
|
pub(crate) use self::toml_ext::LoggedValue;
|
||||||
|
|
||||||
use logger;
|
use logger;
|
||||||
use self::Environment::*;
|
use self::Environment::*;
|
||||||
@ -453,7 +453,7 @@ impl RocketConfig {
|
|||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// If there is a problem, prints a nice error message and bails.
|
/// If there is a problem, prints a nice error message and bails.
|
||||||
crate fn init() -> Config {
|
pub(crate) fn init() -> Config {
|
||||||
let bail = |e: ConfigError| -> ! {
|
let bail = |e: ConfigError| -> ! {
|
||||||
logger::init(LoggingLevel::Debug);
|
logger::init(LoggingLevel::Debug);
|
||||||
e.pretty_print();
|
e.pretty_print();
|
||||||
|
@ -81,7 +81,7 @@ pub fn parse_simple_toml_value(mut input: &str) -> StdResult<Value, String> {
|
|||||||
|
|
||||||
/// A simple wrapper over a `Value` reference with a custom implementation of
|
/// A simple wrapper over a `Value` reference with a custom implementation of
|
||||||
/// `Display`. This is used to log config values at initialization.
|
/// `Display`. This is used to log config values at initialization.
|
||||||
crate struct LoggedValue<'a>(pub &'a Value);
|
pub(crate) struct LoggedValue<'a>(pub &'a Value);
|
||||||
|
|
||||||
impl<'a> fmt::Display for LoggedValue<'a> {
|
impl<'a> fmt::Display for LoggedValue<'a> {
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -91,7 +91,7 @@ impl Data {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: This is absolutely terrible (downcasting!), thanks to Hyper.
|
// FIXME: This is absolutely terrible (downcasting!), thanks to Hyper.
|
||||||
crate fn from_hyp(
|
pub(crate) fn from_hyp(
|
||||||
req: &crate::Request<'_>,
|
req: &crate::Request<'_>,
|
||||||
mut body: HyperBodyReader
|
mut body: HyperBodyReader
|
||||||
) -> Result<Data, &'static str> {
|
) -> Result<Data, &'static str> {
|
||||||
@ -234,7 +234,7 @@ impl Data {
|
|||||||
// bytes `vec[pos..cap]` are buffered and unread. The remainder of the data
|
// bytes `vec[pos..cap]` are buffered and unread. The remainder of the data
|
||||||
// bytes can be read from `stream`.
|
// bytes can be read from `stream`.
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn new(mut stream: BodyReader) -> Data {
|
pub(crate) fn new(mut stream: BodyReader) -> Data {
|
||||||
trace_!("Data::new({:?})", stream);
|
trace_!("Data::new({:?})", stream);
|
||||||
let mut peek_buf: Vec<u8> = vec![0; PEEK_BYTES];
|
let mut peek_buf: Vec<u8> = vec![0; PEEK_BYTES];
|
||||||
|
|
||||||
@ -264,7 +264,7 @@ impl Data {
|
|||||||
|
|
||||||
/// This creates a `data` object from a local data source `data`.
|
/// This creates a `data` object from a local data source `data`.
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn local(data: Vec<u8>) -> Data {
|
pub(crate) fn local(data: Vec<u8>) -> Data {
|
||||||
let empty_stream = Cursor::new(vec![]).chain(NetStream::Empty);
|
let empty_stream = Cursor::new(vec![]).chain(NetStream::Empty);
|
||||||
|
|
||||||
Data {
|
Data {
|
||||||
|
@ -14,7 +14,7 @@ pub type InnerStream = Chain<Cursor<Vec<u8>>, BodyReader>;
|
|||||||
/// [`Data::open()`](::data::Data::open()). The stream contains all of the data
|
/// [`Data::open()`](::data::Data::open()). The stream contains all of the data
|
||||||
/// in the body of the request. It exposes no methods directly. Instead, it must
|
/// in the body of the request. It exposes no methods directly. Instead, it must
|
||||||
/// be used as an opaque [`Read`] structure.
|
/// be used as an opaque [`Read`] structure.
|
||||||
pub struct DataStream(crate InnerStream);
|
pub struct DataStream(pub(crate) InnerStream);
|
||||||
|
|
||||||
// TODO: Have a `BufRead` impl for `DataStream`. At the moment, this isn't
|
// TODO: Have a `BufRead` impl for `DataStream`. At the moment, this isn't
|
||||||
// possible since Hyper's `HttpReader` doesn't implement `BufRead`.
|
// possible since Hyper's `HttpReader` doesn't implement `BufRead`.
|
||||||
|
@ -88,7 +88,7 @@ pub struct LaunchError {
|
|||||||
|
|
||||||
impl LaunchError {
|
impl LaunchError {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn new(kind: LaunchErrorKind) -> LaunchError {
|
pub(crate) fn new(kind: LaunchErrorKind) -> LaunchError {
|
||||||
LaunchError { handled: AtomicBool::new(false), kind }
|
LaunchError { handled: AtomicBool::new(false), kind }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ mod fairings;
|
|||||||
mod ad_hoc;
|
mod ad_hoc;
|
||||||
mod info_kind;
|
mod info_kind;
|
||||||
|
|
||||||
crate use self::fairings::Fairings;
|
pub(crate) use self::fairings::Fairings;
|
||||||
pub use self::ad_hoc::AdHoc;
|
pub use self::ad_hoc::AdHoc;
|
||||||
pub use self::info_kind::{Info, Kind};
|
pub use self::info_kind::{Info, Kind};
|
||||||
|
|
||||||
|
@ -4,7 +4,6 @@
|
|||||||
#![feature(try_trait_v2, control_flow_enum)]
|
#![feature(try_trait_v2, control_flow_enum)]
|
||||||
#![feature(never_type)]
|
#![feature(never_type)]
|
||||||
#![feature(proc_macro_hygiene)]
|
#![feature(proc_macro_hygiene)]
|
||||||
#![feature(crate_visibility_modifier)]
|
|
||||||
#![feature(label_break_value)]
|
#![feature(label_break_value)]
|
||||||
|
|
||||||
#![recursion_limit="256"]
|
#![recursion_limit="256"]
|
||||||
|
@ -69,7 +69,7 @@ use error::LaunchError;
|
|||||||
/// [`post()`]: #method.post
|
/// [`post()`]: #method.post
|
||||||
pub struct Client {
|
pub struct Client {
|
||||||
rocket: Rocket,
|
rocket: Rocket,
|
||||||
crate cookies: Option<RwLock<CookieJar>>,
|
pub(crate) cookies: Option<RwLock<CookieJar>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Client {
|
impl Client {
|
||||||
|
@ -101,7 +101,7 @@ pub struct LocalRequest<'c> {
|
|||||||
|
|
||||||
impl<'c> LocalRequest<'c> {
|
impl<'c> LocalRequest<'c> {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn new(
|
pub(crate) fn new(
|
||||||
client: &'c Client,
|
client: &'c Client,
|
||||||
method: Method,
|
method: Method,
|
||||||
uri: Cow<'c, str>
|
uri: Cow<'c, str>
|
||||||
|
@ -6,7 +6,7 @@ use std::str::FromStr;
|
|||||||
use log;
|
use log;
|
||||||
use yansi::Paint;
|
use yansi::Paint;
|
||||||
|
|
||||||
crate const COLORS_ENV: &str = "ROCKET_CLI_COLORS";
|
pub(crate) const COLORS_ENV: &str = "ROCKET_CLI_COLORS";
|
||||||
|
|
||||||
struct RocketLogger(LoggingLevel);
|
struct RocketLogger(LoggingLevel);
|
||||||
|
|
||||||
@ -71,15 +71,15 @@ macro_rules! launch_info { ($($args:tt)*) => { info!(target: "launch", $($args)*
|
|||||||
#[doc(hidden)] #[macro_export]
|
#[doc(hidden)] #[macro_export]
|
||||||
macro_rules! launch_info_ { ($($args:tt)*) => { info!(target: "launch_", $($args)*) } }
|
macro_rules! launch_info_ { ($($args:tt)*) => { info!(target: "launch_", $($args)*) } }
|
||||||
#[doc(hidden)] #[macro_export]
|
#[doc(hidden)] #[macro_export]
|
||||||
macro_rules! error_ { ($($args:expr),+) => { log_!(error: $($args),+); }; }
|
macro_rules! error_ { ($($args:expr),+) => { log_!(error: $($args),+) }; }
|
||||||
#[doc(hidden)] #[macro_export]
|
#[doc(hidden)] #[macro_export]
|
||||||
macro_rules! info_ { ($($args:expr),+) => { log_!(info: $($args),+); }; }
|
macro_rules! info_ { ($($args:expr),+) => { log_!(info: $($args),+) }; }
|
||||||
#[doc(hidden)] #[macro_export]
|
#[doc(hidden)] #[macro_export]
|
||||||
macro_rules! trace_ { ($($args:expr),+) => { log_!(trace: $($args),+); }; }
|
macro_rules! trace_ { ($($args:expr),+) => { log_!(trace: $($args),+); }; }
|
||||||
#[doc(hidden)] #[macro_export]
|
#[doc(hidden)] #[macro_export]
|
||||||
macro_rules! debug_ { ($($args:expr),+) => { log_!(debug: $($args),+); }; }
|
macro_rules! debug_ { ($($args:expr),+) => { log_!(debug: $($args),+); }; }
|
||||||
#[doc(hidden)] #[macro_export]
|
#[doc(hidden)] #[macro_export]
|
||||||
macro_rules! warn_ { ($($args:expr),+) => { log_!(warn: $($args),+); }; }
|
macro_rules! warn_ { ($($args:expr),+) => { log_!(warn: $($args),+) }; }
|
||||||
|
|
||||||
impl log::Log for RocketLogger {
|
impl log::Log for RocketLogger {
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
@ -145,7 +145,7 @@ impl log::Log for RocketLogger {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn try_init(level: LoggingLevel, verbose: bool) -> bool {
|
pub(crate) fn try_init(level: LoggingLevel, verbose: bool) -> bool {
|
||||||
if level == LoggingLevel::Off {
|
if level == LoggingLevel::Off {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -198,13 +198,13 @@ fn usize_to_filter(num: usize) -> log::LevelFilter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn push_max_level(level: LoggingLevel) {
|
pub(crate) fn push_max_level(level: LoggingLevel) {
|
||||||
LAST_LOG_FILTER.store(filter_to_usize(log::max_level()), Ordering::Release);
|
LAST_LOG_FILTER.store(filter_to_usize(log::max_level()), Ordering::Release);
|
||||||
PUSHED.store(true, Ordering::Release);
|
PUSHED.store(true, Ordering::Release);
|
||||||
log::set_max_level(level.to_level_filter());
|
log::set_max_level(level.to_level_filter());
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn pop_max_level() {
|
pub(crate) fn pop_max_level() {
|
||||||
if PUSHED.load(Ordering::Acquire) {
|
if PUSHED.load(Ordering::Acquire) {
|
||||||
log::set_max_level(usize_to_filter(LAST_LOG_FILTER.load(Ordering::Acquire)));
|
log::set_max_level(usize_to_filter(LAST_LOG_FILTER.load(Ordering::Acquire)));
|
||||||
}
|
}
|
||||||
|
@ -148,7 +148,7 @@ impl<T> Deref for Form<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'f, T: FromForm<'f>> Form<T> {
|
impl<'f, T: FromForm<'f>> Form<T> {
|
||||||
crate fn from_data(
|
pub(crate) fn from_data(
|
||||||
form_str: &'f str,
|
form_str: &'f str,
|
||||||
strict: bool
|
strict: bool
|
||||||
) -> Outcome<T, FormDataError<'f, T::Error>> {
|
) -> Outcome<T, FormDataError<'f, T::Error>> {
|
||||||
|
@ -32,24 +32,24 @@ pub struct Request<'r> {
|
|||||||
uri: Origin<'r>,
|
uri: Origin<'r>,
|
||||||
headers: HeaderMap<'r>,
|
headers: HeaderMap<'r>,
|
||||||
remote: Option<SocketAddr>,
|
remote: Option<SocketAddr>,
|
||||||
crate state: RequestState<'r>,
|
pub(crate) state: RequestState<'r>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
crate struct RequestState<'r> {
|
pub(crate) struct RequestState<'r> {
|
||||||
crate config: &'r Config,
|
pub(crate) config: &'r Config,
|
||||||
crate managed: &'r Container,
|
pub(crate) managed: &'r Container,
|
||||||
crate path_segments: SmallVec<[Indices; 12]>,
|
pub(crate) path_segments: SmallVec<[Indices; 12]>,
|
||||||
crate query_items: Option<SmallVec<[IndexedFormItem; 6]>>,
|
pub(crate) query_items: Option<SmallVec<[IndexedFormItem; 6]>>,
|
||||||
crate route: Cell<Option<&'r Route>>,
|
pub(crate) route: Cell<Option<&'r Route>>,
|
||||||
crate cookies: RefCell<CookieJar>,
|
pub(crate) cookies: RefCell<CookieJar>,
|
||||||
crate accept: Storage<Option<Accept>>,
|
pub(crate) accept: Storage<Option<Accept>>,
|
||||||
crate content_type: Storage<Option<ContentType>>,
|
pub(crate) content_type: Storage<Option<ContentType>>,
|
||||||
crate cache: Rc<Container>,
|
pub(crate) cache: Rc<Container>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
crate struct IndexedFormItem {
|
pub(crate) struct IndexedFormItem {
|
||||||
raw: Indices,
|
raw: Indices,
|
||||||
key: Indices,
|
key: Indices,
|
||||||
value: Indices
|
value: Indices
|
||||||
@ -58,7 +58,7 @@ crate struct IndexedFormItem {
|
|||||||
impl<'r> Request<'r> {
|
impl<'r> Request<'r> {
|
||||||
/// Create a new `Request` with the given `method` and `uri`.
|
/// Create a new `Request` with the given `method` and `uri`.
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn new<'s: 'r>(
|
pub(crate) fn new<'s: 'r>(
|
||||||
rocket: &'r Rocket,
|
rocket: &'r Rocket,
|
||||||
method: Method,
|
method: Method,
|
||||||
uri: Origin<'s>
|
uri: Origin<'s>
|
||||||
@ -740,7 +740,7 @@ impl<'r> Request<'r> {
|
|||||||
// Returns an iterator over the raw segments of the path URI. Does not take
|
// Returns an iterator over the raw segments of the path URI. Does not take
|
||||||
// into account the current route. This is used during routing.
|
// into account the current route. This is used during routing.
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn raw_path_segments(&self) -> impl Iterator<Item = &RawStr> {
|
pub(crate) fn raw_path_segments(&self) -> impl Iterator<Item = &RawStr> {
|
||||||
let path = self.uri.path();
|
let path = self.uri.path();
|
||||||
self.state.path_segments.iter().cloned()
|
self.state.path_segments.iter().cloned()
|
||||||
.map(move |(i, j)| path[i..j].into())
|
.map(move |(i, j)| path[i..j].into())
|
||||||
@ -769,19 +769,19 @@ impl<'r> Request<'r> {
|
|||||||
/// Set `self`'s parameters given that the route used to reach this request
|
/// Set `self`'s parameters given that the route used to reach this request
|
||||||
/// was `route`. Use during routing when attempting a given route.
|
/// was `route`. Use during routing when attempting a given route.
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn set_route(&self, route: &'r Route) {
|
pub(crate) fn set_route(&self, route: &'r Route) {
|
||||||
self.state.route.set(Some(route));
|
self.state.route.set(Some(route));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Set the method of `self`, even when `self` is a shared reference. Used
|
/// Set the method of `self`, even when `self` is a shared reference. Used
|
||||||
/// during routing to override methods for re-routing.
|
/// during routing to override methods for re-routing.
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn _set_method(&self, method: Method) {
|
pub(crate) fn _set_method(&self, method: Method) {
|
||||||
self.method.set(method);
|
self.method.set(method);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Convert from Hyper types into a Rocket Request.
|
/// Convert from Hyper types into a Rocket Request.
|
||||||
crate fn from_hyp(
|
pub(crate) fn from_hyp(
|
||||||
rocket: &'r Rocket,
|
rocket: &'r Rocket,
|
||||||
h_method: hyper::Method,
|
h_method: hyper::Method,
|
||||||
h_headers: hyper::header::Headers,
|
h_headers: hyper::header::Headers,
|
||||||
|
@ -30,7 +30,7 @@ mod stream;
|
|||||||
mod response;
|
mod response;
|
||||||
mod debug;
|
mod debug;
|
||||||
|
|
||||||
crate mod flash;
|
pub(crate) mod flash;
|
||||||
|
|
||||||
pub mod content;
|
pub mod content;
|
||||||
pub mod status;
|
pub mod status;
|
||||||
|
@ -973,7 +973,7 @@ impl<'r> Response<'r> {
|
|||||||
// Makes the `Read`er in the body empty but leaves the size of the body if
|
// Makes the `Read`er in the body empty but leaves the size of the body if
|
||||||
// it exists. Only meant to be used to handle HEAD requests automatically.
|
// it exists. Only meant to be used to handle HEAD requests automatically.
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
crate fn strip_body(&mut self) {
|
pub(crate) fn strip_body(&mut self) {
|
||||||
if let Some(body) = self.take_body() {
|
if let Some(body) = self.take_body() {
|
||||||
self.body = match body {
|
self.body = match body {
|
||||||
Body::Sized(_, n) => Some(Body::Sized(Box::new(io::empty()), n)),
|
Body::Sized(_, n) => Some(Body::Sized(Box::new(io::empty()), n)),
|
||||||
|
@ -29,11 +29,11 @@ use http::uri::Origin;
|
|||||||
/// The main `Rocket` type: used to mount routes and catchers and launch the
|
/// The main `Rocket` type: used to mount routes and catchers and launch the
|
||||||
/// application.
|
/// application.
|
||||||
pub struct Rocket {
|
pub struct Rocket {
|
||||||
crate config: Config,
|
pub(crate) config: Config,
|
||||||
router: Router,
|
router: Router,
|
||||||
default_catchers: HashMap<u16, Catcher>,
|
default_catchers: HashMap<u16, Catcher>,
|
||||||
catchers: HashMap<u16, Catcher>,
|
catchers: HashMap<u16, Catcher>,
|
||||||
crate state: Container,
|
pub(crate) state: Container,
|
||||||
fairings: Fairings,
|
fairings: Fairings,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -200,7 +200,7 @@ impl Rocket {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn dispatch<'s, 'r>(
|
pub(crate) fn dispatch<'s, 'r>(
|
||||||
&'s self,
|
&'s self,
|
||||||
request: &'r mut Request<'s>,
|
request: &'r mut Request<'s>,
|
||||||
data: Data
|
data: Data
|
||||||
@ -283,7 +283,7 @@ impl Rocket {
|
|||||||
// (ensuring `handler` takes an immutable borrow), any caller to `route`
|
// (ensuring `handler` takes an immutable borrow), any caller to `route`
|
||||||
// should be able to supply an `&mut` and retain an `&` after the call.
|
// should be able to supply an `&mut` and retain an `&` after the call.
|
||||||
#[inline]
|
#[inline]
|
||||||
crate fn route<'s, 'r>(
|
pub(crate) fn route<'s, 'r>(
|
||||||
&'s self,
|
&'s self,
|
||||||
request: &'r Request<'s>,
|
request: &'r Request<'s>,
|
||||||
mut data: Data,
|
mut data: Data,
|
||||||
@ -317,7 +317,7 @@ impl Rocket {
|
|||||||
// catcher for `status`, the catcher is called. If the catcher fails to
|
// catcher for `status`, the catcher is called. If the catcher fails to
|
||||||
// return a good response, the 500 catcher is executed. If there is no
|
// return a good response, the 500 catcher is executed. If there is no
|
||||||
// registered catcher for `status`, the default catcher is used.
|
// registered catcher for `status`, the default catcher is used.
|
||||||
crate fn handle_error<'r>(
|
pub(crate) fn handle_error<'r>(
|
||||||
&self,
|
&self,
|
||||||
status: Status,
|
status: Status,
|
||||||
req: &'r Request
|
req: &'r Request
|
||||||
@ -668,7 +668,7 @@ impl Rocket {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn prelaunch_check(mut self) -> Result<Rocket, LaunchError> {
|
pub(crate) fn prelaunch_check(mut self) -> Result<Rocket, LaunchError> {
|
||||||
self.router = match self.router.collisions() {
|
self.router = match self.router.collisions() {
|
||||||
Ok(router) => router,
|
Ok(router) => router,
|
||||||
Err(e) => return Err(LaunchError::new(LaunchErrorKind::Collision(e)))
|
Err(e) => return Err(LaunchError::new(LaunchErrorKind::Collision(e)))
|
||||||
|
@ -12,7 +12,7 @@ use http::Method;
|
|||||||
type Selector = Method;
|
type Selector = Method;
|
||||||
|
|
||||||
// A handler to use when one is needed temporarily.
|
// A handler to use when one is needed temporarily.
|
||||||
crate fn dummy_handler<'r>(r: &'r ::Request, _: ::Data) -> ::handler::Outcome<'r> {
|
pub(crate) fn dummy_handler<'r>(r: &'r ::Request, _: ::Data) -> ::handler::Outcome<'r> {
|
||||||
::Outcome::from(r, ())
|
::Outcome::from(r, ())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,7 +48,7 @@ impl Router {
|
|||||||
matches
|
matches
|
||||||
}
|
}
|
||||||
|
|
||||||
crate fn collisions(mut self) -> Result<Router, Vec<(Route, Route)>> {
|
pub(crate) fn collisions(mut self) -> Result<Router, Vec<(Route, Route)>> {
|
||||||
let mut collisions = vec![];
|
let mut collisions = vec![];
|
||||||
for routes in self.routes.values_mut() {
|
for routes in self.routes.values_mut() {
|
||||||
for i in 0..routes.len() {
|
for i in 0..routes.len() {
|
||||||
|
@ -30,14 +30,14 @@ pub struct Route {
|
|||||||
/// The media type this route matches against, if any.
|
/// The media type this route matches against, if any.
|
||||||
pub format: Option<MediaType>,
|
pub format: Option<MediaType>,
|
||||||
/// Cached metadata that aids in routing later.
|
/// Cached metadata that aids in routing later.
|
||||||
crate metadata: Metadata
|
pub(crate) metadata: Metadata
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Default, Clone)]
|
#[derive(Debug, Default, Clone)]
|
||||||
crate struct Metadata {
|
pub(crate) struct Metadata {
|
||||||
crate path_segments: Vec<RouteSegment<'static, Path>>,
|
pub(crate) path_segments: Vec<RouteSegment<'static, Path>>,
|
||||||
crate query_segments: Option<Vec<RouteSegment<'static, Query>>>,
|
pub(crate) query_segments: Option<Vec<RouteSegment<'static, Query>>>,
|
||||||
crate fully_dynamic_query: bool,
|
pub(crate) fully_dynamic_query: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Metadata {
|
impl Metadata {
|
||||||
|
@ -1,3 +1 @@
|
|||||||
#![feature(external_doc)]
|
|
||||||
|
|
||||||
rocket::rocket_internal_guide_tests!("../guide/*.md");
|
rocket::rocket_internal_guide_tests!("../guide/*.md");
|
||||||
|
Loading…
Reference in New Issue
Block a user