Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: Update from _rust/main template #75

Closed
wants to merge 45 commits into from
Closed
Changes from all commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
69fa026
chore(deps): update actions/setup-python action to v5
renovate[bot] Jan 1, 2024
82c9aa7
chore(deps): update github/codeql-action action to v3
renovate[bot] Jan 1, 2024
c7805bc
Merge pull request #12 from epage/renovate/actions-setup-python-5.x
epage Jan 2, 2024
739d2cf
Merge pull request #13 from epage/renovate/github-codeql-action-3.x
epage Jan 2, 2024
a4c0626
chore: Make renovate commits to match
epage Jan 2, 2024
61250a3
chore(ci): Optimize CI runs
epage Jan 3, 2024
e819db4
chore(ci): Cancel prior CI runs
epage Jan 18, 2024
0b02906
chore(ci): Be explicit in renovate updates
epage Jan 24, 2024
131de55
chore(ci): Add m1 runners
epage Jan 31, 2024
9a5af5c
chore(ci): Only check intel mac on schedule
epage Feb 8, 2024
da56001
chore(ci): Gather coverage
epage Feb 8, 2024
1313256
chore(ci): Use latest for coverage
epage Feb 8, 2024
51a98a2
chore(ci): Defer to package.rust-version for clippy
epage Feb 15, 2024
4db293d
chore(ci): Only verify MSRV for published packages
epage Feb 15, 2024
779496b
chore(ci): Run the latest clippy
epage Feb 15, 2024
c977df5
chore(ci): Prevent cargo-hack from blowing away our lockfile
epage Feb 21, 2024
7846c51
chore(deps): Update pre-commit/action action to v3.0.1
renovate[bot] Mar 1, 2024
2d5ff55
Merge pull request #16 from epage/renovate/pre-commit-action-3.x
epage Mar 1, 2024
3d5ead8
chore(ci): Configure standard lints
epage Mar 21, 2024
ace6e07
chore(ci): Don't update stable and MSRV together
epage Mar 21, 2024
8ec86ab
chore: Normalize clippy lint names
epage Mar 25, 2024
8e647d9
chore: Encourage use of workspace.dependencies
epage Mar 28, 2024
126eb3d
chore: Encourage a single test binary
epage Mar 28, 2024
c8b190b
chore(ci): Use latest SARIF
epage Mar 28, 2024
9b1b566
chore(ci): Fix all rust-version-specific checks to stable
epage Mar 28, 2024
92d486c
chore(ci): Speed up lockfile check
epage Mar 28, 2024
9258d9a
chore(ci): More exhaustively check features
epage Mar 28, 2024
2714cca
chore(ci): Don't check for unused crates
epage Mar 28, 2024
314eef7
chore: Dont check must_use
epage Mar 28, 2024
6a9d2bf
chore: Don't warn on unsafe
epage Mar 28, 2024
8d4b1b6
chore: Remove clippy::tests_outside_test_module
epage Mar 28, 2024
99e034b
chore: Move print lints to lib.rs
epage Mar 28, 2024
a516bda
chore: Drop workspace.dependencies
epage Apr 1, 2024
ebc70d0
chore: Only check missing_docs in lib
epage Apr 1, 2024
3278d49
chore: Allow print in tests
epage Apr 1, 2024
d634de6
chore(ci): Ensure CI job always runs
epage Apr 1, 2024
dc3e937
Merge pull request #19 from epage/t
epage Apr 1, 2024
2570b58
chore(ci): Skip branch protections
epage Apr 1, 2024
afd2755
chore(ci): Don't block on Lint Commits
epage Apr 1, 2024
14225df
chore(ci): Auto-merge linter version updates
epage Apr 17, 2024
be30b1b
chore(ci): Try again with not auto-updating MSRV
epage Apr 26, 2024
a01f25d
chore(ci): Reduce noisy lints
epage Apr 26, 2024
82cf9a6
chore(ci): Reduce noisy lints
epage Apr 26, 2024
181a2cf
chore(ci): Allow prelude wildcard imports
epage Apr 26, 2024
b8bfc43
chore: Update from _rust/main template
epage Apr 26, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions .clippy.toml
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
msrv = "1.73" # MSRV
warn-on-all-wildcard-imports = true
allow-print-in-tests = true
allow-expect-in-tests = true
allow-unwrap-in-tests = true
allow-dbg-in-tests = true
16 changes: 9 additions & 7 deletions .github/renovate.json5
Original file line number Diff line number Diff line change
@@ -3,6 +3,7 @@
'before 5am on the first day of the month',
],
semanticCommits: 'enabled',
commitMessageLowerCase: 'never',
configMigration: true,
dependencyDashboard: true,
customManagers: [
@@ -17,29 +18,28 @@
'^\\.github/workflows/rust-next.yml$',
],
matchStrings: [
'MSRV.*?(?<currentValue>\\d+\\.\\d+(\\.\\d+)?)',
'(?<currentValue>\\d+\\.\\d+(\\.\\d+)?).*?MSRV',
'STABLE.*?(?<currentValue>\\d+\\.\\d+(\\.\\d+)?)',
'(?<currentValue>\\d+\\.\\d+(\\.\\d+)?).*?STABLE',
],
depNameTemplate: 'rust',
depNameTemplate: 'STABLE',
packageNameTemplate: 'rust-lang/rust',
datasourceTemplate: 'github-releases',
},
],
packageRules: [
{
commitMessageTopic: 'MSRV',
commitMessageTopic: 'Rust Stable',
matchManagers: [
'custom.regex',
],
matchPackageNames: [
'rust',
'STABLE',
],
minimumReleaseAge: '126 days', // 3 releases * 6 weeks per release * 7 days per week
internalChecksFilter: 'strict',
extractVersion: '^(?<version>\\d+\\.\\d+)', // Drop the patch version
schedule: [
'* * * * *',
],
automerge: true,
},
// Goals:
// - Keep version reqs low, ignoring compatible normal/build dependencies
@@ -72,6 +72,7 @@
matchCurrentVersion: '>=1.0.0',
matchUpdateTypes: [
'minor',
'patch',
],
enabled: false,
},
@@ -99,6 +100,7 @@
matchCurrentVersion: '>=1.0.0',
matchUpdateTypes: [
'minor',
'patch',
],
automerge: true,
groupName: 'compatible (dev)',
26 changes: 15 additions & 11 deletions .github/settings.yml
Original file line number Diff line number Diff line change
@@ -42,14 +42,18 @@ labels:
color: '#c2e0c6'
description: "Help wanted!"

branches:
- name: master
protection:
required_pull_request_reviews: null
required_conversation_resolution: true
required_status_checks:
# Required. Require branches to be up to date before merging.
strict: false
contexts: ["CI", "Lint Commits", "Spell Check with Typos"]
enforce_admins: false
restrictions: null
# This serves more as documentation.
# Branch protection API was replaced by rulesets but settings isn't updated.
# See https://github.com/repository-settings/app/issues/825
#
# branches:
# - name: master
# protection:
# required_pull_request_reviews: null
# required_conversation_resolution: true
# required_status_checks:
# # Required. Require branches to be up to date before merging.
# strict: false
# contexts: ["CI", "Spell Check with Typos"]
# enforce_admins: false
# restrictions: null
4 changes: 4 additions & 0 deletions .github/workflows/audit.yml
Original file line number Diff line number Diff line change
@@ -17,6 +17,10 @@ env:
CARGO_TERM_COLOR: always
CLICOLOR: 1

concurrency:
group: "${{ github.workflow }}-${{ github.ref }}"
cancel-in-progress: true

jobs:
security_audit:
permissions:
67 changes: 42 additions & 25 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -14,16 +14,22 @@ env:
CARGO_TERM_COLOR: always
CLICOLOR: 1

concurrency:
group: "${{ github.workflow }}-${{ github.ref }}"
cancel-in-progress: true

jobs:
ci:
permissions:
contents: none
name: CI
needs: [test, miri, msrv, docs, rustfmt, clippy]
needs: [test, miri, msrv, lockfile, docs, rustfmt, clippy]
runs-on: ubuntu-latest
if: "always()"
steps:
- name: Done
run: exit 0
- name: Failed
run: exit 1
if: "contains(needs.*.result, 'failure') || contains(needs.*.result, 'cancelled') || contains(needs.*.result, 'skipped')"
test:
name: Test
strategy:
@@ -66,14 +72,11 @@ jobs:
sudo apt-get update
sudo apt-get install gcc-multilib
- uses: Swatinem/rust-cache@v2
- uses: taiki-e/install-action@cargo-hack
- name: Build
run: cargo test --target ${{ matrix.target }} --no-run --workspace --all-features
- name: Default features
run: cargo test --target ${{ matrix.target }} --workspace
- name: All features
run: cargo test --target ${{ matrix.target }} --workspace --all-features
- name: No-default features
run: cargo test --target ${{ matrix.target }} --workspace --no-default-features --features std
run: cargo test --target ${{ matrix.target }} --workspace --no-run
- name: Test
run: cargo hack test --target ${{ matrix.target }} --feature-powerset --workspace
miri:
name: Miri
runs-on: ubuntu-latest
@@ -95,22 +98,19 @@ jobs:
- name: No-default features
run: cargo miri test --no-default-features --features std
msrv:
name: "Check MSRV: 1.73"
name: "Check MSRV"
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
toolchain: "1.73" # MSRV
toolchain: stable
- uses: Swatinem/rust-cache@v2
- uses: taiki-e/install-action@cargo-hack
- name: Default features
run: cargo check --workspace --all-targets
- name: All features
run: cargo check --workspace --all-targets --all-features
- name: No-default features
run: cargo check --workspace --all-targets --no-default-features --features std
run: cargo hack check --feature-powerset --locked --rust-version --ignore-private --workspace --all-targets
lockfile:
runs-on: ubuntu-latest
steps:
@@ -122,7 +122,7 @@ jobs:
toolchain: stable
- uses: Swatinem/rust-cache@v2
- name: "Is lockfile updated?"
run: cargo fetch --locked
run: cargo update --workspace --locked
docs:
name: Docs
runs-on: ubuntu-latest
@@ -132,7 +132,7 @@ jobs:
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
toolchain: "1.76" # STABLE
- uses: Swatinem/rust-cache@v2
- name: Check documentation
env:
@@ -147,9 +147,7 @@ jobs:
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
# Not MSRV because its harder to jump between versions and people are
# more likely to have stable
toolchain: stable
toolchain: "1.76" # STABLE
components: rustfmt
- uses: Swatinem/rust-cache@v2
- name: Check formatting
@@ -165,13 +163,13 @@ jobs:
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
toolchain: "1.73" # MSRV
toolchain: "1.76" # STABLE
components: clippy
- uses: Swatinem/rust-cache@v2
- name: Install SARIF tools
run: cargo install clippy-sarif --version 0.3.4 --locked # Held back due to msrv
run: cargo install clippy-sarif --locked
- name: Install SARIF tools
run: cargo install sarif-fmt --version 0.3.4 --locked # Held back due to msrv
run: cargo install sarif-fmt --locked
- name: Check
run: >
cargo clippy --workspace --all-features --all-targets --message-format=json -- -D warnings --allow deprecated
@@ -186,3 +184,22 @@ jobs:
wait-for-processing: true
- name: Report status
run: cargo clippy --workspace --all-features --all-targets -- -D warnings --allow deprecated
coverage:
name: Coverage
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
- uses: Swatinem/rust-cache@v2
- name: Install cargo-tarpaulin
run: cargo install cargo-tarpaulin
- name: Gather coverage
run: cargo tarpaulin --output-dir coverage --out lcov
- name: Publish to Coveralls
uses: coverallsapp/github-action@master
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
4 changes: 4 additions & 0 deletions .github/workflows/committed.yml
Original file line number Diff line number Diff line change
@@ -11,6 +11,10 @@ env:
CARGO_TERM_COLOR: always
CLICOLOR: 1

concurrency:
group: "${{ github.workflow }}-${{ github.ref }}"
cancel-in-progress: true

jobs:
committed:
name: Lint Commits
4 changes: 4 additions & 0 deletions .github/workflows/pre-commit.yml
Original file line number Diff line number Diff line change
@@ -12,6 +12,10 @@ env:
CARGO_TERM_COLOR: always
CLICOLOR: 1

concurrency:
group: "${{ github.workflow }}-${{ github.ref }}"
cancel-in-progress: true

jobs:
pre-commit:
permissions:
28 changes: 15 additions & 13 deletions .github/workflows/rust-next.yml
Original file line number Diff line number Diff line change
@@ -12,12 +12,16 @@ env:
CARGO_TERM_COLOR: always
CLICOLOR: 1

concurrency:
group: "${{ github.workflow }}-${{ github.ref }}"
cancel-in-progress: true

jobs:
test:
name: Test
strategy:
matrix:
os: ["ubuntu-latest", "windows-latest", "macos-latest"]
os: ["ubuntu-latest", "windows-latest", "macos-latest", "macos-14"]
rust: ["stable", "beta"]
include:
- os: ubuntu-latest
@@ -32,12 +36,11 @@ jobs:
with:
toolchain: ${{ matrix.rust }}
- uses: Swatinem/rust-cache@v2
- name: Default features
run: cargo test --workspace
- name: All features
run: cargo test --workspace --all-features
- name: No-default features
run: cargo test --workspace --no-default-features --features std
- uses: taiki-e/install-action@cargo-hack
- name: Build
run: cargo test --workspace --no-run
- name: Test
run: cargo hack test --feature-powerset --workspace
latest:
name: "Check latest dependencies"
runs-on: ubuntu-latest
@@ -49,11 +52,10 @@ jobs:
with:
toolchain: stable
- uses: Swatinem/rust-cache@v2
- uses: taiki-e/install-action@cargo-hack
- name: Update dependencues
run: cargo update
- name: Default features
run: cargo test --workspace --all-targets
- name: All features
run: cargo test --workspace --all-targets --all-features
- name: No-default features
run: cargo test --workspace --no-default-features --features std
- name: Build
run: cargo test --workspace --no-run
- name: Test
run: cargo hack test --feature-powerset --workspace
4 changes: 4 additions & 0 deletions .github/workflows/spelling.yml
Original file line number Diff line number Diff line change
@@ -10,6 +10,10 @@ env:
CARGO_TERM_COLOR: always
CLICOLOR: 1

concurrency:
group: "${{ github.workflow }}-${{ github.ref }}"
cancel-in-progress: true

jobs:
spelling:
name: Spell Check with Typos
45 changes: 37 additions & 8 deletions Cargo.lock
74 changes: 74 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -16,6 +16,76 @@ include = [
"examples/**/*"
]

[workspace.lints.rust]
rust_2018_idioms = "warn"
unreachable_pub = "warn"
unsafe_op_in_unsafe_fn = "warn"
unused_lifetimes = "warn"
unused_macro_rules = "warn"
unused_qualifications = "warn"

[workspace.lints.clippy]
bool_assert_comparison = "allow"
branches_sharing_code = "allow"
checked_conversions = "warn"
collapsible_else_if = "allow"
create_dir = "warn"
dbg_macro = "warn"
debug_assert_with_mut_call = "warn"
doc_markdown = "warn"
empty_enum = "warn"
enum_glob_use = "warn"
expl_impl_clone_on_copy = "warn"
explicit_deref_methods = "warn"
explicit_into_iter_loop = "warn"
fallible_impl_from = "warn"
filter_map_next = "warn"
flat_map_option = "warn"
float_cmp_const = "warn"
fn_params_excessive_bools = "warn"
from_iter_instead_of_collect = "warn"
if_same_then_else = "allow"
implicit_clone = "warn"
imprecise_flops = "warn"
inconsistent_struct_constructor = "warn"
inefficient_to_string = "warn"
infinite_loop = "warn"
invalid_upcast_comparisons = "warn"
items_after_statements = "warn"
large_digit_groups = "warn"
large_stack_arrays = "warn"
large_types_passed_by_value = "warn"
let_and_return = "allow" # sometimes good to name what you are returning
linkedlist = "warn"
lossy_float_literal = "warn"
macro_use_imports = "warn"
match_wildcard_for_single_variants = "warn"
mem_forget = "warn"
mutex_integer = "warn"
needless_continue = "warn"
needless_for_each = "warn"
negative_feature_names = "warn"
path_buf_push_overwrite = "warn"
ptr_as_ptr = "warn"
rc_mutex = "warn"
redundant_feature_names = "warn"
ref_option_ref = "warn"
rest_pat_in_fully_bound_structs = "warn"
same_functions_in_if_condition = "warn"
self_named_module_files = "warn"
semicolon_if_nothing_returned = "warn"
single_match_else = "warn"
str_to_string = "warn"
string_add = "warn"
string_add_assign = "warn"
string_lit_as_bytes = "warn"
string_to_string = "warn"
todo = "warn"
trait_duplication_in_bounds = "warn"
verbose_file_reads = "warn"
wildcard_imports = "warn"
zero_sized_map_values = "warn"

[package]
name = "kstring"
version = "2.0.0"
@@ -68,6 +138,7 @@ document-features = { version = "0.2", optional = true }
[dev-dependencies]
criterion = "0.5"
proptest = "1.4.0"
automod = "1.0.14"

[[bench]]
name = "clone"
@@ -79,3 +150,6 @@ harness = false

[profile.release]
debug = 1

[lints]
workspace = true
10 changes: 5 additions & 5 deletions benches/access.rs
Original file line number Diff line number Diff line change
@@ -45,35 +45,35 @@ fn bench_access(c: &mut Criterion) {
|b, _| {
let uut = StringCow::Borrowed(*fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.is_empty())
b.iter(|| uut.is_empty());
},
);
group.bench_with_input(BenchmarkId::new("StringCow::Owned", len), &len, |b, _| {
let uut = StringCow::Owned(String::from(*fixture));
let uut = criterion::black_box(uut);
b.iter(|| uut.is_empty())
b.iter(|| uut.is_empty());
});
group.bench_with_input(
BenchmarkId::new("KString::from_static", len),
&len,
|b, _| {
let uut = kstring::KString::from_static(fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.is_empty())
b.iter(|| uut.is_empty());
},
);
group.bench_with_input(BenchmarkId::new("KString::from_ref", len), &len, |b, _| {
let uut = kstring::KString::from_ref(fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.is_empty())
b.iter(|| uut.is_empty());
});
group.bench_with_input(
BenchmarkId::new("KString::from_string", len),
&len,
|b, _| {
let uut = kstring::KString::from_string(String::from(*fixture));
let uut = criterion::black_box(uut);
b.iter(|| uut.is_empty())
b.iter(|| uut.is_empty());
},
);
#[cfg(not(feature = "unstable_bench_subset"))]
10 changes: 5 additions & 5 deletions benches/clone.rs
Original file line number Diff line number Diff line change
@@ -44,29 +44,29 @@ fn bench_clone(c: &mut Criterion) {
|b, _| {
let uut = StringCow::Borrowed(*fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.clone())
b.iter(|| uut.clone());
},
);
group.bench_with_input(BenchmarkId::new("StringCow::Owned", len), &len, |b, _| {
let fixture = String::from(*fixture);
let uut = StringCow::Owned(fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.clone())
b.iter(|| uut.clone());
});
group.bench_with_input(
BenchmarkId::new("KString::from_static", len),
&len,
|b, _| {
let uut = kstring::KString::from_static(fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.clone())
b.iter(|| uut.clone());
},
);
group.bench_with_input(BenchmarkId::new("KString::from_ref", len), &len, |b, _| {
let fixture = String::from(*fixture);
let uut = kstring::KString::from_ref(&fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.clone())
b.iter(|| uut.clone());
});
group.bench_with_input(
BenchmarkId::new("KString::from_string", len),
@@ -75,7 +75,7 @@ fn bench_clone(c: &mut Criterion) {
let fixture = String::from(*fixture);
let uut = kstring::KString::from_string(fixture);
let uut = criterion::black_box(uut);
b.iter(|| uut.clone())
b.iter(|| uut.clone());
},
);
#[cfg(not(feature = "unstable_bench_subset"))]
2 changes: 1 addition & 1 deletion src/backend.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#[cfg(feature = "arc")]
pub(crate) type DefaultStr = crate::backend::ArcStr;
pub(crate) type DefaultStr = ArcStr;
#[cfg(not(feature = "arc"))]
pub(crate) type DefaultStr = crate::backend::BoxedStr;

2 changes: 2 additions & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
@@ -38,6 +38,8 @@
#![cfg_attr(feature = "document-features", doc = document_features::document_features!())]
#![cfg_attr(not(feature = "unsafe"), forbid(unsafe_code))]
#![cfg_attr(docsrs, feature(doc_auto_cfg))]
#![warn(clippy::print_stderr)]
#![warn(clippy::print_stdout)]

#[cfg(not(feature = "std"))]
compile_error!("`std` feature is required; reserved for future `no_std` support");
40 changes: 24 additions & 16 deletions src/stack.rs
Original file line number Diff line number Diff line change
@@ -96,10 +96,12 @@ impl<const CAPACITY: usize> StackString<CAPACITY> {
#[must_use]
#[cfg(feature = "unsafe")]
pub unsafe fn new_unchecked(s: &str) -> Self {
let len = s.as_bytes().len() as u8;
debug_assert!(Self::CAPACITY <= Len::MAX.into());
let buffer = StrBuffer::new_unchecked(s);
Self { len, buffer }
unsafe {
let len = s.as_bytes().len() as u8;
debug_assert!(Self::CAPACITY <= Len::MAX.into());
let buffer = StrBuffer::new_unchecked(s);
Self { len, buffer }
}
}

/// Extracts a string slice containing the entire `StackString`.
@@ -425,28 +427,34 @@ impl<const CAPACITY: usize> StrBuffer<CAPACITY> {
#[inline]
#[cfg(feature = "unsafe")]
pub(crate) unsafe fn new_unchecked(s: &str) -> Self {
let len = s.as_bytes().len();
debug_assert!(len <= CAPACITY);
let mut buffer = Self::default();
buffer
.0
.get_unchecked_mut(..len)
.copy_from_slice(s.as_bytes());
buffer
unsafe {
let len = s.as_bytes().len();
debug_assert!(len <= CAPACITY);
let mut buffer = Self::default();
buffer
.0
.get_unchecked_mut(..len)
.copy_from_slice(s.as_bytes());
buffer
}
}

#[inline]
#[cfg(feature = "unsafe")]
pub(crate) unsafe fn as_str_unchecked(&self, len: usize) -> &str {
let slice = self.0.get_unchecked(..len);
std::str::from_utf8_unchecked(slice)
unsafe {
let slice = self.0.get_unchecked(..len);
std::str::from_utf8_unchecked(slice)
}
}

#[inline]
#[cfg(feature = "unsafe")]
pub(crate) unsafe fn as_mut_str_unchecked(&mut self, len: usize) -> &mut str {
let slice = self.0.get_unchecked_mut(..len);
std::str::from_utf8_unchecked_mut(slice)
unsafe {
let slice = self.0.get_unchecked_mut(..len);
std::str::from_utf8_unchecked_mut(slice)
}
}
}

12 changes: 6 additions & 6 deletions src/string.rs
Original file line number Diff line number Diff line change
@@ -4,7 +4,7 @@ use crate::stack::StackString;
use crate::KStringCowBase;
use crate::KStringRef;

pub(crate) type StdString = std::string::String;
pub(crate) type StdString = String;

/// A UTF-8 encoded, immutable string.
pub type KString = KStringBase<crate::backend::DefaultStr>;
@@ -499,7 +499,7 @@ mod inner {

#[cfg(feature = "unsafe")]
mod inner {
use super::*;
use super::{Cow, KStringRef, StackString, StdString};

pub(super) union KStringInner<B> {
tag: TagVariant,
@@ -511,14 +511,14 @@ mod inner {
impl<B> KStringInner<B> {
/// Create a reference to a `'static` data.
#[inline]
pub const fn from_static(other: &'static str) -> Self {
pub(crate) const fn from_static(other: &'static str) -> Self {
Self {
singleton: SingletonVariant::new(other),
}
}

#[inline]
pub fn try_inline(other: &str) -> Option<Self> {
pub(crate) fn try_inline(other: &str) -> Option<Self> {
StackString::try_new(other).map(|inline| Self {
inline: InlineVariant::new(inline),
})
@@ -679,7 +679,7 @@ mod inner {
if tag.is_owned() {
unsafe {
// SAFETY: `tag` ensures we are using the right variant
std::mem::ManuallyDrop::drop(&mut self.owned)
std::mem::ManuallyDrop::drop(&mut self.owned);
}
}
}
@@ -697,7 +697,7 @@ mod inner {

#[allow(unused)]
const TARGET_SIZE: usize = std::mem::size_of::<Target>();
type Target = crate::string::StdString;
type Target = StdString;

#[allow(unused)]
const MAX_CAPACITY: usize = TARGET_SIZE - LEN_SIZE - TAG_SIZE;
2 changes: 1 addition & 1 deletion src/string_cow.rs
Original file line number Diff line number Diff line change
@@ -4,7 +4,7 @@ use crate::KStringBase;
use crate::KStringRef;
use crate::KStringRefInner;

type StdString = std::string::String;
type StdString = String;
type BoxedStr = Box<str>;

/// A reference to a UTF-8 encoded, immutable string.
2 changes: 1 addition & 1 deletion src/string_ref.rs
Original file line number Diff line number Diff line change
@@ -3,7 +3,7 @@ use std::fmt;
use crate::KStringBase;
use crate::KStringCowBase;

type StdString = std::string::String;
type StdString = String;
type BoxedStr = Box<str>;

/// A reference to a UTF-8 encoded, immutable string.
1 change: 1 addition & 0 deletions tests/testsuite/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
automod::dir!("tests/testsuite");
File renamed without changes.