Skip to content

Commit

Permalink
Fix Material ReferencedById issues
Browse files Browse the repository at this point in the history
  • Loading branch information
Kristjan Nielsen committed Oct 9, 2023
1 parent 45e44f9 commit 289d855
Show file tree
Hide file tree
Showing 8 changed files with 96 additions and 20 deletions.
10 changes: 4 additions & 6 deletions GsaGH/Components/GraveyardComp/CreateProp2d2_OBSOLETE.cs
Original file line number Diff line number Diff line change
Expand Up @@ -172,19 +172,17 @@ protected override void SolveInternal(IGH_DataAccess da) {
if (ghTyp.Value is GsaMaterialGoo materialGoo) {
prop.Material = GsaMaterialFactory.CreateMaterial(materialGoo.Value);
} else {
if (GH_Convert.ToInt32(ghTyp.Value, out int idd, GH_Conversion.Both)) {
prop.Material = new GsaReferencedMaterial(idd);
if (GH_Convert.ToInt32(ghTyp.Value, out int id, GH_Conversion.Both)) {
prop.Material = new GsaReferencedMaterial(id, MatType.Custom);
} else {
this.AddRuntimeError(
"Unable to convert PB input to a Section Property of reference integer");
return;
}
}
} else {
prop.Material = new GsaReferencedMaterial(2);
}
}
} else {
prop.Material = new GsaReferencedMaterial(8);
prop.Material = new GsaReferencedMaterial(1, MatType.Fabric);
}
} else {
prop.ApiProp2d.SupportType = _supportDropDown.FirstOrDefault(x => x.Value == _selectedItems[1]).Key;
Expand Down
5 changes: 5 additions & 0 deletions GsaGH/Helpers/Assembly/Properties/Materials.cs
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ private static GsaGuidDictionary<T> GetStandardMaterialDictionary<T>(
}

private int AddMaterial(GsaMaterial material) {
if (material is GsaReferencedMaterial refMat) {
return refMat.Id;
}

if (!_materials.ContainsKey(material.Guid)) {
_materials.Add(material.Guid, material);
}
Expand Down Expand Up @@ -276,6 +280,7 @@ private MaterialType GetMaterialType(GsaMaterial material) {
if (value.ToLower() == "custom") {
value = "generic";
}

return (MaterialType)Enum.Parse(typeof(MaterialType), value, true);
}

Expand Down
25 changes: 16 additions & 9 deletions GsaGH/Parameters/0_Model/GsaMaterials.cs
Original file line number Diff line number Diff line change
Expand Up @@ -41,35 +41,42 @@ private GsaMaterial GetMaterial(MaterialType type, int analysisProp, int gradePr
if (AnalysisMaterials.ContainsKey(id)) {
return AnalysisMaterials[id];
} else {
return new GsaReferencedMaterial(id);
return new GsaReferencedMaterial(id, GsaMaterialFactory.GetMatType(type));
}
}

id = gradeProp;
switch (type) {
case MaterialType.ALUMINIUM:
return AluminiumMaterials.TryGetValue(id, out GsaMaterial aluminium) ? aluminium : null;
return AluminiumMaterials.TryGetValue(id, out GsaMaterial aluminium) ? aluminium
: new GsaReferencedMaterial(id, MatType.Aluminium);

case MaterialType.CONCRETE:
return ConcreteMaterials.TryGetValue(id, out GsaMaterial concrete) ? concrete : null;
return ConcreteMaterials.TryGetValue(id, out GsaMaterial concrete) ? concrete
: new GsaReferencedMaterial(id, MatType.Concrete);

case MaterialType.FABRIC:
return FabricMaterials.TryGetValue(id, out GsaMaterial fabric) ? fabric : null;
return FabricMaterials.TryGetValue(id, out GsaMaterial fabric) ? fabric
: new GsaReferencedMaterial(id, MatType.Fabric);

case MaterialType.FRP:
return FrpMaterials.TryGetValue(id, out GsaMaterial frp) ? frp : null;
return FrpMaterials.TryGetValue(id, out GsaMaterial frp) ? frp
: new GsaReferencedMaterial(id, MatType.Frp);

case MaterialType.GLASS:
return GlassMaterials.TryGetValue(id, out GsaMaterial glass) ? glass : null;
return GlassMaterials.TryGetValue(id, out GsaMaterial glass) ? glass
: new GsaReferencedMaterial(id, MatType.Glass);

case MaterialType.FIRST:
return SteelMaterials.TryGetValue(id, out GsaMaterial steel) ? steel : null;
return SteelMaterials.TryGetValue(id, out GsaMaterial steel) ? steel
: new GsaReferencedMaterial(id, MatType.Steel);

case MaterialType.TIMBER:
return TimberMaterials.TryGetValue(id, out GsaMaterial timber) ? timber : null;
return TimberMaterials.TryGetValue(id, out GsaMaterial timber) ? timber
: new GsaReferencedMaterial(id, MatType.Timber);

default:
return null;
return new GsaReferencedMaterial(id, GsaMaterialFactory.GetMatType(type));
}
}

Expand Down
9 changes: 9 additions & 0 deletions GsaGH/Parameters/1_Properties/GsaMaterialFactory.cs
Original file line number Diff line number Diff line change
Expand Up @@ -235,6 +235,15 @@ internal static List<string> GetGradeNames(MatType type, string concreteDesignCo
return GetGradeNames(type, m);
}

internal static MatType GetMatType(MaterialType type) {
string value = type.ToString();
if (Enum.TryParse(value, true, out MatType matType)) {
return matType;
}

return MatType.Custom;
}

internal static GsaMaterial RecreateForDesignCode(GsaMaterial material, Model model) {
GsaMaterial recreation = null;

Expand Down
2 changes: 1 addition & 1 deletion GsaGH/Parameters/1_Properties/GsaMaterialParameter.cs
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ protected override GsaMaterialGoo PreferredCast(object data) {
}

if (GH_Convert.ToInt32(data, out int id, GH_Conversion.Both)) {
var customMaterial = new GsaReferencedMaterial(id);
var customMaterial = new GsaReferencedMaterial(id, MatType.Custom);
return new GsaMaterialGoo(customMaterial);
}

Expand Down
4 changes: 2 additions & 2 deletions GsaGH/Parameters/1_Properties/GsaReferencedMaterial.cs
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@ public override string Name {
set => AnalysisMaterial.Name = value;
}

internal GsaReferencedMaterial(int id) {
internal GsaReferencedMaterial(int id, MatType type) {
Id = id;
MaterialType = MatType.ReferencedById;
MaterialType = type;
}

public override string ToString() {
Expand Down
3 changes: 1 addition & 2 deletions GsaGH/Parameters/Enums/MatType.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ public enum MatType {
Glass,
Frp,
Timber,
Fabric,
ReferencedById
Fabric
}
}
58 changes: 58 additions & 0 deletions GsaGHTests/1_BaseParameters/1_Properties/GsaMaterialTest.cs
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,12 @@
using System.Collections.Generic;
using GsaAPI;
using GsaAPI.Materials;
using GsaGH.Helpers.Assembly;
using GsaGH.Parameters;
using GsaGHTests.Helpers;
using OasysUnits;
using Xunit;
using LengthUnit = OasysUnits.Units.LengthUnit;

namespace GsaGHTests.Parameters {
[Collection("GrasshopperFixture collection")]
Expand Down Expand Up @@ -128,6 +131,18 @@ public void CreateCustomMaterialTest() {
DuplicateTest(material);
}

[Fact]
public void GetMatTypeTest() {
GsaAPI.MaterialType concrete = MaterialType.CONCRETE;
Assert.Equal(MatType.Concrete, GsaMaterialFactory.GetMatType(concrete));
GsaAPI.MaterialType steel = MaterialType.STEEL;
Assert.Equal(MatType.Steel, GsaMaterialFactory.GetMatType(steel));
GsaAPI.MaterialType custom = MaterialType.GENERIC;
Assert.Equal(MatType.Custom, GsaMaterialFactory.GetMatType(custom));
GsaAPI.MaterialType other = MaterialType.NONE;
Assert.Equal(MatType.Custom, GsaMaterialFactory.GetMatType(other));
}

[Fact]
public void NonStandardMaterialException() {
Assert.Throws<Exception>(() => {
Expand All @@ -142,6 +157,49 @@ public void NonStandardMaterialGradeNameException() {
});
}

[Fact]
public void ReferenceMaterialsTest() {
var section = new GsaAPI.Section() {
MaterialType = MaterialType.ALUMINIUM,
MaterialGradeProperty = 99
};
var prop2d = new GsaAPI.Prop2D() {
MaterialType = MaterialType.TIMBER,
MaterialGradeProperty = 7
};
var prop3d = new GsaAPI.Prop3D() {
MaterialType = MaterialType.GENERIC,
MaterialGradeProperty = 42
};
var model = new GsaAPI.Model();
model.AddSection(section);
model.AddProp2D(prop2d);
model.AddProp3D(prop3d);

var gsaModel = new GsaModel(model);
GsaSection modelSection = gsaModel.Sections[1].Value;
GsaProperty2d modelProp2d = gsaModel.Prop2ds[1].Value;
GsaProperty3d modelProp3d = gsaModel.Prop3ds[1].Value;
Assert.Equal(99, modelSection.Material.Id);
Assert.Equal(7, modelProp2d.Material.Id);
Assert.Equal(42, modelProp3d.Material.Id);
Assert.Equal(MatType.Aluminium, modelSection.Material.MaterialType);
Assert.Equal(MatType.Timber, modelProp2d.Material.MaterialType);
Assert.Equal(MatType.Custom, modelProp3d.Material.MaterialType);

var assembly = new ModelAssembly(null, null, null, null, null, null, null, null, null,
null, null,
new List<GsaSection> { modelSection },
new List<GsaProperty2d> { modelProp2d },
new List<GsaProperty3d> { modelProp3d },
null, null, null, null, null, LengthUnit.Meter, Length.Zero,
false, null);
GsaAPI.Model assembled = assembly.GetModel();
Assert.Equal(99, assembled.Sections()[1].MaterialGradeProperty);
Assert.Equal(7, assembled.Prop2Ds()[1].MaterialGradeProperty);
Assert.Equal(42, assembled.Prop3Ds()[1].MaterialGradeProperty);
}

internal static void DuplicateTest(GsaMaterial original) {
GsaMaterial duplicate = GsaMaterialFactory.CreateMaterial(original);
Assert.NotSame(duplicate, original);
Expand Down

0 comments on commit 289d855

Please sign in to comment.