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

Return-To-The-Roots / s25client / 4215597188

pending completion
4215597188

push

github

Alexander Grund
s25update submodule update: libCURL 7.32+ fix

22052 of 42816 relevant lines covered (51.5%)

32537.17 hits per line

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

96.97
/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 { namespace mapGenerator {
10

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

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

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

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

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

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

33
                const auto& edges = GetTriangleEdges(triangle, size);
938✔
34
                for(const MapPoint& edge : edges)
3,752✔
35
                {
36
                    river.insert(edge);
2,814✔
37
                }
38
            }
39

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

45
            const auto lastDir = currentDir;
458✔
46

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

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

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

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

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

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

80
        return river;
25✔
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