Go to file
openharmony_ci a078c8ed62
!2 Add OAT.xml and README.OpenSource
Merge pull request !2 from fangting/master
2023-04-14 08:10:54 +00:00
.github/workflows Add GitHub Actions to run tests for default and #![no_std] modes 2021-08-27 07:15:59 +12:00
fuzz Adding fuzzers for unsafe code. 2022-02-02 14:59:53 -08:00
src Typo 2021-08-27 20:51:37 +00:00
.gitignore Add gitignore 2018-08-05 07:51:37 +00:00
BUILD.gn Add GN Build Files and Custom Modifications 2023-04-12 17:27:03 +08:00
Cargo.toml Version bump 2021-08-27 22:36:16 +00:00
CHANGELOG.md Version bump 2021-08-27 22:36:16 +00:00
LICENSE-APACHE add license files and clean up Cargo.toml 2018-03-10 11:22:27 -07:00
LICENSE-MIT add license files and clean up Cargo.toml 2018-03-10 11:22:27 -07:00
README.md Fix CI badge 2022-12-17 22:57:01 -08:00
README.OpenSource Add OAT.xml and README.OpenSource 2023-04-14 14:15:24 +08:00

ci badge crates.io badge docs.rs badge

Same idea as (but implementation not directly based on) the Python shlex module. However, this implementation does not support any of the Python module's customization because it makes parsing slower and is fairly useless. You only get the default settings of shlex.split, which mimic the POSIX shell: https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html

This implementation also deviates from the Python version in not treating \r specially, which I believe is more compliant.

The algorithms in this crate are oblivious to UTF-8 high bytes, so they iterate over the bytes directly as a micro-optimization.

Disabling the std feature (which is enabled by default) will allow the crate to work in no_std environments, where the alloc crate, and a global allocator, are available.

LICENSE

The source code in this repository is Licensed under either of

at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.