Awesome! It's finally been made! Thank you Mr. Penaz!!! I'll get to reading it ASAP!
However, Ruby-cat is not impressed:
I’m glad to hear your response Mr. Penaz.
Well first the bad news.
I haven't personally used any open source Javascript frameworks aimed specifically for game development but there are sure many of them which you can take a look at here: https://gamefromscratch.com/javascript-game-engines/
However the best JavaScript game engine that I know of is the MV engine by RPG Maker.
Unfortunately, regarding the JavaScript documentation, like any run-of the-mill JavaScript API, it is badly documented for RPG Maker. There is an incomplete documentation of the JavaScript code used in RPG Maker MV engine at this link:
Despite being released since 2015, there isn’t any official documentation of the JavaScript code released by Degica, the proprietary company of the MV engine. (at least in my knowledge).
GameDevs tend to just wing it when using the MV Engine. It’s JavaScript afterall.
That’s why there are huge third-party repositories in existence detailing third-party plugins.
Here is the largest plugin library regarding the MV engine in Javascript:
http://yanfly.moe/category/yanfly-engine-plugins/
This library itself links to scores of other plugin libraries. Most of us have had our hands full with them yet the inherent lack of order that is inherent to the JavaScript community technically condemns most RPG Maker MV games to be of shoddy quality (as you may know the reputation that RPG Maker games have on platforms such as this very website or on Steam etc.)
This is why I am humbly requesting a JavaScript version of your awesome book;
to bring order to the chaos.
The most decent introduction to this JavaScript engine I could find is this:
https://www.gamedeveloper.com/programming/rpg-maker-mv-scripting-first-impressio...
Also, don't forget the awesomeness that is SRPG Studio: https://store.steampowered.com/app/857320/SRPG_Studio/
It's codebase is also entirely written in Javascript.
================================================================
On the brighter side,
Regarding open source Ruby game development, look no further than the Gosu Library: https://www.libgosu.org/cgi-bin/mwf/board_show.pl?bid=2
In addition, unlike the JavaScript MV engine, the more matured RPG MAKER VX Ace engine has full official AND third-party documentation of its Ruby code.
INTRO: https://www.gamedeveloper.com/programming/rpg-maker-vx-ace-ruby-scripting-crash-course
Here is the OFFICIAL documentation for the Ruby code used in VX Ace:
This is the basic manual that all budding Scripters begin with. We RPG Maker gamedevs use it as a reference.
There is no better official introduction to the Ruby Game Scripting System 3 (RGSS3 for short) that is used in the RPG Maker VXAce engine based off Ruby version 1.9.
RPG Maker XP might be the more famous engine, but it uses the older Ruby version 1.8 which isn’t my cup of tea. This is also well documented: http://www.rpg-maker.fr/dl/monos/aide/xp/index.html?page=source%2Frgss%2Findex.h..
Next, a deep dive into the code; the complete full fledged in-depth third-party documentation of RGSS3 :
It took an eternity to fully compile the RGSS3 documentation. It even has been listed on Ruby Gems:
https://rubygems.org/gems/rpg-maker-rgss3/versions/1.02.0
In fact, there is an entire wiki dedicated to the VX Ace engine, https://rmvxace.fandom.com/wiki/RPG_Maker_VX_Ace_Wiki
Plus there is a Japanese language wiki about RGSS3
(No fret, Ruby code is one of the most English dependant languages out there. You’ll be able to read the code even if the website is in Japanese!)
FINAL THOUGHTS
When it comes to OOP game development using interpreted languages, starting with the JavaScript MV engine might seem logical, but you’ll get bogged down like the rest of us in the chaos that is its code base.
The good news is that JavaScript MV engine’s chaotic codebase is mostly a translation of the older Ruby codebase found in RGSS3.
The RGSS3 codebase has been fully documented, and once known, one can easily transfer all of its concepts over to the JavaScript codebase in my opinion.
Hence it is easier and more effective to start with a Ruby background, instead of spending an eternity trying to bring some order to the JavaScript camp from the get go in my opinion. Besides, your book could be a huge boost to the Gosu community.
Heaven knows that they need all the help that they can get.
(P.S. the Gosu games aren't all that good IMHO).
In any case, these engines serve as a proving ground for newbies (like myself) before they move onto more in depth books as yours in order to make some truely professional games from scratch.
Migrating from either Ruby or Javascript into Python, let alone C++ is setting the bar a bit too high.
I do urge you to not overextend yourself in trying to fix the pseudocode version of your book. I don’t think many people like pseudocode anyway.
Instead focus on the only two standard programming languages that are used as the fundamental code base for official and non-proprietary 2D game development engines; Ruby and Javascript; as new versions of your book for those who want to strike it out on their own.
Let me know if you need more info.
In my humble opinion Mr. Penaz, you've already done a swell job.
I can personally recommend you take a much needed break.
Burnout is not something to be ignored.
There is an issue that has been pestering me.
Despite my personal recommendations of your book, most of the gamedevs who use these engines respond apathetically:
"C++ is too advanced, Python is unoptimized and is not meant for games and finally pseudo-code has a notorious reputation as not being a real language."
That's the general opinion of most of the 2D gamedevs who I have encountered nowadays who make use of just two game engines: Gamemaker and RPG Maker.
Though I'm not recommending you write a version using GML,
I do insist that you ought to consider writing another version of your
awesome book in the standard languages of Ruby and JavaScript.
Sure JavaScript is not that OOP oriented as Ruby is, (I'd prefer Ruby) but these couple of languages would make a much bigger impact than the current versions.
Just don't inflict self harm on yourself Mr. Penaz.
Cheers!
P.S. Not many use Ren'Py or Godot where I'm from.
* Opinion from India *