Skip to content

Latest commit

 

History

History
89 lines (65 loc) · 3.6 KB

README.md

File metadata and controls

89 lines (65 loc) · 3.6 KB

TimeCalc

A command-line calculator with support for performing operations on time

Written exclusively in Go

Overview

WARNING: Multiplication appears to be very broken in some instances. Also, order of operations via parenthesis is NOT functional beyond very basic grouping (see Usage).

Sometimes just being able to add numbers isn't enough. Often, you need to perform some calculation that involves a period of time. Doing so with a traditional calculator requires constantly transposing the time to and from a natural number that the calculator can handle. This can become extremely time consuming and even unreliable.

TimeCalc aims to solve this problem by providing a complete calculator interface exactly as you would expect, capable of addition, subtraction, multiplication, division, and even remainder operations, but with support for time. Time is formatted exactly as you might expect, right down to the millisecond – hour:minute:second.millisecond – and can be mixed in anywhere with any other calculations. Time takes precedence over a general number, ensuring that whenever a time is involved in an equation the output is always in time format.

Installation

Download the latest release for your operating system (be sure to download a binary file, not the source code). Open a command line where you saved the binary and run:

$ ./timecalc

TimeCalc can be installed globally by moving its executable to /usr/bin/ and locally by adding the executable to your PATH:

$ export PATH=$PATH:/path/to/timecalc

After re-opening the command line you can now simply run:

$ timecalc

From Source

Make sure you have a working Go environment. Go version 1.10 has been tested. See the install instructions for Go.

To install TimeCalc to your GOPATH, simply run:

$ go get github.com/octacian/timecalc

Make sure your PATH includes the $GOPATH/bin directory so your commands can be easily used:

export PATH=$PATH:$GOPATH/bin

Usage

TimeCalc utilizes a natural calculator syntax supporting negative and positive numbers and decimals, groups, and of course, time periods (warning: order of operations outside of basic groups is not yet complete). For example:

>>> 10 + (((7 * 81) - 42) / 20)
36.25
>> 10 + ((7 * 81) - 42) / 20
26.75 # Demonstrates lack of order of operations
>>> .5 - 1.7
-1.2
>>> ::30.5 * 3
00:01:31.5
>>> :30 % (8 * 1000 * 60)
00:06
>>> : + 1
00:00:00.001 # Ones place represents milliseconds, see below

Several shorthand structures are demonstrated above:

  • .5 –> 0.5
  • : –> 00:00:00.0
  • 1: –> 1:00:00.0
  • :10 –> 00:10:00.0
  • ::05 –> 00:00:05.0
  • ::.8 –> 00:00:00.8 (800 milliseconds)
  • :10:.2 –> 00:10:00.2 (10 minutes and 200 milliseconds)
  • etc...

Times are converted to and from numbers as a simple method of applying operations by way of transposing all fields to milliseconds. The max precision of a time is milliseconds, and as a result, when a number is converted to a time, the ones place represents a single millisecond.

You can also eval mode to disable the TimeCalc REPL interface and remove any text decorations for programmatic usecases. For example:

$ timecalc -e 10:22 - 5:28
04:54