-
Notifications
You must be signed in to change notification settings - Fork 29
/
listings-style.tex
104 lines (82 loc) · 2.89 KB
/
listings-style.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
\documentclass[DIV13]{scrartcl}
\usepackage{listings}
\usepackage{listings-rust}
\usepackage[scaled=0.85]{beramono}
\usepackage[T1]{fontenc}
\usepackage{hyperref}
\lstset{language=Rust, style=boxed}
\title{\texttt{listings-rust} demo}
\author{Tobias Denkinger \\ \href{mailto:[email protected]}{\texttt{[email protected]}}}
\begin{document}
\maketitle
\section*{Some identifiers}
\begin{lstlisting}
// keywords
as break const continue crate dyn else enum extern fn for if impl in let loop
match mod move mut pub ref return Self self static struct super trait type
union unsafe use where while
// reserved keywords (for future use)
abstract alignof become box do final macro offsetof override priv proc pure
sizeof typeof unsized virtual yield
// strings
"this is a test"
// characters
'a' 'b' 'c'
// primitive types
bool char f32 f64 i8 i16 i32 i64 isize str u8 u16 u32 u64 unit usize i128 u128
// some common type and value constructors
Box Option Result String Vec Some None Ok Err true false
// some common traits
Copy Send Sized Sync Drop Fn FnMut FnOnce ToOwned Clone PartialEq PartialOrd
Eq Ord AsRef AsMut Into From Default Iterator Extend IntoIterator
DoubleEndedIterator ExactSizeIterator SliceConcatExt ToString
// some common macros
assert! assert_eq! assert_ne! cfg! column! compile_error! concat!
concat_idents! debug_assert! debug_assert_eq! debug_assert_ne! env! eprint!
eprintln! file! format! format_args! include! include_bytes! include_str!
line! module_path! option_env! panic! print! println! select! stringify!
thread_local! try! unimplemented! unreachable! vec! write! writeln!
\end{lstlisting}
\clearpage
\section*{Example file}
\begin{lstlisting}
use std::rc::Rc;
/// upside-down tree with a designated position (the *stack pointer*)
/// and *nodes* of type `A`.
#[derive(Clone, Debug)]
pub struct TreeStack<A> {
parent: Option<(usize, Rc<TreeStack<A>>)>,
value: A,
children: Vec<Option<Rc<TreeStack<A>>>>,
}
impl<A> TreeStack<A> {
/// Creates a new `TreeStack<A>` with root label `a`.
pub fn new(a: A) -> Self {
TreeStack { value: a, children: Vec::new(), parent: None }
}
/// Applies a function `FnMut(&A) -> B` to every node in a `TreeStack<A>`.
pub fn map<F, B>(&self, f: &mut F) -> TreeStack<B>
where F: FnMut(&A) -> B,
{
let new_value = f(&self.value);
let new_parent = match self.parent {
Some((i, ref p)) => Some((i, Rc::new(p.map(f)))),
None => None,
};
let new_children = self.children
.iter()
.map(|o| o.clone().map(|v| Rc::new(v.map(f))))
.collect();
TreeStack {
parent: new_parent,
value: new_value,
children: new_children
}
}
}
\end{lstlisting}
\end{document}
%%% Local Variables:
%%% mode: latex
%%% TeX-master: t
%%% End: