summaryrefslogtreecommitdiff
path: root/pcbnew/router/pns_layerset.h
diff options
context:
space:
mode:
authorsaurabhb172020-02-26 16:01:28 +0530
committerGitHub2020-02-26 16:01:28 +0530
commitd51317f0193609fb43e932730d78aa86a4984083 (patch)
tree6acee185a4dc19113fcbf0f9a3d6941085dedaf7 /pcbnew/router/pns_layerset.h
parent0db48f6533517ecebfd9f0693f89deca28408b76 (diff)
parent886d9cb772e81d2e5262284bc3082664f084337f (diff)
downloadKiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.gz
KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.bz2
KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.zip
Merge pull request #2 from FOSSEE/develop
Develop
Diffstat (limited to 'pcbnew/router/pns_layerset.h')
-rw-r--r--pcbnew/router/pns_layerset.h129
1 files changed, 129 insertions, 0 deletions
diff --git a/pcbnew/router/pns_layerset.h b/pcbnew/router/pns_layerset.h
new file mode 100644
index 0000000..9d01dd1
--- /dev/null
+++ b/pcbnew/router/pns_layerset.h
@@ -0,0 +1,129 @@
+/*
+ * KiRouter - a push-and-(sometimes-)shove PCB router
+ *
+ * Copyright (C) 2013-2014 CERN
+ * Author: Tomasz Wlostowski <tomasz.wlostowski@cern.ch>
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __PNS_LAYERSET_H
+#define __PNS_LAYERSET_H
+
+#include <algorithm>
+
+/**
+ * Class PNS_LAYERSET
+ *
+ * Represents a contiguous set of PCB layers.
+ */
+class PNS_LAYERSET
+{
+public:
+ PNS_LAYERSET() :
+ m_start( -1 ),
+ m_end( -1 )
+ {};
+
+ PNS_LAYERSET( int aStart, int aEnd )
+ {
+ if( aStart > aEnd )
+ std::swap( aStart, aEnd );
+
+ m_start = aStart;
+ m_end = aEnd;
+ }
+
+ PNS_LAYERSET( int aLayer )
+ {
+ m_start = m_end = aLayer;
+ }
+
+ PNS_LAYERSET( const PNS_LAYERSET& aB ) :
+ m_start( aB.m_start ),
+ m_end( aB.m_end )
+ {}
+
+ ~PNS_LAYERSET() {};
+
+ const PNS_LAYERSET& operator=( const PNS_LAYERSET& aB )
+ {
+ m_start = aB.m_start;
+ m_end = aB.m_end;
+ return *this;
+ }
+
+ bool Overlaps( const PNS_LAYERSET& aOther ) const
+ {
+ return m_end >= aOther.m_start && m_start <= aOther.m_end;
+ }
+
+ bool Overlaps( const int aLayer ) const
+ {
+ return aLayer >= m_start && aLayer <= m_end;
+ }
+
+ bool IsMultilayer() const
+ {
+ return m_start != m_end;
+ }
+
+ int Start() const
+ {
+ return m_start;
+ }
+
+ int End() const
+ {
+ return m_end;
+ }
+
+ void Merge( const PNS_LAYERSET& aOther )
+ {
+ if( m_start < 0 || m_end < 0 )
+ {
+ m_start = aOther.m_start;
+ m_end = aOther.m_end;
+ return;
+ }
+
+ if( aOther.m_start < m_start )
+ m_start = aOther.m_start;
+
+ if( aOther.m_end > m_end )
+ m_end = aOther.m_end;
+ }
+
+ ///> Shortcut for comparisons/overlap tests
+ static PNS_LAYERSET All()
+ {
+ return PNS_LAYERSET( 0, 256 ); // fixme: use layer IDs header
+ }
+
+ bool operator==( const PNS_LAYERSET& aOther ) const
+ {
+ return ( m_start == aOther.m_start ) && ( m_end == aOther.m_end );
+ }
+
+ bool operator!=( const PNS_LAYERSET& aOther ) const
+ {
+ return ( m_start != aOther.m_start ) || ( m_end != aOther.m_end );
+ }
+
+private:
+ int m_start;
+ int m_end;
+};
+
+#endif // __PNS_LAYERSET_H