mirror of
				https://github.com/haraldh/chainerror.git
				synced 2025-10-25 21:34:07 +02:00 
			
		
		
		
	doc update
generated from commit 837c7980e8a5b84be28825303faac0ba28e53446
This commit is contained in:
		
							parent
							
								
									991a7a0786
								
							
						
					
					
						commit
						188d93a86a
					
				
					 15 changed files with 116 additions and 18 deletions
				
			
		|  | @ -140,7 +140,7 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <a class="header" href="#simple-string-errors" id="simple-string-errors"><h1>Simple String Errors</h1></a> |                         <a class="header" href="#simple-string-errors" id="simple-string-errors"><h2>Simple String Errors</h2></a> | ||||||
| <p>The most simplest of doing error handling in rust is by returning <code>String</code> as a <code>Box<Error></code>.</p> | <p>The most simplest of doing error handling in rust is by returning <code>String</code> as a <code>Box<Error></code>.</p> | ||||||
| <p>As you can see by running the example, this only prints out the last <code>Error</code>.</p> | <p>As you can see by running the example, this only prints out the last <code>Error</code>.</p> | ||||||
| <p>If the rust <code>main</code> function returns an Err(), this Err() will be displayed with <code>std::fmt::Debug</code>.</p> | <p>If the rust <code>main</code> function returns an Err(), this Err() will be displayed with <code>std::fmt::Debug</code>.</p> | ||||||
|  |  | ||||||
							
								
								
									
										55
									
								
								print.html
									
										
									
									
									
								
							
							
						
						
									
										55
									
								
								print.html
									
										
									
									
									
								
							|  | @ -140,7 +140,7 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <a class="header" href="#simple-string-errors" id="simple-string-errors"><h1>Simple String Errors</h1></a> |                         <a class="header" href="#simple-string-errors" id="simple-string-errors"><h2>Simple String Errors</h2></a> | ||||||
| <p>The most simplest of doing error handling in rust is by returning <code>String</code> as a <code>Box<Error></code>.</p> | <p>The most simplest of doing error handling in rust is by returning <code>String</code> as a <code>Box<Error></code>.</p> | ||||||
| <p>As you can see by running the example, this only prints out the last <code>Error</code>.</p> | <p>As you can see by running the example, this only prints out the last <code>Error</code>.</p> | ||||||
| <p>If the rust <code>main</code> function returns an Err(), this Err() will be displayed with <code>std::fmt::Debug</code>.</p> | <p>If the rust <code>main</code> function returns an Err(), this Err() will be displayed with <code>std::fmt::Debug</code>.</p> | ||||||
|  | @ -170,7 +170,7 @@ fn main() -> Result<(), Box<Error>> { | ||||||
|     func1() |     func1() | ||||||
| } | } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
| <a class="header" href="#simple-chained-string-errors" id="simple-chained-string-errors"><h1>Simple Chained String Errors</h1></a> | <a class="header" href="#simple-chained-string-errors" id="simple-chained-string-errors"><h2>Simple Chained String Errors</h2></a> | ||||||
| <p>Now with the help of the <code>chainerror</code> crate, we can have a nicer output.</p> | <p>Now with the help of the <code>chainerror</code> crate, we can have a nicer output.</p> | ||||||
| <p>Press the play button in the upper right corner and see the nice debug output.</p> | <p>Press the play button in the upper right corner and see the nice debug output.</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
|  | @ -479,6 +479,20 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#what-did-we-do-here" id="what-did-we-do-here"><h3>What did we do here?</h3></a> | ||||||
|  | <pre><code class="language-rust ignore">    if let Err(e) = do_some_io() { | ||||||
|  |         Err(cherr!(e, "func2 error"))?; | ||||||
|  |     } | ||||||
|  | </code></pre> | ||||||
|  | <p>The macro <code>cherr!(cause, newerror)</code> stores <code>cause</code> as the source/cause of <code>newerror</code> and returns | ||||||
|  | <code>newerror</code>, along with the filename (<code>file!()</code>) and line number (<code>line!()</code>).</p> | ||||||
|  | <p><code>Err(e)?</code> then returns the error <code>e</code> applying <code>e.into()</code>, so that we | ||||||
|  | again have a <code>Err(Box<Error>)</code> as a result.</p> | ||||||
|  | <p>The <code>Debug</code> implementation of <code>ChainError<T></code> (which is returned by <code>cherr!()</code>) | ||||||
|  | prints the <code>Debug</code> of <code>T</code> prefixed with the stored filename and line number.</p> | ||||||
|  | <p><code>ChainError<T></code> is in our case <code>ChainError<String></code>.</p> | ||||||
|  | <a class="header" href="#mapping-errors" id="mapping-errors"><h2>Mapping Errors</h2></a> | ||||||
|  | <p>Now let's get more rust idiomatic by using <code>.map_err()</code>.</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  | @ -784,6 +798,22 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <p>If you compare the output to the previous example, you will see, | ||||||
|  | that:</p> | ||||||
|  | <pre><code>Error: src/main.rs:19: "func1 error" | ||||||
|  | </code></pre> | ||||||
|  | <p>changed to just:</p> | ||||||
|  | <pre><code>src/main.rs:16: "func1 error" | ||||||
|  | </code></pre> | ||||||
|  | <p>This is, because we caught the error of <code>func1()</code> in <code>main()</code> and print it out ourselves.</p> | ||||||
|  | <p>We can now control, whether to output in <code>Debug</code> or <code>Display</code> mode. | ||||||
|  | Maybe depending on <code>--debug</code> as a CLI argument.</p> | ||||||
|  | <a class="header" href="#saving-coding-chars" id="saving-coding-chars"><h2>Saving coding chars</h2></a> | ||||||
|  | <p>Because decorating an error with more information should not | ||||||
|  | let you jump through hoops, <code>chainerror</code> has a quick macro for that.</p> | ||||||
|  | <p><code>mstrerror!()</code> fits right into <code>.map_err()</code> letting you quickly add | ||||||
|  | more debug strings.</p> | ||||||
|  | <p><code>mstrerror!()</code> even understands <code>format!()</code> syntax like <code>println!()</code>.</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  | @ -794,7 +824,8 @@ fn do_some_io() -> Result<(), Box<Error>> { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn func2() -> Result<(), Box<Error>> { | fn func2() -> Result<(), Box<Error>> { | ||||||
|     do_some_io().map_err(mstrerr!("func2 error"))?; |     let filename = "foo.txt"; | ||||||
|  |     do_some_io().map_err(mstrerr!("Error reading '{}'", filename))?; | ||||||
|     Ok(()) |     Ok(()) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -1089,6 +1120,9 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#the-source-of-errors" id="the-source-of-errors"><h2>The source() of Errors</h2></a> | ||||||
|  | <p>Sometimes you want to inspect the <code>source()</code> of an <code>Error</code>. | ||||||
|  | <code>chainerror</code> implements <code>std::error::Error::source()</code>, so you can get the cause of an error.</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  | @ -1401,6 +1435,11 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <p>Note, that we changed the output of the error in <code>main()</code> from <code>Debug</code> to <code>Display</code>, so we don't see | ||||||
|  | the error backtrace with filename and line number.</p> | ||||||
|  | <p>To enable the <code>Display</code> backtrace, you have to enable the feature <code>display-cause</code> for <code>chainerror</code>.</p> | ||||||
|  | <a class="header" href="#downcast-the-errors" id="downcast-the-errors"><h2>Downcast the Errors</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  | @ -1721,6 +1760,8 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#the-root-cause-of-all-errors" id="the-root-cause-of-all-errors"><h2>The root cause of all Errors</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  | @ -2042,6 +2083,8 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#finding-an-error-cause" id="finding-an-error-cause"><h2>Finding an Error cause</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  | @ -2363,6 +2406,8 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#selective-error-handling" id="selective-error-handling"><h2>Selective Error Handling</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  | @ -2683,6 +2728,8 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#errorkind-to-the-rescue" id="errorkind-to-the-rescue"><h2>ErrorKind to the rescue</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  | @ -3020,6 +3067,8 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#debug-for-the-errorkind" id="debug-for-the-errorkind"><h2>Debug for the ErrorKind</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -140,7 +140,7 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <a class="header" href="#simple-string-errors" id="simple-string-errors"><h1>Simple String Errors</h1></a> |                         <a class="header" href="#simple-string-errors" id="simple-string-errors"><h2>Simple String Errors</h2></a> | ||||||
| <p>The most simplest of doing error handling in rust is by returning <code>String</code> as a <code>Box<Error></code>.</p> | <p>The most simplest of doing error handling in rust is by returning <code>String</code> as a <code>Box<Error></code>.</p> | ||||||
| <p>As you can see by running the example, this only prints out the last <code>Error</code>.</p> | <p>As you can see by running the example, this only prints out the last <code>Error</code>.</p> | ||||||
| <p>If the rust <code>main</code> function returns an Err(), this Err() will be displayed with <code>std::fmt::Debug</code>.</p> | <p>If the rust <code>main</code> function returns an Err(), this Err() will be displayed with <code>std::fmt::Debug</code>.</p> | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#errorkind-to-the-rescue" id="errorkind-to-the-rescue"><h2>ErrorKind to the rescue</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#debug-for-the-errorkind" id="debug-for-the-errorkind"><h2>Debug for the ErrorKind</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  |  | ||||||
|  | @ -140,7 +140,7 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <a class="header" href="#simple-chained-string-errors" id="simple-chained-string-errors"><h1>Simple Chained String Errors</h1></a> |                         <a class="header" href="#simple-chained-string-errors" id="simple-chained-string-errors"><h2>Simple Chained String Errors</h2></a> | ||||||
| <p>Now with the help of the <code>chainerror</code> crate, we can have a nicer output.</p> | <p>Now with the help of the <code>chainerror</code> crate, we can have a nicer output.</p> | ||||||
| <p>Press the play button in the upper right corner and see the nice debug output.</p> | <p>Press the play button in the upper right corner and see the nice debug output.</p> | ||||||
| <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
|  | @ -449,6 +449,18 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <a class="header" href="#what-did-we-do-here" id="what-did-we-do-here"><h3>What did we do here?</h3></a> | ||||||
|  | <pre><code class="language-rust ignore">    if let Err(e) = do_some_io() { | ||||||
|  |         Err(cherr!(e, "func2 error"))?; | ||||||
|  |     } | ||||||
|  | </code></pre> | ||||||
|  | <p>The macro <code>cherr!(cause, newerror)</code> stores <code>cause</code> as the source/cause of <code>newerror</code> and returns | ||||||
|  | <code>newerror</code>, along with the filename (<code>file!()</code>) and line number (<code>line!()</code>).</p> | ||||||
|  | <p><code>Err(e)?</code> then returns the error <code>e</code> applying <code>e.into()</code>, so that we | ||||||
|  | again have a <code>Err(Box<Error>)</code> as a result.</p> | ||||||
|  | <p>The <code>Debug</code> implementation of <code>ChainError<T></code> (which is returned by <code>cherr!()</code>) | ||||||
|  | prints the <code>Debug</code> of <code>T</code> prefixed with the stored filename and line number.</p> | ||||||
|  | <p><code>ChainError<T></code> is in our case <code>ChainError<String></code>.</p> | ||||||
| 
 | 
 | ||||||
|                     </main> |                     </main> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#mapping-errors" id="mapping-errors"><h2>Mapping Errors</h2></a> | ||||||
|  | <p>Now let's get more rust idiomatic by using <code>.map_err()</code>.</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
| 
 | 
 | ||||||
|  | @ -445,6 +447,16 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <p>If you compare the output to the previous example, you will see, | ||||||
|  | that:</p> | ||||||
|  | <pre><code>Error: src/main.rs:19: "func1 error" | ||||||
|  | </code></pre> | ||||||
|  | <p>changed to just:</p> | ||||||
|  | <pre><code>src/main.rs:16: "func1 error" | ||||||
|  | </code></pre> | ||||||
|  | <p>This is, because we caught the error of <code>func1()</code> in <code>main()</code> and print it out ourselves.</p> | ||||||
|  | <p>We can now control, whether to output in <code>Debug</code> or <code>Display</code> mode. | ||||||
|  | Maybe depending on <code>--debug</code> as a CLI argument.</p> | ||||||
| 
 | 
 | ||||||
|                     </main> |                     </main> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -140,7 +140,13 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#saving-coding-chars" id="saving-coding-chars"><h2>Saving coding chars</h2></a> | ||||||
|  | <p>Because decorating an error with more information should not | ||||||
|  | let you jump through hoops, <code>chainerror</code> has a quick macro for that.</p> | ||||||
|  | <p><code>mstrerror!()</code> fits right into <code>.map_err()</code> letting you quickly add | ||||||
|  | more debug strings.</p> | ||||||
|  | <p><code>mstrerror!()</code> even understands <code>format!()</code> syntax like <code>println!()</code>.</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
| 
 | 
 | ||||||
|  | @ -150,7 +156,8 @@ fn do_some_io() -> Result<(), Box<Error>> { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn func2() -> Result<(), Box<Error>> { | fn func2() -> Result<(), Box<Error>> { | ||||||
|     do_some_io().map_err(mstrerr!("func2 error"))?; |     let filename = "foo.txt"; | ||||||
|  |     do_some_io().map_err(mstrerr!("Error reading '{}'", filename))?; | ||||||
|     Ok(()) |     Ok(()) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -140,7 +140,10 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#the-source-of-errors" id="the-source-of-errors"><h2>The source() of Errors</h2></a> | ||||||
|  | <p>Sometimes you want to inspect the <code>source()</code> of an <code>Error</code>. | ||||||
|  | <code>chainerror</code> implements <code>std::error::Error::source()</code>, so you can get the cause of an error.</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  | @ -452,6 +455,9 @@ fn main() -> Result<(), Box<Error>> { | ||||||
| # } | # } | ||||||
| # } | # } | ||||||
| </code></pre></pre> | </code></pre></pre> | ||||||
|  | <p>Note, that we changed the output of the error in <code>main()</code> from <code>Debug</code> to <code>Display</code>, so we don't see | ||||||
|  | the error backtrace with filename and line number.</p> | ||||||
|  | <p>To enable the <code>Display</code> backtrace, you have to enable the feature <code>display-cause</code> for <code>chainerror</code>.</p> | ||||||
| 
 | 
 | ||||||
|                     </main> |                     </main> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#downcast-the-errors" id="downcast-the-errors"><h2>Downcast the Errors</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#the-root-cause-of-all-errors" id="the-root-cause-of-all-errors"><h2>The root cause of all Errors</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#finding-an-error-cause" id="finding-an-error-cause"><h2>Finding an Error cause</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  |  | ||||||
|  | @ -140,7 +140,9 @@ | ||||||
| 
 | 
 | ||||||
|                 <div id="content" class="content"> |                 <div id="content" class="content"> | ||||||
|                     <main> |                     <main> | ||||||
|                         <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; |                         <a class="header" href="#selective-error-handling" id="selective-error-handling"><h2>Selective Error Handling</h2></a> | ||||||
|  | <p>[TBD]</p> | ||||||
|  | <pre><pre class="playpen"><code class="language-rust">use crate::chainerror::*; | ||||||
| use std::error::Error; | use std::error::Error; | ||||||
| use std::io; | use std::io; | ||||||
| use std::result::Result; | use std::result::Result; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Harald Hoyer
						Harald Hoyer