# README
Neo Cowsay
Neo Cowsay is written in Go. This cowsay is extended the original cowsay. added fun more options, and you can be used as a library.
for GitHub Actions users: Code-Hex/neo-cowsay-action
______________
< I'm Neo cows >
--------------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
About cowsay
According to the original original manual.
cowsay is a configurable talking cow, written in Perl. It operates
much as the figlet program does, and it written in the same spirit
of silliness.
This is also supported COWPATH
env. Please read more details in #33 if you want to use this.
What makes it different from the original?
- fast
- utf8 is supported
- new some cowfiles is added
- cowfiles in binary
- random pickup cowfile option
- provides command-line fuzzy finder to search any cows with
-f -
#39 - coloring filter options
- super mode
Movies for new options 🐮
Random
Rainbow and Aurora, Bold
And, Super Cows mode
https://user-images.githubusercontent.com/6500104/140379043-53e44994-b1b0-442e-bda7-4f7ab3aedf01.mov
Usage
As command
cow{say,think} version 2.0.0, (c) 2021 codehex
Usage: cowsay [-bdgpstwy] [-h] [-e eyes] [-f cowfile] [--random]
[-l] [-n] [-T tongue] [-W wrapcolumn]
[--bold] [--rainbow] [--aurora] [--super] [message]
Original Author: (c) 1999 Tony Monroe
Repository: https://github.com/Code-Hex/Neo-cowsay
Normal
$ cowsay Hello
_______
< Hello >
-------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
Borg mode
$ cowsay -b Hello
_______
< Hello >
-------
\ ^__^
\ (==)\_______
(__)\ )\/\
||----w |
|| ||
As library
package main
import (
"fmt"
cowsay "github.com/Code-Hex/Neo-cowsay/v2"
)
func main() {
say, err := cowsay.Say(
"Hello",
cowsay.Type("default"),
cowsay.BallonWidth(40),
)
if err != nil {
panic(err)
}
fmt.Println(say)
}
Install
Mac and Linux users via Homebrew
$ brew update
$ brew install Code-Hex/tap/neo-cowsay
Binary
You can download from here
library
$ go get github.com/Code-Hex/Neo-cowsay/v2
Go
cowsay
$ go install github.com/Code-Hex/Neo-cowsay/cmd/v2/cowsay@latest
cowthink
$ go install github.com/Code-Hex/Neo-cowsay/cmd/v2/cowthink@latest
License
cowsay license
==============
cowsay License
==============
cowsay is distributed under the same licensing terms as Perl: the
Artistic License or the GNU General Public License. If you don't
want to track down these licenses and read them for yourself, use
the parts that I'd prefer:
(0) I wrote it and you didn't.
(1) Give credit where credit is due if you borrow the code for some
other purpose.
(2) If you have any bugfixes or suggestions, please notify me so
that I may incorporate them.
(3) If you try to make money off of cowsay, you suck.
===============
cowsay Legalese
===============
(0) Copyright (c) 1999 Tony Monroe. All rights reserved. All
lefts may or may not be reversed at my discretion.
(1) This software package can be freely redistributed or modified
under the terms described above in the "cowsay License" section
of this file.
(2) cowsay is provided "as is," with no warranties whatsoever,
expressed or implied. If you want some implied warranty about
merchantability and/or fitness for a particular purpose, you will
not find it here, because there is no such thing here.
(3) I hate legalese.
(The Artistic License or The GNU General Public License)
Author
Neo Cowsay: codehex
Original: (c) 1999 Tony Monroe
# Packages
No description provided by the author
# Functions
Asset loads and returns the asset for the given name.
AssetNames returns the list of filename of the assets.
BallonWidth specifies ballon size.
Cows to get list of cows.
CowsInBinary returns the list of cowfiles which are in binary.
DisableWordWrap disables word wrap.
Eyes specifies eyes The specified string will always be adjusted to be equal to two characters.
New returns pointer of Cow struct that made by options.
Random specifies something .cow from cows directory.
Say to return cowsay string.
Thinking enables thinking mode.
Thoughts Thoughts allows you to specify the rune that will be drawn between the speech bubbles and the cow.
Tongue specifies tongue The specified string will always be adjusted to be less than or equal to two characters.
Type specify name of the cowfile.
# Constants
InBinary indicates the COWPATH in binary.
InDirectory indicates the COWPATH in your directory.