The Gemstone Libraries, maintained by the Grid Protection Alliance (GPA), are a collection of useful open source .NET code based on continuous development since 2004. These libraries represent a focused re-envisioning of the best code, i.e., the "gems", from the Grid Solutions Framework (GSF), which has long been in use by various open source projects and electric power utilities worldwide.
The Gemstone Libraries contain a large variety of code useful for any .NET project with of hundreds of class libraries that extend or expand the functionality provided with .NET, including many tools and protocol parsers that are useful for the electric power industry.
-
Learn: To start learning about the code available in the Gemstone Libraries, start with documentation for gemstone/common.
-
Use: To start using the Gemstone Libraries in an existing .NET application, reference one of the packages from NuGet or GitHub.
-
Develop: To compile or develop with the Gemstone Libraries at a source code level, start with the following instructions:
This repository contains a multi-project Visual Studio solution used for development and debugging of related Gemstone libraries.
To begin development on Gemstone libraries, clone this repository first - it is recommended to put all the Gemstone library repositories into their own folder (see Relative Project Paths below). For example, if a folder was created called C:\Projects\gemstone\
to hold the Gemstone repositories, then after cloning, this repo would be in C:\Projects\gemstone\root-dev
. After cloning, run the clone-all.cmd (or clone-all.sh in POSIX environments) script to clone all other repositories.
Two other scripts, pull-all.cmd and push-all.cmd (or pull-all.sh and push-all.sh in POSIX environments) exist to assist with multi-project git repository operations.
To better ensure acceptance of pull requests, be sure to read the coding style document.
To add a new Gemstone library repository, see the Add Library Steps.
The Visual Studio solution file Gemstone.sln found in this repository references all Gemstone library projects with a common relative parent path. For example, assuming all cloned repositories (including this one) for the gemstone organizational site have the same root folder, e.g., C:\Projects\gemstone\
and each project folder matches the repo name, e.g., C:\Projects\gemstone\threading\
for the threading library, then opening the C:\Projects\gemstone\root-dev\Gemstone.sln
from within Visual Studio will properly open and cross-reference all gemstone libraries.
The Gemstone.sln should be used with the build configuration called Development
. The Development
build configuration is used to associate local "project" references instead of "package" references (e.g., NuGet) that are only active when using this solution. For example, a project referencing both the common and expressions gemstone libraries would conditionally use local "project" references using the following in the .csproj
file:
<ItemGroup>
<ProjectReference Include="..\..\..\common\src\Gemstone\Gemstone.Common.csproj" Condition="'$(Configuration)'=='Development'" />
<PackageReference Include="Gemstone.Common" Version="1.0.0" Condition="'$(Configuration)'!='Development'" />
<ProjectReference Include="..\..\..\expressions\src\Gemstone.Expressions\Gemstone.Expressions.csproj" Condition="'$(Configuration)'=='Development'" />
<PackageReference Include="Gemstone.Expressions" Version="1.0.0" Condition="'$(Configuration)'!='Development'" />
</ItemGroup>
In this example, dependencies are configured as local project references only for the Development
build configuration. Otherwise, any other build configuration, e.g., the common Release
or Debug
configurations, will reference the dependency via the associated package repository, e.g., NuGet.
Newer versions of Visual Studio can now manage multiple repos at once. When developing from the Gemstone.sln in root-dev
, it is recommended to use Visual Studio 2022 (at least version 17.8) to manage check-ins for multiple repos.