Coverage Report

Created: 2025-12-08 09:28

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libreoffice/sc/inc/tabopparams.hxx
Line
Count
Source
1
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
/*
3
 * This file is part of the LibreOffice project.
4
 *
5
 * This Source Code Form is subject to the terms of the Mozilla Public
6
 * License, v. 2.0. If a copy of the MPL was not distributed with this
7
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8
 *
9
 * This file incorporates work covered by the following license notice:
10
 *
11
 *   Licensed to the Apache Software Foundation (ASF) under one or more
12
 *   contributor license agreements. See the NOTICE file distributed
13
 *   with this work for additional information regarding copyright
14
 *   ownership. The ASF licenses this file to you under the Apache
15
 *   License, Version 2.0 (the "License"); you may not use this file
16
 *   except in compliance with the License. You may obtain a copy of
17
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
18
 */
19
20
#pragma once
21
22
#include "address.hxx"
23
24
#include <vector>
25
26
class ScFormulaCell;
27
28
struct ScInterpreterTableOpParams
29
{
30
    ScAddress   aOld1;
31
    ScAddress   aNew1;
32
    ScAddress   aOld2;
33
    ScAddress   aNew2;
34
    ScAddress   aFormulaPos;
35
    ::std::vector< ScFormulaCell* > aNotifiedFormulaCells;
36
    ::std::vector< ScAddress >      aNotifiedFormulaPos;
37
    bool        bValid;
38
    bool        bRefresh;
39
    bool        bCollectNotifications;
40
41
    ScInterpreterTableOpParams()
42
299k
            : bValid( false )
43
299k
            , bRefresh( false )
44
299k
            , bCollectNotifications( true )
45
299k
    {
46
299k
    }
47
48
    ScInterpreterTableOpParams( const ScInterpreterTableOpParams& r )
49
            : aOld1(                 r.aOld1 )
50
            , aNew1(                 r.aNew1 )
51
            , aOld2(                 r.aOld2 )
52
            , aNew2(                 r.aNew2 )
53
            , aFormulaPos(           r.aFormulaPos )
54
            , aNotifiedFormulaPos(   r.aNotifiedFormulaPos )
55
            , bValid(                r.bValid )
56
            , bRefresh(              r.bRefresh )
57
            , bCollectNotifications( r.bCollectNotifications )
58
0
    {
59
0
    }
60
61
    ScInterpreterTableOpParams& operator =( const ScInterpreterTableOpParams& r )
62
91
    {
63
91
        aOld1                 = r.aOld1;
64
91
        aNew1                 = r.aNew1;
65
91
        aOld2                 = r.aOld2;
66
91
        aNew2                 = r.aNew2;
67
91
        aFormulaPos           = r.aFormulaPos;
68
91
        ::std::vector< ScFormulaCell* >().swap( aNotifiedFormulaCells );
69
91
        aNotifiedFormulaPos   = r.aNotifiedFormulaPos;
70
91
        bValid                = r.bValid;
71
91
        bRefresh              = r.bRefresh;
72
91
        bCollectNotifications = r.bCollectNotifications;
73
91
        return *this;
74
91
    }
75
76
    bool operator ==( const ScInterpreterTableOpParams& r ) const
77
111k
    {
78
111k
        return
79
111k
            bValid && r.bValid &&
80
111k
            aOld1       == r.aOld1 &&
81
111k
            aOld2       == r.aOld2 &&
82
111k
            aFormulaPos == r.aFormulaPos ;
83
111k
    }
84
};
85
86
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */