diff options
| author | Mike McQuaid | 2017-06-30 15:14:32 +0100 |
|---|---|---|
| committer | GitHub | 2017-06-30 15:14:32 +0100 |
| commit | bfe4eed034487b2cc353e8f7b0107fbb00c974d7 (patch) | |
| tree | 10fc94b1337f46a4953ec907b6d173370e53b7f5 /Library/Homebrew/language | |
| parent | 202b3bc2c1f83b85cbe2cb3d8a5dd19a076d84b4 (diff) | |
| parent | 5e00c277ce45d6af497ec135faf54571c340e704 (diff) | |
| download | brew-bfe4eed034487b2cc353e8f7b0107fbb00c974d7.tar.bz2 | |
Merge pull request #2826 from chrmoritz/languagenode
language/node: multiple improvements
Diffstat (limited to 'Library/Homebrew/language')
| -rw-r--r-- | Library/Homebrew/language/node.rb | 31 |
1 files changed, 18 insertions, 13 deletions
diff --git a/Library/Homebrew/language/node.rb b/Library/Homebrew/language/node.rb index 01d41041b..eaadc54fc 100644 --- a/Library/Homebrew/language/node.rb +++ b/Library/Homebrew/language/node.rb @@ -1,7 +1,7 @@ module Language module Node def self.npm_cache_config - "cache=#{HOMEBREW_CACHE}/npm_cache\n" + "cache=#{HOMEBREW_CACHE}/npm_cache" end def self.pack_for_installation @@ -10,19 +10,18 @@ module Language # fed to `npm install` only symlinks are created linking back to that # directory, consequently breaking that assumption. We require a tarball # because npm install creates a "real" installation when fed a tarball. - output = Utils.popen_read("npm pack").chomp - raise "npm failed to pack #{Dir.pwd}" unless $CHILD_STATUS.exitstatus.zero? - output + pack_cmd = "npm pack --ignore-scripts" + output = Utils.popen_read(pack_cmd) + if !$CHILD_STATUS.exitstatus.zero? || output.lines.empty? + raise "npm failed to pack #{Dir.pwd}" + end + output.lines.last.chomp end def self.setup_npm_environment - npmrc = Pathname.new("#{ENV["HOME"]}/.npmrc") - # only run setup_npm_environment once per formula - return if npmrc.exist? - # explicitly set npm's cache path to HOMEBREW_CACHE/npm_cache to fix - # issues caused by overriding $HOME (long build times, high disk usage) - # https://github.com/Homebrew/brew/pull/37#issuecomment-208840366 - npmrc.write npm_cache_config + # guard that this is only run once + return if @env_set + @env_set = true # explicitly use our npm and node-gyp executables instead of the user # managed ones in HOMEBREW_PREFIX/lib/node_modules which might be broken begin @@ -42,8 +41,10 @@ module Language # npm install args for global style module format installed into libexec %W[ - --verbose + -ddd --global + --build-from-source + --#{npm_cache_config} --prefix=#{libexec} #{Dir.pwd}/#{pack} ] @@ -52,7 +53,11 @@ module Language def self.local_npm_install_args setup_npm_environment # npm install args for local style module format - ["--verbose"] + %W[ + -ddd + --build-from-source + --#{npm_cache_config} + ] end end end |
