Stationpedia docs
This commit is contained in:
@@ -5,6 +5,8 @@ mod macros;
|
||||
pub trait Documentation {
|
||||
/// Retreive documentation for this specific item.
|
||||
fn docs(&self) -> String;
|
||||
|
||||
fn get_all_documentation() -> Vec<(&'static str, String)>;
|
||||
}
|
||||
|
||||
pub mod prelude {
|
||||
|
||||
@@ -55,7 +55,7 @@ macro_rules! documented {
|
||||
)*
|
||||
}
|
||||
|
||||
// 2. Implement the Trait
|
||||
// 2. Implement the Documentation Trait
|
||||
impl Documentation for $name {
|
||||
fn docs(&self) -> String {
|
||||
match self {
|
||||
@@ -79,6 +79,33 @@ macro_rules! documented {
|
||||
)*
|
||||
}
|
||||
}
|
||||
|
||||
// 3. Implement Static Documentation Provider
|
||||
#[allow(dead_code)]
|
||||
fn get_all_documentation() -> Vec<(&'static str, String)> {
|
||||
vec![
|
||||
$(
|
||||
(
|
||||
stringify!($variant),
|
||||
{
|
||||
// Re-use the same extraction logic
|
||||
let doc_lines: &[Option<&str>] = &[
|
||||
$(
|
||||
documented!(@doc_filter #[ $($variant_attr)* ])
|
||||
),*
|
||||
];
|
||||
doc_lines.iter()
|
||||
.filter_map(|&d| d)
|
||||
.collect::<Vec<_>>()
|
||||
.join("\n")
|
||||
.trim()
|
||||
.to_string()
|
||||
}
|
||||
)
|
||||
),*
|
||||
]
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
@@ -236,6 +236,13 @@ impl Documentation for SysCall {
|
||||
Self::Math(m) => m.docs(),
|
||||
}
|
||||
}
|
||||
|
||||
fn get_all_documentation() -> Vec<(&'static str, String)> {
|
||||
let mut all_docs = System::get_all_documentation();
|
||||
all_docs.extend(Math::get_all_documentation());
|
||||
|
||||
all_docs
|
||||
}
|
||||
}
|
||||
|
||||
impl std::fmt::Display for SysCall {
|
||||
|
||||
@@ -95,6 +95,10 @@ impl Documentation for TokenType {
|
||||
_ => "".into(),
|
||||
}
|
||||
}
|
||||
|
||||
fn get_all_documentation() -> Vec<(&'static str, String)> {
|
||||
Keyword::get_all_documentation()
|
||||
}
|
||||
}
|
||||
|
||||
impl From<TokenType> for u32 {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
use compiler::Compiler;
|
||||
use helpers::Documentation;
|
||||
use parser::Parser;
|
||||
use parser::{sys_call::SysCall, Parser};
|
||||
use safer_ffi::prelude::*;
|
||||
use std::io::BufWriter;
|
||||
use tokenizer::{
|
||||
@@ -27,6 +27,13 @@ pub struct FfiRange {
|
||||
end_line: u32,
|
||||
}
|
||||
|
||||
#[derive_ReprC]
|
||||
#[repr(C)]
|
||||
pub struct FfiDocumentedItem {
|
||||
item_name: safer_ffi::String,
|
||||
docs: safer_ffi::String,
|
||||
}
|
||||
|
||||
impl From<lsp_types::Range> for FfiRange {
|
||||
fn from(value: lsp_types::Range) -> Self {
|
||||
Self {
|
||||
@@ -77,6 +84,11 @@ pub fn free_string(s: safer_ffi::String) {
|
||||
drop(s)
|
||||
}
|
||||
|
||||
#[ffi_export]
|
||||
pub fn free_docs_vec(v: safer_ffi::Vec<FfiDocumentedItem>) {
|
||||
drop(v)
|
||||
}
|
||||
|
||||
/// C# handles strings as UTF16. We do NOT want to allocate that memory in C# because
|
||||
/// we want to avoid GC. So we pass it to Rust to handle all the memory allocations.
|
||||
/// This should result in the ability to compile many times without triggering frame drops
|
||||
@@ -184,3 +196,26 @@ pub fn diagnose_source(input: safer_ffi::slice::Ref<'_, u16>) -> safer_ffi::Vec<
|
||||
|
||||
res.unwrap_or(vec![].into())
|
||||
}
|
||||
|
||||
#[ffi_export]
|
||||
pub fn get_docs() -> safer_ffi::Vec<FfiDocumentedItem> {
|
||||
let res = std::panic::catch_unwind(|| {
|
||||
let mut docs = SysCall::get_all_documentation();
|
||||
docs.extend(TokenType::get_all_documentation());
|
||||
|
||||
docs
|
||||
});
|
||||
|
||||
let Ok(result) = res else {
|
||||
return vec![].into();
|
||||
};
|
||||
|
||||
result
|
||||
.into_iter()
|
||||
.map(|(key, doc)| FfiDocumentedItem {
|
||||
item_name: key.into(),
|
||||
docs: doc.into(),
|
||||
})
|
||||
.collect::<Vec<_>>()
|
||||
.into()
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user