mirror of
https://github.com/mcneel/opennurbs.git
synced 2026-03-01 11:36:09 +08:00
Co-authored-by: Alain <alain@mcneel.com> Co-authored-by: Andrew Le Bihan <andy@mcneel.com> Co-authored-by: chuck <chuck@mcneel.com> Co-authored-by: croudyj <croudyj@gmail.com> Co-authored-by: Dale Fugier <dale@mcneel.com> Co-authored-by: Giulio Piacentino <giulio@mcneel.com> Co-authored-by: Greg Arden <greg@mcneel.com> Co-authored-by: Jussi Aaltonen <jussi@mcneel.com> Co-authored-by: kike-garbo <kike@mcneel.com> Co-authored-by: Steve Baer <steve@mcneel.com>
186 lines
5.2 KiB
C++
186 lines
5.2 KiB
C++
//
|
|
// Copyright (c) 1993-2022 Robert McNeel & Associates. All rights reserved.
|
|
// OpenNURBS, Rhinoceros, and Rhino3D are registered trademarks of Robert
|
|
// McNeel & Associates.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY.
|
|
// ALL IMPLIED WARRANTIES OF FITNESS FOR ANY PARTICULAR PURPOSE AND OF
|
|
// MERCHANTABILITY ARE HEREBY DISCLAIMED.
|
|
//
|
|
// For complete openNURBS copyright information see <http://www.opennurbs.org>.
|
|
//
|
|
////////////////////////////////////////////////////////////////
|
|
|
|
#include "opennurbs.h"
|
|
|
|
#if !defined(ON_COMPILING_OPENNURBS)
|
|
// This check is included in all opennurbs source .c and .cpp files to insure
|
|
// ON_COMPILING_OPENNURBS is defined when opennurbs source is compiled.
|
|
// When opennurbs source is being compiled, ON_COMPILING_OPENNURBS is defined
|
|
// and the opennurbs .h files alter what is declared and how it is declared.
|
|
#error ON_COMPILING_OPENNURBS must be defined when compiling opennurbs
|
|
#endif
|
|
|
|
int ON_ParseLengthExpression(
|
|
const wchar_t* str,
|
|
int str_count,
|
|
ON_ParseSettings parse_settings,
|
|
ON::LengthUnitSystem length_value_unit_system,
|
|
double* length_value,
|
|
ON_ParseSettings* parse_results,
|
|
ON::LengthUnitSystem* str_length_unit_system
|
|
)
|
|
{
|
|
ON::LengthUnitSystem us = ON::LengthUnitSystem::None;
|
|
|
|
if ( ON::LengthUnitSystem::CustomUnits == length_value_unit_system )
|
|
{
|
|
// must use the ON_UnitSystem override for custom units.
|
|
if ( 0 != str_length_unit_system )
|
|
*str_length_unit_system = us;
|
|
if ( 0 != length_value )
|
|
*length_value = ON_UNSET_VALUE;
|
|
if ( 0 != parse_results )
|
|
*parse_results = ON_ParseSettings::FalseSettings;
|
|
return 0;
|
|
}
|
|
|
|
double x = ON_UNSET_VALUE;
|
|
int parsed_element_count = ON_ParseLengthExpression(
|
|
str,
|
|
str_count,
|
|
parse_settings,
|
|
&x,
|
|
parse_results,
|
|
&us
|
|
);
|
|
|
|
if ( parsed_element_count > 0 )
|
|
{
|
|
if ( us != length_value_unit_system
|
|
&& ON::LengthUnitSystem::None != length_value_unit_system
|
|
&& ON::LengthUnitSystem::None != us
|
|
)
|
|
{
|
|
double s = ON::UnitScale(us,length_value_unit_system);
|
|
x *= s;
|
|
}
|
|
}
|
|
|
|
if ( 0 != str_length_unit_system )
|
|
*str_length_unit_system = us;
|
|
if ( 0 != length_value )
|
|
*length_value = x;
|
|
|
|
return parsed_element_count;
|
|
}
|
|
|
|
|
|
int ON_ParseLengthExpression(
|
|
const wchar_t* str,
|
|
int str_count,
|
|
ON_ParseSettings parse_settings,
|
|
const ON_UnitSystem& length_value_unit_system,
|
|
double* length_value,
|
|
ON_ParseSettings* parse_results,
|
|
ON::LengthUnitSystem* str_length_unit_system
|
|
)
|
|
{
|
|
ON::LengthUnitSystem parse_unit_system = ((ON::LengthUnitSystem::CustomUnits != length_value_unit_system.UnitSystem() ) ? length_value_unit_system.UnitSystem() : ON::LengthUnitSystem::None);
|
|
ON::LengthUnitSystem str_us = ON::LengthUnitSystem::None;
|
|
double x = ON_UNSET_VALUE;
|
|
int parsed_element_count = ON_ParseLengthExpression(
|
|
str,
|
|
str_count,
|
|
parse_settings,
|
|
parse_unit_system,
|
|
&x,
|
|
parse_results,
|
|
&str_us
|
|
);
|
|
|
|
if ( parsed_element_count > 0
|
|
&& ON::LengthUnitSystem::CustomUnits == length_value_unit_system.UnitSystem()
|
|
)
|
|
{
|
|
if ( ON::LengthUnitSystem::None == str_us )
|
|
{
|
|
const ON_wString custom_unit_name(length_value_unit_system.UnitSystemName());
|
|
if ( custom_unit_name.IsNotEmpty() )
|
|
{
|
|
const wchar_t* sCustomUnitName = static_cast<const wchar_t*>(custom_unit_name);
|
|
const int imax = ( -1 == str_count ? 2147483647 : str_count) - parsed_element_count;
|
|
for ( int i = 0; i < imax; i++ )
|
|
{
|
|
if ( 0 == sCustomUnitName[i] )
|
|
{
|
|
str_us = ON::LengthUnitSystem::CustomUnits;
|
|
parsed_element_count += i;
|
|
break;
|
|
}
|
|
if ( sCustomUnitName[i] != str[parsed_element_count + i] )
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
double s = ON::UnitScale(str_us,length_value_unit_system);
|
|
x *= s;
|
|
}
|
|
|
|
if ( 0 != str_length_unit_system )
|
|
*str_length_unit_system = str_us;
|
|
if ( 0 != length_value )
|
|
*length_value = x;
|
|
|
|
return parsed_element_count;
|
|
}
|
|
|
|
int ON_ParseLengthExpression(
|
|
const wchar_t* str,
|
|
int str_count,
|
|
ON::AngleUnitSystem default_str_angle_unit_system,
|
|
ON::LengthUnitSystem length_value_unit_system,
|
|
double* length_value
|
|
)
|
|
{
|
|
ON_ParseSettings ps(ON_ParseSettings::DefaultSettings);
|
|
ps.SetDefaultAngleUnitSystem(default_str_angle_unit_system);
|
|
|
|
int parsed_element_count = ON_ParseLengthExpression(
|
|
str,
|
|
str_count,
|
|
ps,
|
|
length_value_unit_system,
|
|
length_value,
|
|
nullptr,
|
|
nullptr
|
|
);
|
|
|
|
return parsed_element_count;
|
|
}
|
|
|
|
int ON_ParseLengthExpression(
|
|
const wchar_t* str,
|
|
int str_count,
|
|
ON::AngleUnitSystem default_str_angle_unit_system,
|
|
const ON_UnitSystem& length_value_unit_system,
|
|
double* length_value
|
|
)
|
|
{
|
|
ON_ParseSettings ps(ON_ParseSettings::DefaultSettings);
|
|
ps.SetDefaultAngleUnitSystem(default_str_angle_unit_system);
|
|
|
|
int parsed_element_count = ON_ParseLengthExpression(
|
|
str,
|
|
str_count,
|
|
ps,
|
|
length_value_unit_system,
|
|
length_value,
|
|
nullptr,
|
|
nullptr
|
|
);
|
|
|
|
return parsed_element_count;
|
|
}
|
|
|