feat: implement expression checker (#714)

* feat: implements expression checker

* dev: resolve information

* dev: delete def_use

* stage

* stage

* stage

* stage concurrent

* stage concurrent

* dev: better concurrency

* dev: final constant evaluation improvement

* dev: change reference site

* dev: handle comments

* dev: remove indirect import structure

* dev: adjust linked_def impl

* dev: finalize goto definition impl

* dev: replace all old import and def_use analyses with expr analysis

* dev: update expr_of snapshots

* dev: split def/expr, refactor definition

* dev: more consistent definition solver

* dev: rename definition crate

* dev: references work again

* dev: resolve root decl

* dev: resolve root decl

* dev: resolve global definitions

* dev: resolve tokens with world

* feat: render semantic tokens with expression information

* dev: loop detection

* dev: recover type checking

* dev: recover more type checking

* dev: refactor analysis context

* fix: process case of spread left

* dev: label inference

* dev: recover more signature checking

* dev: recover more ident reference checking

* dev: pass all tests

* Revert "dev: dirty changes"

This reverts commit 9ae2dacd0c96851e088feea76c61c184a1cf9722.

* test: update snapshot

* fix: bad cached signatures

* fix: slash problem
This commit is contained in:
Myriad-Dreamin 2024-10-25 23:52:11 +08:00 committed by GitHub
parent 136b162360
commit 81ebc8a635
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
173 changed files with 5529 additions and 4370 deletions

View file

@ -16,6 +16,17 @@ use crate::docs::{file_id_repr, module_docs, symbol_docs, SymbolDocs, SymbolsInf
use crate::ty::Ty;
use crate::AnalysisContext;
/// Check Package.
pub fn check_package(ctx: &mut AnalysisContext, spec: &PackageInfo) -> StrResult<()> {
let toml_id = get_manifest_id(spec)?;
let manifest = get_manifest(ctx.world(), toml_id)?;
let entry_point = toml_id.join(&manifest.package.entrypoint);
ctx.shared_().preload_package(entry_point);
Ok(())
}
/// Generate full documents in markdown format
pub fn package_docs(
ctx: &mut AnalysisContext,
@ -30,6 +41,9 @@ pub fn package_docs(
let for_spec = toml_id.package().unwrap();
let entry_point = toml_id.join(&manifest.package.entrypoint);
ctx.preload_package(entry_point);
let SymbolsInfo { root, module_uses } = module_docs(ctx, entry_point)?;
log::debug!("module_uses: {module_uses:#?}");

View file

@ -7,7 +7,7 @@ use parking_lot::Mutex;
use serde::{Deserialize, Serialize};
use tinymist_world::base::{EntryState, ShadowApi, TaskInputs};
use tinymist_world::LspWorld;
use typst::foundations::{Bytes, Func, Value};
use typst::foundations::{Bytes, Value};
use typst::syntax::LinkedNode;
use typst::{
diag::StrResult,
@ -15,7 +15,7 @@ use typst::{
};
use super::tidy::*;
use crate::analysis::{ParamAttrs, ParamSpec};
use crate::analysis::{ParamAttrs, ParamSpec, Signature, ToFunc};
use crate::docs::library;
use crate::ty::{DocSource, Interned};
use crate::upstream::plain_docs_sentence;
@ -101,7 +101,8 @@ pub(crate) fn symbol_docs(
docs: Option<&str>,
doc_ty: Option<ShowTypeRepr>,
) -> Result<SymbolDocs, String> {
let signature = sym_value.and_then(|e| signature_docs(ctx, e, doc_ty));
let signature =
sym_value.and_then(|e| signature_docs(&ctx.signature_dyn(e.to_func()?), doc_ty));
if let Some(signature) = signature {
return Ok(SymbolDocs::Function(Box::new(signature)));
}
@ -344,12 +345,9 @@ pub(crate) fn variable_docs(ctx: &mut AnalysisContext, pos: &LinkedNode) -> Opti
}
pub(crate) fn signature_docs(
ctx: &mut AnalysisContext,
runtime_fn: &Value,
sig: &Signature,
mut doc_ty: Option<ShowTypeRepr>,
) -> Option<SignatureDocs> {
let func = runtime_fn.clone().cast::<Func>().ok()?;
let sig = ctx.signature_dyn(func.clone());
let type_sig = sig.type_sig().clone();
let pos_in = sig