Add syntax::make::ty_alias

The function is fully compliant with the specifications from the Rust Reference.
This commit is contained in:
alibektas 2023-04-17 00:41:08 +03:00
parent a6464392c1
commit 7c9e4e10bc

View File

@ -14,6 +14,8 @@
use crate::{ast, utils::is_raw_identifier, AstNode, SourceFile, SyntaxKind, SyntaxToken};
use super::WhereClause;
/// While the parent module defines basic atomic "constructors", the `ext`
/// module defines shortcuts for common things.
///
@ -158,6 +160,52 @@ fn ty_from_text(text: &str) -> ast::Type {
ast_from_text(&format!("type _T = {text};"))
}
/** Related goto [link](https://doc.rust-lang.org/reference/items/type-aliases.html)
Type Alias syntax is
```
TypeAlias :
type IDENTIFIER GenericParams? ( : TypeParamBounds )? WhereClause? ( = Type WhereClause?)? ;
```
FIXME : ident should be of type ast::Ident
*/
pub fn ty_alias(
ident: String,
generic_param_list: Option<ast::GenericParamList>,
type_param_bounds: Option<ast::TypeParam>,
where_clause: Option<WhereClause>,
assignment: Option<(ast::Type, Option<ast::WhereClause>)>,
) -> ast::TypeAlias {
let mut s = String::new();
s.push_str(format!("type {}", ident.as_str()).as_str());
if let Some(list) = generic_param_list {
s.push_str(list.to_string().as_str());
}
if let Some(list) = type_param_bounds {
s.push_str(format!(" : {}", list.to_string().as_str()).as_str());
}
if let Some(cl) = where_clause {
s.push_str(format!(" {}", cl.to_string().as_str()).as_str());
}
if let Some(exp) = assignment {
if let Some(cl) = exp.1 {
s.push_str(
format!("= {} {}", exp.0.to_string().as_str(), cl.to_string().as_str()).as_str(),
);
} else {
s.push_str(format!("= {}", exp.0.to_string().as_str()).as_str());
}
}
s.push_str(";");
ast_from_text(s.as_str())
}
pub fn assoc_item_list() -> ast::AssocItemList {
ast_from_text("impl C for D {}")
}