aboutsummaryrefslogtreecommitdiffstats
BranchCommit messageAuthorAge
g3_v1_0feat(Angular.js): add externs file for Closure CompilerMartin Probst12 years
g3_v1_2fix(input): don't perform HTML5 validation on updated model-valueCaitlin Potter12 years
g3_v1_3fix(input): don't perform HTML5 validation on updated model-valueCaitlin Potter12 years
masterdocs(guides/directive): add (') to contractionLuke Eller12 years
nganimate-docs-at-symbol-HTML-entity-to-characterdocs(ngAnimate): change "&#64" to "@" symbolTeddy Wing12 years
v0.9.xfix(e2e): add index-nocache.html to run e2e tests without cacheIgor Minar14 years
v1.0.xrefactor(externs): move Closure Externs back to Closure code repositoryMartin Probst12 years
v1.2.xfix(filter.ngdoc): Check if "input" variable is definedRenat Yakubov12 years
 
TagDownloadAuthorAge
v1.2.15angular.js-1.2.15.tar.bz2  jenkins12 years
v1.3.0-beta.3angular.js-1.3.0-beta.3.tar.bz2  jenkins12 years
v1.3.0-beta.2angular.js-1.3.0-beta.2.tar.bz2  jenkins12 years
v1.3.0-beta.1angular.js-1.3.0-beta.1.tar.bz2  jenkins12 years
v1.2.14angular.js-1.2.14.tar.bz2  jenkins12 years
v1.2.13angular.js-1.2.13.tar.bz2  jenkins12 years
v1.2.12angular.js-1.2.12.tar.bz2  jenkins12 years
v1.2.11angular.js-1.2.11.tar.bz2  jenkins12 years
v1.2.10angular.js-1.2.10.tar.bz2  jenkins12 years
v1.2.9angular.js-1.2.9.tar.bz2  jenkins12 years
v1.2.8angular.js-1.2.8.tar.bz2  jenkins12 years
v1.2.7angular.js-1.2.7.tar.bz2  chimney-sweeper12 years
v1.2.6angular.js-1.2.6.tar.bz2  chimney-sweeper12 years
v1.2.5angular.js-1.2.5.tar.bz2  Jeff Cross12 years
v1.2.4angular.js-1.2.4.tar.bz2  Matias Niemelä12 years
v1.2.3angular.js-1.2.3.tar.bz2  Peter Bacon Darwin12 years
v1.2.2angular.js-1.2.2.tar.bz2  Igor Minar12 years
v1.2.1angular.js-1.2.1.tar.bz2  Vojta Jina12 years
v1.2.0angular.js-1.2.0.tar.bz2  Igor Minar12 years
v1.2.0-rc.3angular.js-1.2.0-rc.3.tar.bz2  Igor Minar12 years
v1.2.0-rc.2angular.js-1.2.0-rc.2.tar.bz2  Igor Minar12 years
v1.0.8angular.js-1.0.8.tar.bz2  Igor Minar12 years
v1.2.0rc1angular.js-1.2.0rc1.tar.bz2  Igor Minar12 years
v1.0.7angular.js-1.0.7.tar.bz2  Igor Minar12 years
v1.1.5angular.js-1.1.5.tar.bz2  Igor Minar12 years
v1.0.6angular.js-1.0.6.tar.bz2  Igor Minar13 years
v1.1.4angular.js-1.1.4.tar.bz2  Igor Minar13 years
v1.0.5angular.js-1.0.5.tar.bz2  Igor Minar13 years
v1.1.3angular.js-1.1.3.tar.bz2  Igor Minar13 years
v1.0.4angular.js-1.0.4.tar.bz2  Igor Minar13 years
v1.1.2angular.js-1.1.2.tar.bz2  Igor Minar13 years
v1.1.1angular.js-1.1.1.tar.bz2  Igor Minar13 years
v1.0.3angular.js-1.0.3.tar.bz2  Igor Minar13 years
v1.1.0angular.js-1.1.0.tar.bz2  Igor Minar13 years
v1.0.2angular.js-1.0.2.tar.bz2  Igor Minar13 years
v1.0.1angular.js-1.0.1.tar.bz2  Igor Minar13 years
v1.0.0angular.js-1.0.0.tar.bz2  Igor Minar13 years
v1.0.0rc12angular.js-1.0.0rc12.tar.bz2  Igor Minar13 years
v1.0.0rc11angular.js-1.0.0rc11.tar.bz2  Igor Minar13 years
v1.0.0rc10angular.js-1.0.0rc10.tar.bz2  Igor Minar13 years
v1.0.0rc9angular.js-1.0.0rc9.tar.bz2  Igor Minar13 years
v1.0.0rc8angular.js-1.0.0rc8.tar.bz2  Igor Minar14 years
v1.0.0rc7angular.js-1.0.0rc7.tar.bz2  Igor Minar14 years
v1.0.0rc6angular.js-1.0.0rc6.tar.bz2  Igor Minar14 years
v1.0.0rc5angular.js-1.0.0rc5.tar.bz2  Igor Minar14 years
v1.0.0rc4angular.js-1.0.0rc4.tar.bz2  Igor Minar14 years
v1.0.0rc3angular.js-1.0.0rc3.tar.bz2  Igor Minar14 years
v1.0.0rc2angular.js-1.0.0rc2.tar.bz2  Igor Minar14 years
g3-v1.0.0-rc2angular.js-g3-v1.0.0-rc2.tar.bz2  Vojta Jina14 years
g3-v1.0.0rc1angular.js-g3-v1.0.0rc1.tar.bz2  Vojta Jina14 years
v1.0.0rc1angular.js-1.0.0rc1.tar.bz2  Igor Minar14 years
v0.10.6angular.js-0.10.6.tar.bz2  Igor Minar14 years
v0.10.5angular.js-0.10.5.tar.bz2  Igor Minar14 years
v0.10.4angular.js-0.10.4.tar.bz2  Igor Minar14 years
v0.10.3angular.js-0.10.3.tar.bz2  Igor Minar14 years
v0.10.2angular.js-0.10.2.tar.bz2  Igor Minar14 years
v0.10.1angular.js-0.10.1.tar.bz2  Igor Minar14 years
v0.10.0angular.js-0.10.0.tar.bz2  Igor Minar14 years
v0.9.19angular.js-0.9.19.tar.bz2  Igor Minar14 years
v0.9.18angular.js-0.9.18.tar.bz2  Igor Minar14 years
v0.9.17angular.js-0.9.17.tar.bz2  Igor Minar14 years
v0.9.16angular.js-0.9.16.tar.bz2  Igor Minar14 years
v0.9.15angular.js-0.9.15.tar.bz2  Igor Minar15 years
v0.9.14angular.js-0.9.14.tar.bz2  Igor Minar15 years
v0.9.13angular.js-0.9.13.tar.bz2  Igor Minar15 years
v0.9.12angular.js-0.9.12.tar.bz2  Igor Minar15 years
v0.9.11angular.js-0.9.11.tar.bz2  Igor Minar15 years
v0.9.10angular.js-0.9.10.tar.bz2  Igor Minar15 years
v0.9.9angular.js-0.9.9.tar.bz2  Igor Minar15 years
v0.9.7angular.js-0.9.7.tar.bz2  Igor Minar15 years
v0.9.6angular.js-0.9.6.tar.bz2  Igor Minar15 years
v0.9.5angular.js-0.9.5.tar.bz2  Igor Minar15 years
v0.9.4angular.js-0.9.4.tar.bz2  Igor Minar15 years
v0.9.3angular.js-0.9.3.tar.bz2  Igor Minar15 years
v0.9.2angular.js-0.9.2.tar.bz2  Igor Minar15 years
v0.9.1angular.js-0.9.1.tar.bz2  Igor Minar15 years
v0.9.0angular.js-0.9.0.tar.bz2  Igor Minar15 years
class="n">e.message [] end def check_for_duplicate_pull_requests(formula) pull_requests = fetch_pull_requests(formula) return unless pull_requests return if pull_requests.empty? duplicates_message = <<~EOS These open pull requests may be duplicates: #{pull_requests.map { |pr| "#{pr["title"]} #{pr["html_url"]}" }.join("\n")} EOS error_message = "Duplicate PRs should not be opened. Use --force to override this error." if ARGV.force? && !ARGV.flag?("--quiet") opoo duplicates_message elsif !ARGV.force? && ARGV.flag?("--quiet") odie error_message elsif !ARGV.force? odie <<~EOS #{duplicates_message.chomp} #{error_message} EOS end end def bump_formula_pr # As this command is simplifying user run commands then let's just use a # user path, too. ENV["PATH"] = ENV["HOMEBREW_PATH"] # Use the user's browser, too. ENV["BROWSER"] = ENV["HOMEBREW_BROWSER"] # Setup GitHub environment variables %w[GITHUB_USER GITHUB_PASSWORD GITHUB_TOKEN].each do |env| homebrew_env = ENV["HOMEBREW_#{env}"] next unless homebrew_env next if homebrew_env.empty? ENV[env] = homebrew_env end formula = ARGV.formulae.first if formula check_for_duplicate_pull_requests(formula) checked_for_duplicates = true end new_url = ARGV.value("url") if new_url && !formula # Split the new URL on / and find any formulae that have the same URL # except for the last component, but don't try to match any more than the # first five components since sometimes the last component isn't the only # one to change. new_url_split = new_url.split("/") maximum_url_components_to_match = 5 components_to_match = [new_url_split.count - 1, maximum_url_components_to_match].min base_url = new_url_split.first(components_to_match).join("/") base_url = /#{Regexp.escape(base_url)}/ is_devel = ARGV.include?("--devel") guesses = [] Formula.each do |f| if is_devel && f.devel && f.devel.url && f.devel.url.match(base_url) guesses << f elsif f.stable&.url && f.stable.url.match(base_url) guesses << f end end if guesses.count == 1 formula = guesses.shift elsif guesses.count > 1 odie "Couldn't guess formula for sure: could be one of these:\n#{guesses}" end end odie "No formula found!" unless formula check_for_duplicate_pull_requests(formula) unless checked_for_duplicates requested_spec, formula_spec = if ARGV.include?("--devel") devel_message = " (devel)" [:devel, formula.devel] else [:stable, formula.stable] end odie "#{formula}: no #{requested_spec} specification found!" unless formula_spec hash_type, old_hash = if (checksum = formula_spec.checksum) [checksum.hash_type.to_s, checksum.hexdigest] end new_hash = ARGV.value(hash_type) new_tag = ARGV.value("tag") new_revision = ARGV.value("revision") new_mirror = ARGV.value("mirror") forced_version = ARGV.value("version") new_url_hash = if new_url && new_hash true elsif new_tag && new_revision false elsif !hash_type odie "#{formula}: no --tag=/--revision= arguments specified!" elsif !new_url odie "#{formula}: no --url= argument specified!" else new_mirror = case new_url when requested_spec != :devel && %r{.*ftp.gnu.org/gnu.*} new_url.sub "ftp.gnu.org/gnu", "ftpmirror.gnu.org" when %r{.*mirrors.ocf.berkeley.edu/debian.*} new_url.sub "mirrors.ocf.berkeley.edu/debian", "mirrorservice.org/sites/ftp.debian.org/debian" end resource = Resource.new { @url = new_url } resource.download_strategy = DownloadStrategyDetector.detect_from_url(new_url) resource.owner = Resource.new(formula.name) resource.version = forced_version if forced_version odie "No --version= argument specified!" unless resource.version resource_path = resource.fetch tar_file_extensions = %w[.tar .tb2 .tbz .tbz2 .tgz .tlz .txz .tZ] if tar_file_extensions.any? { |extension| new_url.include? extension } gnu_tar_gtar_path = HOMEBREW_PREFIX/"opt/gnu-tar/bin/gtar" gnu_tar_gtar = gnu_tar_gtar_path if gnu_tar_gtar_path.executable? tar = which("gtar") || gnu_tar_gtar || which("tar") if Utils.popen_read(tar, "-tf", resource_path) =~ %r{/.*\.} new_hash = resource_path.sha256 else odie "#{resource_path} is not a valid tar file!" end else new_hash = resource_path.sha256 end end if ARGV.dry_run? ohai "brew update" else safe_system "brew", "update" end old_formula_version = formula_version(formula, requested_spec) replacement_pairs = [] if requested_spec == :stable && formula.revision.nonzero? replacement_pairs << [/^ revision \d+\n(\n( head "))?/m, "\\2"] end replacement_pairs += formula_spec.mirrors.map do |mirror| [/ +mirror \"#{Regexp.escape(mirror)}\"\n/m, ""] end replacement_pairs += if new_url_hash [ [/#{Regexp.escape(formula_spec.url)}/, new_url], [old_hash, new_hash], ] else [ [formula_spec.specs[:tag], new_tag], [formula_spec.specs[:revision], new_revision], ] end backup_file = File.read(formula.path) unless ARGV.dry_run? if new_mirror replacement_pairs << [/^( +)(url \"#{Regexp.escape(new_url)}\"\n)/m, "\\1\\2\\1mirror \"#{new_mirror}\"\n"] end if forced_version && forced_version != "0" if requested_spec == :stable if File.read(formula.path).include?("version \"#{old_formula_version}\"") replacement_pairs << [old_formula_version.to_s, forced_version] elsif new_mirror replacement_pairs << [/^( +)(mirror \"#{new_mirror}\"\n)/m, "\\1\\2\\1version \"#{forced_version}\"\n"] else replacement_pairs << [/^( +)(url \"#{new_url}\"\n)/m, "\\1\\2\\1version \"#{forced_version}\"\n"] end elsif requested_spec == :devel replacement_pairs << [/( devel do.+?version \")#{old_formula_version}(\"\n.+?end\n)/m, "\\1#{forced_version}\\2"] end elsif forced_version && forced_version == "0" if requested_spec == :stable replacement_pairs << [/^ version \"[\w\.\-\+]+\"\n/m, ""] elsif requested_spec == :devel replacement_pairs << [/( devel do.+?)^ +version \"[^\n]+\"\n(.+?end\n)/m, "\\1\\2"] end end new_contents = inreplace_pairs(formula.path, replacement_pairs) new_formula_version = formula_version(formula, requested_spec, new_contents) if new_formula_version < old_formula_version formula.path.atomic_write(backup_file) unless ARGV.dry_run? odie <<~EOS You probably need to bump this formula manually since changing the version from #{old_formula_version} to #{new_formula_version} would be a downgrade. EOS elsif new_formula_version == old_formula_version formula.path.atomic_write(backup_file) unless ARGV.dry_run? odie <<~EOS You probably need to bump this formula manually since the new version and old version are both #{new_formula_version}. EOS end if ARGV.dry_run? if ARGV.include? "--strict" ohai "brew audit --strict #{formula.path.basename}" elsif ARGV.include? "--audit" ohai "brew audit #{formula.path.basename}" end else failed_audit = false if ARGV.include? "--strict" system HOMEBREW_BREW_FILE, "audit", "--strict", formula.path failed_audit = !$CHILD_STATUS.success? elsif ARGV.include? "--audit" system HOMEBREW_BREW_FILE, "audit", formula.path failed_audit = !$CHILD_STATUS.success? end if failed_audit formula.path.atomic_write(backup_file) odie "brew audit failed!" end end unless Formula["hub"].any_version_installed? if ARGV.dry_run? ohai "brew install hub" else safe_system "brew", "install", "hub" end end formula.path.parent.cd do branch = "#{formula.name}-#{new_formula_version}" git_dir = Utils.popen_read("git rev-parse --git-dir").chomp shallow = !git_dir.empty? && File.exist?("#{git_dir}/shallow") hub_args = [] git_final_checkout_args = [] if ARGV.include?("--no-browse") git_final_checkout_args << "--quiet" else hub_args << "--browse" end if ARGV.dry_run? ohai "hub fork # read $HUB_REMOTE" ohai "git fetch --unshallow origin" if shallow ohai "git checkout --no-track -b #{branch} origin/master" ohai "git commit --no-edit --verbose --message='#{formula.name} #{new_formula_version}#{devel_message}' -- #{formula.path}" ohai "git push --set-upstream $HUB_REMOTE #{branch}:#{branch}" ohai "hub pull-request #{hub_args.join(" ")} -m '#{formula.name} #{new_formula_version}#{devel_message}'" ohai "git checkout -" else reply = IO.popen(["hub", "fork"], "r+", err: "/dev/null") do |io| reader = Thread.new { io.read } sleep 1 io.close_write reader.value end if reply.to_s.include? "username:" formula.path.atomic_write(backup_file) unless ARGV.dry_run? git_path = "$(brew --repo #{formula.tap})" if formula.tap git_path ||= formula.path.parent odie <<~EOS Retry after configuring hub by running: hub -C "#{git_path}" fork Or setting HOMEBREW_GITHUB_TOKEN with at least 'public_repo' scope. EOS end remote = reply[/remote:? (\S+)/, 1] # repeat for hub 2.2 backwards compatibility: remote = Utils.popen_read("hub", "fork", err: :out)[/remote:? (\S+)/, 1] if remote.to_s.empty? if remote.to_s.empty? formula.path.atomic_write(backup_file) unless ARGV.dry_run? odie "cannot get remote from 'hub'!" end safe_system "git", "fetch", "--unshallow", "origin" if shallow safe_system "git", "checkout", "--no-track", "-b", branch, "origin/master" safe_system "git", "commit", "--no-edit", "--verbose", "--message=#{formula.name} #{new_formula_version}#{devel_message}", "--", formula.path safe_system "git", "push", "--set-upstream", remote, "#{branch}:#{branch}" pr_message = <<~EOS #{formula.name} #{new_formula_version}#{devel_message} Created with `brew bump-formula-pr`. EOS user_message = ARGV.value("message") if user_message pr_message += "\n" + <<~EOS --- #{user_message} EOS end safe_system "hub", "pull-request", *hub_args, "-m", pr_message safe_system "git", "checkout", *git_final_checkout_args, "-" end end end end