lemon/bits/edge_set_extender.h
author Balazs Dezso <deba@inf.elte.hu>
Mon, 23 Feb 2009 11:58:39 +0100
changeset 566 c786cd201266
parent 491 68fe66e2b34a
child 606 c5fd2d996909
permissions -rw-r--r--
Fix several missing includes (#232)
deba@491
     1
/* -*- C++ -*-
deba@491
     2
 *
deba@491
     3
 * This file is a part of LEMON, a generic C++ optimization library
deba@491
     4
 *
deba@491
     5
 * Copyright (C) 2003-2008
deba@491
     6
 * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
deba@491
     7
 * (Egervary Research Group on Combinatorial Optimization, EGRES).
deba@491
     8
 *
deba@491
     9
 * Permission to use, modify and distribute this software is granted
deba@491
    10
 * provided that this copyright notice appears in all copies. For
deba@491
    11
 * precise terms see the accompanying LICENSE file.
deba@491
    12
 *
deba@491
    13
 * This software is provided "AS IS" with no warranty of any kind,
deba@491
    14
 * express or implied, and with no claim as to its suitability for any
deba@491
    15
 * purpose.
deba@491
    16
 *
deba@491
    17
 */
deba@491
    18
deba@491
    19
#ifndef LEMON_BITS_EDGE_SET_EXTENDER_H
deba@491
    20
#define LEMON_BITS_EDGE_SET_EXTENDER_H
deba@491
    21
deba@566
    22
#include <lemon/core.h>
deba@491
    23
#include <lemon/error.h>
deba@491
    24
#include <lemon/bits/default_map.h>
deba@566
    25
#include <lemon/bits/map_extender.h>
deba@491
    26
deba@491
    27
///\ingroup digraphbits
deba@491
    28
///\file
deba@491
    29
///\brief Extenders for the arc set types
deba@491
    30
namespace lemon {
deba@491
    31
deba@491
    32
  /// \ingroup digraphbits
deba@491
    33
  ///
deba@491
    34
  /// \brief Extender for the ArcSets
deba@491
    35
  template <typename Base>
deba@491
    36
  class ArcSetExtender : public Base {
deba@491
    37
  public:
deba@491
    38
deba@491
    39
    typedef Base Parent;
deba@491
    40
    typedef ArcSetExtender Digraph;
deba@491
    41
deba@491
    42
    // Base extensions
deba@491
    43
deba@491
    44
    typedef typename Parent::Node Node;
deba@491
    45
    typedef typename Parent::Arc Arc;
deba@491
    46
deba@491
    47
    int maxId(Node) const {
deba@491
    48
      return Parent::maxNodeId();
deba@491
    49
    }
deba@491
    50
deba@491
    51
    int maxId(Arc) const {
deba@491
    52
      return Parent::maxArcId();
deba@491
    53
    }
deba@491
    54
deba@491
    55
    Node fromId(int id, Node) const {
deba@491
    56
      return Parent::nodeFromId(id);
deba@491
    57
    }
deba@491
    58
deba@491
    59
    Arc fromId(int id, Arc) const {
deba@491
    60
      return Parent::arcFromId(id);
deba@491
    61
    }
deba@491
    62
deba@491
    63
    Node oppositeNode(const Node &n, const Arc &e) const {
deba@491
    64
      if (n == Parent::source(e))
deba@491
    65
	return Parent::target(e);
deba@491
    66
      else if(n==Parent::target(e))
deba@491
    67
	return Parent::source(e);
deba@491
    68
      else
deba@491
    69
	return INVALID;
deba@491
    70
    }
deba@491
    71
deba@491
    72
deba@491
    73
    // Alteration notifier extensions
deba@491
    74
deba@491
    75
    /// The arc observer registry.
deba@491
    76
    typedef AlterationNotifier<ArcSetExtender, Arc> ArcNotifier;
deba@491
    77
deba@491
    78
  protected:
deba@491
    79
deba@491
    80
    mutable ArcNotifier arc_notifier;
deba@491
    81
deba@491
    82
  public:
deba@491
    83
deba@491
    84
    using Parent::notifier;
deba@491
    85
deba@491
    86
    /// \brief Gives back the arc alteration notifier.
deba@491
    87
    ///
deba@491
    88
    /// Gives back the arc alteration notifier.
deba@491
    89
    ArcNotifier& notifier(Arc) const {
deba@491
    90
      return arc_notifier;
deba@491
    91
    }
deba@491
    92
deba@491
    93
    // Iterable extensions
deba@491
    94
deba@491
    95
    class NodeIt : public Node { 
deba@491
    96
      const Digraph* digraph;
deba@491
    97
    public:
deba@491
    98
deba@491
    99
      NodeIt() {}
deba@491
   100
deba@491
   101
      NodeIt(Invalid i) : Node(i) { }
deba@491
   102
deba@491
   103
      explicit NodeIt(const Digraph& _graph) : digraph(&_graph) {
deba@491
   104
	_graph.first(static_cast<Node&>(*this));
deba@491
   105
      }
deba@491
   106
deba@491
   107
      NodeIt(const Digraph& _graph, const Node& node) 
deba@491
   108
	: Node(node), digraph(&_graph) {}
deba@491
   109
deba@491
   110
      NodeIt& operator++() { 
deba@491
   111
	digraph->next(*this);
deba@491
   112
	return *this; 
deba@491
   113
      }
deba@491
   114
deba@491
   115
    };
deba@491
   116
deba@491
   117
deba@491
   118
    class ArcIt : public Arc { 
deba@491
   119
      const Digraph* digraph;
deba@491
   120
    public:
deba@491
   121
deba@491
   122
      ArcIt() { }
deba@491
   123
deba@491
   124
      ArcIt(Invalid i) : Arc(i) { }
deba@491
   125
deba@491
   126
      explicit ArcIt(const Digraph& _graph) : digraph(&_graph) {
deba@491
   127
	_graph.first(static_cast<Arc&>(*this));
deba@491
   128
      }
deba@491
   129
deba@491
   130
      ArcIt(const Digraph& _graph, const Arc& e) : 
deba@491
   131
	Arc(e), digraph(&_graph) { }
deba@491
   132
deba@491
   133
      ArcIt& operator++() { 
deba@491
   134
	digraph->next(*this);
deba@491
   135
	return *this; 
deba@491
   136
      }
deba@491
   137
deba@491
   138
    };
deba@491
   139
deba@491
   140
deba@491
   141
    class OutArcIt : public Arc { 
deba@491
   142
      const Digraph* digraph;
deba@491
   143
    public:
deba@491
   144
deba@491
   145
      OutArcIt() { }
deba@491
   146
deba@491
   147
      OutArcIt(Invalid i) : Arc(i) { }
deba@491
   148
deba@491
   149
      OutArcIt(const Digraph& _graph, const Node& node) 
deba@491
   150
	: digraph(&_graph) {
deba@491
   151
	_graph.firstOut(*this, node);
deba@491
   152
      }
deba@491
   153
deba@491
   154
      OutArcIt(const Digraph& _graph, const Arc& arc) 
deba@491
   155
	: Arc(arc), digraph(&_graph) {}
deba@491
   156
deba@491
   157
      OutArcIt& operator++() { 
deba@491
   158
	digraph->nextOut(*this);
deba@491
   159
	return *this; 
deba@491
   160
      }
deba@491
   161
deba@491
   162
    };
deba@491
   163
deba@491
   164
deba@491
   165
    class InArcIt : public Arc { 
deba@491
   166
      const Digraph* digraph;
deba@491
   167
    public:
deba@491
   168
deba@491
   169
      InArcIt() { }
deba@491
   170
deba@491
   171
      InArcIt(Invalid i) : Arc(i) { }
deba@491
   172
deba@491
   173
      InArcIt(const Digraph& _graph, const Node& node) 
deba@491
   174
	: digraph(&_graph) {
deba@491
   175
	_graph.firstIn(*this, node);
deba@491
   176
      }
deba@491
   177
deba@491
   178
      InArcIt(const Digraph& _graph, const Arc& arc) : 
deba@491
   179
	Arc(arc), digraph(&_graph) {}
deba@491
   180
deba@491
   181
      InArcIt& operator++() { 
deba@491
   182
	digraph->nextIn(*this);
deba@491
   183
	return *this; 
deba@491
   184
      }
deba@491
   185
deba@491
   186
    };
deba@491
   187
deba@491
   188
    /// \brief Base node of the iterator
deba@491
   189
    ///
deba@491
   190
    /// Returns the base node (ie. the source in this case) of the iterator
deba@491
   191
    Node baseNode(const OutArcIt &e) const {
deba@491
   192
      return Parent::source(static_cast<const Arc&>(e));
deba@491
   193
    }
deba@491
   194
    /// \brief Running node of the iterator
deba@491
   195
    ///
deba@491
   196
    /// Returns the running node (ie. the target in this case) of the
deba@491
   197
    /// iterator
deba@491
   198
    Node runningNode(const OutArcIt &e) const {
deba@491
   199
      return Parent::target(static_cast<const Arc&>(e));
deba@491
   200
    }
deba@491
   201
deba@491
   202
    /// \brief Base node of the iterator
deba@491
   203
    ///
deba@491
   204
    /// Returns the base node (ie. the target in this case) of the iterator
deba@491
   205
    Node baseNode(const InArcIt &e) const {
deba@491
   206
      return Parent::target(static_cast<const Arc&>(e));
deba@491
   207
    }
deba@491
   208
    /// \brief Running node of the iterator
deba@491
   209
    ///
deba@491
   210
    /// Returns the running node (ie. the source in this case) of the
deba@491
   211
    /// iterator
deba@491
   212
    Node runningNode(const InArcIt &e) const {
deba@491
   213
      return Parent::source(static_cast<const Arc&>(e));
deba@491
   214
    }
deba@491
   215
deba@491
   216
    using Parent::first;
deba@491
   217
deba@491
   218
    // Mappable extension
deba@491
   219
    
deba@491
   220
    template <typename _Value>
deba@491
   221
    class ArcMap 
deba@491
   222
      : public MapExtender<DefaultMap<Digraph, Arc, _Value> > {
deba@491
   223
    public:
deba@491
   224
      typedef ArcSetExtender Digraph;
deba@491
   225
      typedef MapExtender<DefaultMap<Digraph, Arc, _Value> > Parent;
deba@491
   226
deba@491
   227
      explicit ArcMap(const Digraph& _g) 
deba@491
   228
	: Parent(_g) {}
deba@491
   229
      ArcMap(const Digraph& _g, const _Value& _v) 
deba@491
   230
	: Parent(_g, _v) {}
deba@491
   231
deba@491
   232
      ArcMap& operator=(const ArcMap& cmap) {
deba@491
   233
	return operator=<ArcMap>(cmap);
deba@491
   234
      }
deba@491
   235
deba@491
   236
      template <typename CMap>
deba@491
   237
      ArcMap& operator=(const CMap& cmap) {
deba@491
   238
        Parent::operator=(cmap);
deba@491
   239
	return *this;
deba@491
   240
      }
deba@491
   241
deba@491
   242
    };
deba@491
   243
deba@491
   244
deba@491
   245
    // Alteration extension
deba@491
   246
deba@491
   247
    Arc addArc(const Node& from, const Node& to) {
deba@491
   248
      Arc arc = Parent::addArc(from, to);
deba@491
   249
      notifier(Arc()).add(arc);
deba@491
   250
      return arc;
deba@491
   251
    }
deba@491
   252
    
deba@491
   253
    void clear() {
deba@491
   254
      notifier(Arc()).clear();
deba@491
   255
      Parent::clear();
deba@491
   256
    }
deba@491
   257
deba@491
   258
    void erase(const Arc& arc) {
deba@491
   259
      notifier(Arc()).erase(arc);
deba@491
   260
      Parent::erase(arc);
deba@491
   261
    }
deba@491
   262
deba@491
   263
    ArcSetExtender() {
deba@491
   264
      arc_notifier.setContainer(*this);
deba@491
   265
    }
deba@491
   266
deba@491
   267
    ~ArcSetExtender() {
deba@491
   268
      arc_notifier.clear();
deba@491
   269
    }
deba@491
   270
deba@491
   271
  };
deba@491
   272
deba@491
   273
deba@491
   274
  /// \ingroup digraphbits
deba@491
   275
  ///
deba@491
   276
  /// \brief Extender for the EdgeSets
deba@491
   277
  template <typename Base>
deba@491
   278
  class EdgeSetExtender : public Base {
deba@491
   279
deba@491
   280
  public:
deba@491
   281
deba@491
   282
    typedef Base Parent;
deba@491
   283
    typedef EdgeSetExtender Digraph;
deba@491
   284
deba@491
   285
    typedef typename Parent::Node Node;
deba@491
   286
    typedef typename Parent::Arc Arc;
deba@491
   287
    typedef typename Parent::Edge Edge;
deba@491
   288
deba@491
   289
deba@491
   290
    int maxId(Node) const {
deba@491
   291
      return Parent::maxNodeId();
deba@491
   292
    }
deba@491
   293
deba@491
   294
    int maxId(Arc) const {
deba@491
   295
      return Parent::maxArcId();
deba@491
   296
    }
deba@491
   297
deba@491
   298
    int maxId(Edge) const {
deba@491
   299
      return Parent::maxEdgeId();
deba@491
   300
    }
deba@491
   301
deba@491
   302
    Node fromId(int id, Node) const {
deba@491
   303
      return Parent::nodeFromId(id);
deba@491
   304
    }
deba@491
   305
deba@491
   306
    Arc fromId(int id, Arc) const {
deba@491
   307
      return Parent::arcFromId(id);
deba@491
   308
    }
deba@491
   309
deba@491
   310
    Edge fromId(int id, Edge) const {
deba@491
   311
      return Parent::edgeFromId(id);
deba@491
   312
    }
deba@491
   313
deba@491
   314
    Node oppositeNode(const Node &n, const Edge &e) const {
deba@491
   315
      if( n == Parent::u(e))
deba@491
   316
	return Parent::v(e);
deba@491
   317
      else if( n == Parent::v(e))
deba@491
   318
	return Parent::u(e);
deba@491
   319
      else
deba@491
   320
	return INVALID;
deba@491
   321
    }
deba@491
   322
deba@491
   323
    Arc oppositeArc(const Arc &e) const {
deba@491
   324
      return Parent::direct(e, !Parent::direction(e));
deba@491
   325
    }
deba@491
   326
deba@491
   327
    using Parent::direct;
deba@491
   328
    Arc direct(const Edge &e, const Node &s) const {
deba@491
   329
      return Parent::direct(e, Parent::u(e) == s);
deba@491
   330
    }
deba@491
   331
deba@491
   332
    typedef AlterationNotifier<EdgeSetExtender, Arc> ArcNotifier;
deba@491
   333
    typedef AlterationNotifier<EdgeSetExtender, Edge> EdgeNotifier;
deba@491
   334
deba@491
   335
deba@491
   336
  protected:
deba@491
   337
deba@491
   338
    mutable ArcNotifier arc_notifier;
deba@491
   339
    mutable EdgeNotifier edge_notifier;
deba@491
   340
deba@491
   341
  public:
deba@491
   342
deba@491
   343
    using Parent::notifier;
deba@491
   344
    
deba@491
   345
    ArcNotifier& notifier(Arc) const {
deba@491
   346
      return arc_notifier;
deba@491
   347
    }
deba@491
   348
deba@491
   349
    EdgeNotifier& notifier(Edge) const {
deba@491
   350
      return edge_notifier;
deba@491
   351
    }
deba@491
   352
deba@491
   353
deba@491
   354
    class NodeIt : public Node { 
deba@491
   355
      const Digraph* digraph;
deba@491
   356
    public:
deba@491
   357
deba@491
   358
      NodeIt() {}
deba@491
   359
deba@491
   360
      NodeIt(Invalid i) : Node(i) { }
deba@491
   361
deba@491
   362
      explicit NodeIt(const Digraph& _graph) : digraph(&_graph) {
deba@491
   363
	_graph.first(static_cast<Node&>(*this));
deba@491
   364
      }
deba@491
   365
deba@491
   366
      NodeIt(const Digraph& _graph, const Node& node) 
deba@491
   367
	: Node(node), digraph(&_graph) {}
deba@491
   368
deba@491
   369
      NodeIt& operator++() { 
deba@491
   370
	digraph->next(*this);
deba@491
   371
	return *this; 
deba@491
   372
      }
deba@491
   373
deba@491
   374
    };
deba@491
   375
deba@491
   376
deba@491
   377
    class ArcIt : public Arc { 
deba@491
   378
      const Digraph* digraph;
deba@491
   379
    public:
deba@491
   380
deba@491
   381
      ArcIt() { }
deba@491
   382
deba@491
   383
      ArcIt(Invalid i) : Arc(i) { }
deba@491
   384
deba@491
   385
      explicit ArcIt(const Digraph& _graph) : digraph(&_graph) {
deba@491
   386
	_graph.first(static_cast<Arc&>(*this));
deba@491
   387
      }
deba@491
   388
deba@491
   389
      ArcIt(const Digraph& _graph, const Arc& e) : 
deba@491
   390
	Arc(e), digraph(&_graph) { }
deba@491
   391
deba@491
   392
      ArcIt& operator++() { 
deba@491
   393
	digraph->next(*this);
deba@491
   394
	return *this; 
deba@491
   395
      }
deba@491
   396
deba@491
   397
    };
deba@491
   398
deba@491
   399
deba@491
   400
    class OutArcIt : public Arc { 
deba@491
   401
      const Digraph* digraph;
deba@491
   402
    public:
deba@491
   403
deba@491
   404
      OutArcIt() { }
deba@491
   405
deba@491
   406
      OutArcIt(Invalid i) : Arc(i) { }
deba@491
   407
deba@491
   408
      OutArcIt(const Digraph& _graph, const Node& node) 
deba@491
   409
	: digraph(&_graph) {
deba@491
   410
	_graph.firstOut(*this, node);
deba@491
   411
      }
deba@491
   412
deba@491
   413
      OutArcIt(const Digraph& _graph, const Arc& arc) 
deba@491
   414
	: Arc(arc), digraph(&_graph) {}
deba@491
   415
deba@491
   416
      OutArcIt& operator++() { 
deba@491
   417
	digraph->nextOut(*this);
deba@491
   418
	return *this; 
deba@491
   419
      }
deba@491
   420
deba@491
   421
    };
deba@491
   422
deba@491
   423
deba@491
   424
    class InArcIt : public Arc { 
deba@491
   425
      const Digraph* digraph;
deba@491
   426
    public:
deba@491
   427
deba@491
   428
      InArcIt() { }
deba@491
   429
deba@491
   430
      InArcIt(Invalid i) : Arc(i) { }
deba@491
   431
deba@491
   432
      InArcIt(const Digraph& _graph, const Node& node) 
deba@491
   433
	: digraph(&_graph) {
deba@491
   434
	_graph.firstIn(*this, node);
deba@491
   435
      }
deba@491
   436
deba@491
   437
      InArcIt(const Digraph& _graph, const Arc& arc) : 
deba@491
   438
	Arc(arc), digraph(&_graph) {}
deba@491
   439
deba@491
   440
      InArcIt& operator++() { 
deba@491
   441
	digraph->nextIn(*this);
deba@491
   442
	return *this; 
deba@491
   443
      }
deba@491
   444
deba@491
   445
    };
deba@491
   446
deba@491
   447
deba@491
   448
    class EdgeIt : public Parent::Edge { 
deba@491
   449
      const Digraph* digraph;
deba@491
   450
    public:
deba@491
   451
deba@491
   452
      EdgeIt() { }
deba@491
   453
deba@491
   454
      EdgeIt(Invalid i) : Edge(i) { }
deba@491
   455
deba@491
   456
      explicit EdgeIt(const Digraph& _graph) : digraph(&_graph) {
deba@491
   457
	_graph.first(static_cast<Edge&>(*this));
deba@491
   458
      }
deba@491
   459
deba@491
   460
      EdgeIt(const Digraph& _graph, const Edge& e) : 
deba@491
   461
	Edge(e), digraph(&_graph) { }
deba@491
   462
deba@491
   463
      EdgeIt& operator++() { 
deba@491
   464
	digraph->next(*this);
deba@491
   465
	return *this; 
deba@491
   466
      }
deba@491
   467
deba@491
   468
    };
deba@491
   469
deba@491
   470
    class IncEdgeIt : public Parent::Edge {
deba@491
   471
      friend class EdgeSetExtender;
deba@491
   472
      const Digraph* digraph;
deba@491
   473
      bool direction;
deba@491
   474
    public:
deba@491
   475
deba@491
   476
      IncEdgeIt() { }
deba@491
   477
deba@491
   478
      IncEdgeIt(Invalid i) : Edge(i), direction(false) { }
deba@491
   479
deba@491
   480
      IncEdgeIt(const Digraph& _graph, const Node &n) : digraph(&_graph) {
deba@491
   481
	_graph.firstInc(*this, direction, n);
deba@491
   482
      }
deba@491
   483
deba@491
   484
      IncEdgeIt(const Digraph& _graph, const Edge &ue, const Node &n)
deba@491
   485
	: digraph(&_graph), Edge(ue) {
deba@491
   486
	direction = (_graph.source(ue) == n);
deba@491
   487
      }
deba@491
   488
deba@491
   489
      IncEdgeIt& operator++() {
deba@491
   490
	digraph->nextInc(*this, direction);
deba@491
   491
	return *this; 
deba@491
   492
      }
deba@491
   493
    };
deba@491
   494
deba@491
   495
    /// \brief Base node of the iterator
deba@491
   496
    ///
deba@491
   497
    /// Returns the base node (ie. the source in this case) of the iterator
deba@491
   498
    Node baseNode(const OutArcIt &e) const {
deba@491
   499
      return Parent::source(static_cast<const Arc&>(e));
deba@491
   500
    }
deba@491
   501
    /// \brief Running node of the iterator
deba@491
   502
    ///
deba@491
   503
    /// Returns the running node (ie. the target in this case) of the
deba@491
   504
    /// iterator
deba@491
   505
    Node runningNode(const OutArcIt &e) const {
deba@491
   506
      return Parent::target(static_cast<const Arc&>(e));
deba@491
   507
    }
deba@491
   508
deba@491
   509
    /// \brief Base node of the iterator
deba@491
   510
    ///
deba@491
   511
    /// Returns the base node (ie. the target in this case) of the iterator
deba@491
   512
    Node baseNode(const InArcIt &e) const {
deba@491
   513
      return Parent::target(static_cast<const Arc&>(e));
deba@491
   514
    }
deba@491
   515
    /// \brief Running node of the iterator
deba@491
   516
    ///
deba@491
   517
    /// Returns the running node (ie. the source in this case) of the
deba@491
   518
    /// iterator
deba@491
   519
    Node runningNode(const InArcIt &e) const {
deba@491
   520
      return Parent::source(static_cast<const Arc&>(e));
deba@491
   521
    }
deba@491
   522
deba@491
   523
    /// Base node of the iterator
deba@491
   524
    ///
deba@491
   525
    /// Returns the base node of the iterator
deba@491
   526
    Node baseNode(const IncEdgeIt &e) const {
deba@491
   527
      return e.direction ? u(e) : v(e);
deba@491
   528
    }
deba@491
   529
    /// Running node of the iterator
deba@491
   530
    ///
deba@491
   531
    /// Returns the running node of the iterator
deba@491
   532
    Node runningNode(const IncEdgeIt &e) const {
deba@491
   533
      return e.direction ? v(e) : u(e);
deba@491
   534
    }
deba@491
   535
deba@491
   536
deba@491
   537
    template <typename _Value>
deba@491
   538
    class ArcMap 
deba@491
   539
      : public MapExtender<DefaultMap<Digraph, Arc, _Value> > {
deba@491
   540
    public:
deba@491
   541
      typedef EdgeSetExtender Digraph;
deba@491
   542
      typedef MapExtender<DefaultMap<Digraph, Arc, _Value> > Parent;
deba@491
   543
deba@491
   544
      ArcMap(const Digraph& _g) 
deba@491
   545
	: Parent(_g) {}
deba@491
   546
      ArcMap(const Digraph& _g, const _Value& _v) 
deba@491
   547
	: Parent(_g, _v) {}
deba@491
   548
deba@491
   549
      ArcMap& operator=(const ArcMap& cmap) {
deba@491
   550
	return operator=<ArcMap>(cmap);
deba@491
   551
      }
deba@491
   552
deba@491
   553
      template <typename CMap>
deba@491
   554
      ArcMap& operator=(const CMap& cmap) {
deba@491
   555
        Parent::operator=(cmap);
deba@491
   556
	return *this;
deba@491
   557
      }
deba@491
   558
deba@491
   559
    };
deba@491
   560
deba@491
   561
deba@491
   562
    template <typename _Value>
deba@491
   563
    class EdgeMap 
deba@491
   564
      : public MapExtender<DefaultMap<Digraph, Edge, _Value> > {
deba@491
   565
    public:
deba@491
   566
      typedef EdgeSetExtender Digraph;
deba@491
   567
      typedef MapExtender<DefaultMap<Digraph, Edge, _Value> > Parent;
deba@491
   568
deba@491
   569
      EdgeMap(const Digraph& _g) 
deba@491
   570
	: Parent(_g) {}
deba@491
   571
deba@491
   572
      EdgeMap(const Digraph& _g, const _Value& _v) 
deba@491
   573
	: Parent(_g, _v) {}
deba@491
   574
deba@491
   575
      EdgeMap& operator=(const EdgeMap& cmap) {
deba@491
   576
	return operator=<EdgeMap>(cmap);
deba@491
   577
      }
deba@491
   578
deba@491
   579
      template <typename CMap>
deba@491
   580
      EdgeMap& operator=(const CMap& cmap) {
deba@491
   581
        Parent::operator=(cmap);
deba@491
   582
	return *this;
deba@491
   583
      }
deba@491
   584
deba@491
   585
    };
deba@491
   586
deba@491
   587
deba@491
   588
    // Alteration extension
deba@491
   589
deba@491
   590
    Edge addEdge(const Node& from, const Node& to) {
deba@491
   591
      Edge edge = Parent::addEdge(from, to);
deba@491
   592
      notifier(Edge()).add(edge);
deba@491
   593
      std::vector<Arc> arcs;
deba@491
   594
      arcs.push_back(Parent::direct(edge, true));
deba@491
   595
      arcs.push_back(Parent::direct(edge, false));
deba@491
   596
      notifier(Arc()).add(arcs);
deba@491
   597
      return edge;
deba@491
   598
    }
deba@491
   599
    
deba@491
   600
    void clear() {
deba@491
   601
      notifier(Arc()).clear();
deba@491
   602
      notifier(Edge()).clear();
deba@491
   603
      Parent::clear();
deba@491
   604
    }
deba@491
   605
deba@491
   606
    void erase(const Edge& edge) {
deba@491
   607
      std::vector<Arc> arcs;
deba@491
   608
      arcs.push_back(Parent::direct(edge, true));
deba@491
   609
      arcs.push_back(Parent::direct(edge, false));
deba@491
   610
      notifier(Arc()).erase(arcs);
deba@491
   611
      notifier(Edge()).erase(edge);
deba@491
   612
      Parent::erase(edge);
deba@491
   613
    }
deba@491
   614
deba@491
   615
deba@491
   616
    EdgeSetExtender() {
deba@491
   617
      arc_notifier.setContainer(*this);
deba@491
   618
      edge_notifier.setContainer(*this);
deba@491
   619
    }
deba@491
   620
deba@491
   621
    ~EdgeSetExtender() {
deba@491
   622
      edge_notifier.clear();
deba@491
   623
      arc_notifier.clear();
deba@491
   624
    }
deba@491
   625
    
deba@491
   626
  };
deba@491
   627
deba@491
   628
}
deba@491
   629
deba@491
   630
#endif