106 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			3.4 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
 | |
| 
 | |
|   # Create a formula from a tarball URL
 | |
|   def create
 | |
|     Homebrew::CLI::Parser.parse 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
 | |
|     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 "#{fc.name} is blacklisted for creation.\n#{reason}\nIf you really want to create this formula use --force."
 | |
|       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
 | 
