rusefi_documentation/HOWTO-contribute-to-documen...

113 lines
6.4 KiB
Markdown
Raw Normal View History

2019-12-30 07:53:14 -08:00
# How to contribute to documentation
2019-12-30 09:09:58 -08:00
In order to leverage the Github pull request process for access control to the wiki, it is stored in a [Github repo](https://github.com/rusefi/rusefi_documentation).
## Editing
### Editing from a Wiki3 page
1. From the wiki page you wish to edit on [https://wiki.rusefi.com](https://wiki.rusefi.com), click on the "Edit on GitHub" link in the upper right hand corner.
2. Sign up or sign in to [Github](https://github.com) if you aren't already
2022-12-30 08:26:33 -08:00
3. If you have been given write access the the rusefi_documentation previously, you can commit changes directly. If not, clicking on "Propose Changes" will fork the repository and give you the option to create a pull request.
![image](https://user-images.githubusercontent.com/22799428/200407238-74b1fd66-e6b1-46cc-a7b8-398f5c5b41f6.png)
4. Click "Create Pull Request" and wait for your change to be reviewed.
### Alternative: Editing from a fork of the repo
1. Sign up or sign in to [Github](https://github.com) if you aren't already
2. Open [the documentation repo](https://github.com/rusefi/rusefi_documentation) and click 'Fork' - this would produce your own fork/copy of rusefi_documentation which you can now edit right in your browser!
![editor](FAQ/github_online_editor.png)
3. Edit your code and Commit changes using the button below the editor.
2019-12-30 09:09:58 -08:00
4. Once you are ready to contribute your changes, click the 'New pull request' button on the main page of your fork.
2019-12-30 09:09:58 -08:00
### After creating a Pull Request
2019-12-30 09:09:58 -08:00
Within the next 5 minutes after the pull request has been merged, a Github Action automatically builds the wiki and uploads it to both wikis.
2019-12-30 09:09:58 -08:00
## How to contribute to rusEFI TunerStudio project
2019-12-30 09:09:58 -08:00
1. Sign up or sign in to [Github](https://github.com) if you aren't already
2019-12-30 09:09:58 -08:00
2. Go to [https://github.com/rusefi/rusefi](https://github.com/rusefi/rusefi) and click "Fork" near the upper right corner
2019-12-30 09:09:58 -08:00
3. Edit your fork of [the TunerStudio input](https://github.com/rusefi/rusefi/blob/master/firmware/tunerstudio/rusefi.input) file
2019-12-30 09:09:58 -08:00
4. Click "Contribute", then "Open Pull Request", and finally "Create Pull Request"
2019-12-30 09:09:58 -08:00
5. Wait for your changes to be reviewed and merged.
[This commit](https://github.com/rusefi/rusefi/commit/9d9ae5a05499027b32ed76df3e7ee2e2e8240c31) is an example of how more help could be added
2019-12-30 09:09:58 -08:00
right into TunerStudio project file. Lines with green background are the lines being added.
Unfortunately while you would be modifying your mainController.ini file while trying your changes, you need to edit rusefi.input file which
is a template from which rusefi.ini is generated programmatically on rusefi side.
## Technical implementation details
Github Wiki is weird.
2019-12-30 07:53:14 -08:00
One the one hand, we have [https://github.com/rusefi/rusefi_documentation](https://github.com/rusefi/rusefi_documentation), which we will call "wiki-source".
That's a git repository with nice pull request process, but less nice web page rendering which starts each page by showing a list of files - that's not what end users want to see.
2019-12-30 07:53:14 -08:00
On the other hand, we have [the Github Wiki](https://github.com/rusefi/rusefi/wiki), which we will call "wiki2" which is displayed much nicer - and that is actually implemented by ANOTHER git repository https://github.com/rusefi/rusefi.wiki.git behind the scenes.
That repository does not have a nice Pull Request process :(
2019-12-30 07:53:14 -08:00
Solution? A combination. [wiki2](https://github.com/rusefi/rusefi/wiki) and [wiki-source](https://github.com/rusefi/rusefi_documentation) repositories are actually set to mirror each other.
This way we have the nice Pull Request process on [wiki-source](https://github.com/rusefi/rusefi_documentation) and once changes are merged, the wiki-source repo is then automatically merged into the wiki2 repo, which makes actual content nicely visible on [wiki2](https://github.com/rusefi/rusefi/wiki)
Synchronization between wiki2 and wiki-source is automated via [Github Action](https://github.com/rusefi/rusefi/blob/master/.github/workflows/sync-wiki.yaml), file content is expected to be the same between these two repositories.
## How Page Titles Work on Wiki3
If the first line with content is a top-level header, e.g. `# rusEFI Documentation`, that will be used as the page title.
If not, the file name will be used as the page title, only without the hyphens.
## How URLs work
Links to page names use only the name of the page.
Example:
`[How to contribute to documentation](HOWTO-contribute-to-documentation)`
Result:
[How to contribute to documentation](HOWTO-contribute-to-documentation)
Links to images are relative to the root of the wiki on Wiki2, and relative to the .md file location on Wiki3.
The only way for this to work consistently between Wiki2 and Wiki3 is to have a flat directory structure.
Example:
2019-12-30 07:53:14 -08:00
`![TunerStudio New Project View](FAQ/images/TunerStudio_new_project.png)`
Result:
![TunerStudio New Project View](FAQ/images/TunerStudio_new_project.png)
2019-12-30 07:53:14 -08:00
## Technical FAQ
2019-12-30 07:53:14 -08:00
**Q:** Is there a place where we are holding all images for these documents?
**A:** We have images in the same repository! Just add your images while editing pages. Please consider using some (any really) folder structure.
For example [https://github.com/rusefi/rusefi_documentation/blob/master/FAQ/images/TunerStudio_new_project.png](https://github.com/rusefi/rusefi_documentation/blob/master/FAQ/images/TunerStudio_new_project.png) is visible on wiki.rusefi.com as [https://wiki.rusefi.com/FAQ/images/TunerStudio_new_project.png](https://wiki.rusefi.com/FAQ/images/TunerStudio_new_project.png)
2019-12-30 07:53:14 -08:00
**Q:** What sort of fancy options do we have?
**A:** We can do collapsible sections & hints sections! See [cranking](Cranking) for an example. Unfortunately, it's quite picky about how you format the markdown.
```
<details markdown="1"><summary>More...</summary>
2019-12-30 07:53:14 -08:00
^ Must have empty line after </summary>
# Content
</details>
2019-12-30 09:30:32 -08:00
^ Must have empty line after </details>
```
2019-12-30 09:30:32 -08:00
**Q**: Is it ok that https://github.com/rusefi/rusefi.wiki.git cannot be opened from browser?
**A**: There is no reason to open https://github.com/rusefi/rusefi.wiki.git from browser. Also while you technically
2019-12-30 09:30:32 -08:00
CAN "git clone https://github.com/rusefi/rusefi_documentation.wiki.git" and it would work -
you should NOT. Anyone looking to make changes should be making changes to non-wiki git via normal fork & pull request process.
Additional automation is in charge of merging from https://github.com/rusefi/rusefi_documentation.git into https://github.com/rusefi/rusefi_documentation.wiki.git