Merge pull request #597 from schungx/master
Gate definitions with internals feature.
This commit is contained in:
commit
e91286a2b9
@ -88,7 +88,7 @@ required-features = ["serde"]
|
|||||||
|
|
||||||
[[example]]
|
[[example]]
|
||||||
name = "definitions"
|
name = "definitions"
|
||||||
required-features = ["metadata"]
|
required-features = ["metadata", "internals"]
|
||||||
|
|
||||||
[profile.release]
|
[profile.release]
|
||||||
lto = "fat"
|
lto = "fat"
|
||||||
|
@ -1,19 +1,21 @@
|
|||||||
//! Module that defines functions to output definition files for [`Engine`].
|
//! Module that defines functions to output definition files for [`Engine`].
|
||||||
|
//! Exported under the `internals` and `metadata` feature only.
|
||||||
|
#![cfg(feature = "internals")]
|
||||||
#![cfg(feature = "metadata")]
|
#![cfg(feature = "metadata")]
|
||||||
|
|
||||||
use crate::module::FuncInfo;
|
use crate::module::FuncInfo;
|
||||||
use crate::plugin::*;
|
use crate::plugin::*;
|
||||||
use crate::tokenizer::is_valid_function_name;
|
use crate::tokenizer::{is_valid_function_name, Token};
|
||||||
use crate::{Engine, Module, Scope, INT};
|
use crate::{Engine, Module, Scope, INT};
|
||||||
use core::fmt::Write;
|
|
||||||
|
|
||||||
#[cfg(feature = "no_std")]
|
#[cfg(feature = "no_std")]
|
||||||
use std::prelude::v1::*;
|
use std::prelude::v1::*;
|
||||||
use std::{any::type_name, borrow::Cow, cmp::Ordering, fmt};
|
use std::{any::type_name, borrow::Cow, cmp::Ordering, fmt, fmt::Write};
|
||||||
|
|
||||||
impl Engine {
|
impl Engine {
|
||||||
/// Return [`Definitions`] that can be used to generate definition files for the [`Engine`].
|
/// _(metadata, internals)_ Return [`Definitions`] that can be used to generate definition files
|
||||||
/// Exported under the `metadata` feature only.
|
/// for the [`Engine`].
|
||||||
|
/// Exported under the `internals` and `metadata` feature only.
|
||||||
///
|
///
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
@ -37,9 +39,9 @@ impl Engine {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return [`Definitions`] that can be used to generate definition files for the [`Engine`] and
|
/// _(metadata, internals)_ Return [`Definitions`] that can be used to generate definition files
|
||||||
/// the given [`Scope`].
|
/// for the [`Engine`] and the given [`Scope`].
|
||||||
/// Exported under the `metadata` feature only.
|
/// Exported under the `internals` and `metadata` feature only.
|
||||||
///
|
///
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
@ -64,7 +66,9 @@ impl Engine {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Definitions helper type to generate definition files based on the contents of an [`Engine`].
|
/// _(metadata, internals)_ Definitions helper type to generate definition files based on the
|
||||||
|
/// contents of an [`Engine`].
|
||||||
|
/// Exported under the `internals` and `metadata` feature only.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub struct Definitions<'e> {
|
pub struct Definitions<'e> {
|
||||||
@ -76,11 +80,11 @@ pub struct Definitions<'e> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'e> Definitions<'e> {
|
impl<'e> Definitions<'e> {
|
||||||
/// Whether to write `module ...` headers in separate definitions,
|
/// Write `module ...` headers in separate definitions, default `false`.
|
||||||
/// `false` by default.
|
|
||||||
///
|
///
|
||||||
/// Headers are always present in content
|
/// Headers are always present in content that is expected to be written to a file
|
||||||
/// that is expected to be written to a file (`write_to*` and `*_file` methods).
|
/// (i.e. `write_to*` and `*_file` methods).
|
||||||
|
#[inline(always)]
|
||||||
pub fn with_headers(mut self, headers: bool) -> Self {
|
pub fn with_headers(mut self, headers: bool) -> Self {
|
||||||
self.config.write_headers = headers;
|
self.config.write_headers = headers;
|
||||||
self
|
self
|
||||||
@ -93,6 +97,7 @@ impl<'e> Definitions<'e> {
|
|||||||
///
|
///
|
||||||
/// This function creates the directories and overrides any existing files if needed.
|
/// This function creates the directories and overrides any existing files if needed.
|
||||||
#[cfg(all(not(feature = "no_std"), not(target_family = "wasm")))]
|
#[cfg(all(not(feature = "no_std"), not(target_family = "wasm")))]
|
||||||
|
#[inline]
|
||||||
pub fn write_to_dir(&self, path: impl AsRef<std::path::Path>) -> std::io::Result<()> {
|
pub fn write_to_dir(&self, path: impl AsRef<std::path::Path>) -> std::io::Result<()> {
|
||||||
use std::fs;
|
use std::fs;
|
||||||
|
|
||||||
@ -111,11 +116,14 @@ impl<'e> Definitions<'e> {
|
|||||||
///
|
///
|
||||||
/// The parent directory must exist but the file will be created or overwritten as needed.
|
/// The parent directory must exist but the file will be created or overwritten as needed.
|
||||||
#[cfg(all(not(feature = "no_std"), not(target_family = "wasm")))]
|
#[cfg(all(not(feature = "no_std"), not(target_family = "wasm")))]
|
||||||
|
#[inline(always)]
|
||||||
pub fn write_to_file(&self, path: impl AsRef<std::path::Path>) -> std::io::Result<()> {
|
pub fn write_to_file(&self, path: impl AsRef<std::path::Path>) -> std::io::Result<()> {
|
||||||
std::fs::write(path, self.single_file())
|
std::fs::write(path, self.single_file())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return all definitions merged into a single file.
|
/// Return all definitions merged into a single file.
|
||||||
|
#[inline]
|
||||||
|
#[must_use]
|
||||||
pub fn single_file(&self) -> String {
|
pub fn single_file(&self) -> String {
|
||||||
let config = DefinitionsConfig {
|
let config = DefinitionsConfig {
|
||||||
write_headers: false,
|
write_headers: false,
|
||||||
@ -191,11 +199,14 @@ impl<'e> Definitions<'e> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Return definitions for all builtin functions.
|
/// Return definitions for all builtin functions.
|
||||||
|
#[inline(always)]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn builtin_functions(&self) -> String {
|
pub fn builtin_functions(&self) -> String {
|
||||||
self.builtin_functions_impl(&self.config)
|
self.builtin_functions_impl(&self.config)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Return definitions for all builtin functions.
|
||||||
|
#[must_use]
|
||||||
fn builtin_functions_impl(&self, config: &DefinitionsConfig) -> String {
|
fn builtin_functions_impl(&self, config: &DefinitionsConfig) -> String {
|
||||||
let def = include_str!("builtin-functions.d.rhai");
|
let def = include_str!("builtin-functions.d.rhai");
|
||||||
|
|
||||||
@ -207,11 +218,14 @@ impl<'e> Definitions<'e> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Return definitions for all builtin operators.
|
/// Return definitions for all builtin operators.
|
||||||
|
#[inline(always)]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn builtin_functions_operators(&self) -> String {
|
pub fn builtin_functions_operators(&self) -> String {
|
||||||
self.builtin_functions_operators_impl(&self.config)
|
self.builtin_functions_operators_impl(&self.config)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Return definitions for all builtin operators.
|
||||||
|
#[must_use]
|
||||||
fn builtin_functions_operators_impl(&self, config: &DefinitionsConfig) -> String {
|
fn builtin_functions_operators_impl(&self, config: &DefinitionsConfig) -> String {
|
||||||
let def = include_str!("builtin-operators.d.rhai");
|
let def = include_str!("builtin-operators.d.rhai");
|
||||||
|
|
||||||
@ -222,13 +236,15 @@ impl<'e> Definitions<'e> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return definitions for all globally available functions
|
/// Return definitions for all globally available functions and constants.
|
||||||
/// and constants.
|
#[inline(always)]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn static_module(&self) -> String {
|
pub fn static_module(&self) -> String {
|
||||||
self.static_module_impl(&self.config)
|
self.static_module_impl(&self.config)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Return definitions for all globally available functions and constants.
|
||||||
|
#[must_use]
|
||||||
fn static_module_impl(&self, config: &DefinitionsConfig) -> String {
|
fn static_module_impl(&self, config: &DefinitionsConfig) -> String {
|
||||||
let mut s = if config.write_headers {
|
let mut s = if config.write_headers {
|
||||||
String::from("module static;\n\n")
|
String::from("module static;\n\n")
|
||||||
@ -249,11 +265,14 @@ impl<'e> Definitions<'e> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Return definitions for all items inside the [`Scope`], if any.
|
/// Return definitions for all items inside the [`Scope`], if any.
|
||||||
|
#[inline(always)]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn scope(&self) -> String {
|
pub fn scope(&self) -> String {
|
||||||
self.scope_impl(&self.config)
|
self.scope_impl(&self.config)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Return definitions for all items inside the [`Scope`], if any.
|
||||||
|
#[must_use]
|
||||||
fn scope_impl(&self, config: &DefinitionsConfig) -> String {
|
fn scope_impl(&self, config: &DefinitionsConfig) -> String {
|
||||||
let mut s = if config.write_headers {
|
let mut s = if config.write_headers {
|
||||||
String::from("module static;\n\n")
|
String::from("module static;\n\n")
|
||||||
@ -272,10 +291,12 @@ impl<'e> Definitions<'e> {
|
|||||||
///
|
///
|
||||||
/// Not available under `no_module`.
|
/// Not available under `no_module`.
|
||||||
#[cfg(not(feature = "no_module"))]
|
#[cfg(not(feature = "no_module"))]
|
||||||
|
#[inline(always)]
|
||||||
pub fn modules(&self) -> impl Iterator<Item = (String, String)> + '_ {
|
pub fn modules(&self) -> impl Iterator<Item = (String, String)> + '_ {
|
||||||
self.modules_impl(&self.config)
|
self.modules_impl(&self.config)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Return a (module name, definitions) pair for each registered static [module][Module].
|
||||||
#[cfg(not(feature = "no_module"))]
|
#[cfg(not(feature = "no_module"))]
|
||||||
fn modules_impl(
|
fn modules_impl(
|
||||||
&self,
|
&self,
|
||||||
@ -481,7 +502,7 @@ fn def_type_name<'a>(ty: &'a str, engine: &'a Engine) -> Cow<'a, str> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Scope<'_> {
|
impl Scope<'_> {
|
||||||
/// Return definitions for all items inside the [`Scope`].
|
/// _(metadata, internals)_ Return definitions for all items inside the [`Scope`].
|
||||||
fn write_definition(&self, writer: &mut dyn fmt::Write) -> fmt::Result {
|
fn write_definition(&self, writer: &mut dyn fmt::Write) -> fmt::Result {
|
||||||
let mut first = true;
|
let mut first = true;
|
||||||
for (name, constant, _) in self.iter_raw() {
|
for (name, constant, _) in self.iter_raw() {
|
||||||
@ -490,7 +511,7 @@ impl Scope<'_> {
|
|||||||
}
|
}
|
||||||
first = false;
|
first = false;
|
||||||
|
|
||||||
let kw = if constant { "const" } else { "let" };
|
let kw = if constant { Token::Const } else { Token::Let };
|
||||||
|
|
||||||
write!(writer, "{kw} {name};")?;
|
write!(writer, "{kw} {name};")?;
|
||||||
}
|
}
|
||||||
|
@ -182,9 +182,6 @@ pub use types::{
|
|||||||
#[cfg(not(feature = "no_custom_syntax"))]
|
#[cfg(not(feature = "no_custom_syntax"))]
|
||||||
pub use api::custom_syntax::Expression;
|
pub use api::custom_syntax::Expression;
|
||||||
|
|
||||||
#[cfg(feature = "metadata")]
|
|
||||||
pub use api::definitions::Definitions;
|
|
||||||
|
|
||||||
/// _(debugging)_ Module containing types for debugging.
|
/// _(debugging)_ Module containing types for debugging.
|
||||||
/// Exported under the `debugging` feature only.
|
/// Exported under the `debugging` feature only.
|
||||||
#[cfg(feature = "debugging")]
|
#[cfg(feature = "debugging")]
|
||||||
@ -312,6 +309,10 @@ pub use ast::FloatWrapper;
|
|||||||
#[cfg(feature = "internals")]
|
#[cfg(feature = "internals")]
|
||||||
pub use eval::{Caches, FnResolutionCache, FnResolutionCacheEntry, GlobalRuntimeState};
|
pub use eval::{Caches, FnResolutionCache, FnResolutionCacheEntry, GlobalRuntimeState};
|
||||||
|
|
||||||
|
#[cfg(feature = "internals")]
|
||||||
|
#[cfg(feature = "metadata")]
|
||||||
|
pub use api::definitions::Definitions;
|
||||||
|
|
||||||
/// Alias to [`smallvec::SmallVec<[T; 3]>`](https://crates.io/crates/smallvec), which is a
|
/// Alias to [`smallvec::SmallVec<[T; 3]>`](https://crates.io/crates/smallvec), which is a
|
||||||
/// specialized [`Vec`] backed by a small, inline, fixed-size array when there are ≤ 3 items stored.
|
/// specialized [`Vec`] backed by a small, inline, fixed-size array when there are ≤ 3 items stored.
|
||||||
///
|
///
|
||||||
|
@ -575,6 +575,13 @@ pub enum Token {
|
|||||||
EOF,
|
EOF,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for Token {
|
||||||
|
#[inline(always)]
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
|
f.write_str(&self.syntax())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Token {
|
impl Token {
|
||||||
/// Get the literal syntax of the token.
|
/// Get the literal syntax of the token.
|
||||||
#[must_use]
|
#[must_use]
|
||||||
|
Loading…
Reference in New Issue
Block a user