12 releases
0.2.6 | Aug 24, 2024 |
---|---|
0.2.5 | Aug 23, 2024 |
0.1.4 | Aug 21, 2024 |
#100 in Programming languages
20KB
268 lines
Splik
Splik (Simple Language Identifier Kit) is a small CLI tool for identifying the languages used in a project. It has similar capabilities to onefetch, but it has more focused features and does not require the directory to be a git project.
Splik can:
- Calculate the total bytes, lines, and files for all recognized programming language files within a directory
- Display the list of languages and their information sorted from most used to least
- List all files in a directory that are of a given programming language
- Identify project root directory using common indicators (
.git
,node_modules
,Cargo.toml
, etc.)
Installation
Splik is available on all platforms through Cargo:
cargo install splik
Usage
To run splik on the current directory, simply run splik
:
splik
The list of available options is as follows:
output [human-readable | json | yaml] (= human-readable)
- The output format. The default is human readable, but other formats can be specified for scripts to easily parse.
include-dotfiles [bool] (= false)
- Whether to not ignore files and directories that start with a dot (
.
). This is off by default to ignore things like.vscode
,.git
, etc.
- Whether to not ignore files and directories that start with a dot (
find [string | null] (= null)
- Find all files of a given language instead of listing all languages. This will print absolute paths to all files of the given programming language, case-insensitive.
find-root [boolean] (= false)
- Find and print the project root directory using common indicators (
.git
,Cargo.toml
,node_modules
).
- Find and print the project root directory using common indicators (
exclude [string[]] (= [])
- A list of languages to exclude from both the count and display.
include [string[]] (= [])
- A list of file / directory names that are ignored by default (
node_modules
,target
, etc.) to include in the count and display.
- A list of file / directory names that are ignored by default (
here [boolean] (= false)
- Do not search for a root directory; Run
splik
on the current directory.
- Do not search for a root directory; Run
Reference
Splik recognizes the following languages/extensions:
Language | Extensions |
---|---|
Assembly | .asm |
Bash | .bash |
C | .c , .h |
C++ | .cpp , .cxx , .cc , .c++ , .hpp , .hxx , .hh , .h++ |
C# | .cs |
Fortran | .f , .for , .f90 , .f95 |
Gleam | .gleam |
Go | .go |
Haskell | .hs , .lhs |
Java | .java |
JavaScript | .js , .mjs , .cjs |
JavaScript React | .jsx |
Kotlin | .kt |
Lua | .lua |
MATLAB | .m |
PHP | .php |
Python | .py |
R | .r |
Ruby | .rb |
Rust | .rs |
SQL | .sql |
Svelte | .svelte |
Swift | .swift |
TypeScript | .ts |
TypeScript React | .tsx |
V | .v |
Vue | .vue |
Zig | .zig |
Limitations
Splik is limited in a few ways:
- The language of a file is determined purely by its extension/name. The actual contents of the file are not analyzed. This can lead to inaccuracies - i.e., theres nothing stopping you from renaming
main.c
tomain.py
, and splik will think it's a Python file. - Splik operates off of a known list of languages, meaning any new languages need to be manually contributed to splik itself before it can be recognized. Once a new language is added, all users of the tool will need to update splik to be able to recognize that language.
Dependencies
~3–11MB
~125K SLoC