1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-12 09:03:42 -05:00

feat: remove conditional unstable type-checking (#21825)

This commit removes conditional type-checking of unstable APIs.

Before this commit `deno check` (or any other type-checking command and
the LSP) would error out if there was an unstable API in the code, but not
`--unstable` flag provided.

This situation hinders DX and makes it harder to configure Deno. Failing
during runtime unless `--unstable` flag is provided is enough in this case.
This commit is contained in:
Bartek Iwańczuk 2024-01-14 18:29:17 +01:00 committed by GitHub
parent f3bb0a1a0e
commit 0d51c1f90e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 16 additions and 30 deletions

View file

@ -1126,7 +1126,7 @@ impl Inner {
"experimentalDecorators": true, "experimentalDecorators": true,
"isolatedModules": true, "isolatedModules": true,
"jsx": "react", "jsx": "react",
"lib": ["deno.ns", "deno.window"], "lib": ["deno.ns", "deno.window", "deno.unstable"],
"module": "esnext", "module": "esnext",
"moduleDetection": "force", "moduleDetection": "force",
"noEmit": true, "noEmit": true,
@ -1137,14 +1137,6 @@ impl Inner {
// TODO(@kitsonk) remove for Deno 1.15 // TODO(@kitsonk) remove for Deno 1.15
"useUnknownInCatchVariables": false, "useUnknownInCatchVariables": false,
})); }));
let config = &self.config;
let workspace_settings = config.workspace_settings();
if workspace_settings.unstable {
let unstable_libs = json!({
"lib": ["deno.ns", "deno.window", "deno.unstable"]
});
tsconfig.merge(&unstable_libs);
}
if let Err(err) = self.merge_user_tsconfig(&mut tsconfig) { if let Err(err) = self.merge_user_tsconfig(&mut tsconfig) {
self.client.show_message(MessageType::WARNING, err); self.client.show_message(MessageType::WARNING, err);
} }

View file

@ -195,7 +195,7 @@ async fn run_subcommand(flags: Flags) -> Result<i32, AnyError> {
}) })
} }
DenoSubcommand::Types => spawn_subcommand(async move { DenoSubcommand::Types => spawn_subcommand(async move {
let types = tsc::get_types_declaration_file_text(flags.unstable); let types = tsc::get_types_declaration_file_text();
display::write_to_stdout_ignore_sigpipe(types.as_bytes()) display::write_to_stdout_ignore_sigpipe(types.as_bytes())
}), }),
#[cfg(feature = "upgrade")] #[cfg(feature = "upgrade")]

View file

@ -1904,7 +1904,7 @@ fn lsp_exclude_config() {
} }
#[test] #[test]
fn lsp_hover_unstable_disabled() { fn lsp_hover_unstable_always_enabled() {
let context = TestContextBuilder::new().use_temp_cwd().build(); let context = TestContextBuilder::new().use_temp_cwd().build();
let mut client = context.new_lsp_command().build(); let mut client = context.new_lsp_command().build();
client.initialize_default(); client.initialize_default();
@ -1930,16 +1930,17 @@ fn lsp_hover_unstable_disabled() {
assert_eq!( assert_eq!(
res, res,
json!({ json!({
"contents": [ "contents":[
{ {
"language": "typescript", "language":"typescript",
"value": "type Deno.ForeignLibraryInterface = /*unresolved*/ any", "value":"interface Deno.ForeignLibraryInterface"
}, },
"", "**UNSTABLE**: New API, yet to be vetted.\n\nA foreign library interface descriptor.",
"\n\n*@category* - FFI",
], ],
"range": { "range":{
"start": { "line": 0, "character": 14 }, "start":{ "line":0, "character":14 },
"end": { "line": 0, "character": 37 } "end":{ "line":0, "character":37 }
} }
}) })
); );
@ -1951,6 +1952,7 @@ fn lsp_hover_unstable_enabled() {
let context = TestContextBuilder::new().use_temp_cwd().build(); let context = TestContextBuilder::new().use_temp_cwd().build();
let mut client = context.new_lsp_command().build(); let mut client = context.new_lsp_command().build();
client.initialize(|builder| { client.initialize(|builder| {
// NOTE(bartlomieju): this is effectively not used anymore.
builder.set_unstable(true); builder.set_unstable(true);
}); });
client.did_open(json!({ client.did_open(json!({

View file

@ -1,6 +1,5 @@
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
use crate::args::CliOptions;
use crate::args::DocFlags; use crate::args::DocFlags;
use crate::args::DocHtmlFlag; use crate::args::DocHtmlFlag;
use crate::args::DocSourceFileFlag; use crate::args::DocSourceFileFlag;
@ -28,17 +27,15 @@ use indexmap::IndexMap;
use std::collections::BTreeMap; use std::collections::BTreeMap;
use std::path::PathBuf; use std::path::PathBuf;
use std::rc::Rc; use std::rc::Rc;
use std::sync::Arc;
async fn generate_doc_nodes_for_builtin_types( async fn generate_doc_nodes_for_builtin_types(
doc_flags: DocFlags, doc_flags: DocFlags,
cli_options: &Arc<CliOptions>,
parser: &dyn ModuleParser, parser: &dyn ModuleParser,
analyzer: &dyn ModuleAnalyzer, analyzer: &dyn ModuleAnalyzer,
) -> Result<IndexMap<ModuleSpecifier, Vec<doc::DocNode>>, AnyError> { ) -> Result<IndexMap<ModuleSpecifier, Vec<doc::DocNode>>, AnyError> {
let source_file_specifier = let source_file_specifier =
ModuleSpecifier::parse("internal://lib.deno.d.ts").unwrap(); ModuleSpecifier::parse("internal://lib.deno.d.ts").unwrap();
let content = get_types_declaration_file_text(cli_options.unstable()); let content = get_types_declaration_file_text();
let mut loader = deno_graph::source::MemoryLoader::new( let mut loader = deno_graph::source::MemoryLoader::new(
vec![( vec![(
source_file_specifier.to_string(), source_file_specifier.to_string(),
@ -86,7 +83,6 @@ pub async fn doc(flags: Flags, doc_flags: DocFlags) -> Result<(), AnyError> {
DocSourceFileFlag::Builtin => { DocSourceFileFlag::Builtin => {
generate_doc_nodes_for_builtin_types( generate_doc_nodes_for_builtin_types(
doc_flags.clone(), doc_flags.clone(),
cli_options,
&capturing_parser, &capturing_parser,
&analyzer, &analyzer,
) )
@ -156,7 +152,6 @@ pub async fn doc(flags: Flags, doc_flags: DocFlags) -> Result<(), AnyError> {
let deno_ns = if doc_flags.source_files != DocSourceFileFlag::Builtin { let deno_ns = if doc_flags.source_files != DocSourceFileFlag::Builtin {
let deno_ns = generate_doc_nodes_for_builtin_types( let deno_ns = generate_doc_nodes_for_builtin_types(
doc_flags.clone(), doc_flags.clone(),
cli_options,
&capturing_parser, &capturing_parser,
&analyzer, &analyzer,
) )

View file

@ -78,14 +78,14 @@ pub static COMPILER_SNAPSHOT: Lazy<Box<[u8]>> = Lazy::new(
}, },
); );
pub fn get_types_declaration_file_text(unstable: bool) -> String { pub fn get_types_declaration_file_text() -> String {
let mut assets = get_asset_texts_from_new_runtime() let mut assets = get_asset_texts_from_new_runtime()
.unwrap() .unwrap()
.into_iter() .into_iter()
.map(|a| (a.specifier, a.text)) .map(|a| (a.specifier, a.text))
.collect::<HashMap<_, _>>(); .collect::<HashMap<_, _>>();
let mut lib_names = vec![ let lib_names = vec![
"deno.ns", "deno.ns",
"deno.console", "deno.console",
"deno.url", "deno.url",
@ -100,12 +100,9 @@ pub fn get_types_declaration_file_text(unstable: bool) -> String {
"deno.shared_globals", "deno.shared_globals",
"deno.cache", "deno.cache",
"deno.window", "deno.window",
"deno.unstable",
]; ];
if unstable {
lib_names.push("deno.unstable");
}
lib_names lib_names
.into_iter() .into_iter()
.map(|name| { .map(|name| {