-
Notifications
You must be signed in to change notification settings - Fork 14
/
HashString.cs
89 lines (76 loc) · 4.81 KB
/
HashString.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
* This file is part of the Buildings and Habitats object Model (BHoM)
* Copyright (c) 2015 - 2024, the respective contributors. All rights reserved.
*
* Each contributor holds copyright over their respective contributions.
* The project versioning (Git) records all such contribution source information.
*
*
* The BHoM is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3.0 of the License, or
* (at your option) any later version.
*
* The BHoM 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this code. If not, see <https://www.gnu.org/licenses/lgpl-3.0.html>.
*/
using BH.Engine.Base;
using BH.oM.Adapters.Revit;
using BH.oM.Adapters.Revit.Elements;
using BH.oM.Adapters.Revit.Parameters;
using BH.oM.Base;
using BH.oM.Diffing;
using BH.oM.Base.Attributes;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Xml.Linq;
namespace BH.Engine.Adapters.Revit
{
public static partial class Query
{
[Description("Computes the Hash string for a Revit Parameter. This will then be used by the Hash algorithm to compute the overall Hash of an object owning Revit Parameters.")]
[Input("revitParameter", "The revit parameter to compute the hash from.")]
[Input("propertyFullName", "Full name of the RevitParameter property whose Hash is being computed. This name will be used to seek matches in the ComparisonConfig custom named tolerances/significant figures to determine if any custom numerical approximation should be done.")]
[Input("comparisonConfig", "Settings specified for this Hash computation. This can be a RevitComparisonConfig object.")]
public static string HashString(this RevitParameter revitParameter, string propertyFullName = null, BaseComparisonConfig comparisonConfig = null)
{
// Null check.
if (revitParameter == null)
return null;
string hashString = revitParameter.Name + revitParameter.Value;
// Check if we have a RevitComparisonConfig input.
RevitComparisonConfig rcc = comparisonConfig as RevitComparisonConfig;
if (rcc != null)
{
// If there is at least one name in the ParametersToConsider, make sure that the current revitParameter's Name is contained in the list.
if ((rcc.ParametersToConsider?.Any() ?? false) && !rcc.ParametersToConsider.Contains(revitParameter.Name))
// The parameter is not within the ParametersToConsider. RevitParameter must be skipped
return null;
// Check if the current revitParameter is within the ParametersExceptions.
if (rcc.ParametersExceptions?.Contains(revitParameter.Name) ?? false)
// The parameter is not within the ParametersToConsider. RevitParameter must be skipped
return null;
// If the RevitParameter is numeric, take care of custom tolerances/significant figures.
if (revitParameter.Value.GetType().IsNumeric())
{
// If we didn't specify any custom tolerance/significant figures, just return the input.
if (rcc.NumericTolerance == double.MinValue && rcc.SignificantFigures == int.MaxValue
&& (!rcc.ParameterNumericTolerances?.Any() ?? true) && (!rcc.ParameterSignificantFigures?.Any() ?? true))
return hashString;
// Otherwise, return the approximated value.
return BH.Engine.Base.Query.NumericalApproximation(
double.Parse(revitParameter.Value.ToString()), propertyFullName, rcc.ParameterNumericTolerances, rcc.NumericTolerance, rcc.ParameterSignificantFigures, rcc.SignificantFigures)
.ToString();
}
}
// Pass the RevitParameter (do not skip it). Return a string that represents this RevitParameter.
return $"{revitParameter.Name}:{revitParameter.Value}";
}
}
}