From 955c9718566f5e1eadb96a27419cb5aba90da460 Mon Sep 17 00:00:00 2001 From: Rajko Winkler Date: Mon, 4 Jan 2016 17:07:36 +0100 Subject: [PATCH] Clean up for feature #6 --- package.json | 11 +++++++++++ src/features/xmlXPathEngine.ts | 28 ++++++---------------------- 2 files changed, 17 insertions(+), 22 deletions(-) diff --git a/package.json b/package.json index 2363664..100a3c0 100644 --- a/package.json +++ b/package.json @@ -44,6 +44,17 @@ "title": "XML Tools: Evaluate XPath" } ], + "configuration": { + "title": "XML Tools Configuration", + "type": "object", + "properties": { + "xmlTools.persistXPathQuery": { + "type": "boolean", + "default": true, + "description": "Remember the last XPath query used." + } + } + }, "keybindings": [ { "key": "ctrl+shift+alt+b", diff --git a/src/features/xmlXPathEngine.ts b/src/features/xmlXPathEngine.ts index 16282e9..a5acdd9 100644 --- a/src/features/xmlXPathEngine.ts +++ b/src/features/xmlXPathEngine.ts @@ -6,13 +6,15 @@ let xpath = require('xpath'); let dom = require('xmldom').DOMParser; let resultChannel: OutputChannel = null; +export var lastXPath: string; + export function evaluateXPath(editor: TextEditor, edit: TextEditorEdit): void { - let isPersistant = workspace.getConfiguration().has('xmlTools.PersistXPathQuery') && workspace.getConfiguration('xmlTools').get('PersistXPathQuery') === true + let isPersistant = workspace.getConfiguration().has('xmlTools.persistXPathQuery') && workspace.getConfiguration('xmlTools').get('persistXPathQuery') === true window.showInputBox({ placeHolder: 'XPath Query', prompt: 'Please enter an XPath query to evaluate.', - value: isPersistant ? Singleton.getXPathValue() : '' + value: isPersistant ? lastXPath : '' }).then((query) => { if (query === undefined) return; @@ -20,8 +22,6 @@ export function evaluateXPath(editor: TextEditor, edit: TextEditorEdit): void { let xml = editor.document.getText(); let doc = new dom().parseFromString(xml); - Singleton.setXPathValue(query); - try { var nodes = xpath.select(query, doc); } @@ -31,6 +31,8 @@ export function evaluateXPath(editor: TextEditor, edit: TextEditorEdit): void { return; } + lastXPath = query; + if (nodes === null || nodes === undefined || nodes.length == 0) { window.showInformationMessage('Your XPath query returned no results.'); return; @@ -45,22 +47,4 @@ export function evaluateXPath(editor: TextEditor, edit: TextEditorEdit): void { resultChannel.show(ViewColumn.Three); }); -} - -namespace Singleton { - - class XPathContext - { - static _lastXPathValue:string = ''; - } - - export function getXPathValue():string - { - return XPathContext._lastXPathValue; - } - - export function setXPathValue(val:string):void - { - XPathContext._lastXPathValue = val; - } } \ No newline at end of file