node@4: remove npm resource.
This commit is contained in:
parent
3f718e0da6
commit
951c679dc9
1 changed files with 8 additions and 66 deletions
|
@ -14,6 +14,7 @@ class NodeAT4 < Formula
|
|||
keg_only :versioned_formula
|
||||
|
||||
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-completion", "npm bash completion will not be installed"
|
||||
option "with-full-icu", "Build with full-icu (all locales) instead of small-icu (English only)"
|
||||
|
@ -36,7 +37,8 @@ class NodeAT4 < Formula
|
|||
end
|
||||
|
||||
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 << "--shared-openssl" if build.with? "openssl"
|
||||
|
||||
|
@ -51,73 +53,16 @@ class NodeAT4 < Formula
|
|||
|
||||
system "./configure", *args
|
||||
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
|
||||
|
||||
def caveats
|
||||
s = ""
|
||||
|
||||
if build.without? "npm"
|
||||
s += <<~EOS
|
||||
<<~EOS
|
||||
Homebrew has NOT installed npm. If you later install it, you should supplement
|
||||
your NODE_PATH with the npm module folder:
|
||||
#{HOMEBREW_PREFIX}/lib/node_modules
|
||||
EOS
|
||||
end
|
||||
|
||||
s
|
||||
end
|
||||
|
||||
test do
|
||||
|
@ -134,14 +79,11 @@ class NodeAT4 < Formula
|
|||
ENV.prepend_path "PATH", opt_bin
|
||||
ENV.delete "NVM_NODEJS_ORG_MIRROR"
|
||||
assert_equal which("node"), opt_bin/"node"
|
||||
assert_predicate HOMEBREW_PREFIX/"bin/npm", :exist?, "npm must exist"
|
||||
assert_predicate HOMEBREW_PREFIX/"bin/npm", :executable?, "npm must be executable"
|
||||
assert_predicate bin/"npm", :exist?, "npm must exist"
|
||||
assert_predicate bin/"npm", :executable?, "npm must be executable"
|
||||
npm_args = ["-ddd", "--cache=#{HOMEBREW_CACHE}/npm_cache", "--build-from-source"]
|
||||
system "#{HOMEBREW_PREFIX}/bin/npm", *npm_args, "install", "npm@latest"
|
||||
system "#{HOMEBREW_PREFIX}/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")
|
||||
system "#{bin}/npm", *npm_args, "install", "npm@latest"
|
||||
system "#{bin}/npm", *npm_args, "install", "bignum" unless head?
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue