cocainate

command module
v1.0.20 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 23, 2023 License: GPL-3.0 Imports: 2 Imported by: 0

README

cocainate

Go Reference Test CodeQL Release Update Documentation

Description

cocainate is a cross-platform CLI utility for keeping the screen awake until stopped, or for a specified duration.

Why This Name?

The program's functionality and name are inspired by macOS's caffeinate utility that prevents the system from entering sleep mode.

This name is simply a stupid pun, therefore I do not condone and do not promote drug use, for more information: Wikipedia.

Installation

Arch Linux Distributions
yay -S cocainate-bin
paru -S cocainate-bin
macOS
brew install AppleGamer22/tap/cocainate
Windows (working progress)
winget install AppleGamer22.cocainate
Other
  • go:
    • Does not ship with:
      • a manual page
      • pre-built shell completion scripts
go install github.com/AppleGamer22/cocainate

Functionality

Root -d/--duration Flag

This is an optional flag that accepts a duration string (see Go's time.ParseDuration for more details). If this flag is not provided, the program will run until manually stopped.

Acceptable Time Units
  • nanoseconds: ns
  • microseconds: us or µs
  • milliseconds: ms
  • seconds: s
  • minutes: m
  • hours: h
Examples
  • 10 hours: -d 10h
  • 1 hour, 10 minutes and 10 seconds: -d 1h10m10s
  • 1 microsecond: -d 1us

If the -p flag is provided, the -d flag's value is used as process polling interval.

Root -p/--pid Flag

This is an optional flag that accepts a process ID (PID). If a valid PID is provided, the program will wait until that process is terminated. The delay between the termination of the provided process and the termination of screensaver inhibitation depends on the -d flag (which must be provided).

version Sub-command
-v/--verbose Flag
  • If this flag is provided, the following details are printed to the screen:
    1. semantic version number
    2. commit hash
    3. Go compiler version
    4. processor architecture & operating system
  • Otherwise, only the semantic version number is printed.

Dependencies

Linux

Common Contributor Routines

Testing

Running the following command will run go test on the commands and session sub-modules:

make test
Building From Source
Development
  • Using the following make command will save a cocainate binary with the last version tag and the latest git commit hash:
make debug
Release
  • Using the following GoReleaser command with a version git tag and a clean git state:
goreleaser build --rm-dist
  • All release artificats will stored in the dist child directory in the codebase's root directory:
    • compressed package archives with:
      • a cocainate binary
      • manual page
      • shell completion scripts
    • checksums
    • change log

cocainate is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version.

cocainate is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
utils

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL