oh-my-posh/website/docs/contributing/started.mdx

170 lines
4.9 KiB
Plaintext
Raw Normal View History

---
2022-04-20 09:43:59 -07:00
id: started
title: Get Started
sidebar_label: Get Started
---
import Tabs from "@theme/Tabs";
import TabItem from "@theme/TabItem";
## Get the source code
The source is hosted on [Github][omp]. When you want to contribute, create a [fork][gh-fork] so you can make changes in
your repository and create a pull request in the official Oh My Posh repository.
To clone your fork of Oh My Posh locally, open the terminal and replace `<user>` with your Github username.
```powershell
git clone git@github.com:<user>/oh-my-posh.git
```
2020-12-25 10:37:18 -08:00
## Install dependencies
<Tabs
defaultValue="manual"
groupId="git"
values={[
{ label: 'Manual', value: 'manual', },
{ label: 'Winget', value: 'winget', },
]
}>
<TabItem value="manual">
### go
2021-03-17 10:34:09 -07:00
The codebase is in [go][go], meaning we need a working go setup before we can do anything else.
Have a look at the [go guide][go-started] to get up and running with go in no time!
2021-09-01 04:45:33 -07:00
:::caution
Oh My Posh needs at least go 1.22
2021-03-17 10:34:09 -07:00
:::
### golangci-lint
To make sure we keep on writing quality code, [golang-ci lint][golang-ci-lint] is used to validate the changes.
Have a look at the [local installation guide][golang-ci-lint-local] to make sure you can validate this yourself as well.
### nodejs
2020-12-25 10:37:18 -08:00
The documentation is written in markdown and uses [Docusaurus][docusaurus] to generate the website. To validate your
changes, you'll need to have [nodejs] installed so you can run the website locally.
2020-12-25 10:37:18 -08:00
### Visual Studio Code
2020-12-25 10:37:18 -08:00
If you're not using Visual Studio Code yet, it's a great editor to work with go and the project has the configuration built-in.
You can download it [here][code].
</TabItem>
<TabItem value="winget">
The project has a [winget] [configuration][winget-configuration] file available to install the dependencies.
Navigate to the cloned repository and use winget to install the dependencies:
```powershell
winget configure configurations/configuration.dsc.yaml
2020-12-25 10:37:18 -08:00
```
Done! Restart the terminal and you're ready to continue below.
</TabItem>
</Tabs>
## Configure Visual Studio Code
A default config (.vscode folder) for [Visual Studio Code][code] is available in the repo:
- `golangci-lint` is configured as the default linter.
- recommended extensions available for a smooth bootstrap.
- default run and debug configurations available.
Once the extensions are installed:
- debug can be started by hitting F5.
- all tests can be run using the Test explorer.
## Running tests
The go source code can be found in the `src/` directory, make sure to navigate to that one before continuing.
### Unit tests
```powershell
2022-02-01 05:38:25 -08:00
go test -v ./...
```
### golangci-lint
```powershell
golangci-lint run
```
## Building the app
The easiest way to validate your changes is to write tests. Unfortunately, as it's a visual tool, you'll want to validate
the changes by running the prompt in your shell as well.
If you already have Oh My Posh in your `PATH`, you'll need to either use that one as an output parameter, or make sure
that the `$GOPATH/bin/` folder precedes the Oh My Posh binary in your `PATH`.
```powershell
go build -o (Get-Command oh-my-posh.exe).Source
```
Alternatively:
2020-12-29 00:13:56 -08:00
```powershell
$env:PATH = "$env:GOPATH\bin;$env:PATH"
go build -o $GOPATH/bin/oh-my-posh
```
2020-12-29 00:13:56 -08:00
## Run the website locally
2020-12-29 00:13:56 -08:00
Open your terminal and navigate to the `website` folder in the repository. Install the dependencies and start the website:
2020-12-29 00:13:56 -08:00
```powershell
npm install
npm start
```
2020-12-29 00:13:56 -08:00
This will start a local server on `http://localhost:3000` where you can see your changes.
2020-12-29 00:13:56 -08:00
### Extra tips
#### Configure Delve in VS Code
2022-05-12 22:54:59 -07:00
[Delve][delve] config is restrictive by default(string limit especially). You can expand some limits in VS Code(`settings.json` or directly in `launch.json`):
```
"go.delveConfig": {
"dlvLoadConfig": {
"followPointers": true,
"maxVariableRecurse": 3,
"maxStringLen": 400,
"maxArrayValues": 400,
"maxStructFields": -1
},
"apiVersion": 2,
"showGlobalVariables": false
}
```
## Up Next
With everything set up, you're ready to start making changes and create your first [PR][gh-pr]!
[go]: https://go.dev/
[go-started]: https://go.dev/doc/
[golang-ci-lint]: https://golangci-lint.run
2024-08-26 04:44:17 -07:00
[golang-ci-lint-local]: https://golangci-lint.run/welcome/install/#local-installation
[go-bindata]: https://github.com/kevinburke/go-bindata/
[go-global]: https://github.com/golang/go/issues/40276
2021-02-15 23:36:37 -08:00
[pr-go-mod]: https://github.com/JanDeDobbeleer/oh-my-posh/blob/main/.github/workflows/gomod.yml
[gh-pr]: https://github.com/JanDeDobbeleer/oh-my-posh/pulls
[omp]: https://github.com/JanDeDobbeleer/oh-my-posh
2020-12-25 10:37:18 -08:00
[gh-fork]: https://guides.github.com/activities/forking/
2022-05-12 22:54:59 -07:00
[code]: https://code.visualstudio.com
[delve]: https://github.com/go-delve/delve
[docusaurus]: https://docusaurus.io
2024-08-26 04:44:17 -07:00
[winget-configuration]: https://github.com/JanDeDobbeleer/oh-my-posh/blob/main/configurations/configuration.dsc.yaml
[winget]: https://learn.microsoft.com/en-us/windows/package-manager/winget/
[nodejs]: https://nodejs.org/en/download/