caveats: remove python caveats.
These instructions are currently incorrect and need to be ported to `python` 3.x and `python@2` formulae. Until then it's better to not have them than have them be incorrect. Closes #3890.
This commit is contained in:
		
							parent
							
								
									53a71a79b3
								
							
						
					
					
						commit
						36dadbee47
					
				@ -25,7 +25,6 @@ class Caveats
 | 
			
		||||
    caveats << function_completion_caveats(:zsh)
 | 
			
		||||
    caveats << function_completion_caveats(:fish)
 | 
			
		||||
    caveats << plist_caveats
 | 
			
		||||
    caveats << python_caveats
 | 
			
		||||
    caveats << elisp_caveats
 | 
			
		||||
    caveats.compact.join("\n")
 | 
			
		||||
  end
 | 
			
		||||
@ -108,53 +107,6 @@ class Caveats
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def python_caveats
 | 
			
		||||
    return unless keg
 | 
			
		||||
    return unless keg.python_site_packages_installed?
 | 
			
		||||
 | 
			
		||||
    s = nil
 | 
			
		||||
    homebrew_site_packages = Language::Python.homebrew_site_packages
 | 
			
		||||
    user_site_packages = Language::Python.user_site_packages "python"
 | 
			
		||||
    pth_file = user_site_packages/"homebrew.pth"
 | 
			
		||||
    instructions = <<~EOS.gsub(/^/, "  ")
 | 
			
		||||
      mkdir -p #{user_site_packages}
 | 
			
		||||
      echo 'import site; site.addsitedir("#{homebrew_site_packages}")' >> #{pth_file}
 | 
			
		||||
    EOS
 | 
			
		||||
 | 
			
		||||
    if f.keg_only?
 | 
			
		||||
      keg_site_packages = f.opt_prefix/"lib/python2.7/site-packages"
 | 
			
		||||
      unless Language::Python.in_sys_path?("python", keg_site_packages)
 | 
			
		||||
        s = <<~EOS
 | 
			
		||||
          If you need Python to find bindings for this keg-only formula, run:
 | 
			
		||||
            echo #{keg_site_packages} >> #{homebrew_site_packages/f.name}.pth
 | 
			
		||||
        EOS
 | 
			
		||||
        s += instructions unless Language::Python.reads_brewed_pth_files?("python")
 | 
			
		||||
      end
 | 
			
		||||
      return s
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    return if Language::Python.reads_brewed_pth_files?("python")
 | 
			
		||||
 | 
			
		||||
    if !Language::Python.in_sys_path?("python", homebrew_site_packages)
 | 
			
		||||
      s = <<~EOS
 | 
			
		||||
        Python modules have been installed and Homebrew's site-packages is not
 | 
			
		||||
        in your Python sys.path, so you will not be able to import the modules
 | 
			
		||||
        this formula installed. If you plan to develop with these modules,
 | 
			
		||||
        please run:
 | 
			
		||||
      EOS
 | 
			
		||||
      s += instructions
 | 
			
		||||
    elsif keg.python_pth_files_installed?
 | 
			
		||||
      s = <<~EOS
 | 
			
		||||
        This formula installed .pth files to Homebrew's site-packages and your
 | 
			
		||||
        Python isn't configured to process them, so you will not be able to
 | 
			
		||||
        import the modules this formula installed. If you plan to develop
 | 
			
		||||
        with these modules, please run:
 | 
			
		||||
      EOS
 | 
			
		||||
      s += instructions
 | 
			
		||||
    end
 | 
			
		||||
    s
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def elisp_caveats
 | 
			
		||||
    return if f.keg_only?
 | 
			
		||||
    return unless keg
 | 
			
		||||
 | 
			
		||||
@ -201,45 +201,5 @@ describe Caveats do
 | 
			
		||||
        expect(caveats).to include(HOMEBREW_PREFIX/"share/fish/vendor_completions.d")
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    context "python caveats" do
 | 
			
		||||
      before do
 | 
			
		||||
        (f.prefix.resolved_path/"lib/python2.7/site-packages").mkpath
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      context "when f is not keg_only" do
 | 
			
		||||
        let(:f) {
 | 
			
		||||
          formula do
 | 
			
		||||
            url "foo-1.0"
 | 
			
		||||
          end
 | 
			
		||||
        }
 | 
			
		||||
        let(:caveats) { described_class.new(f).caveats }
 | 
			
		||||
        let(:user_site_packages) { Language::Python.user_site_packages("python") }
 | 
			
		||||
 | 
			
		||||
        it "give commands to run when Homebrew's site-packages is not in Python sys.path" do
 | 
			
		||||
          expect(caveats).to include("Homebrew's site-packages is not\nin your Python sys.path")
 | 
			
		||||
          expect(caveats).to include(user_site_packages)
 | 
			
		||||
          expect(caveats).to include("import site")
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it "gives commands to run when python pth files are installed" do
 | 
			
		||||
          allow(Homebrew).to receive(:_system).and_return(true)
 | 
			
		||||
          allow(Dir).to receive(:[]).with(any_args).and_return(["blah.pth"])
 | 
			
		||||
          expect(caveats).to include(".pth files to Homebrew's site-packages and your\nPython isn't configured")
 | 
			
		||||
          expect(caveats).to include(user_site_packages)
 | 
			
		||||
          expect(caveats).to include("import site")
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it "gives commands to run when formula is keg_only" do
 | 
			
		||||
        f = formula do
 | 
			
		||||
          url "foo-1.0"
 | 
			
		||||
          keg_only "some reason"
 | 
			
		||||
        end
 | 
			
		||||
        caveats = described_class.new(f).caveats
 | 
			
		||||
        homebrew_site_packages = Language::Python.homebrew_site_packages
 | 
			
		||||
        expect(caveats).to include("echo #{f.opt_prefix}/lib/python2.7/site-packages >> #{homebrew_site_packages/f.name}.pth")
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user