Compare commits
12 Commits
122cd5ed04
...
v0.1.1
Author | SHA1 | Date | |
---|---|---|---|
6b4d131f4f | |||
51b4029a79 | |||
a1f804ac38 | |||
eb32ec1027 | |||
2625239dba | |||
44de668546 | |||
20cb665b33 | |||
9a6fc3475a | |||
d15a771e89 | |||
f8cb03bf88 | |||
b65cef96c3 | |||
b511c14cc3 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -1,2 +1,3 @@
|
|||||||
ccat
|
ccat
|
||||||
|
*.zip
|
||||||
|
|
||||||
|
16
README.md
16
README.md
@@ -12,11 +12,20 @@ ccat is a file printing tool (like 'cat') which uses Regular Expressions to enab
|
|||||||
- Highly extensible - to add a config file for an specific file type, name the file `<extension>.conf`.
|
- Highly extensible - to add a config file for an specific file type, name the file `<extension>.conf`.
|
||||||
- Support for printing line numbers with the `-n` flag.
|
- Support for printing line numbers with the `-n` flag.
|
||||||
- Statically linked Go binary - no runtime dependencies, config files are distributed along with the binary.
|
- Statically linked Go binary - no runtime dependencies, config files are distributed along with the binary.
|
||||||
- Cross-platform
|
- Linux and MacOS supported.
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### Installing
|
### Installing
|
||||||
|
|
||||||
|
Download the appropriate zip-file from the 'Releases' section. Place the executable in your PATH.
|
||||||
|
|
||||||
|
NOTE: The releases are not available on the GitHub repo (which is a mirror of https://gitea.twomorecents.org/Rockingcool/ccat). Obtain the [releases](https://gitea.twomorecents.org/Rockingcool/ccat/releases) from there instead.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### Building from source
|
||||||
|
|
||||||
If you have the `go` command installed, run `make` after cloning the repository.
|
If you have the `go` command installed, run `make` after cloning the repository.
|
||||||
|
|
||||||
---
|
---
|
||||||
@@ -27,12 +36,11 @@ The following languages have config files included by default:
|
|||||||
|
|
||||||
- C
|
- C
|
||||||
- Go
|
- Go
|
||||||
-
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### Getting Started
|
### Getting Started
|
||||||
The config files are embedded within the binary. They will automatically be installed to the correct location (`%APPDATA/ccat` on Windows, `~/.config/ccat` on UNIX) when the program is first run.
|
The config files are embedded within the binary. They will automatically be installed to the correct location (`~/.config/ccat` on UNIX) when the program is first run.
|
||||||
|
|
||||||
As written above, if provided a file with extension `.example`, the program will look for the config file named `example.conf`. If such a file doesn't exist, the file is printed out without any highlighting.
|
As written above, if provided a file with extension `.example`, the program will look for the config file named `example.conf`. If such a file doesn't exist, the file is printed out without any highlighting.
|
||||||
|
|
||||||
@@ -61,5 +69,5 @@ Note that the color name must be capitalized (and shouldn't contain spaces). The
|
|||||||
---
|
---
|
||||||
|
|
||||||
### TODO:
|
### TODO:
|
||||||
|
- Windows support.
|
||||||
- Allow users to provide a config file in the command-line, overriding the extension-based config file.
|
- Allow users to provide a config file in the command-line, overriding the extension-based config file.
|
||||||
- Provide releases.
|
|
||||||
|
20
config.go
20
config.go
@@ -1,12 +1,11 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"ccat/stack"
|
|
||||||
"embed"
|
"embed"
|
||||||
"errors"
|
"errors"
|
||||||
|
"gitea.twomorecents.org/Rockingcool/ccat/stack"
|
||||||
"io/fs"
|
"io/fs"
|
||||||
"os"
|
"os"
|
||||||
"os/user"
|
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"regexp"
|
"regexp"
|
||||||
"runtime"
|
"runtime"
|
||||||
@@ -18,27 +17,18 @@ import (
|
|||||||
//go:embed config
|
//go:embed config
|
||||||
var storedConfigs embed.FS // Embed the folder containing config files
|
var storedConfigs embed.FS // Embed the folder containing config files
|
||||||
|
|
||||||
|
// runningOnWindows: At the moment this function isn't used. When Window support is added,
|
||||||
|
// it will be used to determine if the program is being run on Windows.
|
||||||
func runningOnWindows() bool {
|
func runningOnWindows() bool {
|
||||||
return runtime.GOOS == "windows"
|
return runtime.GOOS == "windows"
|
||||||
}
|
}
|
||||||
|
|
||||||
// generateDefaultConfigs is used to generate a folder of default config files
|
// generateDefaultConfigs is used to generate a folder of default config files
|
||||||
// for common languages. These default config files are embedded into the program, and will
|
// for common languages. These default config files are embedded into the program, and will
|
||||||
// be outputted into a directory.
|
// be outputted into the given directory.
|
||||||
//
|
//
|
||||||
// If there is an error encountered, the error is returned.
|
// If there is an error encountered, the error is returned.
|
||||||
func generateDefaultConfigs() error {
|
func generateDefaultConfigs(configOutputPath string) error {
|
||||||
|
|
||||||
var configOutputPath string // Location of config files, depends on OS
|
|
||||||
if runningOnWindows() {
|
|
||||||
configOutputPath = "%APPDATA%\\ccat"
|
|
||||||
} else {
|
|
||||||
currentUser, err := user.Current()
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
configOutputPath = filepath.Join("/home/" + currentUser.Username + "/.config/ccat/")
|
|
||||||
}
|
|
||||||
err := os.MkdirAll(configOutputPath, 0755)
|
err := os.MkdirAll(configOutputPath, 0755)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if os.IsExist(err) {
|
if os.IsExist(err) {
|
||||||
|
17
create_release_builds.sh
Executable file
17
create_release_builds.sh
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
POSSIBLE_GOOS=( "linux" "darwin" )
|
||||||
|
POSSIBLE_GOARCH=( "amd64" "arm64" )
|
||||||
|
|
||||||
|
for OS in "${POSSIBLE_GOOS[@]}"; do
|
||||||
|
for ARCH in "${POSSIBLE_GOARCH[@]}"; do
|
||||||
|
FOLDER_NAME="ccat-$OS-$ARCH"
|
||||||
|
mkdir "${FOLDER_NAME}"
|
||||||
|
GOOS=$OS GOARCH=$ARCH go build -o "${FOLDER_NAME}/"
|
||||||
|
zip -r "${FOLDER_NAME}" "${FOLDER_NAME}"
|
||||||
|
rm -r "${FOLDER_NAME}"
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
2
go.mod
2
go.mod
@@ -1,4 +1,4 @@
|
|||||||
module ccat
|
module gitea.twomorecents.org/Rockingcool/ccat
|
||||||
|
|
||||||
go 1.22.5
|
go 1.22.5
|
||||||
|
|
||||||
|
11
main.go
11
main.go
@@ -78,18 +78,13 @@ func main() {
|
|||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
// Check if config exists. If it doesn't, generate the config files.
|
// Check if config exists. If it doesn't, generate the config files.
|
||||||
var configPath string // Location of config files, depends on OS
|
currentUser, err := user.Current() // Get current user, to determine config path
|
||||||
if runningOnWindows() {
|
|
||||||
configPath = "%APPDATA%\\ccat"
|
|
||||||
} else {
|
|
||||||
currentUser, err := user.Current()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
configPath = filepath.Join("/home/" + currentUser.Username + "/.config/ccat/")
|
configPath := filepath.Join("/home/" + currentUser.Username + "/.config/ccat/")
|
||||||
}
|
|
||||||
if _, err := os.Stat(configPath); os.IsNotExist(err) {
|
if _, err := os.Stat(configPath); os.IsNotExist(err) {
|
||||||
generateDefaultConfigs()
|
generateDefaultConfigs(configPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if user has provided a file name
|
// Check if user has provided a file name
|
||||||
|
1
todo.txt
1
todo.txt
@@ -1,5 +1,4 @@
|
|||||||
1. Man page
|
1. Man page
|
||||||
2. README for GitHub Repo
|
|
||||||
2. Logging
|
2. Logging
|
||||||
3. Coloring functions
|
3. Coloring functions
|
||||||
4. Flag to list all available colors for your terminal - some terminals will only support the predefined colors.
|
4. Flag to list all available colors for your terminal - some terminals will only support the predefined colors.
|
||||||
|
Reference in New Issue
Block a user