rust/landgen/src/lib.rs
author unc0rr
Sat, 03 Nov 2018 10:57:47 +0100
changeset 14119 9eca6f2cac6d
parent 14105 4d22be35cfa2
child 14126 69db1d2e4cec
permissions -rw-r--r--
You cannot optimize integral division like this. You end up multiplying by 0, 1 or 2 instead of whole spectre of ratios.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14105
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
     1
mod outline;
14074
abb42ba345b6 Rework lib structure, no code changes
unC0Rr
parents: 14059
diff changeset
     2
pub mod outline_template;
14105
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
     3
pub mod template_based;
13913
9a1f1e8170f2 Start work on landgen rust lib
unc0rr
parents:
diff changeset
     4
13943
1fa905aa4cdb move point struct into integral-geometry and use it to refactor a bit
alfadur
parents: 13913
diff changeset
     5
extern crate integral_geometry;
14105
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
     6
extern crate itertools;
14031
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
     7
extern crate land2d;
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
     8
14032
cef0c685fda8 make useful stuff public
alfadur
parents: 14031
diff changeset
     9
pub struct LandGenerationParameters<T> {
14031
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    10
    zero: T,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    11
    basic: T,
14105
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    12
    distance_divisor: u32,
14031
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    13
}
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    14
14105
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    15
impl<T: Copy + PartialEq> LandGenerationParameters<T> {
14059
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14056
diff changeset
    16
    pub fn new(zero: T, basic: T) -> Self {
14105
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    17
        Self {
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    18
            zero,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    19
            basic,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    20
            distance_divisor: 1,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14074
diff changeset
    21
        }
14059
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14056
diff changeset
    22
    }
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14056
diff changeset
    23
}
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14056
diff changeset
    24
14032
cef0c685fda8 make useful stuff public
alfadur
parents: 14031
diff changeset
    25
pub trait LandGenerator {
14031
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    26
    fn generate_land<T: Copy + PartialEq, I: Iterator<Item = u32>>(
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    27
        &self,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    28
        parameters: LandGenerationParameters<T>,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    29
        random_numbers: &mut I,
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    30
    ) -> land2d::Land2D<T>;
3b3d97ed2286 Start land generators implementation
unc0rr
parents: 13943
diff changeset
    31
}
13943
1fa905aa4cdb move point struct into integral-geometry and use it to refactor a bit
alfadur
parents: 13913
diff changeset
    32
13913
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
}