mirror of
https://github.com/ghostty-org/ghostty.git
synced 2025-07-15 16:26:08 +03:00
Merge pull request #2275 from ghostty-org/sipointer
macos: show clickable mouse pointer when hovering over secure input
This commit is contained in:
10
.github/workflows/release-pr.yml
vendored
10
.github/workflows/release-pr.yml
vendored
@ -92,7 +92,10 @@ jobs:
|
|||||||
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
||||||
# Nix breaks xcodebuild so this has to be run outside.
|
# Nix breaks xcodebuild so this has to be run outside.
|
||||||
- name: Build Ghostty.app
|
- name: Build Ghostty.app
|
||||||
run: cd macos && xcodebuild -target Ghostty -configuration Release
|
run: |
|
||||||
|
cd macos
|
||||||
|
sudo xcode-select -s /Applications/Xcode_16.0.app
|
||||||
|
xcodebuild -target Ghostty -configuration Release
|
||||||
|
|
||||||
# We inject the "build number" as simply the number of commits since HEAD.
|
# We inject the "build number" as simply the number of commits since HEAD.
|
||||||
# This will be a monotonically always increasing build number that we use.
|
# This will be a monotonically always increasing build number that we use.
|
||||||
@ -240,7 +243,10 @@ jobs:
|
|||||||
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
||||||
# Nix breaks xcodebuild so this has to be run outside.
|
# Nix breaks xcodebuild so this has to be run outside.
|
||||||
- name: Build Ghostty.app
|
- name: Build Ghostty.app
|
||||||
run: cd macos && xcodebuild -target Ghostty -configuration Release
|
run: |
|
||||||
|
cd macos
|
||||||
|
sudo xcode-select -s /Applications/Xcode_16.0.app
|
||||||
|
xcodebuild -target Ghostty -configuration Release
|
||||||
|
|
||||||
# We inject the "build number" as simply the number of commits since HEAD.
|
# We inject the "build number" as simply the number of commits since HEAD.
|
||||||
# This will be a monotonically always increasing build number that we use.
|
# This will be a monotonically always increasing build number that we use.
|
||||||
|
15
.github/workflows/release-tip.yml
vendored
15
.github/workflows/release-tip.yml
vendored
@ -140,7 +140,10 @@ jobs:
|
|||||||
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
||||||
# Nix breaks xcodebuild so this has to be run outside.
|
# Nix breaks xcodebuild so this has to be run outside.
|
||||||
- name: Build Ghostty.app
|
- name: Build Ghostty.app
|
||||||
run: cd macos && xcodebuild -target Ghostty -configuration Release
|
run: |
|
||||||
|
cd macos
|
||||||
|
sudo xcode-select -s /Applications/Xcode_16.0.app
|
||||||
|
xcodebuild -target Ghostty -configuration Release
|
||||||
|
|
||||||
# We inject the "build number" as simply the number of commits since HEAD.
|
# We inject the "build number" as simply the number of commits since HEAD.
|
||||||
# This will be a monotonically always increasing build number that we use.
|
# This will be a monotonically always increasing build number that we use.
|
||||||
@ -321,7 +324,10 @@ jobs:
|
|||||||
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
||||||
# Nix breaks xcodebuild so this has to be run outside.
|
# Nix breaks xcodebuild so this has to be run outside.
|
||||||
- name: Build Ghostty.app
|
- name: Build Ghostty.app
|
||||||
run: cd macos && xcodebuild -target Ghostty -configuration Release
|
run: |
|
||||||
|
cd macos
|
||||||
|
sudo xcode-select -s /Applications/Xcode_16.0.app
|
||||||
|
xcodebuild -target Ghostty -configuration Release
|
||||||
|
|
||||||
# We inject the "build number" as simply the number of commits since HEAD.
|
# We inject the "build number" as simply the number of commits since HEAD.
|
||||||
# This will be a monotonically always increasing build number that we use.
|
# This will be a monotonically always increasing build number that we use.
|
||||||
@ -490,7 +496,10 @@ jobs:
|
|||||||
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
# codesigning. IMPORTANT: this must NOT run in a Nix environment.
|
||||||
# Nix breaks xcodebuild so this has to be run outside.
|
# Nix breaks xcodebuild so this has to be run outside.
|
||||||
- name: Build Ghostty.app
|
- name: Build Ghostty.app
|
||||||
run: cd macos && xcodebuild -target Ghostty -configuration Release
|
run: |
|
||||||
|
cd macos
|
||||||
|
sudo xcode-select -s /Applications/Xcode_16.0.app
|
||||||
|
xcodebuild -target Ghostty -configuration Release
|
||||||
|
|
||||||
# We inject the "build number" as simply the number of commits since HEAD.
|
# We inject the "build number" as simply the number of commits since HEAD.
|
||||||
# This will be a monotonically always increasing build number that we use.
|
# This will be a monotonically always increasing build number that we use.
|
||||||
|
3
.github/workflows/test.yml
vendored
3
.github/workflows/test.yml
vendored
@ -160,6 +160,9 @@ jobs:
|
|||||||
name: ghostty
|
name: ghostty
|
||||||
authToken: "${{ secrets.CACHIX_AUTH_TOKEN }}"
|
authToken: "${{ secrets.CACHIX_AUTH_TOKEN }}"
|
||||||
|
|
||||||
|
- name: XCode Select
|
||||||
|
run: sudo xcode-select -s /Applications/Xcode_16.0.app
|
||||||
|
|
||||||
# GhosttyKit is the framework that is built from Zig for our native
|
# GhosttyKit is the framework that is built from Zig for our native
|
||||||
# Mac app to access.
|
# Mac app to access.
|
||||||
- name: Build GhosttyKit
|
- name: Build GhosttyKit
|
||||||
|
@ -39,6 +39,7 @@ struct SecureInputOverlay: View {
|
|||||||
.onTapGesture {
|
.onTapGesture {
|
||||||
isPopover = true
|
isPopover = true
|
||||||
}
|
}
|
||||||
|
.backport.pointerStyle(.link)
|
||||||
.padding(.top, 10)
|
.padding(.top, 10)
|
||||||
.padding(.trailing, 10)
|
.padding(.trailing, 10)
|
||||||
.popover(isPresented: $isPopover, arrowEdge: .bottom) {
|
.popover(isPresented: $isPopover, arrowEdge: .bottom) {
|
||||||
|
@ -23,3 +23,28 @@ extension Backport where Content: Scene {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extension Backport where Content: View {
|
||||||
|
func pointerStyle(_ style: BackportPointerStyle) -> some View {
|
||||||
|
if #available(macOS 15, *) {
|
||||||
|
return content.pointerStyle(style.official)
|
||||||
|
} else {
|
||||||
|
return content
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
enum BackportPointerStyle {
|
||||||
|
case grabIdle
|
||||||
|
case grabActive
|
||||||
|
case link
|
||||||
|
|
||||||
|
@available(macOS 15, *)
|
||||||
|
var official: PointerStyle {
|
||||||
|
switch self {
|
||||||
|
case .grabIdle: return .grabIdle
|
||||||
|
case .grabActive: return .grabActive
|
||||||
|
case .link: return .link
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user