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
//! Logs a `VisibleTimeRanges` archetype for roundtrip checks.

use rerun::{
    datatypes::{TimeInt, TimeRange, TimeRangeBoundary, VisibleTimeRange},
    external::re_types::blueprint::archetypes::VisibleTimeRanges,
    RecordingStream,
};

#[derive(Debug, clap::Parser)]
#[clap(author, version, about)]
struct Args {
    #[command(flatten)]
    rerun: rerun::clap::RerunArgs,
}

fn run(rec: &RecordingStream, _args: &Args) -> anyhow::Result<()> {
    rec.log(
        "visible_time_ranges",
        &VisibleTimeRanges::new([
            VisibleTimeRange {
                timeline: "timeline0".into(),
                range: TimeRange {
                    start: TimeRangeBoundary::Infinite,
                    end: TimeRangeBoundary::CursorRelative(TimeInt(-10)),
                },
            },
            VisibleTimeRange {
                timeline: "timeline1".into(),
                range: TimeRange {
                    start: TimeRangeBoundary::CursorRelative(TimeInt(20)),
                    end: TimeRangeBoundary::Infinite,
                },
            },
            VisibleTimeRange {
                timeline: "timeline2".into(),
                range: TimeRange {
                    start: TimeRangeBoundary::Absolute(TimeInt(20)),
                    end: TimeRangeBoundary::Absolute(TimeInt(40)),
                },
            },
        ]),
    )?;
    Ok(())
}

fn main() -> anyhow::Result<()> {
    re_log::setup_logging();

    use clap::Parser as _;
    let args = Args::parse();

    let (rec, _serve_guard) = args
        .rerun
        .init("rerun_example_roundtrip_visible_time_ranges")?;
    run(&rec, &args)
}