Skip to content

Commit

Permalink
Revert "Remove old API in favor of this"
Browse files Browse the repository at this point in the history
This reverts commit 9543501.
  • Loading branch information
Kartik Raj committed May 11, 2022
1 parent 9543501 commit 5bbea78
Show file tree
Hide file tree
Showing 6 changed files with 23 additions and 13 deletions.
5 changes: 3 additions & 2 deletions src/client/interpreter/contracts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { CodeLensProvider, ConfigurationTarget, Disposable, Event, TextDocument,
import { FileChangeType } from '../common/platform/fileSystemWatcher';
import { Resource } from '../common/types';
import { PythonEnvSource } from '../pythonEnvironments/base/info';
import { ProgressNotificationEvent, PythonLocatorQuery } from '../pythonEnvironments/base/locator';
import { PythonLocatorQuery } from '../pythonEnvironments/base/locator';
import { CondaEnvironmentInfo } from '../pythonEnvironments/common/environmentManagers/conda';
import { EnvironmentType, PythonEnvironment } from '../pythonEnvironments/info';

Expand All @@ -16,7 +16,7 @@ export type PythonEnvironmentsChangedEvent = {

export const IComponentAdapter = Symbol('IComponentAdapter');
export interface IComponentAdapter {
readonly onProgress: Event<ProgressNotificationEvent>;
readonly onRefreshStart: Event<void>;
triggerRefresh(query?: PythonLocatorQuery & { clearCache?: boolean }, trigger?: 'auto' | 'ui'): Promise<void>;
readonly refreshPromise: Promise<void> | undefined;
readonly onChanged: Event<PythonEnvironmentsChangedEvent>;
Expand Down Expand Up @@ -63,6 +63,7 @@ export interface ICondaService {

export const IInterpreterService = Symbol('IInterpreterService');
export interface IInterpreterService {
readonly onRefreshStart: Event<void>;
triggerRefresh(query?: PythonLocatorQuery & { clearCache?: boolean }, trigger?: 'auto' | 'ui'): Promise<void>;
readonly refreshPromise: Promise<void> | undefined;
readonly onDidChangeInterpreters: Event<PythonEnvironmentsChangedEvent>;
Expand Down
13 changes: 5 additions & 8 deletions src/client/interpreter/display/progressDisplay.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import { IDisposableRegistry } from '../../common/types';
import { createDeferred, Deferred } from '../../common/utils/async';
import { Interpreters } from '../../common/utils/localize';
import { traceDecoratorVerbose } from '../../logging';
import { ProgressReportStage } from '../../pythonEnvironments/base/locator';
import { IComponentAdapter } from '../contracts';

// The parts of IComponentAdapter used here.
Expand All @@ -31,13 +30,11 @@ export class InterpreterLocatorProgressStatubarHandler implements IExtensionSing
) {}

public async activate(): Promise<void> {
this.pyenvs.onProgress(
(event) => {
if (event.stage === ProgressReportStage.discoveryStarted) {
this.showProgress();
if (this.pyenvs.refreshPromise) {
this.pyenvs.refreshPromise.then(() => this.hideProgress());
}
this.pyenvs.onRefreshStart(
() => {
this.showProgress();
if (this.pyenvs.refreshPromise) {
this.pyenvs.refreshPromise.then(() => this.hideProgress());
}
},
this,
Expand Down
4 changes: 4 additions & 0 deletions src/client/interpreter/interpreterService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ export class InterpreterService implements Disposable, IInterpreterService {
return this.pyenvs.hasInterpreters(filter);
}

public get onRefreshStart(): Event<void> {
return this.pyenvs.onRefreshStart;
}

public triggerRefresh(
query?: PythonLocatorQuery & { clearCache?: boolean },
trigger?: 'auto' | 'ui',
Expand Down
4 changes: 4 additions & 0 deletions src/client/pythonEnvironments/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,10 @@ class PythonEnvironments implements IDiscoveryAPI {
return this.locator.onProgress;
}

public get onRefreshStart() {
return this.locator.onRefreshStart;
}

public get refreshPromise() {
return this.locator.refreshPromise;
}
Expand Down
6 changes: 5 additions & 1 deletion src/client/pythonEnvironments/base/locator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -188,9 +188,13 @@ export interface IResolvingLocator<I = PythonEnvInfo> extends IResolver, ILocato

export interface IDiscoveryAPI {
/**
* Fires with details of the current discovery progress, i.e when it starts, finishes or any other relevant stage.
* Fires when the known list of environments starts refreshing, i.e when discovery starts or restarts.
*/
readonly onProgress: Event<ProgressNotificationEvent>;
/**
* Fires when the known list of environments starts refreshing, i.e when discovery starts or restarts.
*/
readonly onRefreshStart: Event<void>;
/**
* Fires with details if the known list changes.
*/
Expand Down
4 changes: 2 additions & 2 deletions src/client/pythonEnvironments/legacyIOC.ts
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,8 @@ class ComponentAdapter implements IComponentAdapter {
return this.api.refreshPromise;
}

public get onProgress() {
return this.api.onProgress;
public get onRefreshStart(): vscode.Event<void> {
return this.api.onRefreshStart;
}

public get onChanged() {
Expand Down

0 comments on commit 5bbea78

Please sign in to comment.