faq.rst 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  1. .. meta::
  2. :keywords: FAQ
  3. .. _doc_faq:
  4. Frequently asked questions
  5. ==========================
  6. What can I do with Godot? How much does it cost? What are the license terms?
  7. ----------------------------------------------------------------------------
  8. Godot is `Free and open source Software <https://en.wikipedia.org/wiki/Free_and_open_source_software>`_
  9. available under the `OSI-approved <https://opensource.org/licenses/MIT>`_ MIT license. This means it is
  10. free as in "free speech" as well as in "free beer."
  11. In short:
  12. * You are free to download and use Godot for any purpose: personal, non-profit, commercial, or otherwise.
  13. * You are free to modify, distribute, redistribute, and remix Godot to your heart's content, for any reason,
  14. both non-commercially and commercially.
  15. All the contents of this accompanying documentation are published under the permissive Creative Commons
  16. Attribution 3.0 (`CC BY 3.0 <https://creativecommons.org/licenses/by/3.0/>`_) license, with attribution
  17. to "Juan Linietsky, Ariel Manzur and the Godot Engine community."
  18. Logos and icons are generally under the same Creative Commons license. Note
  19. that some third-party libraries included with Godot's source code may have
  20. different licenses.
  21. For full details, look at the `COPYRIGHT.txt <https://github.com/godotengine/godot/blob/master/COPYRIGHT.txt>`_
  22. as well as the `LICENSE.txt <https://github.com/godotengine/godot/blob/master/LICENSE.txt>`_
  23. and `LOGO_LICENSE.txt <https://github.com/godotengine/godot/blob/master/LOGO_LICENSE.txt>`_ files
  24. in the Godot repository.
  25. Also, see `the license page on the Godot website <https://godotengine.org/license>`_.
  26. Which platforms are supported by Godot?
  27. ---------------------------------------
  28. **For the editor:**
  29. * Windows
  30. * macOS
  31. * Linux, \*BSD
  32. * Android (experimental)
  33. * `Web <https://editor.godotengine.org/>`__ (experimental)
  34. **For exporting your games:**
  35. * Windows
  36. * macOS
  37. * Linux, \*BSD
  38. * Android
  39. * iOS
  40. * Web
  41. Both 32- and 64-bit binaries are supported where it makes sense, with 64
  42. being the default. Official macOS builds support Apple Silicon natively as well as x86_64.
  43. Some users also report building and using Godot successfully on ARM-based
  44. systems with Linux, like the Raspberry Pi.
  45. The Godot team can't provide an open source console export due to the licensing
  46. terms imposed by console manufacturers. Regardless of the engine you use,
  47. though, releasing games on consoles is always a lot of work. You can read more
  48. about :ref:`doc_consoles`.
  49. For more on this, see the sections on :ref:`exporting <toc-learn-workflow-export>`
  50. and :ref:`compiling Godot yourself <toc-devel-compiling>`.
  51. .. note::
  52. Godot 3 also had support for Universal Windows Platform (UWP). This platform
  53. port was removed in Godot 4 due to lack of maintenance, and it being
  54. deprecated by Microsoft. It is still available in the current stable release
  55. of Godot 3 for interested users.
  56. Which programming languages are supported in Godot?
  57. ---------------------------------------------------
  58. The officially supported languages for Godot are GDScript, C#, and C++.
  59. See the subcategories for each language in the :ref:`scripting <toc-learn-scripting>` section.
  60. If you are just starting out with either Godot or game development in general,
  61. GDScript is the recommended language to learn and use since it is native to Godot.
  62. While scripting languages tend to be less performant than lower-level languages in
  63. the long run, for prototyping, developing Minimum Viable Products (MVPs), and
  64. focusing on Time-To-Market (TTM), GDScript will provide a fast, friendly, and capable
  65. way of developing your games.
  66. Note that C# support is still relatively new, and as such, you may encounter
  67. some issues along the way. C# support is also currently missing on the web
  68. platform. Our friendly and hard-working development community is always
  69. ready to tackle new problems as they arise, but since this is an open source
  70. project, we recommend that you first do some due diligence yourself. Searching
  71. through discussions on
  72. `open issues <https://github.com/godotengine/godot/issues?q=is%3Aopen+is%3Aissue+label%3Atopic%3Adotnet>`__
  73. is a great way to start your troubleshooting.
  74. As for new languages, support is possible via third parties with GDExtensions. (See the question
  75. about plugins below). Work is currently underway, for example, on unofficial bindings for Godot
  76. to `Python <https://github.com/touilleMan/godot-python>`_ and `Nim <https://github.com/pragmagic/godot-nim>`_.
  77. .. _doc_faq_what_is_gdscript:
  78. What is GDScript and why should I use it?
  79. -----------------------------------------
  80. GDScript is Godot's integrated scripting language. It was built from the ground
  81. up to maximize Godot's potential in the least amount of code, affording both novice
  82. and expert developers alike to capitalize on Godot's strengths as fast as possible.
  83. If you've ever written anything in a language like Python before, then you'll feel
  84. right at home. For examples and a complete overview of the power GDScript offers
  85. you, check out the :ref:`GDScript scripting guide <doc_gdscript>`.
  86. There are several reasons to use GDScript, especially when you are prototyping, in
  87. alpha/beta stages of your project, or are not creating the next AAA title. The
  88. most salient reason is the overall **reduction of complexity**.
  89. The original intent of creating a tightly integrated, custom scripting language for
  90. Godot was two-fold: first, it reduces the amount of time necessary to get up and running
  91. with Godot, giving developers a rapid way of exposing themselves to the engine with a
  92. focus on productivity; second, it reduces the overall burden of maintenance, attenuates
  93. the dimensionality of issues, and allows the developers of the engine to focus on squashing
  94. bugs and improving features related to the engine core, rather than spending a lot of time
  95. trying to get a small set of incremental features working across a large set of languages.
  96. Since Godot is an open source project, it was imperative from the start to prioritize a
  97. more integrated and seamless experience over attracting additional users by supporting
  98. more familiar programming languages, especially when supporting those more familiar
  99. languages would result in a worse experience. We understand if you would rather use
  100. another language in Godot (see the list of supported options above). That being said, if
  101. you haven't given GDScript a try, try it for **three days**. Just like Godot,
  102. once you see how powerful it is and rapid your development becomes, we think GDScript
  103. will grow on you.
  104. More information about getting comfortable with GDScript or dynamically typed
  105. languages can be found in the :ref:`doc_gdscript_more_efficiently` tutorial.
  106. What were the motivations behind creating GDScript?
  107. ---------------------------------------------------
  108. In the early days, the engine used the `Lua <https://www.lua.org>`__ scripting
  109. language. Lua can be fast thanks to LuaJIT, but creating bindings to an object-oriented
  110. system (by using fallbacks) was complex and slow and took an enormous
  111. amount of code. After some experiments with `Python <https://www.python.org>`__,
  112. that also proved difficult to embed.
  113. The main reasons for creating a custom scripting language for Godot were:
  114. 1. Poor threading support in most script VMs, and Godot uses threads
  115. (Lua, Python, Squirrel, JavaScript, ActionScript, etc.).
  116. 2. Poor class-extending support in most script VMs, and adapting to
  117. the way Godot works is highly inefficient (Lua, Python, JavaScript).
  118. 3. Many existing languages have horrible interfaces for binding to C++, resulting in a
  119. large amount of code, bugs, bottlenecks, and general inefficiency (Lua, Python,
  120. Squirrel, JavaScript, etc.). We wanted to focus on a great engine, not a great number
  121. of integrations.
  122. 4. No native vector types (Vector3, Transform3D, etc.), resulting in highly
  123. reduced performance when using custom types (Lua, Python, Squirrel,
  124. JavaScript, ActionScript, etc.).
  125. 5. Garbage collector results in stalls or unnecessarily large memory
  126. usage (Lua, Python, JavaScript, ActionScript, etc.).
  127. 6. Difficulty integrating with the code editor for providing code
  128. completion, live editing, etc. (all of them).
  129. GDScript was designed to curtail the issues above, and more.
  130. What 3D model formats does Godot support?
  131. -----------------------------------------
  132. You can find detailed information on supported formats, how to export them from
  133. your 3D modeling software, and how to import them for Godot in the
  134. :ref:`doc_importing_3d_scenes` documentation.
  135. Will [insert closed SDK such as FMOD, GameWorks, etc.] be supported in Godot?
  136. -----------------------------------------------------------------------------
  137. The aim of Godot is to create a free and open source MIT-licensed engine that
  138. is modular and extendable. There are no plans for the core engine development
  139. community to support any third-party, closed-source/proprietary SDKs, as integrating
  140. with these would go against Godot's ethos.
  141. That said, because Godot is open source and modular, nothing prevents you or
  142. anyone else interested in adding those libraries as a module and shipping your
  143. game with them, as either open- or closed-source.
  144. To see how support for your SDK of choice could still be provided, look at the
  145. Plugins question below.
  146. If you know of a third-party SDK that is not supported by Godot but that offers
  147. free and open source integration, consider starting the integration work yourself.
  148. Godot is not owned by one person; it belongs to the community, and it grows along
  149. with ambitious community contributors like you.
  150. How can I extend Godot?
  151. -----------------------
  152. For extending Godot, like creating Godot Editor plugins or adding support
  153. for additional languages, take a look at :ref:`EditorPlugins <doc_making_plugins>`
  154. and tool scripts.
  155. Also, see the official blog post on GDExtension, a way to develop native extensions for Godot:
  156. * `Introducing GDNative's successor, GDExtension <https://godotengine.org/article/introducing-gd-extensions>`_
  157. You can also take a look at the GDScript implementation, the Godot modules,
  158. as well as the `Jolt physics engine integration <https://github.com/godot-jolt/godot-jolt>`__
  159. for Godot. This would be a good starting point to see how another
  160. third-party library integrates with Godot.
  161. How do I install the Godot editor on my system (for desktop integration)?
  162. -------------------------------------------------------------------------
  163. Since you don't need to actually install Godot on your system to run it,
  164. this means desktop integration is not performed automatically.
  165. There are two ways to overcome this. You can install Godot from
  166. `Steam <https://store.steampowered.com/app/404790/Godot_Engine/>`__ (all platforms),
  167. `Scoop <https://scoop.sh/>`__ (Windows), `Homebrew <https://brew.sh/>`__ (macOS)
  168. or `Flathub <https://flathub.org/apps/details/org.godotengine.Godot>`__ (Linux).
  169. This will automatically perform the required steps for desktop integration.
  170. Alternatively, you can manually perform the steps that an installer would do for you:
  171. Windows
  172. ^^^^^^^
  173. - Move the Godot executable to a stable location (i.e. outside of your Downloads folder),
  174. so you don't accidentally move it and break the shortcut in the future.
  175. - Right-click the Godot executable and choose **Create Shortcut**.
  176. - Move the created shortcut to ``%APPDATA%\Microsoft\Windows\Start Menu\Programs``.
  177. This is the user-wide location for shortcuts that will appear in the Start menu.
  178. You can also pin Godot in the task bar by right-clicking the executable and choosing
  179. **Pin to Task Bar**.
  180. macOS
  181. ^^^^^
  182. Drag the extracted Godot application to ``/Applications/Godot.app``, then drag it
  183. to the Dock if desired. Spotlight will be able to find Godot as long as it's in
  184. ``/Applications`` or ``~/Applications``.
  185. Linux
  186. ^^^^^
  187. - Move the Godot binary to a stable location (i.e. outside of your Downloads folder),
  188. so you don't accidentally move it and break the shortcut in the future.
  189. - Rename and move the Godot binary to a location present in your ``PATH`` environment variable.
  190. This is typically ``/usr/local/bin/godot`` or ``/usr/bin/godot``.
  191. Doing this requires administrator privileges,
  192. but this also allows you to
  193. :ref:`run the Godot editor from a terminal <doc_command_line_tutorial>` by entering ``godot``.
  194. - If you cannot move the Godot editor binary to a protected location, you can
  195. keep the binary somewhere in your home directory, and modify the ``Path=``
  196. line in the ``.desktop`` file linked below to contain the full *absolute* path
  197. to the Godot binary.
  198. - Save `this .desktop file <https://raw.githubusercontent.com/godotengine/godot/master/misc/dist/linux/org.godotengine.Godot.desktop>`__
  199. to ``$HOME/.local/share/applications/``. If you have administrator privileges,
  200. you can also save the ``.desktop`` file to ``/usr/local/share/applications``
  201. to make the shortcut available for all users.
  202. Is the Godot editor a portable application?
  203. -------------------------------------------
  204. In its default configuration, Godot is *semi-portable*. Its executable can run
  205. from any location (including non-writable locations) and never requires
  206. administrator privileges.
  207. However, configuration files will be written to the user-wide configuration or
  208. data directory. This is usually a good approach, but this means configuration files
  209. will not carry across machines if you copy the folder containing the Godot executable.
  210. See :ref:`doc_data_paths` for more information.
  211. If *true* portable operation is desired (e.g. for use on an USB stick),
  212. follow the steps in :ref:`doc_data_paths_self_contained_mode`.
  213. Why does Godot use Vulkan or OpenGL instead of Direct3D?
  214. --------------------------------------------------------
  215. Godot aims for cross-platform compatibility and open standards first and
  216. foremost. OpenGL and Vulkan are the technologies that are both open and
  217. available on (nearly) all platforms. Thanks to this design decision, a project
  218. developed with Godot on Windows will run out of the box on Linux, macOS, and
  219. more.
  220. Since Godot only has a few people working on its renderer, we would prefer
  221. having fewer rendering backends to maintain. On top of that, using a single API
  222. on all platforms allows for greater consistency with fewer platform-specific
  223. issues.
  224. In the long term, we may develop a Direct3D 12 renderer for Godot (mainly for
  225. Xbox), but Vulkan and OpenGL will remain the default rendering
  226. backends on all platforms, including Windows.
  227. Why does Godot aim to keep its core feature set small?
  228. ------------------------------------------------------
  229. Godot intentionally does not include features that can be implemented by add-ons
  230. unless they are used very often. One example of something not used often is
  231. advanced artificial intelligence functionality.
  232. There are several reasons for this:
  233. - **Code maintenance and surface for bugs.** Every time we accept new code in
  234. the Godot repository, existing contributors often take the responsibility of
  235. maintaining it. Some contributors don't always stick around after getting
  236. their code merged, which can make it difficult for us to maintain the code in
  237. question. This can lead to poorly maintained features with bugs that are never
  238. fixed. On top of that, the "API surface" that needs to be tested and checked
  239. for regressions keeps increasing over time.
  240. - **Ease of contribution.** By keeping the codebase small and tidy, it can remain
  241. fast and easy to compile from source. This makes it easier for new
  242. contributors to get started with Godot, without requiring them to purchase
  243. high-end hardware.
  244. - **Keeping the binary size small for the editor.** Not everyone has a fast Internet
  245. connection. Ensuring that everyone can download the Godot editor, extract it
  246. and run it in less than 5 minutes makes Godot more accessible to developers in
  247. all countries.
  248. - **Keeping the binary size small for export templates.** This directly impacts the
  249. size of projects exported with Godot. On mobile and web platforms, keeping
  250. file sizes low is important to ensure fast installation and loading on
  251. underpowered devices. Again, there are many countries where high-speed
  252. Internet is not readily available. To add to this, strict data usage caps are
  253. often in effect in those countries.
  254. For all the reasons above, we have to be selective of what we can accept as core
  255. functionality in Godot. This is why we are aiming to move some core
  256. functionality to officially supported add-ons in future versions of Godot.
  257. In terms of binary size, this also has the advantage of making you pay only for
  258. what you actually use in your project. (In the meantime, you can
  259. :ref:`compile custom export templates with unused features disabled <doc_optimizing_for_size>`
  260. to optimize the distribution size of your project.)
  261. How should assets be created to handle multiple resolutions and aspect ratios?
  262. ------------------------------------------------------------------------------
  263. This question pops up often and it's probably thanks to the misunderstanding
  264. created by Apple when they originally doubled the resolution of their devices.
  265. It made people think that having the same assets in different resolutions was a
  266. good idea, so many continued towards that path. That originally worked to a
  267. point and only for Apple devices, but then several Android and Apple devices
  268. with different resolutions and aspect ratios were created, with a very wide
  269. range of sizes and DPIs.
  270. The most common and proper way to achieve this is to, instead, use a single base
  271. resolution for the game and only handle different screen aspect ratios. This is
  272. mostly needed for 2D, as in 3D, it's just a matter of camera vertical or
  273. horizontal FOV.
  274. 1. Choose a single base resolution for your game. Even if there are
  275. devices that go up to 1440p and devices that go down to 400p, regular
  276. hardware scaling in your device will take care of this at little or
  277. no performance cost. The most common choices are either near 1080p
  278. (1920x1080) or 720p (1280x720). Keep in mind the higher the
  279. resolution, the larger your assets, the more memory they will take
  280. and the longer the time it will take for loading.
  281. 2. Use the stretch options in Godot; canvas items stretching while keeping
  282. aspect ratios works best. Check the :ref:`doc_multiple_resolutions` tutorial
  283. on how to achieve this.
  284. 3. Determine a minimum resolution and then decide if you want your game
  285. to stretch vertically or horizontally for different aspect ratios, or
  286. if there is one aspect ratio and you want black bars to appear
  287. instead. This is also explained in :ref:`doc_multiple_resolutions`.
  288. 4. For user interfaces, use the :ref:`anchoring <doc_size_and_anchors>`
  289. to determine where controls should stay and move. If UIs are more
  290. complex, consider learning about Containers.
  291. And that's it! Your game should work in multiple resolutions.
  292. When is the next release of Godot out?
  293. --------------------------------------
  294. When it's ready! See :ref:`doc_release_policy_when_is_next_release_out` for more
  295. information.
  296. Which Godot version should I use for a new project?
  297. ---------------------------------------------------
  298. We recommend using Godot 4.x for new projects, but depending on the feature set
  299. you need, it may be better to use 3.x instead. See
  300. :ref:`doc_release_policy_which_version_should_i_use` for more information.
  301. Should I upgrade my project to use new Godot versions?
  302. ------------------------------------------------------
  303. Some new versions are safer to upgrade to than others. In general, whether you
  304. should upgrade depends on your project's circumstances. See
  305. :ref:`doc_release_policy_should_i_upgrade_my_project` for more information.
  306. I would like to contribute! How can I get started?
  307. --------------------------------------------------
  308. Awesome! As an open source project, Godot thrives off of the innovation and
  309. the ambition of developers like you.
  310. The best way to start contributing to Godot is by using it and reporting
  311. any `issues <https://github.com/godotengine/godot/issues>`_ that you might experience.
  312. A good bug report with clear reproduction steps helps your fellow contributors
  313. fix bugs quickly and efficiently. You can also report issues you find in the
  314. `online documentation <https://github.com/godotengine/godot-docs/issues>`_.
  315. If you feel ready to submit your first PR, pick any issue that resonates with you from
  316. one of the links above and try your hand at fixing it. You will need to learn how to
  317. compile the engine from sources, or how to build the documentation. You also need to
  318. get familiar with Git, a version control system that Godot developers use.
  319. We explain how to work with the engine source, how to edit the documentation, and
  320. what other ways to contribute are there in our :ref:`documentation for contributors <doc_ways_to_contribute>`.
  321. I have a great idea for Godot. How can I share it?
  322. --------------------------------------------------
  323. We are always looking for suggestions about how to improve the engine. User feedback
  324. is the main driving force behind our decision-making process, and limitations that
  325. you might face while working on your project are a great data point for us when considering
  326. engine enhancements.
  327. If you experience a usability problem or are missing a feature in the current version of
  328. Godot, start by discussing it with our `community <https://godotengine.org/community/>`_.
  329. There may be other, perhaps better, ways to achieve the desired result that community members
  330. could suggest. And you can learn if other users experience the same issue, and figure out
  331. a good solution together.
  332. If you come up with a well-defined idea for the engine, feel free to open a
  333. `proposal issue <https://github.com/godotengine/godot-proposals/issues>`_.
  334. Try to be specific and concrete while describing your problem and your proposed
  335. solution — only actionable proposals can be considered. It is not required, but
  336. if you want to implement it yourself, that's always appreciated!
  337. If you only have a general idea without specific details, you can open a
  338. `proposal discussion <https://github.com/godotengine/godot-proposals/discussions>`_.
  339. These can be anything you want, and allow for a free-form discussion in search of
  340. a solution. Once you find one, a proposal issue can be opened.
  341. Please, read the `readme <https://github.com/godotengine/godot-proposals/blob/master/README.md>`_
  342. document before creating a proposal to learn more about the process.
  343. .. _doc_faq_non_game_applications:
  344. Is it possible to use Godot to create non-game applications?
  345. ------------------------------------------------------------
  346. Yes! Godot features an extensive built-in UI system, and its small distribution
  347. size can make it a suitable alternative to frameworks like Electron or Qt.
  348. When creating a non-game application, make sure to enable
  349. :ref:`low-processor mode <class_ProjectSettings_property_application/run/low_processor_mode>`
  350. in the Project Settings to decrease CPU and GPU usage.
  351. Check out `Material Maker <https://github.com/RodZill4/material-maker>`__ and
  352. `Pixelorama <https://github.com/Orama-Interactive/Pixelorama>`__ for examples of
  353. open source applications made with Godot.
  354. .. _doc_faq_use_godot_as_library:
  355. Is it possible to use Godot as a library?
  356. -----------------------------------------
  357. Godot is meant to be used with its editor. We recommend you give it a try, as it
  358. will most likely save you time in the long term. There are no plans to make
  359. Godot usable as a library, as it would make the rest of the engine more
  360. convoluted and difficult to use for casual users.
  361. If you want to use a rendering library, look into using an established rendering
  362. engine instead. Keep in mind rendering engines usually have smaller communities
  363. compared to Godot. This will make it more difficult to find answers to your
  364. questions.
  365. What user interface toolkit does Godot use?
  366. -------------------------------------------
  367. Godot does not use a standard :abbr:`GUI (Graphical User Interface)` toolkit
  368. like GTK, Qt or wxWidgets. Instead, Godot uses its own user interface toolkit,
  369. rendered using OpenGL ES or Vulkan. This toolkit is exposed in the form of
  370. Control nodes, which are used to render the editor (which is written in C++).
  371. These Control nodes can also be used in projects from any scripting language
  372. supported by Godot.
  373. This custom toolkit makes it possible to benefit from hardware acceleration and
  374. have a consistent appearance across all platforms. On top of that, it doesn't
  375. have to deal with the LGPL licensing caveats that come with GTK or Qt. Lastly,
  376. this means Godot is "eating its own dog food" since the editor itself is one of
  377. the most complex users of Godot's UI system.
  378. This custom UI toolkit :ref:`can't be used as a library <doc_faq_use_godot_as_library>`,
  379. but you can still
  380. :ref:`use Godot to create non-game applications by using the editor <doc_faq_non_game_applications>`.
  381. .. _doc_faq_why_scons:
  382. Why does Godot use the SCons build system?
  383. ------------------------------------------
  384. Godot uses the `SCons <https://www.scons.org/>`__ build system. There are no
  385. plans to switch to a different build system in the near future. There are many
  386. reasons why we have chosen SCons over other alternatives. For example:
  387. - Godot can be compiled for a dozen different platforms: all PC
  388. platforms, all mobile platforms, many consoles, and WebAssembly.
  389. - Developers often need to compile for several of the platforms **at
  390. the same time**, or even different targets of the same platform. They
  391. can't afford reconfiguring and rebuilding the project each time.
  392. SCons can do this with no sweat, without breaking the builds.
  393. - SCons will *never* break a build no matter how many changes,
  394. configurations, additions, removals etc.
  395. - Godot's build process is not simple. Several files are generated by
  396. code (binders), others are parsed (shaders), and others need to offer
  397. customization (:ref:`modules <doc_custom_modules_in_cpp>`). This requires
  398. complex logic which is easier to write in an actual programming language (like Python)
  399. rather than using a mostly macro-based language only meant for building.
  400. - Godot's build process makes heavy use of cross-compiling tools. Each
  401. platform has a specific detection process, and all these must be
  402. handled as specific cases with special code written for each.
  403. Please try to keep an open mind and get at least a little familiar with SCons if
  404. you are planning to build Godot yourself.
  405. .. _doc_faq_why_not_stl:
  406. Why does Godot not use STL (Standard Template Library)?
  407. -------------------------------------------------------
  408. Like many other libraries (Qt as an example), Godot does not make use of STL
  409. (with a few exceptions such as threading primitives). We believe STL is a great
  410. general-purpose library, but we had special requirements for Godot.
  411. * STL templates create very large symbols, which results in huge debug binaries. We use few
  412. templates with very short names instead.
  413. * Most of our containers cater to special needs, like Vector, which uses copy on write and we
  414. use to pass data around, or the RID system, which requires O(1) access time for performance.
  415. Likewise, our hash map implementations are designed to integrate seamlessly with internal
  416. engine types.
  417. * Our containers have memory tracking built-in, which helps better track memory usage.
  418. * For large arrays, we use pooled memory, which can be mapped to either a preallocated buffer
  419. or virtual memory.
  420. * We use our custom String type, as the one provided by STL is too basic and lacks proper
  421. internationalization support.
  422. Why does Godot not use exceptions?
  423. ----------------------------------
  424. We believe games should not crash, no matter what. If an unexpected
  425. situation happens, Godot will print an error (which can be traced even to
  426. script), but then it will try to recover as gracefully as possible and keep
  427. going.
  428. Additionally, exceptions significantly increase the binary size for the
  429. executable and result in increased compile times.
  430. Does Godot use an ECS (Entity Component System)?
  431. ------------------------------------------------
  432. Godot does **not** use an ECS and relies on inheritance instead. While there
  433. is no universally better approach, we found that using an inheritance-based approach
  434. resulted in better usability while still being fast enough for most use cases.
  435. That said, nothing prevents you from making use of composition in your project
  436. by creating child Nodes with individual scripts. These nodes can then be added and
  437. removed at run-time to dynamically add and remove behaviors.
  438. More information about Godot's design choices can be found in
  439. `this article <https://godotengine.org/article/why-isnt-godot-ecs-based-game-engine>`__.
  440. Why does Godot not force users to implement DOD (Data-Oriented Design)?
  441. -----------------------------------------------------------------------
  442. While Godot internally attempts to use cache coherency as much as possible,
  443. we believe users don't need to be forced to use DOD practices.
  444. DOD is mostly a cache coherency optimization that can only provide
  445. significant performance improvements when dealing with dozens of
  446. thousands of objects which are processed every frame with little
  447. modification. That is, if you are moving a few hundred sprites or enemies
  448. per frame, DOD won't result in a meaningful improvement in performance. In
  449. such a case, you should consider a different approach to optimization.
  450. The vast majority of games do not need this and Godot provides handy helpers
  451. to do the job for most cases when you do.
  452. If a game needs to process such a large amount of objects, our recommendation
  453. is to use C++ and GDExtensions for performance-heavy tasks and GDScript (or C#)
  454. for the rest of the game.
  455. How can I support Godot development or contribute?
  456. --------------------------------------------------
  457. See :ref:`doc_ways_to_contribute`.
  458. Who is working on Godot? How can I contact you?
  459. -----------------------------------------------
  460. See the corresponding page on the `Godot website <https://godotengine.org/contact>`_.