/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2012 NBEE Embedded Systems, Miguel Angel Ajo * Copyright (C) 1992-2012 KiCad Developers, see AUTHORS.txt for contributors. * * 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 2 * 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, you may find one here: * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * or you may search the http://www.gnu.org website for the version 2 license, * or you may write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ /** * @file units.i * @brief unit conversion code */ // Unit conversion, must be conditionally adapter to the new // nanometer mode that will be soon included in pcbnew %pythoncode { def ToMM(iu): if type(iu) in [int,float]: return iu * 0.00254 elif type(iu) in [wxPoint,wxSize]: return tuple(map(ToMM,iu)) def FromMM(iu): if type(iu) in [int,float]: return iu / 0.00254 elif type(iu) in [wxPoint,wxSize]: return tuple(map(FromMM,iu)) def ToMils(iu): if type(iu) in [int,float]: return iu / 10.0 elif type(iu) in [wxPoint,wxSize]: return tuple(map(ToMils,iu)) def FromMils(iu): if type(iu) in [int,float]: return mils*10.0 elif type(iu) in [wxPoint,wxSize]: return tuple(map(FromMils,iu)) def wxSizeMM(mmx,mmy): return wxSize(FromMM(mmx),FromMM(mmy)) def wxSizeMils(mmx,mmy): return wxSize(FromMils(mmx),FromMils(mmy)) def wxPointMM(mmx,mmy): return wxPoint(FromMM(mmx),FromMM(mmy)) def wxPointMils(mmx,mmy): return wxPoint(FromMils(mmx),FromMils(mmy)) def wxRectMM(x,y,wx,wy): x = int(FromMM(x)) y = int(FromMM(y)) wx = int(FromMM(wx)) wy = int (FromMM(wy)) return wxRect(x,y,wx,wy) def wxRectMils(x,y,wx,wy): x = int(FromMils(x)) y = int(FromMils(y)) wx = int(FromMils(wx)) wy = int (FromMils(wy)) return wxRect(x,y,wx,wy) }