Coverage Report

Created: 2026-02-14 06:52

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/gdal/apps/gdalalg_raster_zonal_stats.h
Line
Count
Source
1
/******************************************************************************
2
 *
3
 * Project:  GDAL
4
 * Purpose:  gdal "raster zonal-stats" subcommand
5
 * Author:   Dan Baston
6
 *
7
 ******************************************************************************
8
 * Copyright (c) 2025, ISciences LLC
9
 *
10
 * SPDX-License-Identifier: MIT
11
 ****************************************************************************/
12
13
#ifndef GDALALG_RASTER_ZONAL_STATS_INCLUDED
14
#define GDALALG_RASTER_ZONAL_STATS_INCLUDED
15
16
#include "gdalalg_abstract_pipeline.h"
17
18
//! @cond Doxygen_Suppress
19
20
/************************************************************************/
21
/*                    GDALRasterZonalStatsAlgorithm                     */
22
/************************************************************************/
23
24
class GDALRasterZonalStatsAlgorithm /* non final */
25
    : public GDALPipelineStepAlgorithm
26
{
27
  public:
28
    static constexpr const char *NAME = "zonal-stats";
29
    static constexpr const char *DESCRIPTION =
30
        "Calculate raster zonal statistics";
31
    static constexpr const char *HELP_URL =
32
        "/programs/gdal_raster_zonal_stats.html";
33
34
    explicit GDALRasterZonalStatsAlgorithm(bool bStandalone = false);
35
36
    int GetInputType() const override
37
0
    {
38
0
        return GDAL_OF_RASTER;
39
0
    }
40
41
    int GetOutputType() const override
42
0
    {
43
0
        return GDAL_OF_VECTOR;
44
0
    }
45
46
  private:
47
    bool RunStep(GDALPipelineStepRunContext &ctxt) override;
48
    bool RunImpl(GDALProgressFunc pfnProgress, void *pProgressData) override;
49
50
    GDALArgDatasetValue m_weights{};
51
    GDALArgDatasetValue m_zones{};
52
    std::string m_zonesLayer{};
53
    int m_zonesBand{0};
54
    std::vector<int> m_bands{};
55
    std::vector<std::string> m_stats{};
56
    std::vector<std::string> m_includeFields{};
57
    std::string m_strategy{};
58
    std::string m_memoryStr{"5%"};
59
    std::string m_pixels{"default"};
60
    int m_weightsBand{0};
61
    size_t m_memoryBytes{
62
        static_cast<size_t>(100) * 1024 *
63
        1024};  // FIXME validation action doesn't seem to run if arg isn't specified, so this never gets sets?
64
};
65
66
/************************************************************************/
67
/*               GDALRasterZonalStatsAlgorithmStandalone                */
68
/************************************************************************/
69
70
class GDALRasterZonalStatsAlgorithmStandalone final
71
    : public GDALRasterZonalStatsAlgorithm
72
{
73
  public:
74
    GDALRasterZonalStatsAlgorithmStandalone()
75
0
        : GDALRasterZonalStatsAlgorithm(/* standaloneStep = */ true)
76
0
    {
77
0
    }
78
79
    ~GDALRasterZonalStatsAlgorithmStandalone() override;
80
};
81
82
//! @endcond
83
84
#endif