-
Notifications
You must be signed in to change notification settings - Fork 16
The `External` class
When creating an adapter is not possible, the BHoM gives the possibility to reflect specific assemblies that are not compliant.
The methods of the assembly can be found in the UIs via the External
component.
There are three different levels at which an external assembly can be reflected in the BHoM, which differ in the level of compliance. From the least compliant, to the most compliant, they are explained below.
This mechanism reflects the methods of an assembly by keeping their native parameter types. There is no common language (BHoM) that allows a complete communication with other parts of the ecosystem. Although this is the fastest method to reflect an assembly, it does not guarantee that all the reflected methods will be usable, since no curation of the process is in place
To perform a simple reflection, you need to:
- Have the
Engine
project that corresponds to the assembly you want to reflect, e.g.Numpy_Engine
. It follows the usual Engine rules. - Implement the
External
class, the same way you would implement aCreate
orQuery
class. - Provide, in that class, two methods:
public static List<MethodInfo> Methods()
public static List<ConstructorInfo> Constructors()
They will be called by the Reflection_Engine, which will channel this methods into the External component of the UI.
This stage assumes everything that exists in the previous one, and add the necessity to convert any type that is not a System
type into a BHoM object. For instance, a Numpy.NDarray
to a BH.oM.MachineLearning.Tensor
. This guarantees that the object is compatible with the rest of the ecosystem and can them be used interchangeably in any other areas of the code.
To perform reflection with common language you need to:
This mechanism may or may not rely on the Reflection_Engine. It involves the automation of the parsing of the external api, which results into new BHoM code.
API parsing has to be tailored to the library you want to reflect.
It behaves as any other BHoM toolkit, since its methods lie in the usual BHoM classes Compute
, Convert
, Create
, Modify
, Query
.
-
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