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
//! Icepick: Production-ready cloud Iceberg catalogs
//!
//! Specialized Rust library for Apache Iceberg catalog operations on cloud providers.
//! Provides rock-solid implementations for AWS S3 Tables and Cloudflare R2 Data Catalog.
//!
//! # Quick Start
//!
//! ## AWS S3 Tables (native platforms only)
//!
//! ```no_run
//! use icepick::S3TablesCatalog;
//! use icepick::catalog::Catalog;
//! use icepick::spec::{TableIdent, NamespaceIdent};
//!
//! # async fn example() -> Result<(), Box<dyn std::error::Error>> {
//! let catalog = S3TablesCatalog::from_arn(
//! "my-catalog",
//! "arn:aws:s3tables:us-west-2:123456789012:bucket/my-bucket"
//! ).await?;
//!
//! let namespace = NamespaceIdent::new(vec!["namespace".to_string()]);
//! let table_id = TableIdent::new(namespace, "table".to_string());
//! let table = catalog.load_table(&table_id).await?;
//! # Ok(())
//! # }
//! ```
//!
//! ## Cloudflare R2 (all platforms including WASM)
//!
//! ```no_run
//! use icepick::R2Catalog;
//! use icepick::catalog::Catalog;
//! use icepick::spec::{TableIdent, NamespaceIdent};
//!
//! # async fn example() -> Result<(), Box<dyn std::error::Error>> {
//! let catalog = R2Catalog::new(
//! "my-catalog",
//! "account-id",
//! "bucket-name",
//! "api-token"
//! ).await?;
//!
//! let namespace = NamespaceIdent::new(vec!["namespace".to_string()]);
//! let table_id = TableIdent::new(namespace, "table".to_string());
//! let table = catalog.load_table(&table_id).await?;
//! # Ok(())
//! # }
//! ```
// Re-export common types
pub use ;
pub use FileIO;
pub use DataFileEntry;
pub use ;
pub use ;
pub use Table;
pub use Transaction;
pub use arrow_to_parquet;
// Re-export catalog types
pub use R2Catalog;
pub use S3TablesCatalog;