pub struct IntoLiteralString<T>(/* private fields */);Expand description
Parses T and creates a LiteralString from it. When T implements Default, such as
single string (non group) keywords, operators and Const* literals. It can be used to
create IntoLiteralString on the fly.
§Example
let mut token_iter = "foo 123".to_token_iter();
let parsed = <IntoLiteralString<Cons<Ident, LiteralInteger>>>::parser(&mut token_iter).unwrap();
assert_tokens_eq!(parsed, r#" "foo 123" "#);
keyword!{Foo = "foo"}
let default = <IntoLiteralString<Cons<Foo, ConstInteger<1234>>>>::default();
assert_tokens_eq!(default, r#" "foo 1234" "#);Implementations§
Source§impl<T> IntoLiteralString<T>where
T: ToTokens,
impl<T> IntoLiteralString<T>where
T: ToTokens,
Sourcepub fn from(from: &T) -> IntoLiteralString<T>
pub fn from(from: &T) -> IntoLiteralString<T>
Creates a IntoLiteralString from an AST.
let mut token_iter = "foo 123".to_token_iter();
let parsed = <Cons<Ident, LiteralInteger>>::parser(&mut token_iter).unwrap();
let as_string = IntoLiteralString::from(&parsed);
assert_eq!(as_string.as_str(), "foo 123");Source§impl<T> IntoLiteralString<T>
impl<T> IntoLiteralString<T>
Sourcepub fn into_inner(self) -> LiteralString
pub fn into_inner(self) -> LiteralString
Destructures IntoLiteralString<T> to get the inner LiteralString.
Trait Implementations§
Source§impl<T> Debug for IntoLiteralString<T>where
T: Debug,
impl<T> Debug for IntoLiteralString<T>where
T: Debug,
Source§impl<T> Default for IntoLiteralString<T>
impl<T> Default for IntoLiteralString<T>
Source§fn default() -> IntoLiteralString<T>
fn default() -> IntoLiteralString<T>
Returns the “default value” for a type. Read more
Source§impl<T> Parser for IntoLiteralString<T>
impl<T> Parser for IntoLiteralString<T>
Source§fn parser(tokens: &mut TokenIter) -> Result<IntoLiteralString<T>, Error>
fn parser(tokens: &mut TokenIter) -> Result<IntoLiteralString<T>, Error>
The actual parsing function that must be implemented. This mutates the
tokens
iterator directly. It should not be called from user code except for implementing
parsers itself and then only when the rules below are followed. Read moreSource§impl<T> ToTokens for IntoLiteralString<T>
impl<T> ToTokens for IntoLiteralString<T>
Source§fn to_tokens(&self, tokens: &mut TokenStream)
fn to_tokens(&self, tokens: &mut TokenStream)
Source§fn into_token_iter(self) -> TokenIter ⓘwhere
Self: Sized,
fn into_token_iter(self) -> TokenIter ⓘwhere
Self: Sized,
Convert
self into a TokenIter object.Source§fn to_token_stream(&self) -> TokenStream
fn to_token_stream(&self) -> TokenStream
Convert
&self into a TokenStream object.Source§fn into_token_stream(self) -> TokenStreamwhere
Self: Sized,
fn into_token_stream(self) -> TokenStreamwhere
Self: Sized,
Convert
self into a TokenStream object.Auto Trait Implementations§
impl<T> Freeze for IntoLiteralString<T>
impl<T> RefUnwindSafe for IntoLiteralString<T>where
T: RefUnwindSafe,
impl<T> !Send for IntoLiteralString<T>
impl<T> !Sync for IntoLiteralString<T>
impl<T> Unpin for IntoLiteralString<T>where
T: Unpin,
impl<T> UnwindSafe for IntoLiteralString<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> DynamicTokens for T
impl<T> DynamicTokens for T
Source§impl<T> Parse for Twhere
T: Parser,
impl<T> Parse for Twhere
T: Parser,
Source§fn parse(tokens: &mut TokenIter) -> Result<Self, Error>
fn parse(tokens: &mut TokenIter) -> Result<Self, Error>
This is the user facing API to parse grammatical entities. Calls a
parser() within a
transaction. Commits changes on success and returns the parsed value. Read more