Удаление префикса пути Windows - PullRequest
1 голос
/ 13 апреля 2019

Я пытаюсь удалить префикс из пути Windows. Я попытался сделать это, используя метод strip_prefix, но это не удалось. Вы можете попробовать это на Rust Playground . Я не смог получить какие-либо разумные подробности о том, почему это не удалось даже с RUST_BACKTRACE=full.

use std::path::Path;

fn main() {
    let pwd = Path::new(r#"C:\Users\me"#);
    let path = Path::new(r#"C:\Users\me\site"#);
    let result = path.strip_prefix(pwd).map_err(|_| ());
    println!("Result: {:?}", result); // Result: Err(())
    path.strip_prefix(pwd).unwrap();
}

Это ошибка или я что-то упустил?

Результат с RUST_BACKTRACE=full:

Result: Err(())
thread 'main' panicked at 'called `Result::unwrap()` on an `Err` value: StripPrefixError(())', src/libcore/result.rs:997:5
stack backtrace:

0: 0x55f339d5eb53 - std::sys::unix::backtrace::tracing::imp::unwind_backtrace::hf8722b0178fb1b63
    at src/libstd/sys/unix/backtrace/tracing/gcc_s.rs:39
1: 0x55f339d5aa68 - std::sys_common::backtrace::_print::hc40139e5f1d656ee
    at src/libstd/sys_common/backtrace.rs:70
2: 0x55f339d5daa2 - std::panicking::default_hook::{{closure}}::h993d43465919c16a
    at src/libstd/sys_common/backtrace.rs:58
    at src/libstd/panicking.rs:200
3: 0x55f339d5d814 - std::panicking::default_hook::h73d2c2ec3d9ba5a4
    at src/libstd/panicking.rs:215
4: 0x55f339d5e100 - std::panicking::rust_panic_with_hook::h744417edfe714d72
    at src/libstd/panicking.rs:478
5: 0x55f339d5dc81 - std::panicking::continue_panic_fmt::h3557b3c3fa21b47b
    at src/libstd/panicking.rs:385
6: 0x55f339d5db65 - rust_begin_unwind
    at src/libstd/panicking.rs:312
7: 0x55f339d6e0cc - core::panicking::panic_fmt::h74ee8034b317ceed
    at src/libcore/panicking.rs:85
8: 0x55f339d536fd - core::result::unwrap_failed::h3406097ad0bd8fc9
    at /rustc/2aa4c46cfdd726e97360c2734835aa3515e8c858/src/libcore/macros.rs:16
9: 0x55f339d53429 - <core::result::Result<T, E>>::unwrap::hac51cf7638922ce6
    at /rustc/2aa4c46cfdd726e97360c2734835aa3515e8c858/src/libcore/result.rs:798
10: 0x55f339d53e89 - g::main::h131de6fc3bc2b7fb
    at src/main.rs:8
11: 0x55f339d538df - std::rt::lang_start::{{closure}}::h68e0b763dc36e392
    at /rustc/2aa4c46cfdd726e97360c2734835aa3515e8c858/src/libstd/rt.rs:64
12: 0x55f339d5db52 - std::panicking::try::do_call::h7a0381557c6c2cee
    at src/libstd/rt.rs:49
    at src/libstd/panicking.rs:297
13: 0x55f339d5faa9 - __rust_maybe_catch_panic
    at src/libpanic_unwind/lib.rs:92
14: 0x55f339d5e655 - std::rt::lang_start_internal::he0d8d06abc6f912f
    at src/libstd/panicking.rs:276
    at src/libstd/panic.rs:388
    at src/libstd/rt.rs:48
15: 0x55f339d538b8 - std::rt::lang_start::h565ec575e9c57feb
    at /rustc/2aa4c46cfdd726e97360c2734835aa3515e8c858/src/libstd/rt.rs:64
16: 0x55f339d53ec9 - main
17: 0x7f59a6820412 - __libc_start_main
18: 0x55f339d531fd - _start
19: 0x0 - <unknown>

1 Ответ

1 голос
/ 14 апреля 2019

Как сказано в документе std::path::Path:

Этот тип поддерживает ряд операций для проверки пути, включая разбиение пути на его компоненты (, разделенные / в Unix и / или \ в Windows ), извлечение имени файла, определение абсолютного пути и т. д.

(ударение мое)

Это означает, что в Linux \ не будет распознаваться как разделитель пути, и поэтому C:\Users\me и C:\\Users\me\site - это просто имена файлов в текущем каталоге. В Linux \ действительно не является специальным символом в именах файлов:

$ mkdir foo
$ cd foo
$ touch 'C:\Users\me'
$ ls -l
total 0
-rw-r--r-- 1 martin martin 0 Apr 14 01:47 'C:\Users\me'

Поскольку Playground работает на Linux (, на что намекает тот факт, что нет информации о развертывании для Windows , хотя технически возможно также разместить ее на Windows), ваш код не может работать там .

Однако в Windows работает как положено .

...