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
//! A capability-oriented API modeled after `async_std`.
//!
//! This corresponds to [`async_std`].
//!
//! Capability-oriented APIs represent access to external resources as
//! objects which can be passed around between different parts of a
//! program.
//!
//! Two notable features are the [`Dir`] and [`Catalog`] types:
//! - `Dir` represents an open directory in a filesystem. Instead of
//! opening files by absolute paths or paths relative to the current
//! working directory, files are opened via paths relative to a
//! `Dir`. The concepts of a process-wide "current working directory"
//! and a single global filesystem namespace are de-emphasized.
//! - `Catalog` represents a set of network addresses. Instead of
//! allowing applications to request access to any address and then
//! applying process-wide filtering rules, filtering rules are
//! built into catalogs which may be passed through the program.
//!
//! On WASI, use of this library closely reflects the underlying system
//! API, so it avoids compatibility layers.
//!
//! [`async_std`]: https://docs.rs/async-std/latest/async_std/
//! [`Dir`]: fs/struct.Dir.html
//! [`Catalog`]: net/struct.Catalog.html
// Disable `net` on WASI until it has networking support.