mirror of https://github.com/grafana/grafana
Chore: Switch yarn 2 to plug-n-play strategy (#40300)
parent
690849cfd6
commit
3a7c5a0755
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require eslint/bin/eslint.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real eslint/bin/eslint.js your application uses
|
||||
module.exports = absRequire(`eslint/bin/eslint.js`); |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require eslint/lib/api.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real eslint/lib/api.js your application uses
|
||||
module.exports = absRequire(`eslint/lib/api.js`); |
@ -0,0 +1,6 @@ |
||||
{ |
||||
"name": "eslint", |
||||
"version": "7.21.0-sdk", |
||||
"main": "./lib/api.js", |
||||
"type": "commonjs" |
||||
} |
@ -0,0 +1,5 @@ |
||||
# This file is automatically generated by @yarnpkg/sdks. |
||||
# Manual changes might be lost! |
||||
|
||||
integrations: |
||||
- vscode |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require prettier/index.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real prettier/index.js your application uses
|
||||
module.exports = absRequire(`prettier/index.js`); |
@ -0,0 +1,6 @@ |
||||
{ |
||||
"name": "prettier", |
||||
"version": "2.2.1-sdk", |
||||
"main": "./index.js", |
||||
"type": "commonjs" |
||||
} |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require stylelint/bin/stylelint.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real stylelint/bin/stylelint.js your application uses
|
||||
module.exports = absRequire(`stylelint/bin/stylelint.js`); |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require stylelint/lib/index.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real stylelint/lib/index.js your application uses
|
||||
module.exports = absRequire(`stylelint/lib/index.js`); |
@ -0,0 +1,6 @@ |
||||
{ |
||||
"name": "stylelint", |
||||
"version": "13.13.1-sdk", |
||||
"main": "lib/index.js", |
||||
"type": "commonjs" |
||||
} |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node |
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require typescript/bin/tsc |
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real typescript/bin/tsc your application uses |
||||
module.exports = absRequire(`typescript/bin/tsc`); |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node |
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require typescript/bin/tsserver |
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real typescript/bin/tsserver your application uses |
||||
module.exports = absRequire(`typescript/bin/tsserver`); |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require typescript/lib/tsc.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real typescript/lib/tsc.js your application uses
|
||||
module.exports = absRequire(`typescript/lib/tsc.js`); |
@ -0,0 +1,184 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
const moduleWrapper = tsserver => { |
||||
if (!process.versions.pnp) { |
||||
return tsserver; |
||||
} |
||||
|
||||
const {isAbsolute} = require(`path`); |
||||
const pnpApi = require(`pnpapi`); |
||||
|
||||
const isVirtual = str => str.match(/\/(\$\$virtual|__virtual__)\//); |
||||
const normalize = str => str.replace(/\\/g, `/`).replace(/^\/?/, `/`); |
||||
|
||||
const dependencyTreeRoots = new Set(pnpApi.getDependencyTreeRoots().map(locator => { |
||||
return `${locator.name}@${locator.reference}`; |
||||
})); |
||||
|
||||
// VSCode sends the zip paths to TS using the "zip://" prefix, that TS
|
||||
// doesn't understand. This layer makes sure to remove the protocol
|
||||
// before forwarding it to TS, and to add it back on all returned paths.
|
||||
|
||||
function toEditorPath(str) { |
||||
// We add the `zip:` prefix to both `.zip/` paths and virtual paths
|
||||
if (isAbsolute(str) && !str.match(/^\^?(zip:|\/zip\/)/) && (str.match(/\.zip\//) || isVirtual(str))) { |
||||
// We also take the opportunity to turn virtual paths into physical ones;
|
||||
// this makes it much easier to work with workspaces that list peer
|
||||
// dependencies, since otherwise Ctrl+Click would bring us to the virtual
|
||||
// file instances instead of the real ones.
|
||||
//
|
||||
// We only do this to modules owned by the the dependency tree roots.
|
||||
// This avoids breaking the resolution when jumping inside a vendor
|
||||
// with peer dep (otherwise jumping into react-dom would show resolution
|
||||
// errors on react).
|
||||
//
|
||||
const resolved = isVirtual(str) ? pnpApi.resolveVirtual(str) : str; |
||||
if (resolved) { |
||||
const locator = pnpApi.findPackageLocator(resolved); |
||||
if (locator && dependencyTreeRoots.has(`${locator.name}@${locator.reference}`)) { |
||||
str = resolved; |
||||
} |
||||
} |
||||
|
||||
str = normalize(str); |
||||
|
||||
if (str.match(/\.zip\//)) { |
||||
switch (hostInfo) { |
||||
// Absolute VSCode `Uri.fsPath`s need to start with a slash.
|
||||
// VSCode only adds it automatically for supported schemes,
|
||||
// so we have to do it manually for the `zip` scheme.
|
||||
// The path needs to start with a caret otherwise VSCode doesn't handle the protocol
|
||||
//
|
||||
// Ref: https://github.com/microsoft/vscode/issues/105014#issuecomment-686760910
|
||||
//
|
||||
// Update Oct 8 2021: VSCode changed their format in 1.61.
|
||||
// Before | ^zip:/c:/foo/bar.zip/package.json
|
||||
// After | ^/zip//c:/foo/bar.zip/package.json
|
||||
//
|
||||
case `vscode <1.61`: { |
||||
str = `^zip:${str}`; |
||||
} break; |
||||
|
||||
case `vscode`: { |
||||
str = `^/zip/${str}`; |
||||
} break; |
||||
|
||||
// To make "go to definition" work,
|
||||
// We have to resolve the actual file system path from virtual path
|
||||
// and convert scheme to supported by [vim-rzip](https://github.com/lbrayner/vim-rzip)
|
||||
case `coc-nvim`: { |
||||
str = normalize(resolved).replace(/\.zip\//, `.zip::`); |
||||
str = resolve(`zipfile:${str}`); |
||||
} break; |
||||
|
||||
// Support neovim native LSP and [typescript-language-server](https://github.com/theia-ide/typescript-language-server)
|
||||
// We have to resolve the actual file system path from virtual path,
|
||||
// everything else is up to neovim
|
||||
case `neovim`: { |
||||
str = normalize(resolved).replace(/\.zip\//, `.zip::`); |
||||
str = `zipfile:${str}`; |
||||
} break; |
||||
|
||||
default: { |
||||
str = `zip:${str}`; |
||||
} break; |
||||
} |
||||
} |
||||
} |
||||
|
||||
return str; |
||||
} |
||||
|
||||
function fromEditorPath(str) { |
||||
switch (hostInfo) { |
||||
case `coc-nvim`: |
||||
case `neovim`: { |
||||
str = str.replace(/\.zip::/, `.zip/`); |
||||
// The path for coc-nvim is in format of /<pwd>/zipfile:/<pwd>/.yarn/...
|
||||
// So in order to convert it back, we use .* to match all the thing
|
||||
// before `zipfile:`
|
||||
return process.platform === `win32` |
||||
? str.replace(/^.*zipfile:\//, ``) |
||||
: str.replace(/^.*zipfile:/, ``); |
||||
} break; |
||||
|
||||
case `vscode`: |
||||
default: { |
||||
return process.platform === `win32` |
||||
? str.replace(/^\^?(zip:|\/zip)\/+/, ``) |
||||
: str.replace(/^\^?(zip:|\/zip)\/+/, `/`); |
||||
} break; |
||||
} |
||||
} |
||||
|
||||
// Force enable 'allowLocalPluginLoads'
|
||||
// TypeScript tries to resolve plugins using a path relative to itself
|
||||
// which doesn't work when using the global cache
|
||||
// https://github.com/microsoft/TypeScript/blob/1b57a0395e0bff191581c9606aab92832001de62/src/server/project.ts#L2238
|
||||
// VSCode doesn't want to enable 'allowLocalPluginLoads' due to security concerns but
|
||||
// TypeScript already does local loads and if this code is running the user trusts the workspace
|
||||
// https://github.com/microsoft/vscode/issues/45856
|
||||
const ConfiguredProject = tsserver.server.ConfiguredProject; |
||||
const {enablePluginsWithOptions: originalEnablePluginsWithOptions} = ConfiguredProject.prototype; |
||||
ConfiguredProject.prototype.enablePluginsWithOptions = function() { |
||||
this.projectService.allowLocalPluginLoads = true; |
||||
return originalEnablePluginsWithOptions.apply(this, arguments); |
||||
}; |
||||
|
||||
// And here is the point where we hijack the VSCode <-> TS communications
|
||||
// by adding ourselves in the middle. We locate everything that looks
|
||||
// like an absolute path of ours and normalize it.
|
||||
|
||||
const Session = tsserver.server.Session; |
||||
const {onMessage: originalOnMessage, send: originalSend} = Session.prototype; |
||||
let hostInfo = `unknown`; |
||||
|
||||
Object.assign(Session.prototype, { |
||||
onMessage(/** @type {string} */ message) { |
||||
const parsedMessage = JSON.parse(message) |
||||
|
||||
if ( |
||||
parsedMessage != null && |
||||
typeof parsedMessage === `object` && |
||||
parsedMessage.arguments && |
||||
typeof parsedMessage.arguments.hostInfo === `string` |
||||
) { |
||||
hostInfo = parsedMessage.arguments.hostInfo; |
||||
if (hostInfo === `vscode` && process.env.VSCODE_IPC_HOOK && process.env.VSCODE_IPC_HOOK.match(/Code\/1\.([1-5][0-9]|60)\./)) { |
||||
hostInfo += ` <1.61`; |
||||
} |
||||
} |
||||
|
||||
return originalOnMessage.call(this, JSON.stringify(parsedMessage, (key, value) => { |
||||
return typeof value === `string` ? fromEditorPath(value) : value; |
||||
})); |
||||
}, |
||||
|
||||
send(/** @type {any} */ msg) { |
||||
return originalSend.call(this, JSON.parse(JSON.stringify(msg, (key, value) => { |
||||
return typeof value === `string` ? toEditorPath(value) : value; |
||||
}))); |
||||
} |
||||
}); |
||||
|
||||
return tsserver; |
||||
}; |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require typescript/lib/tsserver.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real typescript/lib/tsserver.js your application uses
|
||||
module.exports = moduleWrapper(absRequire(`typescript/lib/tsserver.js`)); |
@ -0,0 +1,184 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
const moduleWrapper = tsserver => { |
||||
if (!process.versions.pnp) { |
||||
return tsserver; |
||||
} |
||||
|
||||
const {isAbsolute} = require(`path`); |
||||
const pnpApi = require(`pnpapi`); |
||||
|
||||
const isVirtual = str => str.match(/\/(\$\$virtual|__virtual__)\//); |
||||
const normalize = str => str.replace(/\\/g, `/`).replace(/^\/?/, `/`); |
||||
|
||||
const dependencyTreeRoots = new Set(pnpApi.getDependencyTreeRoots().map(locator => { |
||||
return `${locator.name}@${locator.reference}`; |
||||
})); |
||||
|
||||
// VSCode sends the zip paths to TS using the "zip://" prefix, that TS
|
||||
// doesn't understand. This layer makes sure to remove the protocol
|
||||
// before forwarding it to TS, and to add it back on all returned paths.
|
||||
|
||||
function toEditorPath(str) { |
||||
// We add the `zip:` prefix to both `.zip/` paths and virtual paths
|
||||
if (isAbsolute(str) && !str.match(/^\^?(zip:|\/zip\/)/) && (str.match(/\.zip\//) || isVirtual(str))) { |
||||
// We also take the opportunity to turn virtual paths into physical ones;
|
||||
// this makes it much easier to work with workspaces that list peer
|
||||
// dependencies, since otherwise Ctrl+Click would bring us to the virtual
|
||||
// file instances instead of the real ones.
|
||||
//
|
||||
// We only do this to modules owned by the the dependency tree roots.
|
||||
// This avoids breaking the resolution when jumping inside a vendor
|
||||
// with peer dep (otherwise jumping into react-dom would show resolution
|
||||
// errors on react).
|
||||
//
|
||||
const resolved = isVirtual(str) ? pnpApi.resolveVirtual(str) : str; |
||||
if (resolved) { |
||||
const locator = pnpApi.findPackageLocator(resolved); |
||||
if (locator && dependencyTreeRoots.has(`${locator.name}@${locator.reference}`)) { |
||||
str = resolved; |
||||
} |
||||
} |
||||
|
||||
str = normalize(str); |
||||
|
||||
if (str.match(/\.zip\//)) { |
||||
switch (hostInfo) { |
||||
// Absolute VSCode `Uri.fsPath`s need to start with a slash.
|
||||
// VSCode only adds it automatically for supported schemes,
|
||||
// so we have to do it manually for the `zip` scheme.
|
||||
// The path needs to start with a caret otherwise VSCode doesn't handle the protocol
|
||||
//
|
||||
// Ref: https://github.com/microsoft/vscode/issues/105014#issuecomment-686760910
|
||||
//
|
||||
// Update Oct 8 2021: VSCode changed their format in 1.61.
|
||||
// Before | ^zip:/c:/foo/bar.zip/package.json
|
||||
// After | ^/zip//c:/foo/bar.zip/package.json
|
||||
//
|
||||
case `vscode <1.61`: { |
||||
str = `^zip:${str}`; |
||||
} break; |
||||
|
||||
case `vscode`: { |
||||
str = `^/zip/${str}`; |
||||
} break; |
||||
|
||||
// To make "go to definition" work,
|
||||
// We have to resolve the actual file system path from virtual path
|
||||
// and convert scheme to supported by [vim-rzip](https://github.com/lbrayner/vim-rzip)
|
||||
case `coc-nvim`: { |
||||
str = normalize(resolved).replace(/\.zip\//, `.zip::`); |
||||
str = resolve(`zipfile:${str}`); |
||||
} break; |
||||
|
||||
// Support neovim native LSP and [typescript-language-server](https://github.com/theia-ide/typescript-language-server)
|
||||
// We have to resolve the actual file system path from virtual path,
|
||||
// everything else is up to neovim
|
||||
case `neovim`: { |
||||
str = normalize(resolved).replace(/\.zip\//, `.zip::`); |
||||
str = `zipfile:${str}`; |
||||
} break; |
||||
|
||||
default: { |
||||
str = `zip:${str}`; |
||||
} break; |
||||
} |
||||
} |
||||
} |
||||
|
||||
return str; |
||||
} |
||||
|
||||
function fromEditorPath(str) { |
||||
switch (hostInfo) { |
||||
case `coc-nvim`: |
||||
case `neovim`: { |
||||
str = str.replace(/\.zip::/, `.zip/`); |
||||
// The path for coc-nvim is in format of /<pwd>/zipfile:/<pwd>/.yarn/...
|
||||
// So in order to convert it back, we use .* to match all the thing
|
||||
// before `zipfile:`
|
||||
return process.platform === `win32` |
||||
? str.replace(/^.*zipfile:\//, ``) |
||||
: str.replace(/^.*zipfile:/, ``); |
||||
} break; |
||||
|
||||
case `vscode`: |
||||
default: { |
||||
return process.platform === `win32` |
||||
? str.replace(/^\^?(zip:|\/zip)\/+/, ``) |
||||
: str.replace(/^\^?(zip:|\/zip)\/+/, `/`); |
||||
} break; |
||||
} |
||||
} |
||||
|
||||
// Force enable 'allowLocalPluginLoads'
|
||||
// TypeScript tries to resolve plugins using a path relative to itself
|
||||
// which doesn't work when using the global cache
|
||||
// https://github.com/microsoft/TypeScript/blob/1b57a0395e0bff191581c9606aab92832001de62/src/server/project.ts#L2238
|
||||
// VSCode doesn't want to enable 'allowLocalPluginLoads' due to security concerns but
|
||||
// TypeScript already does local loads and if this code is running the user trusts the workspace
|
||||
// https://github.com/microsoft/vscode/issues/45856
|
||||
const ConfiguredProject = tsserver.server.ConfiguredProject; |
||||
const {enablePluginsWithOptions: originalEnablePluginsWithOptions} = ConfiguredProject.prototype; |
||||
ConfiguredProject.prototype.enablePluginsWithOptions = function() { |
||||
this.projectService.allowLocalPluginLoads = true; |
||||
return originalEnablePluginsWithOptions.apply(this, arguments); |
||||
}; |
||||
|
||||
// And here is the point where we hijack the VSCode <-> TS communications
|
||||
// by adding ourselves in the middle. We locate everything that looks
|
||||
// like an absolute path of ours and normalize it.
|
||||
|
||||
const Session = tsserver.server.Session; |
||||
const {onMessage: originalOnMessage, send: originalSend} = Session.prototype; |
||||
let hostInfo = `unknown`; |
||||
|
||||
Object.assign(Session.prototype, { |
||||
onMessage(/** @type {string} */ message) { |
||||
const parsedMessage = JSON.parse(message) |
||||
|
||||
if ( |
||||
parsedMessage != null && |
||||
typeof parsedMessage === `object` && |
||||
parsedMessage.arguments && |
||||
typeof parsedMessage.arguments.hostInfo === `string` |
||||
) { |
||||
hostInfo = parsedMessage.arguments.hostInfo; |
||||
if (hostInfo === `vscode` && process.env.VSCODE_IPC_HOOK && process.env.VSCODE_IPC_HOOK.match(/Code\/1\.([1-5][0-9]|60)\./)) { |
||||
hostInfo += ` <1.61`; |
||||
} |
||||
} |
||||
|
||||
return originalOnMessage.call(this, JSON.stringify(parsedMessage, (key, value) => { |
||||
return typeof value === `string` ? fromEditorPath(value) : value; |
||||
})); |
||||
}, |
||||
|
||||
send(/** @type {any} */ msg) { |
||||
return originalSend.call(this, JSON.parse(JSON.stringify(msg, (key, value) => { |
||||
return typeof value === `string` ? toEditorPath(value) : value; |
||||
}))); |
||||
} |
||||
}); |
||||
|
||||
return tsserver; |
||||
}; |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require typescript/lib/tsserverlibrary.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real typescript/lib/tsserverlibrary.js your application uses
|
||||
module.exports = moduleWrapper(absRequire(`typescript/lib/tsserverlibrary.js`)); |
@ -0,0 +1,20 @@ |
||||
#!/usr/bin/env node
|
||||
|
||||
const {existsSync} = require(`fs`); |
||||
const {createRequire, createRequireFromPath} = require(`module`); |
||||
const {resolve} = require(`path`); |
||||
|
||||
const relPnpApiPath = "../../../../.pnp.cjs"; |
||||
|
||||
const absPnpApiPath = resolve(__dirname, relPnpApiPath); |
||||
const absRequire = (createRequire || createRequireFromPath)(absPnpApiPath); |
||||
|
||||
if (existsSync(absPnpApiPath)) { |
||||
if (!process.versions.pnp) { |
||||
// Setup the environment to be able to require typescript/lib/typescript.js
|
||||
require(absPnpApiPath).setup(); |
||||
} |
||||
} |
||||
|
||||
// Defer to the real typescript/lib/typescript.js your application uses
|
||||
module.exports = absRequire(`typescript/lib/typescript.js`); |
@ -0,0 +1,6 @@ |
||||
{ |
||||
"name": "typescript", |
||||
"version": "4.4.3-sdk", |
||||
"main": "./lib/typescript.js", |
||||
"type": "commonjs" |
||||
} |
@ -1,2 +1,2 @@ |
||||
// Need to import this to get default styles from rc-drawer |
||||
@import '~rc-drawer/assets/index.css'; |
||||
@import 'rc-drawer/assets/index.css'; |
||||
|
@ -1 +1 @@ |
||||
@import '~rc-slider/assets/index.css'; |
||||
@import 'rc-slider/assets/index.css'; |
||||
|
@ -1,11 +1,10 @@ |
||||
{ |
||||
"compilerOptions": { |
||||
"baseUrl": "node_modules/@types", |
||||
"paths": { |
||||
"@grafana/slate-react": ["slate-react"] |
||||
}, |
||||
"typeRoots": ["node_modules/@types"] |
||||
"baseUrl": ".", |
||||
"allowJs": true, |
||||
"jsx": "react" |
||||
}, |
||||
"exclude": ["dist", "node_modules"], |
||||
"extends": "@grafana/tsconfig", |
||||
"include": ["src/**/*.ts*", "typings", "../../public/app/types/jquery/*.ts", "../../public/app/types/*.d.ts"] |
||||
} |
||||
|
Loading…
Reference in new issue