Skip to content

🦬 cli utility to return macos window information for a given pid

Notifications You must be signed in to change notification settings

mikesmithgh/pdubs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pdubsbuffalo

🦬 pdubs

A simple command-line utility to return macos window information for a given pid.

macos: 11+ swift: 5.5+

If a given pid does not have an associated window, then it will check all of its ancestors. The window information for the first pid that is associated will be returned. The window information is a list in JSON format.

You may supply one optional parameter providing the pid. If no parameter is provided, then it will search for the current processes pid.

🤔 Motivation

I wanted an easy way to get the window ID of my current process so that I could take a screenshot from the command-line with screencapture.

screenshot example

win=$(./pdubs | jq .[0].kCGWindowNumber); screencapture -l"$win" pdubs.png

pdubs

📦 Installation

Download the binary for your system

curl --silent --fail --location --output pdubs.tar.gz https://github.com/mikesmithgh/pdubs/releases/latest/download/pdubs.tar.gz
curl --silent --fail --location --output pdubs.tar.gz.sha256 https://github.com/mikesmithgh/pdubs/releases/latest/download/pdubs.tar.gz.sha256
if shasum -c pdubs.tar.gz.sha256; then 
  tar -xvf pdubs.tar.gz 
else
  rm pdubs.tar.gz
fi

Move the binary pdubs to the desired location and place on your $PATH

For example,

mv pdubs ~/bin

👩‍💻 Usage examples

current process

./pdubs
[
  {
    "kCGWindowName" : "./pdubs",
    "kCGWindowStoreType" : 1,
    "kCGWindowOwnerName" : "kitty",
    "kCGWindowAlpha" : 1,
    "kCGWindowSharingState" : 1,
    "kCGWindowBounds" : {
      "X" : 3440,
      "Height" : 1055,
      "Y" : 385,
      "Width" : 1920
    },
    "kCGWindowIsOnscreen" : true,
    "kCGWindowOwnerPID" : 57175,
    "kCGWindowNumber" : 9382,
    "kCGWindowMemoryUsage" : 2288,
    "kCGWindowLayer" : 0
  },
  {
    "kCGWindowStoreType" : 1,
    "kCGWindowName" : "vi README.md ",
    "kCGWindowLayer" : 0,
    "kCGWindowOwnerName" : "kitty",
    "kCGWindowOwnerPID" : 57175,
    "kCGWindowMemoryUsage" : 2288,
    "kCGWindowNumber" : 9432,
    "kCGWindowSharingState" : 1,
    "kCGWindowIsOnscreen" : true,
    "kCGWindowAlpha" : 1,
    "kCGWindowBounds" : {
      "X" : 1720,
      "Height" : 1415,
      "Y" : 25,
      "Width" : 1720
    }
  }
]

target process

./pdubs 62556
[
  {
    "kCGWindowStoreType" : 1,
    "kCGWindowNumber" : 9422,
    "kCGWindowAlpha" : 1,
    "kCGWindowBounds" : {
      "X" : 0,
      "Height" : 1415,
      "Y" : 25,
      "Width" : 1720
    },
    "kCGWindowMemoryUsage" : 2288,
    "kCGWindowOwnerPID" : 62553,
    "kCGWindowLayer" : 0,
    "kCGWindowSharingState" : 1,
    "kCGWindowName" : "-bash",
    "kCGWindowIsOnscreen" : true,
    "kCGWindowOwnerName" : "iTerm2"
  }
]

🔨 Swift commands

debug build

swift build

release build

swift build -c release --arch arm64 --arch x86_64
cd .build/apple/Products/Release || exit 1
tar -czvf pdubs.tar.gz pdubs
shasum --algorithm 256 pdubs.tar.gz | tee pdubs.tar.gz.sha256

run

swift run

🍎 Supported OS versions

  • macOS 13 Ventura
  • macOS 12 Monterey
  • macOS 11 Big Sur

🕵️ Troubleshooting

Developer cannot be verified warning

"pdubs" cannot be opened because the developer cannot be verified.

If you receive the warning message while trying to execute pdubs, this is most likely because you manually downloaded the file from the release page. Depending on your download method, Apple will quarantine an app if it is not by an identified developer. I do not have an Apple developer account which is why you will see this warning.

Before removing the app from quarantine, please verify the checksum has not been changed with the shasum command. If this fails, then delete and download pdubs from the release page.

shasum -c pdubs.tar.gz.sha256

You can manually resolves the quarantine by control-clicking and opening the application from Finder or via the following command.

xattr -d com.apple.quarantine pdubs

See What should I do about com.apple.quarantine? for additional information.

About

🦬 cli utility to return macos window information for a given pid

Resources

Stars

Watchers

Forks

Languages