coriolis/anabatic/src/anabatic/AutoContactVTee.h

70 lines
2.7 KiB
C++

// -*- C++ -*-
//
// This file is part of the Coriolis Software.
// Copyright (c) UPMC 2012-2016, All Rights Reserved
//
// +-----------------------------------------------------------------+
// | C O R I O L I S |
// | A n a b a t i c - Routing Toolbox |
// | |
// | Author : Jean-Paul CHAPUT |
// | E-mail : Jean-Paul.Chaput@lip6.fr |
// | =============================================================== |
// | C++ Header : "./anabatic/AutoContactVTee.h" |
// +-----------------------------------------------------------------+
#ifndef ANABATIC_AUTOCONTACT_VTEE_H
#define ANABATIC_AUTOCONTACT_VTEE_H
#include "anabatic/AutoContact.h"
namespace Anabatic {
// -------------------------------------------------------------------
// Class : "Anabatic::AutoContactVTee".
class AutoContactVTee : public AutoContact {
typedef AutoContact Super;
friend class AutoContact;
public:
static AutoContactVTee* create ( GCell*, Net*, const Layer* );
protected:
// Constructors & Destructors.
AutoContactVTee ( GCell*, Contact* );
virtual ~AutoContactVTee ();
virtual void _invalidate ( Flags flags );
public:
virtual AutoHorizontal* getHorizontal1 () const;
virtual AutoVertical* getVertical1 () const;
virtual AutoVertical* getVertical2 () const;
virtual AutoSegment* getOpposite ( const AutoSegment* ) const;
virtual AutoSegment* getPerpandicular ( const AutoSegment* ) const;
virtual AutoSegment* getSegment ( unsigned int ) const;
virtual void updateGeometry ();
virtual void updateTopology ();
virtual void cacheDetach ( AutoSegment* );
virtual void cacheAttach ( AutoSegment* );
virtual void updateCache ();
virtual string _getTypeName () const;
private:
AutoContactVTee ( const AutoContactVTee& );
AutoContactVTee& operator= ( const AutoContactVTee& );
private:
AutoHorizontal* _horizontal1;
AutoVertical* _vertical1;
AutoVertical* _vertical2;
};
} // Anabatic namespace.
INSPECTOR_P_SUPPORT(Anabatic::AutoContactVTee);
#endif // ANABATIC_AUTOCONTACT_VTEE_H