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 ).Trim(
false ).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" ) )
120 else if( unit == wxT(
"fs" ) )
122 else if( unit == wxT(
"ps" ) )
124 wxString timeUnit( buf.Mid( brk_point ).Trim(
false ).Left( 5 ).Lower() );
126 if( timeUnit == wxT(
"ps" ) )
128 else if( timeUnit == wxT(
"ps/in" ) )
130 else if( timeUnit == wxT(
"ps/cm" ) )
132 else if( timeUnit == wxT(
"ps/mm" ) )
182 return GetText( aUnits, aType ).Trim(
false );
188 std::string temp = fmt::format(
"{:.10g}", aAngle.
AsDegrees() );
197 double engUnits = aValue;
201 if( engUnits != 0.0 && fabs( engUnits ) <= 0.0001 )
203 buf = fmt::format(
"{:.10f}", engUnits );
206 while( !buf.empty() && buf[buf.size() - 1] ==
'0' )
213 if( buf[buf.size() - 1] ==
'.' )
220 buf = fmt::format(
"{:.10g}", engUnits );
237bool EDA_UNIT_UTILS::ParseInternalUnits(
const std::string& aInput,
const EDA_IU_SCALE& aIuScale,
242 if( std::from_chars( aInput.data(), aInput.data() + aInput.size(), value ).ec != std::errc() )
250bool EDA_UNIT_UTILS::ParseInternalUnits(
const std::string& aInput,
const EDA_IU_SCALE& aIuScale,
253 size_t pos = aInput.find(
' ' );
255 if( pos == std::string::npos )
258 std::string first = aInput.substr( 0, pos );
259 std::string second = aInput.substr( pos + 1 );
263 if( !ParseInternalUnits( first, aIuScale, vec.
x ) )
266 if( !ParseInternalUnits( second, aIuScale, vec.
y ) )
277#define IU_TO_MM( x, scale ) ( x / scale.IU_PER_MM )
278#define IU_TO_IN( x, scale ) ( x / scale.IU_PER_MILS / 1000 )
279#define IU_TO_MILS( x, scale ) ( x / scale.IU_PER_MILS )
280#define IU_TO_PS( x, scale ) ( x / scale.IU_PER_PS )
281#define IU_TO_PS_PER_MM( x, scale ) ( x / scale.IU_PER_PS_PER_MM )
282#define MM_TO_IU( x, scale ) ( x * scale.IU_PER_MM )
283#define IN_TO_IU( x, scale ) ( x * scale.IU_PER_MILS * 1000 )
284#define MILS_TO_IU( x, scale ) ( x * scale.IU_PER_MILS )
285#define PS_TO_IU( x, scale ) ( x * scale.IU_PER_PS )
286#define PS_PER_MM_TO_IU( x, scale ) ( x * scale.IU_PER_PS_PER_MM )
305 default:
return aValue;
311 double aValue,
bool aAddUnitsText,
314 double value_to_print = aValue;
320 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
324 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
328 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
335 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
339 value_to_print =
ToUserUnit( aIuScale, aUnits, value_to_print );
343 const wxChar* format =
nullptr;
347 case EDA_UNITS::MILS: format = is_eeschema ? wxT(
"%.3f" ) : wxT(
"%.5f" );
break;
348 case EDA_UNITS::INCH: format = is_eeschema ? wxT(
"%.6f" ) : wxT(
"%.8f" );
break;
353 default: format = wxT(
"%.10f" );
break;
357 text.Printf( format, value_to_print );
360 if( value_to_print != 0.0 && (
text == wxS(
"0" ) ||
text == wxS(
"-0" ) ) )
362 text.Printf( wxS(
"%.10f" ), value_to_print );
386 long long int aValue,
397 return wxString::Format( wxT(
"%.1f°" ), aValue.
AsDegrees() );
399 return wxString::Format( wxT(
"%.1f" ), aValue.
AsDegrees() );
405 double aValue,
bool aAddUnitsText,
409 const wxChar* format;
410 double value = aValue;
417 value =
ToUserUnit( aIuScale, aUnits, value );
422 value =
ToUserUnit( aIuScale, aUnits, value );
427 value =
ToUserUnit( aIuScale, aUnits, value );
434 value =
ToUserUnit( aIuScale, aUnits, value );
438 value =
ToUserUnit( aIuScale, aUnits, value );
445 case EDA_UNITS::UM: format = short_form ? wxT(
"%.0f" ) : wxT(
"%.1f" );
break;
446 case EDA_UNITS::MM: format = short_form ? wxT(
"%.3f" ) : wxT(
"%.4f" );
break;
447 case EDA_UNITS::CM: format = short_form ? wxT(
"%.3f" ) : wxT(
"%.5f" );
break;
448 case EDA_UNITS::MILS: format = short_form ? wxT(
"%.0f" ) : wxT(
"%.2f" );
break;
449 case EDA_UNITS::INCH: format = short_form ? wxT(
"%.3f" ) : wxT(
"%.4f" );
break;
459 text.Printf( format, value );
465 bool showsOnlyZeros =
true;
468 for(
auto ch :
text )
470 if( ch >=
'1' && ch <=
'9' )
472 showsOnlyZeros =
false;
479 text.Printf( wxT(
"%.3e" ), value );
486 struct lconv* lc = localeconv();
487 int length = (int)
text.Length();
489 if( length > 4 &&
text[length - 4] == *lc->decimal_point &&
text[length - 1] ==
'0' )
506 if( aValue.
HasMin() && aValue.
Min() > 0 )
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 ==
'-' )
585 buf.Left( brk_point ).ToDouble( &dtmp );
597 const struct lconv* lc = localeconv();
599 wxChar decimal_point = lc->decimal_point[0];
600 wxString buf( aTextValue.Strip( wxString::both ) );
603 buf.Replace( wxT(
"." ), wxString( decimal_point, 1 ) );
604 buf.Replace( wxT(
"," ), wxString( decimal_point, 1 ) );
607 unsigned brk_point = 0;
609 while( brk_point < buf.Len() )
611 wxChar ch = buf[brk_point];
613 if( !( (ch >=
'0' && ch <=
'9') || (ch == decimal_point) || (ch ==
'-') || (ch ==
'+') ) )
620 buf.Left( brk_point ).ToDouble( &dtmp );
623 wxString unit( buf.Mid( brk_point ).Trim(
false ).Left( 2 ).Lower() );
632 if( unit == wxT(
"um" ) || unit == wxT(
"\u00B5m" ) || unit == wxT(
"\u03BCm" ) )
636 else if( unit == wxT(
"mm" ) )
640 else if( unit == wxT(
"cm" ) )
644 else if( unit == wxT(
"mi" ) || unit == wxT(
"th" ) )
648 else if( unit == wxT(
"in" ) || unit == wxT(
"\"" ) )
652 else if( unit == wxT(
"oz" ) )
660 if( unit == wxT(
"ra" ) )
661 dtmp *= 180.0f /
M_PI;
667 wxString timeUnit( buf.Mid( brk_point ).Trim(
false ).Left( 5 ).Lower() );
669 if( timeUnit == wxT(
"fs" ) )
671 if( timeUnit == wxT(
"ps" ) )
673 else if( timeUnit == wxT(
"ps/in" ) )
675 else if( timeUnit == wxT(
"ps/cm" ) )
677 else if( timeUnit == wxT(
"ps/mm" ) )
712 double& aDoubleValue )
717 const struct lconv* lc = localeconv();
719 wxChar decimal_point = lc->decimal_point[0];
720 wxString buf( aTextValue.Strip( wxString::both ) );
723 buf.Replace( wxT(
"." ), wxString( decimal_point, 1 ) );
724 buf.Replace( wxT(
"," ), wxString( decimal_point, 1 ) );
727 unsigned brk_point = 0;
729 while( brk_point < buf.Len() )
731 wxChar ch = buf[brk_point];
733 if( !( (ch >=
'0' && ch <=
'9') || (ch == decimal_point) || (ch ==
'-') || (ch ==
'+') ) )
743 buf.Left( brk_point ).ToDouble( &dtmp );
746 wxString unit( buf.Mid( brk_point ).Strip( wxString::both ).Lower() );
750 if( unit == wxT(
"um" ) || unit == wxT(
"\u00B5m" ) || unit == wxT(
"\u03BCm" ) )
754 else if( unit == wxT(
"mm" ) )
758 else if( unit == wxT(
"cm" ) )
762 else if( unit == wxT(
"mil" ) || unit == wxT(
"mils" ) || unit == wxT(
"thou" ) )
766 else if( unit == wxT(
"in" ) || unit == wxT(
"\"" ) )
770 else if( unit == wxT(
"oz" ) )
775 else if( unit == wxT(
"ra" ) )
777 dtmp *= 180.0f /
M_PI;
779 else if( unit == wxT(
"fs" ) )
783 else if( unit == wxT(
"ps" ) )
787 else if( unit == wxT(
"ps/in" ) )
791 else if( unit == wxT(
"ps/cm" ) )
795 else if( unit == wxT(
"ps/mm" ) )
constexpr double SCH_IU_PER_MM
Schematic internal units 1=100nm.
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
#define IU_TO_IN(x, scale)
#define IU_TO_PS_PER_MM(x, scale)
#define IN_TO_IU(x, scale)
#define IU_TO_MILS(x, scale)
#define IU_TO_PS(x, scale)
#define MM_TO_IU(x, scale)
#define PS_TO_IU(x, scale)
#define PS_PER_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.
VECTOR2< int32_t > VECTOR2I