generated from krampus/template-godot4
Initial commit
This commit is contained in:
commit
6d52f9cc88
|
@ -0,0 +1,49 @@
|
|||
class-definitions-order:
|
||||
- tools
|
||||
- classnames
|
||||
- extends
|
||||
- docstrings
|
||||
- signals
|
||||
- enums
|
||||
- consts
|
||||
- exports
|
||||
- pubvars
|
||||
- prvvars
|
||||
- onreadypubvars
|
||||
- onreadyprvvars
|
||||
- staticvars
|
||||
- others
|
||||
class-load-variable-name: (([A-Z][a-z0-9]*)+|_?[a-z][a-z0-9]*(_[a-z0-9]+)*)
|
||||
class-name: ([A-Z][a-z0-9]*)+
|
||||
class-variable-name: _?[a-z][a-z0-9]*(_[a-z0-9]+)*
|
||||
comparison-with-itself: null
|
||||
constant-name: _?[A-Z][A-Z0-9]*(_[A-Z0-9]+)*
|
||||
disable: []
|
||||
duplicated-load: null
|
||||
enum-element-name: '[A-Z][A-Z0-9]*(_[A-Z0-9]+)*'
|
||||
enum-name: ([A-Z][a-z0-9]*)+
|
||||
excluded_directories: !!set
|
||||
.git: null
|
||||
addons: null
|
||||
expression-not-assigned: null
|
||||
function-argument-name: _?[a-z][a-z0-9]*(_[a-z0-9]+)*
|
||||
function-arguments-number: 10
|
||||
function-name: (_on_([A-Z][a-z0-9]*)+(_[a-z0-9]+)*|_?[a-z][a-z0-9]*(_[a-z0-9]+)*)
|
||||
function-preload-variable-name: ([A-Z][a-z0-9]*)+
|
||||
function-variable-name: '[a-z][a-z0-9]*(_[a-z0-9]+)*'
|
||||
load-constant-name: (([A-Z][a-z0-9]*)+|_?[A-Z][A-Z0-9]*(_[A-Z0-9]+)*)
|
||||
loop-variable-name: _?[a-z][a-z0-9]*(_[a-z0-9]+)*
|
||||
max-file-lines: 1000
|
||||
max-line-length: 100
|
||||
max-public-methods: 20
|
||||
max-returns: 6
|
||||
mixed-tabs-and-spaces: null
|
||||
no-elif-return: null
|
||||
no-else-return: null
|
||||
private-method-call: null
|
||||
signal-name: '[a-z][a-z0-9]*(_[a-z0-9]+)*'
|
||||
sub-class-name: _?([A-Z][a-z0-9]*)+
|
||||
tab-characters: 1
|
||||
trailing-whitespace: null
|
||||
unnecessary-pass: null
|
||||
unused-argument: null
|
|
@ -0,0 +1,4 @@
|
|||
# Normalize EOL for all files that Git considers text files.
|
||||
* text=auto eol=lf
|
||||
*.svg filter=lfs diff=lfs merge=lfs -text
|
||||
*.png filter=lfs diff=lfs merge=lfs -text
|
|
@ -0,0 +1,31 @@
|
|||
#!/bin/sh
|
||||
|
||||
GDFORMAT=gdformat
|
||||
GDLINT=gdlint
|
||||
VENV=.venv
|
||||
PYTHON=python3
|
||||
PIP=$VENV/bin/pip
|
||||
|
||||
if ! which $GDFORMAT &> /dev/null; then
|
||||
if ! test -f $VENV/bin/$GDFORMAT; then
|
||||
if ! which $PYTHON &> /dev/null; then
|
||||
echo "Please install Python 3"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "gdscript-toolkit will be installed locally under $VENV."
|
||||
echo "this only needs to be performed once."
|
||||
echo "creating venv..."
|
||||
$PYTHON -m venv $VENV
|
||||
echo "installing gdscript-toolkit..."
|
||||
$PIP install -r requirements.txt
|
||||
fi
|
||||
|
||||
GDFORMAT=$VENV/bin/$GDFORMAT
|
||||
GDLINT=$VENV/bin/$GDLINT
|
||||
fi
|
||||
|
||||
set -x
|
||||
|
||||
$GDFORMAT --check .
|
||||
$GDLINT .
|
|
@ -0,0 +1,21 @@
|
|||
# Godot 4+ specific ignores
|
||||
.godot/
|
||||
|
||||
# Godot-specific ignores
|
||||
.import/
|
||||
export.cfg
|
||||
export_presets.cfg
|
||||
|
||||
# Imported translations (automatically generated from CSV files)
|
||||
*.translation
|
||||
|
||||
# Mono-specific ignores
|
||||
.mono/
|
||||
data_*/
|
||||
mono_crash.*.json
|
||||
|
||||
# Python venv
|
||||
.venv
|
||||
|
||||
# Project demos
|
||||
/demos/
|
|
@ -0,0 +1,160 @@
|
|||
# DEVELOPMENT.md
|
||||
|
||||
This is a set of general guidelines for developers.
|
||||
|
||||
## Dev Tools
|
||||
|
||||
This project uses `gdlint` and `gdformat` from
|
||||
[Scony/godot-gdscript-toolkit](https://github.com/Scony/godot-gdscript-toolkit)
|
||||
for linting & formatting, respectively.
|
||||
|
||||
These tools are integrated into our development workflow using Godot
|
||||
plugins:
|
||||
[ryan-haskell/gdformat-on-save](https://github.com/ryan-haskell/gdformat-on-save)
|
||||
and
|
||||
[krampus/gdlint-plugin](https://git.of.the.spectacle.lol/krampus/gdlint-plugin)
|
||||
respectively.
|
||||
|
||||
When a script is saved in the Godot editor, it is automatically
|
||||
formatted and checked for linting errors which are shown as warnings.
|
||||
|
||||
### Setup on Linux Environment
|
||||
|
||||
`gdlint` and `gdformat` require Python >=3.8. On Ubuntu:
|
||||
|
||||
```bash
|
||||
$ sudo apt update
|
||||
$ sudo apt install python3 python3-venv
|
||||
```
|
||||
|
||||
Next, install `gdscript-toolkit` through `pip`:
|
||||
|
||||
```bash
|
||||
$ pip install --user -r requirements.txt
|
||||
```
|
||||
|
||||
Then run `godot`. The plugins should be configured automatically.
|
||||
|
||||
(If you prefer to install `gdscript-toolkit` in a venv, just make sure
|
||||
the plugins can find their required binaries.)
|
||||
|
||||
### Setup on Windows Environment
|
||||
|
||||
Download and run the appropriate installer from the [Python website](https://www.python.org/downloads/windows/)
|
||||
|
||||
During installation, select the "Add python.exe to PATH" checkbox when prompted.
|
||||
|
||||
Open "Windows PowerShell" and run the following command to make sure pip is installed:
|
||||
```
|
||||
pip --version
|
||||
```
|
||||
|
||||
Assuming pip is installed you should see a message like:
|
||||
```
|
||||
pip 24.0 from C:\Users\dummy\AppData\Local\Programs\Python\Python312\Lib\site-packages\pip (python 3.12)
|
||||
```
|
||||
|
||||
If pip is installed, run the following command to install the toolkit for the linter and formatter:
|
||||
```
|
||||
install gdtoolkit==4.2.2
|
||||
```
|
||||
|
||||
Then run the following command to finish the installation process:
|
||||
```
|
||||
pip install setuptools==69.5.1
|
||||
```
|
||||
|
||||
Check that everything installed by running "gdlint -h" and you should see something like:
|
||||
|
||||
```
|
||||
GDScript linter
|
||||
|
||||
A tool for diagnosing typical GDScript code problems.
|
||||
On success and the exitcode is 0.
|
||||
On failure, python exception or list of problems is shown and exitcode is non-zero.
|
||||
...
|
||||
```
|
||||
Also run "gdformat -h" and you should see something like:
|
||||
|
||||
```
|
||||
GDScript formatter
|
||||
|
||||
Uncompromising GDScript code formatter. The only configurable thing is
|
||||
max line length allowed and tabs/spaces indent. The rest will be taken
|
||||
care of by gdformat in a one, consistent way.
|
||||
...
|
||||
```
|
||||
|
||||
### Git Hooks
|
||||
|
||||
If you like, you can use the included githooks to automatically check formatting & linting before making a commit.
|
||||
|
||||
You can enable our githooks like this:
|
||||
|
||||
```bash
|
||||
$ git config core.hooksPath .githooks
|
||||
```
|
||||
|
||||
## Standards & Practices
|
||||
|
||||
### Style
|
||||
|
||||
Code should generally conform to the [GDScript style
|
||||
guide](https://docs.godotengine.org/en/stable/tutorials/scripting/gdscript/gdscript_styleguide.html)
|
||||
where possible. Use the provided [linter and formatter](#dev-tools) to
|
||||
apply most style guidelines automatically.
|
||||
|
||||
### Type Annotations
|
||||
|
||||
Use explicit type annotations wherever possible. Don't fret about it
|
||||
too much, this is GDScript and there are a lot of situations where you
|
||||
gotta do some freaky duck typing, but try to do as much explicit type
|
||||
annotation as you can.
|
||||
|
||||
### Organization
|
||||
|
||||
_NOTE update this section as we build out the project more_
|
||||
|
||||
- All non-code assets go under `assets`
|
||||
- Graphical assets go under `assets/images`
|
||||
- Sprites go under `assets/images/sprites`
|
||||
- Audio assets go under `assets/audio`
|
||||
- Music goes under `assets/audio/music`
|
||||
- SFX assets go under `assets/audio/sfx`
|
||||
- Video assets go under `assets/video`
|
||||
- Scenes and GDScript source files go under `src`
|
||||
- Godot plugins go under `addons`
|
||||
|
||||
## Git Workflow
|
||||
|
||||
We use a standard branching workflow. Here's the full process of getting something merged in:
|
||||
|
||||
1. [Create an issue](../../../issues/new) for the feature you want to
|
||||
implement or the bug you want to fix, and assign it to
|
||||
yourself. Alternately, pick an existing issue you want to work on
|
||||
from the [issue tracker](../../../issues).
|
||||
2. In your local repo, create a new branch off of `main`. Your feature
|
||||
branch's name should include the issue number and a brief
|
||||
descriptive title, e.g. `37-immanentize-eschaton` or similar.
|
||||
3. Build the feature or fix the bug or whatever it is you're
|
||||
doing. Frequent, small commits are preferred, and it's a good idea
|
||||
to merge new changes from `main` often.
|
||||
4. Push your changes to the server and
|
||||
[create a pull request](../../../compare/main...main) to merge your
|
||||
feature branch into `main`. Your PR description should include the
|
||||
changes you made. If you include the phrase _"closes #[issue
|
||||
number]"_ in your PR description, the issue will automatically be
|
||||
closed when your PR is merged, which is nice.
|
||||
5. Request review from `intrusive/Owners`. If your patch touches
|
||||
something you think a specific dev needs to see, tag them for
|
||||
review explicitly.
|
||||
6. Once your PR gets approval from either 1 member of
|
||||
`intrusive/Owners` or from the specific developer who needs to see
|
||||
it, merge it into `main` yourself. There should be a button on the
|
||||
PR page to do this. If it says you can't merge automatically, you
|
||||
probably need to merge new changes from `main`
|
||||
7. If it wasn't done automatically, close the issue and delete the
|
||||
feature branch.
|
||||
|
||||
Try to stick to the above workflow as much as you can, but occasional
|
||||
shortcuts for hotfixes etc aren't the end of the world.
|
|
@ -0,0 +1,7 @@
|
|||
# Sunstation
|
||||
|
||||
Stylish mech combat game (prototype)
|
||||
|
||||
## Development
|
||||
|
||||
see [[DEVELOPMENT.md]]
|
|
@ -0,0 +1,21 @@
|
|||
MIT License
|
||||
|
||||
Copyright (c) 2023 Ryan Haskell-Glatz
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
|
@ -0,0 +1,70 @@
|
|||
@tool
|
||||
class_name FormatOnSave extends EditorPlugin
|
||||
|
||||
const SUCCESS: int = 0
|
||||
const AUTO_RELOAD_SETTING: String = "text_editor/behavior/files/auto_reload_scripts_on_external_change"
|
||||
var original_auto_reload_setting: bool
|
||||
|
||||
|
||||
# LIFECYCLE EVENTS
|
||||
func _enter_tree():
|
||||
activate_auto_reload_setting()
|
||||
resource_saved.connect(on_resource_saved)
|
||||
|
||||
|
||||
func _exit_tree():
|
||||
resource_saved.disconnect(on_resource_saved)
|
||||
restore_original_auto_reload_setting()
|
||||
|
||||
|
||||
# CALLED WHEN A SCRIPT IS SAVED
|
||||
func on_resource_saved(resource: Resource):
|
||||
if resource is Script:
|
||||
var script: Script = resource
|
||||
var current_script = get_editor_interface().get_script_editor().get_current_script()
|
||||
var text_edit: CodeEdit = (
|
||||
get_editor_interface().get_script_editor().get_current_editor().get_base_editor()
|
||||
)
|
||||
|
||||
# Prevents other unsaved scripts from overwriting the active one
|
||||
if current_script == script:
|
||||
var filepath: String = ProjectSettings.globalize_path(resource.resource_path)
|
||||
|
||||
# Run gdformat
|
||||
var exit_code = OS.execute("gdformat", [filepath])
|
||||
|
||||
# Replace source_code with formatted source_code
|
||||
if exit_code == SUCCESS:
|
||||
var formatted_source = FileAccess.get_file_as_string(resource.resource_path)
|
||||
FormatOnSave.reload_script(text_edit, formatted_source)
|
||||
|
||||
|
||||
# Workaround until this PR is merged:
|
||||
# https://github.com/godotengine/godot/pull/83267
|
||||
# Thanks, @KANAjetzt 💖
|
||||
static func reload_script(text_edit: TextEdit, source_code: String) -> void:
|
||||
var column := text_edit.get_caret_column()
|
||||
var row := text_edit.get_caret_line()
|
||||
var scroll_position_h := text_edit.get_h_scroll_bar().value
|
||||
var scroll_position_v := text_edit.get_v_scroll_bar().value
|
||||
|
||||
text_edit.text = source_code
|
||||
text_edit.set_caret_column(column)
|
||||
text_edit.set_caret_line(row)
|
||||
text_edit.scroll_horizontal = scroll_position_h
|
||||
text_edit.scroll_vertical = scroll_position_v
|
||||
|
||||
text_edit.tag_saved_version()
|
||||
|
||||
|
||||
# For this workaround to work, we need to disable the "Reload/Resave" pop-up
|
||||
func activate_auto_reload_setting():
|
||||
var settings := get_editor_interface().get_editor_settings()
|
||||
original_auto_reload_setting = settings.get(AUTO_RELOAD_SETTING)
|
||||
settings.set(AUTO_RELOAD_SETTING, true)
|
||||
|
||||
|
||||
# If the plugin is disabled, let's attempt to restore the original editor setting
|
||||
func restore_original_auto_reload_setting():
|
||||
var settings := get_editor_interface().get_editor_settings()
|
||||
settings.set(AUTO_RELOAD_SETTING, original_auto_reload_setting)
|
|
@ -0,0 +1,6 @@
|
|||
[plugin]
|
||||
name="Format on Save"
|
||||
description="Runs `gdformat` on save to automatically format your GD script as you code."
|
||||
author="Ryan Haskell-Glatz"
|
||||
version="1.2.0"
|
||||
script="format_on_save.gd"
|
|
@ -0,0 +1,21 @@
|
|||
MIT License
|
||||
|
||||
Copyright (c) 2024 Rob Kelly <contact@robkel.ly>
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
|
@ -0,0 +1,6 @@
|
|||
[plugin]
|
||||
name="gdLint Plugin"
|
||||
description="Static code analysis with `gdlint`"
|
||||
author="Rob Kelly"
|
||||
version="1.0.0"
|
||||
script="run_linter.gd"
|
|
@ -0,0 +1,33 @@
|
|||
@tool
|
||||
class_name GDLintPlugin extends EditorPlugin
|
||||
|
||||
# If you've installed gdlint in a venv, you may want to overwrite this
|
||||
const GDLINT: String = "gdlint"
|
||||
|
||||
|
||||
func _enter_tree() -> void:
|
||||
assert(not OS.execute(GDLINT, ["-h"]), "Could not find gdLint binary at {0}".format([GDLINT]))
|
||||
resource_saved.connect(on_save)
|
||||
|
||||
|
||||
func _exit_tree() -> void:
|
||||
resource_saved.disconnect(on_save)
|
||||
|
||||
|
||||
func on_save(resource: Resource) -> void:
|
||||
# Run linting when a script resource is saved
|
||||
if resource is Script:
|
||||
var script: Script = resource
|
||||
var filepath: String = ProjectSettings.globalize_path(resource.resource_path)
|
||||
|
||||
var script_editor = EditorInterface.get_script_editor()
|
||||
var code_editor: CodeEdit = (
|
||||
script_editor.get_current_editor().get_base_editor()
|
||||
if script_editor.get_current_script() == script
|
||||
else null
|
||||
)
|
||||
|
||||
var gdlint_output: Array[String] = []
|
||||
var error: int = OS.execute(GDLINT, [filepath], gdlint_output, true)
|
||||
if error:
|
||||
push_warning("gdLint:\n" + gdlint_output[0])
|
|
@ -0,0 +1,40 @@
|
|||
; Engine configuration file.
|
||||
; It's best edited using the editor UI and not directly,
|
||||
; since the parameters that go here are not all obvious.
|
||||
;
|
||||
; Format:
|
||||
; [section] ; section goes between []
|
||||
; param=value ; assign values to parameters
|
||||
|
||||
config_version=5
|
||||
|
||||
[application]
|
||||
|
||||
config/name="Sunstation"
|
||||
config/features=PackedStringArray("4.2", "Forward Plus")
|
||||
run/max_fps=60
|
||||
config/icon="res://icon.svg"
|
||||
|
||||
[debug]
|
||||
|
||||
gdscript/warnings/untyped_declaration=2
|
||||
gdscript/warnings/unsafe_property_access=2
|
||||
gdscript/warnings/unsafe_method_access=2
|
||||
gdscript/warnings/unsafe_cast=1
|
||||
gdscript/warnings/unsafe_call_argument=2
|
||||
|
||||
[display]
|
||||
|
||||
window/stretch/mode="canvas_items"
|
||||
|
||||
[dotnet]
|
||||
|
||||
project/assembly_name="Sunstation"
|
||||
|
||||
[editor]
|
||||
|
||||
movie_writer/movie_file="demos/demo.avi"
|
||||
|
||||
[editor_plugins]
|
||||
|
||||
enabled=PackedStringArray("res://addons/format_on_save/plugin.cfg", "res://addons/gdlint_plugin/plugin.cfg")
|
|
@ -0,0 +1,2 @@
|
|||
gdtoolkit>=4.2.2,<4.3
|
||||
setuptools>=69.5.1,<69.6
|
Loading…
Reference in New Issue