diff --git a/po/ko.po b/po/ko.po
index bae35a27dcb1..b6533650d507 100644
--- a/po/ko.po
+++ b/po/ko.po
@@ -5,38 +5,37 @@ msgstr ""
"PO-Revision-Date: \n"
"Last-Translator: \n"
"Language-Team: \n"
-"Language: ko\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
+"Language: ko\n"
"Plural-Forms: nplurals=1; plural=0;\n"
-"X-Generator: Poedit 3.2.2\n"
-#: src/SUMMARY.md:3
+#: src/SUMMARY.md:3 src/welcome.md:1
msgid "Welcome to Comprehensive Rust ๐ฆ"
msgstr "Comprehensive Rust์ ์ค์ ๊ฒ์ ํ์ํฉ๋๋ค ๐ฆ"
-#: src/SUMMARY.md:4
+#: src/SUMMARY.md:4 src/running-the-course.md:1
msgid "Running the Course"
msgstr "๊ฐ์ ์งํ"
-#: src/SUMMARY.md:5
+#: src/SUMMARY.md:5 src/running-the-course/course-structure.md:1
msgid "Course Structure"
msgstr "๊ฐ์ ๊ตฌ์ฑ"
-#: src/SUMMARY.md:6
+#: src/SUMMARY.md:6 src/running-the-course/day-4.md:1
msgid "Day 4"
msgstr "4์ผ์ฐจ"
-#: src/SUMMARY.md:7
+#: src/SUMMARY.md:7 src/running-the-course/keyboard-shortcuts.md:1
msgid "Keyboard Shortcuts"
msgstr "๋จ์ถํค"
-#: src/SUMMARY.md:8
+#: src/SUMMARY.md:8 src/running-the-course/translations.md:1
msgid "Translations"
msgstr "๋ค๋ฅธ ์ธ์ด๋ค"
-#: src/SUMMARY.md:9
+#: src/SUMMARY.md:9 src/cargo.md:1
msgid "Using Cargo"
msgstr "์นด๊ณ ์ฌ์ฉํ๊ธฐ"
@@ -60,55 +59,55 @@ msgstr "1์ผ์ฐจ ์ค์ "
msgid "Welcome"
msgstr "๊ฐ์"
-#: src/SUMMARY.md:20
+#: src/SUMMARY.md:20 src/welcome-day-1/what-is-rust.md:1
msgid "What is Rust?"
msgstr "๋ฌ์คํธ๋?"
-#: src/SUMMARY.md:21
+#: src/SUMMARY.md:21 src/hello-world.md:1
msgid "Hello World!"
msgstr "Hello World!"
-#: src/SUMMARY.md:22
+#: src/SUMMARY.md:22 src/hello-world/small-example.md:1
msgid "Small Example"
msgstr "์์ ์์ "
-#: src/SUMMARY.md:23
+#: src/SUMMARY.md:23 src/why-rust.md:1
msgid "Why Rust?"
msgstr "๋ฌ์คํธ๋ฅผ ์จ์ผํ๋ ์ด์ "
-#: src/SUMMARY.md:24
+#: src/SUMMARY.md:24 src/why-rust/compile-time.md:1
msgid "Compile Time Guarantees"
msgstr "์ปดํ์ผ ์ ๋ณด์ฅ๋๋ ๊ฒ๋ค"
-#: src/SUMMARY.md:25
+#: src/SUMMARY.md:25 src/why-rust/runtime.md:1
msgid "Runtime Guarantees"
msgstr "๋ฐํ์ ์ ๋ณด์ฅ๋๋ ๊ฒ๋ค"
-#: src/SUMMARY.md:26
+#: src/SUMMARY.md:26 src/why-rust/modern.md:1
msgid "Modern Features"
msgstr "ํ๋์ ์ธ ํน์ง"
-#: src/SUMMARY.md:27
+#: src/SUMMARY.md:27 src/basic-syntax.md:1
msgid "Basic Syntax"
msgstr "๊ธฐ๋ณธ ๋ฌธ๋ฒ"
-#: src/SUMMARY.md:28
+#: src/SUMMARY.md:28 src/basic-syntax/scalar-types.md:1
msgid "Scalar Types"
msgstr "์ค์นผ๋ผ ํ์ "
-#: src/SUMMARY.md:29
+#: src/SUMMARY.md:29 src/basic-syntax/compound-types.md:1
msgid "Compound Types"
msgstr "๋ณตํฉ ํ์ "
-#: src/SUMMARY.md:30
+#: src/SUMMARY.md:30 src/basic-syntax/references.md:1
msgid "References"
msgstr "์ฐธ์กฐ"
-#: src/SUMMARY.md:31
+#: src/SUMMARY.md:31 src/basic-syntax/references-dangling.md:1
msgid "Dangling References"
msgstr "ํ์(dangling) ์ฐธ์กฐ"
-#: src/SUMMARY.md:32
+#: src/SUMMARY.md:32 src/basic-syntax/slices.md:1
msgid "Slices"
msgstr "์ฌ๋ผ์ด์ค"
@@ -116,11 +115,12 @@ msgstr "์ฌ๋ผ์ด์ค"
msgid "String vs str"
msgstr "String๊ณผ str"
-#: src/SUMMARY.md:34
+#: src/SUMMARY.md:34 src/basic-syntax/functions.md:1
msgid "Functions"
msgstr "ํจ์"
-#: src/SUMMARY.md:35 src/SUMMARY.md:82
+#: src/SUMMARY.md:35 src/SUMMARY.md:82 src/basic-syntax/methods.md:1
+#: src/methods.md:1
msgid "Methods"
msgstr "๋ฉ์๋"
@@ -130,10 +130,11 @@ msgstr "์ค๋ฒ๋ก๋ฉ"
#: src/SUMMARY.md:37 src/SUMMARY.md:66 src/SUMMARY.md:90 src/SUMMARY.md:119
#: src/SUMMARY.md:148 src/SUMMARY.md:176 src/SUMMARY.md:199 src/SUMMARY.md:226
+#: src/exercises/day-4/morning.md:1 src/exercises/day-4/android.md:1
msgid "Exercises"
msgstr "์ฐ์ต๋ฌธ์ "
-#: src/SUMMARY.md:38
+#: src/SUMMARY.md:38 src/exercises/day-1/implicit-conversions.md:1
msgid "Implicit Conversions"
msgstr "๋ฌต์์ ํ๋ณํ"
@@ -145,11 +146,11 @@ msgstr "๋ฐฐ์ด๊ณผ for ๋ฐ๋ณต๋ฌธ"
msgid "Day 1: Afternoon"
msgstr "1์ผ์ฐจ ์คํ"
-#: src/SUMMARY.md:43
+#: src/SUMMARY.md:43 src/basic-syntax/variables.md:1
msgid "Variables"
msgstr "๋ณ์"
-#: src/SUMMARY.md:44
+#: src/SUMMARY.md:44 src/basic-syntax/type-inference.md:1
msgid "Type Inference"
msgstr "ํ์ ์ถ๋ก "
@@ -157,11 +158,11 @@ msgstr "ํ์ ์ถ๋ก "
msgid "static & const"
msgstr "์ ์ ๋ณ์(static)์ ์์(const)"
-#: src/SUMMARY.md:46
+#: src/SUMMARY.md:46 src/basic-syntax/scopes-shadowing.md:1
msgid "Scopes and Shadowing"
msgstr "๋ฒ์(Scopes)์ ์๋์(Shadowing)"
-#: src/SUMMARY.md:47
+#: src/SUMMARY.md:47 src/memory-management.md:1
msgid "Memory Management"
msgstr "๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
@@ -169,15 +170,15 @@ msgstr "๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
msgid "Stack vs Heap"
msgstr "์คํ(Stack)๊ณผ ํ(Heap)"
-#: src/SUMMARY.md:49
+#: src/SUMMARY.md:49 src/memory-management/stack.md:1
msgid "Stack Memory"
msgstr "์คํ ๋ฉ๋ชจ๋ฆฌ"
-#: src/SUMMARY.md:50
+#: src/SUMMARY.md:50 src/memory-management/manual.md:1
msgid "Manual Memory Management"
msgstr "์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
-#: src/SUMMARY.md:51
+#: src/SUMMARY.md:51 src/memory-management/scope-based.md:1
msgid "Scope-Based Memory Management"
msgstr "๋ฒ์๊ธฐ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
@@ -189,59 +190,60 @@ msgstr "๊ฐ๋น์ง ์ปฌ๋ ์ "
msgid "Rust Memory Management"
msgstr "๋ฌ์คํธ์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
-#: src/SUMMARY.md:54
+#: src/SUMMARY.md:54 src/memory-management/comparison.md:1
msgid "Comparison"
msgstr "๋น๊ต"
-#: src/SUMMARY.md:55
+#: src/SUMMARY.md:55 src/ownership.md:1
msgid "Ownership"
msgstr "์์ ๊ถ"
-#: src/SUMMARY.md:56
+#: src/SUMMARY.md:56 src/ownership/move-semantics.md:1
msgid "Move Semantics"
msgstr "Move ๋ฌธ๋ฒ"
-#: src/SUMMARY.md:57
+#: src/SUMMARY.md:57 src/ownership/moved-strings-rust.md:1
msgid "Moved Strings in Rust"
msgstr "๋ฌ์คํธ์์์ ๋ฌธ์์ด ์ด๋"
-#: src/SUMMARY.md:58
+#: src/SUMMARY.md:58 src/ownership/double-free-modern-cpp.md:1
msgid "Double Frees in Modern C++"
msgstr "Modern C++์์ ์ด์คํด์ ๋ฌธ์ "
-#: src/SUMMARY.md:59
+#: src/SUMMARY.md:59 src/ownership/moves-function-calls.md:1
msgid "Moves in Function Calls"
msgstr "ํจ์ ํธ์ถ์์์ ์ด๋(Move)"
-#: src/SUMMARY.md:60
+#: src/SUMMARY.md:60 src/ownership/copy-clone.md:1
msgid "Copying and Cloning"
msgstr "๋ณต์ฌ์ ๋ณต์ "
-#: src/SUMMARY.md:61
+#: src/SUMMARY.md:61 src/ownership/borrowing.md:1
msgid "Borrowing"
msgstr "๋น๋ฆผ"
-#: src/SUMMARY.md:62
+#: src/SUMMARY.md:62 src/ownership/shared-unique-borrows.md:1
msgid "Shared and Unique Borrows"
msgstr "๊ณต์ ์ ๊ณ ์ ๋น๋ฆผ"
-#: src/SUMMARY.md:63
+#: src/SUMMARY.md:63 src/ownership/lifetimes.md:1
msgid "Lifetimes"
msgstr "์๋ช "
-#: src/SUMMARY.md:64
+#: src/SUMMARY.md:64 src/ownership/lifetimes-function-calls.md:1
msgid "Lifetimes in Function Calls"
msgstr "ํจ์ ํธ์ถ์์์ ์๋ช "
-#: src/SUMMARY.md:65
+#: src/SUMMARY.md:65 src/ownership/lifetimes-data-structures.md:1
msgid "Lifetimes in Data Structures"
msgstr "๊ตฌ์กฐ์ฒด์์์ ์๋ช "
-#: src/SUMMARY.md:67
+#: src/SUMMARY.md:67 src/exercises/day-1/book-library.md:1
+#: src/exercises/day-1/solutions-afternoon.md:3
msgid "Designing a Library"
msgstr "๋์๊ด ์ค๊ณ"
-#: src/SUMMARY.md:68
+#: src/SUMMARY.md:68 src/exercises/day-1/iterators-and-ownership.md:1
msgid "Iterators and Ownership"
msgstr "๋ฐ๋ณต์์ ์์ ๊ถ"
@@ -249,63 +251,64 @@ msgstr "๋ฐ๋ณต์์ ์์ ๊ถ"
msgid "Day 2: Morning"
msgstr "2์ผ์ฐจ ์ค์ "
-#: src/SUMMARY.md:76
+#: src/SUMMARY.md:76 src/structs.md:1
msgid "Structs"
msgstr "๊ตฌ์กฐ์ฒด"
-#: src/SUMMARY.md:77
+#: src/SUMMARY.md:77 src/structs/tuple-structs.md:1
msgid "Tuple Structs"
msgstr "ํํ"
-#: src/SUMMARY.md:78
+#: src/SUMMARY.md:78 src/structs/field-shorthand.md:1
msgid "Field Shorthand Syntax"
msgstr "ํ๋ ํ ๋น ๋จ์ถ ๋ฌธ๋ฒ"
-#: src/SUMMARY.md:79
+#: src/SUMMARY.md:79 src/enums.md:1
msgid "Enums"
msgstr "์ด๊ฑฐํ"
-#: src/SUMMARY.md:80
+#: src/SUMMARY.md:80 src/enums/variant-payloads.md:1
msgid "Variant Payloads"
msgstr "๋ฐ์ดํฐ๋ฅผ ํฌํจํ๋ ์ด๊ฑฐํ(Variant Payloads)"
-#: src/SUMMARY.md:81
+#: src/SUMMARY.md:81 src/enums/sizes.md:1
msgid "Enum Sizes"
msgstr "์ด๊ฑฐํ์ ํฌ๊ธฐ"
-#: src/SUMMARY.md:83
+#: src/SUMMARY.md:83 src/methods/receiver.md:1
msgid "Method Receiver"
msgstr "๋ฉ์๋ ๋ฆฌ์๋ฒ(Receiver)"
#: src/SUMMARY.md:84 src/SUMMARY.md:159 src/SUMMARY.md:194
+#: src/methods/example.md:1 src/concurrency/shared_state/example.md:1
msgid "Example"
msgstr "์์ "
-#: src/SUMMARY.md:85
+#: src/SUMMARY.md:85 src/pattern-matching.md:1
msgid "Pattern Matching"
msgstr "ํจํด ๋งค์นญ"
-#: src/SUMMARY.md:86
+#: src/SUMMARY.md:86 src/pattern-matching/destructuring-enums.md:1
msgid "Destructuring Enums"
msgstr "์ด๊ฑฐํ ๋ถํด(์ญ๊ตฌ์กฐํ)"
-#: src/SUMMARY.md:87
+#: src/SUMMARY.md:87 src/pattern-matching/destructuring-structs.md:1
msgid "Destructuring Structs"
msgstr "๊ตฌ์กฐ์ฒด ๋ถํด(์ญ๊ตฌ์กฐํ)"
-#: src/SUMMARY.md:88
+#: src/SUMMARY.md:88 src/pattern-matching/destructuring-arrays.md:1
msgid "Destructuring Arrays"
msgstr "๋ฐฐ์ด ๋ถํด(์ญ๊ตฌ์กฐํ)"
-#: src/SUMMARY.md:89
+#: src/SUMMARY.md:89 src/pattern-matching/match-guards.md:1
msgid "Match Guards"
msgstr "๋งค์น ๊ฐ๋"
-#: src/SUMMARY.md:91
+#: src/SUMMARY.md:91 src/exercises/day-2/health-statistics.md:1
msgid "Health Statistics"
msgstr "๊ฑด๊ฐ์ํ ๋ชจ๋ํฐ๋ง ์์คํ "
-#: src/SUMMARY.md:92
+#: src/SUMMARY.md:92 src/exercises/day-2/solutions-morning.md:3
msgid "Points and Polygons"
msgstr "์ ๊ณผ ๋ค๊ฐํ"
@@ -313,11 +316,11 @@ msgstr "์ ๊ณผ ๋ค๊ฐํ"
msgid "Day 2: Afternoon"
msgstr "2์ผ์ฐจ ์คํ"
-#: src/SUMMARY.md:96
+#: src/SUMMARY.md:96 src/control-flow.md:1
msgid "Control Flow"
msgstr "ํ๋ฆ ์ ์ด"
-#: src/SUMMARY.md:97
+#: src/SUMMARY.md:97 src/control-flow/blocks.md:1
msgid "Blocks"
msgstr "๋ธ๋ก"
@@ -353,7 +356,7 @@ msgstr "match ํํ์"
msgid "break & continue"
msgstr "break์ continue"
-#: src/SUMMARY.md:106
+#: src/SUMMARY.md:106 src/std.md:1
msgid "Standard Library"
msgstr "ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ"
@@ -361,7 +364,7 @@ msgstr "ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ"
msgid "Option and Result"
msgstr "Option๊ณผ Result"
-#: src/SUMMARY.md:108
+#: src/SUMMARY.md:108 src/std/string.md:1
msgid "String"
msgstr "String"
@@ -381,7 +384,7 @@ msgstr "Box"
msgid "Recursive Data Types"
msgstr "์ฌ๊ท์ ์๋ฃ๊ตฌ์กฐ"
-#: src/SUMMARY.md:113
+#: src/SUMMARY.md:113 src/std/box-niche.md:1
msgid "Niche Optimization"
msgstr "๋์น(ํ์) ์ต์ ํ(Niche Optimization)"
@@ -389,27 +392,29 @@ msgstr "๋์น(ํ์) ์ต์ ํ(Niche Optimization)"
msgid "Rc"
msgstr "Rc"
-#: src/SUMMARY.md:115
+#: src/SUMMARY.md:115 src/modules.md:1
msgid "Modules"
msgstr "๋ชจ๋"
-#: src/SUMMARY.md:116
+#: src/SUMMARY.md:116 src/modules/visibility.md:1
msgid "Visibility"
msgstr "๊ฐ์์ฑ"
-#: src/SUMMARY.md:117
+#: src/SUMMARY.md:117 src/modules/paths.md:1
msgid "Paths"
msgstr "๊ฒฝ๋ก"
-#: src/SUMMARY.md:118
+#: src/SUMMARY.md:118 src/modules/filesystem.md:1
msgid "Filesystem Hierarchy"
msgstr "ํ์ผ์์คํ ๊ณ์ธต"
-#: src/SUMMARY.md:120
+#: src/SUMMARY.md:120 src/exercises/day-2/luhn.md:1
+#: src/exercises/day-2/solutions-afternoon.md:3
msgid "Luhn Algorithm"
msgstr "๋ฃฌ ์๊ณ ๋ฆฌ์ฆ"
-#: src/SUMMARY.md:121
+#: src/SUMMARY.md:121 src/exercises/day-2/strings-iterators.md:1
+#: src/exercises/day-2/solutions-afternoon.md:98
msgid "Strings and Iterators"
msgstr "๋ฌธ์์ด๊ณผ ๋ฐ๋ณต์"
@@ -417,19 +422,19 @@ msgstr "๋ฌธ์์ด๊ณผ ๋ฐ๋ณต์"
msgid "Day 3: Morning"
msgstr "3์ผ์ฐจ ์ค์ "
-#: src/SUMMARY.md:129
+#: src/SUMMARY.md:129 src/traits.md:1
msgid "Traits"
msgstr "ํธ๋ ์(Trait)"
-#: src/SUMMARY.md:130
+#: src/SUMMARY.md:130 src/traits/deriving-traits.md:1
msgid "Deriving Traits"
msgstr "ํธ๋ ์ ์์ํ๊ธฐ"
-#: src/SUMMARY.md:131
+#: src/SUMMARY.md:131 src/traits/default-methods.md:1
msgid "Default Methods"
msgstr "๊ธฐ๋ณธ ๋ฉ์๋"
-#: src/SUMMARY.md:132
+#: src/SUMMARY.md:132 src/traits/important-traits.md:1
msgid "Important Traits"
msgstr "์ค์ํ ํธ๋ ์"
@@ -437,7 +442,7 @@ msgstr "์ค์ํ ํธ๋ ์"
msgid "Iterator"
msgstr "Iterator"
-#: src/SUMMARY.md:134
+#: src/SUMMARY.md:134 src/traits/from-iterator.md:1
msgid "FromIterator"
msgstr "FromIterator"
@@ -461,19 +466,19 @@ msgstr "Drop"
msgid "Default"
msgstr "Default"
-#: src/SUMMARY.md:140
+#: src/SUMMARY.md:140 src/generics.md:1
msgid "Generics"
msgstr "์ ๋ค๋ฆญ"
-#: src/SUMMARY.md:141
+#: src/SUMMARY.md:141 src/generics/data-types.md:1
msgid "Generic Data Types"
msgstr "์ ๋ค๋ฆญ ๋ฐ์ดํฐ ํ์ "
-#: src/SUMMARY.md:142
+#: src/SUMMARY.md:142 src/generics/methods.md:1
msgid "Generic Methods"
msgstr "์ ๋ค๋ฆญ ๋ฉ์๋"
-#: src/SUMMARY.md:143
+#: src/SUMMARY.md:143 src/generics/trait-bounds.md:1
msgid "Trait Bounds"
msgstr "์ ๋ค๋ฆญ ํ์ ์ ํ(ํธ๋ ์ ๊ฒฝ๊ณ)"
@@ -481,19 +486,20 @@ msgstr "์ ๋ค๋ฆญ ํ์ ์ ํ(ํธ๋ ์ ๊ฒฝ๊ณ)"
msgid "impl Trait"
msgstr "ํธ๋ ์ ๊ตฌํํ๊ธฐ"
-#: src/SUMMARY.md:145
+#: src/SUMMARY.md:145 src/generics/closures.md:1
msgid "Closures"
msgstr "ํด๋ก์ "
-#: src/SUMMARY.md:146
+#: src/SUMMARY.md:146 src/generics/monomorphization.md:1
msgid "Monomorphization"
msgstr "๋จํํ"
-#: src/SUMMARY.md:147
+#: src/SUMMARY.md:147 src/generics/trait-objects.md:1
msgid "Trait Objects"
msgstr "ํธ๋ ์ ๊ฐ์ฒด"
-#: src/SUMMARY.md:149
+#: src/SUMMARY.md:149 src/exercises/day-3/simple-gui.md:1
+#: src/exercises/day-3/solutions-morning.md:3
msgid "A Simple GUI Library"
msgstr "๊ฐ๋จํ GUI ๋ผ์ด๋ธ๋ฌ๋ฆฌ"
@@ -501,11 +507,11 @@ msgstr "๊ฐ๋จํ GUI ๋ผ์ด๋ธ๋ฌ๋ฆฌ"
msgid "Day 3: Afternoon"
msgstr "3์ผ์ฐจ ์คํ"
-#: src/SUMMARY.md:153
+#: src/SUMMARY.md:153 src/error-handling.md:1
msgid "Error Handling"
msgstr "์ค๋ฅ์ฒ๋ฆฌ"
-#: src/SUMMARY.md:154
+#: src/SUMMARY.md:154 src/error-handling/panics.md:1
msgid "Panics"
msgstr "ํจ๋"
@@ -521,63 +527,64 @@ msgstr "๊ตฌ์กฐํ๋ ์ค๋ฅ์ฒ๋ฆฌ"
msgid "Propagating Errors with ?"
msgstr "'?'๋ฅผ ์ด์ฉํ ์ค๋ฅ ์ ํ"
-#: src/SUMMARY.md:158
+#: src/SUMMARY.md:158 src/error-handling/converting-error-types.md:1
+#: src/error-handling/converting-error-types-example.md:1
msgid "Converting Error Types"
msgstr "์ค๋ฅํ์ ๋ณํ"
-#: src/SUMMARY.md:160
+#: src/SUMMARY.md:160 src/error-handling/deriving-error-enums.md:1
msgid "Deriving Error Enums"
msgstr "๋๋ค๋ฅธ ์ค๋ฅ ์ด๊ฑฐํ"
-#: src/SUMMARY.md:161
+#: src/SUMMARY.md:161 src/error-handling/dynamic-errors.md:1
msgid "Dynamic Error Types"
msgstr "๋์ ์ธ ์๋ฌ ํ์ "
-#: src/SUMMARY.md:162
+#: src/SUMMARY.md:162 src/error-handling/error-contexts.md:1
msgid "Adding Context to Errors"
msgstr "์ค๋ฅ์ ์ํฉ์ ๋ณด ์ถ๊ฐ"
-#: src/SUMMARY.md:163
+#: src/SUMMARY.md:163 src/testing.md:1
msgid "Testing"
msgstr "ํ ์คํธ"
-#: src/SUMMARY.md:164
+#: src/SUMMARY.md:164 src/testing/unit-tests.md:1
msgid "Unit Tests"
msgstr "๋จ์ ํ ์คํธ"
-#: src/SUMMARY.md:165
+#: src/SUMMARY.md:165 src/testing/test-modules.md:1
msgid "Test Modules"
msgstr "ํ ์คํธ ๋ชจ๋"
-#: src/SUMMARY.md:166
+#: src/SUMMARY.md:166 src/testing/doc-tests.md:1
msgid "Documentation Tests"
msgstr "๋ฌธ์ํ์ฃผ์ ํ ์คํธ"
-#: src/SUMMARY.md:167
+#: src/SUMMARY.md:167 src/testing/integration-tests.md:1
msgid "Integration Tests"
msgstr "ํตํฉ ํ ์คํธ"
-#: src/SUMMARY.md:168
+#: src/SUMMARY.md:168 src/unsafe.md:1
msgid "Unsafe Rust"
msgstr "์์ ํ์ง ์์ ๋ฌ์คํธ"
-#: src/SUMMARY.md:169
+#: src/SUMMARY.md:169 src/unsafe/raw-pointers.md:1
msgid "Dereferencing Raw Pointers"
msgstr "์์ ํฌ์ธํฐ ์ญ์ฐธ์กฐ(๋ฐ๋ผ๊ฐ๊ธฐ)"
-#: src/SUMMARY.md:170
+#: src/SUMMARY.md:170 src/unsafe/mutable-static-variables.md:1
msgid "Mutable Static Variables"
msgstr "์ ์ ๊ฐ๋ณ ๋ณ์"
-#: src/SUMMARY.md:171
+#: src/SUMMARY.md:171 src/unsafe/unions.md:1
msgid "Unions"
msgstr "Unions"
-#: src/SUMMARY.md:172
+#: src/SUMMARY.md:172 src/unsafe/calling-unsafe-functions.md:1
msgid "Calling Unsafe Functions"
msgstr "์์ ํ์ง ์์ ํจ์ ํธ์ถ"
-#: src/SUMMARY.md:173
+#: src/SUMMARY.md:173 src/unsafe/writing-unsafe-functions.md:1
msgid "Writing Unsafe Functions"
msgstr "์์ ํ์ง ์์ ํจ์ ์์ฑํ๊ธฐ"
@@ -585,11 +592,12 @@ msgstr "์์ ํ์ง ์์ ํจ์ ์์ฑํ๊ธฐ"
msgid "Extern Functions"
msgstr "์ธ๋ถ(๋ค๋ฅธ์ธ์ด) ํจ์๋ค"
-#: src/SUMMARY.md:175
+#: src/SUMMARY.md:175 src/unsafe/unsafe-traits.md:1
msgid "Implementing Unsafe Traits"
msgstr "์์ ํ์ง ์์ ํธ๋ ์ ๊ตฌํํ๊ธฐ"
-#: src/SUMMARY.md:177
+#: src/SUMMARY.md:177 src/exercises/day-3/safe-ffi-wrapper.md:1
+#: src/exercises/day-3/solutions-afternoon.md:3
msgid "Safe FFI Wrapper"
msgstr "FFI๋ํผ"
@@ -601,27 +609,27 @@ msgstr "4์ผ์ฐจ ์ค์ "
msgid "Concurrency"
msgstr "๋์์ฑ"
-#: src/SUMMARY.md:186
+#: src/SUMMARY.md:186 src/concurrency/threads.md:1
msgid "Threads"
msgstr "์ค๋ ๋"
-#: src/SUMMARY.md:187
+#: src/SUMMARY.md:187 src/concurrency/scoped-threads.md:1
msgid "Scoped Threads"
msgstr "๋ฒ์ ์ค๋ ๋(Scoped Threads)"
-#: src/SUMMARY.md:188
+#: src/SUMMARY.md:188 src/concurrency/channels.md:1
msgid "Channels"
msgstr "์ฑ๋"
-#: src/SUMMARY.md:189
+#: src/SUMMARY.md:189 src/concurrency/channels/unbounded.md:1
msgid "Unbounded Channels"
msgstr "๋ฌด๊ฒฝ๊ณ ์ฑ๋"
-#: src/SUMMARY.md:190
+#: src/SUMMARY.md:190 src/concurrency/channels/bounded.md:1
msgid "Bounded Channels"
msgstr "๊ฒฝ๊ณ ์ฑ๋"
-#: src/SUMMARY.md:191
+#: src/SUMMARY.md:191 src/concurrency/shared_state.md:1
msgid "Shared State"
msgstr "์ํ ๊ณต์ "
@@ -645,15 +653,16 @@ msgstr "Send"
msgid "Sync"
msgstr "Sync"
-#: src/SUMMARY.md:198
+#: src/SUMMARY.md:198 src/concurrency/send-sync/examples.md:1
msgid "Examples"
msgstr "์์ "
-#: src/SUMMARY.md:200
+#: src/SUMMARY.md:200 src/exercises/day-4/dining-philosophers.md:1
+#: src/exercises/day-4/solutions-morning.md:3
msgid "Dining Philosophers"
msgstr "์์ฌํ๋ ์ฒ ํ์๋ค"
-#: src/SUMMARY.md:201
+#: src/SUMMARY.md:201 src/exercises/day-4/link-checker.md:1
msgid "Multi-threaded Link Checker"
msgstr "๋ฉํฐ์ค๋ ๋ ๋งํฌ ๊ฒ์ฌ๊ธฐ"
@@ -661,15 +670,15 @@ msgstr "๋ฉํฐ์ค๋ ๋ ๋งํฌ ๊ฒ์ฌ๊ธฐ"
msgid "Day 4: Afternoon (Android)"
msgstr "4์ผ์ฐจ ์คํ (์๋๋ก์ด๋)"
-#: src/SUMMARY.md:203
+#: src/SUMMARY.md:203 src/running-the-course/day-4.md:15 src/android.md:1
msgid "Android"
msgstr "์๋๋ก์ด๋"
-#: src/SUMMARY.md:208
+#: src/SUMMARY.md:208 src/android/setup.md:1
msgid "Setup"
msgstr "์ค์น"
-#: src/SUMMARY.md:209
+#: src/SUMMARY.md:209 src/android/build-rules.md:1
msgid "Build Rules"
msgstr "๋น๋ ๊ท์น"
@@ -681,7 +690,7 @@ msgstr "๋ฐ์ด๋๋ฆฌ"
msgid "Library"
msgstr "๋ผ์ด๋ธ๋ฌ๋ฆฌ"
-#: src/SUMMARY.md:212
+#: src/SUMMARY.md:212 src/android/aidl.md:1
msgid "AIDL"
msgstr "AIDL"
@@ -697,7 +706,7 @@ msgstr "์๋น์ค ๊ตฌํ"
msgid "Server"
msgstr "AIDL ์๋ฒ"
-#: src/SUMMARY.md:216
+#: src/SUMMARY.md:216 src/android/aidl/deploy.md:1
msgid "Deploy"
msgstr "๋ฐฐํฌ"
@@ -705,15 +714,15 @@ msgstr "๋ฐฐํฌ"
msgid "Client"
msgstr "ํด๋ผ์ด์ธํธ"
-#: src/SUMMARY.md:218
+#: src/SUMMARY.md:218 src/android/aidl/changing.md:1
msgid "Changing API"
msgstr "API ์์ "
-#: src/SUMMARY.md:219
+#: src/SUMMARY.md:219 src/android/logging.md:1
msgid "Logging"
msgstr "๋ก๊น "
-#: src/SUMMARY.md:220
+#: src/SUMMARY.md:220 src/android/interoperability.md:1
msgid "Interoperability"
msgstr "์ํธ์ด์ฉ์ฑ"
@@ -729,7 +738,7 @@ msgstr "Bindgen์ ์ฌ์ฉํ Cํธ์ถ"
msgid "Calling Rust from C"
msgstr "C์์ ๋ฌ์คํธ ํธ์ถ"
-#: src/SUMMARY.md:224
+#: src/SUMMARY.md:224 src/android/interoperability/cpp.md:1
msgid "With C++"
msgstr "C++์์ ์ํธ์ด์ฉ์ฑ"
@@ -741,7 +750,7 @@ msgstr "Java์์ ์ํธ์ด์ฉ์ฑ"
msgid "Final Words"
msgstr "๋์ผ๋ก..."
-#: src/SUMMARY.md:230
+#: src/SUMMARY.md:230 src/thanks.md:1
msgid "Thanks!"
msgstr "๊ฐ์ฌ์ธ์ฌ"
@@ -749,11 +758,11 @@ msgstr "๊ฐ์ฌ์ธ์ฌ"
msgid "Other Resources"
msgstr "๋ฌ์คํธ ์ฐธ๊ณ ์๋ฃ"
-#: src/SUMMARY.md:232
+#: src/SUMMARY.md:232 src/credits.md:1
msgid "Credits"
msgstr "๋์์ฃผ์ ๋ถ๋ค"
-#: src/SUMMARY.md:236
+#: src/SUMMARY.md:236 src/exercises/solutions.md:1
msgid "Solutions"
msgstr "ํด๋ต"
@@ -785,12 +794,11 @@ msgstr "3์ผ์ฐจ ์คํ"
msgid "Day 4 Morning"
msgstr "4์ผ์ฐจ ์ค์ "
-#: src/welcome.md:1
-msgid "# Welcome to Comprehensive Rust ๐ฆ"
-msgstr "# Welcome to Comprehensive Rust ๐ฆ"
-
#: src/welcome.md:3
-msgid "[](https://github.com/google/comprehensive-rust/actions/workflows/build.yml)"
+msgid ""
+"[](https://github.com/"
+"google/comprehensive-rust/actions/workflows/build.yml)"
msgstr ""
#: src/welcome.md:3
@@ -799,11 +807,19 @@ msgstr "๋น๋ ์ํฌํ๋ก"
#: src/welcome.md:3
msgid ""
-"[](https://github.com/google/comprehensive-rust/actions/workflows/build.yml)\n"
-"[](https://github.com/google/comprehensive-rust/graphs/contributors)"
+"[](https://github.com/"
+"google/comprehensive-rust/actions/workflows/build.yml) [](https://github.com/google/"
+"comprehensive-rust/graphs/contributors)"
msgstr ""
-"[](https://github.com/google/comprehensive-rust/actions/workflows/build.yml)\n"
-"[](https://github.com/google/comprehensive-rust/graphs/contributors)"
+"[](https://github.com/"
+"google/comprehensive-rust/actions/workflows/build.yml) [](https://github.com/google/"
+"comprehensive-rust/graphs/contributors)"
#: src/welcome.md:4
msgid "GitHub contributors"
@@ -811,246 +827,167 @@ msgstr "GitHub ์ฐธ์ฌ์"
#: src/welcome.md:4
msgid ""
-"[](https://github.com/google/comprehensive-rust/graphs/contributors)\n"
-"[](https://github.com/google/comprehensive-rust/stargazers)"
+"[](https://github.com/google/"
+"comprehensive-rust/graphs/contributors) [](https://github."
+"com/google/comprehensive-rust/stargazers)"
msgstr ""
-"[](https://github.com/google/comprehensive-rust/graphs/contributors)\n"
-"[](https://github.com/google/comprehensive-rust/stargazers)"
+"[](https://github.com/google/"
+"comprehensive-rust/graphs/contributors) [](https://github."
+"com/google/comprehensive-rust/stargazers)"
#: src/welcome.md:5
msgid "GitHub stars"
msgstr "GitHub stars"
#: src/welcome.md:5
-msgid "[](https://github.com/google/comprehensive-rust/stargazers)"
-msgstr "[](https://github.com/google/comprehensive-rust/stargazers)"
+msgid ""
+"[](https://github.com/google/comprehensive-rust/"
+"stargazers)"
+msgstr ""
+"[](https://github.com/google/comprehensive-rust/"
+"stargazers)"
#: src/welcome.md:7
msgid ""
-"This is a four day Rust course developed by the Android team. The course covers\n"
-"the full spectrum of Rust, from basic syntax to advanced topics like generics\n"
-"and error handling. It also includes Android-specific content on the last day."
-msgstr "์ด 4์ผ์ง๋ฆฌ ๋ฌ์คํธ ๊ฐ์๋ ์๋๋ก์ด๋ ํ์ด ๋ง๋ค์์ต๋๋ค. ๊ธฐ๋ณธ ๋ฌธ๋ฒ๋ถํฐ ์ ๋ค๋ฆญ, ์๋ฌ ํธ๋ค๋ง๊ณผ ๊ฐ์ ๊ณ ๊ธ์ฃผ์ ๊น์ง ๋ฌ์คํธ์ ๋ชจ๋ ๊ฒ์ ํฌํจํฉ๋๋ค. ๋ง์ง๋ง ๋ ์๋ ์๋๋ก์ด๋์ ๋ํ ๊ฒ ๊น์ง ๋ค๋ฃน๋๋ค."
+"This is a four day Rust course developed by the Android team. The course "
+"covers the full spectrum of Rust, from basic syntax to advanced topics like "
+"generics and error handling. It also includes Android-specific content on "
+"the last day."
+msgstr ""
+"์ด 4์ผ์ง๋ฆฌ ๋ฌ์คํธ ๊ฐ์๋ ์๋๋ก์ด๋ ํ์ด ๋ง๋ค์์ต๋๋ค. ๊ธฐ๋ณธ ๋ฌธ๋ฒ๋ถํฐ ์ ๋ค๋ฆญ, "
+"์๋ฌ ํธ๋ค๋ง๊ณผ ๊ฐ์ ๊ณ ๊ธ์ฃผ์ ๊น์ง ๋ฌ์คํธ์ ๋ชจ๋ ๊ฒ์ ํฌํจํฉ๋๋ค. ๋ง์ง๋ง ๋ ์๋ "
+"์๋๋ก์ด๋์ ๋ํ ๊ฒ ๊น์ง ๋ค๋ฃน๋๋ค."
#: src/welcome.md:11
msgid ""
-"The goal of the course is to teach you Rust. We assume you don't know anything\n"
-"about Rust and hope to:"
-msgstr "๊ฐ์๋ ๋น์ ์ด ๋ฌ์คํธ์ ๋ํด์ ์๋ฌด๊ฒ๋ ๋ชจ๋ฅธ๋ค๊ณ ๊ฐ์ ํ๊ณ ์๋์ ๋ชฉํ๋ฅผ ๊ฐ์ง๊ณ ์์ต๋๋ค:"
+"The goal of the course is to teach you Rust. We assume you don't know "
+"anything about Rust and hope to:"
+msgstr ""
+"๊ฐ์๋ ๋น์ ์ด ๋ฌ์คํธ์ ๋ํด์ ์๋ฌด๊ฒ๋ ๋ชจ๋ฅธ๋ค๊ณ ๊ฐ์ ํ๊ณ ์๋์ ๋ชฉํ๋ฅผ ๊ฐ์ง"
+"๊ณ ์์ต๋๋ค:"
#: src/welcome.md:14
-msgid ""
-"* Give you a comprehensive understanding of the Rust syntax and language.\n"
-"* Enable you to modify existing programs and write new programs in Rust.\n"
-"* Show you common Rust idioms."
-msgstr ""
-"* ๋ฌ์คํธ ๊ตฌ๋ฌธ๊ณผ ์ธ์ด์ ๋ํ ํฌ๊ด์ ์ธ ์ดํด๋ฅผ ์ ๊ณตํฉ๋๋ค.\n"
-"* ๊ธฐ์กด ํ๋ก๊ทธ๋จ์ ์์ ํ๊ณ ๋ฌ์คํธ์์ ์ ํ๋ก๊ทธ๋จ์ ์์ฑํ ์ ์์ต๋๋ค.\n"
-"* ์ผ๋ฐ์ ์ธ ๋ฌ์คํธ ๊ด์ฉ๊ตฌ๋ฅผ ๋ณด์ฌ์ค๋๋ค."
+msgid "Give you a comprehensive understanding of the Rust syntax and language."
+msgstr "๋ฌ์คํธ ๊ตฌ๋ฌธ๊ณผ ์ธ์ด์ ๋ํ ํฌ๊ด์ ์ธ ์ดํด๋ฅผ ์ ๊ณตํฉ๋๋ค."
+
+#: src/welcome.md:15
+msgid "Enable you to modify existing programs and write new programs in Rust."
+msgstr "๊ธฐ์กด ํ๋ก๊ทธ๋จ์ ์์ ํ๊ณ ๋ฌ์คํธ์์ ์ ํ๋ก๊ทธ๋จ์ ์์ฑํ ์ ์์ต๋๋ค."
+
+#: src/welcome.md:16
+msgid "Show you common Rust idioms."
+msgstr "์ผ๋ฐ์ ์ธ ๋ฌ์คํธ ๊ด์ฉ๊ตฌ๋ฅผ ๋ณด์ฌ์ค๋๋ค."
#: src/welcome.md:18
msgid "On Day 4, we will cover Android-specific things such as:"
msgstr "4์ผ์ฐจ ๊ฐ์์ ์ฐ๋ฆฌ๋ ์๋์ ๊ฐ์ ์๋๋ก์ด๋ ํนํ๋ ๋ด์ฉ๋ค๋ ์ค๋ช ํฉ๋๋ค:"
#: src/welcome.md:20
-msgid ""
-"* Building Android components in Rust.\n"
-"* AIDL servers and clients.\n"
-"* Interoperability with C, C++, and Java."
-msgstr ""
-"* ๋ฌ์คํธ์์ Android ๊ตฌ์ฑ ์์๋ฅผ ๊ตฌ์ถ.\n"
-"* AIDL ์๋ฒ ๋ฐ ํด๋ผ์ด์ธํธ.\n"
-"* C, C++ ๋ฐ Java์์ ์ํธ ์ด์ฉ์ฑ."
+msgid "Building Android components in Rust."
+msgstr "๋ฌ์คํธ์์ Android ๊ตฌ์ฑ ์์๋ฅผ ๊ตฌ์ถ."
+
+#: src/welcome.md:21
+msgid "AIDL servers and clients."
+msgstr "AIDL ์๋ฒ ๋ฐ ํด๋ผ์ด์ธํธ."
+
+#: src/welcome.md:22
+msgid "Interoperability with C, C++, and Java."
+msgstr "C, C++ ๋ฐ Java์์ ์ํธ ์ด์ฉ์ฑ."
#: src/welcome.md:24
msgid ""
-"It is important to note that this course does not cover Android **application** \n"
-"development in Rust, and that the Android-specific parts are specifically about\n"
-"writing code for Android itself, the operating system. "
-msgstr "์ด ๊ฐ์์์๋ ๋ฌ์คํธ๋ก ์๋๋ก์ด๋ **์ ํ๋ฆฌ์ผ์ด์ **์ ๊ฐ๋ฐํ๋ ๊ฒ์ ๋ค๋ฃจ์ง ์์ต๋๋ค. ์ด ๊ฐ์์์ ๋ค๋ฃจ๋ ์๋๋ก์ด๋ ํนํ๋ ๋ด์ฉ์ ์๋๋ก์ด๋ OS์ ์ผ๋ถ๋ฅผ ๋ฌ์คํธ๋ก ๊ฐ๋ฐํ๋ ๊ฒ์ ๋ํ ๊ฒ์ ๋๋ค. "
+"It is important to note that this course does not cover Android "
+"**application** development in Rust, and that the Android-specific parts "
+"are specifically about writing code for Android itself, the operating "
+"system. "
+msgstr ""
+"์ด ๊ฐ์์์๋ ๋ฌ์คํธ๋ก ์๋๋ก์ด๋ **์ ํ๋ฆฌ์ผ์ด์ **์ ๊ฐ๋ฐํ๋ ๊ฒ์ ๋ค๋ฃจ์ง ์"
+"์ต๋๋ค. ์ด ๊ฐ์์์ ๋ค๋ฃจ๋ ์๋๋ก์ด๋ ํนํ๋ ๋ด์ฉ์ ์๋๋ก์ด๋ OS์ ์ผ๋ถ๋ฅผ ๋ฌ"
+"์คํธ๋ก ๊ฐ๋ฐํ๋ ๊ฒ์ ๋ํ ๊ฒ์ ๋๋ค. "
#: src/welcome.md:28
-msgid "## Non-Goals"
-msgstr "## ์ ์ธ์ฌํญ"
+msgid "Non-Goals"
+msgstr "์ ์ธ์ฌํญ"
#: src/welcome.md:30
msgid ""
-"Rust is a large language and we won't be able to cover all of it in a few days.\n"
-"Some non-goals of this course are:"
-msgstr "๋ฌ์คํธ๋ ๋ฉฐ์น ๋ง์ ๋ชจ๋ ๊ฒ์ ๋ค๋ฃจ๊ธฐ์๋ ๋๋ฌด ํฐ ์ธ์ด์ ๋๋ค. ๊ทธ๋์ ์๋์ ๊ฐ์๊ฒ์ ๋ชฉํ๋ก ํ์ง ์์ต๋๋ค:"
+"Rust is a large language and we won't be able to cover all of it in a few "
+"days. Some non-goals of this course are:"
+msgstr ""
+"๋ฌ์คํธ๋ ๋ฉฐ์น ๋ง์ ๋ชจ๋ ๊ฒ์ ๋ค๋ฃจ๊ธฐ์๋ ๋๋ฌด ํฐ ์ธ์ด์ ๋๋ค. ๊ทธ๋์ ์๋์ ๊ฐ์"
+"๊ฒ์ ๋ชฉํ๋ก ํ์ง ์์ต๋๋ค:"
#: src/welcome.md:33
msgid ""
-"* Learn how to use async Rust --- we'll only mention async Rust when\n"
-" covering traditional concurrency primitives. Please see [Asynchronous\n"
-" Programming in Rust](https://rust-lang.github.io/async-book/) instead for\n"
-" details on this topic.\n"
-"* Learn how to develop macros, please see [Chapter 19.5 in the Rust\n"
-" Book](https://doc.rust-lang.org/book/ch19-06-macros.html) and [Rust by\n"
-" Example](https://doc.rust-lang.org/rust-by-example/macros.html) instead."
+"Learn how to use async Rust --- we'll only mention async Rust when covering "
+"traditional concurrency primitives. Please see [Asynchronous Programming in "
+"Rust](https://rust-lang.github.io/async-book/) instead for details on this "
+"topic."
+msgstr ""
+"๋น๋๊ธฐ์ ๋ฌ์คํธ ์ฌ์ฉ๋ฒ. ๊ฐ๋จํ๊ฒ ์ธ๊ธ์ ๋๋ ํ๊ฒ ์ง๋ง ์ข ๋ ์์ธํ ๋ด์ฉ์ "
+"[Asynchronous Programming in Rust](https://rust-lang.github.io/async-book/)"
+"๋ฅผ ์ฐธ์กฐํด์ฃผ์ธ์."
+
+#: src/welcome.md:37
+msgid ""
+"Learn how to develop macros, please see [Chapter 19.5 in the Rust Book]"
+"(https://doc.rust-lang.org/book/ch19-06-macros.html) and [Rust by Example]"
+"(https://doc.rust-lang.org/rust-by-example/macros.html) instead."
msgstr ""
-"* ๋น๋๊ธฐ์ ๋ฌ์คํธ ์ฌ์ฉ๋ฒ. ๊ฐ๋จํ๊ฒ ์ธ๊ธ์ ๋๋ ํ๊ฒ ์ง๋ง ์ข ๋ ์์ธํ ๋ด์ฉ์ [Asynchronous Programming in Rust](https://rust-lang.github.io/async-book/)๋ฅผ ์ฐธ์กฐํด์ฃผ์ธ์.\n"
-"* ๋งคํฌ๋ก๋ฅผ ๊ฐ๋ฐํ๋ ๋ฐฉ๋ฒ. [Chapter 19.5 in the Rust Book](https://doc.rust-lang.org/book/ch19-06-macros.html)์ [Rust by Example](https://doc.rust-lang.org/rust-by-example/macros.html)๋ฅผ ์ฐธ์กฐํ์ธ์."
+"๋งคํฌ๋ก๋ฅผ ๊ฐ๋ฐํ๋ ๋ฐฉ๋ฒ. [Chapter 19.5 in the Rust Book](https://doc.rust-"
+"lang.org/book/ch19-06-macros.html)์ [Rust by Example](https://doc.rust-lang."
+"org/rust-by-example/macros.html)๋ฅผ ์ฐธ์กฐํ์ธ์."
#: src/welcome.md:41
-msgid "## Assumptions"
-msgstr "## ๋ ์ ์์ค์ ๋ํ ๊ฐ์ "
+msgid "Assumptions"
+msgstr "๋ ์ ์์ค์ ๋ํ ๊ฐ์ "
#: src/welcome.md:43
msgid ""
-"The course assumes that you already know how to program. Rust is a statically\n"
-"typed language and we will sometimes make comparisons with C and C++ to better\n"
-"explain or contrast the Rust approach."
-msgstr "๋ณธ ๊ฐ์๋ ์ฌ๋ฌ๋ถ์ด ํ๋ก๊ทธ๋๋ฐ ์์ฒด์ ๋ํด์๋ ์๊ณ ์๋ค๊ณ ๊ฐ์ ํฉ๋๋ค. ๋ฌ์คํธ๋ ์ ์ ํ์ ์ธ์ด์ด๋ฉฐ, ๊ฐ์ข์์๋ C/C++ ์์ ๋น๊ต, ๋์กฐ๋ฅผ ํตํด ๋ฌ์คํธ๋ฅผ ์ค๋ช ํ ๊ฒ์ ๋๋ค."
+"The course assumes that you already know how to program. Rust is a "
+"statically typed language and we will sometimes make comparisons with C and "
+"C++ to better explain or contrast the Rust approach."
+msgstr ""
+"๋ณธ ๊ฐ์๋ ์ฌ๋ฌ๋ถ์ด ํ๋ก๊ทธ๋๋ฐ ์์ฒด์ ๋ํด์๋ ์๊ณ ์๋ค๊ณ ๊ฐ์ ํฉ๋๋ค. ๋ฌ์คํธ"
+"๋ ์ ์ ํ์ ์ธ์ด์ด๋ฉฐ, ๊ฐ์ข์์๋ C/C++ ์์ ๋น๊ต, ๋์กฐ๋ฅผ ํตํด ๋ฌ์คํธ๋ฅผ ์ค๋ช "
+"ํ ๊ฒ์ ๋๋ค."
#: src/welcome.md:47
msgid ""
-"If you know how to program in a dynamically typed language such as Python or\n"
+"If you know how to program in a dynamically typed language such as Python or "
"JavaScript, then you will be able to follow along just fine too."
-msgstr "C/C++์ ๋ชจ๋ฅด๋๋ผ๋ ๋์ ํ์ ์ธ์ด(Python์ด๋ JavaScript ๋ฑ) ํ๋ก๊ทธ๋๋ฐ ๊ฒฝํ์ด ์๋ค๋ฉด ๋ฐ๋ผ์ค๋๋ฐ ํฐ ๋ฌธ์ ๋ ์์ ๊ฒ์ ๋๋ค."
-
-#: src/welcome.md:50 src/cargo/rust-ecosystem.md:19
-#: src/cargo/code-samples.md:22 src/cargo/running-locally.md:68
-#: src/welcome-day-1.md:14 src/welcome-day-1/what-is-rust.md:19
-#: src/hello-world.md:20 src/hello-world/small-example.md:21 src/why-rust.md:9
-#: src/why-rust/compile-time.md:14 src/why-rust/runtime.md:8
-#: src/why-rust/modern.md:19 src/basic-syntax/compound-types.md:28
-#: src/basic-syntax/slices.md:18 src/basic-syntax/string-slices.md:25
-#: src/basic-syntax/functions.md:33 src/basic-syntax/functions-interlude.md:25
-#: src/exercises/day-1/morning.md:9 src/exercises/day-1/for-loops.md:90
-#: src/basic-syntax/variables.md:15 src/basic-syntax/type-inference.md:24
-#: src/basic-syntax/static-and-const.md:46
-#: src/basic-syntax/scopes-shadowing.md:23 src/memory-management/stack.md:26
-#: src/memory-management/rust.md:12 src/ownership/move-semantics.md:20
-#: src/ownership/moves-function-calls.md:18 src/ownership/copy-clone.md:33
-#: src/ownership/borrowing.md:25 src/ownership/shared-unique-borrows.md:23
-#: src/ownership/lifetimes-function-calls.md:27
-#: src/ownership/lifetimes-data-structures.md:23
-#: src/exercises/day-1/afternoon.md:9 src/exercises/day-1/book-library.md:102
-#: src/structs/tuple-structs.md:35 src/structs/field-shorthand.md:25
-#: src/enums.md:31 src/enums/variant-payloads.md:33 src/enums/sizes.md:27
-#: src/methods.md:28 src/methods/receiver.md:23 src/methods/example.md:44
-#: src/pattern-matching.md:23 src/pattern-matching/destructuring-enums.md:33
-#: src/pattern-matching/destructuring-structs.md:21
-#: src/pattern-matching/destructuring-arrays.md:19
-#: src/pattern-matching/match-guards.md:20 src/exercises/day-2/morning.md:9
-#: src/exercises/day-2/points-polygons.md:115 src/control-flow/blocks.md:40
-#: src/control-flow/if-expressions.md:29
-#: src/control-flow/if-let-expressions.md:19
-#: src/control-flow/while-let-expressions.md:25
-#: src/control-flow/for-expressions.md:22
-#: src/control-flow/loop-expressions.md:23
-#: src/control-flow/match-expressions.md:25 src/std.md:23
-#: src/std/option-result.md:16 src/std/string.md:28 src/std/vec.md:35
-#: src/std/hashmap.md:36 src/std/box.md:32 src/std/box-recursive.md:31
-#: src/std/rc.md:29 src/modules.md:26 src/modules/visibility.md:37
-#: src/modules/filesystem.md:24 src/exercises/day-2/afternoon.md:5
-#: src/traits.md:39 src/traits/iterator.md:30 src/traits/from-iterator.md:15
-#: src/traits/from-into.md:27 src/traits/operators.md:24 src/traits/drop.md:32
-#: src/traits/default.md:38 src/generics/methods.md:23
-#: src/generics/trait-bounds.md:33 src/generics/impl-trait.md:22
-#: src/generics/closures.md:23 src/exercises/day-3/morning.md:5
-#: src/error-handling/result.md:25 src/error-handling/try-operator.md:48
-#: src/error-handling/converting-error-types-example.md:48
-#: src/error-handling/deriving-error-enums.md:37
-#: src/error-handling/dynamic-errors.md:34
-#: src/error-handling/error-contexts.md:33 src/unsafe.md:26
-#: src/unsafe/raw-pointers.md:24 src/unsafe/mutable-static-variables.md:30
-#: src/unsafe/unions.md:19 src/unsafe/writing-unsafe-functions.md:31
-#: src/unsafe/extern-functions.md:19 src/unsafe/unsafe-traits.md:28
-#: src/exercises/day-3/afternoon.md:5 src/welcome-day-4.md:6
-#: src/concurrency/threads.md:28 src/concurrency/scoped-threads.md:35
-#: src/concurrency/channels.md:25 src/concurrency/shared_state/arc.md:27
-#: src/concurrency/shared_state/mutex.md:29
-#: src/concurrency/shared_state/example.md:21 src/concurrency/send-sync.md:18
-#: src/concurrency/send-sync/sync.md:12 src/exercises/day-4/morning.md:10
-#: src/android/interoperability/with-c/rust.md:81
-#: src/exercises/day-4/android.md:10
-msgid ""
-msgstr ""
+msgstr ""
+"C/C++์ ๋ชจ๋ฅด๋๋ผ๋ ๋์ ํ์ ์ธ์ด(Python์ด๋ JavaScript ๋ฑ) ํ๋ก๊ทธ๋๋ฐ ๊ฒฝํ"
+"์ด ์๋ค๋ฉด ๋ฐ๋ผ์ค๋๋ฐ ํฐ ๋ฌธ์ ๋ ์์ ๊ฒ์ ๋๋ค."
#: src/welcome.md:52
msgid ""
-"This is an example of a _speaker note_. We will use these to add additional\n"
-"information to the slides. This could be key points which the instructor should\n"
-"cover as well as answers to typical questions which come up in class."
-msgstr "์ด๊ฒ์ \"๋ฐํ์ ๋ ธํธ\"์ ์์ ์ ๋๋ค. ์ด ๋ถ๋ถ์ ์ด์ฉํด์ ์ถ๊ฐ ์ ๋ณด๋ฅผ ์ ๊ณตํฉ๋๋ค. ์ฃผ๋ก ๊ฐ์์ค์์ ์ ๊ธฐ๋๋ ์ผ๋ฐ์ ์ธ ์ง๋ฌธ์ ๋ํ ๋ต๋ณ๊ณผ ๊ฐ์ฌ๊ฐ ๋ค๋ฃจ์ด์ผ ํ ํค ํฌ์ธํธ์ผ ์ ์์ต๋๋ค."
-
-#: src/welcome.md:56 src/cargo/rust-ecosystem.md:67
-#: src/cargo/code-samples.md:35 src/cargo/running-locally.md:74
-#: src/welcome-day-1.md:42 src/welcome-day-1/what-is-rust.md:29
-#: src/hello-world.md:40 src/hello-world/small-example.md:44 src/why-rust.md:24
-#: src/why-rust/compile-time.md:35 src/why-rust/runtime.md:22
-#: src/why-rust/modern.md:66 src/basic-syntax/compound-types.md:62
-#: src/basic-syntax/references.md:28 src/basic-syntax/slices.md:36
-#: src/basic-syntax/string-slices.md:44 src/basic-syntax/functions.md:54
-#: src/exercises/day-1/morning.md:28 src/exercises/day-1/for-loops.md:95
-#: src/basic-syntax/variables.md:20 src/basic-syntax/type-inference.md:48
-#: src/basic-syntax/static-and-const.md:52
-#: src/basic-syntax/scopes-shadowing.md:39 src/memory-management/stack.md:49
-#: src/memory-management/rust.md:18 src/ownership/move-semantics.md:26
-#: src/ownership/moves-function-calls.md:26 src/ownership/copy-clone.md:51
-#: src/ownership/borrowing.md:51 src/ownership/shared-unique-borrows.md:29
-#: src/ownership/lifetimes-function-calls.md:60
-#: src/ownership/lifetimes-data-structures.md:30
-#: src/exercises/day-1/afternoon.md:15 src/exercises/day-1/book-library.md:106
-#: src/structs.md:41 src/structs/tuple-structs.md:43
-#: src/structs/field-shorthand.md:72 src/enums.md:41
-#: src/enums/variant-payloads.md:45 src/enums/sizes.md:155 src/methods.md:41
-#: src/methods/receiver.md:29 src/methods/example.md:53
-#: src/pattern-matching.md:35 src/pattern-matching/destructuring-enums.md:39
-#: src/pattern-matching/destructuring-structs.md:25
-#: src/pattern-matching/destructuring-arrays.md:46
-#: src/pattern-matching/match-guards.md:28 src/exercises/day-2/morning.md:15
-#: src/exercises/day-2/points-polygons.md:125 src/control-flow/blocks.md:46
-#: src/control-flow/if-expressions.md:33
-#: src/control-flow/if-let-expressions.md:26
-#: src/control-flow/while-let-expressions.md:30
-#: src/control-flow/for-expressions.md:29
-#: src/control-flow/loop-expressions.md:27
-#: src/control-flow/match-expressions.md:32 src/std.md:31
-#: src/std/option-result.md:25 src/std/string.md:40 src/std/vec.md:49
-#: src/std/hashmap.md:66 src/std/box.md:39 src/std/box-recursive.md:41
-#: src/std/rc.md:69 src/modules.md:32 src/modules/visibility.md:48
-#: src/modules/filesystem.md:53 src/exercises/day-2/afternoon.md:11
-#: src/traits.md:53 src/traits/iterator.md:39 src/traits/from-iterator.md:26
-#: src/traits/from-into.md:33 src/traits/operators.md:38 src/traits/drop.md:42
-#: src/traits/default.md:47 src/generics/methods.md:31
-#: src/generics/trait-bounds.md:50 src/generics/impl-trait.md:38
-#: src/generics/closures.md:38 src/exercises/day-3/morning.md:11
-#: src/error-handling/result.md:33 src/error-handling/try-operator.md:55
-#: src/error-handling/converting-error-types-example.md:60
-#: src/error-handling/deriving-error-enums.md:45
-#: src/error-handling/dynamic-errors.md:41
-#: src/error-handling/error-contexts.md:42 src/unsafe.md:32
-#: src/unsafe/raw-pointers.md:42 src/unsafe/mutable-static-variables.md:35
-#: src/unsafe/unions.md:28 src/unsafe/writing-unsafe-functions.md:38
-#: src/unsafe/extern-functions.md:28 src/unsafe/unsafe-traits.md:37
-#: src/exercises/day-3/afternoon.md:11 src/welcome-day-4.md:11
-#: src/concurrency/threads.md:45 src/concurrency/scoped-threads.md:40
-#: src/concurrency/channels.md:32 src/concurrency/shared_state/arc.md:38
-#: src/concurrency/shared_state/mutex.md:45
-#: src/concurrency/shared_state/example.md:56 src/concurrency/send-sync.md:23
-#: src/concurrency/send-sync/sync.md:18 src/exercises/day-4/morning.md:16
-#: src/android/interoperability/with-c/rust.md:86
-#: src/exercises/day-4/android.md:15
-msgid ""
-msgstr ""
-
-#: src/running-the-course.md:1
-msgid "# Running the Course"
-msgstr "# ๊ฐ์ ์งํ ๋ฐฉ์"
+"This is an example of a _speaker note_. We will use these to add additional "
+"information to the slides. This could be key points which the instructor "
+"should cover as well as answers to typical questions which come up in class."
+msgstr ""
+"์ด๊ฒ์ \"๋ฐํ์ ๋ ธํธ\"์ ์์ ์ ๋๋ค. ์ด ๋ถ๋ถ์ ์ด์ฉํด์ ์ถ๊ฐ ์ ๋ณด๋ฅผ ์ ๊ณตํฉ๋"
+"๋ค. ์ฃผ๋ก ๊ฐ์์ค์์ ์ ๊ธฐ๋๋ ์ผ๋ฐ์ ์ธ ์ง๋ฌธ์ ๋ํ ๋ต๋ณ๊ณผ ๊ฐ์ฌ๊ฐ ๋ค๋ฃจ์ด์ผ ํ "
+"ํค ํฌ์ธํธ์ผ ์ ์์ต๋๋ค."
#: src/running-the-course.md:3 src/running-the-course/course-structure.md:3
#: src/running-the-course/day-4.md:3
-msgid "> This page is for the course instructor."
-msgstr "> ๊ฐ์ฌ๋ฅผ ์ํ ์๋ด ํ์ด์ง์ ๋๋ค."
+msgid "This page is for the course instructor."
+msgstr "๊ฐ์ฌ๋ฅผ ์ํ ์๋ด ํ์ด์ง์ ๋๋ค."
#: src/running-the-course.md:5
msgid ""
-"Here is a bit of background information about how we've been running the course\n"
-"internally at Google."
-msgstr "๋ค์์ ๊ตฌ๊ธ ๋ด๋ถ์์ ์ด ๊ณผ์ ์ ์ด๋ค์์ผ๋ก ์ด์ํด์๋์ง์ ๋ํ ๋ฐฐ๊ฒฝ ์ ๋ณด์ ๋๋ค."
+"Here is a bit of background information about how we've been running the "
+"course internally at Google."
+msgstr ""
+"๋ค์์ ๊ตฌ๊ธ ๋ด๋ถ์์ ์ด ๊ณผ์ ์ ์ด๋ค์์ผ๋ก ์ด์ํด์๋์ง์ ๋ํ ๋ฐฐ๊ฒฝ ์ ๋ณด์ ๋"
+"๋ค."
#: src/running-the-course.md:8
msgid "Before you run the course, you will want to:"
@@ -1058,282 +995,369 @@ msgstr "๊ฐ์๋ฅผ ์คํํ๊ธฐ ์ํ ์ค๋น:"
#: src/running-the-course.md:10
msgid ""
-"1. Make yourself familiar with the course material. We've included speaker notes\n"
-" to help highlight the key points (please help us by contributing more speaker\n"
-" notes!). When presenting, you should make sure to open the speaker notes in a\n"
-" popup (click the link with a little arrow next to \"Speaker Notes\"). This way\n"
-" you have a clean screen to present to the class.\n"
-"\n"
-"1. Select your topic for the afternoon of the fourth day. This may be based on\n"
-" the audience you expect, or on your own expertise.\n"
-"\n"
-"1. Decide on the dates. Since the course is large, we recommend that you\n"
-" schedule the four days over two weeks. Course participants have said that\n"
-" they find it helpful to have a gap in the course since it helps them process\n"
-" all the information we give them.\n"
-"\n"
-"1. Find a room large enough for your in-person participants. We recommend a\n"
-" class size of 15-20 people. That's small enough that people are comfortable\n"
-" asking questions --- it's also small enough that one instructor will have\n"
-" time to answer the questions. Make sure the room has _desks_ for yourself and for the\n"
-" students: you will all need to be able to sit and work with your laptops.\n"
-" In particular, you will be doing a lot of live-coding as an instructor, so a lectern won't\n"
-" be very helpful for you.\n"
-"\n"
-"1. On the day of your course, show up to the room a little early to set things\n"
-" up. We recommend presenting directly using `mdbook serve` running on your\n"
-" laptop (see the [installation instructions][3]). This ensures optimal performance with no lag as you change pages.\n"
-" Using your laptop will also allow you to fix typos as you or the course\n"
-" participants spot them.\n"
-"\n"
-"1. Let people solve the exercises by themselves or in small groups. Make sure to\n"
-" ask people if they're stuck or if there is anything you can help with. When\n"
-" you see that several people have the same problem, call it out to the class\n"
-" and offer a solution, e.g., by showing people where to find the relevant\n"
-" information in the standard library.\n"
-"\n"
-"1. Prepare anything you need to have available for the afternoon of day 4."
+"Make yourself familiar with the course material. We've included speaker "
+"notes to help highlight the key points (please help us by contributing more "
+"speaker notes!). When presenting, you should make sure to open the speaker "
+"notes in a popup (click the link with a little arrow next to \"Speaker "
+"Notes\"). This way you have a clean screen to present to the class."
msgstr ""
-"1. ๊ฐ์ ์๋ฃ๋ฅผ ์์งํฉ๋๋ค. ์ฃผ์ ์์ ์ ๊ฐ์กฐํ๊ธฐ ์ํด ๊ฐ์ ์ฐธ์กฐ ๋ ธํธ๋ฅผ ํฌํจํ์์ต๋๋ค. (์ถ๊ฐ์ ์ธ ๋ ธํธ๋ฅผ ์์ฑํ์ฌ ์ ๊ณตํด ์ฃผ์๋ฉด ๊ฐ์ฌํ๊ฒ ์ต๋๋ค.) ๊ฐ์ ์ฐธ์กฐ ๋ ธํธ์ ๋งํฌ๋ฅผ ๋๋ฅด๋ฉด ๋ณ๋์ ํ์ ์ผ๋ก ๋ถ๋ฆฌ๊ฐ ๋๋ฉฐ, ๋ฉ์ธ ํ๋ฉด์์๋ ์ฌ๋ผ์ง๋๋ค. ๊น๋ํ ํ๋ฉด์ผ๋ก ๊ฐ์๋ฅผ ์งํํ ์ ์์ต๋๋ค.\n"
-"\n"
-"1. 4์ผ์ฐจ ์คํ์ ์ฃผ์ ๋ฅผ ์ ํํฉ๋๋ค. ์๊ฐ์๋ค์ด ์ํ๋, ํน์ ์ฌ๋ฌ๋ถ์ด ์์ ์๋ ์ฃผ์ ๋ฅผ ๊ณ ๋ฅด์ธ์.\n"
-"\n"
-"1. ๊ฐ์ ๋ ์ง๋ฅผ ์ ํฉ๋๋ค. ๊ฐ์ ๋ด์ฉ์ด ๋ง๊ณ ์๊ฐ์๋ค์ด ๋ชจ๋ ์ ๋ณด๋ฅผ ๊ณต๋ถํ ์ ์๋๋ก ์ค๊ฐ์ ํ์ ๋์ด 2์ฃผ์ ๊ฑธ์ณ 4์ผ์ ์ก๋ ๊ฒ์ ์ถ์ฒํฉ๋๋ค.\n"
-"\n"
-"1. ์ถฉ๋ถํ ๊ณต๊ฐ์ ํ๋ณดํฉ๋๋ค. 15์์ 20๋ช ๊ท๋ชจ์ ๊ณต๊ฐ์ ์ถ์ฒํฉ๋๋ค. ์๊ฐ์๊ณผ ๊ฐ์ฌ๊ฐ ์ง์๋ฅผ ํ๊ธฐ์ ์ถฉ๋ถํ ์๊ฐ๊ณผ ๊ณต๊ฐ์ด์ด์ผ ํฉ๋๋ค. ๊ฐ์ฌ๋ ์๊ฐ์ ๋ชจ๋ ์ฑ ์์ ์ฌ์ฉํ ์ ์๋ ๊ฐ์์ค์ด๋ฉด ์ข์ต๋๋ค. ๊ฐ์ ์ค์ ๊ฐ์ฌ๊ฐ ๋ผ์ด๋ธ ์ฝ๋ฉ์ ํ๊ฒ ๋ ๊ฒฝ์ฐ๊ฐ ๋ง์ผ๋ฉฐ, ์ด๋ ์๋ฆฌ์ ์์ ๋ ธํธ๋ถ์ ์ฌ์ฉํ๋ ๊ฒ์ด ๋์์ด ๋ฉ๋๋ค.\n"
-"\n"
-"1. ๊ฐ์ ๋น์ผ ์กฐ๊ธ ์ผ์ฐ ์์ ์ค๋นํฉ๋๋ค. ๊ฐ์ฌ ๋ ธํธ๋ถ์์ `mdbook serve -d book/ko`๋ฅผ ์ด์ฉํด ์ง์ ํ๋ ์ ํ ์ด์ ํ๋ฉด ํ์ด์ง ์ด๋ ์์ ์ง์ฐ์ด ์์ต๋๋ค.([์ค์น ๋ฐฉ๋ฒ][3]์ ์ฐธ์กฐํ์ธ์.) ๋ํ, ๊ทธ๋ ๊ฒ ํ๋ฉด ๊ฐ์ ๋์ค ์คํ๋ฅผ ๋ฐ๊ฒฌํ์ ๋ ๊ทธ ์๋ฆฌ์์ ๋ฐ๋ก ์์ ๊ฐ๋ฅํ๋ค๋ ์ฅ์ ๋ ์์ต๋๋ค.\n"
-"\n"
-"1. ์๊ฐ์๋ค์ด ์ง์ (๊ฐ๋ณ ํน์ ๊ทธ๋ฃน์ผ๋ก) ์ฐ์ต๋ฌธ์ ๋ฅผ ํ๋๋ก ํฉ๋๋ค. ์งํ์ด ๋งํ ๋์์ ํ์๋ก ํ๋ ์๊ฐ์์ด ์๋์ง ์์๋ก ํ์ธํฉ๋๋ค. ๋ง์ฝ ๊ฐ์ ๋ฌธ์ ๋ฅผ ์ฌ๋ฌ ์ฌ๋์ด ๊ฒช๊ณ ์๋ค๋ฉด, ๊ทธ ๋ฌธ์ ๋ฅผ ๊ฐ์์ค ์ ์ฒด ์ธ์์๊ฒ ์๋ฆฌ๊ณ ํด๊ฒฐ์ฑ ์ ์ ์ํฉ๋๋ค. ์๋ฅผ ๋ค์ด ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ ์ด๋์ ๊ฐ๋ฉด ๊ทธ ๋ฌธ์ ์ ๋ํ ํด๋ต์ ์ฐพ์ ์ ์๋์ง ์๋ ค ์ค๋๋ค.\n"
-"\n"
-"1. 4์ผ์ฐจ ์คํ์ ํ์ํ ๊ฒ๋ค์ ์ค๋นํ์ธ์."
+"๊ฐ์ ์๋ฃ๋ฅผ ์์งํฉ๋๋ค. ์ฃผ์ ์์ ์ ๊ฐ์กฐํ๊ธฐ ์ํด ๊ฐ์ ์ฐธ์กฐ ๋ ธํธ๋ฅผ ํฌํจํ์์ต"
+"๋๋ค. (์ถ๊ฐ์ ์ธ ๋ ธํธ๋ฅผ ์์ฑํ์ฌ ์ ๊ณตํด ์ฃผ์๋ฉด ๊ฐ์ฌํ๊ฒ ์ต๋๋ค.) ๊ฐ์ ์ฐธ์กฐ ๋ ธํธ"
+"์ ๋งํฌ๋ฅผ ๋๋ฅด๋ฉด ๋ณ๋์ ํ์ ์ผ๋ก ๋ถ๋ฆฌ๊ฐ ๋๋ฉฐ, ๋ฉ์ธ ํ๋ฉด์์๋ ์ฌ๋ผ์ง๋๋ค. ๊น"
+"๋ํ ํ๋ฉด์ผ๋ก ๊ฐ์๋ฅผ ์งํํ ์ ์์ต๋๋ค."
+
+#: src/running-the-course.md:16
+msgid ""
+"Select your topic for the afternoon of the fourth day. This may be based on "
+"the audience you expect, or on your own expertise."
+msgstr ""
+"4์ผ์ฐจ ์คํ์ ์ฃผ์ ๋ฅผ ์ ํํฉ๋๋ค. ์๊ฐ์๋ค์ด ์ํ๋, ํน์ ์ฌ๋ฌ๋ถ์ด ์์ ์๋ ์ฃผ"
+"์ ๋ฅผ ๊ณ ๋ฅด์ธ์."
+
+#: src/running-the-course.md:19
+msgid ""
+"Decide on the dates. Since the course is large, we recommend that you "
+"schedule the four days over two weeks. Course participants have said that "
+"they find it helpful to have a gap in the course since it helps them process "
+"all the information we give them."
+msgstr ""
+"๊ฐ์ ๋ ์ง๋ฅผ ์ ํฉ๋๋ค. ๊ฐ์ ๋ด์ฉ์ด ๋ง๊ณ ์๊ฐ์๋ค์ด ๋ชจ๋ ์ ๋ณด๋ฅผ ๊ณต๋ถํ ์ ์๋"
+"๋ก ์ค๊ฐ์ ํ์ ๋์ด 2์ฃผ์ ๊ฑธ์ณ 4์ผ์ ์ก๋ ๊ฒ์ ์ถ์ฒํฉ๋๋ค."
+
+#: src/running-the-course.md:24
+msgid ""
+"Find a room large enough for your in-person participants. We recommend a "
+"class size of 15-20 people. That's small enough that people are comfortable "
+"asking questions --- it's also small enough that one instructor will have "
+"time to answer the questions. Make sure the room has _desks_ for yourself "
+"and for the students: you will all need to be able to sit and work with your "
+"laptops. In particular, you will be doing a lot of live-coding as an "
+"instructor, so a lectern won't be very helpful for you."
+msgstr ""
+"์ถฉ๋ถํ ๊ณต๊ฐ์ ํ๋ณดํฉ๋๋ค. 15์์ 20๋ช ๊ท๋ชจ์ ๊ณต๊ฐ์ ์ถ์ฒํฉ๋๋ค. ์๊ฐ์๊ณผ ๊ฐ์ฌ"
+"๊ฐ ์ง์๋ฅผ ํ๊ธฐ์ ์ถฉ๋ถํ ์๊ฐ๊ณผ ๊ณต๊ฐ์ด์ด์ผ ํฉ๋๋ค. ๊ฐ์ฌ๋ ์๊ฐ์ ๋ชจ๋ ์ฑ ์์ "
+"์ฌ์ฉํ ์ ์๋ ๊ฐ์์ค์ด๋ฉด ์ข์ต๋๋ค. ๊ฐ์ ์ค์ ๊ฐ์ฌ๊ฐ ๋ผ์ด๋ธ ์ฝ๋ฉ์ ํ๊ฒ ๋ ๊ฒฝ"
+"์ฐ๊ฐ ๋ง์ผ๋ฉฐ, ์ด๋ ์๋ฆฌ์ ์์ ๋ ธํธ๋ถ์ ์ฌ์ฉํ๋ ๊ฒ์ด ๋์์ด ๋ฉ๋๋ค."
+
+#: src/running-the-course.md:32
+msgid ""
+"On the day of your course, show up to the room a little early to set things "
+"up. We recommend presenting directly using `mdbook serve` running on your "
+"laptop (see the [installation instructions](https://github.com/google/"
+"comprehensive-rust#building)). This ensures optimal performance with no lag "
+"as you change pages. Using your laptop will also allow you to fix typos as "
+"you or the course participants spot them."
+msgstr ""
+"๊ฐ์ ๋น์ผ ์กฐ๊ธ ์ผ์ฐ ์์ ์ค๋นํฉ๋๋ค. ๊ฐ์ฌ ๋ ธํธ๋ถ์์ `mdbook serve -d book/"
+"ko`๋ฅผ ์ด์ฉํด ์ง์ ํ๋ ์ ํ ์ด์ ํ๋ฉด ํ์ด์ง ์ด๋ ์์ ์ง์ฐ์ด ์์ต๋๋ค.([์ค์น "
+"๋ฐฉ๋ฒ](https://github.com/google/comprehensive-rust#building)์ ์ฐธ์กฐํ์ธ์.) "
+"๋ํ, ๊ทธ๋ ๊ฒ ํ๋ฉด ๊ฐ์ ๋์ค ์คํ๋ฅผ ๋ฐ๊ฒฌํ์ ๋ ๊ทธ ์๋ฆฌ์์ ๋ฐ๋ก ์์ ๊ฐ๋ฅํ๋ค"
+"๋ ์ฅ์ ๋ ์์ต๋๋ค."
+
+#: src/running-the-course.md:38
+msgid ""
+"Let people solve the exercises by themselves or in small groups. Make sure "
+"to ask people if they're stuck or if there is anything you can help with. "
+"When you see that several people have the same problem, call it out to the "
+"class and offer a solution, e.g., by showing people where to find the "
+"relevant information in the standard library."
+msgstr ""
+"์๊ฐ์๋ค์ด ์ง์ (๊ฐ๋ณ ํน์ ๊ทธ๋ฃน์ผ๋ก) ์ฐ์ต๋ฌธ์ ๋ฅผ ํ๋๋ก ํฉ๋๋ค. ์งํ์ด ๋งํ ๋"
+"์์ ํ์๋ก ํ๋ ์๊ฐ์์ด ์๋์ง ์์๋ก ํ์ธํฉ๋๋ค. ๋ง์ฝ ๊ฐ์ ๋ฌธ์ ๋ฅผ ์ฌ๋ฌ ์ฌ"
+"๋์ด ๊ฒช๊ณ ์๋ค๋ฉด, ๊ทธ ๋ฌธ์ ๋ฅผ ๊ฐ์์ค ์ ์ฒด ์ธ์์๊ฒ ์๋ฆฌ๊ณ ํด๊ฒฐ์ฑ ์ ์ ์ํฉ๋๋ค. "
+"์๋ฅผ ๋ค์ด ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ ์ด๋์ ๊ฐ๋ฉด ๊ทธ ๋ฌธ์ ์ ๋ํ ํด๋ต์ ์ฐพ์ ์ ์๋์ง ์"
+"๋ ค ์ค๋๋ค."
+
+#: src/running-the-course.md:44
+msgid "Prepare anything you need to have available for the afternoon of day 4."
+msgstr "4์ผ์ฐจ ์คํ์ ํ์ํ ๊ฒ๋ค์ ์ค๋นํ์ธ์."
#: src/running-the-course.md:46
msgid ""
-"That is all, good luck running the course! We hope it will be as much fun for\n"
-"you as it has been for us!"
-msgstr "์ด์ ์ค๋น๋ ๋๋ฌ์ต๋๋ค. ์ฐ๋ฆฌ๊ฐ ๊ทธ๋ฌ๋ฏ์ด ์ฌ๋ฌ๋ถ๋ค๋ ์ด ๊ฐ์๋ฅผ ์ฆ๊ธฐ์๊ธธ ๋ฐ๋๋๋ค!"
+"That is all, good luck running the course! We hope it will be as much fun "
+"for you as it has been for us!"
+msgstr ""
+"์ด์ ์ค๋น๋ ๋๋ฌ์ต๋๋ค. ์ฐ๋ฆฌ๊ฐ ๊ทธ๋ฌ๋ฏ์ด ์ฌ๋ฌ๋ถ๋ค๋ ์ด ๊ฐ์๋ฅผ ์ฆ๊ธฐ์๊ธธ ๋ฐ๋๋"
+"๋ค!"
#: src/running-the-course.md:49
msgid ""
-"Please [provide feedback][1] afterwards so that we can keep improving the\n"
-"course. We would love to hear what worked well for you and what can be made\n"
-"better. Your students are also very welcome to [send us feedback][2]!"
-msgstr "๊ฐ์๋ฅผ ๊ณ์ ๊ฐ์ ํ ์ ์๋๋ก [ํผ๋๋ฐฑ][1]์ ์ ๊ณตํด ์ฃผ์ญ์์ค. ์ฐ๋ฆฌ๋ ๋ฌด์์ด ์ข์๊ณ , ๋ฌด์์ด ๋ชจ์๋๋์ง ๋ฃ๊ณ ์ถ์ต๋๋ค. ์๊ฐ์๋ค๋ก ๋ถํฐ์ [ํผ๋๋ฐฑ][2]๋ ํ์ํฉ๋๋ค!"
-
-#: src/running-the-course/course-structure.md:1
-msgid "# Course Structure"
-msgstr "# ๊ฐ์ ๊ตฌ์ฑ"
+"Please [provide feedback](https://github.com/google/comprehensive-rust/"
+"discussions/86) afterwards so that we can keep improving the course. We "
+"would love to hear what worked well for you and what can be made better. "
+"Your students are also very welcome to [send us feedback](https://github.com/"
+"google/comprehensive-rust/discussions/100)!"
+msgstr ""
+"๊ฐ์๋ฅผ ๊ณ์ ๊ฐ์ ํ ์ ์๋๋ก [ํผ๋๋ฐฑ](https://github.com/google/"
+"comprehensive-rust/discussions/86)์ ์ ๊ณตํด ์ฃผ์ญ์์ค. ์ฐ๋ฆฌ๋ ๋ฌด์์ด ์ข์๊ณ , "
+"๋ฌด์์ด ๋ชจ์๋๋์ง ๋ฃ๊ณ ์ถ์ต๋๋ค. ์๊ฐ์๋ค๋ก ๋ถํฐ์ [ํผ๋๋ฐฑ](https://github."
+"com/google/comprehensive-rust/discussions/100)๋ ํ์ํฉ๋๋ค!"
#: src/running-the-course/course-structure.md:5
msgid "The course is fast paced and covers a lot of ground:"
msgstr "๊ฐ์๋ ๋น ๋ฅธ ์๋๋ก ์งํ๋๋ฉฐ, ์๋ ๋ด์ฉ๋ค์ ๋ค๋ฃน๋๋ค:"
#: src/running-the-course/course-structure.md:7
-msgid ""
-"* Day 1: Basic Rust, ownership and the borrow checker.\n"
-"* Day 2: Compound data types, pattern matching, the standard library.\n"
-"* Day 3: Traits and generics, error handling, testing, unsafe Rust.\n"
-"* Day 4: Concurrency in Rust and seeing Rust in action."
+msgid "Day 1: Basic Rust, ownership and the borrow checker."
+msgstr "1์ผ์ฐจ: ๋ฌ์คํธ ๊ธฐ๋ณธ, ์์ ๊ถ(ownership)๊ณผ ๋น๋ฆผ(borrow) ์ฒดํฌ"
+
+#: src/running-the-course/course-structure.md:8
+msgid "Day 2: Compound data types, pattern matching, the standard library."
+msgstr "2์ผ์ฐจ: ๋ณตํฉ ๋ฐ์ดํฐ ์ ํ, ํจํด ๋งค์นญ, ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ"
+
+#: src/running-the-course/course-structure.md:9
+msgid "Day 3: Traits and generics, error handling, testing, unsafe Rust."
msgstr ""
-"* 1์ผ์ฐจ: ๋ฌ์คํธ ๊ธฐ๋ณธ, ์์ ๊ถ(ownership)๊ณผ ๋น๋ฆผ(borrow) ์ฒดํฌ\n"
-"* 2์ผ์ฐจ: ๋ณตํฉ ๋ฐ์ดํฐ ์ ํ, ํจํด ๋งค์นญ, ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ\n"
-"* 3์ผ์ฐจ: ํธ๋ ์(trait)์ ์ ๋ค๋ฆญ(generic), ์ค๋ฅ ์ฒ๋ฆฌ, ํ ์คํธ, ์์ ํ์ง ์์ ๋ฌ์คํธ\n"
-"* 4์ผ์ฐจ: ๋ฌ์คํธ์ ๋์์ฑ ๋ฐ ๋ฌ์คํธ๊ฐ ์ค์ ํ์ฉ๋๋ ์ฌ๋ก ์ดํด๋ณด๊ธฐ"
+"3์ผ์ฐจ: ํธ๋ ์(trait)์ ์ ๋ค๋ฆญ(generic), ์ค๋ฅ ์ฒ๋ฆฌ, ํ ์คํธ, ์์ ํ์ง ์์ ๋ฌ์ค"
+"ํธ"
+
+#: src/running-the-course/course-structure.md:10
+msgid "Day 4: Concurrency in Rust and seeing Rust in action."
+msgstr "4์ผ์ฐจ: ๋ฌ์คํธ์ ๋์์ฑ ๋ฐ ๋ฌ์คํธ๊ฐ ์ค์ ํ์ฉ๋๋ ์ฌ๋ก ์ดํด๋ณด๊ธฐ"
#: src/running-the-course/course-structure.md:12
-msgid "## Format"
-msgstr "## ๊ฐ์ ํ์"
+msgid "Format"
+msgstr "๊ฐ์ ํ์"
#: src/running-the-course/course-structure.md:14
msgid ""
-"The course is meant to be very interactive and we recommend letting the\n"
+"The course is meant to be very interactive and we recommend letting the "
"questions drive the exploration of Rust!"
-msgstr "์ด ๊ฐ์๋ ๊ฐ์ฌ์ ์๊ฐ์์ด ์๋ฐฉํฅ์ผ๋ก ์ํตํ๋ฉด์ ์งํํ๋๋ก ๋์์ธ ๋์์ต๋๋ค. ๋ค์ํ ์ง๋ฌธ์ ํตํด ๋ฌ์คํธ์ ์ฌ๋ฌ ๋ถ๋ถ์ ํํํ ์ ์๋๋ก ํ์ธ์!"
-
-#: src/running-the-course/day-4.md:1
-msgid "# Day 4"
-msgstr "# 4์ผ์ฐจ"
+msgstr ""
+"์ด ๊ฐ์๋ ๊ฐ์ฌ์ ์๊ฐ์์ด ์๋ฐฉํฅ์ผ๋ก ์ํตํ๋ฉด์ ์งํํ๋๋ก ๋์์ธ ๋์์ต๋"
+"๋ค. ๋ค์ํ ์ง๋ฌธ์ ํตํด ๋ฌ์คํธ์ ์ฌ๋ฌ ๋ถ๋ถ์ ํํํ ์ ์๋๋ก ํ์ธ์!"
#: src/running-the-course/day-4.md:5
msgid ""
-"The afternoon of the fourth day should cover a topic of your choice. Include\n"
-"the topic in the announcement of the course, so that participants know what to\n"
-"expect."
-msgstr "4์ผ์ฐจ ์คํ์๋ ์ฌ๋ฌ๋ถ์ ์ ํ์ ๋ฐ๋ผ ๋ค๋ฅธ ์ฃผ์ ๋ฅผ ๋ค๋ฃฐ ์ ์์ต๋๋ค. ๊ฐ์๋ฅผ ์๋ดํ ๋ 4์ผ์ฐจ ์คํ์ ์ฃผ์ ๋ฅผ ํฌํจํ์ฌ ์๊ฐ์๋ค์ด ๋ฏธ๋ฆฌ ์ ์ ์๊ฒ ํ์ธ์."
+"The afternoon of the fourth day should cover a topic of your choice. Include "
+"the topic in the announcement of the course, so that participants know what "
+"to expect."
+msgstr ""
+"4์ผ์ฐจ ์คํ์๋ ์ฌ๋ฌ๋ถ์ ์ ํ์ ๋ฐ๋ผ ๋ค๋ฅธ ์ฃผ์ ๋ฅผ ๋ค๋ฃฐ ์ ์์ต๋๋ค. ๊ฐ์๋ฅผ ์๋ด"
+"ํ ๋ 4์ผ์ฐจ ์คํ์ ์ฃผ์ ๋ฅผ ํฌํจํ์ฌ ์๊ฐ์๋ค์ด ๋ฏธ๋ฆฌ ์ ์ ์๊ฒ ํ์ธ์."
#: src/running-the-course/day-4.md:9
msgid ""
-"This phase of the course is a chance for participants to see Rust in action on a\n"
-"codebase they might be familiar with. You can choose from the topics already\n"
-"defined here, or plan your own."
-msgstr "4์ผ์ฐจ ์ฏค์ด๋ฉด, ์ค์ ์ฝ๋ ๋ฒ ์ด์ค๋ฅผ ํตํด ๋ฌ์คํธ๊ฐ ํ์ฉ๋๋ ๋ชจ์ต์ ์ดํด๋ณด๋ฉด ์ข์ต๋๋ค. ์ด๋ฏธ ์ค๋น๋ ์ฃผ์ ์ค์์ ๊ณ ๋ฅผ ์๋ ์๊ณ , ์ฌ๋ฌ๋ถ์ด ์ง์ ์ค๋นํ ์ฃผ์ ๋ฅผ ๋ค๋ฃฐ ์๋ ์์ต๋๋ค."
+"This phase of the course is a chance for participants to see Rust in action "
+"on a codebase they might be familiar with. You can choose from the topics "
+"already defined here, or plan your own."
+msgstr ""
+"4์ผ์ฐจ ์ฏค์ด๋ฉด, ์ค์ ์ฝ๋ ๋ฒ ์ด์ค๋ฅผ ํตํด ๋ฌ์คํธ๊ฐ ํ์ฉ๋๋ ๋ชจ์ต์ ์ดํด๋ณด๋ฉด ์ข์ต"
+"๋๋ค. ์ด๋ฏธ ์ค๋น๋ ์ฃผ์ ์ค์์ ๊ณ ๋ฅผ ์๋ ์๊ณ , ์ฌ๋ฌ๋ถ์ด ์ง์ ์ค๋นํ ์ฃผ์ ๋ฅผ ๋ค"
+"๋ฃฐ ์๋ ์์ต๋๋ค."
#: src/running-the-course/day-4.md:13
msgid "Some topics need additional preparation:"
msgstr "์ค๋น๋ ์ฃผ์ (์ด๋ค ์ฃผ์ ๋ ์ถ๊ฐ์ ์ธ ์ค๋น๊ฐ ํ์ํฉ๋๋ค):"
-#: src/running-the-course/day-4.md:15
-msgid "## Android"
-msgstr "## ์๋๋ก์ด๋"
-
#: src/running-the-course/day-4.md:17
msgid ""
-"If you chose Android for Day 4 afternoon, you will need an [AOSP checkout][1].\n"
-"Make a checkout of the [course repository][2] on the same machine and move the\n"
-"`src/android/` directory into the root of your AOSP checkout. This will ensure\n"
-"that the Android build system sees the `Android.bp` files in `src/android/`."
-msgstr "4์ผ์ฐจ ์คํ์ ์๋๋ก์ด๋๋ฅผ ๋ค๋ฃจ๊ธฐ๋ก ํ๋ค๋ฉด, [AOSP ์ฝ๋][1]๋ฅผ ์ฒดํฌ์์ํด์ผ ํฉ๋๋ค. ๊ทธ๋ฐ ๋ค์, ๊ฐ์ ์ปดํจํฐ์์ [๊ณผ์ ์ ์ฅ์][2]๋ฅผ ์ฒดํฌ์์ํ๊ณ `src/android/` ๋๋ ํฐ๋ฆฌ๋ฅผ AOSP ์ฝ๋์ ๋ฃจํธ๋ก ์ด๋ํฉ๋๋ค. ์ด๋ ๊ฒ ํ๋ฉด ์๋๋ก์ด๋ ๋น๋ ์์คํ ์์ ๊ณผ์ ์ฉ์ผ๋ก ์ถ๊ฐ๋ `Android.bp`ํ์ผ์ ์ธ์ํ ์ ์์ต๋๋ค."
+"If you chose Android for Day 4 afternoon, you will need an \\[AOSP "
+"checkout\\]\\[1\\]. Make a checkout of the \\[course repository\\]\\[2\\] on "
+"the same machine and move the `src/android/` directory into the root of your "
+"AOSP checkout. This will ensure that the Android build system sees the "
+"`Android.bp` files in `src/android/`."
+msgstr ""
+"4์ผ์ฐจ ์คํ์ ์๋๋ก์ด๋๋ฅผ ๋ค๋ฃจ๊ธฐ๋ก ํ๋ค๋ฉด, \\[AOSP ์ฝ๋\\]\\[1\\]๋ฅผ ์ฒดํฌ์์"
+"ํด์ผ ํฉ๋๋ค. ๊ทธ๋ฐ ๋ค์, ๊ฐ์ ์ปดํจํฐ์์ \\[๊ณผ์ ์ ์ฅ์\\]\\[2\\]๋ฅผ ์ฒดํฌ์์ํ"
+"๊ณ `src/android/` ๋๋ ํฐ๋ฆฌ๋ฅผ AOSP ์ฝ๋์ ๋ฃจํธ๋ก ์ด๋ํฉ๋๋ค. ์ด๋ ๊ฒ ํ๋ฉด ์๋"
+"๋ก์ด๋ ๋น๋ ์์คํ ์์ ๊ณผ์ ์ฉ์ผ๋ก ์ถ๊ฐ๋ `Android.bp`ํ์ผ์ ์ธ์ํ ์ ์์ต๋"
+"๋ค."
#: src/running-the-course/day-4.md:22
msgid ""
-"Ensure that `adb sync` works with your emulator or real device and pre-build\n"
-"all Android examples using `src/android/build_all.sh`. Read the script to see\n"
-"the commands it runs and make sure they work when you run them by hand."
-msgstr "`adb sync` ๋ช ๋ ์ด๊ฐ ์๋ฎฌ๋ ์ดํฐ ํน์ ์ค์ ์ฅ์น์ ์๋ํ๋์ง ํ์ธํฉ๋๋ค. ๊ทธ๋ฆฌ๊ณ `src/android/build_all.sh`๋ฅผ ์ํํด์ ๋ชจ๋ ์๋๋ก์ด๋ ์์ ๋ฅผ ๋ฏธ๋ฆฌ ๋น๋ํด ๋ณด์ธ์. ๊ทธ ์ ์คํฌ๋ฆฝํธ๋ฅผ ์ฝ๊ณ , ๊ทธ ์์์ ์ํ๋๋ ๋ช ๋ น์ด๋ค์ ํ์ธํ ํ ๊ฐ ๋ช ๋ น์ด๋ค์ ์๋์ผ๋ก ์คํํด๋ ์ ๋๋์ง ํ์ธํ์ธ์."
+"Ensure that `adb sync` works with your emulator or real device and pre-build "
+"all Android examples using `src/android/build_all.sh`. Read the script to "
+"see the commands it runs and make sure they work when you run them by hand."
+msgstr ""
+"`adb sync` ๋ช ๋ ์ด๊ฐ ์๋ฎฌ๋ ์ดํฐ ํน์ ์ค์ ์ฅ์น์ ์๋ํ๋์ง ํ์ธํฉ๋๋ค. ๊ทธ๋ฆฌ"
+"๊ณ `src/android/build_all.sh`๋ฅผ ์ํํด์ ๋ชจ๋ ์๋๋ก์ด๋ ์์ ๋ฅผ ๋ฏธ๋ฆฌ ๋น๋ํด "
+"๋ณด์ธ์. ๊ทธ ์ ์คํฌ๋ฆฝํธ๋ฅผ ์ฝ๊ณ , ๊ทธ ์์์ ์ํ๋๋ ๋ช ๋ น์ด๋ค์ ํ์ธํ ํ ๊ฐ ๋ช "
+"๋ น์ด๋ค์ ์๋์ผ๋ก ์คํํด๋ ์ ๋๋์ง ํ์ธํ์ธ์."
#: src/running-the-course/day-4.md:26
-msgid "## Async"
-msgstr "## ๋น๋๊ธฐ"
+msgid "Async"
+msgstr "๋น๋๊ธฐ"
#: src/running-the-course/day-4.md:28
msgid ""
-"If you chose Async for Day 4 afternoon, you will need a fresh crate set up and\n"
-"the dependencies downloaded and ready to go. You can then copy/paste the\n"
+"If you chose Async for Day 4 afternoon, you will need a fresh crate set up "
+"and the dependencies downloaded and ready to go. You can then copy/paste the "
"examples into `src/main.rs` to experiment with them."
-msgstr "4์ผ ์ฐจ ์คํ์ ๋น๋๊ธฐ๋ฅผ ๋ค๋ฃจ๊ธฐ๋ก ํ๋ค๋ฉด, ์ ํฌ๋ ์ดํธ๋ฅผ ์ค์ ํ๊ณ ๋ช ๊ฐ์ง ์์กด์ฑ์ ๋ค์ด๋ก๋ํด ๋์ด์ผ ํฉ๋๋ค. ๊ทธ๋ฐ ๋ค์ ์์ ๋ฅผ `src/main.rs`์ ๋ณต์ฌ/๋ถ์ฌ๋ฃ๊ธฐ ํ์ฌ ์คํํ ์ ์์ต๋๋ค."
-
-#: src/running-the-course/keyboard-shortcuts.md:1
-msgid "# Keyboard Shortcuts"
-msgstr "# ๋จ์ถํค"
+msgstr ""
+"4์ผ ์ฐจ ์คํ์ ๋น๋๊ธฐ๋ฅผ ๋ค๋ฃจ๊ธฐ๋ก ํ๋ค๋ฉด, ์ ํฌ๋ ์ดํธ๋ฅผ ์ค์ ํ๊ณ ๋ช ๊ฐ์ง ์์กด์ฑ"
+"์ ๋ค์ด๋ก๋ํด ๋์ด์ผ ํฉ๋๋ค. ๊ทธ๋ฐ ๋ค์ ์์ ๋ฅผ `src/main.rs`์ ๋ณต์ฌ/๋ถ์ฌ๋ฃ๊ธฐ "
+"ํ์ฌ ์คํํ ์ ์์ต๋๋ค."
#: src/running-the-course/keyboard-shortcuts.md:3
msgid "There are several useful keyboard shortcuts in mdBook:"
msgstr "mdBook ์์คํ (ํ ์ฌ์ดํธ)์์ ์ ์ฉํ ๋จ์ถํค๋ค ์ ๋๋ค:"
#: src/running-the-course/keyboard-shortcuts.md:5
-msgid ""
-"* Arrow-Left: Navigate to the previous page.\n"
-"* Arrow-Right: Navigate to the next page.\n"
-"* Ctrl + Enter: Execute the code sample that has focus.\n"
-"* s: Activate the search bar."
-msgstr ""
-"* ์ผ์ชฝ ํ์ดํ: ์ด์ ํ์ด์ง๋ก ์ด๋ํฉ๋๋ค.\n"
-"* ์ค๋ฅธ์ชฝ ํ์ดํ: ๋ค์ ํ์ด์ง๋ก ์ด๋ํฉ๋๋ค.\n"
-"* Ctrl + Enter: ํ์ฌ ํฌ์ปค์ค๋ฅผ ๋ฐ์ ์ฝ๋ ์ํ ๋ธ๋ก์ ์คํํฉ๋๋ค.\n"
-"* s: ๊ฒ์์ฐฝ์ ํ์ฑํํฉ๋๋ค.(mdBook ๋ฌธ์ ๋ก 23.01.19 ๊ธฐ์ค ์์ด๋ก๋ง ๊ฐ๋ฅํฉ๋๋ค.)"
+msgid "Arrow-Left"
+msgstr "์ผ์ชฝ ํ์ดํ"
-#: src/running-the-course/translations.md:1
-msgid "# Translations"
-msgstr "# ๋ค๋ฅธ ์ธ์ด๋ค"
+#: src/running-the-course/keyboard-shortcuts.md:5
+msgid ": Navigate to the previous page."
+msgstr ": ์ด์ ํ์ด์ง๋ก ์ด๋ํฉ๋๋ค."
+
+#: src/running-the-course/keyboard-shortcuts.md:6
+msgid "Arrow-Right"
+msgstr "์ค๋ฅธ์ชฝ ํ์ดํ"
+
+#: src/running-the-course/keyboard-shortcuts.md:6
+msgid ": Navigate to the next page."
+msgstr ": ๋ค์ ํ์ด์ง๋ก ์ด๋ํฉ๋๋ค."
+
+#: src/running-the-course/keyboard-shortcuts.md:7 src/cargo/code-samples.md:19
+msgid "Ctrl + Enter"
+msgstr "Ctrl + Enter"
+
+#: src/running-the-course/keyboard-shortcuts.md:7
+msgid ": Execute the code sample that has focus."
+msgstr ": ํ์ฌ ํฌ์ปค์ค๋ฅผ ๋ฐ์ ์ฝ๋ ์ํ ๋ธ๋ก์ ์คํํฉ๋๋ค."
+
+#: src/running-the-course/keyboard-shortcuts.md:8
+msgid "s"
+msgstr "s"
+
+#: src/running-the-course/keyboard-shortcuts.md:8
+msgid ": Activate the search bar."
+msgstr ""
+": ๊ฒ์์ฐฝ์ ํ์ฑํํฉ๋๋ค.(mdBook ๋ฌธ์ ๋ก 23.01.19 ๊ธฐ์ค ์์ด๋ก๋ง ๊ฐ๋ฅํฉ๋๋ค.)"
#: src/running-the-course/translations.md:3
msgid ""
-"The course has been translated into other languages by a set of wonderful\n"
+"The course has been translated into other languages by a set of wonderful "
"volunteers:"
-msgstr "์ด ๊ณผ์ ์ ๋ค๋ฅธ ์ธ์ด๋ก๋ ์ ๊ณต๋ฉ๋๋ค. ๊ดํธ ์์ ๋ฒ์ญ์ ๋์ ์ฃผ์ ๋ถ๋ค์ ๋๋ค."
+msgstr ""
+"์ด ๊ณผ์ ์ ๋ค๋ฅธ ์ธ์ด๋ก๋ ์ ๊ณต๋ฉ๋๋ค. ๊ดํธ ์์ ๋ฒ์ญ์ ๋์ ์ฃผ์ ๋ถ๋ค์ ๋๋ค."
#: src/running-the-course/translations.md:6
+#, fuzzy
+msgid ""
+"[Brazilian Portuguese](https://google.github.io/comprehensive-rust/pt-BR/) "
+"by [@rastringer](https://github.com/rastringer) and [@hugojacob](https://"
+"github.com/hugojacob)."
+msgstr "[์์ด](https://google.github.io/comprehensive-rust/)"
+
+#: src/running-the-course/translations.md:7
+#, fuzzy
msgid ""
-"* [Brazilian Portuguese][pt-BR] by [@rastringer] and [@hugojacob].\n"
-"* [Korean][ko] by [@keispace], [@jiyongp] and [@jooyunghan]."
+"[Korean](https://google.github.io/comprehensive-rust/ko/) by [@keispace]"
+"(https://github.com/keispace), [@jiyongp](https://github.com/jiyongp) and "
+"[@jooyunghan](https://github.com/jooyunghan)."
msgstr ""
-"* [์์ด](https://google.github.io/comprehensive-rust/)\n"
-"* [๋ธ๋ผ์ง ํฌ๋ฅดํฌ๊ฐ์ด][pt-BR] ([@rastringer], [@hugojacob]).\n"
-"* [ํ๊ตญ์ด][ko] ([@keispace], [@jiyongp], [@jooyunghan])"
+"[๋ธ๋ผ์ง ํฌ๋ฅดํฌ๊ฐ์ด](https://google.github.io/comprehensive-rust/pt-BR/) "
+"([@rastringer](https://github.com/rastringer), [@hugojacob](https://github."
+"com/hugojacob)).\n"
+"\n"
+"[ํ๊ตญ์ด](https://google.github.io/comprehensive-rust/ko/) ([@keispace]"
+"(https://github.com/keispace), [@jiyongp](https://github.com/jiyongp), "
+"[@jooyunghan](https://github.com/jooyunghan))"
#: src/running-the-course/translations.md:9
-msgid "Use the language picker in the top-right corner to switch between languages."
+msgid ""
+"Use the language picker in the top-right corner to switch between languages."
msgstr "ํ์ด์ง ์ค๋ฅธ์ชฝ ์์ ๋ฉ๋ด๋ฅผ ํตํด ๋ค๋ฅธ ์ธ์ด๋ก ์ ํํ ์ ์์ต๋๋ค."
#: src/running-the-course/translations.md:11
msgid ""
-"If you want to help with this effort, please see [our instructions] for how to\n"
-"get going. Translations are coordinated on the [issue tracker]."
+"If you want to help with this effort, please see [our instructions](https://"
+"github.com/google/comprehensive-rust/blob/main/TRANSLATIONS.md) for how to "
+"get going. Translations are coordinated on the [issue tracker](https://"
+"github.com/google/comprehensive-rust/issues/282)."
msgstr ""
-"์ด ๊ณผ์ ์ ๋ฒ์ญ ์์ ์ ๋์์ ์ฃผ๊ณ ์ถ๋ค๋ฉด [์ฌ๊ธฐ][our instructions] ์ค๋ช ๋ ๋ด์ฉ์ ์ฐธ๊ณ ํ์ธ์.\n"
-"์งํ ์ค์ธ ๋ฒ์ญ ์์ ์ ๋ํ ๋ด์ฉ์ [์ด์ ํธ๋์ปค][issue tracker]๋ฅผ ์ฐธ๊ณ ํ์ธ์."
+"์ด ๊ณผ์ ์ ๋ฒ์ญ ์์ ์ ๋์์ ์ฃผ๊ณ ์ถ๋ค๋ฉด [์ฌ๊ธฐ](https://github.com/google/"
+"comprehensive-rust/blob/main/TRANSLATIONS.md) ์ค๋ช ๋ ๋ด์ฉ์ ์ฐธ๊ณ ํ์ธ์. ์งํ "
+"์ค์ธ ๋ฒ์ญ ์์ ์ ๋ํ ๋ด์ฉ์ [์ด์ ํธ๋์ปค](https://github.com/google/"
+"comprehensive-rust/issues/282)๋ฅผ ์ฐธ๊ณ ํ์ธ์."
#: src/running-the-course/translations.md:13
msgid ""
-"There is a large number of in-progress translations. We link to the most\n"
+"There is a large number of in-progress translations. We link to the most "
"recently updated translations:"
msgstr ""
-"์งํ ์ค์ธ ๋ฒ์ญ์ด ๋ง์ต๋๋ค. ์ต๊ทผ์ ์ ๋ฐ์ดํธ๋ ๋ฒ์ญ๋ณธ์ผ๋ก\n"
-"์ฐ๊ฒฐ๋๋ ๋งํฌ๋ ๋ค์๊ณผ ๊ฐ์ต๋๋ค."
+"์งํ ์ค์ธ ๋ฒ์ญ์ด ๋ง์ต๋๋ค. ์ต๊ทผ์ ์ ๋ฐ์ดํธ๋ ๋ฒ์ญ๋ณธ์ผ๋ก ์ฐ๊ฒฐ๋๋ ๋งํฌ๋ ๋ค์"
+"๊ณผ ๊ฐ์ต๋๋ค."
#: src/running-the-course/translations.md:16
msgid ""
-"* [French][fr] by [@KookaS] and [@vcaen].\n"
-"* [German][de] by [@Throvn] and [@ronaldfw].\n"
-"* [Japanese][ja] by [@CoinEZ-JPN] and [@momotaro1105]."
+"[French](https://google.github.io/comprehensive-rust/fr/) by [@KookaS]"
+"(https://github.com/KookaS) and [@vcaen](https://github.com/vcaen)."
+msgstr ""
+"[French](https://google.github.io/comprehensive-rust/fr/): [@KookaS](https://"
+"github.com/KookaS) ๋ฐ [@vcaen](https://github.com/vcaen) ์ ๊ณต"
+
+#: src/running-the-course/translations.md:17
+msgid ""
+"[German](https://google.github.io/comprehensive-rust/de/) by [@Throvn]"
+"(https://github.com/Throvn) and [@ronaldfw](https://github.com/ronaldfw)."
msgstr ""
-"* [French][fr]: [@KookaS] ๋ฐ [@vcaen] ์ ๊ณต\n"
-"* [German][de]: [@Throvn] ๋ฐ [@ronaldfw] ์ ๊ณต\n"
-"* [Japanese][ja]: [@CoinEZ-JPN] ๋ฐ [@momotaro1105] ์ ๊ณต"
+"[German](https://google.github.io/comprehensive-rust/de/): [@Throvn](https://"
+"github.com/Throvn) ๋ฐ [@ronaldfw](https://github.com/ronaldfw) ์ ๊ณต"
+
+#: src/running-the-course/translations.md:18
+msgid ""
+"[Japanese](https://google.github.io/comprehensive-rust/ja/) by [@CoinEZ-JPN]"
+"(https://github.com/CoinEZ) and [@momotaro1105](https://github.com/"
+"momotaro1105)."
+msgstr ""
+"[Japanese](https://google.github.io/comprehensive-rust/ja/): [@CoinEZ-JPN]"
+"(https://github.com/CoinEZ) ๋ฐ [@momotaro1105](https://github.com/"
+"momotaro1105) ์ ๊ณต"
#: src/running-the-course/course-structure.md:11
-msgid "## Deep Dives"
-msgstr "## ์ฌํ ํ์ต"
+msgid "Deep Dives"
+msgstr "์ฌํ ํ์ต"
#: src/running-the-course/course-structure.md:13
msgid ""
-"In addition to the 3-day class on Rust Fundamentals, we cover some more\n"
+"In addition to the 3-day class on Rust Fundamentals, we cover some more "
"specialized topics:"
-msgstr ""
-"Rust ๊ธฐ์ด์ ๊ดํ 3์ผ ๊ณผ์ ์ธ์๋\n"
-"๋ค์๊ณผ ๊ฐ์ ์ ๋ฌธ ์ฃผ์ ๋ฅผ ๋ค๋ฃน๋๋ค."
+msgstr "Rust ๊ธฐ์ด์ ๊ดํ 3์ผ ๊ณผ์ ์ธ์๋ ๋ค์๊ณผ ๊ฐ์ ์ ๋ฌธ ์ฃผ์ ๋ฅผ ๋ค๋ฃน๋๋ค."
#: src/running-the-course/course-structure.md:18
msgid ""
"The [Android Deep Dive](../android.md) is a half-day course on using Rust "
-"for\n"
-"Android platform development. This includes interoperability with C, C++, "
-"and\n"
-"Java."
+"for Android platform development. This includes interoperability with C, C+"
+"+, and Java."
msgstr ""
-"[Android ์ฌํ ํ์ต](../android.md)๋ Android ํ๋ซํผ ๊ฐ๋ฐ ์ Rust ์ฌ์ฉ์ ๊ด"
-"ํ\n"
-"๋ฐ๋์ ๊ณผ์ ์ ๋๋ค. ์ฌ๊ธฐ์๋ C, C++, Java์์ ์ํธ ์ด์ฉ์ฑ์ด\n"
-"ํฌํจ๋ฉ๋๋ค."
+"[Android ์ฌํ ํ์ต](../android.md)๋ Android ํ๋ซํผ ๊ฐ๋ฐ ์ Rust ์ฌ์ฉ์ ๊ดํ "
+"๋ฐ๋์ ๊ณผ์ ์ ๋๋ค. ์ฌ๊ธฐ์๋ C, C++, Java์์ ์ํธ ์ด์ฉ์ฑ์ด ํฌํจ๋ฉ๋๋ค."
#: src/running-the-course/course-structure.md:34
-msgid "### Bare-Metal"
-msgstr "### Bare-Metal"
+msgid "Bare-Metal"
+msgstr "Bare-Metal"
#: src/running-the-course/course-structure.md:36
msgid ""
"The [Bare-Metal Deep Dive](../bare-metal.md): a full day class on using Rust "
-"for\n"
-"bare-metal (embedded) development. Both microcontrollers and application\n"
+"for bare-metal (embedded) development. Both microcontrollers and application "
"processors are covered."
msgstr ""
"[Bare-Metal ์ฌํ ํ์ต](../bare-metal.md): bare-metal(์๋ฒ ๋๋) ๊ฐ๋ฐ ์ Rust "
-"์ฌ์ฉ์ ๊ดํ\n"
-"์ข ์ผ ๊ณผ์ ์ ๋๋ค. ๋ง์ดํฌ๋ก์ปจํธ๋กค๋ฌ์ ์ ํ๋ฆฌ์ผ์ด์ ํ๋ก์ธ์๋ฅผ\n"
-"๋ชจ๋ ๋ค๋ฃน๋๋ค."
+"์ฌ์ฉ์ ๊ดํ ์ข ์ผ ๊ณผ์ ์ ๋๋ค. ๋ง์ดํฌ๋ก์ปจํธ๋กค๋ฌ์ ์ ํ๋ฆฌ์ผ์ด์ ํ๋ก์ธ์๋ฅผ ๋ชจ๋ "
+"๋ค๋ฃน๋๋ค."
#: src/running-the-course/course-structure.md:40
msgid ""
-"For the microcontroller part, you will need to buy the [BBC\n"
-"micro:bit](https://microbit.org/) v2 development board ahead of time. "
-"Everybody\n"
-"will need to install a number of packages as described on the [welcome\n"
-"page](../bare-metal.md)."
+"For the microcontroller part, you will need to buy the [BBC micro:bit]"
+"(https://microbit.org/) v2 development board ahead of time. Everybody will "
+"need to install a number of packages as described on the [welcome page](../"
+"bare-metal.md)."
msgstr ""
-"๋ง์ดํฌ๋ก์ปจํธ๋กค๋ฌ ํํธ๋ฅผ ์งํํ๊ธฐ ์ํด์๋ [BBC micro:bit](https://microbit.org/) v2\n"
-"๊ฐ๋ฐ ๋ณด๋๋ฅผ ๋ฏธ๋ฆฌ ๊ตฌ๋งคํด์ผ ํฉ๋๋ค. ๋ชจ๋ ์ฌ์ฉ์๋\n"
-"[์์ ํ์ด์ง](../bare-metal.md)์ ์ค๋ช ๋ ๋๋ก\n"
-"๊ฐ์ข ํจํค์ง๋ฅผ ์ค์นํด์ผ ํฉ๋๋ค."
+"๋ง์ดํฌ๋ก์ปจํธ๋กค๋ฌ ํํธ๋ฅผ ์งํํ๊ธฐ ์ํด์๋ [BBC micro:bit](https://microbit."
+"org/) v2 ๊ฐ๋ฐ ๋ณด๋๋ฅผ ๋ฏธ๋ฆฌ ๊ตฌ๋งคํด์ผ ํฉ๋๋ค. ๋ชจ๋ ์ฌ์ฉ์๋ [์์ ํ์ด์ง](../"
+"bare-metal.md)์ ์ค๋ช ๋ ๋๋ก ๊ฐ์ข ํจํค์ง๋ฅผ ์ค์นํด์ผ ํฉ๋๋ค."
#: src/running-the-course/course-structure.md:47
msgid ""
"The [Concurrency Deep Dive](../concurrency.md) is a full day class on "
-"classical\n"
-"as well as `async`/`await` concurrency."
+"classical as well as `async`/`await` concurrency."
msgstr ""
-"[๋์์ฑ ์ฌํํ์ต](../concurrency.md)์ ๊ณ ์ ์ ์ธ ๋์์ฑ ๋ฐ\n"
-"`async`/`await` ๋์์ฑ์ ๋ค๋ฃจ๋ ์ข ์ผ ๊ณผ์ ์ ๋๋ค."
+"[๋์์ฑ ์ฌํํ์ต](../concurrency.md)์ ๊ณ ์ ์ ์ธ ๋์์ฑ ๋ฐ `async`/`await` ๋"
+"์์ฑ์ ๋ค๋ฃจ๋ ์ข ์ผ ๊ณผ์ ์ ๋๋ค."
#: src/running-the-course/course-structure.md:54
msgid ""
@@ -1351,45 +1375,61 @@ msgstr ""
"cargo run\n"
"```"
-#: src/cargo.md:1
-msgid "# Using Cargo"
-msgstr "# ์นด๊ณ (Cargo) ์ฌ์ฉํ๊ธฐ"
-
#: src/cargo.md:3
msgid ""
-"When you start reading about Rust, you will soon meet [Cargo](https://doc.rust-lang.org/cargo/), the standard tool\n"
-"used in the Rust ecosystem to build and run Rust applications. Here we want to\n"
-"give a brief overview of what Cargo is and how it fits into the wider ecosystem\n"
-"and how it fits into this training."
-msgstr "๋ฌ์คํธ๋ฅผ ์์ํ๋ ค๊ณ ํ๋ฉด ๋น์ ์ ๊ณง [Cargo](https://doc.rust-lang.org/cargo/)๋ผ๋, ๋ฌ์คํธ ์ํ๊ณ์์ ์ฌ์ฉํ๋ ํ์ค ๋น๋/์คํ ๋๊ตฌ๋ฅผ ๋ง๋ ๊ฒ ์ ๋๋ค. ์ฌ๊ธฐ์๋ ์นด๊ณ ๊ฐ ๋ฌด์์ธ์ง, ๊ทธ๋ฆฌ๊ณ ์นด๊ณ ๊ฐ ๋ฌ์คํธ ์ํ๊ณ์์ ์ด๋ค ์ญํ ์ ํ๋์ง, ๊ทธ๋ฆฌ๊ณ ์ด ๊ฐ์์์ ์ด๋ป๊ฒ ์ฌ์ฉ๋ ์ง์ ๋ํด ๊ฐ๋ตํ ์ค๋ช ํ๊ฒ ์ต๋๋ค."
+"When you start reading about Rust, you will soon meet [Cargo](https://doc."
+"rust-lang.org/cargo/), the standard tool used in the Rust ecosystem to build "
+"and run Rust applications. Here we want to give a brief overview of what "
+"Cargo is and how it fits into the wider ecosystem and how it fits into this "
+"training."
+msgstr ""
+"๋ฌ์คํธ๋ฅผ ์์ํ๋ ค๊ณ ํ๋ฉด ๋น์ ์ ๊ณง [Cargo](https://doc.rust-lang.org/cargo/)๋ผ"
+"๋, ๋ฌ์คํธ ์ํ๊ณ์์ ์ฌ์ฉํ๋ ํ์ค ๋น๋/์คํ ๋๊ตฌ๋ฅผ ๋ง๋ ๊ฒ ์ ๋๋ค. ์ฌ๊ธฐ์"
+"๋ ์นด๊ณ ๊ฐ ๋ฌด์์ธ์ง, ๊ทธ๋ฆฌ๊ณ ์นด๊ณ ๊ฐ ๋ฌ์คํธ ์ํ๊ณ์์ ์ด๋ค ์ญํ ์ ํ๋์ง, ๊ทธ๋ฆฌ"
+"๊ณ ์ด ๊ฐ์์์ ์ด๋ป๊ฒ ์ฌ์ฉ๋ ์ง์ ๋ํด ๊ฐ๋ตํ ์ค๋ช ํ๊ฒ ์ต๋๋ค."
#: src/cargo.md:8
-msgid "## Installation"
-msgstr "## ์ค์นํ๊ธฐ"
+msgid "Installation"
+msgstr "์ค์นํ๊ธฐ"
#: src/cargo.md:10
-msgid "### Rustup (Recommended)"
-msgstr "#### Rustup (์ถ์ฒ)"
+msgid "Rustup (Recommended)"
+msgstr "Rustup (์ถ์ฒ)"
#: src/cargo.md:12
-msgid "You can follow the instructions to install cargo and rust compiler, among other standard ecosystem tools with the [rustup][3] tool, which is maintained by the Rust Foundation."
-msgstr "๋ฌ์คํธ ์ฌ๋จ์์ ๊ด๋ฆฌํ๊ณ ์๋ [rustup][3] ๋๊ตฌ๋ฅผ ์ฌ์ฉํ์ฌ ์นด๊ณ ๋ฐ ๋ฌ์คํธ ์ปดํ์ผ๋ฌ ๋ฑ ํ์ค ๋๊ตฌ๋ฅผ ์ค์น ํ ์ ์์ต๋๋ค."
+msgid ""
+"You can follow the instructions to install cargo and rust compiler, among "
+"other standard ecosystem tools with the [rustup](https://rust-analyzer."
+"github.io/) tool, which is maintained by the Rust Foundation."
+msgstr ""
+"๋ฌ์คํธ ์ฌ๋จ์์ ๊ด๋ฆฌํ๊ณ ์๋ [rustup](https://rust-analyzer.github.io/) ๋๊ตฌ"
+"๋ฅผ ์ฌ์ฉํ์ฌ ์นด๊ณ ๋ฐ ๋ฌ์คํธ ์ปดํ์ผ๋ฌ ๋ฑ ํ์ค ๋๊ตฌ๋ฅผ ์ค์น ํ ์ ์์ต๋๋ค."
#: src/cargo.md:14
-msgid "Along with cargo and rustc, Rustup will install itself as a command line utility that you can use to install/switch toolchains, setup cross compilation, etc."
-msgstr "์นด๊ณ (cargo)์ ๋ฌ์คํธ ์ปดํ์ผ๋ฌ(rustc)์ ํจ๊ป, rustup์ ํด์ฒด์ธ์ ์ค์นํ๊ณ , ๋ค๋ฅธ ํด์ฒด์ธ์ผ๋ก ์ ํํ๊ณ , ํฌ๋ก์ค ์ปดํ์ผ ์ค์ ์ ํ๋ ์ผ์ ๋ด๋นํ๋ ์ปค๋งจ๋ ๋ผ์ธ ์ ํธ๋ฆฌํฐ ์ ๋๋ค."
+msgid ""
+"Along with cargo and rustc, Rustup will install itself as a command line "
+"utility that you can use to install/switch toolchains, setup cross "
+"compilation, etc."
+msgstr ""
+"์นด๊ณ (cargo)์ ๋ฌ์คํธ ์ปดํ์ผ๋ฌ(rustc)์ ํจ๊ป, rustup์ ํด์ฒด์ธ์ ์ค์นํ๊ณ , ๋ค"
+"๋ฅธ ํด์ฒด์ธ์ผ๋ก ์ ํํ๊ณ , ํฌ๋ก์ค ์ปดํ์ผ ์ค์ ์ ํ๋ ์ผ์ ๋ด๋นํ๋ ์ปค๋งจ๋ ๋ผ์ธ "
+"์ ํธ๋ฆฌํฐ ์ ๋๋ค."
#: src/cargo.md:16
-msgid "### Package Managers"
-msgstr "### ํจํค์ง ๋งค๋์ "
+msgid "Package Managers"
+msgstr "ํจํค์ง ๋งค๋์ "
#: src/cargo.md:18
-msgid "#### Debian"
-msgstr "#### ๋ฐ๋น์"
+msgid "Debian"
+msgstr "๋ฐ๋น์"
#: src/cargo.md:20
-msgid "On Debian/Ubuntu, you can install Cargo, the Rust source and the [Rust formatter][6] with"
-msgstr "๋ฐ๋น์์ด๋ ์ฐ๋ถํฌ์์ cargo, ๋ฌ์คํธ ์์ค์ฝ๋, [๋ฌ์คํธ ํฌ๋งคํฐ][6]๋ฅผ ์๋ ์ปค๋งจ๋๋ก ์ค์นํฉ๋๋ค."
+msgid ""
+"On Debian/Ubuntu, you can install Cargo, the Rust source and the [Rust "
+"formatter](https://github.com/rust-lang/rustfmt) with"
+msgstr ""
+"๋ฐ๋น์์ด๋ ์ฐ๋ถํฌ์์ cargo, ๋ฌ์คํธ ์์ค์ฝ๋, [๋ฌ์คํธ ํฌ๋งคํฐ](https://github."
+"com/rust-lang/rustfmt)๋ฅผ ์๋ ์ปค๋งจ๋๋ก ์ค์นํฉ๋๋ค."
#: src/cargo.md:22
msgid ""
@@ -1403,43 +1443,72 @@ msgstr ""
#: src/cargo.md:26
msgid ""
-"This will allow [rust-analyzer][1] to jump to the definitions. We suggest using\n"
-"[VS Code][2] to edit the code (but any LSP compatible editor works)."
-msgstr "์ด๋ ๊ฒ ํ๋ฉด [rust-analyzer][1]๋ฅผ ์ด์ฉํด์ ํน์ ์ฌ๋ณผ์ด ์ ์๋ ์์น๋ก ์ฝ๊ฒ ์ด๋ํ ์ ์์ต๋๋ค. ์ฐ๋ฆฌ๋ ์๋ํฐ๋ก [VS Code][2]๋ฅผ ์ถ์ฒํฉ๋๋ค๋ง, ์ฌ์ค LSP๋ฅผ ์ง์ํ๋ค๋ฉด ์ด๋ค ์๋ํฐ๋ ๋ฌด๋ฐฉํฉ๋๋ค."
+"This will allow \\[rust-analyzer\\]\\[1\\] to jump to the definitions. We "
+"suggest using [VS Code](https://code.visualstudio.com/) to edit the code "
+"(but any LSP compatible editor works)."
+msgstr ""
+"์ด๋ ๊ฒ ํ๋ฉด \\[rust-analyzer\\]\\[1\\]๋ฅผ ์ด์ฉํด์ ํน์ ์ฌ๋ณผ์ด ์ ์๋ ์์น๋ก "
+"์ฝ๊ฒ ์ด๋ํ ์ ์์ต๋๋ค. ์ฐ๋ฆฌ๋ ์๋ํฐ๋ก [VS Code](https://code.visualstudio."
+"com/)๋ฅผ ์ถ์ฒํฉ๋๋ค๋ง, ์ฌ์ค LSP๋ฅผ ์ง์ํ๋ค๋ฉด ์ด๋ค ์๋ํฐ๋ ๋ฌด๋ฐฉํฉ๋๋ค."
#: src/cargo.md:29
-msgid "Some folks also like to use the [JetBrains][4] family of IDEs, which do their own analysis but have their own tradeoffs. If you prefer them, you can install the [Rust Plugin][5]. Please take note that as of January 2023 debugging only works on the CLion version of the JetBrains IDEA suite."
-msgstr "์ด๋ค ์ฌ๋๋ค์ [JetBrains][4] ์ ํ๊ตฐ์ ์ ํธํ๊ธฐ๋ ํฉ๋๋ค. ์ด ์ ํ๋ค์ rust-analyzer ๋ฅผ ํ์ฉํ์ง ์๊ณ IDE ์์ฒด์ ์ผ๋ก ๊ตฌ๋ฌธ๋ถ์์ ํฉ๋๋ค. ๋ง์ฝ ์ด IDE๋ฅผ ์ค์นํ์ จ๋ค๋ฉด [Rust Plugin][5]๋ฅผ ์ค์นํ์๊ธฐ ๋ฐ๋๋๋ค. ๋ค๋ง 2023๋ 1์ ๊ธฐ์ค, ๋๋ฒ๊น ์ JetBrains IDEA suite์ CLion ๋ฒ์ ์์๋ง ์๋ํ๋ค๋ ์ ์ ์ ์ํ์๊ธฐ ๋ฐ๋๋๋ค."
+msgid ""
+"Some folks also like to use the [JetBrains](https://www.jetbrains.com/"
+"clion/) family of IDEs, which do their own analysis but have their own "
+"tradeoffs. If you prefer them, you can install the [Rust Plugin](https://www."
+"jetbrains.com/rust/). Please take note that as of January 2023 debugging "
+"only works on the CLion version of the JetBrains IDEA suite."
+msgstr ""
+"์ด๋ค ์ฌ๋๋ค์ [JetBrains](https://www.jetbrains.com/clion/) ์ ํ๊ตฐ์ ์ ํธํ๊ธฐ"
+"๋ ํฉ๋๋ค. ์ด ์ ํ๋ค์ rust-analyzer ๋ฅผ ํ์ฉํ์ง ์๊ณ IDE ์์ฒด์ ์ผ๋ก ๊ตฌ๋ฌธ๋ถ์"
+"์ ํฉ๋๋ค. ๋ง์ฝ ์ด IDE๋ฅผ ์ค์นํ์ จ๋ค๋ฉด [Rust Plugin](https://www.jetbrains."
+"com/rust/)๋ฅผ ์ค์นํ์๊ธฐ ๋ฐ๋๋๋ค. ๋ค๋ง 2023๋ 1์ ๊ธฐ์ค, ๋๋ฒ๊น ์ JetBrains "
+"IDEA suite์ CLion ๋ฒ์ ์์๋ง ์๋ํ๋ค๋ ์ ์ ์ ์ํ์๊ธฐ ๋ฐ๋๋๋ค."
#: src/cargo/rust-ecosystem.md:1
-msgid "# The Rust Ecosystem"
-msgstr "# ๋ฌ์คํธ ์ํ๊ณ"
+msgid "The Rust Ecosystem"
+msgstr "๋ฌ์คํธ ์ํ๊ณ"
#: src/cargo/rust-ecosystem.md:3
-msgid "The Rust ecosystem consists of a number of tools, of which the main ones are:"
-msgstr "๋ฌ์คํธ์ ์ํ๊ณ๋ ์ฌ๋ฌ๊ฐ์ง ๋๊ตฌ๋ค๋ก ๊ตฌ์ฑ๋์ด ์์ผ๋ฉฐ, ๊ทธ ์ค ์ค์ํ ๊ฒ๋ค์ ์๋์ ๊ฐ์ต๋๋ค:"
+msgid ""
+"The Rust ecosystem consists of a number of tools, of which the main ones are:"
+msgstr ""
+"๋ฌ์คํธ์ ์ํ๊ณ๋ ์ฌ๋ฌ๊ฐ์ง ๋๊ตฌ๋ค๋ก ๊ตฌ์ฑ๋์ด ์์ผ๋ฉฐ, ๊ทธ ์ค ์ค์ํ ๊ฒ๋ค์ ์๋"
+"์ ๊ฐ์ต๋๋ค:"
#: src/cargo/rust-ecosystem.md:5
msgid ""
-"* `rustc`: the Rust compiler which turns `.rs` files into binaries and other\n"
-" intermediate formats.\n"
-"\n"
-"* `cargo`: the Rust dependency manager and build tool. Cargo knows how to\n"
-" download dependencies hosted on and it will pass them to\n"
-" `rustc` when building your project. Cargo also comes with a built-in test\n"
-" runner which is used to execute unit tests.\n"
-"\n"
-"* `rustup`: the Rust toolchain installer and updater. This tool is used to\n"
-" install and update `rustc` and `cargo` when new versions of Rust is released.\n"
-" In addition, `rustup` can also download documentation for the standard\n"
-" library. You can have multiple versions of Rust installed at once and `rustup`\n"
-" will let you switch between them as needed."
+"`rustc`: the Rust compiler which turns `.rs` files into binaries and other "
+"intermediate formats."
msgstr ""
-"* `rustc`: `.rs` ํ์ฅ์ ํ์ผ์ ๋ฐ์ด๋๋ฆฌ ํน์ ๋ค๋ฅธ ์ค๊ฐ ํ์์ผ๋ก ๋ณํํด์ฃผ๋ Rust ์ปดํ์ผ๋ฌ์ ๋๋ค.\n"
-"\n"
-"* `cargo`: ๋ฌ์คํธ ์์กด์ฑ ๊ด๋ฆฌ์ ๋ฐ ๋น๋๋๊ตฌ ์ ๋๋ค. ์ฌ๋ฌ๋ถ์ ํ๋ก์ ํธ์ ๋ช ์๋ ์์กด์ฑ๋ค์ ์์ ์๋์ผ๋ก ๋ค์ด๋ก๋ ๋ฐ๊ณ , ๊ทธ ์์ค์ฝ๋๋ฅผ `rustc`๋ก ์ ๋ฌํ์ฌ ๋น๋๋ฅผ ์ํต๋๋ค. ๋ํ ์ ๋ ํ ์คํธ๋ฅผ ์คํํ๋ ํ ์คํธ ๋ฌ๋๋ฅผ ๋ด์ฅํ๊ณ ์์ต๋๋ค.\n"
-"\n"
-"* `rustup`: ๋ฌ์คํธ ํด์ฒด์ธ ์ค์น ํ๋ก๊ทธ๋จ ๋ฐ ์ ๋ฐ์ดํธ ํ๋ก๊ทธ๋จ. ์ด ๋๊ตฌ๋ ์ ๋ฒ์ ์ ๋ฌ์คํธ๊ฐ ์ถ์๋ ๋ `rustc` ๋ฐ `cargo` ์ค์นํ๊ณ ์ ๋ฐ์ดํธํ๋ ๋ฐ ์ฌ์ฉ๋ฉ๋๋ค. ๋ํ `rustup`์ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ๋ํ ๋ฌธ์๋ฅผ ๋ค์ด๋ก๋ํ ์๋ ์์ต๋๋ค. ํ ๋ฒ์ ์ฌ๋ฌ ๋ฒ์ ์ ๋ฌ์คํธ๋ฅผ ์ค์นํ ์ ์์ผ๋ฉฐ `rustup`์ ํตํด ํ์์ ๋ฐ๋ผ ์ด๋ค ๋ฒ์ ์ ์ ํํ ์ ์์ต๋๋ค."
+"`rustc`: `.rs` ํ์ฅ์ ํ์ผ์ ๋ฐ์ด๋๋ฆฌ ํน์ ๋ค๋ฅธ ์ค๊ฐ ํ์์ผ๋ก ๋ณํํด์ฃผ๋ "
+"Rust ์ปดํ์ผ๋ฌ์ ๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:8
+msgid ""
+"`cargo`: the Rust dependency manager and build tool. Cargo knows how to "
+"download dependencies hosted on and it will pass them to "
+"`rustc` when building your project. Cargo also comes with a built-in test "
+"runner which is used to execute unit tests."
+msgstr ""
+"`cargo`: ๋ฌ์คํธ ์์กด์ฑ ๊ด๋ฆฌ์ ๋ฐ ๋น๋๋๊ตฌ ์ ๋๋ค. ์ฌ๋ฌ๋ถ์ ํ๋ก์ ํธ์ ๋ช ์๋ "
+"์์กด์ฑ๋ค์ ์์ ์๋์ผ๋ก ๋ค์ด๋ก๋ ๋ฐ๊ณ , ๊ทธ ์์ค์ฝ๋๋ฅผ "
+"`rustc`๋ก ์ ๋ฌํ์ฌ ๋น๋๋ฅผ ์ํต๋๋ค. ๋ํ ์ ๋ ํ ์คํธ๋ฅผ ์คํํ๋ ํ ์คํธ ๋ฌ๋"
+"๋ฅผ ๋ด์ฅํ๊ณ ์์ต๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:13
+msgid ""
+"`rustup`: the Rust toolchain installer and updater. This tool is used to "
+"install and update `rustc` and `cargo` when new versions of Rust is "
+"released. In addition, `rustup` can also download documentation for the "
+"standard library. You can have multiple versions of Rust installed at once "
+"and `rustup` will let you switch between them as needed."
+msgstr ""
+"`rustup`: ๋ฌ์คํธ ํด์ฒด์ธ ์ค์น ํ๋ก๊ทธ๋จ ๋ฐ ์ ๋ฐ์ดํธ ํ๋ก๊ทธ๋จ. ์ด ๋๊ตฌ๋ ์ ๋ฒ์ "
+"์ ๋ฌ์คํธ๊ฐ ์ถ์๋ ๋ `rustc` ๋ฐ `cargo` ์ค์นํ๊ณ ์ ๋ฐ์ดํธํ๋ ๋ฐ ์ฌ์ฉ๋ฉ๋"
+"๋ค. ๋ํ `rustup`์ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ๋ํ ๋ฌธ์๋ฅผ ๋ค์ด๋ก๋ํ ์๋ ์์ต๋๋ค. "
+"ํ ๋ฒ์ ์ฌ๋ฌ ๋ฒ์ ์ ๋ฌ์คํธ๋ฅผ ์ค์นํ ์ ์์ผ๋ฉฐ `rustup`์ ํตํด ํ์์ ๋ฐ๋ผ ์ด"
+"๋ค ๋ฒ์ ์ ์ ํํ ์ ์์ต๋๋ค."
#: src/cargo/rust-ecosystem.md:21 src/hello-world.md:25
#: src/hello-world/small-example.md:27 src/why-rust/runtime.md:10
@@ -1453,81 +1522,139 @@ msgstr "ํค ํฌ์ธํธ:"
#: src/cargo/rust-ecosystem.md:23
msgid ""
-"* Rust has a rapid release schedule with a new release coming out\n"
-" every six weeks. New releases maintain backwards compatibility with\n"
-" old releases --- plus they enable new functionality.\n"
-"\n"
-"* There are three release channels: \"stable\", \"beta\", and \"nightly\".\n"
-"\n"
-"* New features are being tested on \"nightly\", \"beta\" is what becomes\n"
-" \"stable\" every six weeks.\n"
-"\n"
-"* Rust also has [editions]: the current edition is Rust 2021. Previous\n"
-" editions were Rust 2015 and Rust 2018.\n"
-"\n"
-" * The editions are allowed to make backwards incompatible changes to\n"
-" the language.\n"
-"\n"
-" * To prevent breaking code, editions are opt-in: you select the\n"
-" edition for your crate via the `Cargo.toml` file.\n"
-"\n"
-" * To avoid splitting the ecosystem, Rust compilers can mix code\n"
-" written for different editions.\n"
-"\n"
-" * Mention that it is quite rare to ever use the compiler directly not through `cargo` (most users never do).\n"
-"\n"
-" * It might be worth alluding that Cargo itself is an extremely powerful and comprehensive tool. It is capable of many advanced features including but not limited to: \n"
-" * Project/package structure\n"
-" * [workspaces]\n"
-" * Dev Dependencies and Runtime Dependency management/caching\n"
-" * [build scripting]\n"
-" * [global installation]\n"
-" * It is also extensible with sub command plugins as well (such as [cargo clippy]).\n"
-" * Read more from the [official Cargo Book]"
+"Rust has a rapid release schedule with a new release coming out every six "
+"weeks. New releases maintain backwards compatibility with old releases --- "
+"plus they enable new functionality."
msgstr ""
-"* ๋ฌ์คํธ๋ 6์ฃผ๋ง๋ค ์๋ก์ด ๋ฆด๋ฆฌ์ฆ๊ฐ ๋ฐํ๋๋ฉฐ ์ด์ ๋ฆด๋ฆฌ์ฆ์์ ํธํ์ฑ์ ์ ์งํ๊ณ ์์ต๋๋ค.\n"
-"\n"
-"* ๋ฆด๋ฆฌ์ฆ๋ 3๊ฐ์ง ๋ฒ์ ์ผ๋ก ์ ๊ณต๋ฉ๋๋ค: \"stable\", \"beta\" ๊ทธ๋ฆฌ๊ณ \"nightly\".\n"
-"\n"
-"* ์๋ก์ด ๊ธฐ๋ฅ์ \"nightly\" -> \"beta\" -(6์ฃผ ํ)-> \"stable\" ๋ก ๋ณ๊ฒฝ๋ฉ๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ๋ [์๋์ ][editions]์ผ๋ก ๊ตฌ๋ถ๋ฉ๋๋ค. ํ์ฌ๋ Rust 2021 ์๋์ ์ ๋๋ค. ์ด ์ ์๋์ ์ผ๋ก Rust 2015์ Rust 2018์ด ์์ต๋๋ค.\n"
-"\n"
-" * ์๋์ ์ ์ด์ ์๋์ ๊ณผ ํธํ์ด ๋์ง ์์ ์ ์์ต๋๋ค.\n"
-"\n"
-" * ์๋์ ์ด ๋ฐ๋๋ฉด์ ํ๋ก๊ทธ๋จ์ด ์๋์น ์๊ฒ ๊นจ์ง๋ ๋ฌธ์ ๋ฅผ ๋ง๊ธฐ ์ํด, ๊ฐ ํ๋ก๊ทธ๋จ์ ์์ ์ด ๋น๋๋ ์๋์ ์ ๋ช ์์ ์ผ๋ก `Cargo.toml`์ ์ง์ ํด์ผ ํฉ๋๋ค.\n"
-"\n"
-" * ๋ฌ์คํธ ์ํ๊ณ๊ฐ ์๋์ ๋ณ๋ก ํํธํ ๋๋ ๊ฒ์ ๋ง๊ธฐ ์ํด, ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ์๋ก ๋ค๋ฅธ ์๋์ ์์ ์์ฑ๋ ์ฝ๋๋ค์ ํ๋์ ๋ฐ์ด๋๋ฆฌ๋ก ๋ฌถ์ ์ ์์ต๋๋ค.\n"
-"\n"
-" * `cargo`๋ฅผ ์ฌ์ฉํ์ง ์๊ณ ์ปดํ์ผ๋ฌ๋ฅผ ์ง์ ์ฌ์ฉํ๋ ๊ฒฝ์ฐ๋ ๊ฑฐ์ ์์์ ์ธ๊ธํด ์ฃผ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-"\n"
-" * ์นด๊ณ ์์ฒด๊ฐ ๋งค์ฐ ๊ฐ๋ ฅํ๊ณ ํฌ๊ด์ ์ธ ๋๊ตฌ์์ ์ ๊ทน์ ์ผ๋ก ์๋ฆฌ์ธ์.\n"
-" ์นด๊ณ ๋ ๋ค์๊ณผ ๊ฐ์ ๋ค์ํ ๊ณ ๊ธ ๊ธฐ๋ฅ์ ์ ๊ณตํฉ๋๋ค.\n"
-" * ํ๋ก์ ํธ/ํจํค์ง ๊ตฌ์กฐํ\n"
-" * [์ํฌ์คํ์ด์ค][workspaces]\n"
-" * ๊ฐ๋ฐ/๋ฐํ์ ์ข ์์ฑ ๊ด๋ฆฌ ๋ฐ ์บ์ฑ\n"
-" * [๋น๋ ์คํฌ๋ฆฝํธ][build scripting]\n"
-" * [์ ์ญ ์ค์น][global installation]\n"
-" * [cargo clippy]์ ๊ฐ์ ํ์ ํ๋ฌ๊ทธ์ธ์ผ๋ก ํ์ฅ ๊ฐ๋ฅ\n"
-" * [๊ณต์ Cargo Book][official Cargo Book]์์ ์์ธํ ์ฌํญ์ ํ์ธํ์๊ธฐ ๋ฐ๋๋๋ค."
+"๋ฌ์คํธ๋ 6์ฃผ๋ง๋ค ์๋ก์ด ๋ฆด๋ฆฌ์ฆ๊ฐ ๋ฐํ๋๋ฉฐ ์ด์ ๋ฆด๋ฆฌ์ฆ์์ ํธํ์ฑ์ ์ ์งํ๊ณ "
+"์์ต๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:27
+msgid ""
+"There are three release channels: \"stable\", \"beta\", and \"nightly\"."
+msgstr ""
+"๋ฆด๋ฆฌ์ฆ๋ 3๊ฐ์ง ๋ฒ์ ์ผ๋ก ์ ๊ณต๋ฉ๋๋ค: \"stable\", \"beta\" ๊ทธ๋ฆฌ๊ณ \"nightly\"."
+
+#: src/cargo/rust-ecosystem.md:29
+msgid ""
+"New features are being tested on \"nightly\", \"beta\" is what becomes "
+"\"stable\" every six weeks."
+msgstr ""
+"์๋ก์ด ๊ธฐ๋ฅ์ \"nightly\" -> \"beta\" -(6์ฃผ ํ)-> \"stable\" ๋ก ๋ณ๊ฒฝ๋ฉ๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:32
+msgid ""
+"Rust also has [editions](https://doc.rust-lang.org/edition-guide/): the "
+"current edition is Rust 2021. Previous editions were Rust 2015 and Rust 2018."
+msgstr ""
+"๋ฌ์คํธ๋ [์๋์ ](https://doc.rust-lang.org/edition-guide/)์ผ๋ก ๊ตฌ๋ถ๋ฉ๋๋ค. "
+"ํ์ฌ๋ Rust 2021 ์๋์ ์ ๋๋ค. ์ด ์ ์๋์ ์ผ๋ก Rust 2015์ Rust 2018์ด ์์ต"
+"๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:35
+msgid ""
+"The editions are allowed to make backwards incompatible changes to the "
+"language."
+msgstr "์๋์ ์ ์ด์ ์๋์ ๊ณผ ํธํ์ด ๋์ง ์์ ์ ์์ต๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:38
+msgid ""
+"To prevent breaking code, editions are opt-in: you select the edition for "
+"your crate via the `Cargo.toml` file."
+msgstr ""
+"์๋์ ์ด ๋ฐ๋๋ฉด์ ํ๋ก๊ทธ๋จ์ด ์๋์น ์๊ฒ ๊นจ์ง๋ ๋ฌธ์ ๋ฅผ ๋ง๊ธฐ ์ํด, ๊ฐ ํ๋ก๊ทธ๋จ"
+"์ ์์ ์ด ๋น๋๋ ์๋์ ์ ๋ช ์์ ์ผ๋ก `Cargo.toml`์ ์ง์ ํด์ผ ํฉ๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:41
+msgid ""
+"To avoid splitting the ecosystem, Rust compilers can mix code written for "
+"different editions."
+msgstr ""
+"๋ฌ์คํธ ์ํ๊ณ๊ฐ ์๋์ ๋ณ๋ก ํํธํ ๋๋ ๊ฒ์ ๋ง๊ธฐ ์ํด, ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ์"
+"๋ก ๋ค๋ฅธ ์๋์ ์์ ์์ฑ๋ ์ฝ๋๋ค์ ํ๋์ ๋ฐ์ด๋๋ฆฌ๋ก ๋ฌถ์ ์ ์์ต๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:44
+msgid ""
+"Mention that it is quite rare to ever use the compiler directly not through "
+"`cargo` (most users never do)."
+msgstr ""
+"`cargo`๋ฅผ ์ฌ์ฉํ์ง ์๊ณ ์ปดํ์ผ๋ฌ๋ฅผ ์ง์ ์ฌ์ฉํ๋ ๊ฒฝ์ฐ๋ ๊ฑฐ์ ์์์ ์ธ๊ธํด ์ฃผ"
+"์๊ธฐ ๋ฐ๋๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:46
+msgid ""
+"It might be worth alluding that Cargo itself is an extremely powerful and "
+"comprehensive tool. It is capable of many advanced features including but "
+"not limited to: "
+msgstr ""
+"์นด๊ณ ์์ฒด๊ฐ ๋งค์ฐ ๊ฐ๋ ฅํ๊ณ ํฌ๊ด์ ์ธ ๋๊ตฌ์์ ์ ๊ทน์ ์ผ๋ก ์๋ฆฌ์ธ์. ์นด๊ณ ๋ ๋ค์"
+"๊ณผ ๊ฐ์ ๋ค์ํ ๊ณ ๊ธ ๊ธฐ๋ฅ์ ์ ๊ณตํฉ๋๋ค."
+
+#: src/cargo/rust-ecosystem.md:47
+msgid "Project/package structure"
+msgstr "ํ๋ก์ ํธ/ํจํค์ง ๊ตฌ์กฐํ"
+
+#: src/cargo/rust-ecosystem.md:48
+msgid "[workspaces](https://doc.rust-lang.org/cargo/reference/workspaces.html)"
+msgstr ""
+"[์ํฌ์คํ์ด์ค](https://doc.rust-lang.org/cargo/reference/workspaces.html)"
+
+#: src/cargo/rust-ecosystem.md:49
+msgid "Dev Dependencies and Runtime Dependency management/caching"
+msgstr "๊ฐ๋ฐ/๋ฐํ์ ์ข ์์ฑ ๊ด๋ฆฌ ๋ฐ ์บ์ฑ"
+
+#: src/cargo/rust-ecosystem.md:50
+msgid ""
+"[build scripting](https://doc.rust-lang.org/cargo/reference/build-scripts."
+"html)"
+msgstr ""
+"[๋น๋ ์คํฌ๋ฆฝํธ](https://doc.rust-lang.org/cargo/reference/build-scripts.html)"
+
+#: src/cargo/rust-ecosystem.md:51
+msgid ""
+"[global installation](https://doc.rust-lang.org/cargo/commands/cargo-install."
+"html)"
+msgstr ""
+"[์ ์ญ ์ค์น](https://doc.rust-lang.org/cargo/commands/cargo-install.html)"
+
+#: src/cargo/rust-ecosystem.md:52
+msgid ""
+"It is also extensible with sub command plugins as well (such as [cargo "
+"clippy](https://github.com/rust-lang/rust-clippy))."
+msgstr ""
+"[cargo clippy](https://github.com/rust-lang/rust-clippy)์ ๊ฐ์ ํ์ ํ๋ฌ๊ทธ์ธ"
+"์ผ๋ก ํ์ฅ ๊ฐ๋ฅ"
+
+#: src/cargo/rust-ecosystem.md:53
+msgid ""
+"Read more from the [official Cargo Book](https://doc.rust-lang.org/cargo/)"
+msgstr ""
+"[๊ณต์ Cargo Book](https://doc.rust-lang.org/cargo/)์์ ์์ธํ ์ฌํญ์ ํ์ธํ"
+"์๊ธฐ ๋ฐ๋๋๋ค."
#: src/cargo/code-samples.md:1
-msgid "# Code Samples in This Training"
-msgstr "# ๊ฐ์์์์ ์ฝ๋ ์ํ"
+msgid "Code Samples in This Training"
+msgstr "๊ฐ์์์์ ์ฝ๋ ์ํ"
#: src/cargo/code-samples.md:3
msgid ""
-"For this training, we will mostly explore the Rust language through examples\n"
-"which can be executed through your browser. This makes the setup much easier and\n"
-"ensures a consistent experience for everyone."
-msgstr "์ด ๊ฐ์์๋ฃ์ ์๋ ๋ชจ๋ ์์ ๋ ๋ธ๋ผ์ฐ์ ์์ ๋ฐ๋ก ์ํ ๊ฐ๋ฅํฉ๋๋ค. ์ด๋ ๊ฒ ํ ์ด์ ๋, ์ค๋น ๊ณผ์ ์ ๋จ์ํ ์ํค๊ณ , ๋ชจ๋๊ฐ ๊ฐ์ ํ๊ฒฝ์์ ์์ ํ ์ ์๋๋ก ํ๊ธฐ ์ํจ์ ๋๋ค."
+"For this training, we will mostly explore the Rust language through examples "
+"which can be executed through your browser. This makes the setup much easier "
+"and ensures a consistent experience for everyone."
+msgstr ""
+"์ด ๊ฐ์์๋ฃ์ ์๋ ๋ชจ๋ ์์ ๋ ๋ธ๋ผ์ฐ์ ์์ ๋ฐ๋ก ์ํ ๊ฐ๋ฅํฉ๋๋ค. ์ด๋ ๊ฒ ํ "
+"์ด์ ๋, ์ค๋น ๊ณผ์ ์ ๋จ์ํ ์ํค๊ณ , ๋ชจ๋๊ฐ ๊ฐ์ ํ๊ฒฝ์์ ์์ ํ ์ ์๋๋ก ํ"
+"๊ธฐ ์ํจ์ ๋๋ค."
#: src/cargo/code-samples.md:7
msgid ""
-"Installing Cargo is still encouraged: it will make it easier for you to do the\n"
-"exercises. On the last day, we will do a larger exercise which shows you how to\n"
-"work with dependencies and for that you need Cargo."
-msgstr "๊ทธ๋ผ์๋ ๋ถ๊ตฌํ๊ณ , ์นด๊ณ (cargo)๋ฅผ ์ง์ ์ค์นํ๋ ๊ฒ์ ๊ฐ๋ ฅ ๊ถ์ฅํฉ๋๋ค. ์ด๊ฒ ๊ณผ์ ์์ฑ์ ๋ ๋์์ด ๋ ๊ฒ๋๋ค. ๋ํ, ๋ง์ง๋ง ๋ ์๋ ์์กด์ฑ์ด ์๋ ์์ ๋ฅผ ์์ ํ๊ฒ ๋ ํ ๋ฐ, ๊ทธ ๋์๋ ์ด์ฐจํผ ์นด๊ณ ๊ฐ ํ์ํฉ๋๋ค."
+"Installing Cargo is still encouraged: it will make it easier for you to do "
+"the exercises. On the last day, we will do a larger exercise which shows you "
+"how to work with dependencies and for that you need Cargo."
+msgstr ""
+"๊ทธ๋ผ์๋ ๋ถ๊ตฌํ๊ณ , ์นด๊ณ (cargo)๋ฅผ ์ง์ ์ค์นํ๋ ๊ฒ์ ๊ฐ๋ ฅ ๊ถ์ฅํฉ๋๋ค. ์ด๊ฒ ๊ณผ"
+"์ ์์ฑ์ ๋ ๋์์ด ๋ ๊ฒ๋๋ค. ๋ํ, ๋ง์ง๋ง ๋ ์๋ ์์กด์ฑ์ด ์๋ ์์ ๋ฅผ ์์ ํ"
+"๊ฒ ๋ ํ ๋ฐ, ๊ทธ ๋์๋ ์ด์ฐจํผ ์นด๊ณ ๊ฐ ํ์ํฉ๋๋ค."
#: src/cargo/code-samples.md:11
msgid "The code blocks in this course are fully interactive:"
@@ -1548,42 +1675,55 @@ msgstr ""
"```"
#: src/cargo/code-samples.md:19
-msgid ""
-"You can use Ctrl + Enter to execute the code when focus is in the\n"
-"text box."
-msgstr "์ฝ๋ ๋ธ๋ก์ ํฌ์ปค์ค๋ฅผ ๋๊ณ Ctrl + Enter๋ฅผ ๋๋ฌ ์คํํด ๋ณผ ์ ์์ต๋๋ค."
+msgid "You can use "
+msgstr "์ฝ๋ ๋ธ๋ก์ ํฌ์ปค์ค๋ฅผ ๋๊ณ "
+
+#: src/cargo/code-samples.md:19
+msgid " to execute the code when focus is in the text box."
+msgstr "๋ฅผ ๋๋ฌ ์คํํด ๋ณผ ์ ์์ต๋๋ค."
#: src/cargo/code-samples.md:24
msgid ""
-"Most code samples are editable like shown above. A few code samples\n"
-"are not editable for various reasons:"
-msgstr "๊ฐ์์์ ๋๋ถ๋ถ์ ์ฝ๋ ์ํ์ ์์ ๊ฐ์ด ์์ ํ ์ ์์ง๋ง ์ผ๋ถ ์ฝ๋๋ ๋ค์๊ณผ ๊ฐ์ ์ด์ ๋ก ์์ ํ ์ ์์ต๋๋ค:"
+"Most code samples are editable like shown above. A few code samples are not "
+"editable for various reasons:"
+msgstr ""
+"๊ฐ์์์ ๋๋ถ๋ถ์ ์ฝ๋ ์ํ์ ์์ ๊ฐ์ด ์์ ํ ์ ์์ง๋ง ์ผ๋ถ ์ฝ๋๋ ๋ค์๊ณผ ๊ฐ"
+"์ ์ด์ ๋ก ์์ ํ ์ ์์ต๋๋ค:"
#: src/cargo/code-samples.md:27
msgid ""
-"* The embedded playgrounds cannot execute unit tests. Copy-paste the\n"
-" code and open it in the real Playground to demonstrate unit tests.\n"
-"\n"
-"* The embedded playgrounds lose their state the moment you navigate\n"
-" away from the page! This is the reason that the students should\n"
-" solve the exercises using a local Rust installation or via the\n"
-" Playground."
+"The embedded playgrounds cannot execute unit tests. Copy-paste the code and "
+"open it in the real Playground to demonstrate unit tests."
msgstr ""
-"* ์ ๋ ํ ์คํธ๋ ๋ด์ฅ ํ๋ ์ด๊ทธ๋ผ์ด๋์์ ์คํ์ด ์๋ฉ๋๋ค. ์ธ๋ถ ํ๋ ์ด๊ทธ๋ผ์ด๋ ์ฌ์ดํธ์ ๋ถ์ฌ๋ฃ์ด ํ ์คํธ๋ฅผ ์คํํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-"\n"
-"* ๋ด์ฅ๋ ํ๋ ์ด๊ทธ๋ผ์ด๋์์๋ ํ์ด์ง ์ด๋์ ์์ฑ๋ ๋ชจ๋ ๋ด์ฉ์ด ์ฌ๋ผ์ง๋๋ค. ๋ฐ๋ผ์ ๋ก์ปฌ ํ๊ฒฝ์ด๋ ์ธ๋ถ ํ๋ ์ด๊ทธ๋ผ์ด๋ ์ฌ์ดํธ์์ ์ฐ์ต๋ฌธ์ ๋ฅผ ํด๊ฒฐํ๋ ๊ฒ์ด ์ข์ต๋๋ค."
+"์ ๋ ํ ์คํธ๋ ๋ด์ฅ ํ๋ ์ด๊ทธ๋ผ์ด๋์์ ์คํ์ด ์๋ฉ๋๋ค. ์ธ๋ถ ํ๋ ์ด๊ทธ๋ผ์ด๋ ์ฌ"
+"์ดํธ์ ๋ถ์ฌ๋ฃ์ด ํ ์คํธ๋ฅผ ์คํํ์๊ธฐ ๋ฐ๋๋๋ค."
+
+#: src/cargo/code-samples.md:30
+msgid ""
+"The embedded playgrounds lose their state the moment you navigate away from "
+"the page! This is the reason that the students should solve the exercises "
+"using a local Rust installation or via the Playground."
+msgstr ""
+"๋ด์ฅ๋ ํ๋ ์ด๊ทธ๋ผ์ด๋์์๋ ํ์ด์ง ์ด๋์ ์์ฑ๋ ๋ชจ๋ ๋ด์ฉ์ด ์ฌ๋ผ์ง๋๋ค. ๋ฐ๋ผ"
+"์ ๋ก์ปฌ ํ๊ฒฝ์ด๋ ์ธ๋ถ ํ๋ ์ด๊ทธ๋ผ์ด๋ ์ฌ์ดํธ์์ ์ฐ์ต๋ฌธ์ ๋ฅผ ํด๊ฒฐํ๋ ๊ฒ์ด ์ข์ต"
+"๋๋ค."
#: src/cargo/running-locally.md:1
-msgid "# Running Code Locally with Cargo"
-msgstr "# ๋ก์ปฌ ํ๊ฒฝ์ ์นด๊ณ "
+msgid "Running Code Locally with Cargo"
+msgstr "๋ก์ปฌ ํ๊ฒฝ์ ์นด๊ณ "
#: src/cargo/running-locally.md:3
msgid ""
-"If you want to experiment with the code on your own system, then you will need\n"
-"to first install Rust. Do this by following the [instructions in the Rust\n"
-"Book][1]. This should give you a working `rustc` and `cargo`. At the time of\n"
-"writing, the latest stable Rust release has these version numbers:"
-msgstr "๋ง์ฝ ๊ฐ์ธ์ฉ ์ปดํจํฐ์์ ์ฝ๋๋ฅผ ์คํํด๋ณด๋ ค๋ฉด ๋จผ์ ๋ฌ์คํธ๋ฅผ ์ค์นํด์ผ ํฉ๋๋ค. [Rust Book][1]์ ์ง์นจ์ ๋ฐ๋ผ `rustc`์ `cargo`๋ฅผ ํจ๊ป ์ค์น ํ์๊ธฐ ๋ฐ๋๋๋ค. ์ค์น ํ ์๋ ์ปค๋งจ๋๋ฅผ ํตํด ๊ฐ ํด์ ๋ฒ์ ์ ํ์ธ ํ ์ ์์ต๋๋ค:"
+"If you want to experiment with the code on your own system, then you will "
+"need to first install Rust. Do this by following the [instructions in the "
+"Rust Book](https://doc.rust-lang.org/book/ch01-01-installation.html). This "
+"should give you a working `rustc` and `cargo`. At the time of writing, the "
+"latest stable Rust release has these version numbers:"
+msgstr ""
+"๋ง์ฝ ๊ฐ์ธ์ฉ ์ปดํจํฐ์์ ์ฝ๋๋ฅผ ์คํํด๋ณด๋ ค๋ฉด ๋จผ์ ๋ฌ์คํธ๋ฅผ ์ค์นํด์ผ ํฉ๋๋ค. "
+"[Rust Book](https://doc.rust-lang.org/book/ch01-01-installation.html)์ ์ง์นจ"
+"์ ๋ฐ๋ผ `rustc`์ `cargo`๋ฅผ ํจ๊ป ์ค์น ํ์๊ธฐ ๋ฐ๋๋๋ค. ์ค์น ํ ์๋ ์ปค๋งจ๋๋ฅผ "
+"ํตํด ๊ฐ ํด์ ๋ฒ์ ์ ํ์ธ ํ ์ ์์ต๋๋ค:"
#: src/cargo/running-locally.md:8
msgid ""
@@ -1603,247 +1743,326 @@ msgstr ""
#: src/cargo/running-locally.md:15
msgid ""
-"With this is in place, then follow these steps to build a Rust binary from one\n"
-"of the examples in this training:"
-msgstr "์ ์์ ์ผ๋ก ์ค์น๊ฐ ๋์์ผ๋ฉด ๊ฐ์์ ์ฝ๋ ๋ธ๋ก์ค ํ๋๋ฅผ ์๋ ๋จ๊ณ๋ฅผ ๋ฐ๋ผ ๋ก์ปฌ์์ ์คํํ ์ ์์ต๋๋ค:"
+"With this is in place, then follow these steps to build a Rust binary from "
+"one of the examples in this training:"
+msgstr ""
+"์ ์์ ์ผ๋ก ์ค์น๊ฐ ๋์์ผ๋ฉด ๊ฐ์์ ์ฝ๋ ๋ธ๋ก์ค ํ๋๋ฅผ ์๋ ๋จ๊ณ๋ฅผ ๋ฐ๋ผ ๋ก์ปฌ์"
+"์ ์คํํ ์ ์์ต๋๋ค:"
#: src/cargo/running-locally.md:18
+msgid "Click the \"Copy to clipboard\" button on the example you want to copy."
+msgstr "์์ ๋ธ๋ก์ ์๋ \"Copy to clipboard\" ๋ฒํผ์ ํด๋ฆญํด์ ๋ณต์ฌํฉ๋๋ค."
+
+#: src/cargo/running-locally.md:20
msgid ""
-"1. Click the \"Copy to clipboard\" button on the example you want to copy.\n"
-"\n"
-"2. Use `cargo new exercise` to create a new `exercise/` directory for your code:\n"
-"\n"
-" ```shell\n"
-" $ cargo new exercise\n"
-" Created binary (application) `exercise` package\n"
-" ```\n"
-"\n"
-"3. Navigate into `exercise/` and use `cargo run` to build and run your binary:\n"
-"\n"
-" ```shell\n"
-" $ cd exercise\n"
-" $ cargo run\n"
-" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
-" Finished dev [unoptimized + debuginfo] target(s) in 0.75s\n"
-" Running `target/debug/exercise`\n"
-" Hello, world!\n"
-" ```\n"
-"\n"
-"4. Replace the boiler-plate code in `src/main.rs` with your own code. For\n"
-" example, using the example on the previous page, make `src/main.rs` look like\n"
-"\n"
-" ```rust\n"
-" fn main() {\n"
-" println!(\"Edit me!\");\n"
-" }\n"
-" ```\n"
-"\n"
-"5. Use `cargo run` to build and run your updated binary:\n"
-"\n"
-" ```shell\n"
-" $ cargo run\n"
-" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
-" Finished dev [unoptimized + debuginfo] target(s) in 0.24s\n"
-" Running `target/debug/exercise`\n"
-" Edit me!\n"
-" ```\n"
-"\n"
-"6. Use `cargo check` to quickly check your project for errors, use `cargo build`\n"
-" to compile it without running it. You will find the output in `target/debug/`\n"
-" for a normal debug build. Use `cargo build --release` to produce an optimized\n"
-" release build in `target/release/`.\n"
-"\n"
-"7. You can add dependencies for your project by editing `Cargo.toml`. When you\n"
-" run `cargo` commands, it will automatically download and compile missing\n"
-" dependencies for you."
+"Use `cargo new exercise` to create a new `exercise/` directory for your code:"
msgstr ""
-"1. ์์ ๋ธ๋ก์ ์๋ \"Copy to clipboard\" ๋ฒํผ์ ํด๋ฆญํด์ ๋ณต์ฌํฉ๋๋ค.\n"
-"\n"
-"2. ํฐ๋ฏธ๋์์ `cargo new exercise`๋ฅผ ์ ๋ ฅํด์ ์๋ก์ด `exercise/` ํด๋๋ฅผ ๋ง๋ญ๋๋ค:\n"
-"\n"
-" ```shell\n"
-" $ cargo new exercise\n"
-" Created binary (application) `exercise` package\n"
-" ```\n"
-"\n"
-"3. `exercise/` ํด๋๋ก ์ด๋ํ ํ, `cargo run` ์ปค๋งจ๋๋ก ์ฝ๋๋ฅผ ์คํํฉ๋๋ค:\n"
-"\n"
-" ```shell\n"
-" $ cd exercise\n"
-" $ cargo run\n"
-" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
-" Finished dev [unoptimized + debuginfo] target(s) in 0.75s\n"
-" Running `target/debug/exercise`\n"
-" Hello, world!\n"
-" ```\n"
-"\n"
-"4. `src/main.rs`์ ์ฝ๋๋ฅผ ์์ฑํฉ๋๋ค. ์๋ฅผ ๋ค์ด ์ด์ ํ์ด์ง์ ์์ค๋ฅผ ์๋์ ๊ฐ์ด `src/main.rs`์ ์์ฑํฉ๋๋ค\n"
-"\n"
-" ```rust\n"
-" fn main() {\n"
-" println!(\"Edit me!\");\n"
-" }\n"
-" ```\n"
-"\n"
-"5. `cargo run`์ปค๋งจ๋๋ก ์์ค๋ฅผ ๋น๋ํ๊ณ ์คํํฉ๋๋ค:\n"
-"\n"
-" ```shell\n"
-" $ cargo run\n"
-" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
-" Finished dev [unoptimized + debuginfo] target(s) in 0.24s\n"
-" Running `target/debug/exercise`\n"
-" Edit me!\n"
-" ```\n"
-"\n"
-"6. `cargo check`์ปค๋งจ๋๋ ๋น ๋ฅด๊ฒ ์๋ฌ๋ฅผ ํ์ธํ ์ ์์ต๋๋ค. `cargo build`๋ ์คํ์์ด ์ปดํ์ผ๋ง ํฉ๋๋ค. ์ด ๊ฒฝ์ฐ์ `target/debug/`ํด๋์์ output์ ํ์ธ ํ ์ ์์ต๋๋ค. `cargo build --release`์ปค๋งจ๋๋ ๋ฆด๋ฆฌ์ฆ ๋ฒ์ ์ฉ ์ต์ ํ๋ฅผ ์ผ์ ์ปดํ์ผํ๋ฉฐ `target/release/`ํด๋์์ ํ์ธ ํ ์ ์์ต๋๋ค.\n"
-"\n"
-"7. `Cargo.toml`ํ์ผ์๋ ์์กด์ฑ ํจํค์ง๋ฅผ ์ถ๊ฐํ ์ ์์ต๋๋ค. `cargo`์ปค๋งจ๋๋ฅผ ์คํํ๋ฉด ์๋์ผ๋ก ์์กด์ฑ ํจํค์ง๋ฅผ ๋ค์ด๋ก๋ํ๊ณ ์ปดํ์ผ ๊น์ง ํด ์ค๋๋ค."
+"ํฐ๋ฏธ๋์์ `cargo new exercise`๋ฅผ ์ ๋ ฅํด์ ์๋ก์ด `exercise/` ํด๋๋ฅผ ๋ง๋ญ๋"
+"๋ค:"
-#: src/cargo/running-locally.md:70
+#: src/cargo/running-locally.md:22
msgid ""
-"Try to encourage the class participants to install Cargo and use a\n"
-"local editor. It will make their life easier since they will have a\n"
-"normal development environment."
-msgstr "์๊ฐ์๋ค์ด ์นด๊ณ ๋ฅผ ์ค์นํ๊ณ ๋ก์ปฌ ํธ์ง๊ธฐ๋ฅผ ์ด์ฉํ๋๋ก ๋ ๋ คํ์ธ์. ์กฐ๊ธ ๊ท์ฐฎ์ ์๋ ์์ง๋ง, ์ด๋ ๊ฒ ํด์ผ๋ง ์ข ๋ ์ค์ ์ ๊ฐ๊น์ด ๊ฐ๋ฐํ๊ฒฝ์ ๊ฐ์ถ๊ฒ ๋๋ ๊ฒ์ ๋๋ค."
-
-#: src/welcome-day-1.md:1
-msgid "# Welcome to Day 1"
-msgstr "# 1์ผ์ฐจ ๊ฐ์"
+"```shell\n"
+"$ cargo new exercise\n"
+" Created binary (application) `exercise` package\n"
+"```"
+msgstr ""
+"```shell\n"
+"$ cargo new exercise\n"
+" Created binary (application) `exercise` package\n"
+"```"
-#: src/welcome-day-1.md:3
+#: src/cargo/running-locally.md:27
msgid ""
-"This is the first day of Comprehensive Rust. We will cover a lot of ground\n"
-"today:"
-msgstr "๊ฐ์ ์ฒซ ๋ ์ ๋๋ค. ์ค๋ ๋ฐฐ์ธ ๊ฒ์ด ์ฐธ ๋ง์ต๋๋ค:"
+"Navigate into `exercise/` and use `cargo run` to build and run your binary:"
+msgstr "`exercise/` ํด๋๋ก ์ด๋ํ ํ, `cargo run` ์ปค๋งจ๋๋ก ์ฝ๋๋ฅผ ์คํํฉ๋๋ค:"
-#: src/welcome-day-1.md:6
+#: src/cargo/running-locally.md:29
msgid ""
-"* Basic Rust syntax: variables, scalar and compound types, enums, structs,\n"
-" references, functions, and methods.\n"
-"\n"
-"* Memory management: stack vs heap, manual memory management, scope-based memory\n"
-" management, and garbage collection.\n"
-"\n"
-"* Ownership: move semantics, copying and cloning, borrowing, and lifetimes."
+"```shell\n"
+"$ cd exercise\n"
+"$ cargo run\n"
+" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
+" Finished dev [unoptimized + debuginfo] target(s) in 0.75s\n"
+" Running `target/debug/exercise`\n"
+"Hello, world!\n"
+"```"
msgstr ""
-"* ๋ฌ์คํธ ๊ธฐ๋ณธ ๋ฌธ๋ฒ: ๋ณ์, ์ค์นผ๋ผ / ๋ณตํฉ ํ์ , ์ด๊ฑฐํ, ๊ตฌ์กฐ์ฒด, ์ฐธ์กฐํ, ํจ์์ ๋ฉ์๋.\n"
-"\n"
-"* ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ: ์คํ๊ณผ ํ, ์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ, ์ค์ฝํ(๋ฒ์)๊ธฐ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ, ๊ฐ๋น์ง ์ปฌ๋ ์ (GC)\n"
-"\n"
-"* ์์ ๊ถ: Move ๋ฌธ๋ฒ, ๋ณต์ฌ์ ๋ณต์ , ๋น๋ฆผ, ์๋ช ."
-
+"```shell\n"
+"$ cd exercise\n"
+"$ cargo run\n"
+" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
+" Finished dev [unoptimized + debuginfo] target(s) in 0.75s\n"
+" Running `target/debug/exercise`\n"
+"Hello, world!\n"
+"```"
+
+#: src/cargo/running-locally.md:38
+msgid ""
+"Replace the boiler-plate code in `src/main.rs` with your own code. For "
+"example, using the example on the previous page, make `src/main.rs` look like"
+msgstr ""
+"`src/main.rs`์ ์ฝ๋๋ฅผ ์์ฑํฉ๋๋ค. ์๋ฅผ ๋ค์ด ์ด์ ํ์ด์ง์ ์์ค๋ฅผ ์๋์ ๊ฐ"
+"์ด `src/main.rs`์ ์์ฑํฉ๋๋ค"
+
+#: src/cargo/running-locally.md:41
+msgid ""
+"```rust\n"
+"fn main() {\n"
+" println!(\"Edit me!\");\n"
+"}\n"
+"```"
+msgstr ""
+"```rust\n"
+"fn main() {\n"
+" println!(\"Edit me!\");\n"
+"}\n"
+"```"
+
+#: src/cargo/running-locally.md:47
+msgid "Use `cargo run` to build and run your updated binary:"
+msgstr "`cargo run`์ปค๋งจ๋๋ก ์์ค๋ฅผ ๋น๋ํ๊ณ ์คํํฉ๋๋ค:"
+
+#: src/cargo/running-locally.md:49
+msgid ""
+"```shell\n"
+"$ cargo run\n"
+" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
+" Finished dev [unoptimized + debuginfo] target(s) in 0.24s\n"
+" Running `target/debug/exercise`\n"
+"Edit me!\n"
+"```"
+msgstr ""
+"```shell\n"
+"$ cargo run\n"
+" Compiling exercise v0.1.0 (/home/mgeisler/tmp/exercise)\n"
+" Finished dev [unoptimized + debuginfo] target(s) in 0.24s\n"
+" Running `target/debug/exercise`\n"
+"Edit me!\n"
+"```"
+
+#: src/cargo/running-locally.md:57
+msgid ""
+"Use `cargo check` to quickly check your project for errors, use `cargo "
+"build` to compile it without running it. You will find the output in `target/"
+"debug/` for a normal debug build. Use `cargo build --release` to produce an "
+"optimized release build in `target/release/`."
+msgstr ""
+"`cargo check`์ปค๋งจ๋๋ ๋น ๋ฅด๊ฒ ์๋ฌ๋ฅผ ํ์ธํ ์ ์์ต๋๋ค. `cargo build`๋ ์คํ"
+"์์ด ์ปดํ์ผ๋ง ํฉ๋๋ค. ์ด ๊ฒฝ์ฐ์ `target/debug/`ํด๋์์ output์ ํ์ธ ํ ์ "
+"์์ต๋๋ค. `cargo build --release`์ปค๋งจ๋๋ ๋ฆด๋ฆฌ์ฆ ๋ฒ์ ์ฉ ์ต์ ํ๋ฅผ ์ผ์ ์ปดํ์ผ"
+"ํ๋ฉฐ `target/release/`ํด๋์์ ํ์ธ ํ ์ ์์ต๋๋ค."
+
+#: src/cargo/running-locally.md:62
+msgid ""
+"You can add dependencies for your project by editing `Cargo.toml`. When you "
+"run `cargo` commands, it will automatically download and compile missing "
+"dependencies for you."
+msgstr ""
+"`Cargo.toml`ํ์ผ์๋ ์์กด์ฑ ํจํค์ง๋ฅผ ์ถ๊ฐํ ์ ์์ต๋๋ค. `cargo`์ปค๋งจ๋๋ฅผ ์คํ"
+"ํ๋ฉด ์๋์ผ๋ก ์์กด์ฑ ํจํค์ง๋ฅผ ๋ค์ด๋ก๋ํ๊ณ ์ปดํ์ผ ๊น์ง ํด ์ค๋๋ค."
+
+#: src/cargo/running-locally.md:70
+msgid ""
+"Try to encourage the class participants to install Cargo and use a local "
+"editor. It will make their life easier since they will have a normal "
+"development environment."
+msgstr ""
+"์๊ฐ์๋ค์ด ์นด๊ณ ๋ฅผ ์ค์นํ๊ณ ๋ก์ปฌ ํธ์ง๊ธฐ๋ฅผ ์ด์ฉํ๋๋ก ๋ ๋ คํ์ธ์. ์กฐ๊ธ ๊ท์ฐฎ์ "
+"์๋ ์์ง๋ง, ์ด๋ ๊ฒ ํด์ผ๋ง ์ข ๋ ์ค์ ์ ๊ฐ๊น์ด ๊ฐ๋ฐํ๊ฒฝ์ ๊ฐ์ถ๊ฒ ๋๋ ๊ฒ์ ๋"
+"๋ค."
+
+#: src/welcome-day-1.md:1
+msgid "Welcome to Day 1"
+msgstr "1์ผ์ฐจ ๊ฐ์"
+
+#: src/welcome-day-1.md:3
+msgid ""
+"This is the first day of Comprehensive Rust. We will cover a lot of ground "
+"today:"
+msgstr "๊ฐ์ ์ฒซ ๋ ์ ๋๋ค. ์ค๋ ๋ฐฐ์ธ ๊ฒ์ด ์ฐธ ๋ง์ต๋๋ค:"
+
+#: src/welcome-day-1.md:6
+msgid ""
+"Basic Rust syntax: variables, scalar and compound types, enums, structs, "
+"references, functions, and methods."
+msgstr ""
+"๋ฌ์คํธ ๊ธฐ๋ณธ ๋ฌธ๋ฒ: ๋ณ์, ์ค์นผ๋ผ / ๋ณตํฉ ํ์ , ์ด๊ฑฐํ, ๊ตฌ์กฐ์ฒด, ์ฐธ์กฐํ, ํจ์์ ๋ฉ"
+"์๋."
+
+#: src/welcome-day-1.md:9
+msgid ""
+"Memory management: stack vs heap, manual memory management, scope-based "
+"memory management, and garbage collection."
+msgstr ""
+"๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ: ์คํ๊ณผ ํ, ์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ, ์ค์ฝํ(๋ฒ์)๊ธฐ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ, ๊ฐ๋น"
+"์ง ์ปฌ๋ ์ (GC)"
+
+#: src/welcome-day-1.md:12
+msgid ""
+"Ownership: move semantics, copying and cloning, borrowing, and lifetimes."
+msgstr "์์ ๊ถ: Move ๋ฌธ๋ฒ, ๋ณต์ฌ์ ๋ณต์ , ๋น๋ฆผ, ์๋ช ."
+
#: src/welcome-day-1.md:16
msgid "Please remind the students that:"
msgstr "ํ์๋ค์๊ฒ ๋ค์์ ์๊ธฐ์์ผ ์ฃผ์๊ธฐ ๋ฐ๋๋๋ค:"
#: src/welcome-day-1.md:18
msgid ""
-"* They should ask questions when they get them, don't save them to the end.\n"
-"* The class is meant to be interactive and discussions are very much encouraged!\n"
-" * As an instructor, you should try to keep the discussions relevant, i.e.,\n"
-" keep the related to how Rust does things vs some other language. It can be\n"
-" hard to find the right balance, but err on the side of allowing discussions\n"
-" since they engage people much more than one-way communication.\n"
-"* The questions will likely mean that we talk about things ahead of the slides.\n"
-" * This is perfectly okay! Repetition is an important part of learning. Remember\n"
-" that the slides are just a support and you are free to skip them as you\n"
-" like."
-msgstr ""
-"* ๊ถ๊ธํ ์ ์ด ์์ผ๋ฉด ์ฃผ์ ํ์ง ๋ง๊ณ ์ง๋ฌธ ํด์ผ ํฉ๋๋ค.\n"
-"* ์ด ์์ ์ ์ํธ์์ฉ์ด ์ค์ํ๊ณ ํ ๋ก ์ ๊ถ์ฅํฉ๋๋ค.\n"
-" * ๊ฐ์ฌ๋ก์ ํ ๋ก ์ด ์๊ธธ๋ก ์์ง ์๊ฒ ์ฃผ์ํ์ธ์. ์๋ฅผ ๋ค์ด ๋ฌ์คํธ์ ๋ค๋ฅธ ์ธ์ด๋ค์ ๋น๊ตํ๋ค๋ ์ง ํ๋ ๊ฒ์ ์ข์ต๋๋ค. ์ ์ ํ ๊ท ํ์ ์ฐพ๊ธฐ ์ ๋งคํ ๊ฒฝ์ฐ๋ผ๋ฉด ํ ๋ก ์ ํ์ฉํ๋ ์ชฝ์ด ์ผ๋ฐฉ์ ์ธ ๊ฐ์๋ณด๋ค๋ ๋ ๋ง์ ์ฌ๋๋ค์ ์ฐธ์ฌ๋ฅผ ์ด๋์ด ๋ผ ์ ์์ต๋๋ค.\n"
-"* ์ง๋ฌธ์ด ์ฌ๋ผ์ด๋๋ณด๋ค ์์๊ฐ๋ ๊ด์ฐฎ์ต๋๋ค.\n"
-" * ํ์ต์ ์์ด์ ๋ฐ๋ณต์ ๋งค์ฐ ์ค์ํฉ๋๋ค. ์ฌ๋ผ์ด๋๋ ๊ทธ์ ๋์์ ์ค ๋ฟ, ์ํ๋ ๋๋ก ๊ฑด๋๋์ด๋ ๋ฉ๋๋ค."
+"They should ask questions when they get them, don't save them to the end."
+msgstr "๊ถ๊ธํ ์ ์ด ์์ผ๋ฉด ์ฃผ์ ํ์ง ๋ง๊ณ ์ง๋ฌธ ํด์ผ ํฉ๋๋ค."
+
+#: src/welcome-day-1.md:19
+msgid ""
+"The class is meant to be interactive and discussions are very much "
+"encouraged!"
+msgstr "์ด ์์ ์ ์ํธ์์ฉ์ด ์ค์ํ๊ณ ํ ๋ก ์ ๊ถ์ฅํฉ๋๋ค."
+
+#: src/welcome-day-1.md:20
+msgid ""
+"As an instructor, you should try to keep the discussions relevant, i.e., "
+"keep the related to how Rust does things vs some other language. It can be "
+"hard to find the right balance, but err on the side of allowing discussions "
+"since they engage people much more than one-way communication."
+msgstr ""
+"๊ฐ์ฌ๋ก์ ํ ๋ก ์ด ์๊ธธ๋ก ์์ง ์๊ฒ ์ฃผ์ํ์ธ์. ์๋ฅผ ๋ค์ด ๋ฌ์คํธ์ ๋ค๋ฅธ ์ธ์ด๋ค"
+"์ ๋น๊ตํ๋ค๋ ์ง ํ๋ ๊ฒ์ ์ข์ต๋๋ค. ์ ์ ํ ๊ท ํ์ ์ฐพ๊ธฐ ์ ๋งคํ ๊ฒฝ์ฐ๋ผ๋ฉด ํ ๋ก "
+"์ ํ์ฉํ๋ ์ชฝ์ด ์ผ๋ฐฉ์ ์ธ ๊ฐ์๋ณด๋ค๋ ๋ ๋ง์ ์ฌ๋๋ค์ ์ฐธ์ฌ๋ฅผ ์ด๋์ด ๋ผ ์ ์"
+"์ต๋๋ค."
+
+#: src/welcome-day-1.md:24
+msgid ""
+"The questions will likely mean that we talk about things ahead of the slides."
+msgstr "์ง๋ฌธ์ด ์ฌ๋ผ์ด๋๋ณด๋ค ์์๊ฐ๋ ๊ด์ฐฎ์ต๋๋ค."
+
+#: src/welcome-day-1.md:25
+msgid ""
+"This is perfectly okay! Repetition is an important part of learning. "
+"Remember that the slides are just a support and you are free to skip them as "
+"you like."
+msgstr ""
+"ํ์ต์ ์์ด์ ๋ฐ๋ณต์ ๋งค์ฐ ์ค์ํฉ๋๋ค. ์ฌ๋ผ์ด๋๋ ๊ทธ์ ๋์์ ์ค ๋ฟ, ์ํ๋ ๋"
+"๋ก ๊ฑด๋๋์ด๋ ๋ฉ๋๋ค."
#: src/welcome-day-1.md:29
msgid ""
-"The idea for the first day is to show _just enough_ of Rust to be able to speak\n"
-"about the famous borrow checker. The way Rust handles memory is a major feature\n"
-"and we should show students this right away."
-msgstr "์ฒซ ๋ ๊ฐ์์ ๋ชฉํ๋, ๋ฌ์คํธ์์ ๊ทธ ์ ๋ช ํ ๋น๋ฆผ ํ์ธ์ ๋ํด์ ์ด์ผ๊ธฐ ํ ์ ์์ ์ ๋ ๊น์ง๋ง ๋ฌ์คํธ๋ฅผ ์๊ฐํ๋ ๊ฒ์ ๋๋ค. ๋ฌ์คํธ์ ๊ฐ์ฅ ๋ ํนํ ํน์ง์ด ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋ค๋ฃจ๋ ๋ฐฉ์์ด๊ธฐ ๋๋ฌธ์, ํ์๋ค์๊ฒ ์ด ๋ถ๋ถ ์ ์ฐ์ ์ ์ผ๋ก ๋ณด์ฌ์ฃผ๋ ค ํฉ๋๋ค."
+"The idea for the first day is to show _just enough_ of Rust to be able to "
+"speak about the famous borrow checker. The way Rust handles memory is a "
+"major feature and we should show students this right away."
+msgstr ""
+"์ฒซ ๋ ๊ฐ์์ ๋ชฉํ๋, ๋ฌ์คํธ์์ ๊ทธ ์ ๋ช ํ ๋น๋ฆผ ํ์ธ์ ๋ํด์ ์ด์ผ๊ธฐ ํ ์ ์"
+"์ ์ ๋ ๊น์ง๋ง ๋ฌ์คํธ๋ฅผ ์๊ฐํ๋ ๊ฒ์ ๋๋ค. ๋ฌ์คํธ์ ๊ฐ์ฅ ๋ ํนํ ํน์ง์ด ๋ฉ๋ชจ๋ฆฌ"
+"๋ฅผ ๋ค๋ฃจ๋ ๋ฐฉ์์ด๊ธฐ ๋๋ฌธ์, ํ์๋ค์๊ฒ ์ด ๋ถ๋ถ ์ ์ฐ์ ์ ์ผ๋ก ๋ณด์ฌ์ฃผ๋ ค ํฉ๋๋ค."
#: src/welcome-day-1.md:33
msgid ""
-"If you're teaching this in a classroom, this is a good place to go over the\n"
+"If you're teaching this in a classroom, this is a good place to go over the "
"schedule. We suggest splitting the day into two parts (following the slides):"
-msgstr "๋ง์ฝ ๋น์ ์ด ๊ฐ์์ค์์ ๊ฐ๋ฅด์น๊ณ ์๋ค๋ฉด, ์ด ์ฌ๋ผ์ด๋๋ ์ผ์ ์ ๊ฒํ ํ๊ธฐ์ ์ ํฉํ ๊ณณ์ ๋๋ค. ํ๋ฃจ์น ๊ฐ์๋ฅผ ์๋์ฒ๋ผ ์ค์ ์คํ๋ก ๋๋์ด ์งํํ๋ ๊ฒ์ ์ถ์ฒํฉ๋๋ค. (์ฌ๋ผ์ด๋๊ฐ ๊ทธ๋ฐ์์ผ๋ก ๋๋์ด ์์ต๋๋ค.)"
+msgstr ""
+"๋ง์ฝ ๋น์ ์ด ๊ฐ์์ค์์ ๊ฐ๋ฅด์น๊ณ ์๋ค๋ฉด, ์ด ์ฌ๋ผ์ด๋๋ ์ผ์ ์ ๊ฒํ ํ๊ธฐ์ ์ ํฉ"
+"ํ ๊ณณ์ ๋๋ค. ํ๋ฃจ์น ๊ฐ์๋ฅผ ์๋์ฒ๋ผ ์ค์ ์คํ๋ก ๋๋์ด ์งํํ๋ ๊ฒ์ ์ถ์ฒํฉ๋"
+"๋ค. (์ฌ๋ผ์ด๋๊ฐ ๊ทธ๋ฐ์์ผ๋ก ๋๋์ด ์์ต๋๋ค.)"
#: src/welcome-day-1.md:36
-msgid ""
-"* Morning: 9:00 to 12:00,\n"
-"* Afternoon: 13:00 to 16:00."
-msgstr ""
-"* ์ค์ : 9:00 ~ 12:00,\n"
-"* ์คํ: 13:00 ~ 16:00."
+msgid "Morning: 9:00 to 12:00,"
+msgstr "์ค์ : 9:00 ~ 12:00,"
+
+#: src/welcome-day-1.md:37
+msgid "Afternoon: 13:00 to 16:00."
+msgstr "์คํ: 13:00 ~ 16:00."
#: src/welcome-day-1.md:39
msgid ""
-"You can of course adjust this as necessary. Please make sure to include breaks,\n"
-"we recommend a break every hour!"
-msgstr "๋ฌผ๋ก ํ์์ ๋ฐ๋ผ ์กฐ์ ํ ์ ์์ต๋๋ค. ๊ฐ์ ์ค๊ฐ์ ์ฌ๋์๊ฐ์ ๋ฃ๋ ๊ฒ์ ์์ง ๋ง์ธ์. ๋งค ์๊ฐ ํด์์ ๊ฐ๋๊ฑธ ์ถ์ฒํฉ๋๋ค!"
-
-#: src/welcome-day-1/what-is-rust.md:1
-msgid "# What is Rust?"
-msgstr "# ๋ฌ์คํธ๋?"
+"You can of course adjust this as necessary. Please make sure to include "
+"breaks, we recommend a break every hour!"
+msgstr ""
+"๋ฌผ๋ก ํ์์ ๋ฐ๋ผ ์กฐ์ ํ ์ ์์ต๋๋ค. ๊ฐ์ ์ค๊ฐ์ ์ฌ๋์๊ฐ์ ๋ฃ๋ ๊ฒ์ ์์ง ๋ง"
+"์ธ์. ๋งค ์๊ฐ ํด์์ ๊ฐ๋๊ฑธ ์ถ์ฒํฉ๋๋ค!"
#: src/welcome-day-1/what-is-rust.md:3
-msgid "Rust is a new programming language which had its [1.0 release in 2015][1]:"
-msgstr "๋ฌ์คํธ๋ 2015๋ ์ [๋ฒ์ 1.0][1]์ ๋ฆด๋ฆฌ์ฆ ํ ์๋ก์ด ํ๋ก๊ทธ๋จ ์ธ์ด์ ๋๋ค:"
+msgid ""
+"Rust is a new programming language which had its [1.0 release in 2015]"
+"(https://blog.rust-lang.org/2015/05/15/Rust-1.0.html):"
+msgstr ""
+"๋ฌ์คํธ๋ 2015๋ ์ [๋ฒ์ 1.0](https://blog.rust-lang.org/2015/05/15/Rust-1.0."
+"html)์ ๋ฆด๋ฆฌ์ฆ ํ ์๋ก์ด ํ๋ก๊ทธ๋จ ์ธ์ด์ ๋๋ค:"
#: src/welcome-day-1/what-is-rust.md:5
+msgid "Rust is a statically compiled language in a similar role as C++"
+msgstr "๋ฌ์คํธ๋ C++์ ์ ์ฌํ ์ ์ ์ปดํ์ผ ์ธ์ด์ ๋๋ค."
+
+#: src/welcome-day-1/what-is-rust.md:6
+msgid "`rustc` uses LLVM as its backend."
+msgstr "`rustc`๋ LLVM์ ๋ฐฑ์๋๋ก ์ฌ์ฉํฉ๋๋ค."
+
+#: src/welcome-day-1/what-is-rust.md:7
msgid ""
-"* Rust is a statically compiled language in a similar role as C++\n"
-" * `rustc` uses LLVM as its backend.\n"
-"* Rust supports many [platforms and\n"
-" architectures](https://doc.rust-lang.org/nightly/rustc/platform-support.html):\n"
-" * x86, ARM, WebAssembly, ...\n"
-" * Linux, Mac, Windows, ...\n"
-"* Rust is used for a wide range of devices:\n"
-" * firmware and boot loaders,\n"
-" * smart displays,\n"
-" * mobile phones,\n"
-" * desktops,\n"
-" * servers."
-msgstr ""
-"* ๋ฌ์คํธ๋ C++์ ์ ์ฌํ ์ ์ ์ปดํ์ผ ์ธ์ด์ ๋๋ค.\n"
-" * `rustc`๋ LLVM์ ๋ฐฑ์๋๋ก ์ฌ์ฉํฉ๋๋ค.\n"
-"* ๋ฌ์คํธ๋ ๋ค์ํ ํ๋ซํผ๊ณผ ์ํคํ ์ณ๋ฅผ ์ง์ํฉ๋๋ค.\n"
-" * x86, ARM, WebAssembly, ...\n"
-" * Linux, Mac, Windows, ...\n"
-"* ๋ฌ์คํธ๋ ๋ค์ํ ์ฅ์น์์ ์ฌ์ฉ๋ ์ ์์ต๋๋ค:\n"
-" * ํ์จ์ด์ ๋ถํธ๋ก๋(์๋ฒ ๋๋)\n"
-" * ์ค๋งํธ ๋์คํ๋ ์ด\n"
-" * ์ค๋งํธํฐ\n"
-" * ๋ฐ์คํฌํ\n"
-" * ์๋ฒ"
+"Rust supports many [platforms and architectures](https://doc.rust-lang.org/"
+"nightly/rustc/platform-support.html):"
+msgstr "๋ฌ์คํธ๋ ๋ค์ํ ํ๋ซํผ๊ณผ ์ํคํ ์ณ๋ฅผ ์ง์ํฉ๋๋ค."
+
+#: src/welcome-day-1/what-is-rust.md:9
+msgid "x86, ARM, WebAssembly, ..."
+msgstr "x86, ARM, WebAssembly, ..."
+
+#: src/welcome-day-1/what-is-rust.md:10
+msgid "Linux, Mac, Windows, ..."
+msgstr "Linux, Mac, Windows, ..."
+
+#: src/welcome-day-1/what-is-rust.md:11
+msgid "Rust is used for a wide range of devices:"
+msgstr "๋ฌ์คํธ๋ ๋ค์ํ ์ฅ์น์์ ์ฌ์ฉ๋ ์ ์์ต๋๋ค:"
+
+#: src/welcome-day-1/what-is-rust.md:12
+msgid "firmware and boot loaders,"
+msgstr "ํ์จ์ด์ ๋ถํธ๋ก๋(์๋ฒ ๋๋)"
+
+#: src/welcome-day-1/what-is-rust.md:13
+msgid "smart displays,"
+msgstr "์ค๋งํธ ๋์คํ๋ ์ด"
+
+#: src/welcome-day-1/what-is-rust.md:14
+msgid "mobile phones,"
+msgstr "์ค๋งํธํฐ"
+
+#: src/welcome-day-1/what-is-rust.md:15
+msgid "desktops,"
+msgstr "๋ฐ์คํฌํ"
+
+#: src/welcome-day-1/what-is-rust.md:16
+msgid "servers."
+msgstr "์๋ฒ"
#: src/welcome-day-1/what-is-rust.md:21
msgid "Rust fits in the same area as C++:"
msgstr "๋ฌ์คํธ๋ C++๊ฐ ์ฌ์ฉ๋๋ ๋๋ถ๋ถ์ ๊ณณ์์ ์ฌ์ฉ ๊ฐ๋ฅํฉ๋๋ค:"
#: src/welcome-day-1/what-is-rust.md:23
-msgid ""
-"* High flexibility.\n"
-"* High level of control.\n"
-"* Can be scaled down to very constrained devices like mobile phones.\n"
-"* Has no runtime or garbage collection.\n"
-"* Focuses on reliability and safety without sacrificing performance."
-msgstr ""
-"* ๋์ ์ ์ฐ์ฑ.\n"
-"* ๋์ ๋ ๋ฒจ ์์ค์ ์ ์ด.\n"
-"* ํด๋ํฐ๊ณผ ๊ฐ์ ๋งค์ฐ ์ ํ๋ ์ฅ์น๋ก ์ค์ผ์ผ ๋ค์ด ๊ฐ๋ฅ.\n"
-"* ๋ณ๋์ ๋ฐํ์์ ํ์๋ก ํ์ง ์์ผ๋ฉฐ, ๊ฐ๋น์ง ์ปฌ๋ ์ ๋ ์์.\n"
-"* ์ฑ๋ฅ์ ํํํ์ง ์์ผ๋ฉด์๋ ์์ ์ฑ๊ณผ ์์ ์ ์ค์ ์ ๋ ."
+msgid "High flexibility."
+msgstr "๋์ ์ ์ฐ์ฑ."
+
+#: src/welcome-day-1/what-is-rust.md:24
+msgid "High level of control."
+msgstr "๋์ ๋ ๋ฒจ ์์ค์ ์ ์ด."
+
+#: src/welcome-day-1/what-is-rust.md:25
+msgid "Can be scaled down to very constrained devices like mobile phones."
+msgstr "ํด๋ํฐ๊ณผ ๊ฐ์ ๋งค์ฐ ์ ํ๋ ์ฅ์น๋ก ์ค์ผ์ผ ๋ค์ด ๊ฐ๋ฅ."
+
+#: src/welcome-day-1/what-is-rust.md:26
+msgid "Has no runtime or garbage collection."
+msgstr "๋ณ๋์ ๋ฐํ์์ ํ์๋ก ํ์ง ์์ผ๋ฉฐ, ๊ฐ๋น์ง ์ปฌ๋ ์ ๋ ์์."
-#: src/hello-world.md:1
-msgid "# Hello World!"
-msgstr "# Hello World!"
+#: src/welcome-day-1/what-is-rust.md:27
+msgid "Focuses on reliability and safety without sacrificing performance."
+msgstr "์ฑ๋ฅ์ ํํํ์ง ์์ผ๋ฉด์๋ ์์ ์ฑ๊ณผ ์์ ์ ์ค์ ์ ๋ ."
#: src/hello-world.md:3
msgid ""
-"Let us jump into the simplest possible Rust program, a classic Hello World\n"
+"Let us jump into the simplest possible Rust program, a classic Hello World "
"program:"
-msgstr "๊ฐ์ฅ ๊ฐ๋จํ ๋ฌ์คํธ ํ๋ก๊ทธ๋จ์ผ๋ก์จ, ๊ณ ์ ์ ์ธ Hello World ๋ฅผ ์์ฑํด ๋ณด๊ฒ ์ต๋๋ค:"
+msgstr ""
+"๊ฐ์ฅ ๊ฐ๋จํ ๋ฌ์คํธ ํ๋ก๊ทธ๋จ์ผ๋ก์จ, ๊ณ ์ ์ ์ธ Hello World ๋ฅผ ์์ฑํด ๋ณด๊ฒ ์ต๋๋ค:"
#: src/hello-world.md:6
msgid ""
@@ -1859,51 +2078,70 @@ msgid "What you see:"
msgstr "ํ์ธํ ์ ์๋ ๊ฒ๋ค:"
#: src/hello-world.md:14
-msgid ""
-"* Functions are introduced with `fn`.\n"
-"* Blocks are delimited by curly braces like in C and C++.\n"
-"* The `main` function is the entry point of the program.\n"
-"* Rust has hygienic macros, `println!` is an example of this.\n"
-"* Rust strings are UTF-8 encoded and can contain any Unicode character."
+msgid "Functions are introduced with `fn`."
+msgstr "ํจ์๋ `fn`์ผ๋ก ์ ์ธํฉ๋๋ค."
+
+#: src/hello-world.md:15
+msgid "Blocks are delimited by curly braces like in C and C++."
+msgstr "C/C++ ์ ๋ง์ฐฌ๊ฐ์ง๋ก ์ค๊ดํธ`{}`๋ก ๋ธ๋ก์ ํ์ํฉ๋๋ค."
+
+#: src/hello-world.md:16
+msgid "The `main` function is the entry point of the program."
+msgstr "`main` ํจ์๋ ํ๋ก๊ทธ๋จ ์ง์ ์ ์ ๋๋ค."
+
+#: src/hello-world.md:17
+msgid "Rust has hygienic macros, `println!` is an example of this."
+msgstr ""
+"๋ฌ์คํธ๋ ๋๋ํ ๋งคํฌ๋ก(hygienic macros) ์์คํ ์ ๊ฐ์ง๊ณ ์์ต๋๋ค. `println!`"
+"๋ ๊ทธ ์์์ ๋๋ค."
+
+#: src/hello-world.md:18
+msgid "Rust strings are UTF-8 encoded and can contain any Unicode character."
msgstr ""
-"* ํจ์๋ `fn`์ผ๋ก ์ ์ธํฉ๋๋ค.\n"
-"* C/C++ ์ ๋ง์ฐฌ๊ฐ์ง๋ก ์ค๊ดํธ`{}`๋ก ๋ธ๋ก์ ํ์ํฉ๋๋ค.\n"
-"* `main` ํจ์๋ ํ๋ก๊ทธ๋จ ์ง์ ์ ์ ๋๋ค.\n"
-"* ๋ฌ์คํธ๋ ๋๋ํ ๋งคํฌ๋ก(hygienic macros) ์์คํ ์ ๊ฐ์ง๊ณ ์์ต๋๋ค. `println!`๋ ๊ทธ ์์์ ๋๋ค.\n"
-"* ๋ฌ์คํธ์ ๋ฌธ์์ด์ UTF-8๋ก ์ธ์ฝ๋ฉ๋๋ฉฐ ์ด๋ชจ์ง์ ๊ฐ์ ์ ๋์ฝ๋ ๋ฌธ์๋ฅผ ํฌํจํ ์ ์์ต๋๋ค."
+"๋ฌ์คํธ์ ๋ฌธ์์ด์ UTF-8๋ก ์ธ์ฝ๋ฉ๋๋ฉฐ ์ด๋ชจ์ง์ ๊ฐ์ ์ ๋์ฝ๋ ๋ฌธ์๋ฅผ ํฌํจํ ์ "
+"์์ต๋๋ค."
#: src/hello-world.md:22
msgid ""
-"This slide tries to make the students comfortable with Rust code. They will see\n"
-"a ton of it over the next four days so we start small with something familiar."
-msgstr "์ด ์ฌ๋ผ์ด๋๋ ํ์๋ค์ด ๋ฌ์คํธ ์ฝ๋์ ์ต์ํด์ง๊ธฐ ์ํด ์์ฑ๋์์ต๋๋ค. ์์ผ๋ก 4์ผ ๋์ ๋ง์ ์ฝ๋๋ฅผ ์ ํ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ ์ฐ์ ์น์ํ ์ฝ๋๋ถํฐ ์์ํฉ๋๋ค."
+"This slide tries to make the students comfortable with Rust code. They will "
+"see a ton of it over the next four days so we start small with something "
+"familiar."
+msgstr ""
+"์ด ์ฌ๋ผ์ด๋๋ ํ์๋ค์ด ๋ฌ์คํธ ์ฝ๋์ ์ต์ํด์ง๊ธฐ ์ํด ์์ฑ๋์์ต๋๋ค. ์์ผ๋ก 4"
+"์ผ ๋์ ๋ง์ ์ฝ๋๋ฅผ ์ ํ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ ์ฐ์ ์น์ํ ์ฝ๋๋ถํฐ ์์ํฉ๋๋ค."
#: src/hello-world.md:27
msgid ""
-"* Rust is very much like other languages in the C/C++/Java tradition. It is\n"
-" imperative (not functional) and it doesn't try to reinvent things unless\n"
-" absolutely necessary.\n"
-"\n"
-"* Rust is modern with full support for things like Unicode.\n"
-"\n"
-"* Rust uses macros for situations where you want to have a variable number of\n"
-" arguments (no function [overloading](basic-syntax/functions-interlude.md)).\n"
-"\n"
-"* Macros being 'hygienic' means they don't accidentally capture identifiers from\n"
-" the scope they are used in. Rust macros are actually only\n"
-" [partially hygenic](https://veykril.github.io/tlborm/decl-macros/minutiae/hygiene.html)."
+"Rust is very much like other languages in the C/C++/Java tradition. It is "
+"imperative (not functional) and it doesn't try to reinvent things unless "
+"absolutely necessary."
msgstr ""
-"* ๋ฌ์คํธ๋ C/C++/Java์ ๊ฐ์ ์ ํต์ ์ธ ๋ค๋ฅธ ์ธ์ด์ ๋งค์ฐ ์ ์ฌํฉ๋๋ค. ๋ฌ์คํธ๋ ์ ์ฐจ์ (ํจ์ํ ์๋) ์ธ์ด์ ๋๋ค. ์ ๋ง๋ก ํ์ํ ๊ฒฝ์ฐ๊ฐ ์๋๋ผ๋ฉด, ๋ฌ์คํธ๋ ์ด๋ฏธ ์กด์ฌํ๋ ๊ฒ์ ์๋ก ๊ตฌํํ๋ ค๊ณ ํ์ง ์์ต๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ๋ ์ ๋์ฝ๋ ์ง์๊ณผ ๊ฐ์ ํ๋ ์ธ์ด์ ํน์ง์ ์ ๋ถ ์ง์ํฉ๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ๋ ์ธ์์ ๊ฐ์๋ฅผ ์ฌ์ ์ ์ง์ ํ ์ ์๋ ์ํฉ์์ ํจ์ [์ค๋ฒ๋ก๋ฉ](basic-syntax/functions-interlude.md)๋์ ๋งคํฌ๋ก๋ฅผ ์ฌ์ฉํฉ๋๋ค.\n"
-"\n"
-"* ๋๋ํ ๋งคํฌ๋ก(hygienic macro)๋ ๋งคํฌ๋ก๊ฐ ์ฌ์ฉ๋๋ ์ค์ฝํ์์ ์๋์น ์๊ฒ ๋ณ์๋ฅผ ๊ฐ๋ก์ฑ์ง ์์ต๋๋ค. ์ฌ์ค ๋ฌ์คํธ ๋งคํฌ๋ก๋ ์์ ํ hygenicํ์ง๋ ์์ต๋๋ค. [๋งํฌ](https://veykril.github.io/tlborm/decl-macros/minutiae/hygiene.html)๋ฅผ ์ฐธ๊ณ ํ์ธ์."
+"๋ฌ์คํธ๋ C/C++/Java์ ๊ฐ์ ์ ํต์ ์ธ ๋ค๋ฅธ ์ธ์ด์ ๋งค์ฐ ์ ์ฌํฉ๋๋ค. ๋ฌ์คํธ๋ ์ "
+"์ฐจ์ (ํจ์ํ ์๋) ์ธ์ด์ ๋๋ค. ์ ๋ง๋ก ํ์ํ ๊ฒฝ์ฐ๊ฐ ์๋๋ผ๋ฉด, ๋ฌ์คํธ๋ ์ด๋ฏธ ์กด"
+"์ฌํ๋ ๊ฒ์ ์๋ก ๊ตฌํํ๋ ค๊ณ ํ์ง ์์ต๋๋ค."
+
+#: src/hello-world.md:31
+msgid "Rust is modern with full support for things like Unicode."
+msgstr "๋ฌ์คํธ๋ ์ ๋์ฝ๋ ์ง์๊ณผ ๊ฐ์ ํ๋ ์ธ์ด์ ํน์ง์ ์ ๋ถ ์ง์ํฉ๋๋ค."
-#: src/hello-world/small-example.md:1
-msgid "# Small Example"
-msgstr "# ์์ ์์ "
+#: src/hello-world.md:33
+msgid ""
+"Rust uses macros for situations where you want to have a variable number of "
+"arguments (no function [overloading](basic-syntax/functions-interlude.md))."
+msgstr ""
+"๋ฌ์คํธ๋ ์ธ์์ ๊ฐ์๋ฅผ ์ฌ์ ์ ์ง์ ํ ์ ์๋ ์ํฉ์์ ํจ์ [์ค๋ฒ๋ก๋ฉ](basic-"
+"syntax/functions-interlude.md)๋์ ๋งคํฌ๋ก๋ฅผ ์ฌ์ฉํฉ๋๋ค."
+
+#: src/hello-world.md:36
+msgid ""
+"Macros being 'hygienic' means they don't accidentally capture identifiers "
+"from the scope they are used in. Rust macros are actually only [partially "
+"hygenic](https://veykril.github.io/tlborm/decl-macros/minutiae/hygiene.html)."
+msgstr ""
+"๋๋ํ ๋งคํฌ๋ก(hygienic macro)๋ ๋งคํฌ๋ก๊ฐ ์ฌ์ฉ๋๋ ์ค์ฝํ์์ ์๋์น ์๊ฒ ๋ณ์"
+"๋ฅผ ๊ฐ๋ก์ฑ์ง ์์ต๋๋ค. ์ฌ์ค ๋ฌ์คํธ ๋งคํฌ๋ก๋ ์์ ํ hygenicํ์ง๋ ์์ต๋๋ค. [๋ง"
+"ํฌ](https://veykril.github.io/tlborm/decl-macros/minutiae/hygiene.html)๋ฅผ ์ฐธ"
+"๊ณ ํ์ธ์."
#: src/hello-world/small-example.md:3
msgid "Here is a small example program in Rust:"
@@ -1945,346 +2183,542 @@ msgstr ""
#: src/hello-world/small-example.md:23
msgid ""
-"The code implements the Collatz conjecture: it is believed that the loop will\n"
-"always end, but this is not yet proved. Edit the code and play with different\n"
-"inputs."
-msgstr "์ด ์ฝ๋๋ ์ฝ๋ผ์ธ ์ถ์ธก(Collatz conjecture)์ผ๋ก ๊ตฌํ๋ฉ๋๋ค: ๋ฐ๋ณต๋ฌธ์ด ์ธ์ ๋ ์ข ๋ฃ๋ ๊ฒ์ด๋ผ๊ณ ๋ฏฟ์ง๋ง ์ฆ๋ช ๋ ๊ฒ์ ์๋๋๋ค. ์ฝ๋๋ฅผ ์์ ํ๊ณ ์คํํด ๋ณด์๊ธฐ ๋ฐ๋๋๋ค."
+"The code implements the Collatz conjecture: it is believed that the loop "
+"will always end, but this is not yet proved. Edit the code and play with "
+"different inputs."
+msgstr ""
+"์ด ์ฝ๋๋ ์ฝ๋ผ์ธ ์ถ์ธก(Collatz conjecture)์ผ๋ก ๊ตฌํ๋ฉ๋๋ค: ๋ฐ๋ณต๋ฌธ์ด ์ธ์ ๋ ์ข "
+"๋ฃ๋ ๊ฒ์ด๋ผ๊ณ ๋ฏฟ์ง๋ง ์ฆ๋ช ๋ ๊ฒ์ ์๋๋๋ค. ์ฝ๋๋ฅผ ์์ ํ๊ณ ์คํํด ๋ณด์๊ธฐ ๋ฐ๋"
+"๋๋ค."
#: src/hello-world/small-example.md:29
msgid ""
-"* Explain that all variables are statically typed. Try removing `i32` to trigger\n"
-" type inference. Try with `i8` instead and trigger a runtime integer overflow.\n"
-"\n"
-"* Change `let mut x` to `let x`, discuss the compiler error.\n"
-"\n"
-"* Show how `print!` gives a compilation error if the arguments don't match the\n"
-" format string.\n"
-"\n"
-"* Show how you need to use `{}` as a placeholder if you want to print an\n"
-" expression which is more complex than just a single variable.\n"
-"\n"
-"* Show the students the standard library, show them how to search for `std::fmt`\n"
-" which has the rules of the formatting mini-language. It's important that the\n"
-" students become familiar with searching in the standard library."
+"Explain that all variables are statically typed. Try removing `i32` to "
+"trigger type inference. Try with `i8` instead and trigger a runtime integer "
+"overflow."
msgstr ""
-"* ๋ชจ๋ ๋ณ์๊ฐ ์ปดํ์ผ ์ ์ ํด์ง ํ์ ์ ๊ฐ์ง์ ์ค๋ช ํฉ๋๋ค. `i32`๋ฅผ ์ญ์ ํ์ฌ ์ปดํ์ผ๋ฌ๊ฐ ํ์ ์ถ๋ก ์ ํ๋๋ก ํด ๋ด ๋๋ค. `i32`์ `i8`๋ก ๋ณ๊ฒฝํ์ฌ ๋ฐํ์ ์ค๋ฒํ๋ก๋ฅผ ์ ๋ฐํด ๋ณผ ์ ์์ต๋๋ค.\n"
-"\n"
-"* `let mut x`๋ฅผ `let x`๋ก ์์ ํ์ฌ ์ปดํ์ผ ์ค๋ฅ์ ๋ํด ํ ๋ก ํฉ๋๋ค.\n"
-"\n"
-"* ์ธ์๊ฐ ํฌ๋งท ๋ฌธ์์ด๊ณผ ์ผ์นํ์ง ์๋ ๊ฒฝ์ฐ `print!`์์ ์ปดํ์ผ ์ค๋ฅ๊ฐ ๋ฐ์ํจ์ ์ธ๊ธํ๋ ๊ฒ๋ ์ข์ต๋๋ค.\n"
-"\n"
-"* ๋จ์ผ ๋ณ์๋ณด๋ค ๋ณต์กํ ์์ ์ถ๋ คํ๋ ค๋ฉด `{}`์ ์๋ฆฌ ํ์์๋ก ์ฌ์ฉํ๋ ๋ฐฉ๋ฒ์ ๋ณด์ฌ ์ค๋๋ค.\n"
-"\n"
-"* ํ์๋ค์๊ฒ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ ์ด๋ ์๋์ง ์๋ ค ์ฃผ๊ณ ๋, `print!`๊ฐ ์ง์ํ๋ ํฌ๋งทํ ์ธ์ด์ ๋ฌธ๋ฒ์ ์๊ธฐ ์ํด `std::fmt`๋ฅผ ๊ฒ์ํด์ผ ํ๋ค๋ ๊ฒ์ ๊ฐ๋ฅด์น์ธ์.ํ์๋ค์ด ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ๊ฒ์ ๊ธฐ๋ฅ์ ์ต์ํด ์ง๋๋ก ํ๋ ๊ฒ์ด ์ค์ํฉ๋๋ค."
+"๋ชจ๋ ๋ณ์๊ฐ ์ปดํ์ผ ์ ์ ํด์ง ํ์ ์ ๊ฐ์ง์ ์ค๋ช ํฉ๋๋ค. `i32`๋ฅผ ์ญ์ ํ์ฌ ์ปดํ"
+"์ผ๋ฌ๊ฐ ํ์ ์ถ๋ก ์ ํ๋๋ก ํด ๋ด ๋๋ค. `i32`์ `i8`๋ก ๋ณ๊ฒฝํ์ฌ ๋ฐํ์ ์ค๋ฒํ๋ก"
+"๋ฅผ ์ ๋ฐํด ๋ณผ ์ ์์ต๋๋ค."
-#: src/why-rust.md:1
-msgid "# Why Rust?"
-msgstr "# ๋ฌ์คํธ๋ฅผ ์จ์ผํ๋ ์ด์ "
+#: src/hello-world/small-example.md:32
+msgid "Change `let mut x` to `let x`, discuss the compiler error."
+msgstr "`let mut x`๋ฅผ `let x`๋ก ์์ ํ์ฌ ์ปดํ์ผ ์ค๋ฅ์ ๋ํด ํ ๋ก ํฉ๋๋ค."
+
+#: src/hello-world/small-example.md:34
+msgid ""
+"Show how `print!` gives a compilation error if the arguments don't match the "
+"format string."
+msgstr ""
+"์ธ์๊ฐ ํฌ๋งท ๋ฌธ์์ด๊ณผ ์ผ์นํ์ง ์๋ ๊ฒฝ์ฐ `print!`์์ ์ปดํ์ผ ์ค๋ฅ๊ฐ ๋ฐ์ํจ์ "
+"์ธ๊ธํ๋ ๊ฒ๋ ์ข์ต๋๋ค."
+
+#: src/hello-world/small-example.md:37
+msgid ""
+"Show how you need to use `{}` as a placeholder if you want to print an "
+"expression which is more complex than just a single variable."
+msgstr ""
+"๋จ์ผ ๋ณ์๋ณด๋ค ๋ณต์กํ ์์ ์ถ๋ คํ๋ ค๋ฉด `{}`์ ์๋ฆฌ ํ์์๋ก ์ฌ์ฉํ๋ ๋ฐฉ๋ฒ์ ๋ณด"
+"์ฌ ์ค๋๋ค."
+
+#: src/hello-world/small-example.md:40
+msgid ""
+"Show the students the standard library, show them how to search for `std::"
+"fmt` which has the rules of the formatting mini-language. It's important "
+"that the students become familiar with searching in the standard library."
+msgstr ""
+"ํ์๋ค์๊ฒ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ ์ด๋ ์๋์ง ์๋ ค ์ฃผ๊ณ ๋, `print!`๊ฐ ์ง์ํ๋ ํฌ"
+"๋งทํ ์ธ์ด์ ๋ฌธ๋ฒ์ ์๊ธฐ ์ํด `std::fmt`๋ฅผ ๊ฒ์ํด์ผ ํ๋ค๋ ๊ฒ์ ๊ฐ๋ฅด์น์ธ์.ํ"
+"์๋ค์ด ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ๊ฒ์ ๊ธฐ๋ฅ์ ์ต์ํด ์ง๋๋ก ํ๋ ๊ฒ์ด ์ค์ํฉ๋๋ค."
#: src/why-rust.md:3
msgid "Some unique selling points of Rust:"
msgstr "๋ฌ์คํธ๋ง์ ๋ ํนํ ์ธ์ผ์ฆ ํฌ์ธํธ(์ฅ์ ):"
#: src/why-rust.md:5
-msgid ""
-"* Compile time memory safety.\n"
-"* Lack of undefined runtime behavior.\n"
-"* Modern language features."
-msgstr ""
-"* ์ปดํ์ผ ์ ๋ฉ๋ชจ๋ฆฌ ์์ ์ด ๋ณด์ฅ๋จ.\n"
-"* ์ ์๋์ง ์์ ๋ฐํ์ ๋์์ด ์์.\n"
-"* ํ๋์ ์ธ ์ธ์ด ๊ธฐ๋ฅ."
+msgid "Compile time memory safety."
+msgstr "์ปดํ์ผ ์ ๋ฉ๋ชจ๋ฆฌ ์์ ์ด ๋ณด์ฅ๋จ."
+
+#: src/why-rust.md:6
+msgid "Lack of undefined runtime behavior."
+msgstr "์ ์๋์ง ์์ ๋ฐํ์ ๋์์ด ์์."
+
+#: src/why-rust.md:7
+msgid "Modern language features."
+msgstr "ํ๋์ ์ธ ์ธ์ด ๊ธฐ๋ฅ."
#: src/why-rust.md:11
msgid ""
-"Make sure to ask the class which languages they have experience with. Depending\n"
-"on the answer you can highlight different features of Rust:"
-msgstr "์๊ฐ์๋ค์๊ฒ ์ด๋ค ํ๋ก๊ทธ๋๋ฐ ์ธ์ด๋ฅผ ์ฌ์ฉํ๋์ง ๋ฌผ์ด๋ณด์๊ธฐ ๋ฐ๋๋๋ค. ์ด๋ค ์ธ์ด๋ฅผ ์ฌ์ฉํ๋๋์ ๋ฐ๋ผ ๋ฌ์คํธ์์ ์ด๋ค ์ ์ ๊ฐ์กฐํด์ผ ํ ์ง๋ฅผ ๊ณ ๋ฏผํด ๋ณด์ธ์:"
+"Make sure to ask the class which languages they have experience with. "
+"Depending on the answer you can highlight different features of Rust:"
+msgstr ""
+"์๊ฐ์๋ค์๊ฒ ์ด๋ค ํ๋ก๊ทธ๋๋ฐ ์ธ์ด๋ฅผ ์ฌ์ฉํ๋์ง ๋ฌผ์ด๋ณด์๊ธฐ ๋ฐ๋๋๋ค. ์ด๋ค ์ธ์ด"
+"๋ฅผ ์ฌ์ฉํ๋๋์ ๋ฐ๋ผ ๋ฌ์คํธ์์ ์ด๋ค ์ ์ ๊ฐ์กฐํด์ผ ํ ์ง๋ฅผ ๊ณ ๋ฏผํด ๋ณด์ธ์:"
#: src/why-rust.md:14
msgid ""
-"* Experience with C or C++: Rust eliminates a whole class of _runtime errors_\n"
-" via the borrow checker. You get performance like in C and C++, but you don't\n"
-" have the memory unsafety issues. In addition, you get a modern language with\n"
-" constructs like pattern matching and built-in dependency management.\n"
-"\n"
-"* Experience with Java, Go, Python, JavaScript...: You get the same memory safety\n"
-" as in those languages, plus a similar high-level language feeling. In addition\n"
-" you get fast and predictable performance like C and C++ (no garbage collector)\n"
-" as well as access to low-level hardware (should you need it)"
+"Experience with C or C++: Rust eliminates a whole class of _runtime errors_ "
+"via the borrow checker. You get performance like in C and C++, but you don't "
+"have the memory unsafety issues. In addition, you get a modern language with "
+"constructs like pattern matching and built-in dependency management."
msgstr ""
-"* C/C++: ๋ฌ์คํธ๋ '๋น๋ฆผ'๊ฒ์ฌ๊ธฐ๋ฅผ ํตํด์ ์ํ์ค์ ๋ฐ์ํ ์ ์๋ ๋ชจ๋ ์๋ฌ๋ฅผ ์ ๊ฑฐํฉ๋๋ค. ๋ฌ์คํธ๋ C์ C++๊ณผ ๋น์ทํ ์์ค์ ์ฑ๋ฅ์ ๋ณด์ฌ์ฃผ๋ฉด์๋, ๊ทธ ์ธ์ด๋ค์์ ์ข ์ข ๋ฐ์ํ๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ จ ์ค๋ฅ๊ฐ ์์ต๋๋ค. ๋ํ, ํจํด ๋งค์นญ์ด๋, ๊ธฐ๋ณธ์ ์ผ๋ก ์ ๊ณต๋๋ ์ข ์์ฑ ๊ด๋ฆฌ์ ๊ฐ์ ํ๋์ ์ธ ์ธ์ด์ ๊ธฐ๋ฅ๋ค์ ์ ๊ณตํฉ๋๋ค.\n"
-"\n"
-"* Java, Go, Python, JaveScript: ์ด ์ธ์ด๋ค๊ณผ ๋์ผํ ๋ฉ๋ชจ๋ฆฌ ์์ ์ฑ๊ณผ ํจ๊ป, 'ํ์ด๋ ๋ฒจ'์ธ์ด์ ๋๋์ ๋๋ ์ ์์ต๋๋ค. ๊ฑฐ๊ธฐ์ ๋ํด, ๊ฐ๋น์ง ์ปฌ๋ ํฐ๊ฐ ์๋ C/C++์ ์ ์ฌํ ์์ค์ ๋น ๋ฅด๊ณ ์์ธก ๊ฐ๋ฅํ ์ฑ๋ฅ์ ๊ธฐ๋ํ ์ ์์ต๋๋ค. ๊ทธ๋ฆฌ๊ณ ํ์ํ ๊ฒฝ์ฐ ์ ์์ค ํ๋์จ์ด๋ฅผ ๋ค๋ฃจ๋ ์ฝ๋๋ก ์์ฑํ ์ ์์ต๋๋ค."
+"C/C++: ๋ฌ์คํธ๋ '๋น๋ฆผ'๊ฒ์ฌ๊ธฐ๋ฅผ ํตํด์ ์ํ์ค์ ๋ฐ์ํ ์ ์๋ ๋ชจ๋ ์๋ฌ๋ฅผ ์ "
+"๊ฑฐํฉ๋๋ค. ๋ฌ์คํธ๋ C์ C++๊ณผ ๋น์ทํ ์์ค์ ์ฑ๋ฅ์ ๋ณด์ฌ์ฃผ๋ฉด์๋, ๊ทธ ์ธ์ด๋ค์"
+"์ ์ข ์ข ๋ฐ์ํ๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ จ ์ค๋ฅ๊ฐ ์์ต๋๋ค. ๋ํ, ํจํด ๋งค์นญ์ด๋, ๊ธฐ๋ณธ์ ์ผ"
+"๋ก ์ ๊ณต๋๋ ์ข ์์ฑ ๊ด๋ฆฌ์ ๊ฐ์ ํ๋์ ์ธ ์ธ์ด์ ๊ธฐ๋ฅ๋ค์ ์ ๊ณตํฉ๋๋ค."
-#: src/why-rust/compile-time.md:1
-msgid "# Compile Time Guarantees"
-msgstr "# ์ปดํ์ผ ์ ๋ณด์ฅ๋๋ ๊ฒ๋ค"
+#: src/why-rust.md:19
+msgid ""
+"Experience with Java, Go, Python, JavaScript...: You get the same memory "
+"safety as in those languages, plus a similar high-level language feeling. In "
+"addition you get fast and predictable performance like C and C++ (no garbage "
+"collector) as well as access to low-level hardware (should you need it)"
+msgstr ""
+"Java, Go, Python, JaveScript: ์ด ์ธ์ด๋ค๊ณผ ๋์ผํ ๋ฉ๋ชจ๋ฆฌ ์์ ์ฑ๊ณผ ํจ๊ป, 'ํ์ด"
+"๋ ๋ฒจ'์ธ์ด์ ๋๋์ ๋๋ ์ ์์ต๋๋ค. ๊ฑฐ๊ธฐ์ ๋ํด, ๊ฐ๋น์ง ์ปฌ๋ ํฐ๊ฐ ์๋ C/C+"
+"+์ ์ ์ฌํ ์์ค์ ๋น ๋ฅด๊ณ ์์ธก ๊ฐ๋ฅํ ์ฑ๋ฅ์ ๊ธฐ๋ํ ์ ์์ต๋๋ค. ๊ทธ๋ฆฌ๊ณ ํ์"
+"ํ ๊ฒฝ์ฐ ์ ์์ค ํ๋์จ์ด๋ฅผ ๋ค๋ฃจ๋ ์ฝ๋๋ก ์์ฑํ ์ ์์ต๋๋ค."
#: src/why-rust/compile-time.md:3
msgid "Static memory management at compile time:"
msgstr "์ปดํ์ผ ์ ์ ์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ:"
#: src/why-rust/compile-time.md:5
-msgid ""
-"* No uninitialized variables.\n"
-"* No memory leaks (_mostly_, see notes).\n"
-"* No double-frees.\n"
-"* No use-after-free.\n"
-"* No `NULL` pointers.\n"
-"* No forgotten locked mutexes.\n"
-"* No data races between threads.\n"
-"* No iterator invalidation."
-msgstr ""
-"* ์ด๊ธฐํ๋์ง ์๋ ๋ณ์๊ฐ ์์ต๋๋ค.\n"
-"* ๋ฉ๋ชจ๋ฆฌ ๋์ถ ์์(_๊ฑฐ์_. ๊ฐ์์ฐธ์กฐ๋ ธํธ ์ฐธ๊ณ .)\n"
-"* ๋ฉ๋ชจ๋ฆฌ ์ด์ค ํด์ ๊ฐ ์์ฒ์ ์ผ๋ก ๋ถ๊ฐ๋ฅ ํฉ๋๋ค.\n"
-"* ๋ฉ๋ชจ๋ฆฌ ํด์ ํ ์ฌ์ฉ์ด ์์ฒ์ ์ผ๋ก ๋ถ๊ฐ๋ฅ ํฉ๋๋ค.\n"
-"* `NULL`ํฌ์ธํฐ๋ ์์ต๋๋ค.\n"
-"* ๋ฎคํ ์ค๋ฅผ ์ ๊ถ ๋๊ณ ์ฌ๋ ๊ฒ์ ์๋ ์ค์๋ฅผ ํ ์ ์์ต๋๋ค.\n"
-"* ์ค๋ ๋๊ฐ ๋ฐ์ดํฐ ๋ ์ด์ค๋ฅผ ๋ง์์ค๋๋ค.\n"
-"* ๋ฐ๋ณต์๊ฐ ๊ฐ์๊ธฐ ๋ฌดํจํ ๋๋ ๊ฒฝ์ฐ๊ฐ ์์ต๋๋ค."
+msgid "No uninitialized variables."
+msgstr "์ด๊ธฐํ๋์ง ์๋ ๋ณ์๊ฐ ์์ต๋๋ค."
+
+#: src/why-rust/compile-time.md:6
+msgid "No memory leaks (_mostly_, see notes)."
+msgstr "๋ฉ๋ชจ๋ฆฌ ๋์ถ ์์(_๊ฑฐ์_. ๊ฐ์์ฐธ์กฐ๋ ธํธ ์ฐธ๊ณ .)"
+
+#: src/why-rust/compile-time.md:7
+msgid "No double-frees."
+msgstr "๋ฉ๋ชจ๋ฆฌ ์ด์ค ํด์ ๊ฐ ์์ฒ์ ์ผ๋ก ๋ถ๊ฐ๋ฅ ํฉ๋๋ค."
+
+#: src/why-rust/compile-time.md:8
+msgid "No use-after-free."
+msgstr "๋ฉ๋ชจ๋ฆฌ ํด์ ํ ์ฌ์ฉ์ด ์์ฒ์ ์ผ๋ก ๋ถ๊ฐ๋ฅ ํฉ๋๋ค."
+
+#: src/why-rust/compile-time.md:9
+msgid "No `NULL` pointers."
+msgstr "`NULL`ํฌ์ธํฐ๋ ์์ต๋๋ค."
+
+#: src/why-rust/compile-time.md:10
+msgid "No forgotten locked mutexes."
+msgstr "๋ฎคํ ์ค๋ฅผ ์ ๊ถ ๋๊ณ ์ฌ๋ ๊ฒ์ ์๋ ์ค์๋ฅผ ํ ์ ์์ต๋๋ค."
+
+#: src/why-rust/compile-time.md:11
+msgid "No data races between threads."
+msgstr "์ค๋ ๋๊ฐ ๋ฐ์ดํฐ ๋ ์ด์ค๋ฅผ ๋ง์์ค๋๋ค."
+
+#: src/why-rust/compile-time.md:12
+msgid "No iterator invalidation."
+msgstr "๋ฐ๋ณต์๊ฐ ๊ฐ์๊ธฐ ๋ฌดํจํ ๋๋ ๊ฒฝ์ฐ๊ฐ ์์ต๋๋ค."
#: src/why-rust/compile-time.md:16
msgid ""
-"It is possible to produce memory leaks in (safe) Rust. Some examples\n"
-"are:"
-msgstr "(์์ ํ) ๋ฌ์คํธ์์๋ ๋ฉ๋ชจ๋ฆฌ ๋์ถ์ด ๋ฐ์ํ ์ ์๋ ๋ช ๊ฐ์ง ๊ฒฝ์ฐ๊ฐ ์์ต๋๋ค:"
+"It is possible to produce memory leaks in (safe) Rust. Some examples are:"
+msgstr ""
+"(์์ ํ) ๋ฌ์คํธ์์๋ ๋ฉ๋ชจ๋ฆฌ ๋์ถ์ด ๋ฐ์ํ ์ ์๋ ๋ช ๊ฐ์ง ๊ฒฝ์ฐ๊ฐ ์์ต๋๋ค:"
#: src/why-rust/compile-time.md:19
msgid ""
-"* You can for use [`Box::leak`] to leak a pointer. A use of this could\n"
-" be to get runtime-initialized and runtime-sized static variables\n"
-"* You can use [`std::mem::forget`] to make the compiler \"forget\" about\n"
-" a value (meaning the destructor is never run).\n"
-"* You can also accidentally create a [reference cycle] with `Rc` or\n"
-" `Arc`.\n"
-"* In fact, some will consider infinitely populating a collection a memory\n"
-" leak and Rust does not protect from those."
+"You can for use [`Box::leak`](https://doc.rust-lang.org/std/boxed/struct.Box."
+"html#method.leak) to leak a pointer. A use of this could be to get runtime-"
+"initialized and runtime-sized static variables"
msgstr ""
-"* [`Box::leak`]์ ์ด์ฉํ์ฌ ํฌ์ธํฐ๋ฅผ ์๋์ ์ผ๋ก ๋์ถ์ํฌ ์ ์์ต๋๋ค. ์ด๋ฅผ ์ด์ฉํด์ ๋ฐํ์์ด ์์ฑํ๊ณ ๋ฐํ์์ด ํฌ๊ธฐ๋ฅผ ์ ํ ์ ์ ๋ณ์๋ฅผ ๊ฐ์ ธ์ฌ ์ ์์ต๋๋ค.\n"
-"* [`std::mem::forget`]์ ์ฌ์ฉํ์ฌ ์ปดํ์ผ๋ฌ๊ฐ ๊ฐ์ ๋ํด \"์๋๋ก\" ๋ง๋ค ์ ์์ต๋๋ค(์๋ฉธ์๊ฐ ์คํ๋์ง ์์์ ์๋ฏธํฉ๋๋ค).\n"
-"* `Rc` ๋๋ `Arc`๋ฅผ ์ฌ์ฉํ์ฌ ์ค์๋ก [์ํ์ฐธ์กฐ][reference cycle]๋ฅผ ์์ฑํ ์๋ ์์ต๋๋ค.\n"
-"* ์ปฌ๋ ์ ์ ๋ฌดํ์ ์ฑ์ฐ๋ ๊ฒ์ ๋ฉ๋ชจ๋ฆฌ ๋์ถ๋ก ๊ฐ์ฃผํ ์๋ ์์ง๋ง, ๋ฌ์คํธ๋ ์ด๋ฅผ ๋ณดํธํ์ง ๋ชปํฉ๋๋ค."
+"[`Box::leak`](https://doc.rust-lang.org/std/boxed/struct.Box.html#method."
+"leak)์ ์ด์ฉํ์ฌ ํฌ์ธํฐ๋ฅผ ์๋์ ์ผ๋ก ๋์ถ์ํฌ ์ ์์ต๋๋ค. ์ด๋ฅผ ์ด์ฉํด์ ๋ฐํ"
+"์์ด ์์ฑํ๊ณ ๋ฐํ์์ด ํฌ๊ธฐ๋ฅผ ์ ํ ์ ์ ๋ณ์๋ฅผ ๊ฐ์ ธ์ฌ ์ ์์ต๋๋ค."
-#: src/why-rust/compile-time.md:28
+#: src/why-rust/compile-time.md:21
+msgid ""
+"You can use [`std::mem::forget`](https://doc.rust-lang.org/std/mem/fn.forget."
+"html) to make the compiler \"forget\" about a value (meaning the destructor "
+"is never run)."
+msgstr ""
+"[`std::mem::forget`](https://doc.rust-lang.org/std/mem/fn.forget.html)์ ์ฌ์ฉ"
+"ํ์ฌ ์ปดํ์ผ๋ฌ๊ฐ ๊ฐ์ ๋ํด \"์๋๋ก\" ๋ง๋ค ์ ์์ต๋๋ค(์๋ฉธ์๊ฐ ์คํ๋์ง ์์"
+"์ ์๋ฏธํฉ๋๋ค)."
+
+#: src/why-rust/compile-time.md:23
+msgid ""
+"You can also accidentally create a [reference cycle](https://doc.rust-lang."
+"org/book/ch15-06-reference-cycles.html) with `Rc` or `Arc`."
+msgstr ""
+"`Rc` ๋๋ `Arc`๋ฅผ ์ฌ์ฉํ์ฌ ์ค์๋ก [์ํ์ฐธ์กฐ](https://doc.rust-lang.org/book/"
+"ch15-06-reference-cycles.html)๋ฅผ ์์ฑํ ์๋ ์์ต๋๋ค."
+
+#: src/why-rust/compile-time.md:25
msgid ""
-"For the purpose of this course, \"No memory leaks\" should be understood\n"
-"as \"Pretty much no *accidental* memory leaks\"."
-msgstr "๋ณธ ๊ฐ์์์๋ \"๋ฉ๋ชจ๋ฆฌ ๋์ถ ์์\"์ \"์ฐ๋ฐ์ ์ธ ๋ฉ๋ชจ๋ฆฌ ๋์ถ ์์\"์ผ๋ก ์ดํดํด์ผ ํฉ๋๋ค."
+"In fact, some will consider infinitely populating a collection a memory leak "
+"and Rust does not protect from those."
+msgstr ""
+"์ปฌ๋ ์ ์ ๋ฌดํ์ ์ฑ์ฐ๋ ๊ฒ์ ๋ฉ๋ชจ๋ฆฌ ๋์ถ๋ก ๊ฐ์ฃผํ ์๋ ์์ง๋ง, ๋ฌ์คํธ๋ ์ด๋ฅผ "
+"๋ณดํธํ์ง ๋ชปํฉ๋๋ค."
-#: src/why-rust/runtime.md:1
-msgid "# Runtime Guarantees"
-msgstr "# ๋ฐํ์ ์ ๋ณด์ฅ๋๋ ๊ฒ๋ค"
+#: src/why-rust/compile-time.md:28
+msgid ""
+"For the purpose of this course, \"No memory leaks\" should be understood as "
+"\"Pretty much no _accidental_ memory leaks\"."
+msgstr ""
+"๋ณธ ๊ฐ์์์๋ \"๋ฉ๋ชจ๋ฆฌ ๋์ถ ์์\"์ \"์ฐ๋ฐ์ ์ธ ๋ฉ๋ชจ๋ฆฌ ๋์ถ ์์\"์ผ๋ก ์ดํดํด"
+"์ผ ํฉ๋๋ค."
#: src/why-rust/runtime.md:3
msgid "No undefined behavior at runtime:"
msgstr "๋ฐํ์ ์ ์ ์๋์ง ์์(undefined) ๋์ ์์:"
#: src/why-rust/runtime.md:5
-msgid ""
-"* Array access is bounds checked.\n"
-"* Integer overflow is defined."
-msgstr ""
-"* ๋ฐฐ์ด ์ ๊ทผ์ ๊ฒฝ๊ณ ์ฒดํฌ\n"
-"* ์ ์ํ ํ์ ์ ๋ณ์์์ ์ค๋ฒํ๋ก์ฐ ๋ฐ์์ ๋์์ด ์ ์ ์๋์ด์์ต๋๋ค."
+msgid "Array access is bounds checked."
+msgstr "๋ฐฐ์ด ์ ๊ทผ์ ๊ฒฝ๊ณ ์ฒดํฌ"
+
+#: src/why-rust/runtime.md:6
+msgid "Integer overflow is defined."
+msgstr "์ ์ํ ํ์ ์ ๋ณ์์์ ์ค๋ฒํ๋ก์ฐ ๋ฐ์์ ๋์์ด ์ ์ ์๋์ด์์ต๋๋ค."
#: src/why-rust/runtime.md:12
msgid ""
-"* Integer overflow is defined via a compile-time flag. The options are\n"
-" either a panic (a controlled crash of the program) or wrap-around\n"
-" semantics. By default, you get panics in debug mode (`cargo build`)\n"
-" and wrap-around in release mode (`cargo build --release`).\n"
-"\n"
-"* Bounds checking cannot be disabled with a compiler flag. It can also\n"
-" not be disabled directly with the `unsafe` keyword. However,\n"
-" `unsafe` allows you to call functions such as `slice::get_unchecked`\n"
-" which does not do bounds checking."
+"Integer overflow is defined via a compile-time flag. The options are either "
+"a panic (a controlled crash of the program) or wrap-around semantics. By "
+"default, you get panics in debug mode (`cargo build`) and wrap-around in "
+"release mode (`cargo build --release`)."
msgstr ""
-"* ์ ์ํ ์ค๋ฒํ๋ก์ฐ๋ ์ปดํ์ผ ํ์ ํ๋ ๊ทธ๋ฅผ ํตํด ์ ์๋ฉ๋๋ค. ์ต์ ์ ํจ๋(ํ๋ก๊ทธ๋จ ํฌ๋ ์) ํน์ ์ฌ๋ฆผ(wrap-around)์ ๋๋ค. ๊ธฐ๋ณธ์ ์ผ๋ก ๋๋ฒ๊ทธ ๋ชจ๋(`cargo build`)์์๋ ํจ๋์ด, ๋ฆด๋ฆฌ์ฆ ๋ชจ๋(`cargo build --release`)์์๋ wrap-around๊ฐ ๋ฐ์ํฉ๋๋ค.\n"
-"\n"
-"* ์ปดํ์ผ ํ๋๊ทธ๋ฅผ ์ฌ์ฉํ์ฌ ๊ฒฝ๊ณ์ฒดํฌ๋ฅผ ๋ฌด๋ ฅํ ํ ์ ์์ต๋๋ค. `unsafe`๋ฅผ ์ฌ์ฉํ๋๋ผ๋ ๋ง์ฐฌ๊ฐ์ง์ ๋๋ค. ํ์ง๋ง `unsafe`์์ ํธ์ถ ๊ฐ๋ฅํ `slice::get_unchecked`๊ฐ์ ํจ์๋ ๊ฒฝ๊ณ ๊ฒ์ฌ๋ฅผ ์ํํ์ง ์์ต๋๋ค."
+"์ ์ํ ์ค๋ฒํ๋ก์ฐ๋ ์ปดํ์ผ ํ์ ํ๋ ๊ทธ๋ฅผ ํตํด ์ ์๋ฉ๋๋ค. ์ต์ ์ ํจ๋(ํ๋ก๊ทธ"
+"๋จ ํฌ๋ ์) ํน์ ์ฌ๋ฆผ(wrap-around)์ ๋๋ค. ๊ธฐ๋ณธ์ ์ผ๋ก ๋๋ฒ๊ทธ ๋ชจ๋(`cargo "
+"build`)์์๋ ํจ๋์ด, ๋ฆด๋ฆฌ์ฆ ๋ชจ๋(`cargo build --release`)์์๋ wrap-around"
+"๊ฐ ๋ฐ์ํฉ๋๋ค."
-#: src/why-rust/modern.md:1
-msgid "# Modern Features"
-msgstr "# ํ๋์ ์ธ ํน์ง"
+#: src/why-rust/runtime.md:17
+msgid ""
+"Bounds checking cannot be disabled with a compiler flag. It can also not be "
+"disabled directly with the `unsafe` keyword. However, `unsafe` allows you to "
+"call functions such as `slice::get_unchecked` which does not do bounds "
+"checking."
+msgstr ""
+"์ปดํ์ผ ํ๋๊ทธ๋ฅผ ์ฌ์ฉํ์ฌ ๊ฒฝ๊ณ์ฒดํฌ๋ฅผ ๋ฌด๋ ฅํ ํ ์ ์์ต๋๋ค. `unsafe`๋ฅผ ์ฌ์ฉํ"
+"๋๋ผ๋ ๋ง์ฐฌ๊ฐ์ง์ ๋๋ค. ํ์ง๋ง `unsafe`์์ ํธ์ถ ๊ฐ๋ฅํ `slice::get_unchecked`"
+"๊ฐ์ ํจ์๋ ๊ฒฝ๊ณ ๊ฒ์ฌ๋ฅผ ์ํํ์ง ์์ต๋๋ค."
#: src/why-rust/modern.md:3
msgid "Rust is built with all the experience gained in the last 40 years."
-msgstr "๋ฌ์คํธ๋ ์ง๋ 40๋ ๊ฐ์ ๋ชจ๋ (ํ๋ก๊ทธ๋๋ฐ ์ธ์ด๋ค์) ๊ฒฝํ์ผ๋ก ๋ง๋ค์ด์ก์ต๋๋ค."
+msgstr ""
+"๋ฌ์คํธ๋ ์ง๋ 40๋ ๊ฐ์ ๋ชจ๋ (ํ๋ก๊ทธ๋๋ฐ ์ธ์ด๋ค์) ๊ฒฝํ์ผ๋ก ๋ง๋ค์ด์ก์ต๋๋ค."
#: src/why-rust/modern.md:5
-msgid "## Language Features"
-msgstr "## ์ธ์ด์ ํน์ง"
+msgid "Language Features"
+msgstr "์ธ์ด์ ํน์ง"
#: src/why-rust/modern.md:7
-msgid ""
-"* Enums and pattern matching.\n"
-"* Generics.\n"
-"* No overhead FFI.\n"
-"* Zero-cost abstractions."
+#, fuzzy
+msgid "Enums and pattern matching."
+msgstr "์ด๊ฑฐํ๊ณผ ํจํด ๋งค์นญ."
+
+#: src/why-rust/modern.md:8
+#, fuzzy
+msgid "Generics."
+msgstr "์ ๋ค๋ฆญ."
+
+#: src/why-rust/modern.md:9
+#, fuzzy
+msgid "No overhead FFI."
+msgstr "FFI ๋ฐํ์ ์ค๋ฒํค๋ ์์."
+
+#: src/why-rust/modern.md:10
+#, fuzzy
+msgid "Zero-cost abstractions."
msgstr ""
-"* ์ด๊ฑฐํ๊ณผ ํจํด ๋งค์นญ.\n"
-"* ์ ๋ค๋ฆญ.\n"
-"* FFI ๋ฐํ์ ์ค๋ฒํค๋ ์์.\n"
-" * _์ญ์ฃผ: FFI: Foreign Function Interface. ํ ์ธ์ด ์ฝ๋๋ฅผ ํธ์ถํ๊ธฐ ์ํ ์ธํฐํ์ด์ค_\n"
-"* ์ ๋ก ์ฝ์คํธ ์ถ์ํ."
+"_์ญ์ฃผ: FFI: Foreign Function Interface. ํ ์ธ์ด ์ฝ๋๋ฅผ ํธ์ถํ๊ธฐ ์ํ ์ธํฐํ์ด"
+"์ค_\n"
+"\n"
+"์ ๋ก ์ฝ์คํธ ์ถ์ํ."
#: src/why-rust/modern.md:12
-msgid "## Tooling"
-msgstr "## ๋๊ตฌ๋ค"
+msgid "Tooling"
+msgstr "๋๊ตฌ๋ค"
#: src/why-rust/modern.md:14
+msgid "Great compiler errors."
+msgstr "์น์ ํ ์ปดํ์ผ๋ฌ ์ค๋ฅ๋ฉ์์ง."
+
+#: src/why-rust/modern.md:15
+msgid "Built-in dependency manager."
+msgstr "๋ด์ฅ ์ข ์์ฑ ๊ด๋ฆฌ์."
+
+#: src/why-rust/modern.md:16
+msgid "Built-in support for testing."
+msgstr "๋ด์ฅ ํ ์คํธ ์ง์."
+
+#: src/why-rust/modern.md:17
+msgid "Excellent Language Server Protocol support."
+msgstr "LSP (Language Server Protocol, ์ธ์ด ์๋ฒ ํ๋กํ ์ฝ) ์ง์์ด ์๋์ด ์์."
+
+#: src/why-rust/modern.md:23
msgid ""
-"* Great compiler errors.\n"
-"* Built-in dependency manager.\n"
-"* Built-in support for testing.\n"
-"* Excellent Language Server Protocol support."
+"Zero-cost abstractions, similar to C++, means that you don't have to 'pay' "
+"for higher-level programming constructs with memory or CPU. For example, "
+"writing a loop using `for` should result in roughly the same low level "
+"instructions as using the `.iter().fold()` construct."
msgstr ""
-"* ์น์ ํ ์ปดํ์ผ๋ฌ ์ค๋ฅ๋ฉ์์ง.\n"
-"* ๋ด์ฅ ์ข ์์ฑ ๊ด๋ฆฌ์.\n"
-"* ๋ด์ฅ ํ ์คํธ ์ง์.\n"
-"* LSP (Language Server Protocol, ์ธ์ด ์๋ฒ ํ๋กํ ์ฝ) ์ง์์ด ์๋์ด ์์."
+"C++ ์ ์ ์ฌํ๊ฒ ์ ๋ก ์ฝ์คํธ ์ถ์ํ๋ CPU๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฌ์ฉํ์ฌ ์์๋ ๋ฒจ ํ๋ก๊ทธ"
+"๋๋ฐ ๊ตฌ์กฐ๋ฅผ ๋ง๋๋๋ฐ '๋น์ฉ'์ ์ง๋ถํ ํ์๊ฐ ์์ต๋๋ค. ์๋ฅผ ๋ค์ด `for` ๋ฃจํ์"
+"์ `iter().fold()` ๊ตฌ์กฐ๋ฅผ ์ฌ์ฉํ๋ ๊ฒ๊ณผ ๊ฑฐ์ ๋์ผํ ๋ฎ์ ์์ค์ ๋ช ๋ น์ด๊ฐ ์์ฑ"
+"๋ ๊ฒ ์ ๋๋ค."
-#: src/why-rust/modern.md:23
+#: src/why-rust/modern.md:28
msgid ""
-"* Zero-cost abstractions, similar to C++, means that you don't have to 'pay'\n"
-" for higher-level programming constructs with memory or CPU. For example,\n"
-" writing a loop using `for` should result in roughly the same low level\n"
-" instructions as using the `.iter().fold()` construct.\n"
-"\n"
-"* It may be worth mentioning that Rust enums are 'Algebraic Data Types', also\n"
-" known as 'sum types', which allow the type system to express things like\n"
-" `Option` and `Result`.\n"
-"\n"
-"* Remind people to read the errors --- many developers have gotten used to\n"
-" ignore lengthy compiler output. The Rust compiler is significantly more\n"
-" talkative than other compilers. It will often provide you with _actionable_\n"
-" feedback, ready to copy-paste into your code.\n"
-"\n"
-"* The Rust standard library is small compared to languages like Java, Python,\n"
-" and Go. Rust does not come with several things you might consider standard and\n"
-" essential:\n"
-"\n"
-" * a random number generator, but see [rand].\n"
-" * support for SSL or TLS, but see [rusttls].\n"
-" * support for JSON, but see [serde_json].\n"
-"\n"
-" The reasoning behind this is that functionality in the standard library cannot\n"
-" go away, so it has to be very stable. For the examples above, the Rust\n"
-" community is still working on finding the best solution --- and perhaps there\n"
-" isn't a single \"best solution\" for some of these things.\n"
-"\n"
-" Rust comes with a built-in package manager in the form of Cargo and this makes\n"
-" it trivial to download and compile third-party crates. A consequence of this\n"
-" is that the standard library can be smaller.\n"
-"\n"
-" Discovering good third-party crates can be a problem. Sites like\n"
-" help with this by letting you compare health metrics for\n"
-" crates to find a good and trusted one.\n"
-" \n"
-"* [rust-analyzer] is a well supported LSP implementation used in major\n"
-" IDEs and text editors."
+"It may be worth mentioning that Rust enums are 'Algebraic Data Types', also "
+"known as 'sum types', which allow the type system to express things like "
+"`Option` and `Result`."
msgstr ""
-"* C++ ์ ์ ์ฌํ๊ฒ ์ ๋ก ์ฝ์คํธ ์ถ์ํ๋ CPU๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฌ์ฉํ์ฌ ์์๋ ๋ฒจ ํ๋ก๊ทธ๋๋ฐ ๊ตฌ์กฐ๋ฅผ ๋ง๋๋๋ฐ '๋น์ฉ'์ ์ง๋ถํ ํ์๊ฐ ์์ต๋๋ค. ์๋ฅผ ๋ค์ด `for` ๋ฃจํ์์ `iter().fold()` ๊ตฌ์กฐ๋ฅผ ์ฌ์ฉํ๋ ๊ฒ๊ณผ ๊ฑฐ์ ๋์ผํ ๋ฎ์ ์์ค์ ๋ช ๋ น์ด๊ฐ ์์ฑ๋ ๊ฒ ์ ๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ์ ์ด๊ฑฐํ(enum)์ ํฉ๊ณ ํ์ (sum type)์ผ๋ก ์๋ ค์ง ๋์ํ์ ๋ฐ์ดํฐํ(Algebraic Data Type)์ผ๋ก, ํ์ ์์คํ ์ด `Option`์ `Result`๋ฑ์ ํํํ ์ ์๊ฒ ํด์ค๋๋ค.\n"
-"\n"
-"* ์ค๋ฅ๋ฅผ ์ฝ์ด๋ณด์๊ธฐ ๋ฐ๋๋๋ค --- ์ค๋๊ธฐ๊ฐ ๋ง์ ๊ฐ๋ฐ์๋ค์ด ์ปดํ์ผ๋ฌ ์ถ๋ ฅ์ ๋ฌด์ํ๋๋ฐ ์ต์ํด์ ธ ์์ต๋๋ค. ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ๋ค๋ฅธ ์ปดํ์ผ๋ฌ๋ณด๋ค ๋ ์๋ค์ค๋ฝ๊ณ , ๋ณต์ฌ-๋ถ์ฌ๋ฃ๊ธฐ ํ ์ ์๋ ์ ๋์ ์ฝ๋ ํผ๋๋ฐฑ์ ์ ๊ณตํ๋ ๊ฒฝ์ฐ๊ฐ ๋ง์ต๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ Java, Python์ด๋ Go์ ๊ฐ์ ์ธ์ด์ ๋นํด์ ๊ท๋ชจ๊ฐ ์์ต๋๋ค. ๋น์ฐํ ํฌํจ๋์ด์ผ ํ๋ค๊ณ ์๊ฐํ ์๋ ์๋ ์๋์ ๊ฐ์ ๊ฒ๋ค์ด ๋ฌ์คํธ์ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ์์ต๋๋ค:\n"
-"\n"
-" * ๋์ ์์ฑ๊ธฐ, ํ์ง๋ง [rand]๋ฌธ์๋ฅผ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-" * SSL ๋๋ TLS์ง์, ํ์ง๋ง [rusttls]๋ฌธ์๋ฅผ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-" * JSON ์ง์, ํ์ง๋ง [serde_json] ๋ฌธ์๋ฅผ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-"\n"
-" ๊ทธ ์ด์ ๋ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์์ ํ ๋ฒ ์ด๋ค ๊ธฐ๋ฅ์ ์ ๊ณตํ๋ฉด ๋บ ์ ์์ผ๋ฉฐ, ๋งค์ฐ ์์ ์ ์ด์ด์ผ ํ๊ธฐ ๋๋ฌธ์ ๋๋ค. ์์ ์ธ๊ธํ ๊ธฐ๋ฅ๋ค์ ์์ง ๋ฌ์คํธ ์ปค๋ฎค๋ํฐ๊ฐ ์ต๊ณ ์ ์๋ฃจ์ ์ ์ฐพ์ง ๋ชปํ๊ธฐ ๋๋ฌธ์ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ํฌํจ๋์ง ์์์ต๋๋ค. ์ด์ฉ๋ฉด ์ด๋ค ์ค ๋ช ๊ฐ๋ '์ต๊ณ ์ ์๋ฃจ์ '์ด ์์ ์กด์ฌํ ์ ์์ ์ง๋ ๋ชจ๋ฆ ๋๋ค.\n"
-"\n"
-" ๋ฌ์คํธ๋ ์นด๊ณ ๋ผ๋ ํจํค์ง ๊ด๋ฆฌ์๊ฐ ๋ด์ฅ๋์ด ์๊ณ , ์๋ํํฐ ํฌ๋ ์ดํธ๋ฅผ ๋ค์ด๋ก๋, ์ปดํ์ผ ํ๊ธฐ ๋งค์ฐ ์ฝ์ต๋๋ค. ์ด ๋ํ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ ์์ ์ด์ ์ ๋๋ค.\n"
-"\n"
-" ์ข์ ์๋ํํฐ ํฌ๋ ์ดํธ๋ฅผ ์ฐพ๋ ๊ฒ์ ์ด๋ ต์ต๋๋ค. ์ ๊ฐ์ ์ฌ์ดํธ๊ฐ ์ ๋ขฐํ ์ ์๋ ์ข์ ํฌ๋ ์ดํธ๋ฅผ ๋น๊ตํ์ฌ ์ฐพ๋๋ฐ ์ข์ต๋๋ค.\n"
-"\n"
-"* [rust-analyzer]๋ ์ฃผ์ IDE๋ ํ ์คํธ ์๋ํฐ์์ ์ฌ์ฉ๋๋ ๋ฌ์คํธ์ฉ LSP์๋ฒ ์ ๋๋ค."
+"๋ฌ์คํธ์ ์ด๊ฑฐํ(enum)์ ํฉ๊ณ ํ์ (sum type)์ผ๋ก ์๋ ค์ง ๋์ํ์ ๋ฐ์ดํฐํ"
+"(Algebraic Data Type)์ผ๋ก, ํ์ ์์คํ ์ด `Option`์ `Result`๋ฑ์ ํ"
+"ํํ ์ ์๊ฒ ํด์ค๋๋ค."
+
+#: src/why-rust/modern.md:32
+msgid ""
+"Remind people to read the errors --- many developers have gotten used to "
+"ignore lengthy compiler output. The Rust compiler is significantly more "
+"talkative than other compilers. It will often provide you with _actionable_ "
+"feedback, ready to copy-paste into your code."
+msgstr ""
+"์ค๋ฅ๋ฅผ ์ฝ์ด๋ณด์๊ธฐ ๋ฐ๋๋๋ค --- ์ค๋๊ธฐ๊ฐ ๋ง์ ๊ฐ๋ฐ์๋ค์ด ์ปดํ์ผ๋ฌ ์ถ๋ ฅ์ ๋ฌด์"
+"ํ๋๋ฐ ์ต์ํด์ ธ ์์ต๋๋ค. ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ๋ค๋ฅธ ์ปดํ์ผ๋ฌ๋ณด๋ค ๋ ์๋ค์ค๋ฝ๊ณ , "
+"๋ณต์ฌ-๋ถ์ฌ๋ฃ๊ธฐ ํ ์ ์๋ ์ ๋์ ์ฝ๋ ํผ๋๋ฐฑ์ ์ ๊ณตํ๋ ๊ฒฝ์ฐ๊ฐ ๋ง์ต๋๋ค."
-#: src/basic-syntax.md:1
-msgid "# Basic Syntax"
-msgstr "# ๊ธฐ๋ณธ ๋ฌธ๋ฒ"
+#: src/why-rust/modern.md:37
+msgid ""
+"The Rust standard library is small compared to languages like Java, Python, "
+"and Go. Rust does not come with several things you might consider standard "
+"and essential:"
+msgstr ""
+"๋ฌ์คํธ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ Java, Python์ด๋ Go์ ๊ฐ์ ์ธ์ด์ ๋นํด์ ๊ท๋ชจ๊ฐ ์์ต"
+"๋๋ค. ๋น์ฐํ ํฌํจ๋์ด์ผ ํ๋ค๊ณ ์๊ฐํ ์๋ ์๋ ์๋์ ๊ฐ์ ๊ฒ๋ค์ด ๋ฌ์คํธ์ "
+"ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ์์ต๋๋ค:"
+
+#: src/why-rust/modern.md:41
+msgid "a random number generator, but see [rand](https://docs.rs/rand/)."
+msgstr ""
+"๋์ ์์ฑ๊ธฐ, ํ์ง๋ง [rand](https://docs.rs/rand/)๋ฌธ์๋ฅผ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค."
+
+#: src/why-rust/modern.md:42
+msgid "support for SSL or TLS, but see [rusttls](https://docs.rs/rustls/)."
+msgstr ""
+"SSL ๋๋ TLS์ง์, ํ์ง๋ง [rusttls](https://docs.rs/rustls/)๋ฌธ์๋ฅผ ์ฐธ์กฐํ์๊ธฐ "
+"๋ฐ๋๋๋ค."
+
+#: src/why-rust/modern.md:43
+msgid "support for JSON, but see [serde_json](https://docs.rs/serde_json/)."
+msgstr ""
+"JSON ์ง์, ํ์ง๋ง [serde_json](https://docs.rs/serde_json/) ๋ฌธ์๋ฅผ ์ฐธ์กฐํ์"
+"๊ธฐ ๋ฐ๋๋๋ค."
+
+#: src/why-rust/modern.md:45
+msgid ""
+"The reasoning behind this is that functionality in the standard library "
+"cannot go away, so it has to be very stable. For the examples above, the "
+"Rust community is still working on finding the best solution --- and perhaps "
+"there isn't a single \"best solution\" for some of these things."
+msgstr ""
+"๊ทธ ์ด์ ๋ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์์ ํ ๋ฒ ์ด๋ค ๊ธฐ๋ฅ์ ์ ๊ณตํ๋ฉด ๋บ ์ ์์ผ๋ฉฐ, ๋งค์ฐ "
+"์์ ์ ์ด์ด์ผ ํ๊ธฐ ๋๋ฌธ์ ๋๋ค. ์์ ์ธ๊ธํ ๊ธฐ๋ฅ๋ค์ ์์ง ๋ฌ์คํธ ์ปค๋ฎค๋ํฐ๊ฐ ์ต"
+"๊ณ ์ ์๋ฃจ์ ์ ์ฐพ์ง ๋ชปํ๊ธฐ ๋๋ฌธ์ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ํฌํจ๋์ง ์์์ต๋๋ค. ์ด์ฉ"
+"๋ฉด ์ด๋ค ์ค ๋ช ๊ฐ๋ '์ต๊ณ ์ ์๋ฃจ์ '์ด ์์ ์กด์ฌํ ์ ์์ ์ง๋ ๋ชจ๋ฆ ๋๋ค."
+
+#: src/why-rust/modern.md:50
+msgid ""
+"Rust comes with a built-in package manager in the form of Cargo and this "
+"makes it trivial to download and compile third-party crates. A consequence "
+"of this is that the standard library can be smaller."
+msgstr ""
+"๋ฌ์คํธ๋ ์นด๊ณ ๋ผ๋ ํจํค์ง ๊ด๋ฆฌ์๊ฐ ๋ด์ฅ๋์ด ์๊ณ , ์๋ํํฐ ํฌ๋ ์ดํธ๋ฅผ ๋ค์ด๋ก"
+"๋, ์ปดํ์ผ ํ๊ธฐ ๋งค์ฐ ์ฝ์ต๋๋ค. ์ด ๋ํ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ ์์ ์ด์ ์ ๋๋ค."
+
+#: src/why-rust/modern.md:54
+msgid ""
+"Discovering good third-party crates can be a problem. Sites like help with this by letting you compare health metrics for crates to "
+"find a good and trusted one."
+msgstr ""
+"์ข์ ์๋ํํฐ ํฌ๋ ์ดํธ๋ฅผ ์ฐพ๋ ๊ฒ์ ์ด๋ ต์ต๋๋ค. ์ ๊ฐ์ ์ฌ์ด"
+"ํธ๊ฐ ์ ๋ขฐํ ์ ์๋ ์ข์ ํฌ๋ ์ดํธ๋ฅผ ๋น๊ตํ์ฌ ์ฐพ๋๋ฐ ์ข์ต๋๋ค."
+
+#: src/why-rust/modern.md:58
+msgid ""
+"[rust-analyzer](https://rust-analyzer.github.io/) is a well supported LSP "
+"implementation used in major IDEs and text editors."
+msgstr ""
+"[rust-analyzer](https://rust-analyzer.github.io/)๋ ์ฃผ์ IDE๋ ํ ์คํธ ์๋ํฐ"
+"์์ ์ฌ์ฉ๋๋ ๋ฌ์คํธ์ฉ LSP์๋ฒ ์ ๋๋ค."
#: src/basic-syntax.md:3
msgid "Much of the Rust syntax will be familiar to you from C, C++ or Java:"
msgstr "๋๋ถ๋ถ์ ๋ฌ์คํธ ๋ฌธ๋ฒ์ C/C++/Java ์ ์ ์ฌํฉ๋๋ค:"
#: src/basic-syntax.md:5
+msgid "Blocks and scopes are delimited by curly braces."
+msgstr "๋ธ๋ก๊ณผ ๋ฒ์๋ ์ค๊ดํธ`{}`๋ก ํํํฉ๋๋ค."
+
+#: src/basic-syntax.md:6
msgid ""
-"* Blocks and scopes are delimited by curly braces.\n"
-"* Line comments are started with `//`, block comments are delimited by `/* ...\n"
-" */`.\n"
-"* Keywords like `if` and `while` work the same.\n"
-"* Variable assignment is done with `=`, comparison is done with `==`."
-msgstr ""
-"* ๋ธ๋ก๊ณผ ๋ฒ์๋ ์ค๊ดํธ`{}`๋ก ํํํฉ๋๋ค.\n"
-"* ์ธ๋ผ์ธ ์ฃผ์์ `//`, ๋ธ๋ก ์ฃผ์์ `/* ... */`๋ก ์ฌ์ฉํฉ๋๋ค.\n"
-"* `if`๋ `while`๊ฐ์ ํค์๋๋ ๋์ผํฉ๋๋ค.\n"
-"* ๋ณ์ ํ ๋น์ `=`, ๋น๊ต๋ `==`๋ฅผ ์ฌ์ฉํฉ๋๋ค."
-
-#: src/basic-syntax/scalar-types.md:1
-msgid "# Scalar Types"
-msgstr "# ์ค์นผ๋ผ ํ์ "
-
-#: src/basic-syntax/scalar-types.md:3
-msgid ""
-"| | Types | Literals |\n"
-"|------------------------|--------------------------------------------|-------------------------------|\n"
-"| Signed integers | `i8`, `i16`, `i32`, `i64`, `i128`, `isize` | `-10`, `0`, `1_000`, `123i64` |\n"
-"| Unsigned integers | `u8`, `u16`, `u32`, `u64`, `u128`, `usize` | `0`, `123`, `10u16` |\n"
-"| Floating point numbers | `f32`, `f64` | `3.14`, `-10.0e20`, `2f32` |\n"
-"| Strings | `&str` | `\"foo\"`, `r#\"\\\\\"#` |\n"
-"| Unicode scalar values | `char` | `'a'`, `'ฮฑ'`, `'โ'` |\n"
-"| Byte strings | `&[u8]` | `b\"abc\"`, `br#\" \" \"#` |\n"
-"| Booleans | `bool` | `true`, `false` |"
-msgstr ""
-"| | ํ์ | ์ค์นผ๋ผ ๋ฆฌํฐ๋ด ๊ฐ |\n"
-"|-----------------|--------------------------------------------|-------------------------------|\n"
-"| ๋ถํธ์๋ ์ ์ | `i8`, `i16`, `i32`, `i64`, `i128`, `isize` | `-10`, `0`, `1_000`, `123i64` |\n"
-"| ๋ถํธ์๋ ์ ์ | `u8`, `u16`, `u32`, `u64`, `u128`, `usize` | `0`, `123`, `10u16` |\n"
-"| ๋ถ๋์์ | `f32`, `f64` | `3.14`, `-10.0e20`, `2f32` |\n"
-"| ๋ฌธ์์ด | `&str` | `\"foo\"`, `r#\"\\\\\"#` |\n"
-"| ์ ๋์ฝ๋ ๋ฌธ์ | `char` | `'a'`, `'ฮฑ'`, `'โ'` |\n"
-"| ๋ฐ์ดํธ ๋ฌธ์ | `&[u8]` | `b\"abc\"`, `br#\" \" \"#` |\n"
-"| ๋ถ๋ฆฌ์ธ | `bool` | `true`, `false` |"
+"Line comments are started with `//`, block comments are delimited by `/* ... "
+"*/`."
+msgstr "์ธ๋ผ์ธ ์ฃผ์์ `//`, ๋ธ๋ก ์ฃผ์์ `/* ... */`๋ก ์ฌ์ฉํฉ๋๋ค."
+
+#: src/basic-syntax.md:8
+msgid "Keywords like `if` and `while` work the same."
+msgstr "`if`๋ `while`๊ฐ์ ํค์๋๋ ๋์ผํฉ๋๋ค."
+
+#: src/basic-syntax.md:9
+msgid "Variable assignment is done with `=`, comparison is done with `==`."
+msgstr "๋ณ์ ํ ๋น์ `=`, ๋น๊ต๋ `==`๋ฅผ ์ฌ์ฉํฉ๋๋ค."
+
+#: src/basic-syntax/scalar-types.md:3 src/basic-syntax/compound-types.md:3
+msgid "Types"
+msgstr "ํ์ "
+
+#: src/basic-syntax/scalar-types.md:3 src/basic-syntax/compound-types.md:3
+msgid "Literals"
+msgstr "์ค์นผ๋ผ ๋ฆฌํฐ๋ด ๊ฐ"
+
+#: src/basic-syntax/scalar-types.md:5
+msgid "Signed integers"
+msgstr "๋ถํธ์๋ ์ ์"
+
+#: src/basic-syntax/scalar-types.md:5
+msgid "`i8`, `i16`, `i32`, `i64`, `i128`, `isize`"
+msgstr "`i8`, `i16`, `i32`, `i64`, `i128`, `isize`"
+
+#: src/basic-syntax/scalar-types.md:5
+msgid "`-10`, `0`, `1_000`, `123i64`"
+msgstr "`-10`, `0`, `1_000`, `123i64`"
+
+#: src/basic-syntax/scalar-types.md:6
+msgid "Unsigned integers"
+msgstr "๋ถํธ์๋ ์ ์"
+
+#: src/basic-syntax/scalar-types.md:6
+msgid "`u8`, `u16`, `u32`, `u64`, `u128`, `usize`"
+msgstr "`u8`, `u16`, `u32`, `u64`, `u128`, `usize`"
+
+#: src/basic-syntax/scalar-types.md:6
+msgid "`0`, `123`, `10u16`"
+msgstr "`0`, `123`, `10u16`"
+
+#: src/basic-syntax/scalar-types.md:7
+msgid "Floating point numbers"
+msgstr "๋ถ๋์์"
+
+#: src/basic-syntax/scalar-types.md:7
+msgid "`f32`, `f64`"
+msgstr "`f32`, `f64`"
+
+#: src/basic-syntax/scalar-types.md:7
+msgid "`3.14`, `-10.0e20`, `2f32`"
+msgstr "`3.14`, `-10.0e20`, `2f32`"
+
+#: src/basic-syntax/scalar-types.md:8
+msgid "Strings"
+msgstr "๋ฌธ์์ด"
+
+#: src/basic-syntax/scalar-types.md:8
+msgid "`&str`"
+msgstr "`&str`"
+
+#: src/basic-syntax/scalar-types.md:8
+msgid "`\"foo\"`, `r#\"\\\\\"#`"
+msgstr "`\"foo\"`, `r#\"\\\\\"#`"
+
+#: src/basic-syntax/scalar-types.md:9
+msgid "Unicode scalar values"
+msgstr "์ ๋์ฝ๋ ๋ฌธ์"
+
+#: src/basic-syntax/scalar-types.md:9
+msgid "`char`"
+msgstr "`char`"
+
+#: src/basic-syntax/scalar-types.md:9
+msgid "`'a'`, `'ฮฑ'`, `'โ'`"
+msgstr "`'a'`, `'ฮฑ'`, `'โ'`"
+
+#: src/basic-syntax/scalar-types.md:10
+msgid "Byte strings"
+msgstr "๋ฐ์ดํธ ๋ฌธ์"
+
+#: src/basic-syntax/scalar-types.md:10
+msgid "`&[u8]`"
+msgstr "`&[u8]`"
+
+#: src/basic-syntax/scalar-types.md:10
+msgid "`b\"abc\"`, `br#\" \" \"#`"
+msgstr "`b\"abc\"`, `br#\" \" \"#`"
+
+#: src/basic-syntax/scalar-types.md:11
+msgid "Booleans"
+msgstr "๋ถ๋ฆฌ์ธ"
+
+#: src/basic-syntax/scalar-types.md:11
+msgid "`bool`"
+msgstr "`bool`"
+
+#: src/basic-syntax/scalar-types.md:11
+msgid "`true`, `false`"
+msgstr "`true`, `false`"
#: src/basic-syntax/scalar-types.md:13
msgid "The types have widths as follows:"
msgstr "๊ฐ ํ์ ์ ํฌ๊ธฐ๋ ๋ค์๊ณผ ๊ฐ์ต๋๋ค:"
#: src/basic-syntax/scalar-types.md:15
-msgid ""
-"* `iN`, `uN`, and `fN` are _N_ bits wide,\n"
-"* `isize` and `usize` are the width of a pointer,\n"
-"* `char` is 32 bit wide,\n"
-"* `bool` is 8 bit wide."
+#, fuzzy
+msgid "`iN`, `uN`, and `fN` are _N_ bits wide,"
msgstr ""
-"* ์ ์(`i`) ๋ฐ ๋ถ๋์์ํ(`f`)์ ๋ค์ ์ซ์์ ๊ฐ์ ๋นํธ ์ ์ ๋๋ค. (`i8` = 8๋นํธ)\n"
-"* `isize` ์ `usize` ๋ ํฌ์ธํฐ์ ๊ฐ์ ํฌ๊ธฐ์ ๋๋ค.\n"
-" * _์ญ์ฃผ: 32 ๋นํธ ์์คํ ์์๋ 32 ๋นํธ, 64 ๋นํธ ์์คํ ์์๋ 64 ๋นํธ. C์ `int`์ ๊ฐ์._\n"
-"* `char` 32 ๋นํธ ์ ๋๋ค.\n"
-"* `bool`์ 8 ๋นํธ ์ ๋๋ค."
+"์ ์(`i`) ๋ฐ ๋ถ๋์์ํ(`f`)์ ๋ค์ ์ซ์์ ๊ฐ์ ๋นํธ ์ ์ ๋๋ค. (`i8` = 8๋น"
+"ํธ)"
-#: src/basic-syntax/compound-types.md:1
-msgid "# Compound Types"
-msgstr "# ๋ณตํฉ ํ์ "
+#: src/basic-syntax/scalar-types.md:16
+#, fuzzy
+msgid "`isize` and `usize` are the width of a pointer,"
+msgstr "`isize` ์ `usize` ๋ ํฌ์ธํฐ์ ๊ฐ์ ํฌ๊ธฐ์ ๋๋ค."
-#: src/basic-syntax/compound-types.md:3
-msgid ""
-"| | Types | Literals |\n"
-"|--------|-------------------------------|-----------------------------------|\n"
-"| Arrays | `[T; N]` | `[20, 30, 40]`, `[0; 3]` |\n"
-"| Tuples | `()`, `(T,)`, `(T1, T2)`, ... | `()`, `('x',)`, `('x', 1.2)`, ... |"
+#: src/basic-syntax/scalar-types.md:17
+#, fuzzy
+msgid "`char` is 32 bit wide,"
+msgstr ""
+"_์ญ์ฃผ: 32 ๋นํธ ์์คํ ์์๋ 32 ๋นํธ, 64 ๋นํธ ์์คํ ์์๋ 64 ๋นํธ. C์ `int`"
+"์ ๊ฐ์._"
+
+#: src/basic-syntax/scalar-types.md:18
+#, fuzzy
+msgid "`bool` is 8 bit wide."
msgstr ""
-"| | ํ์ | ๋ฆฌํฐ๋ด |\n"
-"|------|-------------------------------|-----------------------------------|\n"
-"| ๋ฐฐ์ด | `[T; N]` | `[20, 30, 40]`, `[0; 3]` |\n"
-"| ํํ | `()`, `(T,)`, `(T1, T2)`, ... | `()`, `('x',)`, `('x', 1.2)`, ... |"
+"`char` 32 ๋นํธ ์ ๋๋ค.\n"
+"\n"
+"`bool`์ 8 ๋นํธ ์ ๋๋ค."
+
+#: src/basic-syntax/compound-types.md:5
+msgid "Arrays"
+msgstr "๋ฐฐ์ด"
+
+#: src/basic-syntax/compound-types.md:5
+msgid "`[T; N]`"
+msgstr "`[T; N]`"
+
+#: src/basic-syntax/compound-types.md:5
+msgid "`[20, 30, 40]`, `[0; 3]`"
+msgstr "`[20, 30, 40]`, `[0; 3]`"
+
+#: src/basic-syntax/compound-types.md:6
+msgid "Tuples"
+msgstr "ํํ"
+
+#: src/basic-syntax/compound-types.md:6
+msgid "`()`, `(T,)`, `(T1, T2)`, ..."
+msgstr "`()`, `(T,)`, `(T1, T2)`, ..."
+
+#: src/basic-syntax/compound-types.md:6
+msgid "`()`, `('x',)`, `('x', 1.2)`, ..."
+msgstr "`()`, `('x',)`, `('x', 1.2)`, ..."
#: src/basic-syntax/compound-types.md:8
msgid "Array assignment and access:"
@@ -2336,58 +2770,71 @@ msgstr "๋ฐฐ์ด:"
#: src/basic-syntax/compound-types.md:34
msgid ""
-"* Arrays have elements of the same type, `T`, and length, `N`, which is a compile-time constant.\n"
-" Note that the length of the array is *part of its type*, which means that `[u8; 3]` and\n"
-" `[u8; 4]` are considered two different types.\n"
-"\n"
-"* We can use literals to assign values to arrays.\n"
-"\n"
-"* In the main function, the print statement asks for the debug implementation with the `?` format\n"
-" parameter: `{}` gives the default output, `{:?}` gives the debug output. We\n"
-" could also have used `{a}` and `{a:?}` without specifying the value after the\n"
-" format string.\n"
-"\n"
-"* Adding `#`, eg `{a:#?}`, invokes a \"pretty printing\" format, which can be easier to read."
+"Arrays have elements of the same type, `T`, and length, `N`, which is a "
+"compile-time constant. Note that the length of the array is _part of its "
+"type_, which means that `[u8; 3]` and `[u8; 4]` are considered two different "
+"types."
msgstr ""
-"* ๋ฐฐ์ด์, ๊ฐ์ ํ์ `T`์ ๊ฐ์ด `N`๊ฐ ์๋ ๊ฒ์ ๋๋ค. ์ฌ๊ธฐ์ `N`์ ์ปดํ์ผ ํ์์ ๊ฒฐ์ ๋ ๊ฐ์ด์ด์ผ ํฉ๋๋ค. ์ด ๊ธธ์ด๋ ํ์ ์ ์ผ๋ถ์ ๋๋ค. ๋ฐ๋ผ์, `[u8; 3]`์ `[u8; 4]`์ ์๋ก ๋ค๋ฅธ ํ์ ์ ๋๋ค.\n"
-"\n"
-"* ๋ฆฌํฐ๋ด์ ์ฌ์ฉํ์ฌ ๋ฐฐ์ด์ ๊ฐ์ ํ ๋นํ ์ ์์ต๋๋ค.\n"
-"\n"
-"* ํฌ๋งคํ ๋ฌธ์์ด์์ `?`๋ ๋๋ฒ๊น ์ถ๋ ฅ์ ์๋ฏธํฉ๋๋ค. `{}`๋ ๊ธฐ๋ณธ ์ถ๋ ฅ์ด๋ฉฐ, `{:?}`๋ ๋๋ฒ๊น ์ถ๋ ฅ์ ๋๋ค. `{a}`, `{a:?}`์ ๊ฐ์ด ์ถ๋ ฅํ ๋ณ์ ์ด๋ฆ์ ํฌ๋งคํ ๋ฌธ์์ด์ ํฌํจ์ํฌ ์๋ ์์ผ๋ฉฐ, ์ด ๊ฒฝ์ฐ ์ธ์ `a`๋ ๋ณ๋์ ์ธ์๋ก ์ถ๊ฐํ์ง ์์ต๋๋ค.\n"
-"\n"
-"* `#`์ ์ถ๊ฐํ๋ฉด(`{a:#?}`) ์ข ๋ ์ฝ๊ธฐ ์ฌ์ด \\\"์ด์\\\" ํํ๋ก ์ถ๋ ฅ์ด ๋ฉ๋๋ค."
+"๋ฐฐ์ด์, ๊ฐ์ ํ์ `T`์ ๊ฐ์ด `N`๊ฐ ์๋ ๊ฒ์ ๋๋ค. ์ฌ๊ธฐ์ `N`์ ์ปดํ์ผ ํ์์ "
+"๊ฒฐ์ ๋ ๊ฐ์ด์ด์ผ ํฉ๋๋ค. ์ด ๊ธธ์ด๋ ํ์ ์ ์ผ๋ถ์ ๋๋ค. ๋ฐ๋ผ์, `[u8; 3]`์ "
+"`[u8; 4]`์ ์๋ก ๋ค๋ฅธ ํ์ ์ ๋๋ค."
+
+#: src/basic-syntax/compound-types.md:38
+msgid "We can use literals to assign values to arrays."
+msgstr "๋ฆฌํฐ๋ด์ ์ฌ์ฉํ์ฌ ๋ฐฐ์ด์ ๊ฐ์ ํ ๋นํ ์ ์์ต๋๋ค."
+
+#: src/basic-syntax/compound-types.md:40
+msgid ""
+"In the main function, the print statement asks for the debug implementation "
+"with the `?` format parameter: `{}` gives the default output, `{:?}` gives "
+"the debug output. We could also have used `{a}` and `{a:?}` without "
+"specifying the value after the format string."
+msgstr ""
+"ํฌ๋งคํ ๋ฌธ์์ด์์ `?`๋ ๋๋ฒ๊น ์ถ๋ ฅ์ ์๋ฏธํฉ๋๋ค. `{}`๋ ๊ธฐ๋ณธ ์ถ๋ ฅ์ด๋ฉฐ, `{:?}"
+"`๋ ๋๋ฒ๊น ์ถ๋ ฅ์ ๋๋ค. `{a}`, `{a:?}`์ ๊ฐ์ด ์ถ๋ ฅํ ๋ณ์ ์ด๋ฆ์ ํฌ๋งคํ ๋ฌธ์์ด"
+"์ ํฌํจ์ํฌ ์๋ ์์ผ๋ฉฐ, ์ด ๊ฒฝ์ฐ ์ธ์ `a`๋ ๋ณ๋์ ์ธ์๋ก ์ถ๊ฐํ์ง ์์ต๋๋ค."
+
+#: src/basic-syntax/compound-types.md:45
+msgid ""
+"Adding `#`, eg `{a:#?}`, invokes a \"pretty printing\" format, which can be "
+"easier to read."
+msgstr ""
+"`#`์ ์ถ๊ฐํ๋ฉด(`{a:#?}`) ์ข ๋ ์ฝ๊ธฐ ์ฌ์ด \"์ด์\" ํํ๋ก ์ถ๋ ฅ์ด ๋ฉ๋๋ค."
#: src/basic-syntax/compound-types.md:47
msgid "Tuples:"
msgstr "ํํ:"
#: src/basic-syntax/compound-types.md:49
+msgid "Like arrays, tuples have a fixed length."
+msgstr "๋ฐฐ์ด๊ณผ ๋ง์ฐฌ๊ฐ์ง๋ก ํํ์ ๊ณ ์ ๊ธธ์ด๋ฅผ ๊ฐ์ต๋๋ค."
+
+#: src/basic-syntax/compound-types.md:51
+msgid "Tuples group together values of different types into a compound type."
+msgstr "ํํ์ ์๋ก ๋ค๋ฅธ ํ์ ์ ๊ฐ๋ค์ ํ๋์ ๋ณตํฉ ํ์ ์ผ๋ก ๋ฌถ์ต๋๋ค."
+
+#: src/basic-syntax/compound-types.md:53
msgid ""
-"* Like arrays, tuples have a fixed length.\n"
-"\n"
-"* Tuples group together values of different types into a compound type.\n"
-"\n"
-"* Fields of a tuple can be accessed by the period and the index of the value, e.g. `t.0`, `t.1`.\n"
-"\n"
-"* The empty tuple `()` is also known as the \"unit type\". It is both a type, and\n"
-" the only valid value of that type - that is to say both the type and its value\n"
-" are expressed as `()`. It is used to indicate, for example, that a function or\n"
-" expression has no return value, as we'll see in a future slide. \n"
-" * You can think of it as `void` that can be familiar to you from other \n"
-" programming languages."
+"Fields of a tuple can be accessed by the period and the index of the value, "
+"e.g. `t.0`, `t.1`."
+msgstr "ํํ์ ์ํ ๊ฐ์ `t.0`, `t.1`๊ณผ ๊ฐ์ด ์ธ๋ฑ์ค๋ก ์ ๊ทผํ ์ ์์ต๋๋ค."
+
+#: src/basic-syntax/compound-types.md:55
+msgid ""
+"The empty tuple `()` is also known as the \"unit type\". It is both a type, "
+"and the only valid value of that type - that is to say both the type and its "
+"value are expressed as `()`. It is used to indicate, for example, that a "
+"function or expression has no return value, as we'll see in a future slide. "
msgstr ""
-"* ๋ฐฐ์ด๊ณผ ๋ง์ฐฌ๊ฐ์ง๋ก ํํ์ ๊ณ ์ ๊ธธ์ด๋ฅผ ๊ฐ์ต๋๋ค.\n"
-"\n"
-"* ํํ์ ์๋ก ๋ค๋ฅธ ํ์ ์ ๊ฐ๋ค์ ํ๋์ ๋ณตํฉ ํ์ ์ผ๋ก ๋ฌถ์ต๋๋ค.\n"
-"\n"
-"* ํํ์ ์ํ ๊ฐ์ `t.0`, `t.1`๊ณผ ๊ฐ์ด ์ธ๋ฑ์ค๋ก ์ ๊ทผํ ์ ์์ต๋๋ค.\n"
-"\n"
-"* ๋น์ด์๋ ํํ`()`์ ๋จ์ ํ์ (unit type)์ด๋ผ๊ณ ๋ ํฉ๋๋ค. ์ด๋ ํ์ ์ด๋ฉด์ ํด๋น ํ์ ์ ์ ์ผํ๋ฉฐ ์ ํจํ ๊ฐ์ ๋๋ค. ์ฆ ํ์ ๊ณผ ๊ฐ์ด ๋ชจ๋ `()`์ ๋๋ค. ์๋ฅผ ๋ค์ด ํจ์๋ ์์์ ๋ฐํ ๊ฐ์ด ์์์ ๋ํ๋ผ ๋ ์ฌ์ฉํฉ๋๋ค.\n"
-" * ๋ค๋ฅธ ์ธ์ด์์ ์ต์ํ `void` ๊ฐ๋ ์ผ๋ก ์๊ฐํ ์ ์์ต๋๋ค."
+"๋น์ด์๋ ํํ`()`์ ๋จ์ ํ์ (unit type)์ด๋ผ๊ณ ๋ ํฉ๋๋ค. ์ด๋ ํ์ ์ด๋ฉด์ ํด"
+"๋น ํ์ ์ ์ ์ผํ๋ฉฐ ์ ํจํ ๊ฐ์ ๋๋ค. ์ฆ ํ์ ๊ณผ ๊ฐ์ด ๋ชจ๋ `()`์ ๋๋ค. ์๋ฅผ ๋ค"
+"์ด ํจ์๋ ์์์ ๋ฐํ ๊ฐ์ด ์์์ ๋ํ๋ผ ๋ ์ฌ์ฉํฉ๋๋ค."
-#: src/basic-syntax/references.md:1
-msgid "# References"
-msgstr "# ์ฐธ์กฐ"
+#: src/basic-syntax/compound-types.md:59
+msgid ""
+"You can think of it as `void` that can be familiar to you from other "
+"programming languages."
+msgstr "๋ค๋ฅธ ์ธ์ด์์ ์ต์ํ `void` ๊ฐ๋ ์ผ๋ก ์๊ฐํ ์ ์์ต๋๋ค."
#: src/basic-syntax/references.md:3
msgid "Like C++, Rust has references:"
@@ -2419,33 +2866,37 @@ msgstr "์ฐธ๊ณ ์ฌํญ:"
#: src/basic-syntax/references.md:16
msgid ""
-"* We must dereference `ref_x` when assigning to it, similar to C and C++ pointers.\n"
-"* Rust will auto-dereference in some cases, in particular when invoking\n"
-" methods (try `ref_x.count_ones()`).\n"
-"* References that are declared as `mut` can be bound to different values over their lifetime."
+"We must dereference `ref_x` when assigning to it, similar to C and C++ "
+"pointers."
msgstr ""
-"* `ref_x`์ ๊ฐ์ ํ ๋นํ ๋, C/C++์ ํฌ์ธํฐ์ ์ ์ฌํ๊ฒ `*`๋ฅผ ์ด์ฉํด์ ์ฐธ์กฐ๋ฅผ ๋ฐ๋ผ๊ฐ์ผ(์ญ์ฐธ์กฐ) ํฉ๋๋ค.\n"
-"* ๋ฌ์คํธ๋ ํน์ ํ ๊ฒฝ์ฐ(๋ฉ์๋ ํธ์ถ)์ ์๋์ผ๋ก ์ญ์ฐธ์กฐ๋ฅผ ํฉ๋๋ค.(`ref_x.count_one()`์ ํ๋ฉด `*ref_x`๊ฐ `count_one`์ ์ธ์๋ก ์ ๋ฌ๋ฉ๋๋ค.)\n"
-"* `mut`๋ก ์ ์ธ๋ ์ฐธ์กฐ๋ ๊ทธ ๋ณ์๊ฐ ์ด์์๋ ๋์ ๋ค๋ฅธ ๊ฐ์ ๊ฐ์ง ์ ์์ต๋๋ค."
+"`ref_x`์ ๊ฐ์ ํ ๋นํ ๋, C/C++์ ํฌ์ธํฐ์ ์ ์ฌํ๊ฒ `*`๋ฅผ ์ด์ฉํด์ ์ฐธ์กฐ๋ฅผ ๋ฐ"
+"๋ผ๊ฐ์ผ(์ญ์ฐธ์กฐ) ํฉ๋๋ค."
-#: src/basic-syntax/references.md:21
+#: src/basic-syntax/references.md:17
msgid ""
-"\n"
-"Key points:"
+"Rust will auto-dereference in some cases, in particular when invoking "
+"methods (try `ref_x.count_ones()`)."
msgstr ""
-"\n"
-"ํค ํฌ์ธํธ:"
+"๋ฌ์คํธ๋ ํน์ ํ ๊ฒฝ์ฐ(๋ฉ์๋ ํธ์ถ)์ ์๋์ผ๋ก ์ญ์ฐธ์กฐ๋ฅผ ํฉ๋๋ค.(`ref_x."
+"count_one()`์ ํ๋ฉด `*ref_x`๊ฐ `count_one`์ ์ธ์๋ก ์ ๋ฌ๋ฉ๋๋ค.)"
-#: src/basic-syntax/references.md:24
+#: src/basic-syntax/references.md:19
msgid ""
-"* Be sure to note the difference between `let mut ref_x: &i32` and `let ref_x:\n"
-" &mut i32`. The first one represents a mutable reference which can be bound to\n"
-" different values, while the second represents a reference to a mutable value."
-msgstr "* `let mut ref_x: &i32`์ `let ref_x: &mut i32`์ ์ฐจ์ด์ ์ ์ฃผ์ ํ์๊ธฐ ๋ฐ๋๋๋ค. ์ฒซ๋ฒ์งธ ๊ฐ์ ๋ค๋ฅธ ๊ฐ์ ๋ฐ์ธ๋ฉ ๋ ์ ์๋ ๊ฐ๋ณ ์ฐธ์กฐ์ด๊ณ , ๋๋ฒ์งธ ๊ฐ์ ๊ฐ๋ณ ๊ฐ์ ๋ํ ์ฐธ์กฐ์ ๋๋ค."
+"References that are declared as `mut` can be bound to different values over "
+"their lifetime."
+msgstr ""
+"`mut`๋ก ์ ์ธ๋ ์ฐธ์กฐ๋ ๊ทธ ๋ณ์๊ฐ ์ด์์๋ ๋์ ๋ค๋ฅธ ๊ฐ์ ๊ฐ์ง ์ ์์ต๋๋ค."
-#: src/basic-syntax/references-dangling.md:1
-msgid "# Dangling References"
-msgstr "# ํ์(dangling) ์ฐธ์กฐ"
+#: src/basic-syntax/references.md:24
+msgid ""
+"Be sure to note the difference between `let mut ref_x: &i32` and `let ref_x: "
+"&mut i32`. The first one represents a mutable reference which can be bound "
+"to different values, while the second represents a reference to a mutable "
+"value."
+msgstr ""
+"`let mut ref_x: &i32`์ `let ref_x: &mut i32`์ ์ฐจ์ด์ ์ ์ฃผ์ ํ์๊ธฐ ๋ฐ๋๋"
+"๋ค. ์ฒซ๋ฒ์งธ ๊ฐ์ ๋ค๋ฅธ ๊ฐ์ ๋ฐ์ธ๋ฉ ๋ ์ ์๋ ๊ฐ๋ณ ์ฐธ์กฐ์ด๊ณ , ๋๋ฒ์งธ ๊ฐ์ ๊ฐ๋ณ "
+"๊ฐ์ ๋ํ ์ฐธ์กฐ์ ๋๋ค."
#: src/basic-syntax/references-dangling.md:3
msgid "Rust will statically forbid dangling references:"
@@ -2476,19 +2927,21 @@ msgstr ""
"```"
#: src/basic-syntax/references-dangling.md:16
+msgid "A reference is said to \"borrow\" the value it refers to."
+msgstr "์ฐธ์กฐ๋ ์ด๋ค ๊ฐ์ \"๋น๋ฆฌ๋\" ๊ฒ์ ๋๋ค."
+
+#: src/basic-syntax/references-dangling.md:17
msgid ""
-"* A reference is said to \"borrow\" the value it refers to.\n"
-"* Rust is tracking the lifetimes of all references to ensure they live long\n"
-" enough.\n"
-"* We will talk more about borrowing when we get to ownership."
+"Rust is tracking the lifetimes of all references to ensure they live long "
+"enough."
msgstr ""
-"* ์ฐธ์กฐ๋ ์ด๋ค ๊ฐ์ \"๋น๋ฆฌ๋\" ๊ฒ์ ๋๋ค.\n"
-"* ๋ฌ์คํธ๋ ์ฐธ์กฐ ๋์์ ๊ฐ์ด, ๊ทธ ๊ฐ์ ๋ํ ๋ชจ๋ ์ฐธ์กฐ๋ค๋ณด๋ค ๋ ์ค๋ ์ด์์์์ ์ถ์ ํฉ๋๋ค.\n"
-"* ์์ ๊ถ์ ๋ํ ์ฃผ์ ๋ฅผ ๋ค๋ฃฐ ๋ ์ด ๋น๋ฆผ์ ๋ํด ๋ ์์ธํ ์ด์ผ๊ธฐ ํ๊ฒ ์ต๋๋ค."
+"๋ฌ์คํธ๋ ์ฐธ์กฐ ๋์์ ๊ฐ์ด, ๊ทธ ๊ฐ์ ๋ํ ๋ชจ๋ ์ฐธ์กฐ๋ค๋ณด๋ค ๋ ์ค๋ ์ด์์์์ ์ถ"
+"์ ํฉ๋๋ค."
-#: src/basic-syntax/slices.md:1
-msgid "# Slices"
-msgstr "# ์ฌ๋ผ์ด์ค"
+#: src/basic-syntax/references-dangling.md:19
+msgid "We will talk more about borrowing when we get to ownership."
+msgstr ""
+"์์ ๊ถ์ ๋ํ ์ฃผ์ ๋ฅผ ๋ค๋ฃฐ ๋ ์ด ๋น๋ฆผ์ ๋ํด ๋ ์์ธํ ์ด์ผ๊ธฐ ํ๊ฒ ์ต๋๋ค."
#: src/basic-syntax/slices.md:3
msgid "A slice gives you a view into a larger collection:"
@@ -2517,48 +2970,76 @@ msgstr ""
"```"
#: src/basic-syntax/slices.md:15
+msgid "Slices borrow data from the sliced type."
+msgstr "์ฌ๋ผ์ด์ค๋ ๋ค๋ฅธ(์ฌ๋ผ์ด์ค ๋) ํ์ ์ผ๋ก๋ถํฐ ๋ฐ์ดํฐ๋ฅผ '๋น๋ ค'์ต๋๋ค."
+
+#: src/basic-syntax/slices.md:16
+msgid "Question: What happens if you modify `a[3]`?"
+msgstr "์ง๋ฌธ: `a[3]`์ ์์ ํ๋ฉด ๋ฌด์จ ์ผ์ด ์์ด๋ ๊น์?"
+
+#: src/basic-syntax/slices.md:20
msgid ""
-"* Slices borrow data from the sliced type.\n"
-"* Question: What happens if you modify `a[3]`?"
+"We create a slice by borrowing `a` and specifying the starting and ending "
+"indexes in brackets."
msgstr ""
-"* ์ฌ๋ผ์ด์ค๋ ๋ค๋ฅธ(์ฌ๋ผ์ด์ค ๋) ํ์ ์ผ๋ก๋ถํฐ ๋ฐ์ดํฐ๋ฅผ '๋น๋ ค'์ต๋๋ค.\n"
-"* ์ง๋ฌธ: `a[3]`์ ์์ ํ๋ฉด ๋ฌด์จ ์ผ์ด ์์ด๋ ๊น์?"
+"์ฌ๋ผ์ด์ค๋ ์ฐ์ `a`๋ฅผ ๋น๋ฆฐ๋ค์, ์์๊ณผ ๋ ์ธ๋ฑ์ค๋ฅผ ๋ธ๋ํท(`[]`)์์ ์ง์ ํด์ "
+"๋ง๋ญ๋๋ค."
-#: src/basic-syntax/slices.md:20
+#: src/basic-syntax/slices.md:22
msgid ""
-"* We create a slice by borrowing `a` and specifying the starting and ending indexes in brackets.\n"
-"\n"
-"* If the slice starts at index 0, Rustโs range syntax allows us to drop the starting index, meaning that `&a[0..a.len()]` and `&a[..a.len()]` are identical.\n"
-" \n"
-"* The same is true for the last index, so `&a[2..a.len()]` and `&a[2..]` are identical.\n"
-"\n"
-"* To easily create a slice of the full array, we can therefore use `&a[..]`.\n"
-"\n"
-"* `s` is a reference to a slice of `i32`s. Notice that the type of `s` (`&[i32]`) no longer mentions the array length. This allows us to perform computation on slices of different sizes.\n"
-" \n"
-"* Slices always borrow from another object. In this example, `a` has to remain 'alive' (in scope) for at least as long as our slice. \n"
-" \n"
-"* The question about modifying `a[3]` can spark an interesting discussion, but the answer is that for memory safety reasons\n"
-" you cannot do it through `a` after you created a slice, but you can read the data from both `a` and `s` safely. \n"
-" More details will be explained in the borrow checker section."
+"If the slice starts at index 0, Rustโs range syntax allows us to drop the "
+"starting index, meaning that `&a[0..a.len()]` and `&a[..a.len()]` are "
+"identical."
msgstr ""
-"* ์ฌ๋ผ์ด์ค๋ ์ฐ์ `a`๋ฅผ ๋น๋ฆฐ๋ค์, ์์๊ณผ ๋ ์ธ๋ฑ์ค๋ฅผ ๋ธ๋ํท(`[]`)์์ ์ง์ ํด์ ๋ง๋ญ๋๋ค.\n"
-"\n"
-"* ์ฌ๋ผ์ด์ค๊ฐ ์ธ๋ฑ์ค 0๋ถํฐ ์์ํ๋ค๋ฉด ์์ ์ธ๋ฑ์ค๋ ์๋ต ๊ฐ๋ฅํฉ๋๋ค. ์ฆ `&a[0..a.len()]`์ `&a[..a.len()]` ๋ ๋์ผํฉ๋๋ค.\n"
-"\n"
-"* ๋ง์ง๋ง ์ธ๋ฑ์ค๋ ์๋ต ๊ฐ๋ฅํฉ๋๋ค. ๊ทธ๋์ `&a[2..a.len()]` ์ `&a[2..]`๋ ๋์ผํฉ๋๋ค.\n"
-"\n"
-"* ๋ฐ๋ผ์ ์ ์ฒด ๋ฐฐ์ด์ ๋ํ ์ฌ๋ผ์ด์ค๋ `&a[..]`๊ฐ ๋ฉ๋๋ค.\n"
-"\n"
-"* `s`๋ `i32`๋ค๋ก ์ด๋ฃจ์ด์ง ์ฌ๋ผ์ด์ค์ ๋ํ ์ฐธ์กฐ์ ๋๋ค. `s`์ ํ์ (`&[i32]`)์ ๋ฐฐ์ด์ ํฌ๊ธฐ๊ฐ ๋น ์ ธ์์์ ์ฃผ๋ชฉํ์๊ธฐ ๋ฐ๋๋๋ค. ์ฆ, ์ฌ๋ผ์ด์ค๋ฅผ ์ด์ฉํ๋ฉด ๋ค์ํ ๊ธธ์ด์ ๋ฐ์ดํฐ๋ฅผ ๋ค๋ฃฐ ์ ์์ต๋๋ค.\n"
-"\n"
-"* ์ฌ๋ผ์ด์ค๋ ํญ์ ๋ค๋ฅธ ๊ฐ์ฒด๋ก๋ถํฐ '๋น๋ ค' ์ต๋๋ค. ์ด ์์์์ ๊ฐ์ฒด `a`๋ ์ฌ๋ผ์ด์ค `s`๋ณด๋ค ๋ ์ค๋ ์ด์ ์์ด์ผ๋ง ํฉ๋๋ค.\n"
-"\n"
-"* `a[3]`์ ๊ฐ์ ๋ฐ๊ฟ ์ ์๋๋ ์ง๋ฌธ์ ์ข์ ์ง๋ฌธ์ ๋๋ค. ์ฌ๊ธฐ์ ๋ํ ๋ต์ `a`์ `s`๋ฅผ ํตํด ๋ฐ์ดํฐ๋ฅผ ์ฝ์ ์๋ ์์ง๋ง ์์ ํ ์๋ ์์ผ๋ฉฐ, ์ด๋ ๋ฉ๋ชจ๋ฆฌ ์์ ์ ์ํด์๋ผ๋ ๊ฒ์ ๋๋ค. ์ ๊ทธ๋ฐ์ง์ ๋ํ ์ข๋ ๊ตฌ์ฒด์ ์ธ ๋ต์ ๋น๋ฆผ ๊ฒ์ฌ ๋ถ๋ถ์์ ์์ธํ ์ค๋ช ํฉ๋๋ค."
+"์ฌ๋ผ์ด์ค๊ฐ ์ธ๋ฑ์ค 0๋ถํฐ ์์ํ๋ค๋ฉด ์์ ์ธ๋ฑ์ค๋ ์๋ต ๊ฐ๋ฅํฉ๋๋ค. ์ฆ `&a[0.."
+"a.len()]`์ `&a[..a.len()]` ๋ ๋์ผํฉ๋๋ค."
+
+#: src/basic-syntax/slices.md:24
+msgid ""
+"The same is true for the last index, so `&a[2..a.len()]` and `&a[2..]` are "
+"identical."
+msgstr ""
+"๋ง์ง๋ง ์ธ๋ฑ์ค๋ ์๋ต ๊ฐ๋ฅํฉ๋๋ค. ๊ทธ๋์ `&a[2..a.len()]` ์ `&a[2..]`๋ ๋์ผ"
+"ํฉ๋๋ค."
+
+#: src/basic-syntax/slices.md:26
+msgid ""
+"To easily create a slice of the full array, we can therefore use `&a[..]`."
+msgstr "๋ฐ๋ผ์ ์ ์ฒด ๋ฐฐ์ด์ ๋ํ ์ฌ๋ผ์ด์ค๋ `&a[..]`๊ฐ ๋ฉ๋๋ค."
+
+#: src/basic-syntax/slices.md:28
+msgid ""
+"`s` is a reference to a slice of `i32`s. Notice that the type of `s` "
+"(`&[i32]`) no longer mentions the array length. This allows us to perform "
+"computation on slices of different sizes."
+msgstr ""
+"`s`๋ `i32`๋ค๋ก ์ด๋ฃจ์ด์ง ์ฌ๋ผ์ด์ค์ ๋ํ ์ฐธ์กฐ์ ๋๋ค. `s`์ ํ์ (`&[i32]`)์ "
+"๋ฐฐ์ด์ ํฌ๊ธฐ๊ฐ ๋น ์ ธ์์์ ์ฃผ๋ชฉํ์๊ธฐ ๋ฐ๋๋๋ค. ์ฆ, ์ฌ๋ผ์ด์ค๋ฅผ ์ด์ฉํ๋ฉด ๋ค์ํ "
+"๊ธธ์ด์ ๋ฐ์ดํฐ๋ฅผ ๋ค๋ฃฐ ์ ์์ต๋๋ค."
+
+#: src/basic-syntax/slices.md:30
+msgid ""
+"Slices always borrow from another object. In this example, `a` has to remain "
+"'alive' (in scope) for at least as long as our slice. "
+msgstr ""
+"์ฌ๋ผ์ด์ค๋ ํญ์ ๋ค๋ฅธ ๊ฐ์ฒด๋ก๋ถํฐ '๋น๋ ค' ์ต๋๋ค. ์ด ์์์์ ๊ฐ์ฒด `a`๋ ์ฌ๋ผ์ด"
+"์ค `s`๋ณด๋ค ๋ ์ค๋ ์ด์ ์์ด์ผ๋ง ํฉ๋๋ค."
+
+#: src/basic-syntax/slices.md:32
+msgid ""
+"The question about modifying `a[3]` can spark an interesting discussion, but "
+"the answer is that for memory safety reasons you cannot do it through `a` "
+"after you created a slice, but you can read the data from both `a` and `s` "
+"safely. More details will be explained in the borrow checker section."
+msgstr ""
+"`a[3]`์ ๊ฐ์ ๋ฐ๊ฟ ์ ์๋๋ ์ง๋ฌธ์ ์ข์ ์ง๋ฌธ์ ๋๋ค. ์ฌ๊ธฐ์ ๋ํ ๋ต์ `a`์ "
+"`s`๋ฅผ ํตํด ๋ฐ์ดํฐ๋ฅผ ์ฝ์ ์๋ ์์ง๋ง ์์ ํ ์๋ ์์ผ๋ฉฐ, ์ด๋ ๋ฉ๋ชจ๋ฆฌ ์์ ์ "
+"์ํด์๋ผ๋ ๊ฒ์ ๋๋ค. ์ ๊ทธ๋ฐ์ง์ ๋ํ ์ข๋ ๊ตฌ์ฒด์ ์ธ ๋ต์ ๋น๋ฆผ ๊ฒ์ฌ ๋ถ๋ถ์์ "
+"์์ธํ ์ค๋ช ํฉ๋๋ค."
#: src/basic-syntax/string-slices.md:1
-msgid "# `String` vs `str`"
-msgstr "# `String`๊ณผ `str`"
+msgid "`String` vs `str`"
+msgstr "`String`๊ณผ `str`"
#: src/basic-syntax/string-slices.md:3
msgid "We can now understand the two string types in Rust:"
@@ -2601,52 +3082,77 @@ msgid "Rust terminology:"
msgstr "๋ฌ์คํธ ์ฉ์ด:"
#: src/basic-syntax/string-slices.md:22
+msgid "`&str` an immutable reference to a string slice."
+msgstr "`&str`์ ๋ฌธ์์ด ์ฌ๋ผ์ด์ค์ ๋ํ (๋ถ๋ณ) ์ฐธ์กฐ์ ๋๋ค."
+
+#: src/basic-syntax/string-slices.md:23
+msgid "`String` a mutable string buffer."
+msgstr "`String`์ ๋ฌธ์์ด์ ๋ด์ ์ ์๋ ๋ฒํผ์ ๋๋ค."
+
+#: src/basic-syntax/string-slices.md:27
msgid ""
-"* `&str` an immutable reference to a string slice.\n"
-"* `String` a mutable string buffer."
+"`&str` introduces a string slice, which is an immutable reference to UTF-8 "
+"encoded string data stored in a block of memory. String literals "
+"(`โHelloโ`), are stored in the programโs binary."
msgstr ""
-"* `&str`์ ๋ฌธ์์ด ์ฌ๋ผ์ด์ค์ ๋ํ (๋ถ๋ณ) ์ฐธ์กฐ์ ๋๋ค.\n"
-"* `String`์ ๋ฌธ์์ด์ ๋ด์ ์ ์๋ ๋ฒํผ์ ๋๋ค."
+"`&str`์ ๋ฌธ์์ด ์ฌ๋ผ์ด์ค์ ๋ถ๋ณ ์ฐธ์กฐ์ ๋๋ค. ๋ฌ์คํธ์์ ๋ฌธ์์ด์ UTF-8๋ก ์ธ์ฝ"
+"๋ฉ๋ ๋ฐ์ดํฐ๋ฅผ ์๋ฏธํฉ๋๋ค. ๋ฌธ์์ด ๋ฆฌํฐ๋ด(`\"Hello\"`)์ ํ๋ก๊ทธ๋จ ๋ฐ์ด๋๋ฆฌ์ ์ "
+"์ฅ๋ฉ๋๋ค."
-#: src/basic-syntax/string-slices.md:27
+#: src/basic-syntax/string-slices.md:30
msgid ""
-"* `&str` introduces a string slice, which is an immutable reference to UTF-8 encoded string data \n"
-" stored in a block of memory. String literals (`โHelloโ`), are stored in the programโs binary.\n"
-"\n"
-"* Rustโs `String` type is a wrapper around a vector of bytes. As with a `Vec`, it is owned.\n"
-" \n"
-"* As with many other types `String::from()` creates a string from a string literal; `String::new()` \n"
-" creates a new empty string, to which string data can be added using the `push()` and `push_str()` methods.\n"
-"\n"
-"* The `format!()` macro is a convenient way to generate an owned string from dynamic values. It \n"
-" accepts the same format specification as `println!()`.\n"
-" \n"
-"* You can borrow `&str` slices from `String` via `&` and optionally range selection.\n"
-" \n"
-"* For C++ programmers: think of `&str` as `const char*` from C++, but the one that always points \n"
-" to a valid string in memory. Rust `String` is a rough equivalent of `std::string` from C++ \n"
-" (main difference: it can only contain UTF-8 encoded bytes and will never use a small-string optimization).\n"
-" "
+"Rustโs `String` type is a wrapper around a vector of bytes. As with a "
+"`Vec`, it is owned."
msgstr ""
-"* `&str`์ ๋ฌธ์์ด ์ฌ๋ผ์ด์ค์ ๋ถ๋ณ ์ฐธ์กฐ์ ๋๋ค. ๋ฌ์คํธ์์ ๋ฌธ์์ด์ UTF-8๋ก ์ธ์ฝ๋ฉ๋ ๋ฐ์ดํฐ๋ฅผ ์๋ฏธํฉ๋๋ค. ๋ฌธ์์ด ๋ฆฌํฐ๋ด(`\"Hello\"`)์ ํ๋ก๊ทธ๋จ ๋ฐ์ด๋๋ฆฌ์ ์ ์ฅ๋ฉ๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ์ `String`ํ์ ์ ์ค์ ๋ก๋ ๋ฌธ์์ด์ ์ด๋ฃจ๋ ๋ฐ์ดํธ์ ๋ํ ๋ฐฑํฐ(`Vec`)์ ๋๋ค. `Vec`๊ฐ `T`๋ฅผ ์์ ํ๊ณ ์๋ฏ์ด, `String`์ด ๊ฐ๋ฆฌํค๊ณ ์๋ ๋ฌธ์์ด์ `String`์ ์์ ์ ๋๋ค.\n"
-"\n"
-"* ๋ค๋ฅธ ๋ง์ ํ์ ๋ค์ฒ๋ผ `String::from`๋ ๋ฌธ์์ด ๋ฆฌํฐ๋ด๋ก๋ถํฐ ๋ฌธ์์ด์ ์์ฑํฉ๋๋ค. `String::new()`๋ ์๋ก์ด ๋น ๋ฌธ์์ด์ ์์ฑํฉ๋๋ค. `push()`์ `push_str()`๋ฉ์๋๋ฅผ ์ฌ์ฉํ์ฌ ๋ฌธ์์ด ๋ฐ์ดํฐ๋ฅผ ์ถ๊ฐ ํ ์ ์์ต๋๋ค.\n"
-"\n"
-"* `format!()` ๋งคํฌ๋ก๋ ๋ณ์์ ๊ฐ์ ๋ฌธ์์ด๋ก ๋ณํํ๋ ํธ๋ฆฌํ ๋ฐฉ๋ฒ์ ๋๋ค. ์ด ๋งคํฌ๋ก๋ `println!()` ๋งคํฌ๋ก์ ๋์ผํ ํฌ๋งทํ ํ์์ ์ง์ํฉ๋๋ค.\n"
-"\n"
-"* `&`์ ๋ฒ์ ์ฐ์ฐ์๋ฅผ ์ด์ฉํ์ฌ `String`์์ `&str`์ฌ๋ผ์ด์ค๋ฅผ ๋น๋ ค์ฌ ์ ์์ต๋๋ค.\n"
-"\n"
-"* ๋น์ ์ด C++ ํ๋ก๊ทธ๋๋จธ ๋ผ๋ฉด: `&str`๋ C++์ `const char*`์ ์ ์ฌํ์ง๋ง ํญ์ ์ ํจํ ๋ฌธ์์ด์ ๊ฐ๋ฆฌํจ๋ค๋ ์ ์ด ๋ค๋ฆ ๋๋ค. ๋ฌ์คํธ์ `String`์ C++์ `std::string` ๊ณผ ๋๋ต ๊ฑฐ์ ๋์ผํฉ๋๋ค. (์ฃผ์ ์ฐจ์ด์ : ๋ฌ์คํธ์ `String`์ UTF-8 ์ธ์ฝ๋ฉ ๋ฐ์ดํธ๋ง ํฌํจํ ์ ์์ผ๋ฉฐ ์์ ๋ฌธ์์ด ์ต์ ํ(small-string optimization)๋ ์ฌ์ฉํ์ง ์์ต๋๋ค."
+"๋ฌ์คํธ์ `String`ํ์ ์ ์ค์ ๋ก๋ ๋ฌธ์์ด์ ์ด๋ฃจ๋ ๋ฐ์ดํธ์ ๋ํ ๋ฐฑํฐ"
+"(`Vec`)์ ๋๋ค. `Vec`๊ฐ `T`๋ฅผ ์์ ํ๊ณ ์๋ฏ์ด, `String`์ด ๊ฐ๋ฆฌํค๊ณ ์"
+"๋ ๋ฌธ์์ด์ `String`์ ์์ ์ ๋๋ค."
+
+#: src/basic-syntax/string-slices.md:32
+msgid ""
+"As with many other types `String::from()` creates a string from a string "
+"literal; `String::new()` creates a new empty string, to which string data "
+"can be added using the `push()` and `push_str()` methods."
+msgstr ""
+"๋ค๋ฅธ ๋ง์ ํ์ ๋ค์ฒ๋ผ `String::from`๋ ๋ฌธ์์ด ๋ฆฌํฐ๋ด๋ก๋ถํฐ ๋ฌธ์์ด์ ์์ฑํฉ๋"
+"๋ค. `String::new()`๋ ์๋ก์ด ๋น ๋ฌธ์์ด์ ์์ฑํฉ๋๋ค. `push()`์ `push_str()`"
+"๋ฉ์๋๋ฅผ ์ฌ์ฉํ์ฌ ๋ฌธ์์ด ๋ฐ์ดํฐ๋ฅผ ์ถ๊ฐ ํ ์ ์์ต๋๋ค."
+
+#: src/basic-syntax/string-slices.md:35
+msgid ""
+"The `format!()` macro is a convenient way to generate an owned string from "
+"dynamic values. It accepts the same format specification as `println!()`."
+msgstr ""
+"`format!()` ๋งคํฌ๋ก๋ ๋ณ์์ ๊ฐ์ ๋ฌธ์์ด๋ก ๋ณํํ๋ ํธ๋ฆฌํ ๋ฐฉ๋ฒ์ ๋๋ค. ์ด ๋งคํฌ"
+"๋ก๋ `println!()` ๋งคํฌ๋ก์ ๋์ผํ ํฌ๋งทํ ํ์์ ์ง์ํฉ๋๋ค."
+
+#: src/basic-syntax/string-slices.md:38
+msgid ""
+"You can borrow `&str` slices from `String` via `&` and optionally range "
+"selection."
+msgstr ""
+"`&`์ ๋ฒ์ ์ฐ์ฐ์๋ฅผ ์ด์ฉํ์ฌ `String`์์ `&str`์ฌ๋ผ์ด์ค๋ฅผ ๋น๋ ค์ฌ ์ ์์ต๋"
+"๋ค."
-#: src/basic-syntax/functions.md:1
-msgid "# Functions"
-msgstr "# ํจ์"
+#: src/basic-syntax/string-slices.md:40
+msgid ""
+"For C++ programmers: think of `&str` as `const char*` from C++, but the one "
+"that always points to a valid string in memory. Rust `String` is a rough "
+"equivalent of `std::string` from C++ (main difference: it can only contain "
+"UTF-8 encoded bytes and will never use a small-string optimization)."
+msgstr ""
+"๋น์ ์ด C++ ํ๋ก๊ทธ๋๋จธ ๋ผ๋ฉด: `&str`๋ C++์ `const char*`์ ์ ์ฌํ์ง๋ง ํญ์ ์ "
+"ํจํ ๋ฌธ์์ด์ ๊ฐ๋ฆฌํจ๋ค๋ ์ ์ด ๋ค๋ฆ ๋๋ค. ๋ฌ์คํธ์ `String`์ C++์ `std::"
+"string` ๊ณผ ๋๋ต ๊ฑฐ์ ๋์ผํฉ๋๋ค. (์ฃผ์ ์ฐจ์ด์ : ๋ฌ์คํธ์ `String`์ UTF-8 ์ธ์ฝ"
+"๋ฉ ๋ฐ์ดํธ๋ง ํฌํจํ ์ ์์ผ๋ฉฐ ์์ ๋ฌธ์์ด ์ต์ ํ(small-string optimization)๋ "
+"์ฌ์ฉํ์ง ์์ต๋๋ค."
#: src/basic-syntax/functions.md:3
-msgid "A Rust version of the famous [FizzBuzz](https://en.wikipedia.org/wiki/Fizz_buzz) interview question:"
-msgstr "๋ฌ์คํธ ๋ฒ์ ์ [FizzBuzz](https://en.wikipedia.org/wiki/Fizz_buzz) ํจ์์ ๋๋ค:"
+msgid ""
+"A Rust version of the famous [FizzBuzz](https://en.wikipedia.org/wiki/"
+"Fizz_buzz) interview question:"
+msgstr ""
+"๋ฌ์คํธ ๋ฒ์ ์ [FizzBuzz](https://en.wikipedia.org/wiki/Fizz_buzz) ํจ์์ ๋๋ค:"
#: src/basic-syntax/functions.md:5
msgid ""
@@ -2659,10 +3165,12 @@ msgid ""
" if rhs == 0 {\n"
" return false; // Corner case, early return\n"
" }\n"
-" lhs % rhs == 0 // The last expression in a block is the return value\n"
+" lhs % rhs == 0 // The last expression in a block is the return "
+"value\n"
"}\n"
"\n"
-"fn fizzbuzz(n: u32) -> () { // No return value means returning the unit type `()`\n"
+"fn fizzbuzz(n: u32) -> () { // No return value means returning the unit "
+"type `()`\n"
" match (is_divisible_by(n, 3), is_divisible_by(n, 5)) {\n"
" (true, true) => println!(\"fizzbuzz\"),\n"
" (true, false) => println!(\"fizz\"),\n"
@@ -2680,7 +3188,8 @@ msgid ""
msgstr ""
"```rust,editable\n"
"fn main() {\n"
-" fizzbuzz_to(20); // C/C++ ์ ๋ฌ๋ฆฌ ํธ์ถ๋ถ ํ๋จ์ ์ ์ํด๋ ๋ฌธ์ ์์ต๋๋ค.\n"
+" fizzbuzz_to(20); // C/C++ ์ ๋ฌ๋ฆฌ ํธ์ถ๋ถ ํ๋จ์ ์ ์ํด๋ ๋ฌธ์ ์์ต๋"
+"๋ค.\n"
"}\n"
"\n"
"fn is_divisible_by(lhs: u32, rhs: u32) -> bool {\n"
@@ -2708,53 +3217,83 @@ msgstr ""
#: src/basic-syntax/functions.md:35
msgid ""
-"* We refer in `main` to a function written below. Neither forward declarations nor headers are necessary. \n"
-"* Declaration parameters are followed by a type (the reverse of some programming languages), then a return type.\n"
-"* The last expression in a function body (or any block) becomes the return value. Simply omit the `;` at the end of the expression.\n"
-"* Some functions have no return value, and return the 'unit type', `()`. The compiler will infer this if the `-> ()` return type is omitted.\n"
-"* The range expression in the `for` loop in `fizzbuzz_to()` contains `=n`, which causes it to include the upper bound.\n"
-"* The `match` expression in `fizzbuzz()` is doing a lot of work. It is expanded below to show what is happening.\n"
-"\n"
-" (Type annotations added for clarity, but they can be elided.)\n"
-"\n"
-" ```rust,ignore\n"
-" let by_3: bool = is_divisible_by(n, 3);\n"
-" let by_5: bool = is_divisible_by(n, 5);\n"
-" let by_35: (bool, bool) = (by_3, by_5);\n"
-" match by_35 {\n"
-" // ...\n"
-" ```\n"
-"\n"
-" "
+"We refer in `main` to a function written below. Neither forward declarations "
+"nor headers are necessary. "
msgstr ""
-"* `main` ํจ์์์ ๊ทธ ๋ค์์ ์ค๋ ํจ์๋ค์ ์ฌ์ฉํ ์ ์์ต๋๋ค. ์๋จ์ ์ ์ธ์ด๋ ํค๋ ๊ฐ์๊ฑด ํ์ ์์ต๋๋ค.\n"
-"* ๋งค๊ฐ๋ณ์๋ฅผ ์ ์ธํ ๋์๋ ์ด๋ฆ์ ๋จผ์ ์ฐ๊ณ , ํ์ ์ ๋์ค์ ์๋๋ค. ์ด๋ฆ๊ณผ ํ์ ์ `:` ๋ก ๊ตฌ๋ถํฉ๋๋ค. ์ด๋ ์ผ๋ถ ์ธ์ด(์๋ฅผ ๋ค์ด C)์ ๋ฐ๋์์ ์ ์ํ์๊ธฐ ๋ฐ๋๋๋ค. ๋ง์ฐฌ๊ฐ์ง๋ก, ๋ฆฌํด ํ์ ๋ ํจ์์ ์์์ด ์๋ ๊ฐ์ฅ ๋ท๋ถ๋ถ์ ์ ์ธํฉ๋๋ค.\n"
-"* ํจ์ ๋ณธ๋ฌธ์ ๋ง์ง๋ง ํํ์์ ๋ฐํ ๊ฐ์ด ๋ฉ๋๋ค. ๊ฐ๋จํ, ์ ๋์ ์๋ `;`๋ฅผ ์๋ตํ๋ฉด ๋ฉ๋๋ค.\n"
-"* ๋ฐํ๊ฐ์ด ์๋ ํจ์์ ๊ฒฝ์ฐ, ์ ๋ ํ์ `()`์ ๋ฐํํฉ๋๋ค. `-> ()`๊ฐ ์๋ต๋ ๊ฒฝ์ฐ ์ปดํ์ผ๋ฌ๋ ์ด๋ฅผ ์ถ๋ก ํฉ๋๋ค.\n"
-"* `fizzbuzz_to()`ํจ์ ๋ด `for` ๋ฐ๋ชฉ๋ฌธ์ ๋ฒ์ ํํ์ ์ค `=n`์ n๊น์ง ํฌํจํ๋ค๋ ์๋ฏธ์ ๋๋ค.\n"
-"* `fizzbuzz()`ํจ์์ `match` ํํ์์ ๋ง์ ์ผ์ ํฉ๋๋ค. ๋ฌด์จ ์ผ์ด ์ผ์ด๋๋์ง ์กฐ๊ธ ๋ ์ดํดํ๊ธฐ ์ฝ๋๋ก ์๋ ์ฝ๋๋ฅผ ํ์ธํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-"\n"
-" (๋ช ํํ ์ค๋ช ์ ์ํด ํ์ ์ด ๋ช ์์ ์ผ๋ก ์ ์ธ ๋์์ง๋ง ์๋ต ๊ฐ๋ฅํฉ๋๋ค.)\n"
-"\n"
-" ```rust,ignore\n"
-" let by_3: bool = is_divisible_by(n, 3);\n"
-" let by_5: bool = is_divisible_by(n, 5);\n"
-" let by_35: (bool, bool) = (by_3, by_5);\n"
-" match by_35 {\n"
-" // ...\n"
-" ```\n"
-"\n"
-" "
+"`main` ํจ์์์ ๊ทธ ๋ค์์ ์ค๋ ํจ์๋ค์ ์ฌ์ฉํ ์ ์์ต๋๋ค. ์๋จ์ ์ ์ธ์ด๋ "
+"ํค๋ ๊ฐ์๊ฑด ํ์ ์์ต๋๋ค."
+
+#: src/basic-syntax/functions.md:36
+msgid ""
+"Declaration parameters are followed by a type (the reverse of some "
+"programming languages), then a return type."
+msgstr ""
+"๋งค๊ฐ๋ณ์๋ฅผ ์ ์ธํ ๋์๋ ์ด๋ฆ์ ๋จผ์ ์ฐ๊ณ , ํ์ ์ ๋์ค์ ์๋๋ค. ์ด๋ฆ๊ณผ ํ์ "
+"์ `:` ๋ก ๊ตฌ๋ถํฉ๋๋ค. ์ด๋ ์ผ๋ถ ์ธ์ด(์๋ฅผ ๋ค์ด C)์ ๋ฐ๋์์ ์ ์ํ์๊ธฐ ๋ฐ๋"
+"๋๋ค. ๋ง์ฐฌ๊ฐ์ง๋ก, ๋ฆฌํด ํ์ ๋ ํจ์์ ์์์ด ์๋ ๊ฐ์ฅ ๋ท๋ถ๋ถ์ ์ ์ธํฉ๋๋ค."
+
+#: src/basic-syntax/functions.md:37
+msgid ""
+"The last expression in a function body (or any block) becomes the return "
+"value. Simply omit the `;` at the end of the expression."
+msgstr ""
+"ํจ์ ๋ณธ๋ฌธ์ ๋ง์ง๋ง ํํ์์ ๋ฐํ ๊ฐ์ด ๋ฉ๋๋ค. ๊ฐ๋จํ, ์ ๋์ ์๋ `;`๋ฅผ ์๋ต"
+"ํ๋ฉด ๋ฉ๋๋ค."
-#: src/basic-syntax/methods.md:1 src/methods.md:1
-msgid "# Methods"
-msgstr "# ๋ฉ์๋"
+#: src/basic-syntax/functions.md:38
+msgid ""
+"Some functions have no return value, and return the 'unit type', `()`. The "
+"compiler will infer this if the `-> ()` return type is omitted."
+msgstr ""
+"๋ฐํ๊ฐ์ด ์๋ ํจ์์ ๊ฒฝ์ฐ, ์ ๋ ํ์ `()`์ ๋ฐํํฉ๋๋ค. `-> ()`๊ฐ ์๋ต๋ ๊ฒฝ"
+"์ฐ ์ปดํ์ผ๋ฌ๋ ์ด๋ฅผ ์ถ๋ก ํฉ๋๋ค."
+
+#: src/basic-syntax/functions.md:39
+msgid ""
+"The range expression in the `for` loop in `fizzbuzz_to()` contains `=n`, "
+"which causes it to include the upper bound."
+msgstr ""
+"`fizzbuzz_to()`ํจ์ ๋ด `for` ๋ฐ๋ชฉ๋ฌธ์ ๋ฒ์ ํํ์ ์ค `=n`์ n๊น์ง ํฌํจํ๋ค๋ "
+"์๋ฏธ์ ๋๋ค."
+
+#: src/basic-syntax/functions.md:40
+msgid ""
+"The `match` expression in `fizzbuzz()` is doing a lot of work. It is "
+"expanded below to show what is happening."
+msgstr ""
+"`fizzbuzz()`ํจ์์ `match` ํํ์์ ๋ง์ ์ผ์ ํฉ๋๋ค. ๋ฌด์จ ์ผ์ด ์ผ์ด๋๋์ง ์กฐ"
+"๊ธ ๋ ์ดํดํ๊ธฐ ์ฝ๋๋ก ์๋ ์ฝ๋๋ฅผ ํ์ธํ์๊ธฐ ๋ฐ๋๋๋ค."
+
+#: src/basic-syntax/functions.md:42
+msgid "(Type annotations added for clarity, but they can be elided.)"
+msgstr "(๋ช ํํ ์ค๋ช ์ ์ํด ํ์ ์ด ๋ช ์์ ์ผ๋ก ์ ์ธ ๋์์ง๋ง ์๋ต ๊ฐ๋ฅํฉ๋๋ค.)"
+
+#: src/basic-syntax/functions.md:44
+msgid ""
+"```rust,ignore\n"
+"let by_3: bool = is_divisible_by(n, 3);\n"
+"let by_5: bool = is_divisible_by(n, 5);\n"
+"let by_35: (bool, bool) = (by_3, by_5);\n"
+"match by_35 {\n"
+" // ...\n"
+"```"
+msgstr ""
+"```rust,ignore\n"
+"let by_3: bool = is_divisible_by(n, 3);\n"
+"let by_5: bool = is_divisible_by(n, 5);\n"
+"let by_35: (bool, bool) = (by_3, by_5);\n"
+"match by_35 {\n"
+" // ...\n"
+"```"
#: src/basic-syntax/methods.md:3
msgid ""
-"Rust has methods, they are simply functions that are associated with a particular type. The\n"
-"first argument of a method is an instance of the type it is associated with:"
-msgstr "๋ฌ์คํธ์ ๋ฉ์๋๋ ํน์ ํ์ ๊ณผ ์ฐ๊ฒฐ๋ ํจ์์ ๋๋ค. ๋ฉ์๋์ ์ฒซ๋ฒ์งธ ์ธ์์ ํ์ ์ด ๋ฐ๋ก ๊ทธ ๋ฉ์๋๊ฐ ์ฐ๊ฒฐ๋ ํ์ ์ ๋๋ค:"
+"Rust has methods, they are simply functions that are associated with a "
+"particular type. The first argument of a method is an instance of the type "
+"it is associated with:"
+msgstr ""
+"๋ฌ์คํธ์ ๋ฉ์๋๋ ํน์ ํ์ ๊ณผ ์ฐ๊ฒฐ๋ ํจ์์ ๋๋ค. ๋ฉ์๋์ ์ฒซ๋ฒ์งธ ์ธ์์ ํ์ "
+"์ด ๋ฐ๋ก ๊ทธ ๋ฉ์๋๊ฐ ์ฐ๊ฒฐ๋ ํ์ ์ ๋๋ค:"
#: src/basic-syntax/methods.md:6
msgid ""
@@ -2807,32 +3346,42 @@ msgstr ""
"```"
#: src/basic-syntax/methods.md:30
-msgid "* We will look much more at methods in today's exercise and in tomorrow's class."
-msgstr "* ์ค๋๊ณผ ๋ด์ผ ๊ฐ์์์ ๋ ๋ง์ ๋ฉ์๋ ์ฌ์ฉ๋ฒ์ ๋ค๋ฃฐ ๊ฒ์ ๋๋ค."
+msgid ""
+"We will look much more at methods in today's exercise and in tomorrow's "
+"class."
+msgstr "์ค๋๊ณผ ๋ด์ผ ๊ฐ์์์ ๋ ๋ง์ ๋ฉ์๋ ์ฌ์ฉ๋ฒ์ ๋ค๋ฃฐ ๊ฒ์ ๋๋ค."
#: src/basic-syntax/functions-interlude.md:1
-msgid "# Function Overloading"
-msgstr "# (ํจ์) ์ค๋ฒ๋ก๋ฉ"
+msgid "Function Overloading"
+msgstr "(ํจ์) ์ค๋ฒ๋ก๋ฉ"
#: src/basic-syntax/functions-interlude.md:3
msgid "Overloading is not supported:"
msgstr "์ค๋ฒ๋ก๋ฉ์ ์ง์๋์ง ์์ต๋๋ค:"
#: src/basic-syntax/functions-interlude.md:5
-msgid ""
-"* Each function has a single implementation:\n"
-" * Always takes a fixed number of parameters.\n"
-" * Always takes a single set of parameter types.\n"
-"* Default values are not supported:\n"
-" * All call sites have the same number of arguments.\n"
-" * Macros are sometimes used as an alternative."
-msgstr ""
-"* ๊ฐ๋ณํจ์๋ ๋จ์ผ ๊ตฌํ๋ง ๊ฐ์ต๋๋ค.\n"
-" * ํญ์ ๊ณ ์ ๋ ์์ ํ๋ผ๋งคํฐ๋ง ๊ฐ์ต๋๋ค.\n"
-" * ํ๋ผ๋งคํฐ๋ค์ ํ์ ์ ํญ์ ๊ณ ์ ๋์ด ์์ต๋๋ค.\n"
-"* ํ๋ผ๋งคํฐ์ ๊ธฐ๋ณธ ๊ฐ์ ์ง์๋์ง ์์ต๋๋ค.\n"
-" * ๋ชจ๋ ํธ์ถ๋ถ์์๋ ๋์ผํ ์์ ์ธ์๋ฅผ ์ค์ ํด์ผํฉ๋๋ค. \n"
-" * ์ด๋ฐ ์ฌํญ๋ค์ด ์ ์ฝ์ด ๋ ๊ฒฝ์ฐ, ๋์์ผ๋ก ๋งคํฌ๋ก๋ฅผ ์ฌ์ฉํ๊ธฐ๋ ํฉ๋๋ค."
+msgid "Each function has a single implementation:"
+msgstr "๊ฐ๋ณํจ์๋ ๋จ์ผ ๊ตฌํ๋ง ๊ฐ์ต๋๋ค."
+
+#: src/basic-syntax/functions-interlude.md:6
+msgid "Always takes a fixed number of parameters."
+msgstr "ํญ์ ๊ณ ์ ๋ ์์ ํ๋ผ๋งคํฐ๋ง ๊ฐ์ต๋๋ค."
+
+#: src/basic-syntax/functions-interlude.md:7
+msgid "Always takes a single set of parameter types."
+msgstr "ํ๋ผ๋งคํฐ๋ค์ ํ์ ์ ํญ์ ๊ณ ์ ๋์ด ์์ต๋๋ค."
+
+#: src/basic-syntax/functions-interlude.md:8
+msgid "Default values are not supported:"
+msgstr "ํ๋ผ๋งคํฐ์ ๊ธฐ๋ณธ ๊ฐ์ ์ง์๋์ง ์์ต๋๋ค."
+
+#: src/basic-syntax/functions-interlude.md:9
+msgid "All call sites have the same number of arguments."
+msgstr "๋ชจ๋ ํธ์ถ๋ถ์์๋ ๋์ผํ ์์ ์ธ์๋ฅผ ์ค์ ํด์ผํฉ๋๋ค. "
+
+#: src/basic-syntax/functions-interlude.md:10
+msgid "Macros are sometimes used as an alternative."
+msgstr "์ด๋ฐ ์ฌํญ๋ค์ด ์ ์ฝ์ด ๋ ๊ฒฝ์ฐ, ๋์์ผ๋ก ๋งคํฌ๋ก๋ฅผ ์ฌ์ฉํ๊ธฐ๋ ํฉ๋๋ค."
#: src/basic-syntax/functions-interlude.md:12
msgid "However, function parameters can be generic:"
@@ -2864,31 +3413,28 @@ msgstr ""
#: src/basic-syntax/functions-interlude.md:27
msgid ""
-"* When using generics, the standard library's `Into` can provide a kind of limited\n"
-" polymorphism on argument types. We will see more details in a later section."
-msgstr "* ์ ๋ค๋ฆญ์ ์ฌ์ฉํ ๋ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ `Into`์ ํ์ ์ ๋ํ ๋คํ์ฑ์ ์ ๊ณตํ ์ ์์ต๋๋ค. ๋์ค์ ์์ธํ ์ค๋ช ํ๊ฒ ์ต๋๋ค."
-
-#: src/basic-syntax/functions-interlude.md:30
-msgid ""
-msgstr ""
+"When using generics, the standard library's `Into` can provide a kind of "
+"limited polymorphism on argument types. We will see more details in a later "
+"section."
+msgstr ""
+"์ ๋ค๋ฆญ์ ์ฌ์ฉํ ๋ ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ `Into`์ ํ์ ์ ๋ํ ๋คํ์ฑ์ ์ ๊ณตํ "
+"์ ์์ต๋๋ค. ๋์ค์ ์์ธํ ์ค๋ช ํ๊ฒ ์ต๋๋ค."
#: src/exercises/day-1/morning.md:1
-msgid "# Day 1: Morning Exercises"
-msgstr "# 1์ผ์ฐจ ์ค์ ์ฐ์ต๋ฌธ์ "
+msgid "Day 1: Morning Exercises"
+msgstr "1์ผ์ฐจ ์ค์ ์ฐ์ต๋ฌธ์ "
#: src/exercises/day-1/morning.md:3
msgid "In these exercises, we will explore two parts of Rust:"
msgstr "์ด๋ฒ ์ฐ์ต๋ฌธ์ ๋ ๋ฌ์คํธ์ ๋ ๋ถ๋ถ์ ์์๋ณผ ๊ฒ์ ๋๋ค:"
#: src/exercises/day-1/morning.md:5
-msgid ""
-"* Implicit conversions between types.\n"
-"\n"
-"* Arrays and `for` loops."
-msgstr ""
-"* ํ์ ์ ๋ฌต์์ ๋ณํ.\n"
-"\n"
-"* ๋ฐฐ์ด๊ณผ `for` ๋ฐ๋ณต๋ฌธ."
+msgid "Implicit conversions between types."
+msgstr "ํ์ ์ ๋ฌต์์ ๋ณํ."
+
+#: src/exercises/day-1/morning.md:7
+msgid "Arrays and `for` loops."
+msgstr "๋ฐฐ์ด๊ณผ `for` ๋ฐ๋ณต๋ฌธ."
#: src/exercises/day-1/morning.md:11
msgid "A few things to consider while solving the exercises:"
@@ -2896,37 +3442,43 @@ msgstr "์ฐ์ต๋ฌธ์ ๋ฅผ ํด๊ฒฐํ๋๋ฐ ๊ณ ๋ คํด์ผ ํ ์ฌํญ๋ค:"
#: src/exercises/day-1/morning.md:13
msgid ""
-"* Use a local Rust installation, if possible. This way you can get\n"
-" auto-completion in your editor. See the page about [Using Cargo] for details\n"
-" on installing Rust.\n"
-"\n"
-"* Alternatively, use the Rust Playground."
+"Use a local Rust installation, if possible. This way you can get auto-"
+"completion in your editor. See the page about [Using Cargo](../../cargo.md) "
+"for details on installing Rust."
msgstr ""
-"* ๊ฐ๋ฅํ๋ค๋ฉด ๋ฌ์คํธ๊ฐ ์ค์น๋ ๋ก์ปฌ ํ๊ฒฝ์์ ์งํํ์ธ์. ๊ทธ๋ฌ๋ ํธ์ด ํ ์คํธ ์๋ํฐ์ ์๋์์ฑ ๊ธฐ๋ฅ์ ๋์์ ๋ฐ์ ์ ์์ด์ ์ข์ต๋๋ค. [์นด๊ณ ์ฌ์ฉํ๊ธฐ][Using Cargo] ์ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-"\n"
-"* ํน์ ๋ฌ์คํธ ํ๋ ์ด๊ทธ๋ผ์ด๋๋ฅผ ์ด์ฉํ ์ ์์ต๋๋ค."
+"๊ฐ๋ฅํ๋ค๋ฉด ๋ฌ์คํธ๊ฐ ์ค์น๋ ๋ก์ปฌ ํ๊ฒฝ์์ ์งํํ์ธ์. ๊ทธ๋ฌ๋ ํธ์ด ํ ์คํธ ์๋"
+"ํฐ์ ์๋์์ฑ ๊ธฐ๋ฅ์ ๋์์ ๋ฐ์ ์ ์์ด์ ์ข์ต๋๋ค. [์นด๊ณ ์ฌ์ฉํ๊ธฐ](../../"
+"cargo.md) ์ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค."
+
+#: src/exercises/day-1/morning.md:17
+msgid "Alternatively, use the Rust Playground."
+msgstr "ํน์ ๋ฌ์คํธ ํ๋ ์ด๊ทธ๋ผ์ด๋๋ฅผ ์ด์ฉํ ์ ์์ต๋๋ค."
#: src/exercises/day-1/morning.md:19
msgid ""
-"The code snippets are not editable on purpose: the inline code snippets lose\n"
+"The code snippets are not editable on purpose: the inline code snippets lose "
"their state if you navigate away from the page."
-msgstr "ํ์ด์ง ๋ฐ์ผ๋ก ์ด๋ํ ๊ฒฝ์ฐ ์์ฑํ ๋ด์ฉ์ด ์์ค๋๊ธฐ ๋๋ฌธ์ ์ ๊ณต๋๋ ์ฝ๋ ์ค๋ํซ์ ์๋์ ์ผ๋ก ํธ์งํ ์ ์์ต๋๋ค."
+msgstr ""
+"ํ์ด์ง ๋ฐ์ผ๋ก ์ด๋ํ ๊ฒฝ์ฐ ์์ฑํ ๋ด์ฉ์ด ์์ค๋๊ธฐ ๋๋ฌธ์ ์ ๊ณต๋๋ ์ฝ๋ ์ค๋ํซ"
+"์ ์๋์ ์ผ๋ก ํธ์งํ ์ ์์ต๋๋ค."
#: src/exercises/day-1/morning.md:22 src/exercises/day-1/afternoon.md:11
#: src/exercises/day-2/morning.md:11 src/exercises/day-2/afternoon.md:7
#: src/exercises/day-3/morning.md:7 src/exercises/day-4/morning.md:12
-msgid "After looking at the exercises, you can look at the [solutions] provided."
-msgstr "์ฐ์ต๋ฌธ์ ๋ฅผ ์ดํด ๋ณธ ํ, ์ ๊ณต๋ [ํด๋ต][solutions]์ ์ดํด๋ณผ ์ ์์ต๋๋ค."
-
-#: src/exercises/day-1/implicit-conversions.md:1
-msgid "# Implicit Conversions"
-msgstr "# ๋ฌต์์ ํ๋ณํ"
+msgid ""
+"After looking at the exercises, you can look at the \\[solutions\\] provided."
+msgstr ""
+"์ฐ์ต๋ฌธ์ ๋ฅผ ์ดํด ๋ณธ ํ, ์ ๊ณต๋ \\[ํด๋ต\\]\\[solutions\\]์ ์ดํด๋ณผ ์ ์์ต๋๋ค."
#: src/exercises/day-1/implicit-conversions.md:3
msgid ""
-"Rust will not automatically apply _implicit conversions_ between types ([unlike\n"
-"C++][3]). You can see this in a program like this:"
-msgstr "๋ฌ์คํธ๋ [C++ ์ ๋ค๋ฅด๊ฒ][3] ํ์ ๊ฐ *๋ฌต์์ ๋ณํ*์ ์๋์ผ๋ก ์ ์ฉํ์ง ์์ต๋๋ค. ์๋ ์์๋ฅผ ํ์ธํด ๋ณด์ธ์:"
+"Rust will not automatically apply _implicit conversions_ between types "
+"([unlike C++](https://en.cppreference.com/w/cpp/language/"
+"implicit_conversion)). You can see this in a program like this:"
+msgstr ""
+"๋ฌ์คํธ๋ [C++ ์ ๋ค๋ฅด๊ฒ](https://en.cppreference.com/w/cpp/language/"
+"implicit_conversion) ํ์ ๊ฐ _๋ฌต์์ ๋ณํ_์ ์๋์ผ๋ก ์ ์ฉํ์ง ์์ต๋๋ค. ์"
+"๋ ์์๋ฅผ ํ์ธํด ๋ณด์ธ์:"
#: src/exercises/day-1/implicit-conversions.md:6
msgid ""
@@ -2946,48 +3498,68 @@ msgstr ""
#: src/exercises/day-1/implicit-conversions.md:19
msgid ""
-"The Rust integer types all implement the [`From`][1] and [`Into`][2]\n"
-"traits to let us convert between them. The `From` trait has a single `from()`\n"
-"method and similarly, the `Into` trait has a single `into()` method.\n"
-"Implementing these traits is how a type expresses that it can be converted into\n"
-"another type."
-msgstr "๋ฌ์คํธ์ ์ ์ํ ํ์ ์ ๋ชจ๋ [`From`][1] ์ [`Into`][2] ํธ๋ ์์ ๊ตฌํํ๊ณ ์์ผ๋ฉฐ, ์ด๋ฅผ ํตํด ํ์ ๋ณํ์ด ์ด๋ฃจ์ด ์ง๋๋ค. `From` ํธ๋ ์์ `from()` ๋ฉ์๋๋ฅผ ๊ฐ์ง๊ณ ์๊ณ , `Into`ํธ๋ ์์ `into()` ๋ฉ์๋๋ฅผ ๊ฐ์ง๊ณ ์์ต๋๋ค. ๋ฌ์คํธ์์๋ `From`๊ณผ `Into` ํธ๋ ์์ ๊ตฌํํจ์ผ๋ก์จ, ํ์ ๊ฐ ๋ณํ์ด ๊ฐ๋ฅํ๋ค๋ ๊ฒ์ ํํํฉ๋๋ค."
+"The Rust integer types all implement the [`From`](https://doc.rust-lang."
+"org/std/convert/trait.From.html) and [`Into`](https://doc.rust-lang.org/"
+"std/convert/trait.Into.html) traits to let us convert between them. The "
+"`From` trait has a single `from()` method and similarly, the `Into` "
+"trait has a single `into()` method. Implementing these traits is how a type "
+"expresses that it can be converted into another type."
+msgstr ""
+"๋ฌ์คํธ์ ์ ์ํ ํ์ ์ ๋ชจ๋ [`From`](https://doc.rust-lang.org/std/"
+"convert/trait.From.html) ์ [`Into`](https://doc.rust-lang.org/std/"
+"convert/trait.Into.html) ํธ๋ ์์ ๊ตฌํํ๊ณ ์์ผ๋ฉฐ, ์ด๋ฅผ ํตํด ํ์ ๋ณํ์ด ์ด๋ฃจ"
+"์ด ์ง๋๋ค. `From` ํธ๋ ์์ `from()` ๋ฉ์๋๋ฅผ ๊ฐ์ง๊ณ ์๊ณ , `Into`ํธ๋ ์"
+"์ `into()` ๋ฉ์๋๋ฅผ ๊ฐ์ง๊ณ ์์ต๋๋ค. ๋ฌ์คํธ์์๋ `From`๊ณผ `Into` ํธ๋ ์์ "
+"๊ตฌํํจ์ผ๋ก์จ, ํ์ ๊ฐ ๋ณํ์ด ๊ฐ๋ฅํ๋ค๋ ๊ฒ์ ํํํฉ๋๋ค."
#: src/exercises/day-1/implicit-conversions.md:25
msgid ""
-"The standard library has an implementation of `From for i16`, which means\n"
-"that we can convert a variable `x` of type `i8` to an `i16` by calling \n"
-"`i16::from(x)`. Or, simpler, with `x.into()`, because `From for i16`\n"
-"implementation automatically create an implementation of `Into for i8`."
-msgstr "ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์๋ `From for i16`๊ฐ ๊ตฌํ๋์ด ์๋๋ฐ ์ด๊ฒ์ `i8` ํ์ ์ ๋ณ์ `x`๋ฅผ `i16::from(x)`๋ฅผ ํธ์ถํ์ฌ `i16`ํ์ ์ผ๋ก ๋ณํํ ์ ์๋ค๋ ์๋ฏธ์ ๋๋ค. ํน์ ๋ ๊ฐ๋จํ๊ฒ `x.into()`๋ฅผ ์ฌ์ฉํ ์๋ ์์ต๋๋ค. ์ด๊ฒ์ด ๊ฐ๋ฅํ ์ด์ ๋ `From for i16` ๊ตฌํ์ ๊ฐ์ง๊ณ ์์ผ๋ฉด `Into for i8` ๊ตฌํ์ด ์๋์ผ๋ก ์์ฑ๋๊ธฐ ๋๋ฌธ์ ๋๋ค."
+"The standard library has an implementation of `From for i16`, which "
+"means that we can convert a variable `x` of type `i8` to an `i16` by "
+"calling `i16::from(x)`. Or, simpler, with `x.into()`, because `From for "
+"i16` implementation automatically create an implementation of `Into for "
+"i8`."
+msgstr ""
+"ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ์๋ `From for i16`๊ฐ ๊ตฌํ๋์ด ์๋๋ฐ ์ด๊ฒ์ `i8` ํ์ ์ "
+"๋ณ์ `x`๋ฅผ `i16::from(x)`๋ฅผ ํธ์ถํ์ฌ `i16`ํ์ ์ผ๋ก ๋ณํํ ์ ์๋ค๋ ์๋ฏธ์ ๋"
+"๋ค. ํน์ ๋ ๊ฐ๋จํ๊ฒ `x.into()`๋ฅผ ์ฌ์ฉํ ์๋ ์์ต๋๋ค. ์ด๊ฒ์ด ๊ฐ๋ฅํ ์ด์ ๋ "
+"`From for i16` ๊ตฌํ์ ๊ฐ์ง๊ณ ์์ผ๋ฉด `Into for i8` ๊ตฌํ์ด ์๋์ผ๋ก ์"
+"์ฑ๋๊ธฐ ๋๋ฌธ์ ๋๋ค."
#: src/exercises/day-1/implicit-conversions.md:30
msgid ""
-"The same applies for your own `From` implementations for your own types, so it is\n"
-"sufficient to only implement `From` to get a respective `Into` implementation automatically."
-msgstr "์ด๋ ์ฌ์ฉ์ ์ ์ ํ์ ์๋ ๋์ผํ๊ฒ ์ ์ฉ๋๋ ๊ท์น์ ๋๋ค. ๋ฐ๋ผ์ `From`๋ง์ ๊ตฌํํด๋ `Into`๊น์ง ์๋์ผ๋ก ๊ตฌํ์ด ๋ฉ๋๋ค."
+"The same applies for your own `From` implementations for your own types, so "
+"it is sufficient to only implement `From` to get a respective `Into` "
+"implementation automatically."
+msgstr ""
+"์ด๋ ์ฌ์ฉ์ ์ ์ ํ์ ์๋ ๋์ผํ๊ฒ ์ ์ฉ๋๋ ๊ท์น์ ๋๋ค. ๋ฐ๋ผ์ `From`๋ง์ ๊ตฌ"
+"ํํด๋ `Into`๊น์ง ์๋์ผ๋ก ๊ตฌํ์ด ๋ฉ๋๋ค."
#: src/exercises/day-1/implicit-conversions.md:33
+msgid "Execute the above program and look at the compiler error."
+msgstr "์ ์์ ์ฝ๋๋ฅผ ์คํํ๊ณ ์ด๋ค ์ปดํ์ผ ์๋ฌ๊ฐ ๋ฐ์ํ๋์ง ํ์ธํด ๋ณด์ธ์."
+
+#: src/exercises/day-1/implicit-conversions.md:35
+msgid "Update the code above to use `into()` to do the conversion."
+msgstr "`into()`๋ฅผ ์ฌ์ฉํ์ฌ ์ฝ๋๋ฅผ ์์ ํ์ธ์."
+
+#: src/exercises/day-1/implicit-conversions.md:37
msgid ""
-"1. Execute the above program and look at the compiler error.\n"
-"\n"
-"2. Update the code above to use `into()` to do the conversion.\n"
-"\n"
-"3. Change the types of `x` and `y` to other things (such as `f32`, `bool`,\n"
-" `i128`) to see which types you can convert to which other types. Try\n"
-" converting small types to big types and the other way around. Check the\n"
-" [standard library documentation][1] to see if `From` is implemented for\n"
-" the pairs you check."
+"Change the types of `x` and `y` to other things (such as `f32`, `bool`, "
+"`i128`) to see which types you can convert to which other types. Try "
+"converting small types to big types and the other way around. Check the "
+"[standard library documentation](https://doc.rust-lang.org/std/convert/trait."
+"From.html) to see if `From` is implemented for the pairs you check."
msgstr ""
-"1. ์ ์์ ์ฝ๋๋ฅผ ์คํํ๊ณ ์ด๋ค ์ปดํ์ผ ์๋ฌ๊ฐ ๋ฐ์ํ๋์ง ํ์ธํด ๋ณด์ธ์.\n"
-"\n"
-"2. `into()`๋ฅผ ์ฌ์ฉํ์ฌ ์ฝ๋๋ฅผ ์์ ํ์ธ์.\n"
-"\n"
-"3. `x`์ `y`๋ฅผ `f32`์ด๋ `bool`, `i128` ๋ฑ์ผ๋ก ๋ฐ๊ฟ์ ํด๋น ํ์ ๋ค๋ก ๋ณํ์ด ๋๋์ง ํ์ธํด๋ณด์ธ์. ์์ ์ฌ์ด์ฆ ํ์ ์์ ํฐ ์ฌ์ด์ฆ๋ก ๋ณ๊ฒฝํด๋ณด์๊ณ ๊ทธ ๋ฐ๋๋ก๋ ํด๋ณด์ธ์. [ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ ๋ฌธ์][1]์์ ์๋ํด ๋ณธ ์ผ์ด์ค๊ฐ ๊ตฌํ๋์ด ์๋์ง ํ์ธํด ๋ณด์ธ์."
+"`x`์ `y`๋ฅผ `f32`์ด๋ `bool`, `i128` ๋ฑ์ผ๋ก ๋ฐ๊ฟ์ ํด๋น ํ์ ๋ค๋ก ๋ณํ์ด ๋๋"
+"์ง ํ์ธํด๋ณด์ธ์. ์์ ์ฌ์ด์ฆ ํ์ ์์ ํฐ ์ฌ์ด์ฆ๋ก ๋ณ๊ฒฝํด๋ณด์๊ณ ๊ทธ ๋ฐ๋๋ก๋ ํด"
+"๋ณด์ธ์. [ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ ๋ฌธ์](https://doc.rust-lang.org/std/convert/trait."
+"From.html)์์ ์๋ํด ๋ณธ ์ผ์ด์ค๊ฐ ๊ตฌํ๋์ด ์๋์ง ํ์ธํด ๋ณด์ธ์."
#: src/exercises/day-1/for-loops.md:1
-msgid "# Arrays and `for` Loops"
-msgstr "# ๋ฐฐ์ด๊ณผ `for`๋ฐ๋ณต๋ฌธ"
+#: src/exercises/day-1/solutions-morning.md:3
+msgid "Arrays and `for` Loops"
+msgstr "๋ฐฐ์ด๊ณผ `for`๋ฐ๋ณต๋ฌธ"
#: src/exercises/day-1/for-loops.md:3
msgid "We saw that an array can be declared like this:"
@@ -3001,7 +3573,9 @@ msgid ""
msgstr ""
#: src/exercises/day-1/for-loops.md:9
-msgid "You can print such an array by asking for its debug representation with `{:?}`:"
+msgid ""
+"You can print such an array by asking for its debug representation with `{:?}"
+"`:"
msgstr "๋ฐฐ์ด์ ์ถ๋ ฅํ๋ ค๋ฉด `{:?}`๋ฅผ ์๋๋ค:"
#: src/exercises/day-1/for-loops.md:11
@@ -3016,7 +3590,7 @@ msgstr ""
#: src/exercises/day-1/for-loops.md:18
msgid ""
-"Rust lets you iterate over things like arrays and ranges using the `for`\n"
+"Rust lets you iterate over things like arrays and ranges using the `for` "
"keyword:"
msgstr "๋ฌ์คํธ์์๋ `for` ํค์๋๋ฅผ ์ฌ์ฉํด ๋ฐฐ์ด์ด๋ ๋ฒ์๋ฅผ ๋ฐ๋ณตํ ์ ์์ต๋๋ค:"
@@ -3042,9 +3616,12 @@ msgstr ""
#: src/exercises/day-1/for-loops.md:38
msgid ""
-"Use the above to write a function `pretty_print` which pretty-print a matrix and\n"
-"a function `transpose` which will transpose a matrix (turn rows into columns):"
-msgstr "์ ์ฝ๋๋ฅผ ์ด์ฉํด์, ํ๋ ฌ์ ์์๊ฒ ์ถ๋ ฅํ๋ `pretty_print`ํจ์์, ํ๋ ฌ์ ์ ์น(ํ๊ณผ ์ด์ ์๋ก ๋ฐ๊พธ๋)์ํค๋ `transpose`ํจ์๋ฅผ ์์ฑํด ๋ณด์๊ธฐ ๋ฐ๋๋๋ค:"
+"Use the above to write a function `pretty_print` which pretty-print a matrix "
+"and a function `transpose` which will transpose a matrix (turn rows into "
+"columns):"
+msgstr ""
+"์ ์ฝ๋๋ฅผ ์ด์ฉํด์, ํ๋ ฌ์ ์์๊ฒ ์ถ๋ ฅํ๋ `pretty_print`ํจ์์, ํ๋ ฌ์ ์ ์น"
+"(ํ๊ณผ ์ด์ ์๋ก ๋ฐ๊พธ๋)์ํค๋ `transpose`ํจ์๋ฅผ ์์ฑํด ๋ณด์๊ธฐ ๋ฐ๋๋๋ค:"
#: src/exercises/day-1/for-loops.md:41
msgid ""
@@ -3061,9 +3638,10 @@ msgstr "๋ ํจ์ ๋ชจ๋ ํ๋ ฌ์ ํฌ๊ธฐ๋ 3 x 3 ์ผ๋ก ํ๋์ฝ๋ฉ ํฉ๋
#: src/exercises/day-1/for-loops.md:49
msgid ""
-"Copy the code below to and implement the\n"
+"Copy the code below to and implement the "
"functions:"
-msgstr "์๋ ์ฝ๋๋ฅผ ์ ๋ณต์ฌํด์ ๊ตฌํํ์๋ฉด ๋ฉ๋๋ค:"
+msgstr ""
+"์๋ ์ฝ๋๋ฅผ ์ ๋ณต์ฌํด์ ๊ตฌํํ์๋ฉด ๋ฉ๋๋ค:"
#: src/exercises/day-1/for-loops.md:52
msgid ""
@@ -3124,37 +3702,42 @@ msgstr ""
"```"
#: src/exercises/day-1/for-loops.md:80
-msgid "## Bonus Question"
-msgstr "## ๋ณด๋์ค ๋ฌธ์ "
+msgid "Bonus Question"
+msgstr "๋ณด๋์ค ๋ฌธ์ "
#: src/exercises/day-1/for-loops.md:82
msgid ""
-"Could you use `&[i32]` slices instead of hard-coded 3 ร 3 matrices for your\n"
-"argument and return types? Something like `&[&[i32]]` for a two-dimensional\n"
+"Could you use `&[i32]` slices instead of hard-coded 3 ร 3 matrices for your "
+"argument and return types? Something like `&[&[i32]]` for a two-dimensional "
"slice-of-slices. Why or why not?"
-msgstr "`&[i32]`์ฌ๋ผ์ด์ค๋ฅผ ์ ์ด์ฉํ๋ฉด ํ๋ ฌ ํฌ๊ธฐ๋ฅผ 3 x 3์ผ๋ก ํ๋์ฝ๋ฉ ํ์ง ์์ ์ ์์๊น์? ์์ปจ๋ฐ `&[&[i32]]`๋ 2์ฐจ์ ์ฌ๋ผ์ด์ค์ ์ฌ๋ผ์ด์ค ์ ๋๋ค. ๊ฐ๋ฅํ๋ค๋ฉด/ํ์ง ์๋ค๋ฉด ์ ๊ทธ๋ฐ๊ฐ์?"
+msgstr ""
+"`&[i32]`์ฌ๋ผ์ด์ค๋ฅผ ์ ์ด์ฉํ๋ฉด ํ๋ ฌ ํฌ๊ธฐ๋ฅผ 3 x 3์ผ๋ก ํ๋์ฝ๋ฉ ํ์ง ์์ ์ ์"
+"์๊น์? ์์ปจ๋ฐ `&[&[i32]]`๋ 2์ฐจ์ ์ฌ๋ผ์ด์ค์ ์ฌ๋ผ์ด์ค ์ ๋๋ค. ๊ฐ๋ฅํ๋ค๋ฉด/ํ"
+"์ง ์๋ค๋ฉด ์ ๊ทธ๋ฐ๊ฐ์?"
#: src/exercises/day-1/for-loops.md:87
msgid ""
-"See the [`ndarray` crate](https://docs.rs/ndarray/) for a production quality\n"
+"See the [`ndarray` crate](https://docs.rs/ndarray/) for a production quality "
"implementation."
-msgstr "์์ฉ ํ์ง์ ๊ตฌํ์ ๋ํด์๋ [`ndarray` ํฌ๋ ์ดํธ](https://docs.rs/ndarray/)๋ฅผ ์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค."
+msgstr ""
+"์์ฉ ํ์ง์ ๊ตฌํ์ ๋ํด์๋ [`ndarray` ํฌ๋ ์ดํธ](https://docs.rs/ndarray/)๋ฅผ "
+"์ฐธ์กฐํ์๊ธฐ ๋ฐ๋๋๋ค."
#: src/exercises/day-1/for-loops.md:92
msgid ""
-"The solution and the answer to the bonus section are available in the \n"
+"The solution and the answer to the bonus section are available in the "
"[Solution](solutions-morning.md#arrays-and-for-loops) section."
-msgstr "๋ณด๋์ค ๋ฌธ์ ์ ๋ํ ๋ต๋ณ ์ญ์ [ํด๋ต](solutions-morning.md#arrays-and-for-loops)์์ ํ์ธํ ์ ์์ต๋๋ค."
-
-#: src/basic-syntax/variables.md:1
-msgid "# Variables"
-msgstr "# ๋ณ์"
+msgstr ""
+"๋ณด๋์ค ๋ฌธ์ ์ ๋ํ ๋ต๋ณ ์ญ์ [ํด๋ต](solutions-morning.md#arrays-and-for-"
+"loops)์์ ํ์ธํ ์ ์์ต๋๋ค."
#: src/basic-syntax/variables.md:3
msgid ""
-"Rust provides type safety via static typing. Variable bindings are immutable by\n"
-"default:"
-msgstr "๋ฌ์คํธ๋ ์ ์ ํ์ดํ์ ํตํด ํ์ ์์ ์ฑ์ ์ ๊ณตํฉ๋๋ค. ๋ณ์๋ ๊ธฐ๋ณธ์ ์ผ๋ก ๋ถ๋ณ(immutable)ํฉ๋๋ค:"
+"Rust provides type safety via static typing. Variable bindings are immutable "
+"by default:"
+msgstr ""
+"๋ฌ์คํธ๋ ์ ์ ํ์ดํ์ ํตํด ํ์ ์์ ์ฑ์ ์ ๊ณตํฉ๋๋ค. ๋ณ์๋ ๊ธฐ๋ณธ์ ์ผ๋ก ๋ถ๋ณ"
+"(immutable)ํฉ๋๋ค:"
#: src/basic-syntax/variables.md:6
msgid ""
@@ -3178,15 +3761,19 @@ msgstr ""
#: src/basic-syntax/variables.md:17
msgid ""
-"* Due to type inference the `i32` is optional. We will gradually show the types less and less as the course progresses.\n"
-"* Note that since `println!` is a macro, `x` is not moved, even using the function like syntax of `println!(\"x: {}\", x)`"
+"Due to type inference the `i32` is optional. We will gradually show the "
+"types less and less as the course progresses."
msgstr ""
-"* ํ์ ์ถ๋ก ์ ๋๋ถ์ `i32`๋ ์๋ต ๊ฐ๋ฅํฉ๋๋ค. ๊ฐ์๊ฐ ์งํ๋ ์๋ก ์๋ต ๊ฐ๋ฅํ ๋ถ๋ถ์ ์ ์ ์๋ตํ ๊ฒ์ ๋๋ค.\n"
-"* `println!(\"x: {}\", x)`๋ ํจ์ ํธ์ถ ์ฒ๋ผ ๋ณด์ด์ง๋ง ์ค์ ๋งคํฌ๋ก ํธ์ถ์ด๋ฉฐ `x`๋ ์ด๋๋์ง ์์ต๋๋ค."
+"ํ์ ์ถ๋ก ์ ๋๋ถ์ `i32`๋ ์๋ต ๊ฐ๋ฅํฉ๋๋ค. ๊ฐ์๊ฐ ์งํ๋ ์๋ก ์๋ต ๊ฐ๋ฅํ ๋ถ"
+"๋ถ์ ์ ์ ์๋ตํ ๊ฒ์ ๋๋ค."
-#: src/basic-syntax/type-inference.md:1
-msgid "# Type Inference"
-msgstr "# ํ์ ์ถ๋ก "
+#: src/basic-syntax/variables.md:18
+msgid ""
+"Note that since `println!` is a macro, `x` is not moved, even using the "
+"function like syntax of `println!(\"x: {}\", x)`"
+msgstr ""
+"`println!(\"x: {}\", x)`๋ ํจ์ ํธ์ถ ์ฒ๋ผ ๋ณด์ด์ง๋ง ์ค์ ๋งคํฌ๋ก ํธ์ถ์ด๋ฉฐ `x`"
+"๋ ์ด๋๋์ง ์์ต๋๋ค."
#: src/basic-syntax/type-inference.md:3
msgid "Rust will look at how the variable is _used_ to determine the type:"
@@ -3233,19 +3820,35 @@ msgstr ""
"```"
#: src/basic-syntax/type-inference.md:26
-msgid "This slide demonstrates how the Rust compiler infers types based on constraints given by variable declarations and usages."
-msgstr "์ด ์ฌ๋ผ์ด๋๋, ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๊ฐ ๋ณ์๊ฐ ์ด๋ป๊ฒ ์ ์ธ๋์ด ์๊ณ , ์ด๋ป๊ฒ ์ฌ์ฉ๋๋์ง๋ฅผ ์ ์ฝ ์กฐ๊ฑด์ผ๋ก ์ผ์์ ๋ณ์์ ํ์ ์ ์ถ๋ก ํ๋ ๋ชจ์ต์ ๋ณด์ฌ์ค๋๋ค."
+msgid ""
+"This slide demonstrates how the Rust compiler infers types based on "
+"constraints given by variable declarations and usages."
+msgstr ""
+"์ด ์ฌ๋ผ์ด๋๋, ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๊ฐ ๋ณ์๊ฐ ์ด๋ป๊ฒ ์ ์ธ๋์ด ์๊ณ , ์ด๋ป๊ฒ ์ฌ์ฉ๋๋"
+"์ง๋ฅผ ์ ์ฝ ์กฐ๊ฑด์ผ๋ก ์ผ์์ ๋ณ์์ ํ์ ์ ์ถ๋ก ํ๋ ๋ชจ์ต์ ๋ณด์ฌ์ค๋๋ค."
#: src/basic-syntax/type-inference.md:28
msgid ""
-"It is very important to emphasize that variables declared like this are not of some sort of dynamic \"any type\" that can\n"
-"hold any data. The machine code generated by such declaration is identical to the explicit declaration of a type.\n"
-"The compiler does the job for us and helps us write more concise code."
-msgstr "์ฌ๊ธฐ์ ์ค์ํ ๊ฒ์, ์ด๋ ๊ฒ ๋ช ์์ ์ธ ํ์ ์ ์๋ตํ๊ณ ์ ์ธ๋์๋ค๊ณ ํด์ \"์ด๋ค ํ์ \"์ด๋ผ๋ ๋ค ๋ด์ ์ ์๋ ํ์ ์ด ๋๋ ๊ฒ์ ์๋๋ผ๋ ์ ์ ๋๋ค. ๋ช ์์ ์ธ ํ์ ์ ์ธ์ด ์๋ ์๋, ์ปดํ์ผ๋ฌ๊ฐ ์์ฑํ ๋จธ์ ์ฝ๋๋ ๋์ผํฉ๋๋ค. ์ปดํ์ผ๋ฌ๋ ๋จ์ง ํ์ ์ ์ธ์ ์๋ตํ ์ ์๋๋ก ํด์ ํ๋ก๊ทธ๋๋จธ๊ฐ ๋ ๊ฐ๊ฒฐํ ์ฝ๋๋ฅผ ์ธ ์ ์๋๋ก ๋์์ค ๋ฟ์ ๋๋ค."
+"It is very important to emphasize that variables declared like this are not "
+"of some sort of dynamic \"any type\" that can hold any data. The machine "
+"code generated by such declaration is identical to the explicit declaration "
+"of a type. The compiler does the job for us and helps us write more concise "
+"code."
+msgstr ""
+"์ฌ๊ธฐ์ ์ค์ํ ๊ฒ์, ์ด๋ ๊ฒ ๋ช ์์ ์ธ ํ์ ์ ์๋ตํ๊ณ ์ ์ธ๋์๋ค๊ณ ํด์ \"์ด๋ค "
+"ํ์ \"์ด๋ผ๋ ๋ค ๋ด์ ์ ์๋ ํ์ ์ด ๋๋ ๊ฒ์ ์๋๋ผ๋ ์ ์ ๋๋ค. ๋ช ์์ ์ธ ํ"
+"์ ์ ์ธ์ด ์๋ ์๋, ์ปดํ์ผ๋ฌ๊ฐ ์์ฑํ ๋จธ์ ์ฝ๋๋ ๋์ผํฉ๋๋ค. ์ปดํ์ผ๋ฌ๋ ๋จ"
+"์ง ํ์ ์ ์ธ์ ์๋ตํ ์ ์๋๋ก ํด์ ํ๋ก๊ทธ๋๋จธ๊ฐ ๋ ๊ฐ๊ฒฐํ ์ฝ๋๋ฅผ ์ธ ์ ์๋"
+"๋ก ๋์์ค ๋ฟ์ ๋๋ค."
#: src/basic-syntax/type-inference.md:32
-msgid "The following code tells the compiler to copy into a certain generic container without the code ever explicitly specifying the contained type, using `_` as a placeholder:"
-msgstr "์๋ ์ฝ๋๋, ์ ๋ค๋ฆญ ์ปจํ ์ด๋๋ฅผ ์ธ ๋ ์ปจํ ์ดํฐ ์์ ํฌํจ๋ ๋ฐ์ดํฐ์ ํ์ ์ ๋ช ์์ ์ผ๋ก ์ฐ์ง ์๊ณ `_`๋ก ๋์ฒดํ์ฌ๋ ๋๋ค๋ ๊ฒ์ ๋ณด์ฌ์ค๋๋ค:"
+msgid ""
+"The following code tells the compiler to copy into a certain generic "
+"container without the code ever explicitly specifying the contained type, "
+"using `_` as a placeholder:"
+msgstr ""
+"์๋ ์ฝ๋๋, ์ ๋ค๋ฆญ ์ปจํ ์ด๋๋ฅผ ์ธ ๋ ์ปจํ ์ดํฐ ์์ ํฌํจ๋ ๋ฐ์ดํฐ์ ํ์ ์ ๋ช "
+"์์ ์ผ๋ก ์ฐ์ง ์๊ณ `_`๋ก ๋์ฒดํ์ฌ๋ ๋๋ค๋ ๊ฒ์ ๋ณด์ฌ์ค๋๋ค:"
#: src/basic-syntax/type-inference.md:34
msgid ""
@@ -3274,20 +3877,26 @@ msgstr ""
"```"
#: src/basic-syntax/type-inference.md:46
-msgid "[`collect`](https://doc.rust-lang.org/stable/std/iter/trait.Iterator.html#method.collect) relies on `FromIterator`, which [`HashSet`](https://doc.rust-lang.org/std/iter/trait.FromIterator.html) implements."
-msgstr "[`collect`](https://doc.rust-lang.org/stable/std/iter/trait.Iterator.html#method.collect)๋ [`HashSet`](https://doc.rust-lang.org/std/iter/trait.FromIterator.html)์ ๊ตฌํํ `FromIterator`์ ์์กดํฉ๋๋ค."
+msgid ""
+"[`collect`](https://doc.rust-lang.org/stable/std/iter/trait.Iterator."
+"html#method.collect) relies on `FromIterator`, which [`HashSet`](https://doc."
+"rust-lang.org/std/iter/trait.FromIterator.html) implements."
+msgstr ""
+"[`collect`](https://doc.rust-lang.org/stable/std/iter/trait.Iterator."
+"html#method.collect)๋ [`HashSet`](https://doc.rust-lang.org/std/iter/trait."
+"FromIterator.html)์ ๊ตฌํํ `FromIterator`์ ์์กดํฉ๋๋ค."
#: src/basic-syntax/static-and-const.md:1
-msgid "# Static and Constant Variables"
-msgstr "# ์ ์ ๋ณ์(static)๊ณผ ์์(const)"
+msgid "Static and Constant Variables"
+msgstr "์ ์ ๋ณ์(static)๊ณผ ์์(const)"
#: src/basic-syntax/static-and-const.md:3
msgid "Global state is managed with static and constant variables."
msgstr "ํ๋ก๊ทธ๋จ์ ๊ธ๋ก๋ฒ ์ํ๋ ๊ฒฐ๊ตญ ์ ์ ๋ณ์์ ์์๋ก ํํ๋ฉ๋๋ค."
#: src/basic-syntax/static-and-const.md:5
-msgid "## `const`"
-msgstr "## ์์(`const`)"
+msgid "`const`"
+msgstr "์์(`const`)"
#: src/basic-syntax/static-and-const.md:7
msgid "You can declare compile-time constants:"
@@ -3302,7 +3911,8 @@ msgid ""
"fn compute_digest(text: &str) -> [u8; DIGEST_SIZE] {\n"
" let mut digest = [ZERO.unwrap_or(0); DIGEST_SIZE];\n"
" for (idx, &b) in text.as_bytes().iter().enumerate() {\n"
-" digest[idx % DIGEST_SIZE] = digest[idx % DIGEST_SIZE].wrapping_add(b);\n"
+" digest[idx % DIGEST_SIZE] = digest[idx % DIGEST_SIZE]."
+"wrapping_add(b);\n"
" }\n"
" digest\n"
"}\n"
@@ -3333,12 +3943,16 @@ msgstr ""
"```"
#: src/basic-syntax/static-and-const.md:27
-msgid "According the the [Rust RFC Book][1] these are inlined upon use."
-msgstr "[Rust RFC Book][1]์ ๋ฐ๋ฅด๋ฉด ์์๋, ๊ทธ ์์๊ฐ ์ฌ์ฉ๋๋ ๊ณณ์ ์ธ๋ผ์ธ ๋ฉ๋๋ค."
+msgid ""
+"According the the [Rust RFC Book](https://rust-lang.github.io/rfcs/0246-"
+"const-vs-static.html) these are inlined upon use."
+msgstr ""
+"[Rust RFC Book](https://rust-lang.github.io/rfcs/0246-const-vs-static.html)"
+"์ ๋ฐ๋ฅด๋ฉด ์์๋, ๊ทธ ์์๊ฐ ์ฌ์ฉ๋๋ ๊ณณ์ ์ธ๋ผ์ธ ๋ฉ๋๋ค."
#: src/basic-syntax/static-and-const.md:29
-msgid "## `static`"
-msgstr "## ์ ์ ๋ณ์(`static`)"
+msgid "`static`"
+msgstr "์ ์ ๋ณ์(`static`)"
#: src/basic-syntax/static-and-const.md:31
msgid "You can also declare static variables:"
@@ -3363,32 +3977,49 @@ msgstr ""
"```"
#: src/basic-syntax/static-and-const.md:41
-msgid "As noted in the [Rust RFC Book][1], these are not inlined upon use and have an actual associated memory location. This is useful for unsafe and embedded code, and the variable lives through the entirety of the program execution."
-msgstr "[Rust RFC Book][1]์์ ์ธ๊ธํ ๋ฐ์ ๊ฐ์ด, ์ ์ ๋ณ์๋ ๋ณ๋์ ๋ฉ๋ชจ๋ฆฌ ๊ณต๊ฐ์ ๊ฐ์ง๋ฉฐ, ์ธ๋ผ์ธ ๋์ง ์์ต๋๋ค. ์ ์ ๋ณ์๋ ์์ ํ์ง ์์(unsafe) ๋ฌ์คํธ์ ์๋ฒ ๋๋ ์์คํ ์ฉ ์ฝ๋์์ ์ ์ฉํฉ๋๋ค. ์ด๋ค์ ์๋ช ์ ํ๋ก๊ทธ๋จ์ด ์ํ๋๋ ์ ์ฒด ์๊ฐ๊ณผ ๋์ผํฉ๋๋ค."
+msgid ""
+"As noted in the [Rust RFC Book](https://rust-lang.github.io/rfcs/0246-const-"
+"vs-static.html), these are not inlined upon use and have an actual "
+"associated memory location. This is useful for unsafe and embedded code, "
+"and the variable lives through the entirety of the program execution."
+msgstr ""
+"[Rust RFC Book](https://rust-lang.github.io/rfcs/0246-const-vs-static.html)์"
+"์ ์ธ๊ธํ ๋ฐ์ ๊ฐ์ด, ์ ์ ๋ณ์๋ ๋ณ๋์ ๋ฉ๋ชจ๋ฆฌ ๊ณต๊ฐ์ ๊ฐ์ง๋ฉฐ, ์ธ๋ผ์ธ ๋์ง ์"
+"์ต๋๋ค. ์ ์ ๋ณ์๋ ์์ ํ์ง ์์(unsafe) ๋ฌ์คํธ์ ์๋ฒ ๋๋ ์์คํ ์ฉ ์ฝ๋์"
+"์ ์ ์ฉํฉ๋๋ค. ์ด๋ค์ ์๋ช ์ ํ๋ก๊ทธ๋จ์ด ์ํ๋๋ ์ ์ฒด ์๊ฐ๊ณผ ๋์ผํฉ๋๋ค."
#: src/basic-syntax/static-and-const.md:44
-msgid "We will look at mutating static data in the [chapter on Unsafe Rust](../unsafe.md)."
-msgstr "๊ฐ๋ณ ์ ์ ๋ฐ์ดํฐ์ ๋ํด์๋ [์์ ํ์ง ์์ ๋ฌ์คํธ](../unsafe.md)์์ ์ดํด๋ด ๋๋ค."
+msgid ""
+"We will look at mutating static data in the [chapter on Unsafe Rust](../"
+"unsafe.md)."
+msgstr ""
+"๊ฐ๋ณ ์ ์ ๋ฐ์ดํฐ์ ๋ํด์๋ [์์ ํ์ง ์์ ๋ฌ์คํธ](../unsafe.md)์์ ์ดํด๋ด ๋"
+"๋ค."
#: src/basic-syntax/static-and-const.md:48
+msgid "Mention that `const` behaves semantically similar to C++'s `constexpr`."
+msgstr "`const`๋ C++์ `constexpr`๊ณผ ๋งค์ฐ ๋น์ทํฉ๋๋ค."
+
+#: src/basic-syntax/static-and-const.md:49
msgid ""
-"* Mention that `const` behaves semantically similar to C++'s `constexpr`.\n"
-"* `static`, on the other hand, is much more similar to a `const` or mutable global variable in C++.\n"
-"* It isn't super common that one would need a runtime evaluated constant, but it is helpful and safer than using a static."
-msgstr ""
-"* `const`๋ C++์ `constexpr`๊ณผ ๋งค์ฐ ๋น์ทํฉ๋๋ค.\n"
-"* ๋ฐ๋ฉด์ `static`์ C++์ `const`๋ ๊ฐ๋ณ ์ ์ ๋ณ์์ ํจ์ฌ ๋ ์ ์ฌํฉ๋๋ค.\n"
-"* ํ๋ก๊ทธ๋จ ์ํ์ ๊ทธ ๊ฐ์ด ์ ํด์ง๋ ์์๊ฐ ํ์ํ ๊ฒฝ์ฐ๋ ๋๋ญ ๋๋ค. ๊ทธ๋ฌ๋ ๊ทธ๋ ๋ค๊ณ ํด๋, ์ ์ ๋ณ์๋ฅผ ์ฌ์ฉํ๋ ๊ฒ ๋ณด๋ค๋ ๋ ์ ์ฉํ๊ณ ์์ ํฉ๋๋ค."
+"`static`, on the other hand, is much more similar to a `const` or mutable "
+"global variable in C++."
+msgstr "๋ฐ๋ฉด์ `static`์ C++์ `const`๋ ๊ฐ๋ณ ์ ์ ๋ณ์์ ํจ์ฌ ๋ ์ ์ฌํฉ๋๋ค."
-#: src/basic-syntax/scopes-shadowing.md:1
-msgid "# Scopes and Shadowing"
-msgstr "# ๋ฒ์(Scope)์ ์๋์(Shadowing)"
+#: src/basic-syntax/static-and-const.md:50
+msgid ""
+"It isn't super common that one would need a runtime evaluated constant, but "
+"it is helpful and safer than using a static."
+msgstr ""
+"ํ๋ก๊ทธ๋จ ์ํ์ ๊ทธ ๊ฐ์ด ์ ํด์ง๋ ์์๊ฐ ํ์ํ ๊ฒฝ์ฐ๋ ๋๋ญ ๋๋ค. ๊ทธ๋ฌ๋ ๊ทธ๋ ๋ค"
+"๊ณ ํด๋, ์ ์ ๋ณ์๋ฅผ ์ฌ์ฉํ๋ ๊ฒ ๋ณด๋ค๋ ๋ ์ ์ฉํ๊ณ ์์ ํฉ๋๋ค."
#: src/basic-syntax/scopes-shadowing.md:3
msgid ""
-"You can shadow variables, both those from outer scopes and variables from the\n"
-"same scope:"
-msgstr "ํ์ฌ ๋ฒ์์ ์๋ ๋ณ์์, ๋ฐ๊นฅ ๋ฒ์์ ์๋ ๋ณ์ ๋ชจ๋ ๊ฐ๋ฆด(์๋์)์ ์์ต๋๋ค:"
+"You can shadow variables, both those from outer scopes and variables from "
+"the same scope:"
+msgstr ""
+"ํ์ฌ ๋ฒ์์ ์๋ ๋ณ์์, ๋ฐ๊นฅ ๋ฒ์์ ์๋ ๋ณ์ ๋ชจ๋ ๊ฐ๋ฆด(์๋์)์ ์์ต๋๋ค:"
#: src/basic-syntax/scopes-shadowing.md:6
msgid ""
@@ -3426,17 +4057,39 @@ msgstr ""
"}\n"
"```"
-#: src/basic-syntax/scopes-shadowing.md:25
+#: src/basic-syntax/scopes-shadowing.md:25
+msgid ""
+"Definition: Shadowing is different from mutation, because after shadowing "
+"both variable's memory locations exist at the same time. Both are available "
+"under the same name, depending where you use it in the code. "
+msgstr ""
+"์๋์์ ๊ธฐ์กด ๋ณ์์ ์๋ก์ด ๊ฐ์ ํ ๋นํ๋ ๊ฒ์ด ์๋๋๋ค. ์๋์์ ํ๋ฉด ์๋ก"
+"์ด ๋ณ์๊ฐ ์๊ธฐ๋ฉฐ, ์ด์ ๋ณ์์ ์ ๋ณ์๋ ๋ฉ๋ชจ๋ฆฌ์ ์๋ก ๋ค๋ฅธ ์์น์ ์กด์ฌํฉ๋"
+"๋ค. ๊ทธ ๋ ๋ณ์๋ ๋จ์ง ์ด๋ฆ์ด ๊ฐ์ ๋ฟ์ด๋ฉฐ, ์ฝ๋ ์ค ์ด๋์์ ๊ทธ ์ด๋ฆ์ด ์ฌ์ฉ๋์"
+"๋๋์ ๋ฐ๋ผ ์ด๋ค ๋ณ์๋ฅผ ์ง์นญํ๋ ์ง๊ฐ ๊ฒฐ์ ๋ฉ๋๋ค."
+
+#: src/basic-syntax/scopes-shadowing.md:26
+msgid "A shadowing variable can have a different type. "
+msgstr "์๋์ ์ ํ์ ์ ๋ฐ๊ฟ ์ ์์ต๋๋ค."
+
+#: src/basic-syntax/scopes-shadowing.md:27
+msgid ""
+"Shadowing looks obscure at first, but is convenient for holding on to values "
+"after `.unwrap()`."
+msgstr ""
+"์ฒ์์ ์๋์์ ๋ณด๋ฉด ์ฝ๋๋ฅผ ๋ ๋ชจํธํ๊ฒ ๋ง๋ ๋ค๊ณ ์๊ฐํ ์ ๋ ์์ต๋๋ค. ๊ทธ๋ฌ"
+"๋ ์ค์ ๋ก ์๋์์ ์ด์ฉํ๋ฉด, ์ด๋ค ๋ณ์์์ `.unwrap()` ๋ ๊ฐ์ ์๋ก์ด ๋ณ์์ "
+"๋ด์ ๊ฒฝ์ฐ ์๋ก์ด ์ด๋ฆ์ ์ง์ ํ์ ์์ด ๊ธฐ์กด ์ด๋ฆ์ ์ ์งํ ์ ์์ด์ ํธ๋ฆฌํฉ๋"
+"๋ค."
+
+#: src/basic-syntax/scopes-shadowing.md:28
msgid ""
-"* Definition: Shadowing is different from mutation, because after shadowing both variable's memory locations exist at the same time. Both are available under the same name, depending where you use it in the code. \n"
-"* A shadowing variable can have a different type. \n"
-"* Shadowing looks obscure at first, but is convenient for holding on to values after `.unwrap()`.\n"
-"* The following code demonstrates why the compiler can't simply reuse memory locations when shadowing an immutable variable in a scope, even if the type does not change."
+"The following code demonstrates why the compiler can't simply reuse memory "
+"locations when shadowing an immutable variable in a scope, even if the type "
+"does not change."
msgstr ""
-"* ์๋์์ ๊ธฐ์กด ๋ณ์์ ์๋ก์ด ๊ฐ์ ํ ๋นํ๋ ๊ฒ์ด ์๋๋๋ค. ์๋์์ ํ๋ฉด ์๋ก์ด ๋ณ์๊ฐ ์๊ธฐ๋ฉฐ, ์ด์ ๋ณ์์ ์ ๋ณ์๋ ๋ฉ๋ชจ๋ฆฌ์ ์๋ก ๋ค๋ฅธ ์์น์ ์กด์ฌํฉ๋๋ค. ๊ทธ ๋ ๋ณ์๋ ๋จ์ง ์ด๋ฆ์ด ๊ฐ์ ๋ฟ์ด๋ฉฐ, ์ฝ๋ ์ค ์ด๋์์ ๊ทธ ์ด๋ฆ์ด ์ฌ์ฉ๋์๋๋์ ๋ฐ๋ผ ์ด๋ค ๋ณ์๋ฅผ ์ง์นญํ๋ ์ง๊ฐ ๊ฒฐ์ ๋ฉ๋๋ค.\n"
-"* ์๋์ ์ ํ์ ์ ๋ฐ๊ฟ ์ ์์ต๋๋ค.\n"
-"* ์ฒ์์ ์๋์์ ๋ณด๋ฉด ์ฝ๋๋ฅผ ๋ ๋ชจํธํ๊ฒ ๋ง๋ ๋ค๊ณ ์๊ฐํ ์ ๋ ์์ต๋๋ค. ๊ทธ๋ฌ๋ ์ค์ ๋ก ์๋์์ ์ด์ฉํ๋ฉด, ์ด๋ค ๋ณ์์์ `.unwrap()` ๋ ๊ฐ์ ์๋ก์ด ๋ณ์์ ๋ด์ ๊ฒฝ์ฐ ์๋ก์ด ์ด๋ฆ์ ์ง์ ํ์ ์์ด ๊ธฐ์กด ์ด๋ฆ์ ์ ์งํ ์ ์์ด์ ํธ๋ฆฌํฉ๋๋ค.\n"
-"* ์๋ ์ฝ๋๋ ๋ถ๋ณ ๋ณ์๋ฅผ ์๋์ํ ๋ ํ์ ์ด ๋์ผํ๋๋ผ๋ ์ ๋ณ์๊ฐ ์๋ ๋ณ์์ ๋ฉ๋ชจ๋ฆฌ ์์น๋ฅผ ์ฌ์ฌ์ฉ ํ ์ ์๋์ง ๊ทธ ์ด์ ๋ฅผ ๋ณด์ฌ์ค๋๋ค."
+"์๋ ์ฝ๋๋ ๋ถ๋ณ ๋ณ์๋ฅผ ์๋์ํ ๋ ํ์ ์ด ๋์ผํ๋๋ผ๋ ์ ๋ณ์๊ฐ ์๋ ๋ณ์"
+"์ ๋ฉ๋ชจ๋ฆฌ ์์น๋ฅผ ์ฌ์ฌ์ฉ ํ ์ ์๋์ง ๊ทธ ์ด์ ๋ฅผ ๋ณด์ฌ์ค๋๋ค."
#: src/basic-syntax/scopes-shadowing.md:30
msgid ""
@@ -3458,21 +4111,23 @@ msgstr ""
"}\n"
"```"
-#: src/memory-management.md:1
-msgid "# Memory Management"
-msgstr "# ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
-
#: src/memory-management.md:3
msgid "Traditionally, languages have fallen into two broad categories:"
msgstr "์ ํต์ ์ผ๋ก, ๋ ์ข ๋ฅ์ ํ๋ก๊ทธ๋๋ฐ ์ธ์ด๊ฐ ์์ต๋๋ค:"
#: src/memory-management.md:5
+msgid "Full control via manual memory management: C, C++, Pascal, ..."
+msgstr ""
+"๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๊ฐ ํ๋ก๊ทธ๋๋จธ์ ์์ ํ ํต์ ํ์ ์์ง๋ง ์๋(๊ทธ๋์ ์์ ํ์ง ์์ "
+"์ ์๋)์ธ ์ธ์ด: C, C++, Pascal, ..."
+
+#: src/memory-management.md:6
msgid ""
-"* Full control via manual memory management: C, C++, Pascal, ...\n"
-"* Full safety via automatic memory management at runtime: Java, Python, Go, Haskell, ..."
+"Full safety via automatic memory management at runtime: Java, Python, Go, "
+"Haskell, ..."
msgstr ""
-"* ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๊ฐ ํ๋ก๊ทธ๋๋จธ์ ์์ ํ ํต์ ํ์ ์์ง๋ง ์๋(๊ทธ๋์ ์์ ํ์ง ์์ ์ ์๋)์ธ ์ธ์ด: C, C++, Pascal, ...\n"
-"* ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๊ฐ ๋ฐํ์์ ์ํด ๋๋ฏ๋ก ์์ ํ์ง๋ง ์๋(๊ทธ๋์ ํ๋ก๊ทธ๋๋จธ๊ฐ ๊ฐ์ ํ ์ฌ์ง๊ฐ ์ ๊ฑฐ๋ ์๋)์ธ ์ธ์ด: Java, Python, Go, Haskell, ..."
+"๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๊ฐ ๋ฐํ์์ ์ํด ๋๋ฏ๋ก ์์ ํ์ง๋ง ์๋(๊ทธ๋์ ํ๋ก๊ทธ๋๋จธ๊ฐ ๊ฐ์ "
+"ํ ์ฌ์ง๊ฐ ์ ๊ฑฐ๋ ์๋)์ธ ์ธ์ด: Java, Python, Go, Haskell, ..."
#: src/memory-management.md:8
msgid "Rust offers a new mix:"
@@ -3480,9 +4135,10 @@ msgstr "๋ฌ์คํธ๋ ์ด ๋์ ํผํฉํ ์๋ก์ด ํํ์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ
#: src/memory-management.md:10
msgid ""
-"> Full control *and* safety via compile time enforcement of correct memory\n"
-"> management."
-msgstr "> ์ปดํ์ผ ์ ์ฌ๋ฐ๋ฅธ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๋ฅผ ๊ฐ์ ํจ์ผ๋ก์จ ์์ ํ ํต์ ์ ์์ ์ฑ ๋ชจ๋ ์ ๊ณต"
+"Full control _and_ safety via compile time enforcement of correct memory "
+"management."
+msgstr ""
+"์ปดํ์ผ ์ ์ฌ๋ฐ๋ฅธ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๋ฅผ ๊ฐ์ ํจ์ผ๋ก์จ ์์ ํ ํต์ ์ ์์ ์ฑ ๋ชจ๋ ์ ๊ณต"
#: src/memory-management.md:13
msgid "It does this with an explicit ownership concept."
@@ -3493,42 +4149,56 @@ msgid "First, let's refresh how memory management works."
msgstr "์ฐ์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๊ฐ ์ด๋ค์ง๋ ๋ฐฉ์์ ๋ค์ ์ดํด ๋ณด๊ฒ ์ต๋๋ค."
#: src/memory-management/stack-vs-heap.md:1
-msgid "# The Stack vs The Heap"
-msgstr "# ์คํ(Stack)๊ณผ ํ(Heap)"
+msgid "The Stack vs The Heap"
+msgstr "์คํ(Stack)๊ณผ ํ(Heap)"
#: src/memory-management/stack-vs-heap.md:3
-msgid ""
-"* Stack: Continuous area of memory for local variables.\n"
-" * Values have fixed sizes known at compile time.\n"
-" * Extremely fast: just move a stack pointer.\n"
-" * Easy to manage: follows function calls.\n"
-" * Great memory locality.\n"
-"\n"
-"* Heap: Storage of values outside of function calls.\n"
-" * Values have dynamic sizes determined at runtime.\n"
-" * Slightly slower than the stack: some book-keeping needed.\n"
-" * No guarantee of memory locality."
+msgid "Stack: Continuous area of memory for local variables."
+msgstr "์คํ: ์ง์ญ ๋ณ์๋ฅผ ์ํ ์ฐ์์ ์ธ ๋ฉ๋ชจ๋ฆฌ ์์ญ"
+
+#: src/memory-management/stack-vs-heap.md:4
+msgid "Values have fixed sizes known at compile time."
+msgstr "์ฌ๊ธฐ ์ ์ฅ๋๋ ๊ฐ์ ์ปดํ์ผ ์ ๊ฒฐ์ ๋๋ ๊ณ ์ ํฌ๊ธฐ๋ฅผ ๊ฐ์ต๋๋ค. "
+
+#: src/memory-management/stack-vs-heap.md:5
+msgid "Extremely fast: just move a stack pointer."
msgstr ""
-"* ์คํ: ์ง์ญ ๋ณ์๋ฅผ ์ํ ์ฐ์์ ์ธ ๋ฉ๋ชจ๋ฆฌ ์์ญ\n"
-" * ์ฌ๊ธฐ ์ ์ฅ๋๋ ๊ฐ์ ์ปดํ์ผ ์ ๊ฒฐ์ ๋๋ ๊ณ ์ ํฌ๊ธฐ๋ฅผ ๊ฐ์ต๋๋ค. \n"
-" * ๋งค์ฐ ๋น ๋ฆ: ๋ฉ๋ชจ๋ฆฌ ํ ๋น/๋ฐํ์ด ๋จ์ง ์คํ ํฌ์ธํฐ์ ์ด๋๋ง์ผ๋ก ๊ตฌํ๋ฉ๋๋ค.\n"
-" * ๊ด๋ฆฌ๊ฐ ์ฌ์: ํจ์๊ฐ ํธ์ถ๋๋ฉด ํ ๋น๋๊ณ , ๋ฆฌํดํ๋ฉด ๋ฐํ๋ฉ๋๋ค.\n"
-" * ์คํ์ ์๋ ๊ฐ๋ค์ ๋งค์ฐ ๋์ ๋ฉ๋ชจ๋ฆฌ ์ธ์ ์ฑ์ ๊ฐ์ง๋๋ค(_์ญ์ฃผ_: ๊ทธ๋์ ์บ์๋ฅผ ํจ๊ณผ์ ์ผ๋ก ํ์ฉํ ์ ์์ต๋๋ค)\n"
-"\n"
-"* ํ: ํจ์ ํธ์ถ/๋ฆฌํด๊ณผ ์๊ด ์์ด ์ ์ง๋๋ ๊ฐ์ด ์ ์ฅ๋๋ ๊ณณ\n"
-" * ์ฌ๊ธฐ ์ ์ฅ๋๋ ๊ฐ์ ํ๋ก๊ทธ๋จ ์ํ์ ๊ทธ ํฌ๊ธฐ๊ฐ ๊ฒฐ์ ๋ฉ๋๋ค.\n"
-" * ์คํ ๋ณด๋ค๋ ๋๋ฆผ: ๋ฉ๋ชจ๋ฆฌ ํ ๋น/๋ฐํ์ ํด์ผ ํ ์ผ์ด ์ข ๋ ์์ต๋๋ค.\n"
-" * ๋ฉ๋ชจ๋ฆฌ ์ธ์ ์ฑ์ ๋ณด์ฅํ์ง ์์ต๋๋ค."
+"๋งค์ฐ ๋น ๋ฆ: ๋ฉ๋ชจ๋ฆฌ ํ ๋น/๋ฐํ์ด ๋จ์ง ์คํ ํฌ์ธํฐ์ ์ด๋๋ง์ผ๋ก ๊ตฌํ๋ฉ๋๋ค."
+
+#: src/memory-management/stack-vs-heap.md:6
+msgid "Easy to manage: follows function calls."
+msgstr "๊ด๋ฆฌ๊ฐ ์ฌ์: ํจ์๊ฐ ํธ์ถ๋๋ฉด ํ ๋น๋๊ณ , ๋ฆฌํดํ๋ฉด ๋ฐํ๋ฉ๋๋ค."
+
+#: src/memory-management/stack-vs-heap.md:7
+msgid "Great memory locality."
+msgstr ""
+"์คํ์ ์๋ ๊ฐ๋ค์ ๋งค์ฐ ๋์ ๋ฉ๋ชจ๋ฆฌ ์ธ์ ์ฑ์ ๊ฐ์ง๋๋ค(_์ญ์ฃผ_: ๊ทธ๋์ ์บ์๋ฅผ "
+"ํจ๊ณผ์ ์ผ๋ก ํ์ฉํ ์ ์์ต๋๋ค)"
+
+#: src/memory-management/stack-vs-heap.md:9
+msgid "Heap: Storage of values outside of function calls."
+msgstr "ํ: ํจ์ ํธ์ถ/๋ฆฌํด๊ณผ ์๊ด ์์ด ์ ์ง๋๋ ๊ฐ์ด ์ ์ฅ๋๋ ๊ณณ"
-#: src/memory-management/stack.md:1
-msgid "# Stack Memory"
-msgstr "# ์คํ ๋ฉ๋ชจ๋ฆฌ"
+#: src/memory-management/stack-vs-heap.md:10
+msgid "Values have dynamic sizes determined at runtime."
+msgstr "์ฌ๊ธฐ ์ ์ฅ๋๋ ๊ฐ์ ํ๋ก๊ทธ๋จ ์ํ์ ๊ทธ ํฌ๊ธฐ๊ฐ ๊ฒฐ์ ๋ฉ๋๋ค."
+
+#: src/memory-management/stack-vs-heap.md:11
+msgid "Slightly slower than the stack: some book-keeping needed."
+msgstr "์คํ ๋ณด๋ค๋ ๋๋ฆผ: ๋ฉ๋ชจ๋ฆฌ ํ ๋น/๋ฐํ์ ํด์ผ ํ ์ผ์ด ์ข ๋ ์์ต๋๋ค."
+
+#: src/memory-management/stack-vs-heap.md:12
+msgid "No guarantee of memory locality."
+msgstr "๋ฉ๋ชจ๋ฆฌ ์ธ์ ์ฑ์ ๋ณด์ฅํ์ง ์์ต๋๋ค."
#: src/memory-management/stack.md:3
msgid ""
-"Creating a `String` puts fixed-sized data on the stack and dynamically sized\n"
+"Creating a `String` puts fixed-sized data on the stack and dynamically sized "
"data on the heap:"
-msgstr "`String` ํ์ ์ ๊ณ ์ ํฌ๊ธฐ ๋ฐ์ดํฐ(_์ญ์ฃผ_: ๋ฌธ์์ด์ ๊ธธ์ด, ๋ฌธ์์ด์ด ์ ์ฅ๋ ๋ฒํผ์ ์ฃผ์ ๋ฑ)๋ ์คํ์ ์ ์ฅํ๊ณ , ๊ฐ๋ณ ํฌ๊ธฐ ๋ฐ์ดํฐ(_์ญ์ฃผ_: ๋ฌธ์์ด ๋ฒํผ)๋ ํ์ ์ ์ฅํฉ๋๋ค:"
+msgstr ""
+"`String` ํ์ ์ ๊ณ ์ ํฌ๊ธฐ ๋ฐ์ดํฐ(_์ญ์ฃผ_: ๋ฌธ์์ด์ ๊ธธ์ด, ๋ฌธ์์ด์ด ์ ์ฅ๋ ๋ฒํผ"
+"์ ์ฃผ์ ๋ฑ)๋ ์คํ์ ์ ์ฅํ๊ณ , ๊ฐ๋ณ ํฌ๊ธฐ ๋ฐ์ดํฐ(_์ญ์ฃผ_: ๋ฌธ์์ด ๋ฒํผ)๋ ํ์ "
+"์ ์ฅํฉ๋๋ค:"
#: src/memory-management/stack.md:6
msgid ""
@@ -3576,63 +4246,83 @@ msgstr ""
#: src/memory-management/stack.md:28
msgid ""
-"* Mention that a `String` is backed by a `Vec`, so it has a capacity and length and can grow if mutable via reallocation on the heap.\n"
-"\n"
-"* If students ask about it, you can mention that the underlying memory is heap allocated using the [System Allocator] and custom allocators can be implemented using the [Allocator API]\n"
-"\n"
-"* We can inspect the memory layout with `unsafe` code. However, you should point out that this is rightfully unsafe!\n"
-"\n"
-" ```rust,editable\n"
-" fn main() {\n"
-" let mut s1 = String::from(\"Hello\");\n"
-" s1.push(' ');\n"
-" s1.push_str(\"world\");\n"
-" // DON'T DO THIS AT HOME! For educational purposes only.\n"
-" // String provides no guarantees about its layout, so this could lead to\n"
-" // undefined behavior.\n"
-" unsafe {\n"
-" let (capacity, ptr, len): (usize, usize, usize) = std::mem::transmute(s1);\n"
-" println!(\"ptr = {ptr:#x}, len = {len}, capacity = {capacity}\");\n"
-" }\n"
+"Mention that a `String` is backed by a `Vec`, so it has a capacity and "
+"length and can grow if mutable via reallocation on the heap."
+msgstr ""
+"๋ฌธ์์ด(`String`)์ ์ค์ ๋ก๋ `Vec`์ ๋๋ค. ํฌ๊ธฐ(capacity)์ ํ์ฌ ๊ธธ์ด(length) "
+"์ ๋ณด๋ฅผ ๊ฐ์ง๋ฉฐ, ๋ ํฐ ํฌ๊ธฐ๊ฐ ํ์ํ ๊ฒฝ์ฐ ํ์์ ์ฌ ํ ๋น์ ํฉ๋๋ค."
+
+#: src/memory-management/stack.md:30
+msgid ""
+"If students ask about it, you can mention that the underlying memory is heap "
+"allocated using the [System Allocator](https://doc.rust-lang.org/std/alloc/"
+"struct.System.html) and custom allocators can be implemented using the "
+"[Allocator API](https://doc.rust-lang.org/std/alloc/index.html)"
+msgstr ""
+"ํ์ ๊ธฐ๋ณธ์ ์ผ๋ก [System Allocator](https://doc.rust-lang.org/std/alloc/"
+"struct.System.html)๋ฅผ ํตํด ํ ๋น๋ฉ๋๋ค. ๊ทธ๋ฆฌ๊ณ [Allocator API](https://doc."
+"rust-lang.org/std/alloc/index.html)๋ฅผ ์ด์ฉํด์ ์ปค์คํ ๋ฉ๋ชจ๋ฆฌ ํ ๋น์๋ฅผ ๋ง๋ค ์"
+"๋ ์์ต๋๋ค."
+
+#: src/memory-management/stack.md:32
+msgid ""
+"We can inspect the memory layout with `unsafe` code. However, you should "
+"point out that this is rightfully unsafe!"
+msgstr ""
+"`unsafe` ์ฝ๋๋ก ๋ฉ๋ชจ๋ฆฌ ๋ ์ด์์์ ์ดํด๋ณผ ์ ์์ต๋๋ค. ๋ฌผ๋ก ์ด ์ฝ๋๊ฐ ์์ ํ"
+"์ง ์๋ค๋ ์ ์ ์๋ ค์ฃผ์ธ์!"
+
+#: src/memory-management/stack.md:34
+msgid ""
+"```rust,editable\n"
+"fn main() {\n"
+" let mut s1 = String::from(\"Hello\");\n"
+" s1.push(' ');\n"
+" s1.push_str(\"world\");\n"
+" // DON'T DO THIS AT HOME! For educational purposes only.\n"
+" // String provides no guarantees about its layout, so this could lead "
+"to\n"
+" // undefined behavior.\n"
+" unsafe {\n"
+" let (capacity, ptr, len): (usize, usize, usize) = std::mem::"
+"transmute(s1);\n"
+" println!(\"ptr = {ptr:#x}, len = {len}, capacity = {capacity}\");\n"
" }\n"
-" ```"
+"}\n"
+"```"
msgstr ""
-"* ๋ฌธ์์ด(`String`)์ ์ค์ ๋ก๋ `Vec`์ ๋๋ค. ํฌ๊ธฐ(capacity)์ ํ์ฌ ๊ธธ์ด(length) ์ ๋ณด๋ฅผ ๊ฐ์ง๋ฉฐ, ๋ ํฐ ํฌ๊ธฐ๊ฐ ํ์ํ ๊ฒฝ์ฐ ํ์์ ์ฌ ํ ๋น์ ํฉ๋๋ค.\n"
-"\n"
-"* ํ์ ๊ธฐ๋ณธ์ ์ผ๋ก [System Allocator]๋ฅผ ํตํด ํ ๋น๋ฉ๋๋ค. ๊ทธ๋ฆฌ๊ณ [Allocator API]๋ฅผ ์ด์ฉํด์ ์ปค์คํ ๋ฉ๋ชจ๋ฆฌ ํ ๋น์๋ฅผ ๋ง๋ค ์๋ ์์ต๋๋ค.\n"
-"\n"
-"* `unsafe` ์ฝ๋๋ก ๋ฉ๋ชจ๋ฆฌ ๋ ์ด์์์ ์ดํด๋ณผ ์ ์์ต๋๋ค. ๋ฌผ๋ก ์ด ์ฝ๋๊ฐ ์์ ํ์ง ์๋ค๋ ์ ์ ์๋ ค์ฃผ์ธ์!\n"
-"\n"
-" ```rust,editable\n"
-" fn main() {\n"
-" let mut s1 = String::from(\"Hello\");\n"
-" s1.push(' ');\n"
-" s1.push_str(\"world\");\n"
-" // DON'T DO THIS AT HOME! For educational purposes only.\n"
-" // String provides no guarantees about its layout, so this could lead to\n"
-" // undefined behavior.\n"
-" unsafe {\n"
-" let (capacity, ptr, len): (usize, usize, usize) = std::mem::transmute(s1);\n"
-" println!(\"ptr = {ptr:#x}, len = {len}, capacity = {capacity}\");\n"
-" }\n"
+"```rust,editable\n"
+"fn main() {\n"
+" let mut s1 = String::from(\"Hello\");\n"
+" s1.push(' ');\n"
+" s1.push_str(\"world\");\n"
+" // DON'T DO THIS AT HOME! For educational purposes only.\n"
+" // String provides no guarantees about its layout, so this could lead "
+"to\n"
+" // undefined behavior.\n"
+" unsafe {\n"
+" let (capacity, ptr, len): (usize, usize, usize) = std::mem::"
+"transmute(s1);\n"
+" println!(\"ptr = {ptr:#x}, len = {len}, capacity = {capacity}\");\n"
" }\n"
-" ```"
-
-#: src/memory-management/manual.md:1
-msgid "# Manual Memory Management"
-msgstr "# ์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
+"}\n"
+"```"
#: src/memory-management/manual.md:3
msgid "You allocate and deallocate heap memory yourself."
msgstr "์ฌ์ฉ์๊ฐ ์ง์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ํ ๋น, ํด์ ํฉ๋๋ค."
#: src/memory-management/manual.md:5
-msgid "If not done with care, this can lead to crashes, bugs, security vulnerabilities, and memory leaks."
-msgstr "์กฐ์ฌํ์ง ์์ผ๋ฉด, ์ถฉ๋(crash), ๋ฒ๊ทธ, ๋ณด์์ทจ์ฝ์ฑ ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๋์ถ์ด ๋ฐ์ํ ์ ์์ต๋๋ค."
+msgid ""
+"If not done with care, this can lead to crashes, bugs, security "
+"vulnerabilities, and memory leaks."
+msgstr ""
+"์กฐ์ฌํ์ง ์์ผ๋ฉด, ์ถฉ๋(crash), ๋ฒ๊ทธ, ๋ณด์์ทจ์ฝ์ฑ ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๋์ถ์ด ๋ฐ์ํ ์ ์"
+"์ต๋๋ค."
#: src/memory-management/manual.md:7
-msgid "## C Example"
-msgstr "## C ์ธ์ด ์์ "
+msgid "C Example"
+msgstr "C ์ธ์ด ์์ "
#: src/memory-management/manual.md:9
msgid "You must call `free` on every pointer you allocate with `malloc`:"
@@ -3662,34 +4352,41 @@ msgstr ""
#: src/memory-management/manual.md:21
msgid ""
-"Memory is leaked if the function returns early between `malloc` and `free`: the\n"
-"pointer is lost and we cannot deallocate the memory."
-msgstr "๋ง์ฝ `malloc` ๊ณผ `free` ์ฌ์ด์์ ํจ์๊ฐ ์ผ์ฐ ๋ฐํ๋๋ฉด ๋ฉ๋ชจ๋ฆฌ ๋์ถ์ด ์ผ์ด๋ฉ๋๋ค: ํฌ์ธํฐ๋ฅผ ์์ด๋ฒ๋ฆฌ๊ฒ ๋์ด ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋ฐํํ ์ ์๊ฒ ๋ฉ๋๋ค."
-
-#: src/memory-management/scope-based.md:1
-msgid "# Scope-Based Memory Management"
-msgstr "# ๋ฒ์๊ธฐ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
+"Memory is leaked if the function returns early between `malloc` and `free`: "
+"the pointer is lost and we cannot deallocate the memory."
+msgstr ""
+"๋ง์ฝ `malloc` ๊ณผ `free` ์ฌ์ด์์ ํจ์๊ฐ ์ผ์ฐ ๋ฐํ๋๋ฉด ๋ฉ๋ชจ๋ฆฌ ๋์ถ์ด ์ผ์ด๋ฉ๋"
+"๋ค: ํฌ์ธํฐ๋ฅผ ์์ด๋ฒ๋ฆฌ๊ฒ ๋์ด ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋ฐํํ ์ ์๊ฒ ๋ฉ๋๋ค."
#: src/memory-management/scope-based.md:3
-msgid "Constructors and destructors let you hook into the lifetime of an object."
-msgstr "์์ฑ์์ ์๋ฉธ์๋ฅผ ์ฌ์ฉํ์ฌ ๊ฐ์ฒด์ ์๋ช ์ฃผ๊ธฐ์ ๋ฐ๋ผ ๋ฉ๋ชจ๋ฆฌ ํ ๋น/ํด์ ๊ฐ ์ผ์ด๋๋๋ก ํ ์ ์์ต๋๋ค."
+msgid ""
+"Constructors and destructors let you hook into the lifetime of an object."
+msgstr ""
+"์์ฑ์์ ์๋ฉธ์๋ฅผ ์ฌ์ฉํ์ฌ ๊ฐ์ฒด์ ์๋ช ์ฃผ๊ธฐ์ ๋ฐ๋ผ ๋ฉ๋ชจ๋ฆฌ ํ ๋น/ํด์ ๊ฐ ์ผ์ด๋๋"
+"๋ก ํ ์ ์์ต๋๋ค."
#: src/memory-management/scope-based.md:5
msgid ""
-"By wrapping a pointer in an object, you can free memory when the object is\n"
-"destroyed. The compiler guarantees that this happens, even if an exception is\n"
-"raised."
-msgstr "ํฌ์ธํฐ๋ฅผ ๊ฐ์ฒด๋ก ๊ฐ์ธ๋๋ก ํ๋ฉด, ๊ทธ ๊ฐ์ฒด๊ฐ ์๋ฉธ๋ ๋ ๊ทธ ํฌ์ธํฐ๊ฐ ๊ฐ๋ฆฌํค๋ ๋ฉ๋ชจ๋ฆฌ๊ฐ ํด์ ๋๋๋ก ํ ์ ์์ต๋๋ค. ์ปดํ์ผ๋ฌ๋ ๊ฐ์ฒด๊ฐ ์๋ฉธ๋ ๋ ๋ฐ๋์ ์๋ฉธ์๊ฐ ํธ์ถ๋๋ ๊ฒ์ ๋ณด์ฅํฉ๋๋ค. ์ฌ์ง์ด๋ ์์ธ(exception)๊ฐ ๋ฐ์(_์ญ์ฃผ_: ํจ์์ ๋ฆฌํด์ด๋ ์ค์ฝํ์ ์ข ๋ฃ ๋ฟ๋ง์ด ์๋๋ผ) ํ๋๋ผ๋์."
+"By wrapping a pointer in an object, you can free memory when the object is "
+"destroyed. The compiler guarantees that this happens, even if an exception "
+"is raised."
+msgstr ""
+"ํฌ์ธํฐ๋ฅผ ๊ฐ์ฒด๋ก ๊ฐ์ธ๋๋ก ํ๋ฉด, ๊ทธ ๊ฐ์ฒด๊ฐ ์๋ฉธ๋ ๋ ๊ทธ ํฌ์ธํฐ๊ฐ ๊ฐ๋ฆฌํค๋ ๋ฉ๋ชจ"
+"๋ฆฌ๊ฐ ํด์ ๋๋๋ก ํ ์ ์์ต๋๋ค. ์ปดํ์ผ๋ฌ๋ ๊ฐ์ฒด๊ฐ ์๋ฉธ๋ ๋ ๋ฐ๋์ ์๋ฉธ์๊ฐ "
+"ํธ์ถ๋๋ ๊ฒ์ ๋ณด์ฅํฉ๋๋ค. ์ฌ์ง์ด๋ ์์ธ(exception)๊ฐ ๋ฐ์(_์ญ์ฃผ_: ํจ์์ ๋ฆฌํด"
+"์ด๋ ์ค์ฝํ์ ์ข ๋ฃ ๋ฟ๋ง์ด ์๋๋ผ) ํ๋๋ผ๋์."
#: src/memory-management/scope-based.md:9
msgid ""
-"This is often called _resource acquisition is initialization_ (RAII) and gives\n"
-"you smart pointers."
-msgstr "์ด๋ฅผ ์ข ์ข RAII (Resource Acquisition Is Initialization)๋ผ๊ณ ํ๋ฉฐ, ์ด๋ฐ ๊ฐ์ฒด๋ ์ผ์ข ์ ์ค๋งํธ ํฌ์ธํฐ ์ญํ ์ ํฉ๋๋ค."
+"This is often called _resource acquisition is initialization_ (RAII) and "
+"gives you smart pointers."
+msgstr ""
+"์ด๋ฅผ ์ข ์ข RAII (Resource Acquisition Is Initialization)๋ผ๊ณ ํ๋ฉฐ, ์ด๋ฐ ๊ฐ์ฒด"
+"๋ ์ผ์ข ์ ์ค๋งํธ ํฌ์ธํฐ ์ญํ ์ ํฉ๋๋ค."
#: src/memory-management/scope-based.md:12
-msgid "## C++ Example"
-msgstr "## C++ ์์ "
+msgid "C++ Example"
+msgstr "C++ ์์ "
#: src/memory-management/scope-based.md:14
msgid ""
@@ -3707,17 +4404,22 @@ msgstr ""
#: src/memory-management/scope-based.md:20
msgid ""
-"* The `std::unique_ptr` object is allocated on the stack, and points to\n"
-" memory allocated on the heap.\n"
-"* At the end of `say_hello`, the `std::unique_ptr` destructor will run.\n"
-"* The destructor frees the `Person` object it points to."
+"The `std::unique_ptr` object is allocated on the stack, and points to memory "
+"allocated on the heap."
msgstr ""
-"* `std::unique_ptr`๊ฐ์ฒด๋ ์คํ์ ํ ๋น๋๋ฉฐ, ํ์ ํ ๋น๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๊ฐ๋ฆฌํต๋๋ค.\n"
-"* `say_hello`ํจ์๊ฐ ๋๋๋ฉด `std::unique_ptr`์ ์๋ฉธ์๊ฐ ์คํ๋ฉ๋๋ค.\n"
-"* ์๋ฉธ์๋ `Person` ๊ฐ์ฒด๊ฐ ๊ฐ๋ฆฌํค๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ํด์ ํฉ๋๋ค."
+"`std::unique_ptr`๊ฐ์ฒด๋ ์คํ์ ํ ๋น๋๋ฉฐ, ํ์ ํ ๋น๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๊ฐ๋ฆฌํต๋๋ค."
+
+#: src/memory-management/scope-based.md:22
+msgid "At the end of `say_hello`, the `std::unique_ptr` destructor will run."
+msgstr "`say_hello`ํจ์๊ฐ ๋๋๋ฉด `std::unique_ptr`์ ์๋ฉธ์๊ฐ ์คํ๋ฉ๋๋ค."
+
+#: src/memory-management/scope-based.md:23
+msgid "The destructor frees the `Person` object it points to."
+msgstr "์๋ฉธ์๋ `Person` ๊ฐ์ฒด๊ฐ ๊ฐ๋ฆฌํค๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ํด์ ํฉ๋๋ค."
#: src/memory-management/scope-based.md:25
-msgid "Special move constructors are used when passing ownership to a function:"
+msgid ""
+"Special move constructors are used when passing ownership to a function:"
msgstr "์ด๋ ์์ฑ์๋ ํจ์ ํธ์ถ ์ ์์ ๊ถ์ ์ ๋ฌํ ๋ ์ฌ์ฉ๋ฉ๋๋ค:"
#: src/memory-management/scope-based.md:27
@@ -3733,30 +4435,35 @@ msgstr ""
"```"
#: src/memory-management/garbage-collection.md:1
-msgid "# Automatic Memory Management"
-msgstr "# ์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
+msgid "Automatic Memory Management"
+msgstr "์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
#: src/memory-management/garbage-collection.md:3
msgid ""
-"An alternative to manual and scope-based memory management is automatic memory\n"
-"management:"
-msgstr "์๋, ์ค์ฝํ๊ธฐ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ์ ๋์์ผ๋ก ์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๋ฐฉ์์ด ์์ต๋๋ค:"
+"An alternative to manual and scope-based memory management is automatic "
+"memory management:"
+msgstr ""
+"์๋, ์ค์ฝํ๊ธฐ๋ฐ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ์ ๋์์ผ๋ก ์๋ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๋ฐฉ์์ด ์์ต๋๋ค:"
#: src/memory-management/garbage-collection.md:6
+msgid "The programmer never allocates or deallocates memory explicitly."
+msgstr "๊ฐ๋ฐ์๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋ช ์์ ์ผ๋ก ํ ๋น/ํด์ ํ์ง ์์ต๋๋ค."
+
+#: src/memory-management/garbage-collection.md:7
msgid ""
-"* The programmer never allocates or deallocates memory explicitly.\n"
-"* A garbage collector finds unused memory and deallocates it for the programmer."
-msgstr ""
-"* ๊ฐ๋ฐ์๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋ช ์์ ์ผ๋ก ํ ๋น/ํด์ ํ์ง ์์ต๋๋ค.\n"
-"* ๊ฐ๋น์ง ์ปฌ๋ ํฐ(GC)๋ ์ฌ์ฉ๋์ง ์๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฐพ์ ํด์ ํฉ๋๋ค."
+"A garbage collector finds unused memory and deallocates it for the "
+"programmer."
+msgstr "๊ฐ๋น์ง ์ปฌ๋ ํฐ(GC)๋ ์ฌ์ฉ๋์ง ์๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฐพ์ ํด์ ํฉ๋๋ค."
#: src/memory-management/garbage-collection.md:9
-msgid "## Java Example"
-msgstr "## Jave ์์ "
+msgid "Java Example"
+msgstr "Jave ์์ "
#: src/memory-management/garbage-collection.md:11
msgid "The `person` object is not deallocated after `sayHello` returns:"
-msgstr "`person`๊ฐ์ฒด๋ `sayHello`ํจ์ ๋ฐํ ํ์๋ ํด์ ๋์ง ์์ต๋๋ค. (_์ญ์ฃผ_: GC๊ฐ ๋์ค์ ์์์ ํด์ ํฉ๋๋ค.)"
+msgstr ""
+"`person`๊ฐ์ฒด๋ `sayHello`ํจ์ ๋ฐํ ํ์๋ ํด์ ๋์ง ์์ต๋๋ค. (_์ญ์ฃผ_: GC๊ฐ ๋"
+"์ค์ ์์์ ํด์ ํฉ๋๋ค.)"
#: src/memory-management/garbage-collection.md:13
msgid ""
@@ -3773,122 +4480,170 @@ msgstr ""
"```"
#: src/memory-management/rust.md:1
-msgid "# Memory Management in Rust"
-msgstr "# ๋ฌ์คํธ์์์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
+msgid "Memory Management in Rust"
+msgstr "๋ฌ์คํธ์์์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ"
#: src/memory-management/rust.md:3
msgid "Memory management in Rust is a mix:"
msgstr "๋ฌ์คํธ์ ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ๋ ์ง๊ธ๊น์ง ์ค๋ช ํ ๋ฐฉ์๋ค์ ํผํฉํด์ ์ฌ์ฉํฉ๋๋ค:"
#: src/memory-management/rust.md:5
+msgid "Safe and correct like Java, but without a garbage collector."
+msgstr "์๋ฐ์ฒ๋ผ ์์ ํ๊ณ ์ ํํฉ๋๋ค. ํ์ง๋ง GC๋ ์์ต๋๋ค."
+
+#: src/memory-management/rust.md:6
+msgid ""
+"Depending on which abstraction (or combination of abstractions) you choose, "
+"can be a single unique pointer, reference counted, or atomically reference "
+"counted."
+msgstr ""
+"๋ค์ํ ์ถ์ํ๋ฅผ ์ ๊ณตํฉ๋๋ค: ๋จ์ผ ํฌ์ธํฐ, ์ฐธ์กฐ ์นด์ดํธ, ์ํ ๋ฏน(atomic) ์ฐธ์กฐ ์นด"
+"์ดํธ."
+
+#: src/memory-management/rust.md:7
+msgid "Scope-based like C++, but the compiler enforces full adherence."
+msgstr ""
+"C++ ์ฒ๋ผ ๋ฒ์(์ค์ฝํ) ๊ธฐ๋ฐ์ ๋๋ค. ํ์ง๋ง ์ปดํ์ผ๋ฌ๊ฐ ํจ์ฌ ๋ ์๊ฒฉํฉ๋๋ค."
+
+#: src/memory-management/rust.md:8
msgid ""
-"* Safe and correct like Java, but without a garbage collector.\n"
-"* Depending on which abstraction (or combination of abstractions) you choose, can be a single unique pointer, reference counted, or atomically reference counted.\n"
-"* Scope-based like C++, but the compiler enforces full adherence.\n"
-"* A Rust user can choose the right abstraction for the situation, some even have no cost at runtime like C."
+"A Rust user can choose the right abstraction for the situation, some even "
+"have no cost at runtime like C."
msgstr ""
-"* ์๋ฐ์ฒ๋ผ ์์ ํ๊ณ ์ ํํฉ๋๋ค. ํ์ง๋ง GC๋ ์์ต๋๋ค.\n"
-"* ๋ค์ํ ์ถ์ํ๋ฅผ ์ ๊ณตํฉ๋๋ค: ๋จ์ผ ํฌ์ธํฐ, ์ฐธ์กฐ ์นด์ดํธ, ์ํ ๋ฏน(atomic) ์ฐธ์กฐ ์นด์ดํธ.\n"
-"* C++ ์ฒ๋ผ ๋ฒ์(์ค์ฝํ) ๊ธฐ๋ฐ์ ๋๋ค. ํ์ง๋ง ์ปดํ์ผ๋ฌ๊ฐ ํจ์ฌ ๋ ์๊ฒฉํฉ๋๋ค.\n"
-"* ์ฌ์ฉ์๋ ์ํฉ์ ๋ฐ๋ผ ์ ํฉํ ์ถ์ํ๋ฅผ ์ ํํ ์ ์์ต๋๋ค. ๊ทธ ์ค์๋ C ์ธ์ด ์ฒ๋ผ ๋ฐํ์ ์ค๋ฒํค๋๊ฐ ์๋ ๊ฒ๋ ์์ต๋๋ค."
+"์ฌ์ฉ์๋ ์ํฉ์ ๋ฐ๋ผ ์ ํฉํ ์ถ์ํ๋ฅผ ์ ํํ ์ ์์ต๋๋ค. ๊ทธ ์ค์๋ C ์ธ์ด ์ฒ"
+"๋ผ ๋ฐํ์ ์ค๋ฒํค๋๊ฐ ์๋ ๊ฒ๋ ์์ต๋๋ค."
#: src/memory-management/rust.md:10
msgid "It achieves this by modeling _ownership_ explicitly."
-msgstr "๋ฌ์คํธ๋ *์์ ๊ถ*์ ์ธ์ด ์ฐจ์์์ ๋ช ์์ ์ผ๋ก ๋ชจ๋ธ๋ง ํจ์ผ๋ก์จ ์ด๋ฅผ ์ด๋ฃน๋๋ค."
+msgstr ""
+"๋ฌ์คํธ๋ _์์ ๊ถ_์ ์ธ์ด ์ฐจ์์์ ๋ช ์์ ์ผ๋ก ๋ชจ๋ธ๋ง ํจ์ผ๋ก์จ ์ด๋ฅผ ์ด๋ฃน๋๋ค."
#: src/memory-management/rust.md:14
msgid ""
-"* If asked how at this point, you can mention that in Rust this is usually handled by RAII wrapper types such as [Box], [Vec], [Rc], or [Arc]. These encapsulate ownership and memory allocation via various means, and prevent the potential errors in C.\n"
-"\n"
-"* You may be asked about destructors here, the [Drop] trait is the Rust equivalent."
+"If asked how at this point, you can mention that in Rust this is usually "
+"handled by RAII wrapper types such as [Box](https://doc.rust-lang.org/std/"
+"boxed/struct.Box.html), [Vec](https://doc.rust-lang.org/std/vec/struct.Vec."
+"html), [Rc](https://doc.rust-lang.org/std/rc/struct.Rc.html), or [Arc]"
+"(https://doc.rust-lang.org/std/sync/struct.Arc.html). These encapsulate "
+"ownership and memory allocation via various means, and prevent the potential "
+"errors in C."
msgstr ""
-"* ์ด ์์ ์์ ๊ทธ๊ฒ ์ด๋ป๊ฒ ๊ฐ๋ฅํ๋๋ ์ง๋ฌธ์ด ์์ผ๋ฉด, ๋ฌ์คํธ์์ ์ด ์์ ์ ์ผ๋ฐ์ ์ผ๋ก [Box], [Vec], [Rc] ๋๋ [Arc]์ ๊ฐ์ RAII ํ์ ์ ์ํด ์ฒ๋ฆฌ๋๋ค๊ณ ๋ต๋ณํ ์ ์์ต๋๋ค. ์ด๋ค์ ๋ค์ํ ๋ฐฉ๋ฒ์ ํตํด ์์ ๊ถ๊ณผ ๋ฉ๋ชจ๋ฆฌ ํ ๋น์ ๋ํ ๊ตฌ์ฒด์ ์ธ ๋ด์ฉ์์ ์บก์ํํ์ฌ, C ์ธ์ด์๋ค๋ฉด ๋ฐ์ํ ์ ์์์ ๋ค์ํ ์๋ฌ๋ฅผ ๋ง์ต๋๋ค.\n"
-"\n"
-"* ์๋ฉธ์์ ๋ํ ์ง๋ฌธ๋ ์์ ์ ์์ต๋๋ค. [Drop] ํธ๋ ์์ด ๋ต์ ๋๋ค."
+"์ด ์์ ์์ ๊ทธ๊ฒ ์ด๋ป๊ฒ ๊ฐ๋ฅํ๋๋ ์ง๋ฌธ์ด ์์ผ๋ฉด, ๋ฌ์คํธ์์ ์ด ์์ ์ ์ผ๋ฐ์ "
+"์ผ๋ก [Box](https://doc.rust-lang.org/std/boxed/struct.Box.html), [Vec]"
+"(https://doc.rust-lang.org/std/vec/struct.Vec.html), [Rc](https://doc.rust-"
+"lang.org/std/rc/struct.Rc.html) ๋๋ [Arc](https://doc.rust-lang.org/std/"
+"sync/struct.Arc.html)์ ๊ฐ์ RAII ํ์ ์ ์ํด ์ฒ๋ฆฌ๋๋ค๊ณ ๋ต๋ณํ ์ ์์ต๋๋ค. "
+"์ด๋ค์ ๋ค์ํ ๋ฐฉ๋ฒ์ ํตํด ์์ ๊ถ๊ณผ ๋ฉ๋ชจ๋ฆฌ ํ ๋น์ ๋ํ ๊ตฌ์ฒด์ ์ธ ๋ด์ฉ์์ ์บก์"
+"ํํ์ฌ, C ์ธ์ด์๋ค๋ฉด ๋ฐ์ํ ์ ์์์ ๋ค์ํ ์๋ฌ๋ฅผ ๋ง์ต๋๋ค."
-#: src/memory-management/comparison.md:1
-msgid "# Comparison"
-msgstr "# ๋น๊ต"
+#: src/memory-management/rust.md:16
+msgid ""
+"You may be asked about destructors here, the [Drop](https://doc.rust-lang."
+"org/std/ops/trait.Drop.html) trait is the Rust equivalent."
+msgstr ""
+"์๋ฉธ์์ ๋ํ ์ง๋ฌธ๋ ์์ ์ ์์ต๋๋ค. [Drop](https://doc.rust-lang.org/std/"
+"ops/trait.Drop.html) ํธ๋ ์์ด ๋ต์ ๋๋ค."
#: src/memory-management/comparison.md:3
msgid "Here is a rough comparison of the memory management techniques."
msgstr "๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๊ธฐ์ ์ ๋๋ต์ ์ธ ๋น๊ต์ ๋๋ค."
#: src/memory-management/comparison.md:5
-msgid "## Pros of Different Memory Management Techniques"
-msgstr "## ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๋ฐฉ๋ฒ ๋ณ ์ฅ์ "
-
-#: src/memory-management/comparison.md:7
-msgid ""
-"* Manual like C:\n"
-" * No runtime overhead.\n"
-"* Automatic like Java:\n"
-" * Fully automatic.\n"
-" * Safe and correct.\n"
-"* Scope-based like C++:\n"
-" * Partially automatic.\n"
-" * No runtime overhead.\n"
-"* Compiler-enforced scope-based like Rust:\n"
-" * Enforced by compiler.\n"
-" * No runtime overhead.\n"
-" * Safe and correct."
-msgstr ""
-"* C์ ๊ฐ์ ์๋ ๊ด๋ฆฌ: \n"
-" * ๋ฐํ์ ์ค๋ฒํค๋๊ฐ ์์. \n"
-"* JAVA์ ๊ฐ์ ์๋ํ ๊ด๋ฆฌ: \n"
-" * ์์ ํ ์๋ํ.\n"
-" * ์์ ํ๊ณ ์ ํํจ.\n"
-"* C++ ์ ๊ฐ์ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ: \n"
-" * ๋ถ๋ถ ์๋ํ\n"
-" * ๋ฐํ์ ์ค๋ฒํค๋๊ฐ ์์.\n"
-"* ๋ฌ์คํธ์ ๊ฐ์ ์ปดํ์ผ๋ฌ ์ํ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ: \n"
-" * ์ปดํ์ผ๋ฌ์ ์ํด ์ํ๋ฉ๋๋ค.\n"
-" * ๋ฐํ์ ์ค๋ฒํค๋๊ฐ ์์ต๋๋ค. \n"
-" * ์์ ํ๊ณ ์ ํํฉ๋๋ค."
+msgid "Pros of Different Memory Management Techniques"
+msgstr "๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๋ฐฉ๋ฒ ๋ณ ์ฅ์ "
+
+#: src/memory-management/comparison.md:7 src/memory-management/comparison.md:22
+msgid "Manual like C:"
+msgstr "C์ ๊ฐ์ ์๋ ๊ด๋ฆฌ: "
+
+#: src/memory-management/comparison.md:8 src/memory-management/comparison.md:14
+#: src/memory-management/comparison.md:17
+msgid "No runtime overhead."
+msgstr "๋ฐํ์ ์ค๋ฒํค๋๊ฐ ์์. "
+
+#: src/memory-management/comparison.md:9 src/memory-management/comparison.md:26
+msgid "Automatic like Java:"
+msgstr "JAVA์ ๊ฐ์ ์๋ํ ๊ด๋ฆฌ: "
+
+#: src/memory-management/comparison.md:10
+msgid "Fully automatic."
+msgstr "์์ ํ ์๋ํ."
+
+#: src/memory-management/comparison.md:11
+#: src/memory-management/comparison.md:18
+msgid "Safe and correct."
+msgstr "์์ ํ๊ณ ์ ํํจ."
+
+#: src/memory-management/comparison.md:12
+#: src/memory-management/comparison.md:29
+msgid "Scope-based like C++:"
+msgstr "C++ ์ ๊ฐ์ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ: "
+
+#: src/memory-management/comparison.md:13
+msgid "Partially automatic."
+msgstr "๋ถ๋ถ ์๋ํ"
+
+#: src/memory-management/comparison.md:15
+msgid "Compiler-enforced scope-based like Rust:"
+msgstr "๋ฌ์คํธ์ ๊ฐ์ ์ปดํ์ผ๋ฌ ์ํ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ: "
+
+#: src/memory-management/comparison.md:16
+msgid "Enforced by compiler."
+msgstr "์ปดํ์ผ๋ฌ์ ์ํด ์ํ๋ฉ๋๋ค."
#: src/memory-management/comparison.md:20
-msgid "## Cons of Different Memory Management Techniques"
-msgstr "## ๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๋ฐฉ๋ฒ ๋ณ ๋จ์ "
-
-#: src/memory-management/comparison.md:22
-msgid ""
-"* Manual like C:\n"
-" * Use-after-free.\n"
-" * Double-frees.\n"
-" * Memory leaks.\n"
-"* Automatic like Java:\n"
-" * Garbage collection pauses.\n"
-" * Destructor delays.\n"
-"* Scope-based like C++:\n"
-" * Complex, opt-in by programmer.\n"
-" * Potential for use-after-free.\n"
-"* Compiler-enforced and scope-based like Rust:\n"
-" * Some upfront complexity.\n"
-" * Can reject valid programs."
-msgstr ""
-"* C์ ๊ฐ์ ์๋ ๊ด๋ฆฌ:\n"
-" * ์ฌ์ฉ ํ ํด์ ๋ฌธ์ .\n"
-" * ์ด์ค ํด์ ๋ฌธ์ .\n"
-" * ๋ฉ๋ชจ๋ฆฌ ๋์ถ ๋ฌธ์ .\n"
-"* JAVA์ ๊ฐ์ ์๋ํ ๊ด๋ฆฌ:\n"
-" * GC๋์์ผ๋ก ์ธํ ๋ฉ์ถค.\n"
-" * ์๋ฉธ์ ์ง์ฐ (_์ญ์ฃผ_: ํน์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋์ด์ ์ฌ์ฉํ์ง ์๋๋ผ๋ ๊ณง๋ฐ๋ก ํด์ ๋์ง ์๊ณ GC๊ฐ ๋์ํ ๋ ๊น์ง ๊ธฐ๋ค๋ ค์ผ ํ๋ค๋ ์ )\n"
-"* C++ ์ ๊ฐ์ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ:\n"
-" * ๋ณต์กํ๋ฉฐ, ๊ฐ๋ฐ์์ ์ ํ์ฌํญ์.\n"
-" * ์ฌ์ฉ ํ ํด์ ๋ฌธ์ ๊ฐ๋ฅ์ฑ ์์.\n"
-"* ๋ฌ์คํธ์ ๊ฐ์ ์ปดํ์ผ๋ฌ๊ฐ ๊ฐ์ ํ๋ ์ํ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ:\n"
-" * ์ฝ๊ฐ์ ์ด๊ธฐ ๋ณต์ก์ฑ.\n"
-" * ์ฌ๋ฐ๋ฅธ ํ๋ก๊ทธ๋จ์ด์ง๋ง ์ปดํ์ผ๋ฌ๊ฐ ๊ฑฐ๋ถํ ์ ์์."
-
-#: src/ownership.md:1
-msgid "# Ownership"
-msgstr "# ์์ ๊ถ"
+msgid "Cons of Different Memory Management Techniques"
+msgstr "๋ฉ๋ชจ๋ฆฌ ๊ด๋ฆฌ ๋ฐฉ๋ฒ ๋ณ ๋จ์ "
+
+#: src/memory-management/comparison.md:23
+msgid "Use-after-free."
+msgstr "์ฌ์ฉ ํ ํด์ ๋ฌธ์ ."
+
+#: src/memory-management/comparison.md:24
+msgid "Double-frees."
+msgstr "์ด์ค ํด์ ๋ฌธ์ ."
+
+#: src/memory-management/comparison.md:25
+msgid "Memory leaks."
+msgstr "๋ฉ๋ชจ๋ฆฌ ๋์ถ ๋ฌธ์ ."
+
+#: src/memory-management/comparison.md:27
+msgid "Garbage collection pauses."
+msgstr "GC๋์์ผ๋ก ์ธํ ๋ฉ์ถค."
+
+#: src/memory-management/comparison.md:28
+msgid "Destructor delays."
+msgstr ""
+"์๋ฉธ์ ์ง์ฐ (_์ญ์ฃผ_: ํน์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋์ด์ ์ฌ์ฉํ์ง ์๋๋ผ๋ ๊ณง๋ฐ๋ก ํด์ ๋์ง "
+"์๊ณ GC๊ฐ ๋์ํ ๋ ๊น์ง ๊ธฐ๋ค๋ ค์ผ ํ๋ค๋ ์ )"
+
+#: src/memory-management/comparison.md:30
+msgid "Complex, opt-in by programmer."
+msgstr "๋ณต์กํ๋ฉฐ, ๊ฐ๋ฐ์์ ์ ํ์ฌํญ์."
+
+#: src/memory-management/comparison.md:31
+msgid "Potential for use-after-free."
+msgstr "์ฌ์ฉ ํ ํด์ ๋ฌธ์ ๊ฐ๋ฅ์ฑ ์์."
+
+#: src/memory-management/comparison.md:32
+msgid "Compiler-enforced and scope-based like Rust:"
+msgstr "๋ฌ์คํธ์ ๊ฐ์ ์ปดํ์ผ๋ฌ๊ฐ ๊ฐ์ ํ๋ ์ํ ๋ฒ์ ๊ธฐ๋ฐ ๊ด๋ฆฌ:"
+
+#: src/memory-management/comparison.md:33
+msgid "Some upfront complexity."
+msgstr "์ฝ๊ฐ์ ์ด๊ธฐ ๋ณต์ก์ฑ."
+
+#: src/memory-management/comparison.md:34
+msgid "Can reject valid programs."
+msgstr "์ฌ๋ฐ๋ฅธ ํ๋ก๊ทธ๋จ์ด์ง๋ง ์ปดํ์ผ๋ฌ๊ฐ ๊ฑฐ๋ถํ ์ ์์."
#: src/ownership.md:3
msgid ""
-"All variable bindings have a _scope_ where they are valid and it is an error to\n"
-"use a variable outside its scope:"
-msgstr "๋ชจ๋ ๋ณ์ ๋ฐ์ธ๋ฉ์ ์ ํจํ \"๋ฒ์(์ค์ฝํ)\"๋ฅผ ๊ฐ์ง๋ฉฐ, ๋ฒ์ ๋ฐ์์ ๋ณ์ ์ฌ์ฉํ๋ฉด ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค:"
+"All variable bindings have a _scope_ where they are valid and it is an error "
+"to use a variable outside its scope:"
+msgstr ""
+"๋ชจ๋ ๋ณ์ ๋ฐ์ธ๋ฉ์ ์ ํจํ \"๋ฒ์(์ค์ฝํ)\"๋ฅผ ๊ฐ์ง๋ฉฐ, ๋ฒ์ ๋ฐ์์ ๋ณ์ ์ฌ์ฉํ"
+"๋ฉด ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค:"
#: src/ownership.md:6
msgid ""
@@ -3918,17 +4673,20 @@ msgstr ""
#: src/ownership.md:18
msgid ""
-"* At the end of the scope, the variable is _dropped_ and the data is freed.\n"
-"* A destructor can run here to free up resources.\n"
-"* We say that the variable _owns_ the value."
+"At the end of the scope, the variable is _dropped_ and the data is freed."
+msgstr ""
+"์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ๋ณ์๋ \"์ญ์ (drop)\"๋์๋ค๊ณ ํ๋ฉฐ ๊ทธ ๋ณ์์ ๋ฐ์ดํฐ๋ ๋ฉ๋ชจ"
+"๋ฆฌ์์ ํด์ ๋ฉ๋๋ค."
+
+#: src/ownership.md:19
+msgid "A destructor can run here to free up resources."
msgstr ""
-"* ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ๋ณ์๋ \"์ญ์ (drop)\"๋์๋ค๊ณ ํ๋ฉฐ ๊ทธ ๋ณ์์ ๋ฐ์ดํฐ๋ ๋ฉ๋ชจ๋ฆฌ์์ ํด์ ๋ฉ๋๋ค.\n"
-"* ์ค์ฝํ๊ฐ ์ข ๋ฃ๋ ๋ ๋ค๋ฅธ ๋ฆฌ์์ค๋ฅผ ํด์ ํ๊ธฐ ์ํด ์๋ฉธ์๊ฐ ํธ์ถ๋๋๋ก ํ ์ ์์ต๋๋ค.\n"
-"* ์ด๊ฒ์ ๋๊ณ ๋ณ์๊ฐ ๊ฐ์ \"์์ \"ํ๋ค๊ณ ํํํฉ๋๋ค."
+"์ค์ฝํ๊ฐ ์ข ๋ฃ๋ ๋ ๋ค๋ฅธ ๋ฆฌ์์ค๋ฅผ ํด์ ํ๊ธฐ ์ํด ์๋ฉธ์๊ฐ ํธ์ถ๋๋๋ก ํ ์ ์์ต"
+"๋๋ค."
-#: src/ownership/move-semantics.md:1
-msgid "# Move Semantics"
-msgstr "# Move ๋ฌธ๋ฒ(Move Semantics)"
+#: src/ownership.md:20
+msgid "We say that the variable _owns_ the value."
+msgstr "์ด๊ฒ์ ๋๊ณ ๋ณ์๊ฐ ๊ฐ์ \"์์ \"ํ๋ค๊ณ ํํํฉ๋๋ค."
#: src/ownership/move-semantics.md:3
msgid "An assignment will transfer ownership between variables:"
@@ -3955,32 +4713,40 @@ msgstr ""
"```"
#: src/ownership/move-semantics.md:14
-msgid ""
-"* The assignment of `s1` to `s2` transfers ownership.\n"
-"* The data was _moved_ from `s1` and `s1` is no longer accessible.\n"
-"* When `s1` goes out of scope, nothing happens: it has no ownership.\n"
-"* When `s2` goes out of scope, the string data is freed.\n"
-"* There is always _exactly_ one variable binding which owns a value."
+msgid "The assignment of `s1` to `s2` transfers ownership."
+msgstr "`s1`์ `s2`์ ํ ๋นํ์ฌ ์์ ๊ถ์ ์ด์ ์ํต๋๋ค."
+
+#: src/ownership/move-semantics.md:15
+msgid "The data was _moved_ from `s1` and `s1` is no longer accessible."
msgstr ""
-"* `s1`์ `s2`์ ํ ๋นํ์ฌ ์์ ๊ถ์ ์ด์ ์ํต๋๋ค.\n"
-"* ๋ฐ์ดํฐ๋ `s1`์์ _์ด๋_๋ฉ๋๋ค. ๋ฐ๋ผ์ ํ๋ก๊ทธ๋๋จธ๋ `s1`์ ๋ ์ด์ ์ ๊ทผ ํ ์ ์์ต๋๋ค.\n"
-"* `s1`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ์๋ฌด ์ผ๋ ์์ต๋๋ค: ์๋ํ๋ฉด `s1`์ ์๋ฌด๋ฐ ์์ ๊ถ์ด ์๊ธฐ ๋๋ฌธ์ ๋๋ค.\n"
-"* `s2`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ๋ฌธ์์ด ๋ฐ์ดํฐ๋ ํด์ ๋ฉ๋๋ค.\n"
-"* ๊ฐ(๋ฐ์ดํฐ)์ ์์ ๊ถ์ ๊ฐ๋ ๋ณ์๋ ํญ์ *๋จ* ํ๋ ์ ๋๋ค."
+"๋ฐ์ดํฐ๋ `s1`์์ \\_์ด๋_๋ฉ๋๋ค. ๋ฐ๋ผ์ ํ๋ก๊ทธ๋๋จธ๋ `s1`์ ๋ ์ด์ ์ ๊ทผ ํ "
+"์ ์์ต๋๋ค."
+
+#: src/ownership/move-semantics.md:16
+msgid "When `s1` goes out of scope, nothing happens: it has no ownership."
+msgstr ""
+"`s1`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ์๋ฌด ์ผ๋ ์์ต๋๋ค: ์๋ํ๋ฉด `s1`์ ์๋ฌด๋ฐ ์์ ๊ถ์ด "
+"์๊ธฐ ๋๋ฌธ์ ๋๋ค."
+
+#: src/ownership/move-semantics.md:17
+msgid "When `s2` goes out of scope, the string data is freed."
+msgstr "`s2`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ๋ฌธ์์ด ๋ฐ์ดํฐ๋ ํด์ ๋ฉ๋๋ค."
+
+#: src/ownership/move-semantics.md:18
+msgid "There is always _exactly_ one variable binding which owns a value."
+msgstr "๊ฐ(๋ฐ์ดํฐ)์ ์์ ๊ถ์ ๊ฐ๋ ๋ณ์๋ ํญ์ _๋จ_ ํ๋ ์ ๋๋ค."
#: src/ownership/move-semantics.md:22
msgid ""
-"* Mention that this is the opposite of the defaults in C++, which copies by value unless you use `std::move` (and the move constructor is defined!).\n"
-"\n"
-"* In Rust, clones are explicit (by using `clone`)."
+"Mention that this is the opposite of the defaults in C++, which copies by "
+"value unless you use `std::move` (and the move constructor is defined!)."
msgstr ""
-"* ์ด๋ C++๊ณผ ์ ๋ฐ๋ ์์ ์ค๋ช ํ์ธ์. C++์์๋ ๋ณต์ฌ๊ฐ ๊ธฐ๋ณธ์ด๊ณ , `std::move` ๋ฅผ ์ด์ฉํด์ผ๋ง (๊ทธ๋ฆฌ๊ณ ์ด๋ ์์ฑ์๊ฐ ์ ์๋์ด ์์ด์ผ๋ง!) ์์ ๊ถ ์ด์ ์ด ๋ฉ๋๋ค.\n"
-"\n"
-"* ๋ฌ์คํธ์์๋ ๋ณต์ฌํ ๋์๋ ๋ช ์์ ์ผ๋ก `clone`์ ์ฌ์ฉํฉ๋๋ค."
+"์ด๋ C++๊ณผ ์ ๋ฐ๋ ์์ ์ค๋ช ํ์ธ์. C++์์๋ ๋ณต์ฌ๊ฐ ๊ธฐ๋ณธ์ด๊ณ , `std::move` ๋ฅผ "
+"์ด์ฉํด์ผ๋ง (๊ทธ๋ฆฌ๊ณ ์ด๋ ์์ฑ์๊ฐ ์ ์๋์ด ์์ด์ผ๋ง!) ์์ ๊ถ ์ด์ ์ด ๋ฉ๋๋ค."
-#: src/ownership/moved-strings-rust.md:1
-msgid "# Moved Strings in Rust"
-msgstr "# ๋ฌ์คํธ์์์ ๋ฌธ์์ด ์ด๋(Move)"
+#: src/ownership/move-semantics.md:24
+msgid "In Rust, clones are explicit (by using `clone`)."
+msgstr "๋ฌ์คํธ์์๋ ๋ณต์ฌํ ๋์๋ ๋ช ์์ ์ผ๋ก `clone`์ ์ฌ์ฉํฉ๋๋ค."
#: src/ownership/moved-strings-rust.md:3
msgid ""
@@ -3999,12 +4765,13 @@ msgstr ""
"```"
#: src/ownership/moved-strings-rust.md:10
-msgid ""
-"* The heap data from `s1` is reused for `s2`.\n"
-"* When `s1` goes out of scope, nothing happens (it has been moved from)."
+msgid "The heap data from `s1` is reused for `s2`."
+msgstr "`s1`์ ํ ๋ฐ์ดํฐ๋ `s2`์์ ์ฌ์ฌ์ฉ ๋ฉ๋๋ค."
+
+#: src/ownership/moved-strings-rust.md:11
+msgid "When `s1` goes out of scope, nothing happens (it has been moved from)."
msgstr ""
-"* `s1`์ ํ ๋ฐ์ดํฐ๋ `s2`์์ ์ฌ์ฌ์ฉ ๋ฉ๋๋ค.\n"
-"* `s1`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ์๋ฌด์ผ๋ ์ผ์ด๋์ง ์์ต๋๋ค.(์ด๋ฏธ ์ด๋๋์์ต๋๋ค.)"
+"`s1`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ์๋ฌด์ผ๋ ์ผ์ด๋์ง ์์ต๋๋ค.(์ด๋ฏธ ์ด๋๋์์ต๋๋ค.)"
#: src/ownership/moved-strings-rust.md:13
msgid "Before move to `s2`:"
@@ -4090,10 +4857,6 @@ msgstr ""
"`- - - - - - - - - - - - - -'\n"
"```"
-#: src/ownership/double-free-modern-cpp.md:1
-msgid "# Double Frees in Modern C++"
-msgstr "# Modern C++์์ ์ด์คํด์ ๋ฌธ์ "
-
#: src/ownership/double-free-modern-cpp.md:3
msgid "Modern C++ solves this differently:"
msgstr "Modern C++์ ์ด ๋ฌธ์ ๋ฅผ ๋ค๋ฅด๊ฒ ํด๊ฒฐํฉ๋๋ค:"
@@ -4112,11 +4875,12 @@ msgstr ""
#: src/ownership/double-free-modern-cpp.md:10
msgid ""
-"* The heap data from `s1` is duplicated and `s2` gets its own independent copy.\n"
-"* When `s1` and `s2` go out of scope, they each free their own memory."
-msgstr ""
-"* `s1`์ ํ ๋ฐ์ดํฐ๋ ๋ณต์ ๋๊ณ , `s2`๋ ๋ ๋ฆฝ์ ์ธ ๋ณต์ฌ๋ณธ์ ์ป์ต๋๋ค.\n"
-"* `s1` ์ `s2`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ๊ฐ๊ฐ์ ๋ฉ๋ชจ๋ฆฌ๊ฐ ํด์ ๋ฉ๋๋ค."
+"The heap data from `s1` is duplicated and `s2` gets its own independent copy."
+msgstr "`s1`์ ํ ๋ฐ์ดํฐ๋ ๋ณต์ ๋๊ณ , `s2`๋ ๋ ๋ฆฝ์ ์ธ ๋ณต์ฌ๋ณธ์ ์ป์ต๋๋ค."
+
+#: src/ownership/double-free-modern-cpp.md:11
+msgid "When `s1` and `s2` go out of scope, they each free their own memory."
+msgstr "`s1` ์ `s2`์ ์ค์ฝํ๊ฐ ์ข ๋ฃ๋๋ฉด ๊ฐ๊ฐ์ ๋ฉ๋ชจ๋ฆฌ๊ฐ ํด์ ๋ฉ๋๋ค."
#: src/ownership/double-free-modern-cpp.md:13
msgid "Before copy-assignment:"
@@ -4200,15 +4964,13 @@ msgstr ""
"`- - - - - - - - - - - - - -'\n"
"```"
-#: src/ownership/moves-function-calls.md:1
-msgid "# Moves in Function Calls"
-msgstr "# ํจ์ ํธ์ถ์์์ ์ด๋(Move)"
-
#: src/ownership/moves-function-calls.md:3
msgid ""
-"When you pass a value to a function, the value is assigned to the function\n"
+"When you pass a value to a function, the value is assigned to the function "
"parameter. This transfers ownership:"
-msgstr "๊ฐ์ ํจ์์ ์ ๋ฌํ ๋, ๊ทธ ๊ฐ์ ๋งค๊ฐ๋ณ์์ ํ ๋น๋ฉ๋๋ค. ์ด๋ ์์ ๊ถ์ ์ด๋์ด ์ผ์ด๋ฉ๋๋ค:"
+msgstr ""
+"๊ฐ์ ํจ์์ ์ ๋ฌํ ๋, ๊ทธ ๊ฐ์ ๋งค๊ฐ๋ณ์์ ํ ๋น๋ฉ๋๋ค. ์ด๋ ์์ ๊ถ์ ์ด๋์ด ์ผ"
+"์ด๋ฉ๋๋ค:"
#: src/ownership/moves-function-calls.md:6
msgid ""
@@ -4238,24 +5000,46 @@ msgstr ""
#: src/ownership/moves-function-calls.md:20
msgid ""
-"* With the first call to `say_hello`, `main` gives up ownership of `name`. Afterwards, `name` cannot be used anymore within `main`.\n"
-"* The heap memory allocated for `name` will be freed at the end of the `say_hello` function.\n"
-"* `main` can retain ownership if it passes `name` as a reference (`&name`) and if `say_hello` accepts a reference as a parameter.\n"
-"* Alternatively, `main` can pass a clone of `name` in the first call (`name.clone()`).\n"
-"* Rust makes it harder than C++ to inadvertently create copies by making move semantics the default, and by forcing programmers to make clones explicit."
+"With the first call to `say_hello`, `main` gives up ownership of `name`. "
+"Afterwards, `name` cannot be used anymore within `main`."
+msgstr ""
+"`say_hello`ํจ์์ ์ฒซ๋ฒ์งธ ํธ์ถ์ `main`ํจ์๋ ์์ ์ด ๊ฐ์ง `name`์ ๋ํ ์์ ๊ถ"
+"์ ํฌ๊ธฐํ๋ฏ๋ก, ์ดํ `main`ํจ์์์๋ `name`์ ์ฌ์ฉํ ์ ์์ต๋๋ค."
+
+#: src/ownership/moves-function-calls.md:21
+msgid ""
+"The heap memory allocated for `name` will be freed at the end of the "
+"`say_hello` function."
+msgstr "`name`์ ํ ๋น๋์๋ ํ ๋ฉ๋ชจ๋ฆฌ๋ `say_hello`ํจ์์ ๋์์ ํด์ ๋ฉ๋๋ค."
+
+#: src/ownership/moves-function-calls.md:22
+msgid ""
+"`main` can retain ownership if it passes `name` as a reference (`&name`) and "
+"if `say_hello` accepts a reference as a parameter."
+msgstr ""
+"`main`ํจ์์์ `name`์ ์ฐธ์กฐ๋ก ์ ๋ฌ(๋น๋ฆผ)ํ๊ณ (`&name`), `say_hello`์์ ๋งค๊ฐ"
+"๋ณ์๋ฅผ ์ฐธ์กฐํ์ผ๋ก ์์ ํ๋ค๋ฉด `main`ํจ์๋ `name`์ ์์ ๊ถ์ ์ ์งํ ์ ์์ต๋"
+"๋ค."
+
+#: src/ownership/moves-function-calls.md:23
+msgid ""
+"Alternatively, `main` can pass a clone of `name` in the first call (`name."
+"clone()`)."
msgstr ""
-"* `say_hello`ํจ์์ ์ฒซ๋ฒ์งธ ํธ์ถ์ `main`ํจ์๋ ์์ ์ด ๊ฐ์ง `name`์ ๋ํ ์์ ๊ถ์ ํฌ๊ธฐํ๋ฏ๋ก, ์ดํ `main`ํจ์์์๋ `name`์ ์ฌ์ฉํ ์ ์์ต๋๋ค.\n"
-"* `name`์ ํ ๋น๋์๋ ํ ๋ฉ๋ชจ๋ฆฌ๋ `say_hello`ํจ์์ ๋์์ ํด์ ๋ฉ๋๋ค.\n"
-"* `main`ํจ์์์ `name`์ ์ฐธ์กฐ๋ก ์ ๋ฌ(๋น๋ฆผ)ํ๊ณ (`&name`), `say_hello`์์ ๋งค๊ฐ๋ณ์๋ฅผ ์ฐธ์กฐํ์ผ๋ก ์์ ํ๋ค๋ฉด `main`ํจ์๋ `name`์ ์์ ๊ถ์ ์ ์งํ ์ ์์ต๋๋ค.\n"
-"* ๋๋ ์ฒซ๋ฒ์งธ ํธ์ถ ์ `main`ํจ์์์ `name`์ ๋ณต์ ํ์ฌ ์ ๋ฌํ ์๋ ์์ต๋๋ค.(`name.clone()`)\n"
-"* ๋ฌ์คํธ๋ ์ด๋์ ๊ธฐ๋ณธ์ผ๋ก ํ๊ณ ๋ณต์ ๋ฅผ ๋ช ์์ ์ผ๋ก ์ ์ธํ๋๋ก ๋ง๋ฌ์ผ๋ก, ์๋์น ์๊ฒ ๋ณต์ฌ๋ณธ์ ๋ง๋๋ ๊ฒ์ด C++์์๋ณด๋ค ์ด๋ ต์ต๋๋ค."
+"๋๋ ์ฒซ๋ฒ์งธ ํธ์ถ ์ `main`ํจ์์์ `name`์ ๋ณต์ ํ์ฌ ์ ๋ฌํ ์๋ ์์ต๋๋ค."
+"(`name.clone()`)"
-#: src/ownership/copy-clone.md:1
-msgid "# Copying and Cloning"
-msgstr "# ๋ณต์ฌ(copy)์ ๋ณต์ (clone)"
+#: src/ownership/moves-function-calls.md:24
+msgid ""
+"Rust makes it harder than C++ to inadvertently create copies by making move "
+"semantics the default, and by forcing programmers to make clones explicit."
+msgstr ""
+"๋ฌ์คํธ๋ ์ด๋์ ๊ธฐ๋ณธ์ผ๋ก ํ๊ณ ๋ณต์ ๋ฅผ ๋ช ์์ ์ผ๋ก ์ ์ธํ๋๋ก ๋ง๋ฌ์ผ๋ก, ์๋์น "
+"์๊ฒ ๋ณต์ฌ๋ณธ์ ๋ง๋๋ ๊ฒ์ด C++์์๋ณด๋ค ์ด๋ ต์ต๋๋ค."
#: src/ownership/copy-clone.md:3
-msgid "While move semantics are the default, certain types are copied by default:"
+msgid ""
+"While move semantics are the default, certain types are copied by default:"
msgstr "์ด๋์ด ๊ธฐ๋ณธ ์ค์ ์ด์ง๋ง, ํน์ ํ์ ์ ๋ณต์ฌ๋ฉ๋๋ค:"
#: src/ownership/copy-clone.md:5
@@ -4313,12 +5097,12 @@ msgstr ""
"```"
#: src/ownership/copy-clone.md:30
-msgid ""
-"* After the assignment, both `p1` and `p2` own their own data.\n"
-"* We can also use `p1.clone()` to explicitly copy the data."
-msgstr ""
-"* ํ ๋น ํ, `p1`์ `p2`๋ ์์ ์ ๋ฐ์ดํฐ๋ฅผ ์์ ํฉ๋๋ค.\n"
-"* ๋ช ์์ ์ผ๋ก `p1.clone()`๋ฅผ ์ฌ์ฉํ์ฌ ๋ฐ์ดํฐ๋ฅผ ๋ณต์ฌํ ์ ์์ต๋๋ค."
+msgid "After the assignment, both `p1` and `p2` own their own data."
+msgstr "ํ ๋น ํ, `p1`์ `p2`๋ ์์ ์ ๋ฐ์ดํฐ๋ฅผ ์์ ํฉ๋๋ค."
+
+#: src/ownership/copy-clone.md:31
+msgid "We can also use `p1.clone()` to explicitly copy the data."
+msgstr "๋ช ์์ ์ผ๋ก `p1.clone()`๋ฅผ ์ฌ์ฉํ์ฌ ๋ฐ์ดํฐ๋ฅผ ๋ณต์ฌํ ์ ์์ต๋๋ค."
#: src/ownership/copy-clone.md:35
msgid "Copying and cloning are not the same thing:"
@@ -4326,15 +5110,30 @@ msgstr "๋ณต์ฌ(copy)์ ๋ณต์ (clone)๋ ๊ฐ์ง ์์ต๋๋ค:"
#: src/ownership/copy-clone.md:37
msgid ""
-"* Copying refers to bitwise copies of memory regions and does not work on arbitrary objects.\n"
-"* Copying does not allow for custom logic (unlike copy constructors in C++).\n"
-"* Cloning is a more general operation and also allows for custom behavior by implementing the `Clone` trait.\n"
-"* Copying does not work on types that implement the `Drop` trait."
+"Copying refers to bitwise copies of memory regions and does not work on "
+"arbitrary objects."
+msgstr ""
+"๋ณต์ฌ๋ ๋ฉ๋ชจ๋ฆฌ์ ๋ด์ฉ์ ๊ทธ๋๋ก ํ ๋ฒ ๋ ๋ง๋๋ ๊ฒ์ ์๋ฏธํ๋ฉฐ, ์๋ฌด ๊ฐ์ฒด์์๋ "
+"๋ค ์ง์ํ์ง๋ ์์ต๋๋ค."
+
+#: src/ownership/copy-clone.md:38
+msgid ""
+"Copying does not allow for custom logic (unlike copy constructors in C++)."
+msgstr ""
+"๋ณต์ฌ๋ ์ปค์คํฐ๋ง์ด์ฆ ํ ์ ์์ต๋๋ค. (C++์์ ๋ณต์ฌ ์์ฑ์๋ฅผ ํตํด ๋ณต์ฌ ๋์์ "
+"์์๋ก ๊ตฌํํ ์ ์๋ ๊ฒ๊ณผ ๋น๊ต๊ฐ ๋ฉ๋๋ค.)"
+
+#: src/ownership/copy-clone.md:39
+msgid ""
+"Cloning is a more general operation and also allows for custom behavior by "
+"implementing the `Clone` trait."
msgstr ""
-"* ๋ณต์ฌ๋ ๋ฉ๋ชจ๋ฆฌ์ ๋ด์ฉ์ ๊ทธ๋๋ก ํ ๋ฒ ๋ ๋ง๋๋ ๊ฒ์ ์๋ฏธํ๋ฉฐ, ์๋ฌด ๊ฐ์ฒด์์๋ ๋ค ์ง์ํ์ง๋ ์์ต๋๋ค.\n"
-"* ๋ณต์ฌ๋ ์ปค์คํฐ๋ง์ด์ฆ ํ ์ ์์ต๋๋ค. (C++์์ ๋ณต์ฌ ์์ฑ์๋ฅผ ํตํด ๋ณต์ฌ ๋์์ ์์๋ก ๊ตฌํํ ์ ์๋ ๊ฒ๊ณผ ๋น๊ต๊ฐ ๋ฉ๋๋ค.)\n"
-"* ๋ณต์ ๋ ๋ณด๋ค ์ผ๋ฐ์ ์ธ ์์ ์ด๋ฉฐ, `Clone`ํธ๋ ์์ ๊ตฌํํ์ฌ ๋ณต์ ์ ๋์์ ์ปค์คํฐ๋ง์ด์ฆ ํ ์ ์์ต๋๋ค.\n"
-"* `Drop` ํธ๋ ์์ ๊ตฌํํ ํ์ ์ ๋ณต์ฌ๋์ง ์์ต๋๋ค."
+"๋ณต์ ๋ ๋ณด๋ค ์ผ๋ฐ์ ์ธ ์์ ์ด๋ฉฐ, `Clone`ํธ๋ ์์ ๊ตฌํํ์ฌ ๋ณต์ ์ ๋์์ ์ปค์คํฐ"
+"๋ง์ด์ฆ ํ ์ ์์ต๋๋ค."
+
+#: src/ownership/copy-clone.md:40
+msgid "Copying does not work on types that implement the `Drop` trait."
+msgstr "`Drop` ํธ๋ ์์ ๊ตฌํํ ํ์ ์ ๋ณต์ฌ๋์ง ์์ต๋๋ค."
#: src/ownership/copy-clone.md:42 src/ownership/lifetimes-function-calls.md:29
msgid "In the above example, try the following:"
@@ -4342,29 +5141,40 @@ msgstr "์์ ์์์์ ๋ค์์ ์๋ํด ๋ณด์๊ธฐ ๋ฐ๋๋๋ค:"
#: src/ownership/copy-clone.md:44
msgid ""
-"* Add a `String` field to `struct Point`. It will not compile because `String` is not a `Copy` type.\n"
-"* Remove `Copy` from the `derive` attribute. The compiler error is now in the `println!` for `p1`.\n"
-"* Show that it works if you clone `p1` instead."
+"Add a `String` field to `struct Point`. It will not compile because `String` "
+"is not a `Copy` type."
msgstr ""
-"* `Point`๊ตฌ์กฐ์ฒด์ `String`ํ๋๋ฅผ ์ถ๊ฐํ์ธ์. ์ปดํ์ผ ๋์ง ์์ ๊ฒ์ ๋๋ค. ์๋ํ๋ฉด `String`์ `Copy`ํธ๋ ์์ ๊ตฌํํ๊ณ ์์ง ์๊ธฐ ๋๋ฌธ์ ๋๋ค.\n"
-"* `derive` ์์ฑ์์ `Copy`๋ฅผ ์ ๊ฑฐํด ๋ณด์ธ์. `p1`์ `println!` ํ ๋ ์ปดํ์ผ ์๋ฌ๊ฐ ๋ฐ์ํ ๊ฒ์ ๋๋ค.\n"
-"* `p1`์ ๋ณต์ ํ๋ฉด ์ ๋์ํจ์ ํ์ธํด ๋ณด์ธ์."
+"`Point`๊ตฌ์กฐ์ฒด์ `String`ํ๋๋ฅผ ์ถ๊ฐํ์ธ์. ์ปดํ์ผ ๋์ง ์์ ๊ฒ์ ๋๋ค. ์๋ํ"
+"๋ฉด `String`์ `Copy`ํธ๋ ์์ ๊ตฌํํ๊ณ ์์ง ์๊ธฐ ๋๋ฌธ์ ๋๋ค."
-#: src/ownership/copy-clone.md:48
+#: src/ownership/copy-clone.md:45
msgid ""
-"If students ask about `derive`, it is sufficient to say that this is a way to generate code in Rust\n"
-"at compile time. In this case the default implementations of `Copy` and `Clone` traits are generated."
-msgstr "๋ง์ฝ ํ์๋ค์ด `derive`์ ๋ํด ๋ฌป๋๋ค๋ฉด, ์ปดํ์ผ ์ ๋ฌ์คํธ์์ ์ฝ๋๋ฅผ ์์ฑํ๋๋ฐฉ๋ฒ์ด๋ผ๊ณ ๋งํ๋ ๊ฒ์ผ๋ก ์ถฉ๋ถํฉ๋๋ค. ์ ๊ฒฝ์ฐ `Copy`์ `Clone` ํธ๋ ์์ ๋ํ ๊ธฐ๋ณธ ๊ตฌํ์ด ์์ฑ๋ฉ๋๋ค."
+"Remove `Copy` from the `derive` attribute. The compiler error is now in the "
+"`println!` for `p1`."
+msgstr ""
+"`derive` ์์ฑ์์ `Copy`๋ฅผ ์ ๊ฑฐํด ๋ณด์ธ์. `p1`์ `println!` ํ ๋ ์ปดํ์ผ ์๋ฌ"
+"๊ฐ ๋ฐ์ํ ๊ฒ์ ๋๋ค."
+
+#: src/ownership/copy-clone.md:46
+msgid "Show that it works if you clone `p1` instead."
+msgstr "`p1`์ ๋ณต์ ํ๋ฉด ์ ๋์ํจ์ ํ์ธํด ๋ณด์ธ์."
-#: src/ownership/borrowing.md:1
-msgid "# Borrowing"
-msgstr "# ๋น๋ฆผ(Borrowing)"
+#: src/ownership/copy-clone.md:48
+msgid ""
+"If students ask about `derive`, it is sufficient to say that this is a way "
+"to generate code in Rust at compile time. In this case the default "
+"implementations of `Copy` and `Clone` traits are generated."
+msgstr ""
+"๋ง์ฝ ํ์๋ค์ด `derive`์ ๋ํด ๋ฌป๋๋ค๋ฉด, ์ปดํ์ผ ์ ๋ฌ์คํธ์์ ์ฝ๋๋ฅผ ์์ฑํ๋"
+"๋ฐฉ๋ฒ์ด๋ผ๊ณ ๋งํ๋ ๊ฒ์ผ๋ก ์ถฉ๋ถํฉ๋๋ค. ์ ๊ฒฝ์ฐ `Copy`์ `Clone` ํธ๋ ์์ ๋ํ "
+"๊ธฐ๋ณธ ๊ตฌํ์ด ์์ฑ๋ฉ๋๋ค."
#: src/ownership/borrowing.md:3
msgid ""
-"Instead of transferring ownership when calling a function, you can let a\n"
+"Instead of transferring ownership when calling a function, you can let a "
"function _borrow_ the value:"
-msgstr "ํจ์ ํธ์ถ์ ๊ฐ์ ์์ ๊ถ์ ์ด๋ํ๋ ๋์ ์ ํจ์๊ฐ ๊ฐ์ *๋น๋ ค์ฌ ์* ์์ต๋๋ค:"
+msgstr ""
+"ํจ์ ํธ์ถ์ ๊ฐ์ ์์ ๊ถ์ ์ด๋ํ๋ ๋์ ์ ํจ์๊ฐ ๊ฐ์ _๋น๋ ค์ฌ ์_ ์์ต๋๋ค:"
#: src/ownership/borrowing.md:6
msgid ""
@@ -4401,12 +5211,14 @@ msgstr ""
"```"
#: src/ownership/borrowing.md:22
-msgid ""
-"* The `add` function _borrows_ two points and returns a new point.\n"
-"* The caller retains ownership of the inputs."
+msgid "The `add` function _borrows_ two points and returns a new point."
msgstr ""
-"* `add` ํจ์๋ ๋ `Point` ๊ฐ์ฒด ๊ฐ์ _๋น๋ ค_์์ ์๋ก์ด `Point` ๊ฐ์ฒด๋ฅผ ๋ฐํํฉ๋๋ค.\n"
-"* `p1`๊ณผ `p2`์ ์์ ๊ถ์ ์ฌ์ ํ ํธ์ถ์(`main`ํจ์)์ ์์ต๋๋ค."
+"`add` ํจ์๋ ๋ `Point` ๊ฐ์ฒด ๊ฐ์ \\_๋น๋ ค_์์ ์๋ก์ด `Point` ๊ฐ์ฒด๋ฅผ ๋ฐํํฉ๋"
+"๋ค."
+
+#: src/ownership/borrowing.md:23
+msgid "The caller retains ownership of the inputs."
+msgstr "`p1`๊ณผ `p2`์ ์์ ๊ถ์ ์ฌ์ ํ ํธ์ถ์(`main`ํจ์)์ ์์ต๋๋ค."
#: src/ownership/borrowing.md:27
msgid "Notes on stack returns:"
@@ -4414,67 +5226,84 @@ msgstr "์คํ์ ํ ๋น๋ ๊ฐ์ ๋ฆฌํดํ๋ ๊ฒ์ ๋ํ ์ฐธ๊ณ :"
#: src/ownership/borrowing.md:28
msgid ""
-"* Demonstrate that the return from `add` is cheap because the compiler can eliminate the copy operation. Change the above code to print stack addresses and run it on the [Playground]. In the \"DEBUG\" optimization level, the addresses should change, while they stay the same when changing to the \"RELEASE\" setting:\n"
-"\n"
-" ```rust,editable\n"
-" #[derive(Debug)]\n"
-" struct Point(i32, i32);\n"
-"\n"
-" fn add(p1: &Point, p2: &Point) -> Point {\n"
-" let p = Point(p1.0 + p2.0, p1.1 + p2.1);\n"
-" println!(\"&p.0: {:p}\", &p.0);\n"
-" p\n"
-" }\n"
-"\n"
-" fn main() {\n"
-" let p1 = Point(3, 4);\n"
-" let p2 = Point(10, 20);\n"
-" let p3 = add(&p1, &p2);\n"
-" println!(\"&p3.0: {:p}\", &p3.0);\n"
-" println!(\"{p1:?} + {p2:?} = {p3:?}\");\n"
-" }\n"
-" ```\n"
-"* The Rust compiler can do return value optimization (RVO).\n"
-"* In C++, copy elision has to be defined in the language specification because constructors can have side effects. In Rust, this is not an issue at all. If RVO did not happen, Rust will always performs a simple and efficient `memcpy` copy."
-msgstr ""
-"* `add`์์ ๊ฐ์ ๋ฐํํ๋ ๊ฒ์ ๋งค์ฐ ๊ฐ์ด ์ธ๋ค๋ ๊ฒ์ ์ค๋ช ํ์ธ์. ์๋ํ๋ฉด, ์ปดํ์ผ๋ฌ๊ฐ ๋ณต์ฌ ๊ณผ์ ์ ์๋ตํ ์ ์๊ธฐ ๋๋ฌธ์ ๋๋ค. ์ ์ฝ๋๋ฅผ ์คํ ์ฃผ์๋ฅผ ์ถ๋ ฅํ๋๋ก ์์ ํ๊ณ [Playground]์์ ์ํํด ๋ณด์ธ์. \\\"๋๋ฒ๊ทธ\\\" ์ต์ ํ ๋ ๋ฒจ์์๋ ์ฃผ์๊ฐ ๋ฐ๋์ง๋ง, \\\"๋ฆด๋ฆฌ์ฆ\\\" ๋ ๋ฒจ์์๋ ๋ฐ๋์ง ์์ต๋๋ค:\n"
-"\n"
-" ```rust,editable\n"
-" #[derive(Debug)]\n"
-" struct Point(i32, i32);\n"
-"\n"
-" fn add(p1: &Point, p2: &Point) -> Point {\n"
-" let p = Point(p1.0 + p2.0, p1.1 + p2.1);\n"
-" println!(\"&p.0: {:p}\", &p.0);\n"
-" p\n"
-" }\n"
-"\n"
-" fn main() {\n"
-" let p1 = Point(3, 4);\n"
-" let p2 = Point(10, 20);\n"
-" let p3 = add(&p1, &p2);\n"
-" println!(\"&p3.0: {:p}\", &p3.0);\n"
-" println!(\"{p1:?} + {p2:?} = {p3:?}\");\n"
-" }\n"
-" ```\n"
-"* ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ๋ฐํ๊ฐ ์ต์ ํ(RVO)๋ฅผ ์ํํ ์ ์์ต๋๋ค.\n"
-"* C++์์ copy elision์ ์์ฑ์์ ๋ถ์ํจ๊ณผ ๊ฐ๋ฅ์ฑ์ด ์์ด ์ธ์ด๋ ๋ฒจ์ ์ ์๊ฐ ํ์ํ์ง๋ง ๋ฌ์คํธ์์๋ ๋ฌธ์ ๊ฐ ๋์ง ์์ต๋๋ค. ๋ง์ฝ RVO๊ฐ ๋ฐ์ํ์ง ์์ผ๋ฉด ๋ฌ์คํธ๋ ํญ์ ๊ฐ๋จํ๊ณ ํจ์จ์ ์ธ `memcpy`๋ณต์ฌ๋ฅผ ์ํํ ๊ฒ์ ๋๋ค."
-
-#: src/ownership/shared-unique-borrows.md:1
-msgid "# Shared and Unique Borrows"
-msgstr "# ๊ณต์ ์ ๊ณ ์ ๋น๋ฆผ"
+"Demonstrate that the return from `add` is cheap because the compiler can "
+"eliminate the copy operation. Change the above code to print stack addresses "
+"and run it on the [Playground](https://play.rust-lang.org/). In the "
+"\"DEBUG\" optimization level, the addresses should change, while they stay "
+"the same when changing to the \"RELEASE\" setting:"
+msgstr ""
+"`add`์์ ๊ฐ์ ๋ฐํํ๋ ๊ฒ์ ๋งค์ฐ ๊ฐ์ด ์ธ๋ค๋ ๊ฒ์ ์ค๋ช ํ์ธ์. ์๋ํ๋ฉด, ์ปดํ"
+"์ผ๋ฌ๊ฐ ๋ณต์ฌ ๊ณผ์ ์ ์๋ตํ ์ ์๊ธฐ ๋๋ฌธ์ ๋๋ค. ์ ์ฝ๋๋ฅผ ์คํ ์ฃผ์๋ฅผ ์ถ๋ ฅํ๋"
+"๋ก ์์ ํ๊ณ [Playground](https://play.rust-lang.org/)์์ ์ํํด ๋ณด์ธ์. \"๋"
+"๋ฒ๊ทธ\" ์ต์ ํ ๋ ๋ฒจ์์๋ ์ฃผ์๊ฐ ๋ฐ๋์ง๋ง, \"๋ฆด๋ฆฌ์ฆ\" ๋ ๋ฒจ์์๋ ๋ฐ๋์ง ์์ต๋"
+"๋ค:"
+
+#: src/ownership/borrowing.md:30
+msgid ""
+"```rust,editable\n"
+"#[derive(Debug)]\n"
+"struct Point(i32, i32);\n"
+"\n"
+"fn add(p1: &Point, p2: &Point) -> Point {\n"
+" let p = Point(p1.0 + p2.0, p1.1 + p2.1);\n"
+" println!(\"&p.0: {:p}\", &p.0);\n"
+" p\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" let p1 = Point(3, 4);\n"
+" let p2 = Point(10, 20);\n"
+" let p3 = add(&p1, &p2);\n"
+" println!(\"&p3.0: {:p}\", &p3.0);\n"
+" println!(\"{p1:?} + {p2:?} = {p3:?}\");\n"
+"}\n"
+"```"
+msgstr ""
+"```rust,editable\n"
+"#[derive(Debug)]\n"
+"struct Point(i32, i32);\n"
+"\n"
+"fn add(p1: &Point, p2: &Point) -> Point {\n"
+" let p = Point(p1.0 + p2.0, p1.1 + p2.1);\n"
+" println!(\"&p.0: {:p}\", &p.0);\n"
+" p\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" let p1 = Point(3, 4);\n"
+" let p2 = Point(10, 20);\n"
+" let p3 = add(&p1, &p2);\n"
+" println!(\"&p3.0: {:p}\", &p3.0);\n"
+" println!(\"{p1:?} + {p2:?} = {p3:?}\");\n"
+"}\n"
+"```"
+
+#: src/ownership/borrowing.md:48
+msgid "The Rust compiler can do return value optimization (RVO)."
+msgstr "๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ๋ฐํ๊ฐ ์ต์ ํ(RVO)๋ฅผ ์ํํ ์ ์์ต๋๋ค."
+
+#: src/ownership/borrowing.md:49
+msgid ""
+"In C++, copy elision has to be defined in the language specification because "
+"constructors can have side effects. In Rust, this is not an issue at all. If "
+"RVO did not happen, Rust will always performs a simple and efficient "
+"`memcpy` copy."
+msgstr ""
+"C++์์ copy elision์ ์์ฑ์์ ๋ถ์ํจ๊ณผ ๊ฐ๋ฅ์ฑ์ด ์์ด ์ธ์ด๋ ๋ฒจ์ ์ ์๊ฐ ํ์"
+"ํ์ง๋ง ๋ฌ์คํธ์์๋ ๋ฌธ์ ๊ฐ ๋์ง ์์ต๋๋ค. ๋ง์ฝ RVO๊ฐ ๋ฐ์ํ์ง ์์ผ๋ฉด ๋ฌ์คํธ"
+"๋ ํญ์ ๊ฐ๋จํ๊ณ ํจ์จ์ ์ธ `memcpy`๋ณต์ฌ๋ฅผ ์ํํ ๊ฒ์ ๋๋ค."
#: src/ownership/shared-unique-borrows.md:3
msgid "Rust puts constraints on the ways you can borrow values:"
msgstr "๋ฌ์คํธ์์๋ ๊ฐ์ ๋น๋ฆด ๋ ๋ค์๊ณผ ๊ฐ์ ์ ์ฝ์กฐ๊ฑด์ด ์์ต๋๋ค:"
#: src/ownership/shared-unique-borrows.md:5
-msgid ""
-"* You can have one or more `&T` values at any given time, _or_\n"
-"* You can have exactly one `&mut T` value."
-msgstr ""
-"* ํ๋ฒ์ ํ๋ ์ด์์ `&T` ๊ฐ์ ๊ฐ์ง๊ฑฐ๋, _๋๋_\n"
-"* ์ ํํ ํ๋์ `&mut T` ๊ฐ๋ง์ ๊ฐ์ง ์ ์์ต๋๋ค."
+msgid "You can have one or more `&T` values at any given time, _or_"
+msgstr "ํ๋ฒ์ ํ๋ ์ด์์ `&T` ๊ฐ์ ๊ฐ์ง๊ฑฐ๋, _๋๋_"
+
+#: src/ownership/shared-unique-borrows.md:6
+msgid "You can have exactly one `&mut T` value."
+msgstr "์ ํํ ํ๋์ `&mut T` ๊ฐ๋ง์ ๊ฐ์ง ์ ์์ต๋๋ค."
#: src/ownership/shared-unique-borrows.md:8
msgid ""
@@ -4509,47 +5338,80 @@ msgstr ""
"```"
#: src/ownership/shared-unique-borrows.md:25
+#, fuzzy
msgid ""
-"* The above code does not compile because `a` is borrowed as mutable (through `c`) and as immutable (through `b`) at the same time.\n"
-"* Move the `println!` statement for `b` before the scope that introduces `c` to make the code compile.\n"
-"* After that change, the compiler realizes that `b` is only ever used before the new mutable borrow of `a` through `c`. This is a feature of the borrow checker called \"non-lexical lifetimes\"."
+"The above code does not compile because `a` is borrowed as mutable (through "
+"`c`) and as immutable (through `b`) at the same time."
msgstr ""
-"* ์ ์ฝ๋ ์ปดํ์ผ ๋์ง ์์ต๋๋ค. ์๋ํ๋ฉด `c`๋ `a`๋ฅผ ๊ฐ๋ณ ๋ณ์๋ก ๋น๋ ธ๊ณ , ์ด์ ๋์์ `b`๋ `a`๋ฅผ ๋ถ๋ณ ๋ณ์๋ก ๋น๋ ธ๊ธฐ ๋๋ฌธ์ ๋๋ค.\n"
-"* `b`์ ๋ํ `println!` ๊ตฌ๋ถ์ `c`๊ฐ ์๋ ์ค์ฝํ ์์ผ๋ก ์ด๋ํ๋ฉด ์ปดํ์ผ์ด ๋ฉ๋๋ค.\n"
-"* ์ด๋ ๊ฒ ๋ฐ๊พธ๋ฉด, ์ปดํ์ผ๋ฌ๋ `c`๊ฐ `a`๋ฅผ ๊ฐ๋ณ ๋ณ์๋ก ๋น๋ฆฌ๊ธฐ ์ ์๋ง `b`๊ฐ ์ฌ์ฉ๋๋ค๋ ๊ฒ์ ํ์ธํ ์ ์์ต๋๋ค. ๋น๋ฆผ ๊ฒ์ฌ๊ธฐ์ ์ด๋ฌํ ๊ธฐ๋ฅ์ \"non-lexical lifetime\" ์ด๋ผ๊ณ ํฉ๋๋ค.\n"
-" * ๋จ์ํ ์ค์ฝํ๋ง ๋ณด๋ฉด `b`์ ์๋ช ์ `main`ํจ์์ ์ ์ฒด๋ผ๊ณ ์๊ฐํ ์ ์์ต๋๋ค. ๋๋ฌธ์ `c`์ ๋ธ๋ก ์์์๋ `a`์ ๋ํ ๊ฐ๋ณ ๋น๋ฆผ๊ณผ ๋ถ๋ณ ๋น๋ฆผ์ด ๋์์ ์กด์ฌํ๋ ๊ฒ ์ฒ๋ผ ๋ณด์ด๋ฉฐ, ์ด๋ ์ ์ ์ฝ ์กฐ๊ฑด์ ์๋ฐํ๋ ๊ฒ์ผ๋ก ์๊ฐํ ์ ์์ต๋๋ค. ๊ทธ๋ฌ๋ ์ปดํ์ผ๋ฌ๋ `b`๊ฐ `c`๋ธ๋ก์ด ์์๋๊ธฐ ์ ์๋ง ์ฌ์ฉ๋๋ค๋ ์ ์ ์ ๊ทน ํ์ฉํด์ `b`์ ์๋ช ์ `c`๋ธ๋ก์ ์์ ์ ๊น์ง๋ก ์ค์ ๋๋ค. ๊ทธ๋ฌ๋ฉด `b`์ `c`์ ์๋ช ์ ๊ฒน์น์ง ์๊ณ , ๋ฐ๋ผ์ ์ ์ฝ ์กฐ๊ฑด์ ์๋ฐํ์ง ์์ต๋๋ค."
+"์ ์ฝ๋ ์ปดํ์ผ ๋์ง ์์ต๋๋ค. ์๋ํ๋ฉด `c`๋ `a`๋ฅผ ๊ฐ๋ณ ๋ณ์๋ก ๋น๋ ธ๊ณ , ์ด์ "
+"๋์์ `b`๋ `a`๋ฅผ ๋ถ๋ณ ๋ณ์๋ก ๋น๋ ธ๊ธฐ ๋๋ฌธ์ ๋๋ค."
+
+#: src/ownership/shared-unique-borrows.md:26
+#, fuzzy
+msgid ""
+"Move the `println!` statement for `b` before the scope that introduces `c` "
+"to make the code compile."
+msgstr ""
+"`b`์ ๋ํ `println!` ๊ตฌ๋ถ์ `c`๊ฐ ์๋ ์ค์ฝํ ์์ผ๋ก ์ด๋ํ๋ฉด ์ปดํ์ผ์ด ๋ฉ๋"
+"๋ค."
-#: src/ownership/lifetimes.md:1
-msgid "# Lifetimes"
-msgstr "# ์๋ช "
+#: src/ownership/shared-unique-borrows.md:27
+#, fuzzy
+msgid ""
+"After that change, the compiler realizes that `b` is only ever used before "
+"the new mutable borrow of `a` through `c`. This is a feature of the borrow "
+"checker called \"non-lexical lifetimes\"."
+msgstr ""
+"์ด๋ ๊ฒ ๋ฐ๊พธ๋ฉด, ์ปดํ์ผ๋ฌ๋ `c`๊ฐ `a`๋ฅผ ๊ฐ๋ณ ๋ณ์๋ก ๋น๋ฆฌ๊ธฐ ์ ์๋ง `b`๊ฐ ์ฌ์ฉ๋"
+"๋ค๋ ๊ฒ์ ํ์ธํ ์ ์์ต๋๋ค. ๋น๋ฆผ ๊ฒ์ฌ๊ธฐ์ ์ด๋ฌํ ๊ธฐ๋ฅ์ \"non-lexical "
+"lifetime\" ์ด๋ผ๊ณ ํฉ๋๋ค.\n"
+"\n"
+"๋จ์ํ ์ค์ฝํ๋ง ๋ณด๋ฉด `b`์ ์๋ช ์ `main`ํจ์์ ์ ์ฒด๋ผ๊ณ ์๊ฐํ ์ ์์ต๋๋ค. "
+"๋๋ฌธ์ `c`์ ๋ธ๋ก ์์์๋ `a`์ ๋ํ ๊ฐ๋ณ ๋น๋ฆผ๊ณผ ๋ถ๋ณ ๋น๋ฆผ์ด ๋์์ ์กด์ฌํ"
+"๋ ๊ฒ ์ฒ๋ผ ๋ณด์ด๋ฉฐ, ์ด๋ ์ ์ ์ฝ ์กฐ๊ฑด์ ์๋ฐํ๋ ๊ฒ์ผ๋ก ์๊ฐํ ์ ์์ต๋๋ค. ๊ทธ"
+"๋ฌ๋ ์ปดํ์ผ๋ฌ๋ `b`๊ฐ `c`๋ธ๋ก์ด ์์๋๊ธฐ ์ ์๋ง ์ฌ์ฉ๋๋ค๋ ์ ์ ์ ๊ทน ํ์ฉํด"
+"์ `b`์ ์๋ช ์ `c`๋ธ๋ก์ ์์ ์ ๊น์ง๋ก ์ค์ ๋๋ค. ๊ทธ๋ฌ๋ฉด `b`์ `c`์ ์๋ช ์ "
+"๊ฒน์น์ง ์๊ณ , ๋ฐ๋ผ์ ์ ์ฝ ์กฐ๊ฑด์ ์๋ฐํ์ง ์์ต๋๋ค."
#: src/ownership/lifetimes.md:3
msgid "A borrowed value has a _lifetime_:"
-msgstr "๋น๋ ค์จ ๊ฐ์ *์๋ช *์ ๊ฐ์ต๋๋ค:"
+msgstr "๋น๋ ค์จ ๊ฐ์ _์๋ช _์ ๊ฐ์ต๋๋ค:"
#: src/ownership/lifetimes.md:5
+msgid "The lifetime can be elided: `add(p1: &Point, p2: &Point) -> Point`."
+msgstr "์๋ช ์ ์๋ตํ ์ ์์ต๋๋ค: `add(p1: &Point, p2: &Point) -> Point`."
+
+#: src/ownership/lifetimes.md:6
+msgid "Lifetimes can also be explicit: `&'a Point`, `&'document str`."
+msgstr "๋ฌผ๋ก ๋ช ์ํ ์๋ ์์ต๋๋ค: `&'a Point`, `&'document str`."
+
+#: src/ownership/lifetimes.md:7 src/ownership/lifetimes-function-calls.md:23
+msgid ""
+"Read `&'a Point` as \"a borrowed `Point` which is valid for at least the "
+"lifetime `a`\"."
+msgstr ""
+"`&'a Point` ๋ `Point`์ ์๋ช ์ด ์ต์ํ `'a`๋ผ๋ ์๋ช ๋ณด๋ค๋ ๊ฐ๊ฑฐ๋ ๋ ๊ธธ๋ค๋ "
+"๊ฒ์ ์๋ฏธํฉ๋๋ค."
+
+#: src/ownership/lifetimes.md:9
msgid ""
-"* The lifetime can be elided: `add(p1: &Point, p2: &Point) -> Point`.\n"
-"* Lifetimes can also be explicit: `&'a Point`, `&'document str`.\n"
-"* Read `&'a Point` as \"a borrowed `Point` which is valid for at least the\n"
-" lifetime `a`\".\n"
-"* Lifetimes are always inferred by the compiler: you cannot assign a lifetime\n"
-" yourself.\n"
-" * Lifetime annotations create constraints; the compiler verifies that there is\n"
-" a valid solution."
-msgstr ""
-"* ์๋ช ์ ์๋ตํ ์ ์์ต๋๋ค: `add(p1: &Point, p2: &Point) -> Point`.\n"
-"* ๋ฌผ๋ก ๋ช ์ํ ์๋ ์์ต๋๋ค: `&'a Point`, `&'document str`.\n"
-"* `&'a Point` ๋ `Point`์ ์๋ช ์ด ์ต์ํ `'a`๋ผ๋ ์๋ช ๋ณด๋ค๋ ๊ฐ๊ฑฐ๋ ๋ ๊ธธ๋ค๋ ๊ฒ์ ์๋ฏธํฉ๋๋ค.\n"
-"* ์๋ช ์ ํญ์ ์ปดํ์ผ๋ฌ๊ฐ ์๋์ผ๋ก ์ถ๋ก ํฉ๋๋ค. ์ง์ ์๋ช ์ ์ง์ ํ ์๋ ์์ต๋๋ค.\n"
-" * ์๋ช ํ๊ธฐ(`'`)์ ์๋ช ์ถ๋ก ์ ์ ์ฝ์กฐ๊ฑด์ด ๋ฉ๋๋ค. ์ปดํ์ผ๋ฌ๋ ์ด ์ ์ฝ์กฐ๊ฑด์ ๋ง์กฑ์ํค๋ ์ ์ํ ์๋ช ์ ์ถ๋ก ํ ์ ์๋์ง ๊ฒ์ฌ๋ฅผ ํฉ๋๋ค."
-
-#: src/ownership/lifetimes-function-calls.md:1
-msgid "# Lifetimes in Function Calls"
-msgstr "# ํจ์ ํธ์ถ์์์ ์๋ช "
+"Lifetimes are always inferred by the compiler: you cannot assign a lifetime "
+"yourself."
+msgstr ""
+"์๋ช ์ ํญ์ ์ปดํ์ผ๋ฌ๊ฐ ์๋์ผ๋ก ์ถ๋ก ํฉ๋๋ค. ์ง์ ์๋ช ์ ์ง์ ํ ์๋ ์์ต๋๋ค."
+
+#: src/ownership/lifetimes.md:11
+msgid ""
+"Lifetime annotations create constraints; the compiler verifies that there is "
+"a valid solution."
+msgstr ""
+"์๋ช ํ๊ธฐ(`'`)์ ์๋ช ์ถ๋ก ์ ์ ์ฝ์กฐ๊ฑด์ด ๋ฉ๋๋ค. ์ปดํ์ผ๋ฌ๋ ์ด ์ ์ฝ์กฐ๊ฑด์ ๋ง์กฑ"
+"์ํค๋ ์ ์ํ ์๋ช ์ ์ถ๋ก ํ ์ ์๋์ง ๊ฒ์ฌ๋ฅผ ํฉ๋๋ค."
#: src/ownership/lifetimes-function-calls.md:3
-msgid "In addition to borrowing its arguments, a function can return a borrowed value:"
+msgid ""
+"In addition to borrowing its arguments, a function can return a borrowed "
+"value:"
msgstr "ํจ์๋ ์ธ์๋ฅผ ๋น๋ฆฌ๋ ๊ฒ ์ธ์๋ ๋น๋ฆฐ ๊ฐ์ ๋ฐํํ ์ ์์ต๋๋ค:"
#: src/ownership/lifetimes-function-calls.md:5
@@ -4587,83 +5449,113 @@ msgstr ""
"```"
#: src/ownership/lifetimes-function-calls.md:21
+msgid "`'a` is a generic parameter, it is inferred by the compiler."
+msgstr "`'a`๋ ์ ๋ค๋ฆญ ๋งค๊ฐ๋ณ์๋ก ์ปดํ์ผ๋ฌ๋ก์ ์ํด ์ถ๋ก ๋ฉ๋๋ค."
+
+#: src/ownership/lifetimes-function-calls.md:22
+msgid "Lifetimes start with `'` and `'a` is a typical default name."
+msgstr "์๋ช ์ ์ด๋ฆ์ `'` ๋ก ์์ํ๋ฉฐ ๋ณดํต `'a`๋ฅผ ๋ง์ด ์๋๋ค."
+
+#: src/ownership/lifetimes-function-calls.md:25
msgid ""
-"* `'a` is a generic parameter, it is inferred by the compiler.\n"
-"* Lifetimes start with `'` and `'a` is a typical default name.\n"
-"* Read `&'a Point` as \"a borrowed `Point` which is valid for at least the\n"
-" lifetime `a`\".\n"
-" * The _at least_ part is important when parameters are in different scopes."
+"The _at least_ part is important when parameters are in different scopes."
msgstr ""
-"* `'a`๋ ์ ๋ค๋ฆญ ๋งค๊ฐ๋ณ์๋ก ์ปดํ์ผ๋ฌ๋ก์ ์ํด ์ถ๋ก ๋ฉ๋๋ค.\n"
-"* ์๋ช ์ ์ด๋ฆ์ `'` ๋ก ์์ํ๋ฉฐ ๋ณดํต `'a`๋ฅผ ๋ง์ด ์๋๋ค.\n"
-"* `&'a Point` ๋ `Point`์ ์๋ช ์ด `'a` ์๋ช ๊ณผ ์ต์ํ ๊ฐ๊ฑฐ๋ ๋ ๊ธธ๋ค๋ ๊ฒ์ ์๋ฏธํฉ๋๋ค.\n"
-" * ๋งค๊ฐ๋ณ์๋ค์ด ์๋ก ๋ค๋ฅธ ์ค์ฝํ์ ์์ ๊ฒฝ์ฐ \"์ต์ํ\"์ด๋ผ๋ ์กฐ๊ฑด์ด ์ค์ํฉ๋๋ค."
+"๋งค๊ฐ๋ณ์๋ค์ด ์๋ก ๋ค๋ฅธ ์ค์ฝํ์ ์์ ๊ฒฝ์ฐ \"์ต์ํ\"์ด๋ผ๋ ์กฐ๊ฑด์ด ์ค์ํฉ๋๋ค."
#: src/ownership/lifetimes-function-calls.md:31
msgid ""
-"* Move the declaration of `p2` and `p3` into a a new scope (`{ ... }`), resulting in the following code:\n"
-" ```rust,ignore\n"
-" #[derive(Debug)]\n"
-" struct Point(i32, i32);\n"
-"\n"
-" fn left_most<'a>(p1: &'a Point, p2: &'a Point) -> &'a Point {\n"
-" if p1.0 < p2.0 { p1 } else { p2 }\n"
-" }\n"
-"\n"
-" fn main() {\n"
-" let p1: Point = Point(10, 10);\n"
-" let p3: &Point;\n"
-" {\n"
-" let p2: Point = Point(20, 20);\n"
-" p3 = left_most(&p1, &p2);\n"
-" }\n"
-" println!(\"left-most point: {:?}\", p3);\n"
-" }\n"
-" ```\n"
-" Note how this does not compile since `p3` outlives `p2`.\n"
-"\n"
-"* Reset the workspace and change the function signature to `fn left_most<'a, 'b>(p1: &'a Point, p2: &'a Point) -> &'b Point`. This will not compile because the relationship between the lifetimes `'a` and `'b` is unclear.\n"
-"* Another way to explain it:\n"
-" * Two references to two values are borrowed by a function and the function returns\n"
-" another reference.\n"
-" * It must have come from one of those two inputs (or from a global variable).\n"
-" * Which one is it? The compiler needs to to know, so at the call site the returned reference is not used\n"
-" for longer than a variable from where the reference came from."
-msgstr ""
-"* `p2`์ `p3`๋ฅผ ์๋ก์ด ๋ฒ์(`{...}`)๋ก ์๋ ์ฝ๋์ ๊ฐ์ด ์ด๋ํด ๋ด ๋๋ค:\n"
-" ```rust,ignore\n"
-" #[derive(Debug)]\n"
-" struct Point(i32, i32);\n"
-"\n"
-" fn left_most<'a>(p1: &'a Point, p2: &'a Point) -> &'a Point {\n"
-" if p1.0 < p2.0 { p1 } else { p2 }\n"
-" }\n"
-"\n"
-" fn main() {\n"
-" let p1: Point = Point(10, 10);\n"
-" let p3: &Point;\n"
-" {\n"
-" let p2: Point = Point(20, 20);\n"
-" p3 = left_most(&p1, &p2);\n"
-" }\n"
-" println!(\"left-most point: {:?}\", p3);\n"
-" }\n"
-" ```\n"
-" `p3`์ ์๋ช ์ด `p2` ๋ณด๋ค ๊ธธ๊ธฐ ๋๋ฌธ์ ์ด ์์ ๋ ์ปดํ์ผ๋์ง ์์์ ํ์ธํ์๊ธฐ ๋ฐ๋๋๋ค.\n"
-"\n"
-"* ์์ ๊ณต๊ฐ์ ์ด๊ธฐํ ํ ํ ํจ์ ์๊ทธ๋์ฒ๋ฅผ `fn left_most<'a, 'b>(p1: &'a Point, p2: &'a Point) -> &'b Point`๋ก ๋ณ๊ฒฝํด ๋ด ๋๋ค. ์ด ๊ฒฝ์ฐ `'a`์ `'b`์ฌ์ด์ ๊ด๊ณ๊ฐ ๋ถ๋ถ๋ช ํ๊ธฐ ๋๋ฌธ์ ์ปดํ์ผ ๋์ง ์์ต๋๋ค.\n"
-"* ์ด ์๋ฌ๋ฅผ ์ค๋ช ํ๋ ๋ ๋ค๋ฅธ ๋ฐฉ๋ฒ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค:\n"
-" * ์ด ํจ์๋ ๋ ๊ฐ์ ๋น๋ ค์, ์๋ก์ด ์ฐธ์กฐ๋ฅผ ๋ฐํํฉ๋๋ค.\n"
-" * ์ด ๋ฐํ๋ ์ฐธ์กฐ๋ ๋ ์ ๋ ฅ ์ค ํ๋๋ก ๋ถํฐ ์์ผ ํฉ๋๋ค. (์๋๋ฉด ์ ์ญ ๋ณ์๋ก ๋ถํฐ)\n"
-" * ๋ ์ ๋ ฅ ์ค ์ด๋ค ๊ฒ์ผ๊น์? ์ปดํ์ผ๋ฌ๋ ์ด๋ฅผ ์์์ผ ํฉ๋๋ค. ๊ทธ๋์ผ๋ง ํจ์ ํธ์ถ๋ถ์์ ๋ดค์ ๋, ๋ฐํ๋ ์ฐธ์กฐ์ ์๋ช ์ด ์๋ ๊ฐ์ ์๋ช ๋ณด๋ค ๊ธธ์ง ์์์ ํ์ธํ ์ ์๊ธฐ ๋๋ฌธ์ ๋๋ค."
-
-#: src/ownership/lifetimes-data-structures.md:1
-msgid "# Lifetimes in Data Structures"
-msgstr "# ๊ตฌ์กฐ์ฒด์์์ ์๋ช "
+"Move the declaration of `p2` and `p3` into a a new scope (`{ ... }`), "
+"resulting in the following code:"
+msgstr "`p2`์ `p3`๋ฅผ ์๋ก์ด ๋ฒ์(`{...}`)๋ก ์๋ ์ฝ๋์ ๊ฐ์ด ์ด๋ํด ๋ด ๋๋ค:"
+
+#: src/ownership/lifetimes-function-calls.md:32
+msgid ""
+"```rust,ignore\n"
+"#[derive(Debug)]\n"
+"struct Point(i32, i32);\n"
+"\n"
+"fn left_most<'a>(p1: &'a Point, p2: &'a Point) -> &'a Point {\n"
+" if p1.0 < p2.0 { p1 } else { p2 }\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" let p1: Point = Point(10, 10);\n"
+" let p3: &Point;\n"
+" {\n"
+" let p2: Point = Point(20, 20);\n"
+" p3 = left_most(&p1, &p2);\n"
+" }\n"
+" println!(\"left-most point: {:?}\", p3);\n"
+"}\n"
+"```"
+msgstr ""
+"```rust,ignore\n"
+"#[derive(Debug)]\n"
+"struct Point(i32, i32);\n"
+"\n"
+"fn left_most<'a>(p1: &'a Point, p2: &'a Point) -> &'a Point {\n"
+" if p1.0 < p2.0 { p1 } else { p2 }\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" let p1: Point = Point(10, 10);\n"
+" let p3: &Point;\n"
+" {\n"
+" let p2: Point = Point(20, 20);\n"
+" p3 = left_most(&p1, &p2);\n"
+" }\n"
+" println!(\"left-most point: {:?}\", p3);\n"
+"}\n"
+"```"
+
+#: src/ownership/lifetimes-function-calls.md:50
+msgid "Note how this does not compile since `p3` outlives `p2`."
+msgstr ""
+"`p3`์ ์๋ช ์ด `p2` ๋ณด๋ค ๊ธธ๊ธฐ ๋๋ฌธ์ ์ด ์์ ๋ ์ปดํ์ผ๋์ง ์์์ ํ์ธํ์๊ธฐ ๋ฐ"
+"๋๋๋ค."
+
+#: src/ownership/lifetimes-function-calls.md:52
+msgid ""
+"Reset the workspace and change the function signature to `fn left_most<'a, "
+"'b>(p1: &'a Point, p2: &'a Point) -> &'b Point`. This will not compile "
+"because the relationship between the lifetimes `'a` and `'b` is unclear."
+msgstr ""
+"์์ ๊ณต๊ฐ์ ์ด๊ธฐํ ํ ํ ํจ์ ์๊ทธ๋์ฒ๋ฅผ `fn left_most<'a, 'b>(p1: &'a Point, "
+"p2: &'a Point) -> &'b Point`๋ก ๋ณ๊ฒฝํด ๋ด ๋๋ค. ์ด ๊ฒฝ์ฐ `'a`์ `'b`์ฌ์ด์ ๊ด๊ณ"
+"๊ฐ ๋ถ๋ถ๋ช ํ๊ธฐ ๋๋ฌธ์ ์ปดํ์ผ ๋์ง ์์ต๋๋ค."
+
+#: src/ownership/lifetimes-function-calls.md:53
+msgid "Another way to explain it:"
+msgstr "์ด ์๋ฌ๋ฅผ ์ค๋ช ํ๋ ๋ ๋ค๋ฅธ ๋ฐฉ๋ฒ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค:"
+
+#: src/ownership/lifetimes-function-calls.md:54
+msgid ""
+"Two references to two values are borrowed by a function and the function "
+"returns another reference."
+msgstr "์ด ํจ์๋ ๋ ๊ฐ์ ๋น๋ ค์, ์๋ก์ด ์ฐธ์กฐ๋ฅผ ๋ฐํํฉ๋๋ค."
+
+#: src/ownership/lifetimes-function-calls.md:56
+msgid ""
+"It must have come from one of those two inputs (or from a global variable)."
+msgstr ""
+"์ด ๋ฐํ๋ ์ฐธ์กฐ๋ ๋ ์ ๋ ฅ ์ค ํ๋๋ก ๋ถํฐ ์์ผ ํฉ๋๋ค. (์๋๋ฉด ์ ์ญ ๋ณ์๋ก ๋ถ"
+"ํฐ)"
+
+#: src/ownership/lifetimes-function-calls.md:57
+msgid ""
+"Which one is it? The compiler needs to to know, so at the call site the "
+"returned reference is not used for longer than a variable from where the "
+"reference came from."
+msgstr ""
+"๋ ์ ๋ ฅ ์ค ์ด๋ค ๊ฒ์ผ๊น์? ์ปดํ์ผ๋ฌ๋ ์ด๋ฅผ ์์์ผ ํฉ๋๋ค. ๊ทธ๋์ผ๋ง ํจ์ ํธ์ถ๋ถ"
+"์์ ๋ดค์ ๋, ๋ฐํ๋ ์ฐธ์กฐ์ ์๋ช ์ด ์๋ ๊ฐ์ ์๋ช ๋ณด๋ค ๊ธธ์ง ์์์ ํ์ธํ ์ "
+"์๊ธฐ ๋๋ฌธ์ ๋๋ค."
#: src/ownership/lifetimes-data-structures.md:3
-msgid "If a data type stores borrowed data, it must be annotated with a lifetime:"
-msgstr "์ด๋ค ํ์ ์ด ๋น๋ ค์จ ๋ฐ์ดํฐ๋ฅผ ์ ์ฅํ๊ณ ์๋ค๋ฉด, ๋ฐ๋์ ์๋ช ์ ํ์ํด์ผ ํฉ๋๋ค:"
+msgid ""
+"If a data type stores borrowed data, it must be annotated with a lifetime:"
+msgstr ""
+"์ด๋ค ํ์ ์ด ๋น๋ ค์จ ๋ฐ์ดํฐ๋ฅผ ์ ์ฅํ๊ณ ์๋ค๋ฉด, ๋ฐ๋์ ์๋ช ์ ํ์ํด์ผ ํฉ๋๋ค:"
#: src/ownership/lifetimes-data-structures.md:5
msgid ""
@@ -4676,7 +5568,8 @@ msgid ""
"}\n"
"\n"
"fn main() {\n"
-" let text = String::from(\"The quick brown fox jumps over the lazy dog.\");\n"
+" let text = String::from(\"The quick brown fox jumps over the lazy dog."
+"\");\n"
" let fox = Highlight(&text[4..19]);\n"
" let dog = Highlight(&text[35..43]);\n"
" // erase(text);\n"
@@ -4706,45 +5599,72 @@ msgstr ""
#: src/ownership/lifetimes-data-structures.md:25
msgid ""
-"* In the above example, the annotation on `Highlight` enforces that the data underlying the contained `&str` lives at least as long as any instance of `Highlight` that uses that data.\n"
-"* If `text` is consumed before the end of the lifetime of `fox` (or `dog`), the borrow checker throws an error.\n"
-"* Types with borrowed data force users to hold on to the original data. This can be useful for creating lightweight views, but it generally makes them somewhat harder to use.\n"
-"* When possible, make data structures own their data directly.\n"
-"* Some structs with multiple references inside can have more than one lifetime annotation. This can be necessary if there is a need to describe lifetime relationships between the references themselves, in addition to the lifetime of the struct itself. Those are very advanced use cases."
+"In the above example, the annotation on `Highlight` enforces that the data "
+"underlying the contained `&str` lives at least as long as any instance of "
+"`Highlight` that uses that data."
+msgstr ""
+"์์ ์์ ์์ `Highlight`์ ์ด๋ ธํ ์ด์ (`<'doc>`)์ ์ ์ด๋ `Highlight` ์ธ์คํด"
+"์ค๊ฐ ์ด์์๋ ๋์์๋ ๊ทธ ๋ด๋ถ์ `&str`๊ฐ ๊ฐ๋ฆฌํค๋ ๋ฐ์ดํฐ ์ญ์ ์ด์์์ด์ผ ํ"
+"๋ค๋ ๊ฒ์ ์๋ฏธํฉ๋๋ค."
+
+#: src/ownership/lifetimes-data-structures.md:26
+msgid ""
+"If `text` is consumed before the end of the lifetime of `fox` (or `dog`), "
+"the borrow checker throws an error."
+msgstr ""
+"๋ง์ฝ `text`๊ฐ `fox` (ํน์ `dog`)์ ์๋ช ์ด ๋คํ๊ธฐ ์ ์ `erase`ํจ์ ํธ์ถ ๋ฑ์ผ"
+"๋ก ์ฌ๋ผ์ง๊ฒ ๋๋ค๋ฉด ๋น๋ฆผ ๊ฒ์ฌ๊ธฐ๊ฐ ์๋ฌ๋ฅผ ๋ฐ์ํฉ๋๋ค."
+
+#: src/ownership/lifetimes-data-structures.md:27
+msgid ""
+"Types with borrowed data force users to hold on to the original data. This "
+"can be useful for creating lightweight views, but it generally makes them "
+"somewhat harder to use."
msgstr ""
-"* ์์ ์์ ์์ `Highlight`์ ์ด๋ ธํ ์ด์ (`<'doc>`)์ ์ ์ด๋ `Highlight` ์ธ์คํด์ค๊ฐ ์ด์์๋ ๋์์๋ ๊ทธ ๋ด๋ถ์ `&str`๊ฐ ๊ฐ๋ฆฌํค๋ ๋ฐ์ดํฐ ์ญ์ ์ด์์์ด์ผ ํ๋ค๋ ๊ฒ์ ์๋ฏธํฉ๋๋ค.\n"
-"* ๋ง์ฝ `text`๊ฐ `fox` (ํน์ `dog`)์ ์๋ช ์ด ๋คํ๊ธฐ ์ ์ `erase`ํจ์ ํธ์ถ ๋ฑ์ผ๋ก ์ฌ๋ผ์ง๊ฒ ๋๋ค๋ฉด ๋น๋ฆผ ๊ฒ์ฌ๊ธฐ๊ฐ ์๋ฌ๋ฅผ ๋ฐ์ํฉ๋๋ค.\n"
-"* ๋น๋ฆฐ ๋ฐ์ดํฐ๋ฅผ ๊ฐ์ง๊ณ ์๋ ํ์ ์ ์ฌ์ฉ์๋ก ํ์ฌ๊ธ ์๋ณธ ๋ฐ์ดํฐ๋ฅผ ์ ์งํ๋๋ก ๊ฐ์ ํฉ๋๋ค. ์ด๋ฐ ํ์ ์ ๊ฒฝ๋ ๋ทฐ(lightweight view)๋ฅผ ๋ง๋๋๋ฐ ์ ์ฉํ์ง๋ง, ์ด ์ ์ฝ ์กฐ๊ฑด ๋๋ฌธ์ ์ด๋ฐ ํ์ ์ ์ฌ์ฉํ๋ ๊ฒ์ด ์ฝ์ง๋ง์ ์์ต๋๋ค.\n"
-"* ๋ฐ๋ผ์, ๊ฐ๋ฅํ๋ค๋ฉด, ๊ตฌ์กฐ์ฒด๊ฐ ์์ ์ ๋ฐ์ดํฐ๋ฅผ ์ง์ ์์ ํ๋๋ก ํ๋ ๊ฒ์ด ์ข์ต๋๋ค.\n"
-"* ํ ๊ตฌ์กฐ์ฒด์์ ์ฌ๋ฌ ์ฐธ์กฐ๊ฐ ์์ผ๋ฉด์, ์ด ์ฐธ์กฐ๋ค์ ์๋ช ์ด ์๋ก ๋ค๋ฅด๊ฒ ์ง์ ๋๋ ๊ฒฝ์ฐ๋ ์์ต๋๋ค. ์ด๋ ์ฐธ์กฐ์ ๊ทธ ๊ตฌ์กฐ์ฒด ๊ฐ์ ๊ด๊ณ ๋ฟ๋ง์ด ์๋๋ผ, ๊ทธ ์ฐธ์กฐ๋ค ์ฌ์ด์ ์๋ช ๊ด๊ณ๋ฅผ ์ค๋ช ํด์ผ ํ ๊ฒฝ์ฐ์ ํ์ํฉ๋๋ค. ๋งค์ฐ ๊ณ ๊ธ ๊ธฐ์ ์ ๋๋ค."
+"๋น๋ฆฐ ๋ฐ์ดํฐ๋ฅผ ๊ฐ์ง๊ณ ์๋ ํ์ ์ ์ฌ์ฉ์๋ก ํ์ฌ๊ธ ์๋ณธ ๋ฐ์ดํฐ๋ฅผ ์ ์งํ๋๋ก ๊ฐ"
+"์ ํฉ๋๋ค. ์ด๋ฐ ํ์ ์ ๊ฒฝ๋ ๋ทฐ(lightweight view)๋ฅผ ๋ง๋๋๋ฐ ์ ์ฉํ์ง๋ง, ์ด ์ "
+"์ฝ ์กฐ๊ฑด ๋๋ฌธ์ ์ด๋ฐ ํ์ ์ ์ฌ์ฉํ๋ ๊ฒ์ด ์ฝ์ง๋ง์ ์์ต๋๋ค."
+
+#: src/ownership/lifetimes-data-structures.md:28
+msgid "When possible, make data structures own their data directly."
+msgstr ""
+"๋ฐ๋ผ์, ๊ฐ๋ฅํ๋ค๋ฉด, ๊ตฌ์กฐ์ฒด๊ฐ ์์ ์ ๋ฐ์ดํฐ๋ฅผ ์ง์ ์์ ํ๋๋ก ํ๋ ๊ฒ์ด ์ข์ต๋"
+"๋ค."
+
+#: src/ownership/lifetimes-data-structures.md:29
+msgid ""
+"Some structs with multiple references inside can have more than one lifetime "
+"annotation. This can be necessary if there is a need to describe lifetime "
+"relationships between the references themselves, in addition to the lifetime "
+"of the struct itself. Those are very advanced use cases."
+msgstr ""
+"ํ ๊ตฌ์กฐ์ฒด์์ ์ฌ๋ฌ ์ฐธ์กฐ๊ฐ ์์ผ๋ฉด์, ์ด ์ฐธ์กฐ๋ค์ ์๋ช ์ด ์๋ก ๋ค๋ฅด๊ฒ ์ง์ ๋๋ "
+"๊ฒฝ์ฐ๋ ์์ต๋๋ค. ์ด๋ ์ฐธ์กฐ์ ๊ทธ ๊ตฌ์กฐ์ฒด ๊ฐ์ ๊ด๊ณ ๋ฟ๋ง์ด ์๋๋ผ, ๊ทธ ์ฐธ์กฐ๋ค ์ฌ"
+"์ด์ ์๋ช ๊ด๊ณ๋ฅผ ์ค๋ช ํด์ผ ํ ๊ฒฝ์ฐ์ ํ์ํฉ๋๋ค. ๋งค์ฐ ๊ณ ๊ธ ๊ธฐ์ ์ ๋๋ค."
#: src/exercises/day-1/afternoon.md:1
-msgid "# Day 1: Afternoon Exercises"
-msgstr "# 1์ผ์ฐจ ์คํ ์ฐ์ต๋ฌธ์ "
+msgid "Day 1: Afternoon Exercises"
+msgstr "1์ผ์ฐจ ์คํ ์ฐ์ต๋ฌธ์ "
#: src/exercises/day-1/afternoon.md:3
msgid "We will look at two things:"
msgstr "์ด๋ฒ ์ฐ์ต๋ฌธ์ ๋ ์๋ ๋๊ฐ์ง์ ๋๋ค:"
#: src/exercises/day-1/afternoon.md:5
-msgid ""
-"* A small book library,\n"
-"\n"
-"* Iterators and ownership (hard)."
-msgstr ""
-"* ์์ ๋์๊ด\n"
-"\n"
-"* ๋ฐ๋ณต์์ ์์ ๊ถ (์ด๋ ค์)"
+msgid "A small book library,"
+msgstr "์์ ๋์๊ด"
-#: src/exercises/day-1/book-library.md:1
-msgid "# Designing a Library"
-msgstr "# ๋์๊ด ์ค๊ณ"
+#: src/exercises/day-1/afternoon.md:7
+msgid "Iterators and ownership (hard)."
+msgstr "๋ฐ๋ณต์์ ์์ ๊ถ (์ด๋ ค์)"
#: src/exercises/day-1/book-library.md:3
msgid ""
-"We will learn much more about structs and the `Vec` type tomorrow. For now,\n"
-"you just need to know part of its API:"
-msgstr "์ฐ๋ฆฌ๋ ๋ด์ผ ๊ตฌ์กฐ์ฒด์ `Vec`์ ๋ํด ๋ ๋ง์ ๊ฒ์ ๋ฐฐ์ธ ๊ฒ์ ๋๋ค. ์ผ๋จ ์ค๋์ API์ ์ผ๋ถ๋ง ์๋ฉด ๋ฉ๋๋ค:"
+"We will learn much more about structs and the `Vec` type tomorrow. For "
+"now, you just need to know part of its API:"
+msgstr ""
+"์ฐ๋ฆฌ๋ ๋ด์ผ ๊ตฌ์กฐ์ฒด์ `Vec`์ ๋ํด ๋ ๋ง์ ๊ฒ์ ๋ฐฐ์ธ ๊ฒ์ ๋๋ค. ์ผ๋จ ์ค๋์ "
+"API์ ์ผ๋ถ๋ง ์๋ฉด ๋ฉ๋๋ค:"
#: src/exercises/day-1/book-library.md:6
msgid ""
@@ -4762,9 +5682,11 @@ msgstr ""
#: src/exercises/day-1/book-library.md:17
msgid ""
-"Use this to create a library application. Copy the code below to\n"
-" and update the types to make it compile:"
-msgstr "๋์๊ด ํ๋ก๊ทธ๋จ์ ๋ง๋ค๊ธฐ ์ํด ์๋ ์ฝ๋๋ฅผ ์ ๋ณต์ฌํด์ ๊ตฌํํ์๋ฉด ๋ฉ๋๋ค:"
+"Use this to create a library application. Copy the code below to and update the types to make it compile:"
+msgstr ""
+"๋์๊ด ํ๋ก๊ทธ๋จ์ ๋ง๋ค๊ธฐ ์ํด ์๋ ์ฝ๋๋ฅผ ์ ๋ณต"
+"์ฌํด์ ๊ตฌํํ์๋ฉด ๋ฉ๋๋ค:"
#: src/exercises/day-1/book-library.md:20
msgid ""
@@ -4832,9 +5754,11 @@ msgid ""
" //println!(\"Our library is empty: {}\", library.is_empty());\n"
"\n"
" let favorite_book = Book::new(\"Lord of the Rings\", 1954);\n"
-" println!(\"Our favorite book {favorite_book} should go in the library\");\n"
+" println!(\"Our favorite book {favorite_book} should go in the "
+"library\");\n"
" //library.add_book(favorite_book);\n"
-" //library.add_book(Book::new(\"Alice's Adventures in Wonderland\", 1865));\n"
+" //library.add_book(Book::new(\"Alice's Adventures in Wonderland\", "
+"1865));\n"
" //\n"
" //library.print_books();\n"
" //\n"
@@ -4855,27 +5779,31 @@ msgstr ""
msgid "[Solution](solutions-afternoon.md#designing-a-library)"
msgstr "[ํด๋ต](solutions-afternoon.md#designing-a-library)"
-#: src/exercises/day-1/iterators-and-ownership.md:1
-msgid "# Iterators and Ownership"
-msgstr "# ๋ฐ๋ณต์์ ์์ ๊ถ"
-
#: src/exercises/day-1/iterators-and-ownership.md:3
msgid ""
-"The ownership model of Rust affects many APIs. An example of this is the\n"
-"[`Iterator`](https://doc.rust-lang.org/std/iter/trait.Iterator.html) and\n"
-"[`IntoIterator`](https://doc.rust-lang.org/std/iter/trait.IntoIterator.html)\n"
+"The ownership model of Rust affects many APIs. An example of this is the "
+"[`Iterator`](https://doc.rust-lang.org/std/iter/trait.Iterator.html) and "
+"[`IntoIterator`](https://doc.rust-lang.org/std/iter/trait.IntoIterator.html) "
"traits."
-msgstr "๋ฌ์คํธ์ ์์ ๊ถ ๋ชจ๋ธ์ ๋ง์ API์ ๋ฐ์์ด ๋์ด ์์ต๋๋ค. ์๋ฅผ๋ค์ด [`Iterator`](https://doc.rust-lang.org/std/iter/trait.Iterator.html) ์ [`IntoIterator`](https://doc.rust-lang.org/std/iter/trait.IntoIterator.html) ๊ฐ์ ํธ๋ ์์ด ์์ต๋๋ค."
+msgstr ""
+"๋ฌ์คํธ์ ์์ ๊ถ ๋ชจ๋ธ์ ๋ง์ API์ ๋ฐ์์ด ๋์ด ์์ต๋๋ค. ์๋ฅผ๋ค์ด [`Iterator`]"
+"(https://doc.rust-lang.org/std/iter/trait.Iterator.html) ์ [`IntoIterator`]"
+"(https://doc.rust-lang.org/std/iter/trait.IntoIterator.html) ๊ฐ์ ํธ๋ ์์ด ์"
+"์ต๋๋ค."
-#: src/exercises/day-1/iterators-and-ownership.md:8
-msgid "## `Iterator`"
-msgstr "## `Iterator`"
+#: src/exercises/day-1/iterators-and-ownership.md:8 src/bare-metal/no_std.md:28
+msgid "`Iterator`"
+msgstr "`Iterator`"
#: src/exercises/day-1/iterators-and-ownership.md:10
msgid ""
-"Traits are like interfaces: they describe behavior (methods) for a type. The\n"
-"`Iterator` trait simply says that you can call `next` until you get `None` back:"
-msgstr "ํธ๋ ์์ ํ์ ์ ๋ํ ํ๋(๋ฉ์๋)๋ฅผ ์ค๋ช ํ๋ค๋ ์ ์์ ์ธํฐํ์ด์ค์ ์ ์ฌํฉ๋๋ค. `Iterator`๋ ๋จ์ํ `None`์ด ๋์ฌ๋๊น์ง `next`๋ฅผ ํธ์ถํ๋ ๊ฒ์ด ๊ฐ๋ฅํ๋ค๋ ๊ฒ์ ๋ํ๋ด๋ ํธ๋ ์์ ๋๋ค:"
+"Traits are like interfaces: they describe behavior (methods) for a type. The "
+"`Iterator` trait simply says that you can call `next` until you get `None` "
+"back:"
+msgstr ""
+"ํธ๋ ์์ ํ์ ์ ๋ํ ํ๋(๋ฉ์๋)๋ฅผ ์ค๋ช ํ๋ค๋ ์ ์์ ์ธํฐํ์ด์ค์ ์ ์ฌํฉ๋"
+"๋ค. `Iterator`๋ ๋จ์ํ `None`์ด ๋์ฌ๋๊น์ง `next`๋ฅผ ํธ์ถํ๋ ๊ฒ์ด ๊ฐ๋ฅํ๋ค"
+"๋ ๊ฒ์ ๋ํ๋ด๋ ํธ๋ ์์ ๋๋ค:"
#: src/exercises/day-1/iterators-and-ownership.md:13
msgid ""
@@ -4937,14 +5865,17 @@ msgid "Why is this type used?"
msgstr "์ ์ด๋ฐ ํ์ ์ด ์ฌ์ฉ๋๋ ๊ฒ์ผ๊น์?"
#: src/exercises/day-1/iterators-and-ownership.md:48
-msgid "## `IntoIterator`"
-msgstr "## `IntoIterator`"
+msgid "`IntoIterator`"
+msgstr "`IntoIterator`"
#: src/exercises/day-1/iterators-and-ownership.md:50
msgid ""
-"The `Iterator` trait tells you how to _iterate_ once you have created an\n"
-"iterator. The related trait `IntoIterator` tells you how to create the iterator:"
-msgstr "`Iterator` ํธ๋ ์์ ์์ฑ๋ ๋ฐ๋ณต์๋ฅผ *์ฌ์ฉ*ํ๋ ๋ฐฉ๋ฒ์ ์๋ ค์ค๋๋ค. ๋ฐ๋ฉด `IntoIterator` ํธ๋ ์์ ๋ฐ๋ณต์๋ฅผ *์์ฑ*ํ๋ ๋ฐฉ๋ฒ์ ์๋ ค์ค๋๋ค:"
+"The `Iterator` trait tells you how to _iterate_ once you have created an "
+"iterator. The related trait `IntoIterator` tells you how to create the "
+"iterator:"
+msgstr ""
+"`Iterator` ํธ๋ ์์ ์์ฑ๋ ๋ฐ๋ณต์๋ฅผ _์ฌ์ฉ_ํ๋ ๋ฐฉ๋ฒ์ ์๋ ค์ค๋๋ค. ๋ฐ๋ฉด "
+"`IntoIterator` ํธ๋ ์์ ๋ฐ๋ณต์๋ฅผ _์์ฑ_ํ๋ ๋ฐฉ๋ฒ์ ์๋ ค์ค๋๋ค:"
#: src/exercises/day-1/iterators-and-ownership.md:53
msgid ""
@@ -4960,23 +5891,26 @@ msgstr ""
#: src/exercises/day-1/iterators-and-ownership.md:62
msgid ""
-"The syntax here means that every implementation of `IntoIterator` must\n"
+"The syntax here means that every implementation of `IntoIterator` must "
"declare two types:"
msgstr "`IntoIterator`์ ๋ชจ๋ ๊ตฌํ์ ๋ฐ๋์ ๋ค์์ ๋ ํ์ ์ ์ ์ธํด์ผํฉ๋๋ค:"
#: src/exercises/day-1/iterators-and-ownership.md:65
-msgid ""
-"* `Item`: the type we iterate over, such as `i8`,\n"
-"* `IntoIter`: the `Iterator` type returned by the `into_iter` method."
-msgstr ""
-"* `Item`: `i8`๊ณผ ๊ฐ์ด ๋ฐ๋ณต๋๋ ๊ฐ์ ํ์ \n"
-"* `IntoIter`: `into_iter` ๋ฉ์๋์์ ๋ฐํ๋๋ `Iterator`ํ์ ."
+msgid "`Item`: the type we iterate over, such as `i8`,"
+msgstr "`Item`: `i8`๊ณผ ๊ฐ์ด ๋ฐ๋ณต๋๋ ๊ฐ์ ํ์ "
+
+#: src/exercises/day-1/iterators-and-ownership.md:66
+msgid "`IntoIter`: the `Iterator` type returned by the `into_iter` method."
+msgstr "`IntoIter`: `into_iter` ๋ฉ์๋์์ ๋ฐํ๋๋ `Iterator`ํ์ ."
#: src/exercises/day-1/iterators-and-ownership.md:68
msgid ""
-"Note that `IntoIter` and `Item` are linked: the iterator must have the same\n"
+"Note that `IntoIter` and `Item` are linked: the iterator must have the same "
"`Item` type, which means that it returns `Option`"
-msgstr "`IntoIter`์๋ `Item`์ด ์ฐ๊ฒฐ๋์ด ์์์ ์ฃผ๋ชฉํ์ธ์. `IntoIter` ๋ฐ๋ณต์๋ `Item` ํ์ ์ ๋ฐ์ดํฐ๋ฅผ ๊ฐ๋ฆฌ์ผ์ผ ํฉ๋๋ค. ์ฆ, ๋ฐ๋ณต์๋ `Option`์ ๋ฆฌํดํฉ๋๋ค."
+msgstr ""
+"`IntoIter`์๋ `Item`์ด ์ฐ๊ฒฐ๋์ด ์์์ ์ฃผ๋ชฉํ์ธ์. `IntoIter` ๋ฐ๋ณต์๋ "
+"`Item` ํ์ ์ ๋ฐ์ดํฐ๋ฅผ ๊ฐ๋ฆฌ์ผ์ผ ํฉ๋๋ค. ์ฆ, ๋ฐ๋ณต์๋ `Option`์ ๋ฆฌํดํฉ"
+"๋๋ค."
#: src/exercises/day-1/iterators-and-ownership.md:71
msgid "Like before, what is the type returned by the iterator?"
@@ -4986,7 +5920,8 @@ msgstr "์ด์ ๊ณผ ๋ง์ฐฌ๊ฐ์ง๋ก, ๋ฐ๋ณต์๊ฐ ๋ฐํํ๋ ํ์ ์ ๋ฌด์์
msgid ""
"```rust,editable,compile_fail\n"
"fn main() {\n"
-" let v: Vec = vec![String::from(\"foo\"), String::from(\"bar\")];\n"
+" let v: Vec = vec![String::from(\"foo\"), String::"
+"from(\"bar\")];\n"
" let mut iter = v.into_iter();\n"
"\n"
" let v0: Option<..> = iter.next();\n"
@@ -4996,21 +5931,25 @@ msgid ""
msgstr ""
#: src/exercises/day-1/iterators-and-ownership.md:83
-msgid "## `for` Loops"
-msgstr "## ๋ฐฐ์ด๊ณผ `for` ๋ฐ๋ณต๋ฌธ"
+msgid "`for` Loops"
+msgstr "๋ฐฐ์ด๊ณผ `for` ๋ฐ๋ณต๋ฌธ"
#: src/exercises/day-1/iterators-and-ownership.md:85
msgid ""
-"Now that we know both `Iterator` and `IntoIterator`, we can build `for` loops.\n"
-"They call `into_iter()` on an expression and iterates over the resulting\n"
-"iterator:"
-msgstr "์, ์ด์ ์ฐ๋ฆฌ๋ `Iterator`์ `IntoIterator`๋ฅผ ์์์ผ๋ฏ๋ก `for` ๋ฃจํ๋ฅผ ๋ง๋ค ์ ์์ต๋๋ค. `for` ๋ฃจํ๋ `into_iter()`๋ฅผ ํธ์ถํ์ฌ ๋ฐ๋ณต์๋ฅผ ๋ง๋ ๋ค์ ๊ทธ ๋ฐ๋ณต์๋ฅผ ์ด์ฉํ์ฌ ์์๋ค์ ๋ฐ๋ณตํด์ ์ ๊ทผํฉ๋๋ค:"
+"Now that we know both `Iterator` and `IntoIterator`, we can build `for` "
+"loops. They call `into_iter()` on an expression and iterates over the "
+"resulting iterator:"
+msgstr ""
+"์, ์ด์ ์ฐ๋ฆฌ๋ `Iterator`์ `IntoIterator`๋ฅผ ์์์ผ๋ฏ๋ก `for` ๋ฃจํ๋ฅผ ๋ง๋ค "
+"์ ์์ต๋๋ค. `for` ๋ฃจํ๋ `into_iter()`๋ฅผ ํธ์ถํ์ฌ ๋ฐ๋ณต์๋ฅผ ๋ง๋ ๋ค์ ๊ทธ ๋ฐ๋ณต"
+"์๋ฅผ ์ด์ฉํ์ฌ ์์๋ค์ ๋ฐ๋ณตํด์ ์ ๊ทผํฉ๋๋ค:"
#: src/exercises/day-1/iterators-and-ownership.md:89
msgid ""
"```rust,editable\n"
"fn main() {\n"
-" let v: Vec = vec![String::from(\"foo\"), String::from(\"bar\")];\n"
+" let v: Vec = vec![String::from(\"foo\"), String::"
+"from(\"bar\")];\n"
"\n"
" for word in &v {\n"
" println!(\"word: {word}\");\n"
@@ -5029,49 +5968,52 @@ msgstr "๋งค ๋ฃจํ์์ `word`์ ํ์ ์ ๋ฌด์์ ๋๊น?"
#: src/exercises/day-1/iterators-and-ownership.md:105
msgid ""
-"Experiment with the code above and then consult the documentation for [`impl\n"
-"IntoIterator for\n"
-"&Vec`](https://doc.rust-lang.org/std/vec/struct.Vec.html#impl-IntoIterator-for-%26%27a%20Vec%3CT%2C%20A%3E)\n"
-"and [`impl IntoIterator for\n"
-"Vec`](https://doc.rust-lang.org/std/vec/struct.Vec.html#impl-IntoIterator-for-Vec%3CT%2C%20A%3E)\n"
-"to check your answers."
-msgstr "์ ์ฝ๋์์ ์คํ ํด ๋ณธ ํ ๋ค์ ๋ฌธ์๋ฅผ ์ฐธ์กฐํด์ ๋ต๋ณ์ ํ์ธํ์๊ธฐ ๋ฐ๋๋๋ค: [`impl IntoIterator for &Vec`](https://doc.rust-lang.org/std/vec/struct.Vec.html#impl-IntoIterator-for-%26%27a%20Vec%3CT%2C%20A%3E), [`impl IntoIterator for Vec`](https://doc.rust-lang.org/std/vec/struct.Vec.html#impl-IntoIterator-for-Vec%3CT%2C%20A%3E)"
+"Experiment with the code above and then consult the documentation for [`impl "
+"IntoIterator for &Vec`](https://doc.rust-lang.org/std/vec/struct.Vec."
+"html#impl-IntoIterator-for-%26%27a%20Vec%3CT%2C%20A%3E) and [`impl "
+"IntoIterator for Vec`](https://doc.rust-lang.org/std/vec/struct.Vec."
+"html#impl-IntoIterator-for-Vec%3CT%2C%20A%3E) to check your answers."
+msgstr ""
+"์ ์ฝ๋์์ ์คํ ํด ๋ณธ ํ ๋ค์ ๋ฌธ์๋ฅผ ์ฐธ์กฐํด์ ๋ต๋ณ์ ํ์ธํ์๊ธฐ ๋ฐ๋๋๋ค: "
+"[`impl IntoIterator for &Vec`](https://doc.rust-lang.org/std/vec/struct."
+"Vec.html#impl-IntoIterator-for-%26%27a%20Vec%3CT%2C%20A%3E), [`impl "
+"IntoIterator for Vec`](https://doc.rust-lang.org/std/vec/struct.Vec."
+"html#impl-IntoIterator-for-Vec%3CT%2C%20A%3E)"
#: src/welcome-day-2.md:1
-msgid "# Welcome to Day 2"
-msgstr "# 2์ผ์ฐจ ๊ฐ์"
+msgid "Welcome to Day 2"
+msgstr "2์ผ์ฐจ ๊ฐ์"
#: src/welcome-day-2.md:3
msgid "Now that we have seen a fair amount of Rust, we will continue with:"
msgstr "์๋นํ ๋ถ๋์ ๋ฌ์คํธ์ ๋ํด ๋ณด์๊ณ , ์ด์ด์ ์ค๋ ๊ฐ์๋ฅผ ์งํํ๊ฒ ์ต๋๋ค:"
#: src/welcome-day-2.md:5
+msgid "Structs, enums, methods."
+msgstr "๊ตฌ์กฐ์ฒด, ์ด๊ฑฐํ, ๋ฉ์๋."
+
+#: src/welcome-day-2.md:7
+msgid "Pattern matching: destructuring enums, structs, and arrays."
+msgstr "ํจํด ๋งค์นญ: ์ด๊ฑฐํ, ๊ตฌ์กฐ์ฒด ๊ทธ๋ฆฌ๊ณ ๋ฐฐ์ด ๋ถํด."
+
+#: src/welcome-day-2.md:9
msgid ""
-"* Structs, enums, methods.\n"
-"\n"
-"* Pattern matching: destructuring enums, structs, and arrays.\n"
-"\n"
-"* Control flow constructs: `if`, `if let`, `while`, `while let`, `break`, and\n"
-" `continue`.\n"
-"\n"
-"* The Standard Library: `String`, `Option` and `Result`, `Vec`, `HashMap`, `Rc`\n"
-" and `Arc`.\n"
-"\n"
-"* Modules: visibility, paths, and filesystem hierarchy."
+"Control flow constructs: `if`, `if let`, `while`, `while let`, `break`, and "
+"`continue`."
msgstr ""
-"* ๊ตฌ์กฐ์ฒด, ์ด๊ฑฐํ, ๋ฉ์๋.\n"
-"\n"
-"* ํจํด ๋งค์นญ: ์ด๊ฑฐํ, ๊ตฌ์กฐ์ฒด ๊ทธ๋ฆฌ๊ณ ๋ฐฐ์ด ๋ถํด.\n"
-"\n"
-"* ํ๋ฆ ์ ์ด: `if`, `if let`, `while`, `while let`, `break`, ๊ทธ๋ฆฌ๊ณ `continue`.\n"
-"\n"
-"* ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ: `String`, `Option` ๊ณผ `Result`, `Vec`, `HashMap`, `Rc` ๊ทธ๋ฆฌ๊ณ `Arc`.\n"
-"\n"
-"* ๋ชจ๋: ๊ฐ์์ฑ, ๊ฒฝ๋ก ๋ฐ ํ์ผ ์์คํ ๊ณ์ธต."
+"ํ๋ฆ ์ ์ด: `if`, `if let`, `while`, `while let`, `break`, ๊ทธ๋ฆฌ๊ณ `continue`."
-#: src/structs.md:1
-msgid "# Structs"
-msgstr "# ๊ตฌ์กฐ์ฒด"
+#: src/welcome-day-2.md:12
+msgid ""
+"The Standard Library: `String`, `Option` and `Result`, `Vec`, `HashMap`, "
+"`Rc` and `Arc`."
+msgstr ""
+"ํ์ค ๋ผ์ด๋ธ๋ฌ๋ฆฌ: `String`, `Option` ๊ณผ `Result`, `Vec`, `HashMap`, `Rc` ๊ทธ๋ฆฌ"
+"๊ณ `Arc`."
+
+#: src/welcome-day-2.md:15
+msgid "Modules: visibility, paths, and filesystem hierarchy."
+msgstr "๋ชจ๋: ๊ฐ์์ฑ, ๊ฒฝ๋ก ๋ฐ ํ์ผ ์์คํ ๊ณ์ธต."
#: src/structs.md:3
msgid "Like C and C++, Rust has support for custom structs:"
@@ -5127,37 +6069,58 @@ msgstr ""
"}\n"
"```"
-#: src/structs.md:29
+#: src/structs.md:32
+msgid "Structs work like in C or C++."
+msgstr "๊ตฌ์กฐ์ฒด๋ C/C++ ์ ์ ์ฌํฉ๋๋ค."
+
+#: src/structs.md:33
+msgid "Like in C++, and unlike in C, no typedef is needed to define a type."
+msgstr ""
+"C++ ์ ๊ฐ์ง๋ง C์๋ ๋ฌ๋ฆฌ ํ์ ์ ์ ์ํ๊ธฐ ์ํด 'typedef'๊ฐ ํ์ํ์ง ์์ต๋๋ค."
+
+#: src/structs.md:34
+msgid "Unlike in C++, there is no inheritance between structs."
+msgstr "C++ ์ ๋ฌ๋ฆฌ ๊ตฌ์กฐ์ฒด ๊ฐ ์์์ ์์ต๋๋ค."
+
+#: src/structs.md:35
msgid ""
-"\n"
-"Key Points: "
+"Methods are defined in an `impl` block, which we will see in following "
+"slides."
msgstr ""
-"\n"
-"ํค ํฌ์ธํธ: "
+"๋ฉ์๋๋ `impl`๋ธ๋ก์ ์ ์ ํฉ๋๋ค. ๋ค์ ์ฌ๋ผ์ด๋์์ ํ์ธ ํ ์ ์์ต๋๋ค."
-#: src/structs.md:32
+#: src/structs.md:36
+msgid ""
+"This may be a good time to let people know there are different types of "
+"structs. "
+msgstr ""
+"์ฌ๋๋ค์๊ฒ ๋ค๋ฅธ ์ข ๋ฅ์ ๊ตฌ์กฐ์ฒด๊ฐ ์์์ ์๊ฒ ํ๊ธฐ์ ์ข์ ์๊ฐ์ผ ๊ฒ์ ๋๋ค."
+
+#: src/structs.md:37
msgid ""
-"* Structs work like in C or C++.\n"
-" * Like in C++, and unlike in C, no typedef is needed to define a type.\n"
-" * Unlike in C++, there is no inheritance between structs.\n"
-"* Methods are defined in an `impl` block, which we will see in following slides.\n"
-"* This may be a good time to let people know there are different types of structs. \n"
-" * Zero-sized structs `e.g., struct Foo;` might be used when implementing a trait on some type but donโt have any data that you want to store in the value itself. \n"
-" * The next slide will introduce Tuple structs, used when the field names are not important.\n"
-"* The syntax `..peter` allows us to copy the majority of the fields from the old struct without having to explicitly type it all out. It must always be the last element."
-msgstr ""
-"* ๊ตฌ์กฐ์ฒด๋ C/C++ ์ ์ ์ฌํฉ๋๋ค.\n"
-" * C++ ์ ๊ฐ์ง๋ง C์๋ ๋ฌ๋ฆฌ ํ์ ์ ์ ์ํ๊ธฐ ์ํด 'typedef'๊ฐ ํ์ํ์ง ์์ต๋๋ค.\n"
-" * C++ ์ ๋ฌ๋ฆฌ ๊ตฌ์กฐ์ฒด ๊ฐ ์์์ ์์ต๋๋ค.\n"
-"* ๋ฉ์๋๋ `impl`๋ธ๋ก์ ์ ์ ํฉ๋๋ค. ๋ค์ ์ฌ๋ผ์ด๋์์ ํ์ธ ํ ์ ์์ต๋๋ค.\n"
-"* ์ฌ๋๋ค์๊ฒ ๋ค๋ฅธ ์ข ๋ฅ์ ๊ตฌ์กฐ์ฒด๊ฐ ์์์ ์๊ฒ ํ๊ธฐ์ ์ข์ ์๊ฐ์ผ ๊ฒ์ ๋๋ค.\n"
-" * 0 ํฌ๊ธฐ ๊ตฌ์กฐ์ฒด(์: `struct Foo;`)๋ ๋ฐ์ดํฐ๋ฅผ ๊ฐ์ง๊ณ ์์ง ์์ง๋ง ํน์ ํ์ ์ ํธ๋ ์์ ๊ตฌํํ ๋ ์ ์ฉํฉ๋๋ค.\n"
-" * ๋ค์ ์ฌ๋ผ์ด๋์์๋ ํ๋ ์ด๋ฆ์ด ๋ ์ค์ํ ๋ ์ฌ์ฉํ ์ ์๋ ํํ ๊ตฌ์กฐ์ฒด๋ฅผ ์๊ฐํฉ๋๋ค.\n"
-"* `..peter` ๋ฌธ๋ฒ์ ํ ๊ตฌ์กฐ์ฒด์์ ๋ค๋ฅธ ๊ตฌ์กฐ์ฒด๋ก ๋๋ถ๋ถ์ ๊ฐ์ ๋ณต์ฌํ๋ ค๊ณ ํ๋ ๊ฒฝ์ฐ์ ํ๋ํ๋ ํ์ดํํ๋ ์๊ณ ๋ฅผ ๋์ด์ค๋๋ค. ๋ฐ๋์ ๋งจ ๋ง์ง๋ง์ ์์ผ ํฉ๋๋ค."
-
-#: src/structs/tuple-structs.md:1
-msgid "# Tuple Structs"
-msgstr "# ํํ"
+"Zero-sized structs `e.g., struct Foo;` might be used when implementing a "
+"trait on some type but donโt have any data that you want to store in the "
+"value itself. "
+msgstr ""
+"0 ํฌ๊ธฐ ๊ตฌ์กฐ์ฒด(์: `struct Foo;`)๋ ๋ฐ์ดํฐ๋ฅผ ๊ฐ์ง๊ณ ์์ง ์์ง๋ง ํน์ ํ์ ์ ํธ"
+"๋ ์์ ๊ตฌํํ ๋ ์ ์ฉํฉ๋๋ค."
+
+#: src/structs.md:38
+msgid ""
+"The next slide will introduce Tuple structs, used when the field names are "
+"not important."
+msgstr ""
+"๋ค์ ์ฌ๋ผ์ด๋์์๋ ํ๋ ์ด๋ฆ์ด ๋ ์ค์ํ ๋ ์ฌ์ฉํ ์ ์๋ ํํ ๊ตฌ์กฐ์ฒด๋ฅผ ์"
+"๊ฐํฉ๋๋ค."
+
+#: src/structs.md:39
+msgid ""
+"The syntax `..peter` allows us to copy the majority of the fields from the "
+"old struct without having to explicitly type it all out. It must always be "
+"the last element."
+msgstr ""
+"`..peter` ๋ฌธ๋ฒ์ ํ ๊ตฌ์กฐ์ฒด์์ ๋ค๋ฅธ ๊ตฌ์กฐ์ฒด๋ก ๋๋ถ๋ถ์ ๊ฐ์ ๋ณต์ฌํ๋ ค๊ณ ํ๋ ๊ฒฝ"
+"์ฐ์ ํ๋ํ๋ ํ์ดํํ๋ ์๊ณ ๋ฅผ ๋์ด์ค๋๋ค. ๋ฐ๋์ ๋งจ ๋ง์ง๋ง์ ์์ผ ํฉ๋๋ค."
#: src/structs/tuple-structs.md:3
msgid "If the field names are unimportant, you can use a tuple struct:"
@@ -5185,7 +6148,9 @@ msgstr ""
#: src/structs/tuple-structs.md:14
msgid "This is often used for single-field wrappers (called newtypes):"
-msgstr "ํํ ๊ตฌ์กฐ์ฒด๋ ์ข ์ข ๋จ์ผ ํ๋์ ๋ํผ(wrapper, ๋ฌ์คํธ์์ ๋ดํ์ (newtype)์ด๋ผ๊ณ ๋ถ๋ฆ)๋ก ์ฌ์ฉ๋ฉ๋๋ค:"
+msgstr ""
+"ํํ ๊ตฌ์กฐ์ฒด๋ ์ข ์ข ๋จ์ผ ํ๋์ ๋ํผ(wrapper, ๋ฌ์คํธ์์ ๋ดํ์ (newtype)์ด๋ผ"
+"๊ณ ๋ถ๋ฆ)๋ก ์ฌ์ฉ๋ฉ๋๋ค:"
#: src/structs/tuple-structs.md:16
msgid ""
@@ -5229,29 +6194,48 @@ msgstr ""
#: src/structs/tuple-structs.md:37
msgid ""
-"* Newtypes are a great way to encode additional information about the value in a primitive type, for example:\n"
-" * The number is measured in some units: `Newtons` in the example above.\n"
-" * The value passed some validation when it was created, so you no longer have to validate it again at every use: 'PhoneNumber(String)` or `OddNumber(u32)`.\n"
-"* Demonstrate how to add a `f64` value to a `Newtons` type by accessing the single field in the newtype.\n"
-" * Rust generally doesnโt like inexplicit things, like automatic unwrapping or for instance using booleans as integers.\n"
-" * Operator overloading is discussed on Day 3 (generics). "
+"Newtypes are a great way to encode additional information about the value in "
+"a primitive type, for example:"
msgstr ""
-"* ๋ดํ์ ์ ๋ค์๊ณผ ๊ฐ์ ์์ํ์ ๊ฐ์ ํน๋ณํ ์๋ฏธ๋ฅผ ๋ถ์ฌํ๋ ๋ฐ ์ ์ฉํฉ๋๋ค.\n"
-" * ๋จ์ ํ์๋ฅผ ์ํ ์ซ์: ์ ์์ ์์๋ ๋ดํด ๋จ์ ํ๊ธฐ๋ฅผ ์ํด ์ฌ์ฉํฉ๋๋ค.\n"
-" * ๊ฐ์ด ์์ฑ๋ ๋ ์ด๋ฏธ ์ ํจ์ฑ ๊ฒ์ฌ๋ฅผ ํต๊ณผ ํ์ผ๋ฏ๋ก ์ถ๊ฐ์ ์ธ ๊ฒ์ฌ๊ฐ ํ์์๋ ๊ฒฝ์ฐ: `PhoneNumber(String)`๋๋ `OddNumber(u32)`\n"
-"* `Newtons` ํ์ ์ ๊ฐ์ `f64` ๊ฐ์ ๋ํ๋ ๋ฐฉ๋ฒ์ ๋ณด์ฌ์ฃผ์ธ์.\n"
-" * ๋ฌ์คํธ๋ ๋์ฒด๋ก ๋ถ๋ช ํ์ง ์์ ๊ฒ์ ์ซ์ดํฉ๋๋ค. ์๋ฅผ ๋ค๋ฉด ์๋์ผ๋ก unwrapํ๊ฑฐ๋ ๋ถ๋ฆฌ์ธ ๊ฐ์ ์ ์ ๊ฐ์ผ๋ก ์ฌ์ฉํ๋ ๊ฒ๋ค์ด ๊ทธ๋ ์ต๋๋ค.\n"
-" * ์ฐ์ฐ์ ์ฌ์ ์๋ 3์ผ์ฐจ ์ ๋ค๋ฆญ ๋ถ๋ถ์์ ๋ค๋ฃน๋๋ค."
+"๋ดํ์ ์ ๋ค์๊ณผ ๊ฐ์ ์์ํ์ ๊ฐ์ ํน๋ณํ ์๋ฏธ๋ฅผ ๋ถ์ฌํ๋ ๋ฐ ์ ์ฉํฉ๋๋ค."
-#: src/structs/field-shorthand.md:1
-msgid "# Field Shorthand Syntax"
-msgstr "# ํ๋ ํ ๋น ๋จ์ถ ๋ฌธ๋ฒ(Field Shorthand Syntax)"
+#: src/structs/tuple-structs.md:38
+msgid "The number is measured in some units: `Newtons` in the example above."
+msgstr "๋จ์ ํ์๋ฅผ ์ํ ์ซ์: ์ ์์ ์์๋ ๋ดํด ๋จ์ ํ๊ธฐ๋ฅผ ์ํด ์ฌ์ฉํฉ๋๋ค."
+
+#: src/structs/tuple-structs.md:39
+msgid ""
+"The value passed some validation when it was created, so you no longer have "
+"to validate it again at every use: 'PhoneNumber(String)`or`OddNumber(u32)\\`."
+msgstr ""
+"๊ฐ์ด ์์ฑ๋ ๋ ์ด๋ฏธ ์ ํจ์ฑ ๊ฒ์ฌ๋ฅผ ํต๊ณผ ํ์ผ๋ฏ๋ก ์ถ๊ฐ์ ์ธ ๊ฒ์ฌ๊ฐ ํ์์๋ ๊ฒฝ"
+"์ฐ: `PhoneNumber(String)`๋๋ `OddNumber(u32)`"
+
+#: src/structs/tuple-structs.md:40
+msgid ""
+"Demonstrate how to add a `f64` value to a `Newtons` type by accessing the "
+"single field in the newtype."
+msgstr "`Newtons` ํ์ ์ ๊ฐ์ `f64` ๊ฐ์ ๋ํ๋ ๋ฐฉ๋ฒ์ ๋ณด์ฌ์ฃผ์ธ์."
+
+#: src/structs/tuple-structs.md:41
+msgid ""
+"Rust generally doesnโt like inexplicit things, like automatic unwrapping or "
+"for instance using booleans as integers."
+msgstr ""
+"๋ฌ์คํธ๋ ๋์ฒด๋ก ๋ถ๋ช ํ์ง ์์ ๊ฒ์ ์ซ์ดํฉ๋๋ค. ์๋ฅผ ๋ค๋ฉด ์๋์ผ๋ก unwrapํ๊ฑฐ"
+"๋ ๋ถ๋ฆฌ์ธ ๊ฐ์ ์ ์ ๊ฐ์ผ๋ก ์ฌ์ฉํ๋ ๊ฒ๋ค์ด ๊ทธ๋ ์ต๋๋ค."
+
+#: src/structs/tuple-structs.md:42
+msgid "Operator overloading is discussed on Day 3 (generics). "
+msgstr "์ฐ์ฐ์ ์ฌ์ ์๋ 3์ผ์ฐจ ์ ๋ค๋ฆญ ๋ถ๋ถ์์ ๋ค๋ฃน๋๋ค."
#: src/structs/field-shorthand.md:3
msgid ""
-"If you already have variables with the right names, then you can create the\n"
+"If you already have variables with the right names, then you can create the "
"struct using a shorthand:"
-msgstr "๊ตฌ์กฐ์ฒด ํ๋์ ๋์ผํ ์ด๋ฆ์ ๋ณ์๊ฐ ์๋ค๋ฉด ์๋์ ๊ฐ์ด \"์งง์ ๋ฌธ๋ฒ\"์ผ๋ก ๊ตฌ์กฐ์ฒด๋ฅผ ์์ฑํ ์ ์์ต๋๋ค:"
+msgstr ""
+"๊ตฌ์กฐ์ฒด ํ๋์ ๋์ผํ ์ด๋ฆ์ ๋ณ์๊ฐ ์๋ค๋ฉด ์๋์ ๊ฐ์ด \"์งง์ ๋ฌธ๋ฒ\"์ผ๋ก ๊ตฌ์กฐ"
+"์ฒด๋ฅผ ์์ฑํ ์ ์์ต๋๋ค:"
#: src/structs/field-shorthand.md:6
msgid ""
@@ -5295,104 +6279,120 @@ msgstr ""
#: src/structs/field-shorthand.md:27
msgid ""
-"* The `new` function could be written using `Self` as a type, as it is interchangeable with the struct type name\n"
-"\n"
-" ```rust,editable\n"
-" #[derive(Debug)]\n"
-" struct Person {\n"
-" name: String,\n"
-" age: u8,\n"
-" }\n"
-" impl Person {\n"
-" fn new(name: String, age: u8) -> Self {\n"
-" Self { name, age }\n"
-" }\n"
-" }\n"
-" ``` \n"
-"* Implement the `Default` trait for the struct. Define some fields and use the default values for the other fields.\n"
-"\n"
-" ```rust,editable\n"
-" #[derive(Debug)]\n"
-" struct Person {\n"
-" name: String,\n"
-" age: u8,\n"
-" }\n"
-" impl Default for Person {\n"
-" fn default() -> Person {\n"
-" Person {\n"
-" name: \"Bot\".to_string(),\n"
-" age: 0,\n"
-" }\n"
-" }\n"
-" }\n"
-" fn create_default() {\n"
-" let tmp = Person {\n"
-" ..Default::default()\n"
-" };\n"
-" let tmp = Person {\n"
-" name: \"Sam\".to_string(),\n"
-" ..Default::default()\n"
-" };\n"
-" }\n"
-" ```\n"
-"\n"
-"* Methods are defined in the `impl` block.\n"
-"* Use struct update syntax to define a new structure using `peter`. Note that the variable `peter` will no longer be accessible afterwards.\n"
-"* Use `{:#?}` when printing structs to request the `Debug` representation."
-msgstr ""
-"* `new`ํจ์๋ฅผ ๋ค์์ฒ๋ผ ๊ตฌ์กฐ์ฒด ์ด๋ฆ ๋์ `Self`๋ฅผ ์ฌ์ฉํ์ฌ ์์ฑํด๋ ๋ฉ๋๋ค.\n"
-"\n"
-" ```rust,editable\n"
-" #[derive(Debug)]\n"
-" struct Person {\n"
-" name: String,\n"
-" age: u8,\n"
-" }\n"
-" impl Person {\n"
-" fn new(name: String, age: u8) -> Self {\n"
-" Self { name, age }\n"
-" }\n"
-" }\n"
-" ``` \n"
-"* `Default` ํธ๋ ์์ ๊ตฌํํด๋ณด์ธ์. ํ๋ ๋ช๊ฐ๋ ์ด๊ธฐํํ๊ณ ๋๋จธ์ง ํ๋๋ ๋ํดํธ ๊ฐ์ ์ฌ์ฉํ ์ ์์ต๋๋ค.\n"
-"\n"
-" ```rust,editable\n"
-" #[derive(Debug)]\n"
-" struct Person {\n"
-" name: String,\n"
-" age: u8,\n"
-" }\n"
-" impl Default for Person {\n"
-" fn default() -> Person {\n"
-" Person {\n"
-" name: \"Bot\".to_string(),\n"
-" age: 0,\n"
-" }\n"
-" }\n"
-" }\n"
-" fn create_default() {\n"
-" let tmp = Person {\n"
-" ..Default::default()\n"
-" };\n"
-" let tmp = Person {\n"
-" name: \"Sam\".to_string(),\n"
-" ..Default::default()\n"
-" };\n"
-" }\n"
-" ```\n"
-"\n"
-"* ๋ฉ์๋๋ `impl` ๋ธ๋ก์ ์ ์๋ฉ๋๋ค.\n"
-"* `peter`์ ๊ตฌ์กฐ์ฒด ์ ๋ฐ์ดํธ ๋ฌธ๋ฒ์ ์ฌ์ฉํ์ฌ ์๋ก์ด ๊ตฌ์กฐ์ฒด ์ธ์คํด์ค๋ฅผ ๋ง๋ค์ด๋ณด์ธ์. ์ด๋, `peter`๋ ๋์ด์ ์ฌ์ฉํ ์ ์๊ฒ ๋ฉ๋๋ค.\n"
-"* ๊ตฌ์กฐ์ฒด๋ฅผ `Debug` ํํ๋ก ์ถ๋ ฅํ๋ ค๋ฉด `{:#?}`๋ฅผ ์ฌ์ฉํ์ธ์."
-
-#: src/enums.md:1
-msgid "# Enums"
-msgstr "# ์ด๊ฑฐํ"
+"The `new` function could be written using `Self` as a type, as it is "
+"interchangeable with the struct type name"
+msgstr ""
+"`new`ํจ์๋ฅผ ๋ค์์ฒ๋ผ ๊ตฌ์กฐ์ฒด ์ด๋ฆ ๋์ `Self`๋ฅผ ์ฌ์ฉํ์ฌ ์์ฑํด๋ ๋ฉ๋๋ค."
+
+#: src/structs/field-shorthand.md:29
+msgid ""
+"```rust,editable\n"
+"#[derive(Debug)]\n"
+"struct Person {\n"
+" name: String,\n"
+" age: u8,\n"
+"}\n"
+"impl Person {\n"
+" fn new(name: String, age: u8) -> Self {\n"
+" Self { name, age }\n"
+" }\n"
+"}\n"
+"```"
+msgstr ""
+"```rust,editable\n"
+"#[derive(Debug)]\n"
+"struct Person {\n"
+" name: String,\n"
+" age: u8,\n"
+"}\n"
+"impl Person {\n"
+" fn new(name: String, age: u8) -> Self {\n"
+" Self { name, age }\n"
+" }\n"
+"}\n"
+"```"
+
+#: src/structs/field-shorthand.md:41
+msgid ""
+"Implement the `Default` trait for the struct. Define some fields and use the "
+"default values for the other fields."
+msgstr ""
+"`Default` ํธ๋ ์์ ๊ตฌํํด๋ณด์ธ์. ํ๋ ๋ช๊ฐ๋ ์ด๊ธฐํํ๊ณ ๋๋จธ์ง ํ๋๋ ๋ํดํธ "
+"๊ฐ์ ์ฌ์ฉํ ์ ์์ต๋๋ค."
+
+#: src/structs/field-shorthand.md:43
+msgid ""
+"```rust,editable\n"
+"#[derive(Debug)]\n"
+"struct Person {\n"
+" name: String,\n"
+" age: u8,\n"
+"}\n"
+"impl Default for Person {\n"
+" fn default() -> Person {\n"
+" Person {\n"
+" name: \"Bot\".to_string(),\n"
+" age: 0,\n"
+" }\n"
+" }\n"
+"}\n"
+"fn create_default() {\n"
+" let tmp = Person {\n"
+" ..Default::default()\n"
+" };\n"
+" let tmp = Person {\n"
+" name: \"Sam\".to_string(),\n"
+" ..Default::default()\n"
+" };\n"
+"}\n"
+"```"
+msgstr ""
+"```rust,editable\n"
+"#[derive(Debug)]\n"
+"struct Person {\n"
+" name: String,\n"
+" age: u8,\n"
+"}\n"
+"impl Default for Person {\n"
+" fn default() -> Person {\n"
+" Person {\n"
+" name: \"Bot\".to_string(),\n"
+" age: 0,\n"
+" }\n"
+" }\n"
+"}\n"
+"fn create_default() {\n"
+" let tmp = Person {\n"
+" ..Default::default()\n"
+" };\n"
+" let tmp = Person {\n"
+" name: \"Sam\".to_string(),\n"
+" ..Default::default()\n"
+" };\n"
+"}\n"
+"```"
+
+#: src/structs/field-shorthand.md:68
+msgid "Methods are defined in the `impl` block."
+msgstr "๋ฉ์๋๋ `impl` ๋ธ๋ก์ ์ ์๋ฉ๋๋ค."
+
+#: src/structs/field-shorthand.md:69
+msgid ""
+"Use struct update syntax to define a new structure using `peter`. Note that "
+"the variable `peter` will no longer be accessible afterwards."
+msgstr ""
+"`peter`์ ๊ตฌ์กฐ์ฒด ์ ๋ฐ์ดํธ ๋ฌธ๋ฒ์ ์ฌ์ฉํ์ฌ ์๋ก์ด ๊ตฌ์กฐ์ฒด ์ธ์คํด์ค๋ฅผ ๋ง๋ค์ด๋ณด์ธ"
+"์. ์ด๋, `peter`๋ ๋์ด์ ์ฌ์ฉํ ์ ์๊ฒ ๋ฉ๋๋ค."
+
+#: src/structs/field-shorthand.md:70
+msgid ""
+"Use `{:#?}` when printing structs to request the `Debug` representation."
+msgstr "๊ตฌ์กฐ์ฒด๋ฅผ `Debug` ํํ๋ก ์ถ๋ ฅํ๋ ค๋ฉด `{:#?}`๋ฅผ ์ฌ์ฉํ์ธ์."
#: src/enums.md:3
msgid ""
-"The `enum` keyword allows the creation of a type which has a few\n"
-"different variants:"
+"The `enum` keyword allows the creation of a type which has a few different "
+"variants:"
msgstr "`enum` ํค์๋๋ ๋ช๊ฐ์ง ์ ํ(variant)์ผ๋ก ํํ๋๋ ํ์ ์ ์์ฑํฉ๋๋ค:"
#: src/enums.md:6
@@ -5430,30 +6430,49 @@ msgid "Key Points:"
msgstr "ํค ํฌ์ธํธ:"
#: src/enums.md:35
+msgid "Enumerations allow you to collect a set of values under one type"
+msgstr "์ด๊ฑฐํ์ ๊ฐ๋ค์ ์งํฉ์ ํ๋์ ํ์ ์ผ๋ก ํํํ ์ ์๊ฒ ํฉ๋๋ค."
+
+#: src/enums.md:36
+msgid ""
+"This page offers an enum type `CoinFlip` with two variants `Heads` and "
+"`Tail`. You might note the namespace when using variants."
+msgstr ""
+"์์ `CoinFlip` ์ด๊ฑฐํ ํ์ ์ `Heads`์ `Tail` ๋๊ฐ์ง variant๋ฅผ ๊ฐ์ง๋๋ค. ์ด"
+"๊ฑฐํ ํ์ ์ variant๋ ๋ค์์คํ์ด์ค๋ฅผ ๋ถ์ฌ์ ์ฌ์ฉํฉ๋๋ค."
+
+#: src/enums.md:37
+msgid "This might be a good time to compare Structs and Enums:"
+msgstr "๊ตฌ์กฐ์ฒด์ ์ด๊ฑฐํ์ ๋น๊ตํด ๋ณผ๊น์?"
+
+#: src/enums.md:38
msgid ""
-"* Enumerations allow you to collect a set of values under one type\n"
-"* This page offers an enum type `CoinFlip` with two variants `Heads` and `Tail`. You might note the namespace when using variants.\n"
-"* This might be a good time to compare Structs and Enums:\n"
-" * In both, you can have a simple version without fields (unit struct) or one with different types of fields (variant payloads). \n"
-" * In both, associated functions are defined within an `impl` block.\n"
-" * You could even implement the different variants of an enum with separate structs but then they wouldnโt be the same type as they would if they were all defined in an enum. "
+"In both, you can have a simple version without fields (unit struct) or one "
+"with different types of fields (variant payloads). "
msgstr ""
-"* ์ด๊ฑฐํ์ ๊ฐ๋ค์ ์งํฉ์ ํ๋์ ํ์ ์ผ๋ก ํํํ ์ ์๊ฒ ํฉ๋๋ค.\n"
-"* ์์ `CoinFlip` ์ด๊ฑฐํ ํ์ ์ `Heads`์ `Tail` ๋๊ฐ์ง variant๋ฅผ ๊ฐ์ง๋๋ค. ์ด๊ฑฐํ ํ์ ์ variant๋ ๋ค์์คํ์ด์ค๋ฅผ ๋ถ์ฌ์ ์ฌ์ฉํฉ๋๋ค.\n"
-"* ๊ตฌ์กฐ์ฒด์ ์ด๊ฑฐํ์ ๋น๊ตํด ๋ณผ๊น์?\n"
-" * ๊ตฌ์กฐ์ฒด๋ ์ด๊ฑฐํ ๋ชจ๋, ํ๋๊ฐ ํ๋๋ ์๋ ๋จ์ํ ํํ๋ ๊ฐ๋ฅ ํ๊ณ , ์ฌ๋ฌ ํ์ ์ ํ๋๋ฅผ ๊ฐ์ง ์๋ ์์ต๋๋ค.\n"
-" * ๋ ๋ค ์ฐ๊ดํจ์๋ฅผ `impl`๋ธ๋ก์ผ๋ก ์ ์ ํ ์ ์์ต๋๋ค.\n"
-" * ์ด๊ฑฐํ ํ์ ์ ๊ฐ variant๋ฅผ ๋ณ๋์ ๊ตฌ์กฐ์ฒด๋ก ์ ์ํ ์๋ ์์ง๋ง, ๊ทธ๋ฌ๋ฉด ์ด๊ฑฐํ์ ์ฌ์ฉํ์ ๋์ฒ๋ผ ํ๋์ ํ์ ์ผ๋ก ์ทจ๊ธํ ์ ์์ต๋๋ค."
+"๊ตฌ์กฐ์ฒด๋ ์ด๊ฑฐํ ๋ชจ๋, ํ๋๊ฐ ํ๋๋ ์๋ ๋จ์ํ ํํ๋ ๊ฐ๋ฅ ํ๊ณ , ์ฌ๋ฌ ํ์ "
+"์ ํ๋๋ฅผ ๊ฐ์ง ์๋ ์์ต๋๋ค."
+
+#: src/enums.md:39
+msgid "In both, associated functions are defined within an `impl` block."
+msgstr "๋ ๋ค ์ฐ๊ดํจ์๋ฅผ `impl`๋ธ๋ก์ผ๋ก ์ ์ ํ ์ ์์ต๋๋ค."
-#: src/enums/variant-payloads.md:1
-msgid "# Variant Payloads"
-msgstr "# ๋ฐ์ดํฐ๋ฅผ ํฌํจํ๋ ์ด๊ฑฐํ(Variant Payloads)"
+#: src/enums.md:40
+msgid ""
+"You could even implement the different variants of an enum with separate "
+"structs but then they wouldnโt be the same type as they would if they were "
+"all defined in an enum. "
+msgstr ""
+"์ด๊ฑฐํ ํ์ ์ ๊ฐ variant๋ฅผ ๋ณ๋์ ๊ตฌ์กฐ์ฒด๋ก ์ ์ํ ์๋ ์์ง๋ง, ๊ทธ๋ฌ๋ฉด ์ด๊ฑฐํ"
+"์ ์ฌ์ฉํ์ ๋์ฒ๋ผ ํ๋์ ํ์ ์ผ๋ก ์ทจ๊ธํ ์ ์์ต๋๋ค."
#: src/enums/variant-payloads.md:3
msgid ""
-"You can define richer enums where the variants carry data. You can then use the\n"
-"`match` statement to extract the data from each variant:"
-msgstr "์ข๋ ๋ณต์กํ ์ด๊ฑฐํ์ ๊ฒฝ์ฐ variant์ ๋ฐ์ดํฐ(payload)๋ฅผ ํฌํจ์ํค๋ ํฉ๋๋ค. ๊ฐ variant์ ๋ด๊ธด ๋ฐ์ดํฐ๋ `match`๋ฌธ์ ์ด์ฉํด ์ถ์ถํฉ๋๋ค:"
+"You can define richer enums where the variants carry data. You can then use "
+"the `match` statement to extract the data from each variant:"
+msgstr ""
+"์ข๋ ๋ณต์กํ ์ด๊ฑฐํ์ ๊ฒฝ์ฐ variant์ ๋ฐ์ดํฐ(payload)๋ฅผ ํฌํจ์ํค๋ ํฉ๋๋ค. ๊ฐ "
+"variant์ ๋ด๊ธด ๋ฐ์ดํฐ๋ `match`๋ฌธ์ ์ด์ฉํด ์ถ์ถํฉ๋๋ค:"
#: src/enums/variant-payloads.md:6
msgid ""
@@ -5513,35 +6532,84 @@ msgstr ""
#: src/enums/variant-payloads.md:35
msgid ""
-"* The values in the enum variants can only be accessed after being pattern matched. The pattern binds references to the fields in the \"match arm\" after the `=>`.\n"
-" * The expression is matched against the patterns from top to bottom. There is no fall-through like in C or C++.\n"
-" * The match expression has a value. The value is the last expression in the match arm which was executed.\n"
-" * Starting from the top we look for what pattern matches the value then run the code following the arrow. Once we find a match, we stop. \n"
-"* Demonstrate what happens when the search is inexhaustive. Note the advantage the Rust compiler provides by confirming when all cases are handled. \n"
-"* `match` inspects a hidden discriminant field in the `enum`.\n"
-"* It is possible to retrieve the discriminant by calling `std::mem::discriminant()`\n"
-" * This is useful, for example, if implementing `PartialEq` for structs where comparing field values doesn't affect equality.\n"
-"* `WebEvent::Click { ... }` is not exactly the same as `WebEvent::Click(Click)` with a top level `struct Click { ... }`. The inlined version cannot implement traits, for example. \n"
-" "
-msgstr ""
-"* ์ด๊ฑฐํ ์์ ๊ฐ์ ํจํด ๋งค์นญ์ด ๋๊ณ ๋ ์ดํ์๋ง ์ ๊ทผ ๊ฐ๋ฅํฉ๋๋ค. ๊ทธ ๊ฐ์ ๋ํ ๋ ํผ๋ฐ์ค๋ `=>` ์ดํ์ ์ฌ์ฉ๊ฐ๋ฅํฉ๋๋ค.\n"
-" * ๋งค์น ํจํด๋ค์ ์์์ ์๋๋ก ์์์ ๋ฐ๋ผ ๊ฒ์ฌํฉ๋๋ค. C๋ C++์์์ ๊ฐ์ fall-through๋ ์์ต๋๋ค.\n"
-" * ๋งค์น ํํ์ ์์ฒด๋ ๊ฐ์ ๊ฐ์ง๋๋ค. ๊ทธ ๊ฐ์ ๋งค์นญ์ด ๋ ํจํด์์ ๊ฐ์ฅ ๋ง์ง๋ง์ ์ํ๋ ํํ์์ด ๋ฉ๋๋ค.\n"
-" * ๊ฐ์ฅ ์์์ ๋ถํฐ ์ด๋ค ํจํด์ด ์ฃผ์ด์ง ๊ฐ๊ณผ ๋งค์นญํ๋์ง ๊ฒ์ฌํ ๋ค์, ๋งค์นญ๋ ๊ฒ์ด ๋ฐ๊ฒฌ๋๋ฉด ํ์ดํ๋ฅผ ๋ฐ๋ผ ์ฝ๋๋ฅผ ์ํํฉ๋๋ค. ํ ๋ฒ ๋งค์นญ์ด ๋๊ณ ์ฝ๋๊ฐ ์ํ์ด ๋๋ฉด, ๋์ด์์ ๋งค์นญ์ ์์ต๋๋ค.\n"
-"* ๋งค์นญ ํจํด๋ค์ด ๋ถ์ถฉ๋ถ ํ๋ค๋ฉด ์ด๋ค ์ผ์ด ์ผ์ด๋๋์ง ์ค๋ช ํ์ธ์. ๋ฌ์คํธ ์ปดํ์ผ๋ฌ๋ ๋ชจ๋ ๊ฐ๋ฅํ ์ผ์ด์ค๋ค์ด ํธ๋ค๋ง ๋๋์ง ์ฒดํฌํ๋ค๋ ์ ์ ์๊ธฐ์ํค์ธ์.\n"
-"* `match`๋ ์ฃผ์ด์ง ์ด๊ฑฐํ ๊ฐ์ด ์ค์ ๋ก ์ด๋ค variant์ธ์ง ํ๋จํ๊ธฐ ์ํด, ๊ทธ variant์ ์ข ๋ฅ๊ฐ ๊ธฐ๋ก๋, ์จ๊ฒจ์ง ํ๋(์๋ณ์)์ ๊ฐ์ ๊ฒ์ฌํฉ๋๋ค.\n"
-"* `std::mem::discriminant()`๋ฅผ ์ด์ฉํ์ฌ ์๋ณ์๋ฅผ ์ป์ ์๋ ์์ต๋๋ค.\n"
-" * ์ด๋ ๊ฐ ํ๋ ๊ฐ์ ๊ตณ์ด ๋น๊ตํ ํ์ ์๋ ๊ตฌ์กฐ์ฒด์ ๋ํด `PartialEq` ํธ๋ ์์ ๊ตฌํํ ๋ ์ ์ฉํฉ๋๋ค.\n"
-"* `WebEvent::Click { ... }`์ ์ต์์ ๋ ๋ฒจ ๊ตฌ์กฐ์ฒด `struct Click {...}`๋ฅผ ๋ฐ๋ก ์ ์ํ๊ณ `WebEvent::Click(Click)`์ฒ๋ผ ํํ ํํ๋ก ์ ์ํ ๊ฒ๊ณผ ์ ํํ ๊ฐ์ง ์์ต๋๋ค. ์๋ฅผ ๋ค์ด `WebEvent::Click { ... }` ๋ก ์ ์ํ ๊ฒฝ์ฐ, ๊ตฌ์กฐ์ฒด ํํ์ ์ ์ฌํ์ง๋ง ํธ๋ ์์ ๊ตฌํ ํ ์ ์์ต๋๋ค.\n"
-" "
-
-#: src/enums/sizes.md:1
-msgid "# Enum Sizes"
-msgstr "# ์ด๊ฑฐํ ํ์ ์ ํฌ๊ธฐ"
+"The values in the enum variants can only be accessed after being pattern "
+"matched. The pattern binds references to the fields in the \"match arm\" "
+"after the `=>`."
+msgstr ""
+"์ด๊ฑฐํ ์์ ๊ฐ์ ํจํด ๋งค์นญ์ด ๋๊ณ ๋ ์ดํ์๋ง ์ ๊ทผ ๊ฐ๋ฅํฉ๋๋ค. ๊ทธ ๊ฐ์ ๋ํ "
+"๋ ํผ๋ฐ์ค๋ `=>` ์ดํ์ ์ฌ์ฉ๊ฐ๋ฅํฉ๋๋ค."
+
+#: src/enums/variant-payloads.md:36
+msgid ""
+"The expression is matched against the patterns from top to bottom. There is "
+"no fall-through like in C or C++."
+msgstr ""
+"๋งค์น ํจํด๋ค์ ์์์ ์๋๋ก ์์์ ๋ฐ๋ผ ๊ฒ์ฌํฉ๋๋ค. C๋ C++์์์ ๊ฐ์ fall-"
+"through๋ ์์ต๋๋ค."
+
+#: src/enums/variant-payloads.md:37
+msgid ""
+"The match expression has a value. The value is the last expression in the "
+"match arm which was executed."
+msgstr ""
+"๋งค์น ํํ์ ์์ฒด๋ ๊ฐ์ ๊ฐ์ง๋๋ค. ๊ทธ ๊ฐ์ ๋งค์นญ์ด ๋ ํจํด์์ ๊ฐ์ฅ ๋ง์ง๋ง์ ์"
+"ํ๋ ํํ์์ด ๋ฉ๋๋ค."
+
+#: src/enums/variant-payloads.md:38
+msgid ""
+"Starting from the top we look for what pattern matches the value then run "
+"the code following the arrow. Once we find a match, we stop. "
+msgstr ""
+"๊ฐ์ฅ ์์์ ๋ถํฐ ์ด๋ค ํจํด์ด ์ฃผ์ด์ง ๊ฐ๊ณผ ๋งค์นญํ๋์ง ๊ฒ์ฌํ ๋ค์, ๋งค์นญ๋ ๊ฒ์ด "
+"๋ฐ๊ฒฌ๋๋ฉด ํ์ดํ๋ฅผ ๋ฐ๋ผ ์ฝ๋๋ฅผ ์ํํฉ๋๋ค. ํ ๋ฒ ๋งค์นญ์ด ๋๊ณ ์ฝ๋๊ฐ ์ํ์ด ๋"
+"๋ฉด, ๋์ด์์ ๋งค์นญ์ ์์ต๋๋ค."
+
+#: src/enums/variant-payloads.md:39
+msgid ""
+"Demonstrate what happens when the search is inexhaustive. Note the advantage "
+"the Rust compiler provides by confirming when all cases are handled. "
+msgstr ""
+"๋งค์นญ ํจํด๋ค์ด ๋ถ์ถฉ๋ถ ํ๋ค๋ฉด ์ด๋ค ์ผ์ด ์ผ์ด๋๋์ง ์ค๋ช ํ์ธ์. ๋ฌ์คํธ ์ปดํ์ผ๋ฌ"
+"๋ ๋ชจ๋ ๊ฐ๋ฅํ ์ผ์ด์ค๋ค์ด ํธ๋ค๋ง ๋๋์ง ์ฒดํฌํ๋ค๋ ์ ์ ์๊ธฐ์ํค์ธ์."
+
+#: src/enums/variant-payloads.md:40
+msgid "`match` inspects a hidden discriminant field in the `enum`."
+msgstr ""
+"`match`๋ ์ฃผ์ด์ง ์ด๊ฑฐํ ๊ฐ์ด ์ค์ ๋ก ์ด๋ค variant์ธ์ง ํ๋จํ๊ธฐ ์ํด, ๊ทธ "
+"variant์ ์ข ๋ฅ๊ฐ ๊ธฐ๋ก๋, ์จ๊ฒจ์ง ํ๋(์๋ณ์)์ ๊ฐ์ ๊ฒ์ฌํฉ๋๋ค."
+
+#: src/enums/variant-payloads.md:41
+msgid ""
+"It is possible to retrieve the discriminant by calling `std::mem::"
+"discriminant()`"
+msgstr "`std::mem::discriminant()`๋ฅผ ์ด์ฉํ์ฌ ์๋ณ์๋ฅผ ์ป์ ์๋ ์์ต๋๋ค."
+
+#: src/enums/variant-payloads.md:42
+msgid ""
+"This is useful, for example, if implementing `PartialEq` for structs where "
+"comparing field values doesn't affect equality."
+msgstr ""
+"์ด๋ ๊ฐ ํ๋ ๊ฐ์ ๊ตณ์ด ๋น๊ตํ ํ์ ์๋ ๊ตฌ์กฐ์ฒด์ ๋ํด `PartialEq` ํธ๋ ์์ ๊ตฌ"
+"ํํ ๋ ์ ์ฉํฉ๋๋ค."
+
+#: src/enums/variant-payloads.md:43
+msgid ""
+"`WebEvent::Click { ... }` is not exactly the same as `WebEvent::"
+"Click(Click)` with a top level `struct Click { ... }`. The inlined version "
+"cannot implement traits, for example."
+msgstr ""
+"`WebEvent::Click { ... }`์ ์ต์์ ๋ ๋ฒจ ๊ตฌ์กฐ์ฒด `struct Click {...}`๋ฅผ ๋ฐ๋ก ์ "
+"์ํ๊ณ `WebEvent::Click(Click)`์ฒ๋ผ ํํ ํํ๋ก ์ ์ํ ๊ฒ๊ณผ ์ ํํ ๊ฐ์ง ์์ต"
+"๋๋ค. ์๋ฅผ ๋ค์ด `WebEvent::Click { ... }` ๋ก ์ ์ํ ๊ฒฝ์ฐ, ๊ตฌ์กฐ์ฒด ํํ์ ์ ์ฌ"
+"ํ์ง๋ง ํธ๋ ์์ ๊ตฌํ ํ ์ ์์ต๋๋ค."
#: src/enums/sizes.md:3
-msgid "Rust enums are packed tightly, taking constraints due to alignment into account:"
-msgstr "๋ฌ์คํธ์ ์ด๊ฑฐํ์ ์ ๋ ฌ(alignment)๋ก ์ธํ ์ ์ฝ์ ๊ณ ๋ คํ์ฌ ํฌ๊ธฐ๋ฅผ ๋นฝ๋นฝํ๊ฒ ์ก์ต๋๋ค:"
+msgid ""
+"Rust enums are packed tightly, taking constraints due to alignment into "
+"account:"
+msgstr ""
+"๋ฌ์คํธ์ ์ด๊ฑฐํ์ ์ ๋ ฌ(alignment)๋ก ์ธํ ์ ์ฝ์ ๊ณ ๋ คํ์ฌ ํฌ๊ธฐ๋ฅผ ๋นฝ๋นฝํ๊ฒ ์ก์ต"
+"๋๋ค:"
#: src/enums/sizes.md:5
msgid ""
@@ -5566,190 +6634,250 @@ msgid ""
"```"
msgstr ""
"```rust,editable\n"
-"use std::mem::{align_of, size_of};\n"
+"use std::mem::{align_of, size_of};\n"
+"\n"
+"macro_rules! dbg_size {\n"
+" ($t:ty) => {\n"
+" println!(\"{}: size {} bytes, align: {} bytes\",\n"
+" stringify!($t), size_of::<$t>(), align_of::<$t>());\n"
+" };\n"
+"}\n"
+"\n"
+"enum Foo {\n"
+" A,\n"
+" B,\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" dbg_size!(Foo);\n"
+"}\n"
+"```"
+
+#: src/enums/sizes.md:25
+msgid ""
+"See the [Rust Reference](https://doc.rust-lang.org/reference/type-layout."
+"html)."
+msgstr ""
+"์์ธํ ์ฌํญ์ [๊ณต์๋ฌธ์](https://doc.rust-lang.org/reference/type-layout."
+"html)๋ฅผ ํ์ธํ์ธ์."
+
+#: src/enums/sizes.md:31
+#, fuzzy
+msgid ""
+"Internally Rust is using a field (discriminant) to keep track of the enum "
+"variant."
+msgstr ""
+"๋ฌ์คํธ๋ ์ด๊ฑฐํ variant๋ฅผ ๊ตฌ๋ถํ๊ธฐ ์ํด ๋ด๋ถ์ ์ผ๋ก ์๋ณ์(discriminant) ํ๋"
+"๋ฅผ ์ฌ์ฉํฉ๋๋ค."
+
+#: src/enums/sizes.md:33
+#, fuzzy
+msgid ""
+"You can control the discriminant if needed (e.g., for compatibility with C):"
+msgstr "C์์ ์ฐ๋๊ณผ ๊ฐ์ ์ด์ ๋ก ์๋ณ์๋ฅผ ์ง์ ์ง์ ํ ์๋ ์์ต๋๋ค:"
+
+#: src/enums/sizes.md:35
+#, fuzzy
+msgid ""
+"```rust,editable\n"
+"#[repr(u32)]\n"
+"enum Bar {\n"
+" A, // 0\n"
+" B = 10000,\n"
+" C, // 10001\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" println!(\"A: {}\", Bar::A as u32);\n"
+" println!(\"B: {}\", Bar::B as u32);\n"
+" println!(\"C: {}\", Bar::C as u32);\n"
+"}\n"
+"```"
+msgstr ""
+"```rust,editable\n"
+"#[repr(u32)]\n"
+"enum Bar {\n"
+" A, // 0\n"
+" B = 10000,\n"
+" C, // 10001\n"
+"}\n"
+"\n"
+"fn main() {\n"
+" println!(\"A: {}\", Bar::A as u32);\n"
+" println!(\"B: {}\", Bar::B as u32);\n"
+" println!(\"C: {}\", Bar::C as u32);\n"
+"}\n"
+"```"
+
+#: src/enums/sizes.md:50
+#, fuzzy
+msgid ""
+"Without `repr`, the discriminant type takes 2 bytes, because 10001 fits 2 "
+"bytes."
+msgstr ""
+"`repr` ์์ฑ์ด ์๋ค๋ฉด 10001์ด 2 ๋ฐ์ดํธ๋ก ํํ๊ฐ๋ฅํ๊ธฐ ๋๋ฌธ์ ์๋ณ์์ ํ์ ํฌ"
+"๊ธฐ๋ 2 ๋ฐ์ดํธ๊ฐ ๋ฉ๋๋ค."
+
+#: src/enums/sizes.md:54
+#, fuzzy
+msgid "Try out other types such as"
+msgstr "๋ค๋ฅธ ํ์ ๋ค๋ ํ์ธํด๋ณด์ธ์."
+
+#: src/enums/sizes.md:56
+#, fuzzy
+msgid "`dbg_size!(bool)`: size 1 bytes, align: 1 bytes,"
+msgstr "`dbg_size!(bool)`: size 1 bytes, align: 1 bytes"
+
+#: src/enums/sizes.md:57
+#, fuzzy
+msgid ""
+"`dbg_size!(Option)`: size 1 bytes, align: 1 bytes (niche optimization, "
+"see below),"
+msgstr ""
+"`dbg_size!(Option)`: size 1 bytes, align: 1 bytes (๋์น ์ต์ ํ, ์๋ ์ค"
+"๋ช ์ฐธ์กฐ)"
+
+#: src/enums/sizes.md:58
+#, fuzzy
+msgid "`dbg_size!(&i32)`: size 8 bytes, align: 8 bytes (on a 64-bit machine),"
+msgstr "`dbg_size!(&i32)`: size 8 bytes, align: 8 bytes (64๋นํธ ๋จธ์ ์ธ ๊ฒฝ์ฐ)"
+
+#: src/enums/sizes.md:59
+#, fuzzy
+msgid ""
+"`dbg_size!(Option<&i32>)`: size 8 bytes, align: 8 bytes (null pointer "
+"optimization, see below)."
+msgstr ""
+"`dbg_size!(Option<&i32>)`: size 8 bytes, align: 8 bytes (๋ํฌ์ธํฐ ์ต์ ํ, ์"
+"๋ ์ค๋ช ์ฐธ์กฐ)"
+
+#: src/enums/sizes.md:61
+#, fuzzy
+msgid ""
+"Niche optimization: Rust will merge use unused bit patterns for the enum "
+"discriminant."
+msgstr ""
+"๋์น ์ต์ ํ: ๋ฌ์คํธ๋ ์ด๊ฑฐํ ์๋ณ์๋ฅผ ์ฌ์ฉ๋์ง ์์ ๋นํธ ํจํด๊ณผ ๋ณํฉํฉ๋๋ค."
+
+#: src/enums/sizes.md:64
+msgid ""
+"Null pointer optimization: For [some types](https://doc.rust-lang.org/std/"
+"option/#representation), Rust guarantees that `size_of::()` equals "
+"`size_of::