From 3c5f46f8753f5657fb2a61f4d9217825ba7fccc3 Mon Sep 17 00:00:00 2001 From: Don Jayamanne Date: Mon, 24 Jun 2024 16:34:58 +1000 Subject: [PATCH] Revert changes introduced for Native Locator (#23663) --- .../base/info/environmentInfoService.ts | 43 ------------------- .../base/locators/composite/envsResolver.ts | 2 +- 2 files changed, 1 insertion(+), 44 deletions(-) diff --git a/src/client/pythonEnvironments/base/info/environmentInfoService.ts b/src/client/pythonEnvironments/base/info/environmentInfoService.ts index 4c437431823a..38fcc7bb29be 100644 --- a/src/client/pythonEnvironments/base/info/environmentInfoService.ts +++ b/src/client/pythonEnvironments/base/info/environmentInfoService.ts @@ -30,19 +30,6 @@ export interface IEnvironmentInfoService { env: PythonEnvInfo, priority?: EnvironmentInfoServiceQueuePriority, ): Promise; - /** - * Get the mandatory interpreter information for the given environment. - * E.g. executable path, version and sysPrefix are considered mandatory. - * However if we only have part of the version, thats still sufficient. - * If the fully resolved and acurate information for all parts of the env is required, then - * used `getEnvironmentInfo`. - * @param env The environment to get the interpreter information for. - * @param priority The priority of the request. - */ - getMandatoryEnvironmentInfo( - env: PythonEnvInfo, - priority?: EnvironmentInfoServiceQueuePriority, - ): Promise; /** * Reset any stored interpreter information for the given environment. * @param searchLocation Search location of the environment. @@ -137,36 +124,6 @@ class EnvironmentInfoService implements IEnvironmentInfoService { return deferred.promise; } - public async getMandatoryEnvironmentInfo( - env: PythonEnvInfo, - priority?: EnvironmentInfoServiceQueuePriority, - ): Promise { - const interpreterPath = env.executable.filename; - const result = this.cache.get(normCasePath(interpreterPath)); - if (result !== undefined) { - // Another call for this environment has already been made, return its result. - return result.promise; - } - - const deferred = createDeferred(); - const info = EnvironmentInfoService.getInterpreterInfo(env, true); - if (info !== undefined) { - this.cache.set(normCasePath(interpreterPath), deferred); - deferred.resolve(info); - return info; - } - - this.cache.set(normCasePath(interpreterPath), deferred); - this._getEnvironmentInfo(env, priority) - .then((r) => { - deferred.resolve(r); - }) - .catch((ex) => { - deferred.reject(ex); - }); - return deferred.promise; - } - public async _getEnvironmentInfo( env: PythonEnvInfo, priority?: EnvironmentInfoServiceQueuePriority, diff --git a/src/client/pythonEnvironments/base/locators/composite/envsResolver.ts b/src/client/pythonEnvironments/base/locators/composite/envsResolver.ts index a823e6f77ec5..6bd342d14d9c 100644 --- a/src/client/pythonEnvironments/base/locators/composite/envsResolver.ts +++ b/src/client/pythonEnvironments/base/locators/composite/envsResolver.ts @@ -137,7 +137,7 @@ export class PythonEnvsResolver implements IResolvingLocator { state.pending += 1; // It's essential we increment the pending call count before any asynchronus calls in this method. // We want this to be run even when `resolveInBackground` is called in background. - const info = await this.environmentInfoService.getMandatoryEnvironmentInfo(seen[envIndex]); + const info = await this.environmentInfoService.getEnvironmentInfo(seen[envIndex]); const old = seen[envIndex]; if (info) { const resolvedEnv = getResolvedEnv(info, seen[envIndex], old.identifiedUsingNativeLocator);