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
//! Protocol buffer generated types for ExoMonad FFI boundary.
//!
//! This crate provides the single source of truth for types that cross
//! the Rust/Haskell WASM boundary.
//!
//! ## Proto files
//!
//! ### Core types (exomonad/)
//! Core FFI types use JSON wire format (serde derives).
//! - `ffi.proto` - Core FFI types (ErrorCode, FfiError, FfiResult)
//! - `common.proto` - Shared primitives (SessionId, Role, etc.)
//! - `hook.proto` - Claude Code hook types
//! - `agent.proto` - Agent management types
//! - `popup.proto` - UI popup types
//!
//! ### Effect types (effects/)
//! Effect types use protobuf binary encoding (prost Message).
//! Modules are auto-generated from `proto/effects/*.proto` at build time.
//! Each `.proto` file with a `service` definition gets its own module.
// Conditionally include modules as they become available
// ============================================================================
// Effect types (feature = "effects")
// ============================================================================
/// Effect types module containing all generated effect message types.
///
/// Effect types use protobuf binary encoding (not JSON).
/// Encode/decode via `prost::Message` trait.
///
/// Sub-modules are generated from `proto/effects/*.proto` — see
/// `build.rs` `generate_effect_module_declarations()`.
// Re-export common types at crate root for convenience
pub use ;