From 3bd8baa3b6b3e9199a587e17125de034c0b6f219 Mon Sep 17 00:00:00 2001 From: Eric Lau Date: Mon, 9 Sep 2024 16:23:31 -0400 Subject: [PATCH] Separate conditions --- packages/core/src/utils/make-namespaced.ts | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/packages/core/src/utils/make-namespaced.ts b/packages/core/src/utils/make-namespaced.ts index b67f97933..ef4193fd9 100644 --- a/packages/core/src/utils/make-namespaced.ts +++ b/packages/core/src/utils/make-namespaced.ts @@ -172,7 +172,7 @@ export function makeNamespacedInput(input: SolcInput, output: SolcOutput, solcVe function tryRemoveNonStructNatSpec(origContent: string, solcVersion: string | undefined): string { const natSpecRemovals: Modification[] = []; - if (solcVersion !== undefined && slangSupportsPlatformAndVersion(solcVersion)) { + if (solcVersion !== undefined && tryRequire('@nomicfoundation/slang') && slangSupportsVersion(solcVersion)) { /* eslint-disable @typescript-eslint/no-var-requires */ const { Language } = require('@nomicfoundation/slang/language'); const { NonterminalKind, TerminalKind } = require('@nomicfoundation/slang/kinds'); @@ -217,19 +217,12 @@ function tryRequire(id: string) { return false; } -/** - * Whether Slang is supported for the current platform and the given compiler version. - */ -function slangSupportsPlatformAndVersion(solcVersion: string): boolean { - if (tryRequire('@nomicfoundation/slang')) { - /* eslint-disable @typescript-eslint/no-var-requires */ - const { Language } = require('@nomicfoundation/slang/language'); - /* eslint-enable @typescript-eslint/no-var-requires */ +function slangSupportsVersion(solcVersion: string): boolean { + /* eslint-disable @typescript-eslint/no-var-requires */ + const { Language } = require('@nomicfoundation/slang/language'); + /* eslint-enable @typescript-eslint/no-var-requires */ - return Language.supportedVersions().includes(solcVersion); - } else { - return false; - } + return Language.supportedVersions().includes(solcVersion); } interface Modification {