29#include <wx/translation.h>
34 int len = aText.length();
37 while( --len > 0 && aText[len] ==
'0' )
40 if( len >= 0 && ( aText[len] ==
'.' || aText[len] ==
',' ) )
43 aText = aText.RemoveLast( removeLast );
78 return KiROUND( aVal * 1000. / 25.4 );
84 return KiROUND( aVal * 25.4 / 1000. );
90 wxString buf( aTextValue.Strip( wxString::both ) );
91 unsigned brk_point = 0;
93 while( brk_point < buf.Len() )
95 wxChar c = buf[brk_point];
97 if( !( ( c >=
'0' && c <=
'9' ) || ( c ==
'.' ) || ( c ==
',' ) || ( c ==
'-' )
105 wxString unit( buf.Mid( brk_point ).Strip( wxString::leading ).Left( 2 ).Lower() );
108 if( unit == wxT(
"um" ) || unit == wxT(
"\u00B5m" ) || unit == wxT(
"\u03BCm" ) )
110 else if( unit == wxT(
"mm" ) )
112 if( unit == wxT(
"cm" ) )
114 else if( unit == wxT(
"mi" ) || unit == wxT(
"th" ) )
116 else if( unit == wxT(
"in" ) || unit == wxT(
"\"" ) )
118 else if( unit == wxT(
"de" ) || unit == wxT(
"ra" ) )
158 return GetText( aUnits, aType ).Trim(
false );
164 std::string temp = fmt::format(
"{:.10g}", aAngle.
AsDegrees() );
173 double engUnits = aValue;
177 if( engUnits != 0.0 && fabs( engUnits ) <= 0.0001 )
179 buf = fmt::format(
"{:.10f}", engUnits );
182 while( !buf.empty() && buf[buf.size() - 1] ==
'0' )
189 if( buf[buf.size() - 1] ==
'.' )
196 buf = fmt::format(
"{:.10g}", engUnits );
213bool EDA_UNIT_UTILS::ParseInternalUnits(
const std::string& aInput,
const EDA_IU_SCALE& aIuScale,
218 if( std::from_chars( aInput.data(), aInput.data() + aInput.size(), value ).ec != std::errc() )
226bool EDA_UNIT_UTILS::ParseInternalUnits(
const std::string& aInput,
const EDA_IU_SCALE& aIuScale,
229 size_t pos = aInput.find(
' ' );
231 if( pos == std::string::npos )
234 std::string first = aInput.substr( 0, pos );
235 std::string second = aInput.substr( pos + 1 );
239 if( !ParseInternalUnits( first, aIuScale, vec.
x ) )
242 if( !ParseInternalUnits( second, aIuScale, vec.
y ) )
253#define IU_TO_MM( x, scale ) ( x / scale.IU_PER_MM )
254#define IU_TO_IN( x, scale ) ( x / scale.IU_PER_MILS / 1000 )
255#define IU_TO_MILS( x, scale ) ( x / scale.IU_PER_MILS )
256#define MM_TO_IU( x, scale ) ( x * scale.IU_PER_MM )
257#define IN_TO_IU( x, scale ) ( x * scale.IU_PER_MILS * 1000 )
258#define MILS_TO_IU( x, scale ) ( x * scale.IU_PER_MILS )
267 return IU_TO_MM( aValue, aIuScale ) * 1000;
270 return IU_TO_MM( aValue, aIuScale );
273 return IU_TO_MM( aValue, aIuScale ) / 10;
279 return IU_TO_IN( aValue, aIuScale );
291 double aValue,
bool aAddUnitsText,
294 double value_to_print = aValue;
300 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
304 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
308 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
315 const wxChar* format =
nullptr;
321 format = is_eeschema ? wxT(
"%.3f" ) : wxT(
"%.5f" );
325 format = is_eeschema ? wxT(
"%.6f" ) : wxT(
"%.8f" );
329 format = wxT(
"%.4f" );
333 format = wxT(
"%.10f" );
338 text.Printf( format, value_to_print );
341 if( value_to_print != 0.0 && (
text == wxS(
"0" ) ||
text == wxS(
"-0" ) ) )
343 text.Printf( wxS(
"%.10f" ), value_to_print );
367 long long int aValue,
378 return wxString::Format( wxT(
"%.1f°" ), aValue.
AsDegrees() );
380 return wxString::Format( wxT(
"%.1f" ), aValue.
AsDegrees() );
386 double aValue,
bool aAddUnitsText,
390 const wxChar* format;
391 double value = aValue;
397 value =
ToUserUnit( aIuScale, aUnits, value );
402 value =
ToUserUnit( aIuScale, aUnits, value );
407 value =
ToUserUnit( aIuScale, aUnits, value );
418 format = is_eeschema ? wxT(
"%.0f" ) : wxT(
"%.1f" );
422 format = is_eeschema ? wxT(
"%.2f" ) : wxT(
"%.4f" );
426 format = is_eeschema ? wxT(
"%.3f" ) : wxT(
"%.5f" );
430 format = is_eeschema ? wxT(
"%.0f" ) : wxT(
"%.2f" );
434 format = is_eeschema ? wxT(
"%.3f" ) : wxT(
"%.4f" );
439 format = wxT(
"%.3f" );
443 format = wxT(
"%.0f" );
447 text.Printf( format, value );
462 if( aValue.
HasMin() && aValue.
Min() > 0 )
493 return MM_TO_IU( aValue / 1000.0, aIuScale );
496 return MM_TO_IU( aValue, aIuScale );
499 return MM_TO_IU( aValue * 10, aIuScale );
505 return IN_TO_IU( aValue, aIuScale );
521 const struct lconv* lc = localeconv();
523 wxChar decimal_point = lc->decimal_point[0];
524 wxString buf( aTextValue.Strip( wxString::both ) );
527 buf.Replace( wxT(
"." ), wxString( decimal_point, 1 ) );
528 buf.Replace( wxT(
"," ), wxString( decimal_point, 1 ) );
531 unsigned brk_point = 0;
533 while( brk_point < buf.Len() )
535 wxChar ch = buf[brk_point];
537 if( !( ( ch >=
'0' && ch <=
'9' ) || ( ch == decimal_point ) || ( ch ==
'-' )
547 buf.Left( brk_point ).ToDouble( &dtmp );
559 const struct lconv* lc = localeconv();
561 wxChar decimal_point = lc->decimal_point[0];
562 wxString buf( aTextValue.Strip( wxString::both ) );
565 buf.Replace( wxT(
"." ), wxString( decimal_point, 1 ) );
566 buf.Replace( wxT(
"," ), wxString( decimal_point, 1 ) );
569 unsigned brk_point = 0;
571 while( brk_point < buf.Len() )
573 wxChar ch = buf[brk_point];
575 if( !( (ch >=
'0' && ch <=
'9') || (ch == decimal_point) || (ch ==
'-') || (ch ==
'+') ) )
582 buf.Left( brk_point ).ToDouble( &dtmp );
585 wxString unit( buf.Mid( brk_point ).Strip( wxString::leading ).Left( 2 ).Lower() );
594 if( unit == wxT(
"um" ) || unit == wxT(
"\u00B5m" ) || unit == wxT(
"\u03BCm" ) )
598 else if( unit == wxT(
"mm" ) )
602 else if( unit == wxT(
"cm" ) )
606 else if( unit == wxT(
"mi" ) || unit == wxT(
"th" ) )
610 else if( unit == wxT(
"in" ) || unit == wxT(
"\"" ) )
614 else if( unit == wxT(
"oz" ) )
622 if( unit == wxT(
"ra" ) )
623 dtmp *= 180.0f / M_PI;
653 return KiROUND<double, long long int>( value );
661 return KiROUND<double, long long int>( value );
constexpr double SCH_IU_PER_MM
Schematic internal units 1=100nm.
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
#define IU_TO_IN(x, scale)
#define IN_TO_IU(x, scale)
#define IU_TO_MILS(x, scale)
#define MM_TO_IU(x, scale)
#define IU_TO_MM(x, scale)
#define MILS_TO_IU(x, scale)
static void removeTrailingZeros(wxString &aText)
EDA_DATA_TYPE
The type of unit.
This file contains miscellaneous commonly used macros and functions.
#define KI_FALLTHROUGH
The KI_FALLTHROUGH macro is to be used when switch statement cases should purposely fallthrough from ...
#define UNIMPLEMENTED_FOR(type)
KICOMMON_API wxString MessageTextFromValue(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, double aValue, bool aAddUnitsText=true, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
A helper to convert the double length aValue to a string in inches, millimeters, or unscaled units.
KICOMMON_API double FromUserUnit(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnit, double aValue)
Return in internal units the value aValue given in a real unit such as "in", "mm",...
KICOMMON_API long long int ValueFromString(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, const wxString &aTextValue, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Convert aTextValue in aUnits to internal units used by the application.
KICOMMON_API wxString StringFromValue(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, double aValue, bool aAddUnitsText=false, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Return the string from aValue according to aUnits (inch, mm ...) for display.
KICOMMON_API wxString MessageTextFromMinOptMax(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, const MINOPTMAX< int > &aValue)
KICOMMON_API double DoubleValueFromString(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, const wxString &aTextValue, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Convert aTextValue to a double.
KICOMMON_API double ToUserUnit(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnit, double aValue)
Convert aValue in internal units to the appropriate user units defined by aUnit.
KICOMMON_API wxString GetText(EDA_UNITS aUnits, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Get the units string for a given units type.
KICOMMON_API bool FetchUnitsFromString(const wxString &aTextValue, EDA_UNITS &aUnits)
Write any unit info found in the string to aUnits.
KICOMMON_API bool IsImperialUnit(EDA_UNITS aUnit)
KICOMMON_API bool IsMetricUnit(EDA_UNITS aUnit)
KICOMMON_API wxString GetLabel(EDA_UNITS aUnits, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Get the units string for a given units type.
KICOMMON_API int Mm2mils(double aVal)
Convert mm to mils.
KICOMMON_API std::string FormatInternalUnits(const EDA_IU_SCALE &aIuScale, int aValue)
Converts aValue from internal units to a string appropriate for writing to file.
KICOMMON_API std::string FormatAngle(const EDA_ANGLE &aAngle)
Convert aAngle from board units to a string appropriate for writing to file.
KICOMMON_API int Mils2mm(double aVal)
Convert mils to mm.