From 9c0a3fa7771e5dc5fe545b4147a4f1eca7c455d5 Mon Sep 17 00:00:00 2001
From: Sunman <12025422+synhi@users.noreply.github.com>
Date: Thu, 20 Jun 2024 10:53:31 +0800
Subject: [PATCH 1/2] Update ch09-03-to-panic-or-not-to-panic.md
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
同步官方最新, 修复 9-13 示例代码不显示
---
src/ch09-03-to-panic-or-not-to-panic.md | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/src/ch09-03-to-panic-or-not-to-panic.md b/src/ch09-03-to-panic-or-not-to-panic.md
index 776c118c5..f536012f4 100644
--- a/src/ch09-03-to-panic-or-not-to-panic.md
+++ b/src/ch09-03-to-panic-or-not-to-panic.md
@@ -2,7 +2,7 @@
> [ch09-03-to-panic-or-not-to-panic.md](https://github.com/rust-lang/book/blob/main/src/ch09-03-to-panic-or-not-to-panic.md)
>
-> commit a87db22c297ff9b029f4458c8f303606df767c0b
+> commit dd8f47a74b67178cea8c832e3b4eaf3bb515bd72
那么,该如何决定何时应该 `panic!` 以及何时应该返回 `Result` 呢?如果代码 panic,就没有恢复的可能。你可以选择对任何错误场景都调用 `panic!`,不管是否有可能恢复,不过这样就是你代替调用者决定了这是不可恢复的。选择返回 `Result` 值的话,就将选择权交给了调用者,而不是代替他们做出决定。调用者可能会选择以符合他们场景的方式尝试恢复,或者也可能干脆就认为 `Err` 是不可恢复的,所以他们也可能会调用 `panic!` 并将可恢复的错误变成了不可恢复的错误。因此返回 `Result` 是定义可能会失败的函数的一个好的默认选择。
@@ -48,6 +48,8 @@
一种实现方式是将猜测解析成 `i32` 而不仅仅是 `u32`,来默许输入负数,接着检查数字是否在范围内:
+文件名: src/main.rs
+
```rust,ignore
{{#rustdoc_include ../listings/ch09-error-handling/no-listing-09-guess-out-of-range/src/main.rs:here}}
```
@@ -58,8 +60,10 @@
相反我们可以创建一个新类型来将验证放入创建其实例的函数中,而不是到处重复这些检查。这样就可以安全地在函数签名中使用新类型并相信它们接收到的值。示例 9-13 中展示了一个定义 `Guess` 类型的方法,只有在 `new` 函数接收到 1 到 100 之间的值时才会创建 `Guess` 的实例:
+文件名: src/lib.rs
+
```rust
-{{#rustdoc_include ../listings/ch09-error-handling/listing-09-13/src/lib.rs:here}}
+{{#rustdoc_include ../listings/ch09-error-handling/listing-09-13/src/lib.rs}}
```
示例 9-13:一个 `Guess` 类型,它只在值位于 1 和 100 之间时才继续
From 7e16427629d1c9f0d2a259c394115ef2e47d407b Mon Sep 17 00:00:00 2001
From: Sunman <12025422+synhi@users.noreply.github.com>
Date: Thu, 20 Jun 2024 10:57:54 +0800
Subject: [PATCH 2/2] Update ch09-03-to-panic-or-not-to-panic.md
---
src/ch09-03-to-panic-or-not-to-panic.md | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/ch09-03-to-panic-or-not-to-panic.md b/src/ch09-03-to-panic-or-not-to-panic.md
index f536012f4..8189d3a01 100644
--- a/src/ch09-03-to-panic-or-not-to-panic.md
+++ b/src/ch09-03-to-panic-or-not-to-panic.md
@@ -48,7 +48,7 @@
一种实现方式是将猜测解析成 `i32` 而不仅仅是 `u32`,来默许输入负数,接着检查数字是否在范围内:
-文件名: src/main.rs
+文件名:src/main.rs
```rust,ignore
{{#rustdoc_include ../listings/ch09-error-handling/no-listing-09-guess-out-of-range/src/main.rs:here}}
@@ -60,7 +60,7 @@
相反我们可以创建一个新类型来将验证放入创建其实例的函数中,而不是到处重复这些检查。这样就可以安全地在函数签名中使用新类型并相信它们接收到的值。示例 9-13 中展示了一个定义 `Guess` 类型的方法,只有在 `new` 函数接收到 1 到 100 之间的值时才会创建 `Guess` 的实例:
-文件名: src/lib.rs
+文件名:src/lib.rs
```rust
{{#rustdoc_include ../listings/ch09-error-handling/listing-09-13/src/lib.rs}}