class NodeAT16 < Formula desc "Platform built on V8 to build network applications" homepage "https://nodejs.org/" url "https://nodejs.org/dist/v16.19.0/node-v16.19.0.tar.xz" sha256 "4f1fec1aea2392f6eb6d1d040b01e7ee3e51e762a9791dfea590920bc1156706" license "MIT" livecheck do url "https://nodejs.org/dist/" regex(%r{href=["']?v?(16(?:\.\d+)+)/?["' >]}i) end bottle do sha256 cellar: :any, arm64_ventura: "0e877b5e2c90bf72aae114f0befe0ebc0efd3735919377e228cd21e411a8a378" sha256 cellar: :any, arm64_monterey: "4ea748bf3d6c90f60ae04d823b363b82de3d05fa49cca4539d65597ff8b9be02" sha256 cellar: :any, arm64_big_sur: "48f60d8d4d7bb9743fa5107dda4ffdea575690ef2c98edb610bd8dbeab1bb27b" sha256 cellar: :any, ventura: "a3e0ddd531c81b9f76f9b0bdff1c065a6627625115e39e5fd8f872dfa9a1bf5d" sha256 cellar: :any, monterey: "6aaee79c3ce17469fce42c6e8fc793fa1c07f3daf831e9bb4120c93eb2734502" sha256 cellar: :any, big_sur: "4d61461224e2375eb07197d478dc8a933769ef934c90b6da8201de0d67d67997" sha256 cellar: :any_skip_relocation, x86_64_linux: "ec78b2537f296671435f0294b6d7e96b83181488feea11b207ab70fd4705b637" end keg_only :versioned_formula # https://nodejs.org/en/about/releases/ # disable! date: "2023-09-11", because: :unsupported depends_on "pkg-config" => :build depends_on "python@3.11" => :build depends_on "brotli" depends_on "c-ares" depends_on "icu4c" depends_on "libnghttp2" depends_on "libuv" depends_on "openssl@1.1" uses_from_macos "python", since: :catalina uses_from_macos "zlib" fails_with :clang do build 1099 cause "Node requires Xcode CLT 11+" end fails_with gcc: "5" def install python3 = "python3.11" # make sure subprocesses spawned by make are using our Python 3 ENV["PYTHON"] = which(python3) args = %W[ --prefix=#{prefix} --with-intl=system-icu --shared-libuv --shared-nghttp2 --shared-openssl --shared-zlib --shared-brotli --shared-cares --shared-libuv-includes=#{Formula["libuv"].include} --shared-libuv-libpath=#{Formula["libuv"].lib} --shared-nghttp2-includes=#{Formula["libnghttp2"].include} --shared-nghttp2-libpath=#{Formula["libnghttp2"].lib} --shared-openssl-includes=#{Formula["openssl@1.1"].include} --shared-openssl-libpath=#{Formula["openssl@1.1"].lib} --shared-brotli-includes=#{Formula["brotli"].include} --shared-brotli-libpath=#{Formula["brotli"].lib} --shared-cares-includes=#{Formula["c-ares"].include} --shared-cares-libpath=#{Formula["c-ares"].lib} --openssl-use-def-ca-store ] system python3, "configure.py", *args system "make", "install" end def post_install (lib/"node_modules/npm/npmrc").atomic_write("prefix = #{HOMEBREW_PREFIX}\n") end test do path = testpath/"test.js" path.write "console.log('hello');" output = shell_output("#{bin}/node #{path}").strip assert_equal "hello", output output = shell_output("#{bin}/node -e 'console.log(new Intl.NumberFormat(\"en-EN\").format(1234.56))'").strip assert_equal "1,234.56", output output = shell_output("#{bin}/node -e 'console.log(new Intl.NumberFormat(\"de-DE\").format(1234.56))'").strip assert_equal "1.234,56", output # make sure npm can find node ENV.prepend_path "PATH", opt_bin ENV.delete "NVM_NODEJS_ORG_MIRROR" assert_equal which("node"), opt_bin/"node" 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 "#{bin}/npm", *npm_args, "install", "npm@latest" system "#{bin}/npm", *npm_args, "install", "ref-napi" assert_predicate bin/"npx", :exist?, "npx must exist" assert_predicate bin/"npx", :executable?, "npx must be executable" assert_match "< hello >", shell_output("#{bin}/npx --yes cowsay hello") end end