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
//! # `ModuleRef` Owned Implementation
//!
//! This module provides the owned variant of `ModuleRef` table entries with resolved
//! references and owned data structures for efficient runtime access.
use crate;
/// Owned representation of a `ModuleRef` table entry with resolved references.
///
/// This structure represents the processed entry from the `ModuleRef` metadata table,
/// which contains references to external modules required by the current assembly.
/// Unlike [`ModuleRefRaw`](crate::metadata::tables::ModuleRefRaw), this version contains resolved references
/// to actual module name strings for efficient runtime access.
///
/// ## Purpose
///
/// The `ModuleRef` table entry enables cross-module references in .NET assemblies:
/// - External module identification by name
/// - Support for multi-module assembly structures
/// - Foundation for resolving imported types and methods
/// - Dependency tracking between modules
///
/// ## Cross-Module References
///
/// `ModuleRef` entries serve as the foundation for several cross-module scenarios:
/// - Types defined in external modules referenced by `TypeRef`
/// - Methods defined in external modules referenced by `MemberRef`
/// - Multi-module assemblies with components in separate files
/// - Import resolution for external module dependencies