debugContentProvider.ts 3.0 KB
Newer Older
1 2 3 4 5 6
/*---------------------------------------------------------------------------------------------
 *  Copyright (c) Microsoft Corporation. All rights reserved.
 *  Licensed under the MIT License. See License.txt in the project root for license information.
 *--------------------------------------------------------------------------------------------*/

import uri from 'vs/base/common/uri';
7
import { localize } from 'vs/nls';
8
import { TPromise } from 'vs/base/common/winjs.base';
I
isidor 已提交
9
import { guessMimeTypes, MIME_TEXT } from 'vs/base/common/mime';
10 11 12
import { IModel } from 'vs/editor/common/editorCommon';
import { IModelService } from 'vs/editor/common/services/modelService';
import { IModeService } from 'vs/editor/common/services/modeService';
13
import { ITextModelService, ITextModelContentProvider } from 'vs/editor/common/services/resolverService';
14
import { IWorkbenchContribution } from 'vs/workbench/common/contributions';
15
import { DEBUG_SCHEME, IDebugService, IProcess } from 'vs/workbench/parts/debug/common/debug';
16 17 18 19

export class DebugContentProvider implements IWorkbenchContribution, ITextModelContentProvider {

	constructor(
20
		@ITextModelService textModelResolverService: ITextModelService,
21 22 23 24
		@IDebugService private debugService: IDebugService,
		@IModelService private modelService: IModelService,
		@IModeService private modeService: IModeService
	) {
25
		textModelResolverService.registerTextModelContentProvider(DEBUG_SCHEME, this);
26 27 28 29 30 31 32
	}

	public getId(): string {
		return 'debug.contentprovider';
	}

	public provideTextContent(resource: uri): TPromise<IModel> {
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49

		let process: IProcess;
		if (resource.query) {
			const keyvalues = resource.query.split('&');
			for (let keyvalue of keyvalues) {
				const pair = keyvalue.split('=');
				if (pair.length === 2 && pair[0] === 'session') {
					process = this.debugService.findProcessByUUID(decodeURIComponent(pair[1]));
					break;
				}
			}
		}

		if (!process) {
			// fallback: use focussed process
			process = this.debugService.getViewModel().focusedProcess;
		}
50

51
		if (!process) {
52
			return TPromise.wrapError<IModel>(new Error(localize('unable', "Unable to resolve the resource without a debug session")));
53
		}
54
		const source = process.sources.get(resource.toString());
R
Rob Lourens 已提交
55 56 57
		let rawSource: DebugProtocol.Source;
		if (source) {
			rawSource = source.raw;
R
Rob Lourens 已提交
58
		} else {
R
Rob Lourens 已提交
59
			// Remove debug: scheme
60
			rawSource = { path: resource.with({ scheme: '', query: '' }).toString(true) };
R
Rob Lourens 已提交
61
		}
62

63
		return process.session.source({ sourceReference: source ? source.reference : undefined, source: rawSource }).then(response => {
64 65
			const mime = response.body.mimeType || guessMimeTypes(resource.toString())[0];
			const modePromise = this.modeService.getOrCreateMode(mime);
66
			const model = this.modelService.createModel(response.body.content, modePromise, resource);
67

68
			return model;
I
isidor 已提交
69
		}, (err: DebugProtocol.ErrorResponse) => {
70
			this.debugService.sourceIsNotAvailable(resource);
I
isidor 已提交
71 72 73 74
			const modePromise = this.modeService.getOrCreateMode(MIME_TEXT);
			const model = this.modelService.createModel(err.message, modePromise, resource);

			return model;
75 76 77
		});
	}
}