mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
116 lines
3.5 KiB
Ruby
116 lines
3.5 KiB
Ruby
#: * `create` <URL> [`--autotools`|`--cmake`|`--meson`] [`--no-fetch`] [`--set-name` <name>] [`--set-version` <version>] [`--tap` <user>`/`<repo>]:
|
|
#: Generate a formula for the downloadable file at <URL> and open it in the editor.
|
|
#: Homebrew will attempt to automatically derive the formula name
|
|
#: and version, but if it fails, you'll have to make your own template. The `wget`
|
|
#: formula serves as a simple example. For the complete API have a look at
|
|
#: <http://www.rubydoc.info/github/Homebrew/brew/master/Formula>.
|
|
#:
|
|
#: If `--autotools` is passed, create a basic template for an Autotools-style build.
|
|
#: If `--cmake` is passed, create a basic template for a CMake-style build.
|
|
#: If `--meson` is passed, create a basic template for a Meson-style build.
|
|
#:
|
|
#: If `--no-fetch` is passed, Homebrew will not download <URL> to the cache and
|
|
#: will thus not add the SHA256 to the formula for you. It will also not check
|
|
#: the GitHub API for GitHub projects (to fill out the description and homepage).
|
|
#:
|
|
#: The options `--set-name` and `--set-version` each take an argument and allow
|
|
#: you to explicitly set the name and version of the package you are creating.
|
|
#:
|
|
#: The option `--tap` takes a tap as its argument and generates the formula in
|
|
#: the specified tap.
|
|
|
|
require "formula"
|
|
require "formula_creator"
|
|
require "missing_formula"
|
|
require "cli_parser"
|
|
|
|
module Homebrew
|
|
module_function
|
|
|
|
def create_args
|
|
Homebrew::CLI::Parser.new do
|
|
switch "--autotools"
|
|
switch "--cmake"
|
|
switch "--meson"
|
|
switch "--no-fetch"
|
|
switch "--HEAD"
|
|
switch :force
|
|
switch :verbose
|
|
switch :debug
|
|
flag "--set-name="
|
|
flag "--set-version="
|
|
flag "--tap="
|
|
end
|
|
end
|
|
|
|
# Create a formula from a tarball URL
|
|
def create
|
|
create_args.parse
|
|
|
|
raise UsageError if ARGV.named.empty?
|
|
|
|
# Ensure that the cache exists so we can fetch the tarball
|
|
HOMEBREW_CACHE.mkpath
|
|
|
|
url = ARGV.named.first # Pull the first (and only) url from ARGV
|
|
|
|
version = args.set_version
|
|
name = args.set_name
|
|
tap = args.tap
|
|
|
|
fc = FormulaCreator.new
|
|
fc.name = name
|
|
fc.version = version
|
|
fc.tap = Tap.fetch(tap || "homebrew/core")
|
|
raise TapUnavailableError, tap unless fc.tap.installed?
|
|
|
|
fc.url = url
|
|
|
|
fc.mode = if args.cmake?
|
|
:cmake
|
|
elsif args.autotools?
|
|
:autotools
|
|
elsif args.meson?
|
|
:meson
|
|
end
|
|
|
|
if fc.name.nil? || fc.name.strip.empty?
|
|
stem = Pathname.new(url).stem
|
|
print "Formula name [#{stem}]: "
|
|
fc.name = __gets || stem
|
|
fc.update_path
|
|
end
|
|
|
|
# Don't allow blacklisted formula, or names that shadow aliases,
|
|
# unless --force is specified.
|
|
unless args.force?
|
|
if reason = MissingFormula.blacklisted_reason(fc.name)
|
|
raise <<~EOS
|
|
#{fc.name} is blacklisted for creation.
|
|
#{reason}
|
|
If you really want to create this formula use --force.
|
|
EOS
|
|
end
|
|
|
|
if Formula.aliases.include? fc.name
|
|
realname = Formulary.canonical_name(fc.name)
|
|
raise <<~EOS
|
|
The formula #{realname} is already aliased to #{fc.name}
|
|
Please check that you are not creating a duplicate.
|
|
To force creation use --force.
|
|
EOS
|
|
end
|
|
end
|
|
|
|
fc.generate!
|
|
|
|
puts "Please `brew audit --new-formula #{fc.name}` before submitting, thanks."
|
|
exec_editor fc.path
|
|
end
|
|
|
|
def __gets
|
|
gots = $stdin.gets.chomp
|
|
gots.empty? ? nil : gots
|
|
end
|
|
end
|