Flourite - Language detector
A fork of ts95/lang-detector, rewritten in Typescript with more language support.
Detects a programming language from a given string.
- Built-in support for CommonJS and ESM format
- Built-in Typescript typings
- No external dependencies
- 200 test cases and growing!
Detectable languages
Languages | | | | |
---|
C | Dockerfile | Javascript | Pascal | SQL |
C++ | Elixir | Julia | PHP | YAML |
C# | Go | Kotlin | Python | |
Clojure | HTML | Lua | Ruby | |
CSS | Java | Markdown | Rust | |
Install
$ npm install flourite
or via a CDN (unpkg or jsdelivr)
<script src="https://unpkg.com/flourite@1.2.0"></script>
<script src="https://cdn.jsdelivr.net/npm/flourite@1.2.0/dist/index.iife.js"></script>
Usage
import flourite from 'flourite';
const code = flourite('cout << "Hello world" << endl;');
Or if you want to integrate it with Shiki, you could pass:
flourite('Console.WriteLine("Hello world!");', { shiki: true }).language;
flourite('fn partition<T,F>(v: &mut [T], f: &F) -> usize ', { shiki: true }).language;
If you want to handle Unknown
value, you could pass:
const code = flourite("SELECT 'Hello world!' text FROM dual;", { noUnknown: true });
With Typescript
import flourite from 'flourite';
import type { Options } from 'flourite';
const flouriteOptions: Options = {
heuristic: true,
};
const code = flourite('print!({:?}, &v);', flouriteOptions);
Available Options
| Key | Type | Default | Description |
| --------- | --------- | ------- | ------------------------------------------------------------------------------------------------ | --- |
| heuristic | boolean
| true
| Checks for codes on the top of the given input. Only checks when the lines of code is above 500. | |
| shiki | boolean
| false
| Straightforward compatibility with Shiki's language specification type |
| noUnknown | boolean
| false
| If true
, will not output Unknown
on detected and statistics result |
I'm here for Hacktoberfest, what can I do?
If you're new to open source, we really recommend reading a few articles about contributing to open source projects:
Then you can start by reading our contribution part and guidelines.
Two things that you can do for sure: Create a new language support and improve the regular expression performance on current supported languages.
Have fun!
Contributing
- Use the Node.js version as defined on the
.nvmrc
file. - Run
npm run test:tdd
to initiate a test driven development environment. - Run
npm run lint
and npm run format
before commit a change.
For more details and explanation on how things work, see CONTRIBUTING
License
MIT