We use GitHub to host code, to track issues and feature requests, as well as accept pull requests.
We use GitHub issues to track bugs. Report a bug by opening a new issue.
Great Bug Reports tend to have:
- A quick summary and/or background
- Steps to reproduce
- Be specific!
- Give sample code if you can.
- What you expected would happen
- What actually happens
- Notes (possibly including why you think this might be happening, or what you have tried that didn't work)
Pull requests are the best way to propose changes to the codebase. We actively welcome your pull requests:
- Fork the repo and create your branch from main.
- If you've added code that should be tested, add tests.
- Ensure the test suite passes.
- Create a pull request!
There are two packages that are shipped from the repository:
- WebExtensions.Net
- WebExtensions.Net.Extensions.DependencyInjection
- Namespace Definition - the raw JSON definition retrieved from the source (Mozilla.org)
- Class Entity - A registered entity containing the type (Api/ApiRoot/Type/etc), the namespace entity, the functions and the properties
- Clr Type - An object reflecting the definition of a .Net type
- Code Converter - A processor that defines how to write a Clr Type into C# code
- Code File - An object representing a .cs file
The APIs in WebExtensions.Net/Generated is generated from the WebExtensions.Net.Generator project. The code generation process is summarised as follows:
- Namespace Definitions are retrieved by the NamespaceDefinitionsClient
- The raw Namespace Definitions are then processed by the EntitiesRegistrationManager. In this stage:
- The namespace is registered as a Namespace Entity
- The namespace is registered as an Api Class Entity
- The types in a namespace is registered as a Type Entity
- The types are checked for reference/usage
- The unused or unsupported types are filtered out
- The events in the namespace is registered as property definitions
- The root namespace is registered as an ApiRoot Class Entity
- The Class Entities are translated into Clr Types by the ClrTypeManager. In this stage:
- The class entity is converted to ClrTypeInfo
- The methods in the class entity, their parameters and return type are converted
- The properties in the class entities are converted
- The namespaces required by the type is determined
- The namespaces required to reference the type is determined
- The code generator converts the Clr Types into Code Files. In this stage:
- The Code Converters are determined and injected into the Code File based on the Class Type
- The comments or attributes are defined in the Code Converters
- The Code Files are then written by the CodeManager to physical file. In this stage:
- The Generated folder is cleaned
- The Code Files are written as .cs files
- The Namespace definitions are written as .json files
The APIs generated are only the ones that are defined by the WebExtensions Standards. A non-standard API can be added by extending from the API's partial class.
The browser specific extensions and types should be defined in a directory under WebExtensions.Net/Extensions
based on the API namespace.
Refer to INotificationsApi.cs
and NotificationsApi.cs
under the path WebExtensions.Net/Extensions/Notifications/
for example.
It is best to do a rebase and run the generator again to make sure the changes in the generated files are not overwritten by your pull request.
- 4 spaces (C#) or 2 spaces (XML/JSON/JS) for indentation rather than tabs.
- Every
if
,else
,for
,foreach
,while
etc should have its own opening and closing bracket, even if it is a single line statement. - Every code file changed should be formatted properly (CTRL+K, CTRL+D in VS or ALT+SHIFT+F in VS Code).
- Download the chrome driver from (here)[http://chromedriver.storage.googleapis.com/]
- Extract the chrome driver to the directory C:\SeleniumWebDrivers\ChromeDriver
- Run the tests using either the Test Explorer in VS or
dotnet test
command
By contributing, you agree that your contributions will be licensed under its MIT License.