Для вывода в Webpack требуется точка ввода (машинопись) не в том месте - PullRequest
0 голосов
/ 29 марта 2019

В выводе webpack находится в конце require(".src/extension.ts"), но я не знаю почему, и это приводит к сбою моего выполнения.

Моя структура выглядит довольно стандартной, я думаю:

src
 |- extenstion.ts
out
 |- extension.js
package.json

сейчас мой `extension.js 'ищет:

out
 |-src
    |- extension.ts

Я не знаю, почему и как решить эту проблему.Я думаю, что это должно потребовать только мои codediagnostic-server и codecompletion-server.

//@ts-check

'use strict';

const path = require('path');

/**@type {import('webpack').Configuration}*/
const config = {
    target: 'node', // vscode extensions run in a Node.js-context ? -> https://webpack.js.org/configuration/node/

    entry: './src/extension.ts', // the entry point of this extension, ? -> https://webpack.js.org/configuration/entry-context/
    output: {
        // the bundle is stored in the 'dist' folder (check package.json), ? -> https://webpack.js.org/configuration/output/
        path: path.resolve(__dirname, 'out'),
        filename: 'extension.js',
        libraryTarget: 'commonjs2',
        devtoolModuleFilenameTemplate: '../[resource-path]'
    },
    devtool: 'source-map',
    // externals: '@namespace',
    externals: [{
        vscode: 'commonjs vscode', // the vscode-module is created on-the-fly and must be excluded. Add other modules that cannot be webpack'ed, ? -> https://webpack.js.org/configuration/externals/
    },
    function (context, request, callback) {
        if (/@namespace\/codediagnostic-server/) {
            return callback(null, 'commonjs ' + request);
        }
        if (/@namespace\/codecompletion-server/) {
            return callback(null, 'commonjs ' + request);
        }
        callback(undefined, undefined);
    }],
    resolve: {
        // support reading TypeScript and JavaScript files, ? -> https://github.com/TypeStrong/ts-loader
        extensions: ['.ts', '.js']
    },
    module: {
        rules: [
            {
                test: /\.ts$/,
                exclude: /node_modules/,
                use: [
                    {
                        loader: 'ts-loader'
                    }
                ]
            }
        ]
    }
};
module.exports = config;
...