-
Notifications
You must be signed in to change notification settings - Fork 16
The IImmutable interface
TODO: Specify when to use it
To implement the IImmutable
interface, you need to make two actions:
- Inherit from it: i.e.
public class YourObject : IImmutable
- The properties you want to be immutable must be
public
,get
only, and contain a default value. i.e.public string Title { get; } = ""
- All the properties that are not immutable, can follow the usual BHoM conventions,
public
,get
andset
, and have a default value - It must implement only one constructor, whose parameters are types of all the immutable properties of the object.
For an example, you can check the BH.oM.Structure.SectionProperties.SteelSection
from the Structure_oM
:
https://github.com/BHoM/BHoM/blob/master/Structure_oM/SectionProperties/SteelSection.cs
-
Introduction to the BHoM:
What is the BHoM for?
Structure of the BHoM
Technical Philosophy of the BHoM -
Getting Started:
Installing the BHoM
Using the BHoM
Submitting an Issue
Getting started for developers -
Use GitHub & Visual Studio:
Using the SCRUM Board
Resolving an Issue
Avoiding Conflicts
Creating a new Repository
Using Visual Studio
Using Visual Studio Code -
Contribute:
The oM
The Engine
The Adapter
The Toolkit
The UI
The Tests -
Guidelines:
Unit convention
Geometry
BHoM_Engine Classes
The IImmutable Interface
Handling Exceptional Events
BHoM Structural Conventions
BHoM View Quality Conventions
Code Versioning
Wiki Style
Coding Style
Null Handling
Code Attributes
Creating Icons
Changelog
Releases and Versioning
Open Sourcing Procedure
Dataset guidelines -
Foundational Interfaces:
IElement Required Extension Methods -
Continuous Integration:
Introduction
Check-PR-Builds
Check-Core
Check-Installer -
Code Compliance:
Compliance -
Further Reading:
FAQ
Structural Adapters
Mongo_Toolkit
Socket_Toolkit