-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
11f46f2
commit 1f34ff4
Showing
1 changed file
with
100 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,102 @@ | ||
[![NuGet Badge](https://buildstats.info/nuget/Meadow.Foundation.compositedevices)](https://www.nuget.org/packages/Meadow.Foundation.compositedevices) | ||
[![Develop Branch](https://github.com/WildernessLabs/Meadow.Foundation.compositedevices/actions/workflows/develop-ci.yml/badge.svg)](https://github.com/WildernessLabs/Meadow.Foundation.compositedevices/actions/workflows/develop-ci.yml) | ||
|
||
# Meadow.Foundation.CompositeDevices | ||
|
||
Meadow.Foundation drivers for composite devices | ||
The Meadow.Foundation.CompositeDevices peripherals library is an open source repository of Meadow compatible drivers for hardware that contains multiple peripherals or embeds additional microcontrollers. Meadow.Foundation.CompositeDevices is part of the open source driver and peripheral library [Meadow.Foundation](http://developer.wildernesslabs.co/Meadow/Meadow.Foundation/Peripherals/). | ||
|
||
## Meadow.Foundation | ||
|
||
The [Meadow.Foundation](http://developer.wildernesslabs.co/Meadow/Meadow.Foundation/Peripherals/) peripherals library is an open source repository of drivers and libraries that streamline and simplify adding hardware to your .NET Meadow IoT application. | ||
|
||
Meadow.Foundation makes the task of building connected things easy with Meadow by providing a unified driver and library framework that includes drivers and abstractions for common peripherals such as: sensors, displays, motors, cameras and more. Additionally, it includes utility functions and helpers for common tasks when building connected things. | ||
|
||
## Contents | ||
|
||
* [Repositories](#repositories) | ||
* [Repository Branches](#repository-branches) | ||
* [Main](#main) | ||
* [Develop](#develop) | ||
* [Branch History](#branch-history) | ||
* [Requesting New Drivers](#requesting-new-drivers) | ||
* [Documentation](#documentation) | ||
* [Using Meadow.Foundation](#using-meadowfoundation) | ||
* [Contributing](#contributing) | ||
* [License](#license) | ||
* [Author Credits](#author-credits) | ||
|
||
## Repositories | ||
|
||
Meadow.Foundation is currently split into multiple GitHub repos: | ||
1. [Meadow.Foundation](https://github.com/WildernessLabs/Meadow.Foundation/) which contains the majority of the peripheral and library source code | ||
2. [Meadow.Foundation.CompositeDevices]([https://github.com/WildernessLabs/Meadow.Foundation.Featherwings/](https://github.com/wildernesslabs/meadow.foundation.compositedevices)) contains drivers for devices that combine multiple peripherals or leverage additional onboard microcontrollers | ||
3. [Meadow.Foundation.Featherwings](https://github.com/WildernessLabs/Meadow.Foundation.Featherwings/) contains drivers for hardware that conforms to the [Adafruit Featherwing](https://learn.adafruit.com/adafruit-feather/) form factor | ||
4. [Meadow.Foundation.Grove](https://github.com/WildernessLabs/Meadow.Foundation.Grove/) contains drivers for [Seeed Studio Grove](https://www.seeedstudio.com/grove.html) modular hardware peripherals | ||
5. [Meadow.Foundation.MikroBus](https://github.com/WildernessLabs/Meadow.Foundation.mikrobus/) contains drivers for [MikroElektronika](https://www.mikroe.com/click) mikroBUS Click Boards | ||
|
||
## Repository Branches | ||
|
||
Today, Meadow.Foundation is represented within two branches: `main` and `develop`. | ||
|
||
### Main | ||
|
||
The `main` branch represents the currently published code from the last official release. Meadow.Foundation projects that depend on other projects within Meadow.Foundation will have local project references. For example, display drivers will contain a project reference to MicroGraphics. Any references outside of Meadow.Foundation rely on the latest published nuget packages. Nuget references are typically only present in the Meadow.Foundation sample projects. | ||
|
||
The `main` branch will compile without the need to clone additional projects. This branch is ideally used to review driver structure and run driver samples with the latest published and stable code. | ||
|
||
### Develop | ||
|
||
The `develop` branch represents the current state of development for the next official release. Code in this branch should be tested and functional. However, changes in this branch may depend on changes in other Meadow projects, such as Meadow Core. | ||
|
||
To compile the `develop` branch, you'll need to clone other dependency GitHub repositories at the same folder level as Meadow.Foundation. This includes but is not limited to: Meadow.Core, Meadow.Units, Meadow.Contracts, Meadow.Logging, and Meadow.Modbus. You can review the references in the `_external` solution folder within Meadow.Foundation for the complete list. Typically, all dependency projects should also be on the `develop` branch. This branch is ideal if you want to submit new drivers or propose substantial changes to existing code. | ||
|
||
### Branch history | ||
|
||
All code changes are committed to the `develop` branch. At the time of release, the references within develop are updated for publishing and then merged to `main`. This ensures a consistent and accurate history across `develop` and `main`. This also allows pull requests targeted to `main` to be easily retargeted to `develop`. | ||
|
||
## Requesting New Drivers | ||
|
||
If you have a need for a driver that we don't yet support, you have a couple options: | ||
|
||
- Use an existing, similar driver as a template for your new driver. We accept pull requests, but don't require them. | ||
- Open a new item on the [Issues Tab](https://github.com/WildernessLabs/Meadow.Foundation/issues) and request the driver so we can prioritize it. | ||
|
||
## Documentation | ||
|
||
You can read more Meadow.Foundation and how to get started in our [developer site](http://developer.wildernesslabs.co/Meadow/Meadow.Foundation/). | ||
|
||
## Using Meadow.Foundation | ||
|
||
To use Meadow.Foundation, simply add a Nuget reference to the core library (for core helpers and drivers), or to the specific peripheral driver you'd like to use, and the core will come with it. | ||
|
||
```bash | ||
nuget install Meadow.Foundation | ||
``` | ||
|
||
## Contributing | ||
|
||
Meadow.Foundation, is open source and community powered. We love pull requests, so if you've got a driver to add, send it on over! For each peripheral driver, please include: | ||
|
||
* **Documentation** - Including a Fritzing breadboard schematic on wiring it up, sourcing info, and API docs. Please see other drivers for examples. Documentation is hosted on the Wilderness Labs [DocFx](https://wildernesslabs.github.io/docfx/) site. | ||
* **Datasheet** - For the peripheral, if applicable. | ||
* **Sample** - Application illustrating usage of the peripheral. | ||
|
||
## License | ||
|
||
Copyright 2019-2024, Wilderness Labs Inc. | ||
|
||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
|
||
http://www.apache.org/licenses/LICENSE-2.0 | ||
|
||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
|
||
## Author Credits | ||
|
||
Authors: Bryan Costanich, Mark Stevens, Adrian Stevens, Jorge Ramirez, Brian Kim, Frank Krueger, Craig Dunn |