Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: allow font install on linux #18874

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from
Draft

Conversation

SMillerDev
Copy link
Member

@SMillerDev SMillerDev commented Dec 4, 2024

  • Have you followed the guidelines in our Contributing document?
  • Have you checked to ensure there aren't other open Pull Requests for the same change?
  • Have you added an explanation of what your changes do and why you'd like us to include them?
  • Have you written new tests for your changes? Here's an example.
  • Have you successfully run brew style with your changes locally?
  • Have you successfully run brew typecheck with your changes locally?
  • Have you successfully run brew tests with your changes locally?

This should disable quarantine on Linux, allow installing fonts and set a location for the fonts. Marking this as draft until I've had a moment to test it.

Waiting for #18808 to be merged

@SMillerDev SMillerDev force-pushed the feat/cask/font_install branch 3 times, most recently from 801829e to e5c2c8c Compare December 5, 2024 08:11
@SMillerDev SMillerDev changed the title feat: only block cask install on Linux feat: allow font install on linux Dec 9, 2024
@SMillerDev SMillerDev force-pushed the feat/cask/font_install branch from e5c2c8c to d1b5f68 Compare December 14, 2024 14:30
@SMillerDev
Copy link
Member Author

Installing fonts now works, although it is still installing in the macOS location. I can't get the DEFAULTS to work.

@SMillerDev SMillerDev force-pushed the feat/cask/font_install branch 3 times, most recently from 99e0454 to ed30ba7 Compare December 14, 2024 15:14
@SMillerDev SMillerDev force-pushed the feat/cask/font_install branch from ed30ba7 to 378ff7c Compare December 21, 2024 16:45
}.freeze, T::Hash[Symbol, T.nilable(String)])

sig { returns(T::Hash[Symbol, T.untyped]) }
def self.defaults
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Homebrew/brew I can't get the code to pick up this extended version, no matter what I try. Does anyone have a suggestion how to do that?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dduugg may know!

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ugh, guilty 😬

prepending (like include) only affects instance methods. If I understand what you're trying to do here, you'll want to write this as an instance method in a submodule (e.g. ClassMethods) which is then prepended to the singleton class. See Keg for an example of this dual-prepend approach, specifically:

Keg.singleton_class.prepend(OS::Mac::Keg::ClassMethods)
Keg.prepend(OS::Mac::Keg)

(I'm entirely to blame for this convoluted mess, and I'm open to alternatives. It's probably useful to document this for others, maybe in Typechecking.md, though it has discoverability issues.)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That doesn't look all that bad, I wouldn't have guessed that this was type check related though, so I probably wouldn't have found it in the documentation.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've done this now, but it somehow doesn't get invoked when I run brew install --cask font-<something>. And I have no idea why.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To (hopefully) ask the obvious, you're running that command on Linux, correct?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, was running it in a codespace.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this will fix you up (I know it's confusing…): https://github.com/Homebrew/brew/pull/18874/files#r1909348690

@SMillerDev SMillerDev force-pushed the feat/cask/font_install branch 2 times, most recently from 198387f to 6e8fc52 Compare January 7, 2025 20:16
@SMillerDev SMillerDev force-pushed the feat/cask/font_install branch from 6e8fc52 to 75ac2b5 Compare January 7, 2025 20:36
}.freeze, T::Hash[Symbol, T.nilable(String)])

sig { returns(T::Hash[Symbol, T.untyped]) }
def self.defaults
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Needs to be an instance method for prepend to work:

Suggested change
def self.defaults
def defaults

(It will become a class method once prepended to the singleton class 🤷 🤕 )

end

Cask::Config.singleton_class.prepend(OS::Linux::Cask::Config::ClassMethods)
Cask::Config.prepend(OS::Linux::Cask::Config)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think this is necessary

Suggested change
Cask::Config.prepend(OS::Linux::Cask::Config)

Comment on lines +10 to +13
extend T::Helpers

requires_ancestor { ::Cask::Config }

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This shouldn't be necessary:

Suggested change
extend T::Helpers
requires_ancestor { ::Cask::Config }

Comment on lines +19 to +21
}.freeze, T::Hash[Symbol, T.nilable(String)])

sig { returns(T::Hash[Symbol, T.untyped]) }
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should be able to tighten up the types:

Suggested change
}.freeze, T::Hash[Symbol, T.nilable(String)])
sig { returns(T::Hash[Symbol, T.untyped]) }
}.freeze, T::Hash[Symbol, String])
sig { returns(T::Hash[Symbol, String]) }

# frozen_string_literal: true

require "extend/os/mac/cask/artifact/moved" if OS.mac?
require "extend/os/linux/cask/artifact/moved" if OS.linux?
Copy link
Member

@dduugg dduugg Jan 9, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not something to take on in this PR, but I wonder if we should have a single require file for all of an OS's extensions, rather than introduce three more require files here. 🤔

Comment on lines +13 to +15
def self.check_quarantine_support
:linux
end
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
def self.check_quarantine_support
:linux
end
def self.check_quarantine_support = :linux

@SMillerDev
Copy link
Member Author

Thanks for the pointers @dduugg !

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants