-
Notifications
You must be signed in to change notification settings - Fork 15
Coding Style
Our coding style generally follows the Microsoft guidelines:
https://docs.microsoft.com/en-us/dotnet/csharp/tour-of-csharp/
https://docs.microsoft.com/en-us/dotnet/csharp/tour-of-csharp/classes-and-objects
https://docs.microsoft.com/en-us/dotnet/csharp/tour-of-csharp/types-and-variables
Although, to attain a higher level of clarity and transparency, we also follow some additional rules and style guidelines.
These rules and guidelines are in place to help ensure the code matches what is seen in the UIs, enabling developers to quickly find the portions of code needing examining.
- A
.cs
file can contain only 1 (one)class
, and there is no concept as aHelper
orUtils
class. - For oM objects the name of the
.cs
file is the Name (excluding the namespace) of the Object (class), e.g. theLine
class is in theLine.cs
file. - For engine methods, a file can only contain methods whose name start or end with the name of their file file, e.g.
Flip(Line line)
andFlip(Arc arc)
are in the same fileFlip.cs
, andFilterPanels
andFilterOpenings
can both reside inside aFilter.cs
file.
Namespaces and the folder structure that contains the .cs
files have a close relationship. To define the correct folder structure helps keeping the relationship with the namespaces. This, in turn enables additional functionalities, such as deriving the web address of the source code of a method.
For a Class
, an Attribute
, an Enum
, and an Interface
, the folder structure respects the following rules:
-
If a file is in a sub folder, the namespace of the entity must follow: if
Bar
is in a sub folderElements
, its namespace must suffix theElements
wordBH.oM.Structure.Elements
. -
An
Enum
must be in a separate folderEnums
. Although, the namespace remains unchanged, and does not follow - i.e.Enums
is appended as suffix. For exampleBarFEAType
is in the sub folderElements
, and it is anenum
. Its namespace respects A., so it contains theElements
word, but does not contain theEnum
word: BH.oM.Structure.Elements. At the same time, since it is anEnum
it is in anEnums
folder. -
The same rule as B. applies to:
-
Attribute
=>Attributes
-
Interface
=>Interfaces
-
The order an Enum is written is the order in which it is displayed in the UI dropdown options. This order is therefore important to the UX of using the Enum within a workflow. The order should therefore follow one of the following conventions. There may be occasions when an Enum order does not follow the conventions below. These occasions should be clearly documented with the reasons why a different convention has been followed.
The order of the Enum should be alphabetical (following British-English spelling conventions) in ascending order (i.e. A-z).
Caveat for Undefined
If your Enum option has an Undefined
option to denote a default unset option, then this should go as the first option at the top of the Enum.
For an example of an Enum following this convention, see the Environment Panel Type Enum.
The order of the Enum can be in a logical order instead where this makes more sense than alphabetical. An example of such an Enum might be one that records the size of an object. In this case, the options might be:
ExtraSmall
Small
Normal
Large
ExtraLarge
This order for the Enum makes logical sense and provides a good UX where users will have context from the name of the Enum that the order might be different to alphabetical (e.g. the name might be UnitSize
).
-
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