File: RiseFallValues.hh

package info (click to toggle)
opensta 0~20191111gitc018cb2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, sid
  • size: 5,116 kB
  • sloc: cpp: 99,117; tcl: 8,530; yacc: 1,435; lex: 894; makefile: 541; sh: 107
file content (49 lines) | stat: -rw-r--r-- 1,550 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// OpenSTA, Static Timing Analyzer
// Copyright (c) 2019, Parallax Software, Inc.
// 
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// 
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
// 
// You should have received a copy of the GNU General Public License
// along with this program.  If not, see <https://www.gnu.org/licenses/>.

#ifndef STA_RISE_FALL_VALUES_H
#define STA_RISE_FALL_VALUES_H

#include "DisallowCopyAssign.hh"
#include "Transition.hh"

namespace sta {

// Rise/fall group of two values.
class RiseFallValues
{
public:
  RiseFallValues();
  explicit RiseFallValues(float init_value);
  float value(const TransRiseFall *tr) const;
  void value(const TransRiseFall *tr,
	     float &value, bool &exists) const;
  bool hasValue(const TransRiseFall *tr) const;
  void setValue(const TransRiseFallBoth *tr, float value);
  void setValue(const TransRiseFall *tr, float value);
  void setValue(float value);
  void setValues(RiseFallValues *values);
  void clear();

private:
  DISALLOW_COPY_AND_ASSIGN(RiseFallValues);

  float values_[TransRiseFall::index_count];
  bool exists_[TransRiseFall::index_count];
};

} // namespace
#endif