rust/landgen/src/lib.rs
author alfadur
Thu, 27 Jan 2022 03:51:13 +0300
changeset 15850 44b49f255e31
parent 14228 bb2f301d4fe0
child 15932 230dc46487ea
permissions -rw-r--r--
add type safe power of two sizes
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
     1
mod outline;
14090
abb42ba345b6 Rework lib structure, no code changes
unC0Rr
parents: 14075
diff changeset
     2
pub mod outline_template;
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
     3
pub mod template_based;
13929
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
     4
14048
cef0c685fda8 make useful stuff public
alfadur
parents: 14047
diff changeset
     5
pub struct LandGenerationParameters<T> {
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
     6
    zero: T,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
     7
    basic: T,
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
     8
    distance_divisor: u32,
14142
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
     9
    skip_distort: bool,
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    10
    skip_bezier: bool,
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    11
}
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    12
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
    13
impl<T: Copy + PartialEq> LandGenerationParameters<T> {
15850
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    14
    pub fn new(
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    15
        zero: T,
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    16
        basic: T,
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    17
        distance_divisor: u32,
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    18
        skip_distort: bool,
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    19
        skip_bezier: bool,
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    20
    ) -> Self {
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
    21
        Self {
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
    22
            zero,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
    23
            basic,
14142
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    24
            distance_divisor,
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    25
            skip_distort,
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    26
            skip_bezier,
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14090
diff changeset
    27
        }
14075
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14072
diff changeset
    28
    }
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14072
diff changeset
    29
}
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14072
diff changeset
    30
14048
cef0c685fda8 make useful stuff public
alfadur
parents: 14047
diff changeset
    31
pub trait LandGenerator {
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    32
    fn generate_land<T: Copy + PartialEq, I: Iterator<Item = u32>>(
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    33
        &self,
14142
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    34
        parameters: &LandGenerationParameters<T>,
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    35
        random_numbers: &mut I,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    36
    ) -> land2d::Land2D<T>;
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13959
diff changeset
    37
}
13959
1fa905aa4cdb move point struct into integral-geometry and use it to refactor a bit
alfadur
parents: 13929
diff changeset
    38
13929
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    39
#[cfg(test)]
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    40
mod tests {
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    41
    #[test]
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    42
    fn it_works() {
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    43
        assert_eq!(2 + 2, 4);
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    44
    }
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    45
}