File: constraint.cpp

package info (click to toggle)
tulip 6.0.1%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 196,224 kB
  • sloc: cpp: 571,851; ansic: 13,983; python: 4,105; sh: 1,555; yacc: 522; xml: 484; makefile: 168; pascal: 148; lex: 55
file content (45 lines) | stat: -rw-r--r-- 1,150 bytes parent folder | download | duplicates (2)
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
/**
 * \brief A constraint determines a minimum or exact spacing required between
 * two variables.
 *
 * Authors:
 *   Tim Dwyer <tgdwyer@gmail.com>
 *
 * Copyright (C) 2005 Authors
 *
 * Released under GNU LGPL.  Read the file 'COPYING' for more information.
 */

#include "constraint.h"
#include <cassert>
namespace vpsc {
Constraint::Constraint(Variable *left, Variable *right, double gap, bool equality)
    : left(left), right(right), gap(gap), lm(0), timeStamp(0), active(false), visited(false),
      equality(equality) {
  left->out.push_back(this);
  right->in.push_back(this);
}
Constraint::~Constraint() {
  Constraints::iterator i;

  for (i = left->out.begin(); i != left->out.end(); ++i) {
    if (*i == this)
      break;
  }

  left->out.erase(i);

  for (i = right->in.begin(); i != right->in.end(); ++i) {
    if (*i == this)
      break;
  }

  right->in.erase(i);
}
std::ostream &operator<<(std::ostream &os, const Constraint &c) {
  const char *type = c.equality ? "=" : "<=";
  os << *c.left << "+" << c.gap << type << *c.right << "(" << c.slack() << ")"
     << (c.active ? "-active" : "");
  return os;
}
} // namespace vpsc