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
|
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
|
||||||
|
|
Loading…
Reference in a new issue