tag | bbe3003488e6a07bf5274cbde038b8fb4319c81e | |
---|---|---|
tagger | The Android Open Source Project <initial-contribution@android.com> | Tue May 14 16:43:43 2024 -0700 |
object | f119f04b10f16b6a9c953e713e259d432078bf03 |
Android 14.0.0 release 42
commit | f119f04b10f16b6a9c953e713e259d432078bf03 | [log] [tgz] |
---|---|---|
author | Matthew Maurer <mmaurer@google.com> | Thu Mar 09 18:06:57 2023 +0000 |
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | Thu Mar 09 18:06:57 2023 +0000 |
tree | f7c7d4823a905b00d14ee39cb4477f5c16d85d12 | |
parent | 146644ac7fa9ab546b13720d7d13fba93a2aedb2 [diff] | |
parent | 7daa1d2b8e60aebb87dd835cd21ac2687a14f10b [diff] |
Make shlex available to product and vendor am: bf7615b549 am: 4ed38961a8 am: 076de12f26 am: 7daa1d2b8e Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/shlex/+/2476398 Change-Id: I73845e1316871e83f628882f4fe6e0c386d672cc Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
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.
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.