• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

Return-To-The-Roots / s25client / 14829523399

05 May 2025 05:13AM UTC coverage: 50.286% (-0.01%) from 50.297%
14829523399

push

github

Flow86
Workaround missing include in kaguya

22357 of 44460 relevant lines covered (50.29%)

33453.45 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

84.85
/libs/s25main/mapGenerator/Rivers.cpp
1
// Copyright (C) 2005 - 2021 Settlers Freaks (sf-team at siedler25.org)
2
//
3
// SPDX-License-Identifier: GPL-2.0-or-later
4

5
#include "mapGenerator/Rivers.h"
6
#include "mapGenerator/Terrain.h"
7
#include "mapGenerator/TextureHelper.h"
8

9
namespace rttr::mapGenerator {
10

11
River CreateStream(RandomUtility& rnd, Map& map, const MapPoint& source, Direction direction, unsigned length,
27✔
12
                   unsigned splitRate)
13
{
14
    const MapExtent& size = map.size;
27✔
15

16
    River river;
27✔
17
    std::vector<Direction> exlcuded{direction + 2, direction + 3, direction + 4};
54✔
18

19
    auto& textures = map.textureMap;
27✔
20
    const auto water = textures.Find(IsWater);
27✔
21

22
    MapPoint currentNode = source;
27✔
23
    Direction currentDir = direction;
27✔
24

25
    for(unsigned node = 0; node < length; ++node)
298✔
26
    {
27
        const auto& triangles = GetTriangles(currentNode, size, currentDir);
274✔
28

29
        for(const auto& triangle : triangles)
822✔
30
        {
31
            textures.Set(triangle, water);
548✔
32

33
            const auto& edges = GetTriangleEdges(triangle, size);
548✔
34
            for(const MapPoint& edge : edges)
2,192✔
35
            {
36
                river.insert(edge);
1,644✔
37
            }
38
        }
39

40
        if(map.z[currentNode] == map.height.minimum)
274✔
41
        {
42
            return river;
3✔
43
        }
44

45
        const auto lastDir = currentDir;
271✔
46

47
        while(currentDir == lastDir || helpers::contains(exlcuded, currentDir))
717✔
48
        {
49
            currentDir = lastDir + (rnd.ByChance(50) ? 5 : 1);
446✔
50
        }
51

52
        currentNode = map.getTextures().GetNeighbour(currentNode, lastDir);
271✔
53

54
        if(rnd.ByChance(splitRate))
271✔
55
        {
56
            auto splitDirection = direction + (rnd.ByChance(50) ? 5 : 1);
×
57
            auto anotherRivers = CreateStream(rnd, map, currentNode, splitDirection, length / 2, splitRate / 2);
×
58

59
            for(const MapPoint& node : anotherRivers)
×
60
            {
61
                river.insert(node);
×
62
            }
63
        }
64
    }
65

66
    auto seaLevel = static_cast<unsigned>(map.height.minimum);
24✔
67
    auto& z = map.z;
24✔
68

69
    for(const MapPoint& node : river)
384✔
70
    {
71
        if(z[node] > 0)
360✔
72
        {
73
            z[node] = std::max(static_cast<unsigned>(z[node] - 1), seaLevel);
360✔
74
        } else
75
        {
76
            z[node] = seaLevel;
×
77
        }
78
    }
79

80
    return river;
24✔
81
}
82

83
} // namespace rttr::mapGenerator
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc