node@4: remove npm resource.

This commit is contained in:
Mike McQuaid 2018-02-21 09:24:15 +00:00
parent 3f718e0da6
commit 951c679dc9

View file

@ -14,6 +14,7 @@ class NodeAT4 < Formula
keg_only :versioned_formula keg_only :versioned_formula
option "with-debug", "Build with debugger hooks" option "with-debug", "Build with debugger hooks"
option "with-openssl", "Build against Homebrew's OpenSSL instead of the bundled OpenSSL"
option "without-npm", "npm will not be installed" option "without-npm", "npm will not be installed"
option "without-completion", "npm bash completion will not be installed" option "without-completion", "npm bash completion will not be installed"
option "with-full-icu", "Build with full-icu (all locales) instead of small-icu (English only)" option "with-full-icu", "Build with full-icu (all locales) instead of small-icu (English only)"
@ -36,7 +37,8 @@ class NodeAT4 < Formula
end end
def install def install
args = %W[--prefix=#{prefix} --without-npm] args = ["--prefix=#{prefix}"]
args << "--without-npm" if build.without? "npm"
args << "--debug" if build.with? "debug" args << "--debug" if build.with? "debug"
args << "--shared-openssl" if build.with? "openssl" args << "--shared-openssl" if build.with? "openssl"
@ -51,73 +53,16 @@ class NodeAT4 < Formula
system "./configure", *args system "./configure", *args
system "make", "install" system "make", "install"
if build.with? "npm"
# Allow npm to find Node before installation has completed.
ENV.prepend_path "PATH", bin
bootstrap = buildpath/"npm_bootstrap"
bootstrap.install resource("npm")
system "node", bootstrap/"bin/npm-cli.js", "install", "-ddd", "--global",
"--prefix=#{libexec}", resource("npm").cached_download
# The `package.json` stores integrity information about the above passed
# in `cached_download` npm resource, which breaks `npm -g outdated npm`.
# This copies back over the vanilla `package.json` to fix this issue.
cp bootstrap/"package.json", libexec/"lib/node_modules/npm"
# These symlinks are never used & they've caused issues in the past.
rm_rf libexec/"share"
if build.with? "completion"
bash_completion.install \
bootstrap/"lib/utils/completion.sh" => "npm"
end
end
end
def post_install
return if build.without? "npm"
node_modules = HOMEBREW_PREFIX/"lib/node_modules"
node_modules.mkpath
# Kill npm but preserve all other modules across node updates/upgrades.
rm_rf node_modules/"npm"
cp_r libexec/"lib/node_modules/npm", node_modules
# This symlink doesn't hop into homebrew_prefix/bin automatically so
# we make our own. This is a small consequence of our
# bottle-npm-and-retain-a-private-copy-in-libexec setup
# All other installs **do** symlink to homebrew_prefix/bin correctly.
# We ln rather than cp this because doing so mimics npm's normal install.
ln_sf node_modules/"npm/bin/npm-cli.js", HOMEBREW_PREFIX/"bin/npm"
ln_sf node_modules/"npm/bin/npx-cli.js", HOMEBREW_PREFIX/"bin/npx"
# Let's do the manpage dance. It's just a jump to the left.
# And then a step to the right, with your hand on rm_f.
%w[man1 man5 man7].each do |man|
# Dirs must exist first: https://github.com/Homebrew/legacy-homebrew/issues/35969
mkdir_p HOMEBREW_PREFIX/"share/man/#{man}"
rm_f Dir[HOMEBREW_PREFIX/"share/man/#{man}/{npm.,npm-,npmrc.,package.json.,npx.}*"]
cp Dir[libexec/"lib/node_modules/npm/man/#{man}/{npm,package.json,npx}*"], HOMEBREW_PREFIX/"share/man/#{man}"
end
npm_root = node_modules/"npm"
npmrc = npm_root/"npmrc"
npmrc.atomic_write("prefix = #{HOMEBREW_PREFIX}\n")
end end
def caveats def caveats
s = ""
if build.without? "npm" if build.without? "npm"
s += <<~EOS <<~EOS
Homebrew has NOT installed npm. If you later install it, you should supplement Homebrew has NOT installed npm. If you later install it, you should supplement
your NODE_PATH with the npm module folder: your NODE_PATH with the npm module folder:
#{HOMEBREW_PREFIX}/lib/node_modules #{HOMEBREW_PREFIX}/lib/node_modules
EOS EOS
end end
s
end end
test do test do
@ -134,14 +79,11 @@ class NodeAT4 < Formula
ENV.prepend_path "PATH", opt_bin ENV.prepend_path "PATH", opt_bin
ENV.delete "NVM_NODEJS_ORG_MIRROR" ENV.delete "NVM_NODEJS_ORG_MIRROR"
assert_equal which("node"), opt_bin/"node" assert_equal which("node"), opt_bin/"node"
assert_predicate HOMEBREW_PREFIX/"bin/npm", :exist?, "npm must exist" assert_predicate bin/"npm", :exist?, "npm must exist"
assert_predicate HOMEBREW_PREFIX/"bin/npm", :executable?, "npm must be executable" assert_predicate bin/"npm", :executable?, "npm must be executable"
npm_args = ["-ddd", "--cache=#{HOMEBREW_CACHE}/npm_cache", "--build-from-source"] npm_args = ["-ddd", "--cache=#{HOMEBREW_CACHE}/npm_cache", "--build-from-source"]
system "#{HOMEBREW_PREFIX}/bin/npm", *npm_args, "install", "npm@latest" system "#{bin}/npm", *npm_args, "install", "npm@latest"
system "#{HOMEBREW_PREFIX}/bin/npm", *npm_args, "install", "bignum" unless head? system "#{bin}/npm", *npm_args, "install", "bignum" unless head?
assert_predicate HOMEBREW_PREFIX/"bin/npx", :exist?, "npx must exist"
assert_predicate HOMEBREW_PREFIX/"bin/npx", :executable?, "npx must be executable"
assert_match "< hello >", shell_output("#{HOMEBREW_PREFIX}/bin/npx cowsay hello")
end end
end end
end end