pandemonium_engine_docs/01_about/02_faq.md

532 lines
26 KiB
Markdown
Raw Permalink Normal View History

2024-04-20 16:21:44 +02:00
# Frequently asked questions
2024-04-20 16:21:44 +02:00
## What can I do with Pandemonium? How much does it cost? What are the license terms?
2024-04-20 20:19:10 +02:00
Pandemonium is [Free and Open-Source Software]( https://en.wikipedia.org/wiki/Free_and_open-source_software) available under the
[OSI-approved](https://opensource.org/licenses/MIT) MIT license. This means it is free as in "free speech" as well as in "free beer."
In short:
2024-03-16 20:56:52 +01:00
* You are free to download and use Pandemonium for any purpose: personal, non-profit, commercial, or otherwise.
* You are free to modify, distribute, redistribute, and remix Pandemonium to your heart's content, for any reason, both non-commercially and commercially.
All the contents of this accompanying documentation are published under
2024-04-20 20:19:10 +02:00
the permissive Creative Commons Attribution 3.0 ([CC-BY 3.0]( https://creativecommons.org/licenses/by/3.0/ )) license, with attribution
to "Péter Magyar and the Pandemonium community, and Juan Linietsky, Ariel Manzur and the Godot community".
Logos and icons are generally under the same Creative Commons license. Note
2024-03-16 20:56:52 +01:00
that some third-party libraries included with Pandemonium's source code may have
different licenses.
2024-04-20 20:19:10 +02:00
For full details, look at the [COPYRIGHT.txt](https://github.com/Relintai/pandemonium_engine/blob/master/COPYRIGHT.txt) as well
as the [LICENSE.txt](https://github.com/Relintai/pandemonium_engine/blob/master/LICENSE.txt) and [LOGO_LICENSE.txt](https://github.com/Relintai/pandemonium_engine/blob/master/LOGO_LICENSE.md) files in the Pandemonium repository.
2024-04-20 20:19:10 +02:00
Also, see [the license page on the Pandemonium website](https://pandemoniumengine.org/license).
2024-04-20 16:21:44 +02:00
## Which platforms are supported by Pandemonium?
**For the editor:**
* Windows
* macOS
* X11 (Linux, \*BSD)
2024-04-20 20:19:10 +02:00
* [Web](doc_using_the_web_editor)
* Android (experimental)
**For exporting your games:**
* Windows
* macOS
* X11 (Linux, \*BSD) (x64, x86, arm32, arm64)
* Android
* iOS
* Web
* Single Board Computers (FRT, and FRT SDL backends)
* Eventually UWP. (Currently needs working build containers, and some reworks.)
Both 32- and 64-bit binaries are supported where it makes sense, with 64
being the default.
Just like godot 3.x the codebase should compile for consoles. If you have access
to godot platform implementations for them, they should be simple to make work
with pandemonium aswell.
2024-04-20 20:19:10 +02:00
For more on this, see the sections on [exporting](toc-learn-workflow-export)
and [compiling Pandemonium yourself](toc-devel-compiling).
2024-04-20 16:21:44 +02:00
## Which programming languages are supported in Pandemonium?
2024-04-20 20:19:10 +02:00
The officially supported languages for Pandemonium are GDScript, and C++.
See the subcategories for each language in the [scripting](toc-learn-scripting) section.
2024-03-16 20:56:52 +01:00
If you are just starting out with either Pandemonium or game development in general,
GDScript is the recommended language to learn and use since it is native to Pandemonium.
While scripting languages tend to be less performant than lower-level languages in
the long run, for prototyping, developing Minimum Viable Products (MVPs), and
focusing on Time-To-Market (TTM), GDScript will provide a fast, friendly, and capable
way of developing your games.
### GDNative
GDNative is a C interface that lets you create and dynamically load dll-s.
Code in these dlls can use engine types, and can call engine methods, and
they can even create custom classes.
#### Python
Godot's [GDNative Python](https://github.com/Relintai/gdnative_python) ported to work with pandemonium.
It's setup in a self contained way. Can come in handy for tools,
as python has access to lots of great libraries, and you can
bundle them with your application using this module.
Only has binaries for desktop platforms.
I only recommend it for desktop tools where you want access to some of the python libraries,
but you also need a self contained application. It's a lot simpler than connecting and managing
multiple apps through sockets, but it's still relatively complex to set up.
#### C++
Godot's [GDNative C++](https://github.com/Relintai/gdnative_cpp) ported to work with pandemonium.
Currently under rework to make it's code (hopefully) identical to engine side c++. If successful,
engine side module code could be developed with faster recompile times, and even dynamic reloading
in some cases.
### C#
[C#](https://github.com/Relintai/mono) is available as an engine module,
which means you need to add it to the engine and recompile it to have it.
It comes with lots of complexities.
I only recommend it for tools, and when you need something from the c# ecosystem
integrated into your application.
2023-01-12 20:49:14 +01:00
Most of the time you are probably better off just writing GDScript, or engine modules in c++ though.
2024-04-20 16:21:44 +02:00
## What is GDScript and why should I use it?
2024-03-16 20:56:52 +01:00
GDScript is Pandemonium's integrated scripting language. It was built from the ground
up to maximize Pandemonium's potential in the least amount of code, affording both novice
and expert developers alike to capitalize on Pandemonium's strengths as fast as possible.
If you've ever written anything in a language like Python before then you'll feel
right at home. For examples, history, and a complete overview of the power GDScript
2024-04-20 20:19:10 +02:00
offers you, check out the [GDScript scripting guide](doc_gdscript).
There are several reasons to use GDScript--especially when you are prototyping, in
alpha/beta stages of your project, or are not creating the next AAA title--but the
most salient reason is the overall **reduction of complexity**.
The original intent of creating a tightly integrated, custom scripting language for
2024-03-16 20:56:52 +01:00
Pandemonium was two-fold: first, it reduces the amount of time necessary to get up and running
with Pandemonium, giving developers a rapid way of exposing themselves to the engine with a
focus on productivity; second, it reduces the overall burden of maintenance, attenuates
the dimensionality of issues, and allows the developers of the engine to focus on squashing
bugs and improving features related to the engine core--rather than spending a lot of time
trying to get a small set of incremental features working across a large set of languages.
2024-03-16 20:56:52 +01:00
Since Pandemonium is an open-source project, it was imperative from the start to prioritize a
more integrated and seamless experience over attracting additional users by supporting
more familiar programming languages--especially when supporting those more familiar
languages would result in a worse experience. We understand if you would rather use
2024-03-16 20:56:52 +01:00
another language in Pandemonium (see the list of supported options above). That being said, if
you haven't given GDScript a try, try it for **three days**. Just like Pandemonium,
once you see how powerful it is and rapid your development becomes, we think GDScript
will grow on you.
More information about getting comfortable with GDScript or dynamically typed
2023-01-12 19:29:11 +01:00
languages can be found in the `doc_gdscript_more_efficiently` tutorial.
2024-04-20 16:21:44 +02:00
## What were the motivations behind creating GDScript?
2024-04-20 20:19:10 +02:00
In the early days, the engine used the [Lua](https://www.lua.org)
scripting language. Lua is fast, but creating bindings to an object
oriented system (by using fallbacks) was complex and slow and took an
enormous amount of code. After some experiments with
2024-04-20 20:19:10 +02:00
[Python](https://www.python.org), it also proved difficult to embed.
2024-04-20 20:19:10 +02:00
The main reasons for creating a custom scripting language for Godot were:
2024-04-20 20:19:10 +02:00
1. Poor threading support in most script VMs, and Godot uses threads
(Lua, Python, Squirrel, JavaScript, ActionScript, etc.).
2. Poor class-extending support in most script VMs, and adapting to
2024-04-20 20:19:10 +02:00
the way Godot works is highly inefficient (Lua, Python, JavaScript).
3. Many existing languages have horrible interfaces for binding to C++, resulting in large amount of
code, bugs, bottlenecks, and general inefficiency (Lua, Python,
Squirrel, JavaScript, etc.) We wanted to focus on a great engine, not a great amount of integrations.
4. No native vector types (vector3, matrix4, etc.), resulting in highly
reduced performance when using custom types (Lua, Python, Squirrel,
JavaScript, ActionScript, etc.).
5. Garbage collector results in stalls or unnecessarily large memory
usage (Lua, Python, JavaScript, ActionScript, etc.).
6. Difficulty to integrate with the code editor for providing code
completion, live editing, etc. (all of them). This is well-supported
by GDScript.
GDScript was designed to curtail the issues above, and more.
2024-04-20 16:21:44 +02:00
## What type of 3D model formats does Pandemonium support?
2024-04-20 20:19:10 +02:00
Currently Pandemonium supports glTF and OBJ.
2024-04-20 20:19:10 +02:00
FBX support was removed to reduce engine bloat, because glTF turned out to be easier to
use most of the time. Also FBX is proprietary format. The FBX2glTF tool can easily convert it.
2024-04-20 20:19:10 +02:00
However note that FBX support can be added back relatively easily from
[Godot](https://github.com/godotengine/godot/tree/3.x/modules/fbx) if needed.
2024-04-20 16:21:44 +02:00
## Will [insert closed SDK such as FMOD, GameWorks, etc.] be supported in Pandemonium?
2024-03-16 20:56:52 +01:00
The aim of Pandemonium is to create a free and open-source MIT-licensed engine that
is modular and extendable. There are no plans for the core engine development
community to support any third-party, closed-source/proprietary SDKs, as integrating
2024-03-16 20:56:52 +01:00
with these would go against Pandemonium's ethos.
2024-03-16 20:56:52 +01:00
That said, because Pandemonium is open-source and modular, nothing prevents you or
anyone else interested in adding those libraries as a module and shipping your
game with them--as either open- or closed-source.
To see how support for your SDK of choice could still be provided, look at the
Plugins question below.
2024-03-16 20:56:52 +01:00
If you know of a third-party SDK that is not supported by Pandemonium but that offers
free and open-source integration, consider starting the integration work yourself.
2024-03-16 20:56:52 +01:00
Pandemonium is not owned by one person; it belongs to the community, and it grows along
with ambitious community contributors like you.
2024-04-20 16:21:44 +02:00
## How do I install the Pandemonium editor on my system (for desktop integration)?
2024-03-16 20:56:52 +01:00
Since you don't need to actually install Pandemonium on your system to run it,
this means desktop integration is not performed automatically.
2024-04-20 20:19:10 +02:00
You can manually perform the steps that an installer would do for you:
2024-04-20 16:21:44 +02:00
### Windows
2024-03-16 20:56:52 +01:00
- Move the Pandemonium executable to a stable location (i.e. outside of your Downloads folder),
so you don't accidentally move it and break the shortcut in the future.
2024-03-16 20:56:52 +01:00
- Right-click the Pandemonium executable and choose **Create Shortcut**.
2023-01-12 19:43:03 +01:00
- Move the created shortcut to `%LOCALAPPDATA%\Microsoft\Windows\Start Menu\Programs`.
This is the user-wide location for shortcuts that will appear in the Start menu.
2024-03-16 20:56:52 +01:00
You can also pin Pandemonium in the task bar by right-clicking the executable and choosing
**Pin to Task Bar**.
2024-04-20 16:21:44 +02:00
### macOS
2024-03-16 20:56:52 +01:00
Drag the extracted Pandemonium application to `/Applications/Pandemonium.app`, then drag it
to the Dock if desired. Spotlight will be able to find Pandemonium as long as it's in
2023-01-12 19:43:03 +01:00
`/Applications` or `~/Applications`.
2024-04-20 16:21:44 +02:00
### Linux
2024-03-16 20:56:52 +01:00
- Move the Pandemonium binary to a stable location (i.e. outside of your Downloads folder),
so you don't accidentally move it and break the shortcut in the future.
2024-03-16 20:56:52 +01:00
- Rename and move the Pandemonium binary to a location present in your `PATH` environment variable.
This is typically `/usr/local/bin/pandemonium` or `/usr/bin/pandemonium`.
Doing this requires administrator privileges,
but this also allows you to
2024-03-16 20:56:52 +01:00
`run the Pandemonium editor from a terminal ( doc_command_line_tutorial )` by entering `pandemonium`.
2024-03-16 20:56:52 +01:00
- If you cannot move the Pandemonium editor binary to a protected location, you can
2023-01-12 19:43:03 +01:00
keep the binary somewhere in your home directory, and modify the `Path=`
line in the `.desktop` file linked below to contain the full *absolute* path
2024-03-16 20:56:52 +01:00
to the Pandemonium binary.
2024-04-20 20:19:10 +02:00
- Save [this .desktop file](https://raw.githubusercontent.com/Relintai/pandemonium_engine/master/misc/dist/linux/org.pandemonium.Pandemonium.desktop)
2023-01-12 19:43:03 +01:00
to `$HOME/.local/share/applications/`. If you have administrator privileges,
you can also save the `.desktop` file to `/usr/local/share/applications`
to make the shortcut available for all users.
2024-04-20 16:21:44 +02:00
## Is the Pandemonium editor a portable application?
2024-03-16 20:56:52 +01:00
In its default configuration, Pandemonium is *semi-portable*. Its executable can run
from any location (including non-writable locations) and never requires
administrator privileges.
However, configuration files will be written to the user-wide configuration or
data directory. This is usually a good approach, but this means configuration files
2024-03-16 20:56:52 +01:00
will not carry across machines if you copy the folder containing the Pandemonium executable.
2023-01-12 19:29:11 +01:00
See `doc_data_paths` for more information.
If *true* portable operation is desired (e.g. for use on an USB stick),
2023-01-12 19:29:11 +01:00
follow the steps in `doc_data_paths_self_contained_mode`.
2024-04-20 16:21:44 +02:00
## Why does Pandemonium use Vulkan or OpenGL instead of Direct3D?
2024-03-16 20:56:52 +01:00
Pandemonium aims for cross-platform compatibility and open standards first and
foremost. OpenGL and Vulkan are the technologies that are both open and
available (nearly) on all platforms. Thanks to this design decision, a project
2024-03-16 20:56:52 +01:00
developed with Pandemonium on Windows will run out of the box on Linux, macOS, and
more.
2024-03-16 20:56:52 +01:00
Since Pandemonium only has a few people working on its renderer, we would prefer
having fewer rendering backends to maintain. On top of that, using a single API
on all platforms allows for greater consistency with fewer platform-specific
issues.
2024-03-16 20:56:52 +01:00
In the long term, we may develop a Direct3D 12 renderer for Pandemonium (mainly for
the Xbox's purposes), but Vulkan and OpenGL will remain the default rendering
backends on all platforms, including Windows.
2024-04-20 16:21:44 +02:00
## Why does Pandemonium aim to keep its core feature set small?
2024-03-16 20:56:52 +01:00
Pandemonium intentionally does not include features that can be implemented by add-ons
unless they are used very often. One example of this would be advanced
artificial intelligence functionality.
There are several reasons for this:
- **Code maintenance and surface for bugs.** Every time we accept new code in
2024-03-16 20:56:52 +01:00
the Pandemonium repository, existing contributors often take the reponsibility of
maintaining it. Some contributors don't always stick around after getting
their code merged, which can make it difficult for us to maintain the code in
question. This can lead to poorly maintained features with bugs that are never
fixed. On top of that, the "API surface" that needs to be tested and checked
for regressions keeps increasing over time.
- **Ease of contribution.** By keeping the codebase small and tidy, it can remain
fast and easy to compile from source. This makes it easier for new
2024-03-16 20:56:52 +01:00
contributors to get started with Pandemonium, without requiring them to purchase
high-end hardware.
- **Keeping the binary size small for the editor.** Not everyone has a fast Internet
2024-03-16 20:56:52 +01:00
connection. Ensuring that everyone can download the Pandemonium editor, extract it
and run it in less than 5 minutes makes Pandemonium more accessible to developers in
all countries.
- **Keeping the binary size small for export templates.** This directly impacts the
2024-03-16 20:56:52 +01:00
size of projects exported with Pandemonium. On mobile and web platforms, keeping
file sizes low is primordial to ensure fast installation and loading on
underpowered devices. Again, there are many countries where high-speed
Internet is not readily available. To add to this, strict data usage caps are
often in effect in those countries.
For all the reasons above, we have to be selective of what we can accept as core
2024-03-16 20:56:52 +01:00
functionality in Pandemonium. This is why we are aiming to move some core
functionality to officially supported add-ons in future versions of Pandemonium. In
terms of binary size, this also has the advantage of making you pay only for what
you actually use in your project. (In the meantime, you can
2023-01-12 20:47:54 +01:00
`compile custom export templates with unused features disabled ( doc_optimizing_for_size )`
to optimize the distribution size of your project.)
2024-04-20 16:21:44 +02:00
## How should assets be created to handle multiple resolutions and aspect ratios?
This question pops up often and it's probably thanks to the misunderstanding
created by Apple when they originally doubled the resolution of their devices.
It made people think that having the same assets in different resolutions was a
good idea, so many continued towards that path. That originally worked to a
point and only for Apple devices, but then several Android and Apple devices
with different resolutions and aspect ratios were created, with a very wide
range of sizes and DPIs.
The most common and proper way to achieve this is to, instead, use a single
base resolution for the game and only handle different screen aspect ratios.
This is mostly needed for 2D, as in 3D it's just a matter of Camera XFov or YFov.
1. Choose a single base resolution for your game. Even if there are
devices that go up to 2K and devices that go down to 400p, regular
hardware scaling in your device will take care of this at little or
no performance cost. Most common choices are either near 1080p
(1920x1080) or 720p (1280x720). Keep in mind the higher the
resolution, the larger your assets, the more memory they will take
and the longer the time it will take for loading.
2024-03-16 20:56:52 +01:00
2. Use the stretch options in Pandemonium; 2D stretching while keeping aspect
2023-01-12 19:29:11 +01:00
ratios works best. Check the `doc_multiple_resolutions` tutorial
on how to achieve this.
3. Determine a minimum resolution and then decide if you want your game
to stretch vertically or horizontally for different aspect ratios, or
if there is one aspect ratio and you want black bars to appear
2023-01-12 19:29:11 +01:00
instead. This is also explained in `doc_multiple_resolutions`.
2023-01-12 20:47:54 +01:00
4. For user interfaces, use the `anchoring ( doc_size_and_anchors )`
to determine where controls should stay and move. If UIs are more
complex, consider learning about Containers.
And that's it! Your game should work in multiple resolutions.
If there is a desire to make your game also work on ancient
devices with tiny screens (fewer than 300 pixels in width), you can use
the export option to shrink images, and set that build to be used for
certain screen sizes in the App Store or Google Play.
2024-04-20 16:21:44 +02:00
## How can I extend Pandemonium?
2024-03-16 20:56:52 +01:00
For extending Pandemonium, like creating Pandemonium Editor plugins or adding support
2024-04-20 20:19:10 +02:00
for additional languages, take a look at [EditorPlugins](doc_making_plugins)
and tool scripts.
Also, see the official blog posts on these topics:
2024-04-20 20:19:10 +02:00
* [A look at the GDNative architecture]( https://pandemoniumengine.org/article/look-gdnative-architecture )`
* [GDNative is here!]( https://pandemoniumengine.org/article/dlscript-here )`
2024-03-16 20:56:52 +01:00
You can also take a look at the GDScript implementation, the Pandemonium modules,
2024-04-20 20:19:10 +02:00
as well as the [unofficial Python support]( https://github.com/touilleMan/pandemonium-python ) for Pandemonium.
This would be a good starting point to see how another third-party library
2024-03-16 20:56:52 +01:00
integrates with Pandemonium.
2024-04-20 16:21:44 +02:00
## When is the next release of Pandemonium out?
2023-01-12 19:29:11 +01:00
When it's ready! See `doc_release_policy_when_is_next_release_out` for more
information.
2024-04-20 16:21:44 +02:00
## I would like to contribute! How can I get started?
2024-03-16 20:56:52 +01:00
Awesome! As an open-source project, Pandemonium thrives off of the innovation and
ambition of developers like you.
The first place to get started is in the `issues ( https://github.com/Relintai/pandemonium_engine/issues )`.
Find an issue that resonates with you, then proceed to the `How to Contribute ( https://github.com/Relintai/pandemonium_engine/blob/master/CONTRIBUTING.md#contributing-pull-requests )`
guide to learn how to fork, modify, and submit a Pull Request (PR) with your changes.
2024-04-20 16:21:44 +02:00
## I have a great idea for Pandemonium. How can I share it?
2024-03-16 20:56:52 +01:00
It might be tempting to want to bring ideas to Pandemonium, like ones that
result in massive core changes, some sort of mimicry of what another
game engine does, or alternative workflows that you'd like built into
the editor. These are great, and we are thankful to have such motivated
2024-03-16 20:56:52 +01:00
people want to contribute, but Pandemonium's focus is and always will be the
core functionality as outlined in the `Roadmap ( https://github.com/Relintai/pandemonium_engine-roadmap/blob/master/ROADMAP.md )`,
`squashing bugs and addressing issues ( https://github.com/Relintai/pandemonium_engine/issues )`,
2024-03-16 20:56:52 +01:00
and conversations between Pandemonium community members.
2024-03-16 20:56:52 +01:00
Most developers in the Pandemonium community will be more interested to learn
about things like:
- Your experience using the software and the problems you have (we
care about this much more than ideas on how to improve it).
- The features you would like to see implemented because you need them
for your project.
- The concepts that were difficult to understand while learning the software.
- The parts of your workflow you would like to see optimized.
- Parts where you missed clear tutorials or where the documentation wasn't clear.
2024-03-16 20:56:52 +01:00
Please don't feel like your ideas for Pandemonium are unwelcome. Instead,
try to reformulate them as a problem first, so developers and the community
have a functional foundation to ground your ideas on.
A good way to approach sharing your ideas and problems with the community
is as a set of user stories. Explain what you are trying to do, what behavior
you expect to happen, and then what behavior actually happened. Framing problems
and ideas this way will help the whole community stay focused on improving
developer experiences as a whole.
Bonus points for bringing screenshots, concrete numbers, test cases, or example
projects (if applicable).
2023-01-12 20:49:14 +01:00
2024-04-20 16:21:44 +02:00
## Is it possible to use Pandemonium to create non-game applications?
2024-03-16 20:56:52 +01:00
Yes! Pandemonium features an extensive built-in UI system, and its small distribution
size can make it a suitable alternative to frameworks like Electron or Qt.
When creating a non-game application, make sure to enable
2023-01-12 19:30:47 +01:00
`low-processor mode`
in the Project Settings to decrease CPU and GPU usage.
2024-03-16 20:56:52 +01:00
That said, we wouldn't recommend using Pandemonium to create a *mobile* application
since low-processor mode isn't supported on mobile platforms yet.
2023-01-12 20:39:50 +01:00
Check out `Material Maker ( https://github.com/RodZill4/material-maker )` and
`Pixelorama ( https://github.com/Orama-Interactive/Pixelorama )` for examples of
2024-03-16 20:56:52 +01:00
open source applications made with Pandemonium.
2024-04-20 20:19:10 +02:00
https://github.com/Relintai/pandemonium_cms
2023-01-12 20:49:14 +01:00
2024-04-20 20:19:10 +02:00
https://github.com/Relintai/uml_generator
2024-04-20 16:21:44 +02:00
## Is it possible to use Pandemonium as a library?
2024-03-16 20:56:52 +01:00
Pandemonium is meant to be used with its editor. We recommend you give it a try, as it
will most likely save you time in the long term. There are no plans to make
2024-03-16 20:56:52 +01:00
Pandemonium usable as a library, as it would make the rest of the engine more
convoluted and difficult to use for casual users.
If you want to use a rendering library, look into using an established rendering
engine instead. Keep in mind rendering engines usually have smaller communities
2024-03-16 20:56:52 +01:00
compared to Pandemonium. This will make it more difficult to find answers to your
questions.
2024-04-20 16:21:44 +02:00
## What user interface toolkit does Pandemonium use?
2024-03-16 20:56:52 +01:00
Pandemonium does not use a standard :abbr:`GUI (Graphical User Interface)` toolkit
like GTK, Qt or wxWidgets. Instead, Pandemonium uses its own user interface toolkit,
rendered using OpenGL ES or Vulkan. This toolkit is exposed in the form of
Control nodes, which are used to render the editor (which is written in C++).
These Control nodes can also be used in projects from any scripting language
2024-03-16 20:56:52 +01:00
supported by Pandemonium.
This custom toolkit makes it possible to benefit from hardware acceleration and
have a consistent appearance across all platforms. On top of that, it doesn't
have to deal with the LGPL licensing caveats that come with GTK or Qt. Lastly,
2024-03-16 20:56:52 +01:00
this means Pandemonium is "eating its own dog food" since the editor itself is one of
the most complex users of Pandemonium's UI system.
2024-03-16 20:56:52 +01:00
This custom UI toolkit `can't be used as a library ( doc_faq_use_pandemonium_as_library )`,
but you can still
2024-03-16 20:56:52 +01:00
`use Pandemonium to create non-game applications by using the editor ( doc_faq_non_game_applications )`.
2023-01-12 20:49:14 +01:00
2024-04-20 16:21:44 +02:00
## Why does Pandemonium not use STL (Standard Template Library)?
2024-03-16 20:56:52 +01:00
Like many other libraries (Qt as an example), Pandemonium does not make use of
STL. We believe STL is a great general purpose library, but we had special
2024-03-16 20:56:52 +01:00
requirements for Pandemonium.
* STL templates create very large symbols, which results in huge debug binaries. We use few templates with very short names instead.
* Most of our containers cater to special needs, like Vector, which uses copy on write and we use to pass data around, or the RID system, which requires O(1) access time for performance. Likewise, our hash map implementations are designed to integrate seamlessly with internal engine types.
* Our containers have memory tracking built-in, which helps better track memory usage.
* For large arrays, we use pooled memory, which can be mapped to either a preallocated buffer or virtual memory.
* We use our custom String type, as the one provided by STL is too basic and lacks proper internationalization support.
2024-04-20 16:21:44 +02:00
## Why does Pandemonium not use exceptions?
We believe games should not crash, no matter what. If an unexpected
2024-03-16 20:56:52 +01:00
situation happens, Pandemonium will print an error (which can be traced even to
script), but then it will try to recover as gracefully as possible and keep
going.
Additionally, exceptions significantly increase binary size for the
executable.
2024-04-20 16:21:44 +02:00
## Why does Pandemonium not enforce RTTI?
2024-03-16 20:56:52 +01:00
Pandemonium provides its own type-casting system, which can optionally use RTTI
internally. Disabling RTTI in Pandemonium means considerably smaller binary sizes can
be achieved, at a little performance cost.
2024-04-20 16:21:44 +02:00
## Why does Pandemonium not force users to implement DoD (Data oriented Design)?
2024-03-16 20:56:52 +01:00
While Pandemonium internally for a lot of the heavy performance tasks attempts
to use cache coherency as well as possible, we believe most users don't
really need to be forced to use DoD practices.
DoD is mostly a cache coherency optimization that can only gain you
significant performance improvements when dealing with dozens of
thousands of objects (which are processed every frame with little
modification). As in, if you are moving a few hundred sprites or enemies
per frame, DoD won't help you, and you should consider a different approach
to optimization.
2024-03-16 20:56:52 +01:00
The vast majority of games do not need this and Pandemonium provides handy helpers
to do the job for most cases when you do.
If a game that really needs to process such large amount of objects is
needed, our recommendation is to use C++ and GDNative for the high
performance parts and GDScript (or C#) for the rest of the game.
2024-04-20 16:21:44 +02:00
## How can I support Pandemonium development or contribute?
2023-01-12 19:29:11 +01:00
See `doc_ways_to_contribute`.
2024-04-20 16:21:44 +02:00
## Who is working on Pandemonium? How can I contact you?
2024-04-20 20:19:10 +02:00
See the corresponding page on the [Pandemonium website]( https://pandemoniumengine.org/contact ).