Skip to content

Commit

Permalink
README.md added info on getting started as user.
Browse files Browse the repository at this point in the history
CONTRIBUTING.md added sections Pull Request Workflow and Coding Conventions.
refs terrafx#48
  • Loading branch information
IngmarBitter committed May 17, 2020
1 parent 48aed52 commit 881891f
Show file tree
Hide file tree
Showing 2 changed files with 101 additions and 0 deletions.
76 changes: 76 additions & 0 deletions docs/CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,3 +48,79 @@ template will be requested to be updated. Any pull requests opened without a
corresponding issue may be delayed or be required to undergo further changes
before being accepted.

#### Pull Request Workflow

As workflow for Pull Requests (PR) it is recommended to

1. Fork the [repository](https://github.com/terrafx/terrafx.interop.windows)
Make sure the git configuration has the upstream master set,
e.g. run `git remote add upstream https://github.com/terrafx/terrafx.interop.windows`

2. Create a branch with name reflecting the issue/proposal you are planning to work on.

3. Implement your PR

4. git Commit, Fetch --all, Rebase, Push, and then submit your PR.
The submit can be done via git commandline, or from your git gui tool
or with the button on the github page of your fork.

5. If on your own or prompted by a PR review you make further changes,
then you can update your PR via Commit, Fetch --all, Rebase, Push.
The push will be automatically recognized by github and github
will update the PR on the main upstream repository.

6. While one PR is in the works like this and maybe you are waiting on
a review you can make another branch for another PR and work on that in parallel.

7. When a PR is approved and closed your code becomes part of the upstream code base
and there is no need to keep the branch.
Feel free to delete the branch to reduce clutter in your git log,
but this step is not required.

#### Coding Conventions

TerraFX follows the industry standard
[C# coding conventions as published by Microsoft]
(https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/inside-a-program/coding-conventions)
and as enforced by the messages in Visual Studio 2019
when configured as *build + intellisense* .
Commits should be done such that under these settings there are no warnings.

In addition, there are a few more conventions:

1. **Property vs Method:** a property is auto evaluated by Visual Studio
when stopping at a breakpoint for items in the watch/autos/locals panel.
If that takes long Visual Studio becomes laggy.
So if your property would take long to evaluate then better make it a method.

2. **Compound Names:** Auto completion is very useful to use unfamiliar APIs.
Often there are multiple methods that do similar things.
It helps a lot if they show up next to each other in the auto completion lists.
That means they need to be next to each other in alphabetic order.
So here is the naming rule for compound names:
*Object followed by action* and *general followed by specific*.
So a method that sorts distances ascending should be `DistancesSortAscending`.
That way it fits right in with the other related ones:

```c#
DistancesMax
DistancesMin
DistancesSortAscending
DistancesSortDescending
```

3. **Coordinate Variables**: 3d graphics code has to deal with different coordinate systems.
Confusing which one a vector variable is associated with is causes difficult to trace errors.
Thus every coordinate vector variable should have a coordinate system indicating postfix.
Use `Wo` for world coordinates,
`Sc` for screen coordinates
and `Me` for mesh coordinates.
So you would write for example:

```c#
// map the ball center from mesh to world to screen
var ballCenterWo = meshToWorld4x4 * ballCenterMe;
var ballCenterSc = WorldToScreen4x4 * ballCenterWo;
```


25 changes: 25 additions & 0 deletions docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Interop bindings for Windows.
* [License](#license)
* [Code of Conduct](#code-of-conduct)
* [Contributing](#contributing)
* [Using](#using)

### Goals

Expand Down Expand Up @@ -45,6 +46,30 @@ wiki, etc) must abide by the [CODE_OF_CONDUCT](CODE_OF_CONDUCT.md).
Instances of abusive, harassing, or otherwise unacceptable behavior may be
reported by contacting the project team at [email protected].

### Using
To use TerraFX you need to not only
**clone the [github repository](https://github.com/terrafx/terrafx.interop.windows)**
but also make sure you have the right tools and libraries installed.

For Windows 10 you need
[Visual Studio 2019 Preview](https://visualstudio.microsoft.com/vs/preview/)
in its current release (Preview 6 as of the time of this writing) and you need
**.Net 5.0 Preview** (the name is not .Net Core 5.0).
And finally, in Visual Studio you need need to go to
**Options -> Environment -> Preview Features**
and there enable the option **Use previews of the .NET Core SDK**.

With all requirements in place, start with **TerraFX.Interop.Windows.sln**
in the root directory of the repository.
It will run a few minimalistic examples of using the **TerraFX windows interop API**,
such as rendering a triangle into a DirectX 11 or 12 window.
More examples are being added over time.
**TerraFX.Interop.Windows.Samples.sln** is the second project you might want to try.
It also has minimalistic examples but instead of a full screen window,
the DirectX rendering is embedded into a GUI with buttons and a panel for the rendering.

Those examples should get you started with using DirectX via C# in your own projects.

### Contributing

If you are looking to contribute you should read our
Expand Down

0 comments on commit 881891f

Please sign in to comment.