Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/faveod/strscan-java
A clone of Ruby's StringScanner
https://github.com/faveod/strscan-java
Last synced: 19 days ago
JSON representation
A clone of Ruby's StringScanner
- Host: GitHub
- URL: https://github.com/faveod/strscan-java
- Owner: Faveod
- License: mit
- Created: 2023-05-16T13:06:10.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-11-07T17:01:11.000Z (3 months ago)
- Last Synced: 2024-11-07T18:17:59.884Z (3 months ago)
- Language: Java
- Size: 91.8 KB
- Stars: 1
- Watchers: 5
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# StringScanner
[![Java CI](https://github.com/Faveod/strscan-java/actions/workflows/ci.yml/badge.svg)](https://github.com/Faveod/strscan-java/actions/workflows/ci.yml)
This is a clone of [Ruby's `StringScanner`](https://docs.ruby-lang.org/en/3.2/StringScanner.html) from `strscan`.
It's not feature complete, but it has all the minimum scanning features
expected.## Examples
### `scan`
Tries to match with pattern at the current position. If there's a match, the scanner advances the “scan pointer” and
returns the matched string. Otherwise, the scanner returns `null`.```java
import fr.blackteam.strscan.StringScanner;
import java.util.regex.Pattern;var words = Pattern.compile("\\w+");
var spaces = Pattern.compile("\\s+");
var s = new StringScanner("This is an example string");s.isEos(); // -> false
s.scan(words); // -> "This"
s.scan(words); // -> nil
s.scan(spaces); // -> " "
s.scan(spaces); // -> nil
s.scan(words); // -> "is"
s.isEos(); // -> falses.scan(spaces); // -> " "
s.scan(words); // -> "an"
s.scan(spaces); // -> " "
s.scan(words); // -> "example"
s.scan(spaces); // -> " "
s.scan(words); // -> "string"
s.isEos(); // -> trues.scan(spaces); // -> nil
s.scan(words); // -> nil
```### `scanUntil`
Scans the string until the pattern is matched. Returns the substring up to and including the end of the match, advancing
the scan pointer to that location. If there is no match, `null` is returned.```java
import fr.blackteam.strscan.StringScanner;
import java.util.regex.Pattern;var s = new StringScanner("Fri Dec 12 1975 14:39");
s.scanUntil("1"); // -> "Fri Dec 1"
s.getPos(); // -> 9
```