70 lines
2.7 KiB
C++
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
|