Getting Started with ES Development.
-
@Hex Is there some kind of UML class diagram or any interesting documentation about design stuff anywhere ? I think that would help a lot.
-
@sx-111 They're described on the 1st page of the project
EmulationStation has a few dependencies. For building, you'll need CMake, SDL2, Boost (System, Filesystem, DateTime, Locale), FreeImage, FreeType, Eigen3, and cURL. You also should probably install the fonts-droid package which contains fallback fonts for Chinese/Japanese/Korean characters, but ES will still work fine without it (this package is only used at run-time).
-
So I followed the directions and set up a fork that I can access at https://github.com/korreckj328/EmulationStation
However, I do have a question. Does the official Retropie fork have the ability to pull the code I changed at this point? Or would something more need to be done?
I added some code so that it can compile on macOS fyi.
-
@Charononus said in Getting Started with ES Development.:
However, I do have a question. Does the official Retropie fork have the ability to pull the code I changed at this point? Or would something more need to be done?
That's not how collaborative development works - you need to create a Pull Request to the RetroPie's Emulationstation repository in order for the changes you've added to be incorporated upstream.
Btw, your fork doesn't seem to compile on macOS, I tested it with macOS 10.13, Apple LLVM version 10.0.0 (clang-1000.11.45.5).
-
@mitu
10.14.3 here and compiled with
cmake . -D CMAKE_CXX_COMPILER=g++-8(g++-8 from brew)
-
@Charononus I don't have
g++
installed and with theclang
version included in Xcode it doesn't work. -
I'll have to take a look at clang. In theory I'm not sure why it wouldn't compile with clang and will with g++. Nothing I did was all that major. Just called some AppleScript to get and set the system volume in place of ALSA on linux.
-
@Charononus Just FYI, you might want to test it out also with
clang
, since you might need it to generate an .app with Xcode. -
@mitu
Yeah that getting that app bundle was the next step as it just compiles as a unix executable at the moment.Actually wow, clang pops up a lot of errors from files I never touched. Very interesting.
-
Hey, quite a long time between my posts but I did get it working with Clang now. Still haven't packed the app into a bundle yet.
-
I am trying it now using the Windows Subsystem for Linux but keep running into problems with missing dependencies, even to get past the cmake part. At the moment, I'm trying to figure out how to install freetype. Isn't there some big giant "sudo apt-get install thing1 thing2 thing3 thing4" command someone could write to grab all the dependencies at once instead of needing people to hunt around to find each one?
(later edit) Never mind, I found it.
sudo apt-get install libsdl2-dev libfreeimage-dev libfreetype6-dev libcurl4-openssl-dev rapidjson-dev libasound2-dev libgl1-mesa-dev build-essential cmake fonts-droid-fallback libvlc-dev libvlccore-dev vlc-bin
-
Alright, now it builds but will it run?
I get this result:Creating config directory "/home/ben/.emulationstation" error: XDG_RUNTIME_DIR not set in the environment. Apr 25 14:21:21 lvl0: Error initializing SDL! No available video device Apr 25 14:21:21 lvl0: Renderer failed to initialize! Apr 25 14:21:21 lvl0: Window failed to initialize!
I'm not sure running graphical programs is even possible on Windows Subsystem for Linux. I assumed they would be but I guess that wasn't a safe assumption. I'll have to research this more to find out if that's even possible.
(later edit) Apparently, the thing I need is called an "X server" for Windows. I'm trying vcxsrv
-
Yes! I got it to run!
I got help from this page here. It explains how to set up VcXsrv and let you run your graphical Linux programs through it.
-
@BenMcLean Thats great, you might want to create a post detailing this
-
@Hex said in Getting Started with ES Development.:
@BenMcLean Thats great, you might want to create a post detailing this
This page explains the only stuff you need to do different to build on WSL Ubuntu instead of regular Ubuntu.
However, I have been thinking that the features I want to add would make more sense being in the RetroPie setup menu rather than being in EmulationStation so I've been reading through the source code for that. I have found out that this menu uses Joy2Key to translate the joystick movements into key presses but haven't yet managed to figure out what code is creating all the boxes and blue crap around the menu items or providing the interactivity.
-
@BenMcLean said in Getting Started with ES Development.:
but haven't yet managed to figure out what code is creating all the boxes and blue crap around the menu items or providing the interactivity.
It's called
dialog
- https://linuxgazette.net/101/sunil.html. -
@mitu said in Getting Started with ES Development.:
It's called dialog - https://linuxgazette.net/101/sunil.html.
Wow. In that case, the feature I want to add isn't even a RetroPie-specific feature at all.
I want to add an on-screen-keyboard option to dialog and then have the RetroPie setup script use it when text entry is required. That would enable entering the wifi password with a game controller.
So I believe I'd need to start here, (or maybe here?) code up my own new version and then get RetroPie onto using that, with a new
-osk
command line option.(later edit) I have started a fork of dialog and even got it to make using this guide
-
I hate to disappoint anyone who cared about that feature I was thinking of coding, but a major development has happened since I wrote that: the Raspberry PI 400 came out.
Now anyone who actually cares about typing in the wifi password can just buy a Raspberry PI 400 and never have to worry about this problem ever again. Consequently, I no longer see it as worth my time to work on developing this feature. Sorry, but you have to pick your battles and I have to let go of this if I want to get other development goals done. I'm still full steam ahead on my Wolfenstein 3-D VR remake though
-
-
Create a static class model from ES sources: See here
Contributions to the project are always appreciated, so if you would like to support us with a donation you can do so here.
Hosting provided by Mythic-Beasts. See the Hosting Information page for more information.