diff options
author | Yamagishi Kazutoshi <ykzts@desire.sh> | 2017-06-18 09:57:09 +0900 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-06-18 02:57:09 +0200 |
commit | 53e42bf91ef2c705168f8d04b9374c349ec14074 (patch) | |
tree | 564d8607ee6fd7ac27979d157b261c038e9fad61 /bin/webpack-dev-server | |
parent | 94d0e012dea89058b9c059636fb6d42f6565e534 (diff) |
Upgrade Webpacker to version 2.0 (#3729)
Diffstat (limited to 'bin/webpack-dev-server')
-rwxr-xr-x | bin/webpack-dev-server | 30 |
1 files changed, 20 insertions, 10 deletions
diff --git a/bin/webpack-dev-server b/bin/webpack-dev-server index c2a61ff5e..a867f2c01 100755 --- a/bin/webpack-dev-server +++ b/bin/webpack-dev-server @@ -10,24 +10,34 @@ RAILS_ENV = ENV["RAILS_ENV"] ENV["NODE_ENV"] ||= RAILS_ENV NODE_ENV = ENV["NODE_ENV"] -APP_PATH = File.expand_path("../", __dir__) -CONFIG_PATH = File.join(APP_PATH, "config/webpack/paths.yml") +APP_PATH = File.expand_path("../", __dir__) +CONFIG_FILE = File.join(APP_PATH, "config/webpacker.yml") +NODE_MODULES_PATH = File.join(APP_PATH, "node_modules") +WEBPACK_CONFIG = File.join(APP_PATH, "config/webpack/development.js") + +def args(key) + index = ARGV.index(key) + index ? ARGV[index + 1] : nil +end begin - paths = YAML.load(File.read(CONFIG_PATH))[NODE_ENV] + dev_server = YAML.load_file(CONFIG_FILE)["development"]["dev_server"] - NODE_MODULES_PATH = File.join(APP_PATH.shellescape, paths["node_modules"]) - WEBPACK_CONFIG_PATH = File.join(APP_PATH.shellescape, paths["config"]) + DEV_SERVER_HOST = "http#{"s" if args('--https') || dev_server["https"]}://#{args('--host') || dev_server["host"]}:#{args('--port') || dev_server["port"]}" - WEBPACK_BIN = "#{NODE_MODULES_PATH}/.bin/webpack-dev-server" - DEV_SERVER_CONFIG = "#{WEBPACK_CONFIG_PATH}/development.server.js" rescue Errno::ENOENT, NoMethodError - puts "Configuration not found in config/webpacker/paths.yml." + puts "Webpack dev_server configuration not found in #{CONFIG_FILE}." puts "Please run bundle exec rails webpacker:install to install webpacker" exit! end +newenv = { + "NODE_PATH" => NODE_MODULES_PATH.shellescape, + "ASSET_HOST" => DEV_SERVER_HOST.shellescape +}.freeze + +cmdline = ["yarn", "run", "webpack-dev-server", "--", "--progress", "--color", "--config", WEBPACK_CONFIG] + ARGV + Dir.chdir(APP_PATH) do - exec "NODE_PATH=#{NODE_MODULES_PATH} #{WEBPACK_BIN} --progress --color " \ - "--config #{DEV_SERVER_CONFIG} #{ARGV.join(" ")}" + exec newenv, *cmdline end |