summaryrefslogtreecommitdiffstats
path: root/editor/project_converter_3_to_4.cpp
Commit message (Collapse)AuthorAgeFilesLines
* Merge commit godotengine/godot@fd4c29a189e53a1e085df5b9b9a05cac9351b3efSpartan3222024-11-191-3/+3
|\
| * Use `(r)find_char` instead of `(r)find` for single charactersA Thousand Ships2024-11-171-3/+3
| |
* | Merge commit godotengine/godot@87318a2fb7fffeb72adca934e31915be077c3d1fSpartan3222024-11-061-2/+4
|\|
| * Style: Apply `clang-tidy` fixes (superficial)Thaddeus Crews2024-11-041-2/+4
| | | | | | | | • `modernize-use-bool-literals`, `modernize-use-nullptr`, and `readability-braces-around-statements`
* | Merge commit godotengine/godot@8004c7524fb9f43425c4d6f614410a76678e0f7cSpartan3222024-10-301-6/+6
|\|
| * Set clang-format `RemoveSemicolon` rule to `true`Adam Scott2024-10-251-6/+6
| | | | | | | | - Set clang-format `Standard` rule to `c++20`
* | Fix copyright headers referring to GodotSpartan3222024-10-271-2/+2
| |
* | Rebrand preambles to RedotDubhghlas McLaughlin2024-10-111-0/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Credits: Co-authored-by: Skogi <skogi.b@gmail.com> Co-authored-by: Spartan322 <Megacake1234@gmail.com> Co-authored-by: swashberry <swashdev@pm.me> Co-authored-by: Christoffer Sundbom <christoffer_karlsson@live.se> Co-authored-by: Dubhghlas McLaughlin <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: McDubh <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: Dubhghlas McLaughlin <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: radenthefolf <radenthefolf@gmail.com> Co-authored-by: John Knight <80524176+Tekisasu-JohnK@users.noreply.github.com> Co-authored-by: Adam Vondersaar <adam.vondersaar@uphold.com> Co-authored-by: decryptedchaos <nixgod@gmail.com> Co-authored-by: zaftnotameni <122100803+zaftnotameni@users.noreply.github.com> Co-authored-by: Aaron Benjamin <lifeartstudios@gmail.com> Co-authored-by: wesam <108880473+wesamdev@users.noreply.github.com> Co-authored-by: Mister Puma <MisterPuma80@gmail.com> Co-authored-by: Aaron Benjamin <lifeartstudios@gmail.com> Co-authored-by: SingleError <isaaconeoneone@gmail.com> Co-authored-by: Bioblaze Payne <BioblazePayne@gmail.com>
* | Rebrand Godot to RedotRandolph W. Aarseth II2024-10-111-18/+18
|/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Add Linux Editor tests workflow matrix Add Windows Editor w/ Mono workflow matrix Add Generate Glue Code job to Windows workflow Add Build GodotSharp job to Windows workflow Add godot compatibility version references Add Godot author info Add Godot version compatibility info Add Godot donor info Add Godot authors and donors to editor_about.cpp Credits: Co-authored-by: Skogi <skogi.b@gmail.com> Co-authored-by: Spartan322 <Megacake1234@gmail.com> Co-authored-by: swashberry <swashdev@pm.me> Co-authored-by: Christoffer Sundbom <christoffer_karlsson@live.se> Co-authored-by: Dubhghlas McLaughlin <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: McDubh <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: Dubhghlas McLaughlin <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: radenthefolf <radenthefolf@gmail.com> Co-authored-by: John Knight <80524176+Tekisasu-JohnK@users.noreply.github.com> Co-authored-by: Adam Vondersaar <adam.vondersaar@uphold.com> Co-authored-by: decryptedchaos <nixgod@gmail.com> Co-authored-by: zaftnotameni <122100803+zaftnotameni@users.noreply.github.com> Co-authored-by: Aaron Benjamin <lifeartstudios@gmail.com> Co-authored-by: wesam <108880473+wesamdev@users.noreply.github.com> Co-authored-by: Mister Puma <MisterPuma80@gmail.com> Co-authored-by: Aaron Benjamin <lifeartstudios@gmail.com> Co-authored-by: SingleError <isaaconeoneone@gmail.com> Co-authored-by: Bioblaze Payne <BioblazePayne@gmail.com>
* Add const lvalue ref to editor/* container parametersMuller-Castro2024-02-261-9/+9
|
* Add ufbx for FBX importingK. S. Ernest (iFire) Lee2024-02-231-1/+1
| | | | | | | | | | | | | | | | This update introduces a new import method for FBX files using ufbx. If the fbx2gltf import fails, it will use the most recently cached scene from the ufbx import. The process is sped up by introducing threads to load the ufbx portion. Key changes include: - Support for importing geometry helper nodes in FBX files. - Addition of cameras and lights with updated names. - Removal of the fbx importer manager. - Introduction of ModelDocument3D and updates to its methods. - Changes to FBX import options and visibility. - Updating the documentation and handling some errors. - Store the original non-unique node, mesh and animation names in FBX and glTF. Co-Authored-By: bqqbarbhg <bqqbarbhg@gmail.com>
* Add deprecation notice to a duplicate method of class `Window`Jakub Marcowski2024-01-121-1/+1
|
* Merge pull request #85837 from akien-mga/clang-format-16Rémi Verschelde2024-01-051-99/+100
|\ | | | | | | Style: Mark clang-format 16 as supported for pre-commit hook
| * Style: Mark clang-format 16 as supported for pre-commit hookRémi Verschelde2023-12-061-99/+100
| | | | | | | | | | | | | | | | | | It only introduced a difference in a .glsl file, which I've worked around by removing an empty line. This keeps formatting consistent between clang-format 15 and 16. Also added a change in the 3-to-4 project converter to fix bogus formatting in clang-format < 17.
* | Merge pull request #84445 from Rubonnek/add-const-references-clang-tidyRémi Verschelde2024-01-041-6/+6
|\ \ | | | | | | | | | Add const references detected by clang-tidy
| * | Add const references detected by clang-tidyWilson E. Alvarez2023-12-161-6/+6
| |/
* / project upgrade tool: better space handling in "export"pancelor2023-12-281-4/+5
|/ | | | | | | | | | | | | | | | | the regex had two problems; they were not recognizing export statements that had spaces after "export", or export statements with no space before "var". These are both valid syntax, but the conversion was unsuccessful. This commit fixes both cases. test case 1: `export(int)var x = 1` old conversion: `@export(int)var x = 1` new conversion: `@export var x: int = 1` test case 2: `export (int) var y = 2` old conversion: `@export (int) var y = 2` new conversion: `@export var y: int = 2`
* Fix some typos in source.emacser02023-10-041-3/+3
|
* Fix conversion of hex color strings in project converterEric Liu2023-09-291-1/+29
|
* Merge pull request #79277 from akien-mga/godot-4-everRémi Verschelde2023-07-101-23/+23
|\ | | | | | | Change explicit 'Godot 4.0' references to 'Godot 4'
| * Change explicit 'Godot 4.0' references to 'Godot 4'Rémi Verschelde2023-07-101-23/+23
| | | | | | | | Fixes #79276.
* | Fix `Camera2D.rotating` not being converted and reversed properlyEmmanouil Papadeas2023-07-101-4/+5
|/ | | | Godot 3's Camera2D `rotating = true` and `rotating = false` are supposed to be converted and reversed to `ignore_rotation = false` and `ignore_rotation = true` respectively, but this wasn't the case before this PR, as the project converted was failing to properly read the `true` and `false` strings, thus resulting in `ignore_rotation = true` in all cases.
* Merge pull request #74567 from Garym3/3-to-4-converter-brace-aggregate-fixRémi Verschelde2023-06-201-9/+5
|\ | | | | | | Fix braces handling when parsing method arguments on project conversion
| * Fix braces handling when parsing method arguments on project conversionGarym32023-06-201-9/+5
| |
* | Merge pull request #76179 from Maran23/pause-mode-convert-fixRémi Verschelde2023-06-191-2/+24
|\ \ | | | | | | | | | Fix `pause_mode` may not be converted correctly in .tscn files.
| * | Fix pause_mode may not be converted correctly in .tscn files.Marius Hanl2023-04-171-2/+24
| | |
* | | Merge pull request #74580 from ↵Rémi Verschelde2023-06-161-0/+2
|\ \ \ | | | | | | | | | | | | | | | | | | | | Garym3/3-to-4-converter-fix-ogg-import-file-conversion Fix bad OGG importer's name inside .import files during project conversion
| * | | Fix runtime crash due to missing importer's name conversion inside .import ↵Garym32023-06-151-0/+2
| | |/ | |/| | | | | | | files about OGG vorbis sound files
* | | Merge pull request #77615 from jpcerrone/add_joypad_conversionRémi Verschelde2023-06-131-0/+98
|\ \ \ | | | | | | | | Add joypad input map conversion to project converter
| * | | Add joypad input map conversion to project converter.jpcerrone2023-05-291-0/+98
| | | | | | | | | | | | | | | | Fixes godotengine#77314 (Input Map's joypad button numbers are not converted).
* | | | Merge pull request #75900 from ↵Rémi Verschelde2023-06-121-7/+14
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | Maran23/project-converter-declaring-inferring-types Fix exported variables declaring or inferring the type were not converted correctly
| * | | | Fix exported variables declaring or inferring the type were not converted ↵Marius Hanl2023-06-121-7/+14
| | | | | | | | | | | | | | | | | | | | correctly.
* | | | | Improve function detection to avoid accidental conversionMarius Hanl2023-06-121-35/+59
|/ / / / | | | | | | | | | | | | When converting a function like "connect(", we do not want to detect a function like "reconnect(" as a possible candidate for conversion.
* / / / removing assert statement from the project converterAlex Drozd2023-06-101-15/+0
|/ / /
* | | Ensure quotes are escaped when converting builtin scriptsNinni Pipping2023-05-231-37/+49
| | |
* | | Fix Input Map key assignments missing after project conversionjpcerrone2023-05-161-0/+1
| |/ |/| | | | | | | | | | | | | | | Fixes #76336 (Input Map keys missing). Moves the project.godot config_version stamping from the project manager to the project converter. Now there's no difference between converting through the project manager and the CLI tool. Fixes being prompted to re-convert the project in the project manager after having done so through the CLI tool.
* | Add GDScript `to_wchar_buffer` and `get_string_from_wchar` functions.bruvzg2023-03-211-1/+1
| |
* | Merge pull request #74624 from Maran23/converter-theme-overridesYuri Sizov2023-03-151-0/+14
|\ \ | | | | | | Add conversion for common Theme Overrides
| * | Add conversion for common Theme OverridesMarius Hanl2023-03-101-0/+14
| | |
* | | Add parentheses around arguments when converting xformclayjohn2023-03-091-4/+4
|/ /
* / Add some missing renames to 3to4 tool.Ryan Roden-Corrent2023-03-061-0/+4
|/ | | | | | | MultiplayerPeerExtension isn't an exact replacement for NetworkedMultiplayerCustom, but at least it gets you moving in the right direction. Engine.editor_hint couldn't be fixed by the renames map, because you have to add a `()` at the end.
* Move tool declarations to top in 3to4.Ryan Roden-Corrent2023-03-061-6/+17
| | | | | In godot3, `tool` can follow keywords like `extends` and `class_name` In godot4, `@tool` must be the first line in the file.
* Merge pull request #74306 from dalexeev/gds-var-colon-styleRémi Verschelde2023-03-061-7/+7
|\ | | | | | | Fix GDScript code style regarding colon
| * Fix GDScript code style regarding colonDanil Alexeev2023-03-051-7/+7
| |
* | Project Converter: Do not convert lines that start with a commentMarius Hanl2023-03-061-75/+151
| | | | | | | | Lines that start with # or // are ignored
* | Correct superclass constructors in 3to4.Ryan Roden-Corrent2023-03-041-10/+14
|/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixes #70542. The 3to4 conversion tool was not handling superclass constructors. We should translate the godot3 syntax: ```gdscript func _init(a,b,c).(a,b,c): pass func _init(a,b,c): super(a,b,c) ``` Originally, the _init conversion was intended to remove `void` return types from _init functions, as this was disallowed due to #50589. As that was resolved by #53366, I removed that part of the conversion logic. If a void return type is present on a constructor, the converter now leaves it. Here's a sample diff from my own project: ```diff @@ -103,10 +105,11 @@ class Real: class Text: extends Setting - var choices: PoolStringArray - var value: String setget set_value, get_value + var choices: PackedStringArray + var value: String : get = get_value, set = set_value - func _init(section: String, key: String, default: String, choice_list: Array).(section, key, default) -> void: + func _init(section: String, key: String, default: String, choice_list: Array) -> void: + super(section, key, default) choices = choice_list func normalize(val): @@ -129,9 +132,10 @@ class Text: class Boolean: extends Setting - var value: bool setget set_value, get_value + var value: bool : get = get_value, set = set_value - func _init(section: String, key: String, default: bool).(section, key, default) -> void: + func _init(section: String, key: String, default: bool) -> void: + super(section, key, default) pass ```
* Merge pull request #74237 from AThousandShips/convert_keycodeRémi Verschelde2023-03-031-0/+62
|\ | | | | | | Add keycode project conversion
| * Add keycode project conversionNinni Pipping2023-03-021-0/+62
| |
* | Don't strip whitespace when converting 3to4.Ryan Roden-Corrent2023-03-021-54/+54
|/ | | | | | | | | | | | | | | | | | Fixes #74204. The style guide says > Always use one space around operators and after commas The 3to4 conversion tool currently strips space in certain scenarios. I've updated it to add space whenever it is generating new code. In any case where it substitutes existing code, it leaves it as-is. For example, connect(a,b,c) becomes `connect(a, callable(b, c))`, because the converter is adding new commads/parens. However, `xform(Vector3(a,b,c))` becomes `Transform * Vector3(a,b,c)` because it uses the user's original Vector3 string whole. If the user originally had `xform(Vector3(a, b, c))`, then it becomes `Transform * Vector3(a, b, c)`. Ideally we'd always preserve original formatting, but this seems quite difficult, so I tried to preserve it where we can, but air on the side of following the style guide whenever we're transforming code.
* Add 3-to-4 renames for project settings in project.godotRémi Verschelde2023-02-271-3/+12
| | | | | | | In the ConfigFile format, the first subpath is the category and is not part of the line that the regex would match. Fixes #66125.