Fix docs gen

This commit is contained in:
Filip Tibell 2023-03-24 12:38:27 +01:00
parent 2c6e84bbc1
commit 673c193228
No known key found for this signature in database
4 changed files with 79 additions and 6 deletions

27
Cargo.lock generated
View file

@ -676,6 +676,12 @@ version = "0.23.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "8e4afd9ad95555081e109fe1d21f2a30c691b5f0919c67dfa690a2e1eb6bd51c" checksum = "8e4afd9ad95555081e109fe1d21f2a30c691b5f0919c67dfa690a2e1eb6bd51c"
[[package]]
name = "glob"
version = "0.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d2fabcfbdc87f4758337ca535fb41a6d701b65693ce38287d856d1674551ec9b"
[[package]] [[package]]
name = "h2" name = "h2"
version = "0.3.16" version = "0.3.16"
@ -831,6 +837,26 @@ dependencies = [
"unicode-normalization", "unicode-normalization",
] ]
[[package]]
name = "include_dir"
version = "0.7.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "18762faeff7122e89e0857b02f7ce6fcc0d101d5e9ad2ad7846cc01d61b7f19e"
dependencies = [
"glob",
"include_dir_macros",
]
[[package]]
name = "include_dir_macros"
version = "0.7.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b139284b5cf57ecfa712bcc66950bb635b31aff41c188e8a4cfc758eca374a3f"
dependencies = [
"proc-macro2",
"quote",
]
[[package]] [[package]]
name = "indexmap" name = "indexmap"
version = "1.9.2" version = "1.9.2"
@ -1010,6 +1036,7 @@ dependencies = [
"console", "console",
"full_moon", "full_moon",
"futures-util", "futures-util",
"include_dir",
"lazy_static", "lazy_static",
"lune", "lune",
"regex", "regex",

View file

@ -34,4 +34,5 @@ anyhow = "1.0"
clap = { version = "4.1", features = ["derive"] } clap = { version = "4.1", features = ["derive"] }
full_moon = { version = "0.17", features = ["roblox"] } full_moon = { version = "0.17", features = ["roblox"] }
include_dir = { version = "0.7.3", features = ["glob"] }
regex = { version = "1.7", default-features = false, features = ["std"] } regex = { version = "1.7", default-features = false, features = ["std"] }

View file

@ -3,6 +3,7 @@ use std::process::ExitCode;
use anyhow::{Context, Result}; use anyhow::{Context, Result};
use clap::{CommandFactory, Parser}; use clap::{CommandFactory, Parser};
use include_dir::{include_dir, Dir};
use lune::Lune; use lune::Lune;
use tokio::{ use tokio::{
fs::{read as read_to_vec, write}, fs::{read as read_to_vec, write},
@ -12,7 +13,8 @@ use tokio::{
use crate::{ use crate::{
gen::{ gen::{
generate_docs_json_from_definitions, generate_luau_defs_from_definitions, generate_docs_json_from_definitions, generate_luau_defs_from_definitions,
generate_selene_defs_from_definitions, generate_wiki_dir_from_definitions, generate_selene_defs_from_definitions, generate_typedefs_file_from_dir,
generate_wiki_dir_from_definitions,
}, },
utils::{ utils::{
files::{discover_script_file_path_including_lune_dirs, strip_shebang}, files::{discover_script_file_path_including_lune_dirs, strip_shebang},
@ -24,7 +26,7 @@ pub(crate) const FILE_NAME_SELENE_TYPES: &str = "lune.yml";
pub(crate) const FILE_NAME_LUAU_TYPES: &str = "luneTypes.d.luau"; pub(crate) const FILE_NAME_LUAU_TYPES: &str = "luneTypes.d.luau";
pub(crate) const FILE_NAME_DOCS: &str = "luneDocs.json"; pub(crate) const FILE_NAME_DOCS: &str = "luneDocs.json";
pub(crate) const FILE_CONTENTS_LUAU_TYPES: &str = include_str!("../../../docs/luneTypes.d.luau"); pub(crate) static TYPEDEFS_DIR: Dir<'_> = include_dir!("docs/typedefs");
/// A Luau script runner /// A Luau script runner
#[derive(Parser, Debug, Default, Clone)] #[derive(Parser, Debug, Default, Clone)]
@ -121,26 +123,27 @@ impl Cli {
|| self.generate_docs_file || self.generate_docs_file
|| self.generate_gitbook_dir; || self.generate_gitbook_dir;
if generate_file_requested { if generate_file_requested {
let definitions = generate_typedefs_file_from_dir(&TYPEDEFS_DIR);
if self.generate_luau_types { if self.generate_luau_types {
generate_and_save_file(FILE_NAME_LUAU_TYPES, "Luau type definitions", || { generate_and_save_file(FILE_NAME_LUAU_TYPES, "Luau type definitions", || {
generate_luau_defs_from_definitions(FILE_CONTENTS_LUAU_TYPES) generate_luau_defs_from_definitions(&definitions)
}) })
.await?; .await?;
} }
if self.generate_selene_types { if self.generate_selene_types {
generate_and_save_file(FILE_NAME_SELENE_TYPES, "Selene type definitions", || { generate_and_save_file(FILE_NAME_SELENE_TYPES, "Selene type definitions", || {
generate_selene_defs_from_definitions(FILE_CONTENTS_LUAU_TYPES) generate_selene_defs_from_definitions(&definitions)
}) })
.await?; .await?;
} }
if self.generate_docs_file { if self.generate_docs_file {
generate_and_save_file(FILE_NAME_DOCS, "Luau LSP documentation", || { generate_and_save_file(FILE_NAME_DOCS, "Luau LSP documentation", || {
generate_docs_json_from_definitions(FILE_CONTENTS_LUAU_TYPES, "roblox/global") generate_docs_json_from_definitions(&definitions, "roblox/global")
}) })
.await?; .await?;
} }
if self.generate_gitbook_dir { if self.generate_gitbook_dir {
generate_wiki_dir_from_definitions(FILE_CONTENTS_LUAU_TYPES).await?; generate_wiki_dir_from_definitions(&definitions).await?;
} }
} }
if self.script_path.is_none() { if self.script_path.is_none() {

View file

@ -1,3 +1,6 @@
use include_dir::Dir;
use regex::Regex;
mod docs_file; mod docs_file;
mod luau_defs; mod luau_defs;
mod selene_defs; mod selene_defs;
@ -9,3 +12,42 @@ pub use docs_file::generate_from_type_definitions as generate_docs_json_from_def
pub use luau_defs::generate_from_type_definitions as generate_luau_defs_from_definitions; pub use luau_defs::generate_from_type_definitions as generate_luau_defs_from_definitions;
pub use selene_defs::generate_from_type_definitions as generate_selene_defs_from_definitions; pub use selene_defs::generate_from_type_definitions as generate_selene_defs_from_definitions;
pub use wiki_dir::generate_from_type_definitions as generate_wiki_dir_from_definitions; pub use wiki_dir::generate_from_type_definitions as generate_wiki_dir_from_definitions;
pub fn generate_typedefs_file_from_dir(dir: &Dir<'_>) -> String {
let mut result = String::new();
for entry in dir.find("*.luau").unwrap() {
let entry_file = entry.as_file().unwrap();
let entry_name = entry_file.path().file_name().unwrap().to_string_lossy();
if entry_name.contains("Globals") {
continue;
}
let typedef_name = entry_name.trim_end_matches(".luau");
let typedef_contents = entry_file.contents_utf8().unwrap().to_string().replace(
&format!("export type {typedef_name} = "),
&format!("declare {}: ", typedef_name.to_ascii_lowercase()),
);
if !result.is_empty() {
result.push_str(&"\n".repeat(10));
}
result.push_str(&typedef_contents);
}
let globals_contents = dir
.get_file("Globals.luau")
.unwrap()
.contents_utf8()
.unwrap();
let regex_export_to_declare = Regex::new(r#"export type (\w+) = "#).unwrap();
let regexed_globals = regex_export_to_declare.replace_all(globals_contents, "declare $1: ");
result.push_str(&"\n".repeat(10));
result.push_str(&regexed_globals);
result
}