diff --git a/CHANGELOG.md b/CHANGELOG.md index 3b9f1b52..397e4342 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,17 @@ +## [1.9.4](https://github.com/lgeiger/ide-python/compare/v1.9.3...v1.9.4) (2021-07-17) + + +### Bug Fixes + +* add eslint ([c26448e](https://github.com/lgeiger/ide-python/commit/c26448e85bd7874d74e04af7692b776c3f403481)) +* default to python3 and fallback to python ([2850374](https://github.com/lgeiger/ide-python/commit/2850374140890fff815512bf83ecf4b4c7a97a5d)) +* lazy-load log4js ([6e11dde](https://github.com/lgeiger/ide-python/commit/6e11dde88cad24aab526fb3644e4a1fb3c6186b2)) +* lazy-load RemoteDebuggerCommandService ([c7fff17](https://github.com/lgeiger/ide-python/commit/c7fff17e002225371cbf036b8614daac0c7e62ac)) +* merge activate methods ([e15d390](https://github.com/lgeiger/ide-python/commit/e15d390b937692dd31dd3eda68805b5ff78fdc08)) +* remove excess async ([e52839f](https://github.com/lgeiger/ide-python/commit/e52839f4b1c42e577958baa4876ebb595d90bb25)) +* update atom-languageclient ([cf16a1e](https://github.com/lgeiger/ide-python/commit/cf16a1ebdb953c6efd3af8c38bf51e90fac52a75)) +* use accurate type comparisons and remove unused reject parameters ([dfe5b0d](https://github.com/lgeiger/ide-python/commit/dfe5b0dcc0caf9b4d315c22563ead00a1911d157)) + ## [1.9.3](https://github.com/lgeiger/ide-python/compare/v1.9.2...v1.9.3) (2021-06-13) diff --git a/dist/debugger/RemoteDebuggerCommandService.js b/dist/debugger/RemoteDebuggerCommandService.js index f552f92a..ad9398d0 100644 --- a/dist/debugger/RemoteDebuggerCommandService.js +++ b/dist/debugger/RemoteDebuggerCommandService.js @@ -47,7 +47,7 @@ function observeAttachDebugTargets() { } function isPortUsed(port) { - const tryConnectPromise = new Promise((resolve, reject) => { + const tryConnectPromise = new Promise(resolve => { const client = new _net.default.Socket(); client.once("connect", () => { cleanUp(); @@ -138,7 +138,7 @@ function handleJsonRequest(body, res) { (0, _log4js.getLogger)().info("Remote debug target attach request", body); const target = attachReady.get(port); - if (target != null) { + if (target !== undefined) { debugRequests.next({ type, command, @@ -152,4 +152,4 @@ function handleJsonRequest(body, res) { success })); } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["RemoteDebuggerCommandService.js"],"names":["isServerSetup","debugRequests","Subject","attachReady","Map","DEBUGGER_REGISTRY_PORT","observeRemoteDebugCommands","setupStep","Observable","fromPromise","setupServer","ignoreElements","empty","concat","publish","observeAttachDebugTargets","interval","startWith","switchMap","Promise","all","Array","from","values","map","target","isPortUsed","port","delete","tryConnectPromise","resolve","reject","client","net","Socket","once","cleanUp","err","code","removeAllListeners","end","destroy","unref","connect","host","connectTimeoutPromise","then","race","http","createServer","req","res","method","writeHead","body","on","data","handleJsonRequest","JSON","parse","listen","domain","command","type","success","stringify","Number","options","id","localRoot","remoteRoot","debugOptions","set","info","get","next"],"mappings":"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","sourcesContent":["import type { ConnectableObservable } from \"rxjs-compat/bundles/rxjs-compat.umd.min.js\"\n\nimport http from \"http\"\nimport net from \"net\"\nimport { Observable, Subject } from \"rxjs-compat/bundles/rxjs-compat.umd.min.js\"\nimport { getLogger } from \"log4js\"\nimport { sleep } from \"@atom-ide-community/nuclide-commons/promise\"\n\nlet isServerSetup = false\n\nexport type RemoteDebugCommandRequest = {\n  type: \"python\",\n  command: \"attach\",\n  target: PythonDebuggerAttachTarget,\n}\n\nexport type PythonDebuggerAttachTarget = {\n  port: number,\n  localRoot: ?string,\n  remoteRoot: ?string,\n  debugOptions: ?Array<string>,\n  id: ?string,\n}\n\nconst debugRequests: Subject<RemoteDebugCommandRequest> = new Subject()\nconst attachReady: Map<number, PythonDebuggerAttachTarget> = new Map()\nconst DEBUGGER_REGISTRY_PORT = 9615\n\nexport function observeRemoteDebugCommands(): ConnectableObservable<RemoteDebugCommandRequest> {\n  let setupStep\n  if (!isServerSetup) {\n    setupStep = Observable.fromPromise(setupServer()).ignoreElements()\n  } else {\n    setupStep = Observable.empty()\n  }\n  return setupStep.concat(debugRequests).publish()\n}\n\nexport function observeAttachDebugTargets(): ConnectableObservable<Array<PythonDebuggerAttachTarget>> {\n  // Validate attach-ready values with the processes with used ports (ready to attach).\n  // Note: we can't use process ids because we could be debugging processes inside containers\n  // where the process ids don't map to the host running this code.\n  return Observable.interval(3000)\n    .startWith(0)\n    .switchMap(() =>\n      Promise.all(\n        Array.from(attachReady.values()).map(async (target) => {\n          if (!(await isPortUsed(target.port))) {\n            attachReady.delete(target.port)\n          }\n        })\n      )\n    )\n    .map(() => Array.from(attachReady.values()))\n    .publish()\n}\n\nfunction isPortUsed(port: number): Promise<boolean> {\n  const tryConnectPromise = new Promise((resolve, reject) => {\n    const client = new net.Socket()\n    client\n      .once(\"connect\", () => {\n        cleanUp()\n        resolve(true)\n      })\n      .once(\"error\", (err) => {\n        cleanUp()\n        resolve(err.code !== \"ECONNREFUSED\")\n      })\n\n    function cleanUp() {\n      client.removeAllListeners(\"connect\")\n      client.removeAllListeners(\"error\")\n      client.end()\n      client.destroy()\n      client.unref()\n    }\n\n    client.connect({ port, host: \"127.0.0.1\" })\n  })\n  // Trying to connect can take multiple seconds, then times out (if the server is busy).\n  // Hence, we need to fallback to `true`.\n  const connectTimeoutPromise = sleep(1000).then(() => true)\n  return Promise.race([tryConnectPromise, connectTimeoutPromise])\n}\n\nfunction setupServer(): Promise<void> {\n  return new Promise((resolve, reject) => {\n    http\n      .createServer((req, res) => {\n        if (req.method !== \"POST\") {\n          res.writeHead(500, { \"Content-Type\": \"text/html\" })\n          res.end(\"Invalid request\")\n        } else {\n          let body = \"\"\n          req.on(\"data\", (data) => {\n            body += data\n          })\n          req.on(\"end\", () => {\n            handleJsonRequest(JSON.parse(body), res)\n          })\n        }\n      })\n      .on(\"error\", reject)\n      .listen((DEBUGGER_REGISTRY_PORT: any), () => {\n        isServerSetup = true\n        resolve()\n      })\n  })\n}\n\nfunction handleJsonRequest(body, res) {\n  res.writeHead(200, { \"Content-Type\": \"application/json\" })\n  const { domain, command, type } = body\n  let success = false\n  if (domain !== \"debug\" || type !== \"python\") {\n    res.end(JSON.stringify({ success }))\n    return\n  }\n  if (command === \"enable-attach\") {\n    const port = Number(body.port)\n    const { options } = body\n    const target = {\n      port,\n      id: options.id,\n      localRoot: options.localRoot,\n      remoteRoot: options.remoteRoot,\n      debugOptions: options.debugOptions,\n    }\n    attachReady.set(port, target)\n    getLogger().info(\"Remote debug target is ready to attach\", target)\n    success = true\n  } else if (command === \"attach\") {\n    const port = Number(body.port)\n    getLogger().info(\"Remote debug target attach request\", body)\n    const target = attachReady.get(port)\n    if (target != null) {\n      debugRequests.next({\n        type,\n        command,\n        target,\n      })\n      success = true\n    }\n  }\n  res.end(JSON.stringify({ success }))\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["RemoteDebuggerCommandService.js"],"names":["isServerSetup","debugRequests","Subject","attachReady","Map","DEBUGGER_REGISTRY_PORT","observeRemoteDebugCommands","setupStep","Observable","fromPromise","setupServer","ignoreElements","empty","concat","publish","observeAttachDebugTargets","interval","startWith","switchMap","Promise","all","Array","from","values","map","target","isPortUsed","port","delete","tryConnectPromise","resolve","client","net","Socket","once","cleanUp","err","code","removeAllListeners","end","destroy","unref","connect","host","connectTimeoutPromise","then","race","reject","http","createServer","req","res","method","writeHead","body","on","data","handleJsonRequest","JSON","parse","listen","domain","command","type","success","stringify","Number","options","id","localRoot","remoteRoot","debugOptions","set","info","get","undefined","next"],"mappings":"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","sourcesContent":["import type { ConnectableObservable } from \"rxjs-compat/bundles/rxjs-compat.umd.min.js\"\n\nimport http from \"http\"\nimport net from \"net\"\nimport { Observable, Subject } from \"rxjs-compat/bundles/rxjs-compat.umd.min.js\"\nimport { getLogger } from \"log4js\"\nimport { sleep } from \"@atom-ide-community/nuclide-commons/promise\"\n\nlet isServerSetup = false\n\nexport type RemoteDebugCommandRequest = {\n  type: \"python\",\n  command: \"attach\",\n  target: PythonDebuggerAttachTarget,\n}\n\nexport type PythonDebuggerAttachTarget = {\n  port: number,\n  localRoot: ?string,\n  remoteRoot: ?string,\n  debugOptions: ?Array<string>,\n  id: ?string,\n}\n\nconst debugRequests: Subject<RemoteDebugCommandRequest> = new Subject()\nconst attachReady: Map<number, PythonDebuggerAttachTarget> = new Map()\nconst DEBUGGER_REGISTRY_PORT = 9615\n\nexport function observeRemoteDebugCommands(): ConnectableObservable<RemoteDebugCommandRequest> {\n  let setupStep\n  if (!isServerSetup) {\n    setupStep = Observable.fromPromise(setupServer()).ignoreElements()\n  } else {\n    setupStep = Observable.empty()\n  }\n  return setupStep.concat(debugRequests).publish()\n}\n\nexport function observeAttachDebugTargets(): ConnectableObservable<Array<PythonDebuggerAttachTarget>> {\n  // Validate attach-ready values with the processes with used ports (ready to attach).\n  // Note: we can't use process ids because we could be debugging processes inside containers\n  // where the process ids don't map to the host running this code.\n  return Observable.interval(3000)\n    .startWith(0)\n    .switchMap(() =>\n      Promise.all(\n        Array.from(attachReady.values()).map(async (target) => {\n          if (!(await isPortUsed(target.port))) {\n            attachReady.delete(target.port)\n          }\n        })\n      )\n    )\n    .map(() => Array.from(attachReady.values()))\n    .publish()\n}\n\nfunction isPortUsed(port: number): Promise<boolean> {\n  const tryConnectPromise = new Promise((resolve) => {\n    const client = new net.Socket()\n    client\n      .once(\"connect\", () => {\n        cleanUp()\n        resolve(true)\n      })\n      .once(\"error\", (err) => {\n        cleanUp()\n        resolve(err.code !== \"ECONNREFUSED\")\n      })\n\n    function cleanUp() {\n      client.removeAllListeners(\"connect\")\n      client.removeAllListeners(\"error\")\n      client.end()\n      client.destroy()\n      client.unref()\n    }\n\n    client.connect({ port, host: \"127.0.0.1\" })\n  })\n  // Trying to connect can take multiple seconds, then times out (if the server is busy).\n  // Hence, we need to fallback to `true`.\n  const connectTimeoutPromise = sleep(1000).then(() => true)\n  return Promise.race([tryConnectPromise, connectTimeoutPromise])\n}\n\nfunction setupServer(): Promise<void> {\n  return new Promise((resolve, reject) => {\n    http\n      .createServer((req, res) => {\n        if (req.method !== \"POST\") {\n          res.writeHead(500, { \"Content-Type\": \"text/html\" })\n          res.end(\"Invalid request\")\n        } else {\n          let body = \"\"\n          req.on(\"data\", (data) => {\n            body += data\n          })\n          req.on(\"end\", () => {\n            handleJsonRequest(JSON.parse(body), res)\n          })\n        }\n      })\n      .on(\"error\", reject)\n      .listen((DEBUGGER_REGISTRY_PORT: any), () => {\n        isServerSetup = true\n        resolve()\n      })\n  })\n}\n\nfunction handleJsonRequest(body, res) {\n  res.writeHead(200, { \"Content-Type\": \"application/json\" })\n  const { domain, command, type } = body\n  let success = false\n  if (domain !== \"debug\" || type !== \"python\") {\n    res.end(JSON.stringify({ success }))\n    return\n  }\n  if (command === \"enable-attach\") {\n    const port = Number(body.port)\n    const { options } = body\n    const target = {\n      port,\n      id: options.id,\n      localRoot: options.localRoot,\n      remoteRoot: options.remoteRoot,\n      debugOptions: options.debugOptions,\n    }\n    attachReady.set(port, target)\n    getLogger().info(\"Remote debug target is ready to attach\", target)\n    success = true\n  } else if (command === \"attach\") {\n    const port = Number(body.port)\n    getLogger().info(\"Remote debug target attach request\", body)\n    const target = attachReady.get(port)\n    if (target !== undefined) {\n      debugRequests.next({\n        type,\n        command,\n        target,\n      })\n      success = true\n    }\n  }\n  res.end(JSON.stringify({ success }))\n}\n"]} \ No newline at end of file diff --git a/dist/debugger/utils.js b/dist/debugger/utils.js index c566e428..bce88e1a 100644 --- a/dist/debugger/utils.js +++ b/dist/debugger/utils.js @@ -21,16 +21,8 @@ var _rxjsCompatUmdMin = require("rxjs-compat/bundles/rxjs-compat.umd.min.js"); var _analytics = require("@atom-ide-community/nuclide-commons/analytics"); -var RemoteDebuggerCommandServiceLocal = _interopRequireWildcard(require("./RemoteDebuggerCommandService")); - var _nullthrows = _interopRequireDefault(require("nullthrows")); -var _log4js = require("log4js"); - -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } - -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } let _rpcService = null; @@ -68,7 +60,11 @@ function listenToRemoteDebugCommands() { const service = getRemoteDebuggerCommandServiceByNuclideUri(rootUri); if (service == null) { - (0, _log4js.getLogger)().error("null remote command service for uri:", rootUri); + const { + getLogger + } = require("log4js"); + + getLogger().error("null remote command service for uri:", rootUri); return _rxjsCompatUmdMin.Observable.empty(); } else { return _rxjsCompatUmdMin.Observable.of({ @@ -153,10 +149,12 @@ function findDuplicateAttachTargetIds(targets) { } function getRemoteDebuggerCommandServiceByNuclideUri(uri) { + const RemoteDebuggerCommandServiceLocal = require("./RemoteDebuggerCommandService"); + if (_rpcService == null && !_nuclideUri.default.isRemote(uri)) { return RemoteDebuggerCommandServiceLocal; } return (0, _nullthrows.default)(_rpcService).getServiceByNuclideUri("RemoteDebuggerCommandService", uri); } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["utils.js"],"names":["_rpcService","getPythonAttachTargetProcessConfig","targetRootUri","target","targetUri","debugMode","adapterType","config","getPythonAttachTargetConfig","servicedFileExtensions","localRoot","remoteRoot","port","host","setRpcService","rpcService","UniversalDisposable","listenToRemoteDebugCommands","addedHostnames","startWith","remoteDebuggerServices","flatMap","hostname","rootUri","nuclideUri","createRemoteUri","service","getRemoteDebuggerCommandServiceByNuclideUri","error","Observable","empty","of","observeAttachDebugTargets","refCount","map","targets","findDuplicateAttachTargetIds","subscribe","duplicateTargetIds","notifyDuplicateDebugTargets","observeRemoteDebugCommands","catch","console","warn","String","command","let","attachProcessConfig","debuggerService","startVspDebugging","shouldNotifyDuplicateTargets","duplicateTargetsNotification","size","formattedIds","Array","from","join","atom","notifications","addInfo","buttons","onDidClick","dismiss","text","description","dismissable","onDidDismiss","targetIds","Set","forEach","id","has","add","uri","isRemote","RemoteDebuggerCommandServiceLocal","getServiceByNuclideUri"],"mappings":"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","sourcesContent":["import type { NuclideUri } from \"@atom-ide-community/nuclide-commons/nuclideUri\"\nimport type { PythonDebuggerAttachTarget, RemoteDebugCommandRequest } from \"./RemoteDebuggerCommandService\"\nimport type { IProcessConfig } from \"@atom-ide-community/nuclide-debugger-common\"\nimport typeof * as RemoteDebuggerCommandService from \"./RemoteDebuggerCommandService\"\n\nimport { getDebuggerService } from \"@atom-ide-community/nuclide-commons-atom/debugger\"\nimport { observeAddedHostnames } from \"@atom-ide-community/nuclide-commons-atom/projects\"\nimport nuclideUri from \"@atom-ide-community/nuclide-commons/nuclideUri\"\nimport { fastDebounce } from \"@atom-ide-community/nuclide-commons/observable\"\nimport UniversalDisposable from \"@atom-ide-community/nuclide-commons/UniversalDisposable\"\nimport { Observable } from \"rxjs-compat/bundles/rxjs-compat.umd.min.js\"\nimport { track } from \"@atom-ide-community/nuclide-commons/analytics\"\nimport * as RemoteDebuggerCommandServiceLocal from \"./RemoteDebuggerCommandService\"\nimport nullthrows from \"nullthrows\"\nimport { getLogger } from \"log4js\"\n\nlet _rpcService: ?nuclide$RpcService = null\n\nfunction getPythonAttachTargetProcessConfig(\n  targetRootUri: NuclideUri,\n  target: PythonDebuggerAttachTarget\n): IProcessConfig {\n  return {\n    targetUri: targetRootUri,\n    debugMode: \"attach\",\n    adapterType: \"python\",\n    config: getPythonAttachTargetConfig(target),\n    servicedFileExtensions: [\"py\"],\n  }\n}\n\nfunction getPythonAttachTargetConfig(target: PythonDebuggerAttachTarget): Object {\n  return {\n    localRoot: target.localRoot,\n    remoteRoot: target.remoteRoot,\n    port: target.port,\n    host: \"127.0.0.1\",\n  }\n}\n\nexport function setRpcService(rpcService: nuclide$RpcService): IDisposable {\n  _rpcService = rpcService\n  return new UniversalDisposable(() => {\n    _rpcService = null\n  })\n}\n\nexport function listenToRemoteDebugCommands(): IDisposable {\n  const addedHostnames = observeAddedHostnames().startWith(\"local\")\n\n  const remoteDebuggerServices = addedHostnames.flatMap((hostname) => {\n    const rootUri = hostname === \"local\" ? \"\" : nuclideUri.createRemoteUri(hostname, \"/\")\n    const service = getRemoteDebuggerCommandServiceByNuclideUri(rootUri)\n    if (service == null) {\n      getLogger().error(\"null remote command service for uri:\", rootUri)\n      return Observable.empty()\n    } else {\n      return Observable.of({ service, rootUri })\n    }\n  })\n\n  return new UniversalDisposable(\n    remoteDebuggerServices\n      .flatMap(({ service, rootUri }) => {\n        return service\n          .observeAttachDebugTargets()\n          .refCount()\n          .map((targets) => findDuplicateAttachTargetIds(targets))\n      })\n\n      .subscribe((duplicateTargetIds) => notifyDuplicateDebugTargets(duplicateTargetIds)),\n    remoteDebuggerServices\n      .flatMap(({ service, rootUri }) => {\n        return service\n          .observeRemoteDebugCommands()\n          .refCount()\n          .catch((error) => {\n            // eslint-disable-next-line no-console\n            console.warn(\n              \"Failed to listen to remote debug commands - \" +\n                \"You could be running locally with two Atom windows. \" +\n                `IsLocal: ${String(rootUri === \"\")}`\n            )\n            return Observable.empty()\n          })\n          .map((command: RemoteDebugCommandRequest) => ({ rootUri, command }))\n      })\n      .let(fastDebounce(500))\n      .subscribe(async ({ rootUri, command }) => {\n        const attachProcessConfig = getPythonAttachTargetProcessConfig(rootUri, command.target)\n        const debuggerService = await getDebuggerService()\n        track(\"fb-python-debugger-auto-attach\")\n        debuggerService.startVspDebugging(attachProcessConfig)\n        // Otherwise, we're already debugging that target.\n      })\n  )\n}\n\nlet shouldNotifyDuplicateTargets = true\nlet duplicateTargetsNotification\n\nfunction notifyDuplicateDebugTargets(duplicateTargetIds: Set<string>): void {\n  if (duplicateTargetIds.size > 0 && shouldNotifyDuplicateTargets && duplicateTargetsNotification == null) {\n    const formattedIds = Array.from(duplicateTargetIds).join(\", \")\n    duplicateTargetsNotification = atom.notifications.addInfo(\n      `Debugger: duplicate attach targets: \\`${formattedIds}\\``,\n      {\n        buttons: [\n          {\n            onDidClick: () => {\n              shouldNotifyDuplicateTargets = false\n              if (duplicateTargetsNotification != null) {\n                duplicateTargetsNotification.dismiss()\n              }\n            },\n            text: \"Ignore\",\n          },\n        ],\n        description:\n          `Nuclide debugger detected duplicate attach targets with ids (${formattedIds}) ` +\n          \"That could be instagram running multiple processes - check out https://our.intern.facebook.com/intern/dex/instagram-server/debugging-with-nuclide/\",\n        dismissable: true,\n      }\n    )\n    duplicateTargetsNotification.onDidDismiss(() => {\n      duplicateTargetsNotification = null\n    })\n  }\n}\n\nfunction findDuplicateAttachTargetIds(targets: Array<PythonDebuggerAttachTarget>): Set<string> {\n  const targetIds = new Set()\n  const duplicateTargetIds = new Set()\n  targets.forEach((target) => {\n    const { id } = target\n    if (id == null) {\n      return\n    }\n    if (targetIds.has(id)) {\n      duplicateTargetIds.add(id)\n    } else {\n      targetIds.add(id)\n    }\n  })\n  return duplicateTargetIds\n}\n\nexport function getRemoteDebuggerCommandServiceByNuclideUri(uri: NuclideUri): RemoteDebuggerCommandService {\n  if (_rpcService == null && !nuclideUri.isRemote(uri)) {\n    return RemoteDebuggerCommandServiceLocal\n  }\n\n  return nullthrows(_rpcService).getServiceByNuclideUri(\"RemoteDebuggerCommandService\", uri)\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["utils.js"],"names":["_rpcService","getPythonAttachTargetProcessConfig","targetRootUri","target","targetUri","debugMode","adapterType","config","getPythonAttachTargetConfig","servicedFileExtensions","localRoot","remoteRoot","port","host","setRpcService","rpcService","UniversalDisposable","listenToRemoteDebugCommands","addedHostnames","startWith","remoteDebuggerServices","flatMap","hostname","rootUri","nuclideUri","createRemoteUri","service","getRemoteDebuggerCommandServiceByNuclideUri","getLogger","require","error","Observable","empty","of","observeAttachDebugTargets","refCount","map","targets","findDuplicateAttachTargetIds","subscribe","duplicateTargetIds","notifyDuplicateDebugTargets","observeRemoteDebugCommands","catch","console","warn","String","command","let","attachProcessConfig","debuggerService","startVspDebugging","shouldNotifyDuplicateTargets","duplicateTargetsNotification","size","formattedIds","Array","from","join","atom","notifications","addInfo","buttons","onDidClick","dismiss","text","description","dismissable","onDidDismiss","targetIds","Set","forEach","id","has","add","uri","RemoteDebuggerCommandServiceLocal","isRemote","getServiceByNuclideUri"],"mappings":"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","sourcesContent":["import type { NuclideUri } from \"@atom-ide-community/nuclide-commons/nuclideUri\"\nimport type { PythonDebuggerAttachTarget, RemoteDebugCommandRequest } from \"./RemoteDebuggerCommandService\"\nimport type { IProcessConfig } from \"@atom-ide-community/nuclide-debugger-common\"\nimport typeof * as RemoteDebuggerCommandService from \"./RemoteDebuggerCommandService\"\n\nimport { getDebuggerService } from \"@atom-ide-community/nuclide-commons-atom/debugger\"\nimport { observeAddedHostnames } from \"@atom-ide-community/nuclide-commons-atom/projects\"\nimport nuclideUri from \"@atom-ide-community/nuclide-commons/nuclideUri\"\nimport { fastDebounce } from \"@atom-ide-community/nuclide-commons/observable\"\nimport UniversalDisposable from \"@atom-ide-community/nuclide-commons/UniversalDisposable\"\nimport { Observable } from \"rxjs-compat/bundles/rxjs-compat.umd.min.js\"\nimport { track } from \"@atom-ide-community/nuclide-commons/analytics\"\nimport nullthrows from \"nullthrows\"\n\nlet _rpcService: ?nuclide$RpcService = null\n\nfunction getPythonAttachTargetProcessConfig(\n  targetRootUri: NuclideUri,\n  target: PythonDebuggerAttachTarget\n): IProcessConfig {\n  return {\n    targetUri: targetRootUri,\n    debugMode: \"attach\",\n    adapterType: \"python\",\n    config: getPythonAttachTargetConfig(target),\n    servicedFileExtensions: [\"py\"],\n  }\n}\n\nfunction getPythonAttachTargetConfig(target: PythonDebuggerAttachTarget): Object {\n  return {\n    localRoot: target.localRoot,\n    remoteRoot: target.remoteRoot,\n    port: target.port,\n    host: \"127.0.0.1\",\n  }\n}\n\nexport function setRpcService(rpcService: nuclide$RpcService): IDisposable {\n  _rpcService = rpcService\n  return new UniversalDisposable(() => {\n    _rpcService = null\n  })\n}\n\nexport function listenToRemoteDebugCommands(): IDisposable {\n  const addedHostnames = observeAddedHostnames().startWith(\"local\")\n\n  const remoteDebuggerServices = addedHostnames.flatMap((hostname) => {\n    const rootUri = hostname === \"local\" ? \"\" : nuclideUri.createRemoteUri(hostname, \"/\")\n    const service = getRemoteDebuggerCommandServiceByNuclideUri(rootUri)\n    if (service == null) {\n      const { getLogger } = require(\"log4js\")\n      getLogger().error(\"null remote command service for uri:\", rootUri)\n      return Observable.empty()\n    } else {\n      return Observable.of({ service, rootUri })\n    }\n  })\n\n  return new UniversalDisposable(\n    remoteDebuggerServices\n      .flatMap(({ service, rootUri }) => {\n        return service\n          .observeAttachDebugTargets()\n          .refCount()\n          .map((targets) => findDuplicateAttachTargetIds(targets))\n      })\n\n      .subscribe((duplicateTargetIds) => notifyDuplicateDebugTargets(duplicateTargetIds)),\n    remoteDebuggerServices\n      .flatMap(({ service, rootUri }) => {\n        return service\n          .observeRemoteDebugCommands()\n          .refCount()\n          .catch((error) => {\n            // eslint-disable-next-line no-console\n            console.warn(\n              \"Failed to listen to remote debug commands - \" +\n                \"You could be running locally with two Atom windows. \" +\n                `IsLocal: ${String(rootUri === \"\")}`\n            )\n            return Observable.empty()\n          })\n          .map((command: RemoteDebugCommandRequest) => ({ rootUri, command }))\n      })\n      .let(fastDebounce(500))\n      .subscribe(async ({ rootUri, command }) => {\n        const attachProcessConfig = getPythonAttachTargetProcessConfig(rootUri, command.target)\n        const debuggerService = await getDebuggerService()\n        track(\"fb-python-debugger-auto-attach\")\n        debuggerService.startVspDebugging(attachProcessConfig)\n        // Otherwise, we're already debugging that target.\n      })\n  )\n}\n\nlet shouldNotifyDuplicateTargets = true\nlet duplicateTargetsNotification\n\nfunction notifyDuplicateDebugTargets(duplicateTargetIds: Set<string>): void {\n  if (duplicateTargetIds.size > 0 && shouldNotifyDuplicateTargets && duplicateTargetsNotification == null) {\n    const formattedIds = Array.from(duplicateTargetIds).join(\", \")\n    duplicateTargetsNotification = atom.notifications.addInfo(\n      `Debugger: duplicate attach targets: \\`${formattedIds}\\``,\n      {\n        buttons: [\n          {\n            onDidClick: () => {\n              shouldNotifyDuplicateTargets = false\n              if (duplicateTargetsNotification != null) {\n                duplicateTargetsNotification.dismiss()\n              }\n            },\n            text: \"Ignore\",\n          },\n        ],\n        description:\n          `Nuclide debugger detected duplicate attach targets with ids (${formattedIds}) ` +\n          \"That could be instagram running multiple processes - check out https://our.intern.facebook.com/intern/dex/instagram-server/debugging-with-nuclide/\",\n        dismissable: true,\n      }\n    )\n    duplicateTargetsNotification.onDidDismiss(() => {\n      duplicateTargetsNotification = null\n    })\n  }\n}\n\nfunction findDuplicateAttachTargetIds(targets: Array<PythonDebuggerAttachTarget>): Set<string> {\n  const targetIds = new Set()\n  const duplicateTargetIds = new Set()\n  targets.forEach((target) => {\n    const { id } = target\n    if (id == null) {\n      return\n    }\n    if (targetIds.has(id)) {\n      duplicateTargetIds.add(id)\n    } else {\n      targetIds.add(id)\n    }\n  })\n  return duplicateTargetIds\n}\n\nexport function getRemoteDebuggerCommandServiceByNuclideUri(uri: NuclideUri): RemoteDebuggerCommandService {\n  const RemoteDebuggerCommandServiceLocal = require(\"./RemoteDebuggerCommandService\")\n  if (_rpcService == null && !nuclideUri.isRemote(uri)) {\n    return RemoteDebuggerCommandServiceLocal\n  }\n\n  return nullthrows(_rpcService).getServiceByNuclideUri(\"RemoteDebuggerCommandService\", uri)\n}\n"]} \ No newline at end of file diff --git a/dist/main.js b/dist/main.js index 1baad186..e570a607 100644 --- a/dist/main.js +++ b/dist/main.js @@ -21,7 +21,7 @@ const { // Ref: https://github.com/nteract/hydrogen/blob/master/lib/autocomplete-provider.js#L33 // adapted from http://stackoverflow.com/q/5474008 -const PYTHON_REGEX = /(([^\d\W]|[\u00A0-\uFFFF])[\w.\u00A0-\uFFFF]*)|\.$/; +const PYTHON_REGEX = /(([^\W\d]|[\u00A0-\uFFFF])[\w.\u00A0-\uFFFF]*)|\.$/; class PythonLanguageClient extends AutoLanguageClient { activate() { @@ -35,8 +35,14 @@ class PythonLanguageClient extends AutoLanguageClient { atom.packages.enablePackage("atom-ide-base"); atom.notifications.addSuccess("ide-pyhon: atom-ide-base was installed and enabled..."); }); - } + } // Remove deprecated option + + + atom.config.unset("ide-python.pylsPath"); + (0, _main.activate)(); } + /* eslint-disable class-methods-use-this */ + getGrammarScopes() { return ["source.python", "python"]; @@ -54,13 +60,6 @@ class PythonLanguageClient extends AutoLanguageClient { return "ide-python"; } - activate() { - // Remove deprecated option - atom.config.unset("ide-python.pylsPath"); - super.activate(); - (0, _main.activate)(); - } - mapConfigurationObject(configuration) { return { pyls: { @@ -70,16 +69,26 @@ class PythonLanguageClient extends AutoLanguageClient { } }; } + /* eslint-enable class-methods-use-this */ + async startServerProcess(projectPath) { const venvPath = (await detectPipEnv(projectPath)) || (await detectVirtualEnv(projectPath)); const pylsEnvironment = Object.assign({}, process.env); if (venvPath) { - pylsEnvironment["VIRTUAL_ENV"] = venvPath; + pylsEnvironment.VIRTUAL_ENV = venvPath; + } + + let pythonBin = atom.config.get("ide-python.python") || "python3"; + + if (whichSync(pythonBin, { + nothrow: true + }) === null) { + pythonBin = "python"; } - this.python = replacePipEnvPathVar(atom.config.get("ide-python.python"), venvPath); + this.python = replacePipEnvPathVar(pythonBin, venvPath); let pyls = atom.config.get("ide-python.pyls") || "pylsp"; // check if it exists if (whichSync(pyls, { @@ -96,7 +105,7 @@ class PythonLanguageClient extends AutoLanguageClient { } onSpawnError(err) { - const description = err.code == "ENOENT" ? `No Python interpreter found at \`${this.python}\`.` : `Could not spawn the Python interpreter \`${this.python}\`.`; + const description = err.code === "ENOENT" ? `No Python interpreter found at \`${this.python}\`.` : `Could not spawn the Python interpreter \`${this.python}\`.`; atom.notifications.addError("`ide-python` could not launch your Python runtime.", { dismissable: true, description: `${description}
If you have Python installed please set "Python Executable" setting correctly. If you do not please install Python.
` @@ -104,7 +113,7 @@ class PythonLanguageClient extends AutoLanguageClient { } onSpawnClose(code, signal) { - if (code !== 0 && signal == null) { + if (code !== 0 && signal === null) { atom.notifications.addError("Unable to start the Python language server.", { dismissable: true, buttons: [{ @@ -119,8 +128,11 @@ class PythonLanguageClient extends AutoLanguageClient { } } - async getSuggestions(request) { - if (!PYTHON_REGEX.test(request.prefix)) return null; + getSuggestions(request) { + if (!PYTHON_REGEX.test(request.prefix)) { + return null; + } + return super.getSuggestions(request); } @@ -130,8 +142,8 @@ class PythonLanguageClient extends AutoLanguageClient { } createTimeoutPromise(milliseconds) { - return new Promise((resolve, reject) => { - let timeout = setTimeout(() => { + return new Promise(resolve => { + const timeout = setTimeout(() => { clearTimeout(timeout); this.logger.error(`Server failed to shutdown in ${milliseconds}ms, forcing termination`); resolve(); @@ -145,4 +157,4 @@ const pythonClient = new PythonLanguageClient(); pythonClient.createDebuggerProvider = _main.createDebuggerProvider; // add the debugger module.exports = pythonClient; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["main.js"],"names":["shell","require","whichSync","sync","AutoLanguageClient","detectVirtualEnv","detectPipEnv","replacePipEnvPathVar","sanitizeConfig","PYTHON_REGEX","PythonLanguageClient","activate","atom","packages","isPackageLoaded","install","then","enablePackage","notifications","addSuccess","getGrammarScopes","getLanguageName","getServerName","getRootConfigurationKey","config","unset","mapConfigurationObject","configuration","pyls","configurationSources","pylsConfigurationSources","rope","plugins","pylsPlugins","startServerProcess","projectPath","venvPath","pylsEnvironment","Object","assign","process","env","python","get","nothrow","childProcess","spawn","cwd","onSpawnError","err","description","code","addError","dismissable","onSpawnClose","signal","buttons","text","onDidClick","workspace","open","openExternal","getSuggestions","request","test","prefix","deactivate","Promise","race","createTimeoutPromise","milliseconds","resolve","reject","timeout","setTimeout","clearTimeout","logger","error","pythonClient","createDebuggerProvider","module","exports"],"mappings":"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","sourcesContent":["const { shell } = require(\"electron\")\nconst whichSync = require(\"which\").sync\nconst { AutoLanguageClient } = require(\"atom-languageclient\")\nconst { detectVirtualEnv, detectPipEnv, replacePipEnvPathVar, sanitizeConfig } = require(\"./utils\")\n\nimport { createDebuggerProvider, activate as debuggerActivate, dispose as debuggerDispose } from \"./debugger/main\"\n\n// Ref: https://github.com/nteract/hydrogen/blob/master/lib/autocomplete-provider.js#L33\n// adapted from http://stackoverflow.com/q/5474008\nconst PYTHON_REGEX = /(([^\\d\\W]|[\\u00A0-\\uFFFF])[\\w.\\u00A0-\\uFFFF]*)|\\.$/\n\nclass PythonLanguageClient extends AutoLanguageClient {\n  activate() {\n    super.activate()\n    if (!atom.packages.isPackageLoaded(\"atom-ide-base\")) {\n      // install if not installed\n      // eslint-disable-next-line @typescript-eslint/no-var-requires\n      require(\"atom-package-deps\")\n        .install(\"ide-python\", true)\n        .then(() => {\n          // enable if disabled\n          atom.packages.enablePackage(\"atom-ide-base\")\n          atom.notifications.addSuccess(\"ide-pyhon: atom-ide-base was installed and enabled...\")\n        })\n    }\n  }\n\n  getGrammarScopes() {\n    return [\"source.python\", \"python\"]\n  }\n\n  getLanguageName() {\n    return \"Python\"\n  }\n\n  getServerName() {\n    return \"pyls\"\n  }\n\n  getRootConfigurationKey() {\n    return \"ide-python\"\n  }\n\n  activate() {\n    // Remove deprecated option\n    atom.config.unset(\"ide-python.pylsPath\")\n    super.activate()\n    debuggerActivate()\n  }\n\n  mapConfigurationObject(configuration) {\n    return {\n      pyls: {\n        configurationSources: configuration.pylsConfigurationSources,\n        rope: sanitizeConfig(configuration.rope),\n        plugins: configuration.pylsPlugins,\n      },\n    }\n  }\n\n  async startServerProcess(projectPath) {\n    const venvPath = (await detectPipEnv(projectPath)) || (await detectVirtualEnv(projectPath))\n    const pylsEnvironment = Object.assign({}, process.env)\n    if (venvPath) {\n      pylsEnvironment[\"VIRTUAL_ENV\"] = venvPath\n    }\n    this.python = replacePipEnvPathVar(atom.config.get(\"ide-python.python\"), venvPath)\n\n    let pyls = atom.config.get(\"ide-python.pyls\") || \"pylsp\"\n    // check if it exists\n    if (whichSync(pyls, { nothrow: true }) === null) {\n      pyls = \"pyls\"\n    }\n    const childProcess = super.spawn(this.python, [\"-m\", pyls], {\n      cwd: projectPath,\n      env: pylsEnvironment,\n    })\n    return childProcess\n  }\n\n  onSpawnError(err) {\n    const description =\n      err.code == \"ENOENT\"\n        ? `No Python interpreter found at \\`${this.python}\\`.`\n        : `Could not spawn the Python interpreter \\`${this.python}\\`.`\n    atom.notifications.addError(\"`ide-python` could not launch your Python runtime.\", {\n      dismissable: true,\n      description: `${description}<p>If you have Python installed please set \"Python Executable\" setting correctly. If you do not please install Python.</p>`,\n    })\n  }\n\n  onSpawnClose(code, signal) {\n    if (code !== 0 && signal == null) {\n      atom.notifications.addError(\"Unable to start the Python language server.\", {\n        dismissable: true,\n        buttons: [\n          {\n            text: \"Install Instructions\",\n            onDidClick: () => atom.workspace.open(\"atom://config/packages/ide-python\"),\n          },\n          {\n            text: \"Download Python\",\n            onDidClick: () => shell.openExternal(\"https://www.python.org/downloads/\"),\n          },\n        ],\n        description:\n          \"Make sure to install `pylsp` 0.19 or newer by running:\\n\" +\n          \"```\\n\" +\n          `${this.python} -m pip install 'python-lsp-server[all]'\\n` +\n          `${this.python} -m pip install git+https://github.com/tomv564/pyls-mypy.git\\n` +\n          \"```\",\n      })\n    }\n  }\n\n  async getSuggestions(request) {\n    if (!PYTHON_REGEX.test(request.prefix)) return null\n    return super.getSuggestions(request)\n  }\n\n  deactivate() {\n    debuggerDispose()\n    return Promise.race([super.deactivate(), this.createTimeoutPromise(2000)])\n  }\n\n  createTimeoutPromise(milliseconds) {\n    return new Promise((resolve, reject) => {\n      let timeout = setTimeout(() => {\n        clearTimeout(timeout)\n        this.logger.error(`Server failed to shutdown in ${milliseconds}ms, forcing termination`)\n        resolve()\n      }, milliseconds)\n    })\n  }\n}\n\nconst pythonClient = new PythonLanguageClient()\npythonClient.createDebuggerProvider = createDebuggerProvider // add the debugger\nmodule.exports = pythonClient\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["main.js"],"names":["shell","require","whichSync","sync","AutoLanguageClient","detectVirtualEnv","detectPipEnv","replacePipEnvPathVar","sanitizeConfig","PYTHON_REGEX","PythonLanguageClient","activate","atom","packages","isPackageLoaded","install","then","enablePackage","notifications","addSuccess","config","unset","getGrammarScopes","getLanguageName","getServerName","getRootConfigurationKey","mapConfigurationObject","configuration","pyls","configurationSources","pylsConfigurationSources","rope","plugins","pylsPlugins","startServerProcess","projectPath","venvPath","pylsEnvironment","Object","assign","process","env","VIRTUAL_ENV","pythonBin","get","nothrow","python","childProcess","spawn","cwd","onSpawnError","err","description","code","addError","dismissable","onSpawnClose","signal","buttons","text","onDidClick","workspace","open","openExternal","getSuggestions","request","test","prefix","deactivate","Promise","race","createTimeoutPromise","milliseconds","resolve","timeout","setTimeout","clearTimeout","logger","error","pythonClient","createDebuggerProvider","module","exports"],"mappings":"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","sourcesContent":["const { shell } = require(\"electron\")\nconst whichSync = require(\"which\").sync\nconst { AutoLanguageClient } = require(\"atom-languageclient\")\nconst { detectVirtualEnv, detectPipEnv, replacePipEnvPathVar, sanitizeConfig } = require(\"./utils\")\n\nimport { createDebuggerProvider, activate as debuggerActivate, dispose as debuggerDispose } from \"./debugger/main\"\n\n// Ref: https://github.com/nteract/hydrogen/blob/master/lib/autocomplete-provider.js#L33\n// adapted from http://stackoverflow.com/q/5474008\nconst PYTHON_REGEX = /(([^\\W\\d]|[\\u00A0-\\uFFFF])[\\w.\\u00A0-\\uFFFF]*)|\\.$/\n\nclass PythonLanguageClient extends AutoLanguageClient {\n  activate() {\n    super.activate()\n    if (!atom.packages.isPackageLoaded(\"atom-ide-base\")) {\n      // install if not installed\n      // eslint-disable-next-line @typescript-eslint/no-var-requires\n      require(\"atom-package-deps\")\n        .install(\"ide-python\", true)\n        .then(() => {\n          // enable if disabled\n          atom.packages.enablePackage(\"atom-ide-base\")\n          atom.notifications.addSuccess(\"ide-pyhon: atom-ide-base was installed and enabled...\")\n        })\n    }\n    // Remove deprecated option\n    atom.config.unset(\"ide-python.pylsPath\")\n    debuggerActivate()\n  }\n\n  /* eslint-disable class-methods-use-this */\n  getGrammarScopes() {\n    return [\"source.python\", \"python\"]\n  }\n\n  getLanguageName() {\n    return \"Python\"\n  }\n\n  getServerName() {\n    return \"pyls\"\n  }\n\n  getRootConfigurationKey() {\n    return \"ide-python\"\n  }\n\n  mapConfigurationObject(configuration) {\n    return {\n      pyls: {\n        configurationSources: configuration.pylsConfigurationSources,\n        rope: sanitizeConfig(configuration.rope),\n        plugins: configuration.pylsPlugins,\n      },\n    }\n  }\n  /* eslint-enable class-methods-use-this */\n\n  async startServerProcess(projectPath) {\n    const venvPath = (await detectPipEnv(projectPath)) || (await detectVirtualEnv(projectPath))\n    const pylsEnvironment = Object.assign({}, process.env)\n    if (venvPath) {\n      pylsEnvironment.VIRTUAL_ENV = venvPath\n    }\n\n    let pythonBin = atom.config.get(\"ide-python.python\") || \"python3\"\n    if (whichSync(pythonBin, { nothrow: true }) === null) {\n      pythonBin = \"python\"\n    }\n\n    this.python = replacePipEnvPathVar(pythonBin, venvPath)\n\n    let pyls = atom.config.get(\"ide-python.pyls\") || \"pylsp\"\n    // check if it exists\n    if (whichSync(pyls, { nothrow: true }) === null) {\n      pyls = \"pyls\"\n    }\n\n    const childProcess = super.spawn(this.python, [\"-m\", pyls], {\n      cwd: projectPath,\n      env: pylsEnvironment,\n    })\n    return childProcess\n  }\n\n  onSpawnError(err) {\n    const description =\n      err.code === \"ENOENT\"\n        ? `No Python interpreter found at \\`${this.python}\\`.`\n        : `Could not spawn the Python interpreter \\`${this.python}\\`.`\n    atom.notifications.addError(\"`ide-python` could not launch your Python runtime.\", {\n      dismissable: true,\n      description: `${description}<p>If you have Python installed please set \"Python Executable\" setting correctly. If you do not please install Python.</p>`,\n    })\n  }\n\n  onSpawnClose(code, signal) {\n    if (code !== 0 && signal === null) {\n      atom.notifications.addError(\"Unable to start the Python language server.\", {\n        dismissable: true,\n        buttons: [\n          {\n            text: \"Install Instructions\",\n            onDidClick: () => atom.workspace.open(\"atom://config/packages/ide-python\"),\n          },\n          {\n            text: \"Download Python\",\n            onDidClick: () => shell.openExternal(\"https://www.python.org/downloads/\"),\n          },\n        ],\n        description:\n          \"Make sure to install `pylsp` 0.19 or newer by running:\\n\" +\n          \"```\\n\" +\n          `${this.python} -m pip install 'python-lsp-server[all]'\\n` +\n          `${this.python} -m pip install git+https://github.com/tomv564/pyls-mypy.git\\n` +\n          \"```\",\n      })\n    }\n  }\n\n  getSuggestions(request) {\n    if (!PYTHON_REGEX.test(request.prefix)) {\n      return null\n    }\n    return super.getSuggestions(request)\n  }\n\n  deactivate() {\n    debuggerDispose()\n    return Promise.race([super.deactivate(), this.createTimeoutPromise(2000)])\n  }\n\n  createTimeoutPromise(milliseconds) {\n    return new Promise((resolve) => {\n      const timeout = setTimeout(() => {\n        clearTimeout(timeout)\n        this.logger.error(`Server failed to shutdown in ${milliseconds}ms, forcing termination`)\n        resolve()\n      }, milliseconds)\n    })\n  }\n}\n\nconst pythonClient = new PythonLanguageClient()\npythonClient.createDebuggerProvider = createDebuggerProvider // add the debugger\nmodule.exports = pythonClient\n"]} \ No newline at end of file diff --git a/dist/utils.js b/dist/utils.js index dfd73351..1b1ff3dd 100644 --- a/dist/utils.js +++ b/dist/utils.js @@ -27,26 +27,30 @@ function detectPipEnv(path) { } async function detectVirtualEnv(path) { - const entries = await new Promise(resolve => new Directory(path).getEntries((error, entries) => { - if (error === null) { - resolve(entries); - } else { - resolve(null); - } - })); + const entries = await new Promise(resolve => { + new Directory(path).getEntries((error, resolvedEntries) => { + if (error === null) { + resolve(resolvedEntries); + } else { + resolve(null); + } + }); + }); if (entries) { - for (let entry of entries) { + for (const entry of entries) { if (entry.isDirectory()) { if (VIRTUAL_ENV_BIN_DIRS.indexOf(entry.getBaseName()) !== -1) { - for (let executable of VIRTUAL_ENV_EXECUTABLES) { + for (const executable of VIRTUAL_ENV_EXECUTABLES) { + /* eslint-disable-next-line no-await-in-loop */ if (await entry.getFile(executable).exists()) { return path; } } } else { - for (let dir_name of VIRTUAL_ENV_BIN_DIRS) { - for (let executable of VIRTUAL_ENV_EXECUTABLES) { + for (const dir_name of VIRTUAL_ENV_BIN_DIRS) { + for (const executable of VIRTUAL_ENV_EXECUTABLES) { + /* eslint-disable-next-line no-await-in-loop */ if (await entry.getSubdirectory(dir_name).getFile(executable).exists()) { return entry.getPath(); } @@ -79,4 +83,4 @@ exports.detectVirtualEnv = detectVirtualEnv; exports.sanitizeConfig = sanitizeConfig; exports.detectPipEnv = detectPipEnv; exports.replacePipEnvPathVar = replacePipEnvPathVar; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInV0aWxzLmpzIl0sIm5hbWVzIjpbImNwIiwicmVxdWlyZSIsIkRpcmVjdG9yeSIsIlZJUlRVQUxfRU5WX0JJTl9ESVJTIiwiVklSVFVBTF9FTlZfRVhFQ1VUQUJMRVMiLCJkZXRlY3RQaXBFbnYiLCJwYXRoIiwiUHJvbWlzZSIsInJlc29sdmUiLCJwaXBFbnZQcm9jZXNzIiwic3Bhd24iLCJjd2QiLCJzdGRvdXQiLCJvbiIsImRhdGEiLCJ0cmltIiwic3RkZXJyIiwiZGV0ZWN0VmlydHVhbEVudiIsImVudHJpZXMiLCJnZXRFbnRyaWVzIiwiZXJyb3IiLCJlbnRyeSIsImlzRGlyZWN0b3J5IiwiaW5kZXhPZiIsImdldEJhc2VOYW1lIiwiZXhlY3V0YWJsZSIsImdldEZpbGUiLCJleGlzdHMiLCJkaXJfbmFtZSIsImdldFN1YmRpcmVjdG9yeSIsImdldFBhdGgiLCJzYW5pdGl6ZUNvbmZpZyIsImNvbmZpZyIsIk9iamVjdCIsImZvckVhY2giLCJrZXkiLCJ2YWx1ZSIsInJlcGxhY2VQaXBFbnZQYXRoVmFyIiwicHl0aG9uUGF0aCIsInBpcEVudlBhdGgiLCJyZXBsYWNlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxNQUFNQSxFQUFFLEdBQUdDLE9BQU8sQ0FBQyxlQUFELENBQWxCOztBQUNBLE1BQU07QUFBRUMsRUFBQUE7QUFBRixJQUFnQkQsT0FBTyxDQUFDLE1BQUQsQ0FBN0I7O0FBRUEsTUFBTUUsb0JBQW9CLEdBQUcsQ0FBQyxLQUFELEVBQVEsU0FBUixDQUE3QjtBQUNBLE1BQU1DLHVCQUF1QixHQUFHLENBQUMsUUFBRCxFQUFXLFlBQVgsQ0FBaEM7O0FBRUEsU0FBU0MsWUFBVCxDQUFzQkMsSUFBdEIsRUFBNEI7QUFDMUIsU0FBTyxJQUFJQyxPQUFKLENBQWFDLE9BQUQsSUFBYTtBQUM5QixVQUFNQyxhQUFhLEdBQUdULEVBQUUsQ0FBQ1UsS0FBSCxDQUFTLFFBQVQsRUFBbUIsQ0FBQyxRQUFELENBQW5CLEVBQStCO0FBQ25EQyxNQUFB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LE9BQU8sQ0FBQ1YsY0FBUixHQUF5QkEsY0FBekI7QUFDQVUsT0FBTyxDQUFDcEMsWUFBUixHQUF1QkEsWUFBdkI7QUFDQW9DLE9BQU8sQ0FBQ0osb0JBQVIsR0FBK0JBLG9CQUEvQiIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGNwID0gcmVxdWlyZShcImNoaWxkX3Byb2Nlc3NcIilcbmNvbnN0IHsgRGlyZWN0b3J5IH0gPSByZXF1aXJlKFwiYXRvbVwiKVxuXG5jb25zdCBWSVJUVUFMX0VOVl9CSU5fRElSUyA9IFtcImJpblwiLCBcIlNjcmlwdHNcIl1cbmNvbnN0IFZJUlRVQUxfRU5WX0VYRUNVVEFCTEVTID0gW1wicHl0aG9uXCIsIFwicHl0aG9uLmV4ZVwiXVxuXG5mdW5jdGlvbiBkZXRlY3RQaXBFbnYocGF0aCkge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHtcbiAgICBjb25zdCBwaXBFbnZQcm9jZXNzID0gY3Auc3Bhd24oXCJwaXBlbnZcIiwgW1wiLS12ZW52XCJdLCB7XG4gICAgICBjd2Q6IHBhdGgsXG4gICAgfSlcbiAgICBwaXBFbnZQcm9jZXNzLnN0ZG91dC5vbihcImRhdGFcIiwgKGRhdGEpID0+IHtcbiAgICAgIHJlc29sdmUoYCR7ZGF0YX1gLnRyaW0oKSlcbiAgICB9KVxuICAgIHBpcEVudlByb2Nlc3Muc3RkZXJyLm9uKFwiZGF0YVwiLCAoKSA9PiB7XG4gICAgICByZXNvbHZlKG51bGwpXG4gICAgfSlcbiAgICBwaXBFbnZQcm9jZXNzLm9uKFwiZXJyb3JcIiwgKCkgPT4ge1xuICAgICAgcmVzb2x2ZShudWxsKVxuICAgIH0pXG4gIH0pXG59XG5cbmFzeW5jIGZ1bmN0aW9uIGRldGVjdFZpcnR1YWxFbnYocGF0aCkge1xuICBjb25zdCBlbnRyaWVzID0gYXdhaXQgbmV3IFByb21pc2UoKHJlc29sdmUpID0+XG4gICAgbmV3IERpcmVjdG9yeShwYXRoKS5nZXRFbnRyaWVzKChlcnJvciwgZW50cmllcykgPT4ge1xuICAgICAgaWYgKGVycm9yID09PSBudWxsKSB7XG4gICAgICAgIHJlc29sdmUoZW50cmllcylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlc29sdmUobnVsbClcbiAgICAgIH1cbiAgICB9KVxuICApXG4gIGlmIChlbnRyaWVzKSB7XG4gICAgZm9yIChsZXQgZW50cnkgb2YgZW50cmllcykge1xuICAgICAgaWYgKGVudHJ5LmlzRGlyZWN0b3J5KCkpIHtcbiAgICAgICAgaWYgKFZJUlRVQUxfRU5WX0JJTl9ESVJTLmluZGV4T2YoZW50cnkuZ2V0QmFzZU5hbWUoKSkgIT09IC0xKSB7XG4gICAgICAgICAgZm9yIChsZXQgZXhlY3V0YWJsZSBvZiBWSVJUVUFMX0VOVl9FWEVDVVRBQkxFUykge1xuICAgICAgICAgICAgaWYgKGF3YWl0IGVudHJ5LmdldEZpbGUoZXhlY3V0YWJsZSkuZXhpc3RzKCkpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIHBhdGhcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgZm9yIChsZXQgZGlyX25hbWUgb2YgVklSVFVBTF9FTlZfQklOX0RJUlMpIHtcbiAgICAgICAgICAgIGZvciAobGV0IGV4ZWN1dGFibGUgb2YgVklSVFVBTF9FTlZfRVhFQ1VUQUJMRVMpIHtcbiAgICAgICAgICAgICAgaWYgKGF3YWl0IGVudHJ5LmdldFN1YmRpcmVjdG9yeShkaXJfbmFtZSkuZ2V0RmlsZShleGVjdXRhYmxlKS5leGlzdHMoKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBlbnRyeS5nZXRQYXRoKClcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxufVxuXG5mdW5jdGlvbiBzYW5pdGl6ZUNvbmZpZyhjb25maWcpIHtcbiAgT2JqZWN0LmVudHJpZXMoY29uZmlnKS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICBpZiAodmFsdWUgPT09IFwibnVsbFwiKSB7XG4gICAgICBjb25maWdba2V5XSA9IG51bGxcbiAgICB9XG4gIH0pXG4gIHJldHVybiBjb25maWdcbn1cblxuZnVuY3Rpb24gcmVwbGFjZVBpcEVudlBhdGhWYXIocHl0aG9uUGF0aCwgcGlwRW52UGF0aCkge1xuICBpZiAocHl0aG9uUGF0aC5pbmRleE9mKFwiJFBJUEVOVl9QQVRIXCIpICE9PSAtMSAmJiBwaXBFbnZQYXRoKSB7XG4gICAgcmV0dXJuIHB5dGhvblBhdGgucmVwbGFjZShcIiRQSVBFTlZfUEFUSFwiLCBwaXBFbnZQYXRoKVxuICB9XG4gIHJldHVybiBweXRob25QYXRoXG59XG5cbmV4cG9ydHMuZGV0ZWN0VmlydHVhbEVudiA9IGRldGVjdFZpcnR1YWxFbnZcbmV4cG9ydHMuc2FuaXRpemVDb25maWcgPSBzYW5pdGl6ZUNvbmZpZ1xuZXhwb3J0cy5kZXRlY3RQaXBFbnYgPSBkZXRlY3RQaXBFbnZcbmV4cG9ydHMucmVwbGFjZVBpcEVudlBhdGhWYXIgPSByZXBsYWNlUGlwRW52UGF0aFZhclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInV0aWxzLmpzIl0sIm5hbWVzIjpbImNwIiwicmVxdWlyZSIsIkRpcmVjdG9yeSIsIlZJUlRVQUxfRU5WX0JJTl9ESVJTIiwiVklSVFVBTF9FTlZfRVhFQ1VUQUJMRVMiLCJkZXRlY3RQaXBFbnYiLCJwYXRoIiwiUHJvbWlzZSIsInJlc29sdmUiLCJwaXBFbnZQcm9jZXNzIiwic3Bhd24iLCJjd2QiLCJzdGRvdXQiLCJvbiIsImRhdGEiLCJ0cmltIiwic3RkZXJyIiwiZGV0ZWN0VmlydHVhbEVudiIsImVudHJpZXMiLCJnZXRFbnRyaWVzIiwiZXJyb3IiLCJyZXNvbHZlZEVudHJpZXMiLCJlbnRyeSIsImlzRGlyZWN0b3J5IiwiaW5kZXhPZiIsImdldEJhc2VOYW1lIiwiZXhlY3V0YWJsZSIsImdldEZpbGUiLCJleGlzdHMiLCJkaXJfbmFtZSIsImdldFN1YmRpcmVjdG9yeSIsImdldFBhdGgiLCJzYW5pdGl6ZUNvbmZpZyIsImNvbmZpZyIsIk9iamVjdCIsImZvckVhY2giLCJrZXkiLCJ2YWx1ZSIsInJlcGxhY2VQaXBFbnZQYXRoVmFyIiwicHl0aG9uUGF0aCIsInBpcEVudlBhdGgiLCJyZXBsYWNlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxNQUFNQSxFQUFFLEdBQUdDLE9BQU8sQ0FBQyxlQUFELENBQWxCOztBQUNBLE1BQU07QUFBRUMsRUFBQUE7QUFBRixJQUFnQkQsT0FBTyxDQUFDLE1BQUQsQ0FBN0I7O0FBRUEsTUFBTUUsb0JBQW9CLEdBQUcsQ0FBQyxLQUFELEVBQVEsU0FBUixDQUE3QjtBQUNBLE1BQU1DLHVCQUF1QixHQUFHLENBQUMsUUFBRCxFQUFXLFlBQVgsQ0FBaEM7O0FBRUEsU0FBU0MsWUFBVCxDQUFzQkMsSUFBdEIsRUFBNEI7QUFDMUIsU0FBTyxJQUFJQyxPQUFKLENBQWFDLE9BQUQsSUFBYTtBQUM5QixVQUFNQyxhQUFhLEdBQUdULEVBQUUsQ0FBQ1UsS0FBSCxDQUFTLFFBQVQsRUFBbUIsQ0FBQyxRQUFELENBQW5C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LE9BQU8sQ0FBQ3pCLGdCQUFSLEdBQTJCQSxnQkFBM0I7QUFDQXlCLE9BQU8sQ0FBQ1YsY0FBUixHQUF5QkEsY0FBekI7QUFDQVUsT0FBTyxDQUFDckMsWUFBUixHQUF1QkEsWUFBdkI7QUFDQXFDLE9BQU8sQ0FBQ0osb0JBQVIsR0FBK0JBLG9CQUEvQiIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGNwID0gcmVxdWlyZShcImNoaWxkX3Byb2Nlc3NcIilcbmNvbnN0IHsgRGlyZWN0b3J5IH0gPSByZXF1aXJlKFwiYXRvbVwiKVxuXG5jb25zdCBWSVJUVUFMX0VOVl9CSU5fRElSUyA9IFtcImJpblwiLCBcIlNjcmlwdHNcIl1cbmNvbnN0IFZJUlRVQUxfRU5WX0VYRUNVVEFCTEVTID0gW1wicHl0aG9uXCIsIFwicHl0aG9uLmV4ZVwiXVxuXG5mdW5jdGlvbiBkZXRlY3RQaXBFbnYocGF0aCkge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHtcbiAgICBjb25zdCBwaXBFbnZQcm9jZXNzID0gY3Auc3Bhd24oXCJwaXBlbnZcIiwgW1wiLS12ZW52XCJdLCB7XG4gICAgICBjd2Q6IHBhdGgsXG4gICAgfSlcbiAgICBwaXBFbnZQcm9jZXNzLnN0ZG91dC5vbihcImRhdGFcIiwgKGRhdGEpID0+IHtcbiAgICAgIHJlc29sdmUoYCR7ZGF0YX1gLnRyaW0oKSlcbiAgICB9KVxuICAgIHBpcEVudlByb2Nlc3Muc3RkZXJyLm9uKFwiZGF0YVwiLCAoKSA9PiB7XG4gICAgICByZXNvbHZlKG51bGwpXG4gICAgfSlcbiAgICBwaXBFbnZQcm9jZXNzLm9uKFwiZXJyb3JcIiwgKCkgPT4ge1xuICAgICAgcmVzb2x2ZShudWxsKVxuICAgIH0pXG4gIH0pXG59XG5cbmFzeW5jIGZ1bmN0aW9uIGRldGVjdFZpcnR1YWxFbnYocGF0aCkge1xuICBjb25zdCBlbnRyaWVzID0gYXdhaXQgbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHtcbiAgICBuZXcgRGlyZWN0b3J5KHBhdGgpLmdldEVudHJpZXMoKGVycm9yLCByZXNvbHZlZEVudHJpZXMpID0+IHtcbiAgICAgIGlmIChlcnJvciA9PT0gbnVsbCkge1xuICAgICAgICByZXNvbHZlKHJlc29sdmVkRW50cmllcylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlc29sdmUobnVsbClcbiAgICAgIH1cbiAgICB9KVxuICB9KVxuICBpZiAoZW50cmllcykge1xuICAgIGZvciAoY29uc3QgZW50cnkgb2YgZW50cmllcykge1xuICAgICAgaWYgKGVudHJ5LmlzRGlyZWN0b3J5KCkpIHtcbiAgICAgICAgaWYgKFZJUlRVQUxfRU5WX0JJTl9ESVJTLmluZGV4T2YoZW50cnkuZ2V0QmFzZU5hbWUoKSkgIT09IC0xKSB7XG4gICAgICAgICAgZm9yIChjb25zdCBleGVjdXRhYmxlIG9mIFZJUlRVQUxfRU5WX0VYRUNVVEFCTEVTKSB7XG4gICAgICAgICAgICAvKiBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYXdhaXQtaW4tbG9vcCAqL1xuICAgICAgICAgICAgaWYgKGF3YWl0IGVudHJ5LmdldEZpbGUoZXhlY3V0YWJsZSkuZXhpc3RzKCkpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIHBhdGhcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgZm9yIChjb25zdCBkaXJfbmFtZSBvZiBWSVJUVUFMX0VOVl9CSU5fRElSUykge1xuICAgICAgICAgICAgZm9yIChjb25zdCBleGVjdXRhYmxlIG9mIFZJUlRVQUxfRU5WX0VYRUNVVEFCTEVTKSB7XG4gICAgICAgICAgICAgIC8qIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1hd2FpdC1pbi1sb29wICovXG4gICAgICAgICAgICAgIGlmIChhd2FpdCBlbnRyeS5nZXRTdWJkaXJlY3RvcnkoZGlyX25hbWUpLmdldEZpbGUoZXhlY3V0YWJsZSkuZXhpc3RzKCkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZW50cnkuZ2V0UGF0aCgpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cblxuZnVuY3Rpb24gc2FuaXRpemVDb25maWcoY29uZmlnKSB7XG4gIE9iamVjdC5lbnRyaWVzKGNvbmZpZykuZm9yRWFjaCgoW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgaWYgKHZhbHVlID09PSBcIm51bGxcIikge1xuICAgICAgY29uZmlnW2tleV0gPSBudWxsXG4gICAgfVxuICB9KVxuICByZXR1cm4gY29uZmlnXG59XG5cbmZ1bmN0aW9uIHJlcGxhY2VQaXBFbnZQYXRoVmFyKHB5dGhvblBhdGgsIHBpcEVudlBhdGgpIHtcbiAgaWYgKHB5dGhvblBhdGguaW5kZXhPZihcIiRQSVBFTlZfUEFUSFwiKSAhPT0gLTEgJiYgcGlwRW52UGF0aCkge1xuICAgIHJldHVybiBweXRob25QYXRoLnJlcGxhY2UoXCIkUElQRU5WX1BBVEhcIiwgcGlwRW52UGF0aClcbiAgfVxuICByZXR1cm4gcHl0aG9uUGF0aFxufVxuXG5leHBvcnRzLmRldGVjdFZpcnR1YWxFbnYgPSBkZXRlY3RWaXJ0dWFsRW52XG5leHBvcnRzLnNhbml0aXplQ29uZmlnID0gc2FuaXRpemVDb25maWdcbmV4cG9ydHMuZGV0ZWN0UGlwRW52ID0gZGV0ZWN0UGlwRW52XG5leHBvcnRzLnJlcGxhY2VQaXBFbnZQYXRoVmFyID0gcmVwbGFjZVBpcEVudlBhdGhWYXJcbiJdfQ== \ No newline at end of file diff --git a/package.json b/package.json index fe900d79..cd367180 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "ide-python", "main": "./dist/main", - "version": "1.9.3", + "version": "1.9.4", "description": "Python language support for Atom-IDE", "keywords": [ "ide",