summaryrefslogtreecommitdiffstats
path: root/vendor/arrayvec/benches/arraystring.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /vendor/arrayvec/benches/arraystring.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/arrayvec/benches/arraystring.rs')
-rw-r--r--vendor/arrayvec/benches/arraystring.rs90
1 files changed, 90 insertions, 0 deletions
diff --git a/vendor/arrayvec/benches/arraystring.rs b/vendor/arrayvec/benches/arraystring.rs
new file mode 100644
index 000000000..5b986fa2a
--- /dev/null
+++ b/vendor/arrayvec/benches/arraystring.rs
@@ -0,0 +1,90 @@
+
+extern crate arrayvec;
+#[macro_use] extern crate bencher;
+
+use arrayvec::ArrayString;
+
+use bencher::Bencher;
+
+fn try_push_c(b: &mut Bencher) {
+ let mut v = ArrayString::<512>::new();
+ b.iter(|| {
+ v.clear();
+ while v.try_push('c').is_ok() {
+ }
+ v.len()
+ });
+ b.bytes = v.capacity() as u64;
+}
+
+fn try_push_alpha(b: &mut Bencher) {
+ let mut v = ArrayString::<512>::new();
+ b.iter(|| {
+ v.clear();
+ while v.try_push('α').is_ok() {
+ }
+ v.len()
+ });
+ b.bytes = v.capacity() as u64;
+}
+
+// Yes, pushing a string char-by-char is slow. Use .push_str.
+fn try_push_string(b: &mut Bencher) {
+ let mut v = ArrayString::<512>::new();
+ let input = "abcαβγ“”";
+ b.iter(|| {
+ v.clear();
+ for ch in input.chars().cycle() {
+ if !v.try_push(ch).is_ok() {
+ break;
+ }
+ }
+ v.len()
+ });
+ b.bytes = v.capacity() as u64;
+}
+
+fn push_c(b: &mut Bencher) {
+ let mut v = ArrayString::<512>::new();
+ b.iter(|| {
+ v.clear();
+ while !v.is_full() {
+ v.push('c');
+ }
+ v.len()
+ });
+ b.bytes = v.capacity() as u64;
+}
+
+fn push_alpha(b: &mut Bencher) {
+ let mut v = ArrayString::<512>::new();
+ b.iter(|| {
+ v.clear();
+ while !v.is_full() {
+ v.push('α');
+ }
+ v.len()
+ });
+ b.bytes = v.capacity() as u64;
+}
+
+fn push_string(b: &mut Bencher) {
+ let mut v = ArrayString::<512>::new();
+ let input = "abcαβγ“”";
+ b.iter(|| {
+ v.clear();
+ for ch in input.chars().cycle() {
+ if !v.is_full() {
+ v.push(ch);
+ } else {
+ break;
+ }
+ }
+ v.len()
+ });
+ b.bytes = v.capacity() as u64;
+}
+
+benchmark_group!(benches, try_push_c, try_push_alpha, try_push_string, push_c,
+ push_alpha, push_string);
+benchmark_main!(benches);