rust/landgen/src/lib.rs
author unc0rr
Fri, 26 Apr 2019 23:21:27 +0200
changeset 14841 111c4d750c6d
parent 14207 bb2f301d4fe0
child 15828 44b49f255e31
permissions -rw-r--r--
Limit room name change rate
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14100
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
     1
mod outline;
14069
abb42ba345b6 Rework lib structure, no code changes
unC0Rr
parents: 14054
diff changeset
     2
pub mod outline_template;
14100
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
     3
pub mod template_based;
13908
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
     4
14027
cef0c685fda8 make useful stuff public
alfadur
parents: 14026
diff changeset
     5
pub struct LandGenerationParameters<T> {
14026
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
     6
    zero: T,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
     7
    basic: T,
14100
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
     8
    distance_divisor: u32,
14121
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
     9
    skip_distort: bool,
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
    10
    skip_bezier: bool,
14026
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    11
}
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    12
14100
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
    13
impl<T: Copy + PartialEq> LandGenerationParameters<T> {
14121
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
    14
    pub fn new(zero: T, basic: T, distance_divisor: u32, skip_distort: bool, skip_bezier: bool) -> Self {
14100
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
    15
        Self {
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
    16
            zero,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
    17
            basic,
14121
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
    18
            distance_divisor,
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
    19
            skip_distort,
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
    20
            skip_bezier,
14100
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14069
diff changeset
    21
        }
14054
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14051
diff changeset
    22
    }
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14051
diff changeset
    23
}
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14051
diff changeset
    24
14027
cef0c685fda8 make useful stuff public
alfadur
parents: 14026
diff changeset
    25
pub trait LandGenerator {
14026
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    26
    fn generate_land<T: Copy + PartialEq, I: Iterator<Item = u32>>(
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    27
        &self,
14121
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14100
diff changeset
    28
        parameters: &LandGenerationParameters<T>,
14026
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    29
        random_numbers: &mut I,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    30
    ) -> land2d::Land2D<T>;
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13938
diff changeset
    31
}
13938
1fa905aa4cdb move point struct into integral-geometry and use it to refactor a bit
alfadur
parents: 13908
diff changeset
    32
13908
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    33
#[cfg(test)]
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    34
mod tests {
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    35
    #[test]
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    36
    fn it_works() {
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    37
        assert_eq!(2 + 2, 4);
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    38
    }
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
    39
}