The primary issue here I think is that because of their low barrier to entry, people forget that scripting languages where designed specifically to implement the automation of well understood, but routinely occurring multi-step tasks; as opposed to building fairly large, non-trivial, carefully engineered and maintainable projects.
not really. It's just one of the big obvious downsides of scripting languages. if you step back for a second and say, give scripting languages to a bunch of profeccient long-time programmers, you get other issues. Many issues he brought up in this video, like debuggability, bug-prone interpretation, lack of strict type checking (this is literally a bug generator marketed as a feature). I understand the idea and benefit of accepting any type by default but its absolutely insane to not check for a function paramter type until runtime by default. Another is tool fragmentation, like compilers and build systems, limited feature support, weak interoperability between lower level languages, having to write bindings all the time, being dog slow. Scripting languages can just be a pain all around and ironically none of them having anything to do with being "interpreted". Java, C# and C++ all have interpreters, you don't see them having issues with performance or strict type checking. Arguably C# is a bit *too* strict with type checking
@@Mallchad No...the fundamental issues with scripting languages within the context of using them in use cases they aren't suited for is because they are interpreted and all that is associated with that. This is by simple definition.
@@thecollector6746 I don't understand what interpreters have to do with debuggers, strict typing, or anything else. x86 assembly instructions can be interpreted. What does that have to do with making good code? and how does that shape what the language can be good for?
@@Mallchad ..that's because you are rebutting an argument I never made. Scripting Languages were not designed for building non-trivial, scaled, performant applications. FULL STOP. This is a FACT. I didn't bother reading the rest past your open because why bother ?
Tldr use the right tool for your job. Don't use python to write a raytracing program and don't use c to write a web scraper you'll use once a week. Ffs this is common sense
It CAN mean that, but it doenst HAVE to mean that. You can compile to a dynamically linked library and reload it at runtime. This way you can write that C++ code in the editor and compile it, then bring it into the game as the game is running. If it fails to compile, for any reason, then you dont and the game keeps running without problem.
When working in Unreal Engine, I make such things a editable property (e.g. public UPROPERTY) so they can be edited in a editor. I don't see any reason why any game shouldn't be able to support such functionality.
The value of scripting language is not its performance, but in community making the game content. I can provide some games where modding gave more to the game then devs themselves
There's no reason you can't make mods without scripting languages. Counter Strike is probably the most well known mod ever created, but it did *not* use a scripting language.
I still think that Blow's point that modding it with the same language that the game is built in solves many many problems. But I think you also have a solid point that a _community_ forms and grows much much better when it's even a little bit easier or more accessible. If the goal is quality community mods, excitement about modding is extremely beneficial, no matter how bad the actual experience of modding is. Most people (unlike Blow) get excited about the surface level and not the little details that matter in the long run.
If your own team members can't use the tools very well, how good a game can you possibly make? The point JB was making was simply that as a tool scripting language is always a worse choice compared to real programming language (for coders) or a custom made tool (for other members of dev team) like Blueprints. If your team has good tools, you can always provide those for modding.
If only people would let Jon get past the first parts of his discussion so we would be able to have someone as experienced as him discuss the more interesting part underneath this which is where do you draw the line between how much dynamic you let the data for you game become between how much you keep in gameplay code. If you make your data dynamic enough (let it define complex behavior) you could easily end up with having almost a badly implemented scripting language. But you still want a data oriented design and have things be dynamic through data. That is a balance act and I would love to have Jon discuss how he approaches that problem.
This is a trash take, it's undefensible... he makes generalizations that are total BS, talking about scripting languages as a whole, where there's scripting languages with type checking, for example... you can definitely have a full blown debugger, for example Python has a full debugger... etc. It is just an awful take.
@@davidgildegomezperez4364Python is also 100x-180x slower than C++ with the exact same code (simply due to its interpreter), so that'll instantly be your game's bottleneck
@@davidgildegomezperez4364 What are you even saying? Do you agree that an instruction takes cycles for the CPU to do? Take *LEA C,[A+B]* (c = a+b), which is an instruction that takes at worst 1 cycle to complete (uops dot info). Comparing that to 180 instructions that average out to 100 cycles, with cache misses etc. - do you agree that it's only logical for it to take longer? You can go measure and get the same result like I did, but my statement should be obvious and logical even without measuring. In C# it just turns into 1 LEA instruction. But in Python the same LEA turned into: mov qword ptr [r11+38h],r14 add r14,2 jmp _PyEval_EvalFrameDefault+5872h mov rdi,qword ptr [r12-8] lea rax,[__ImageBase] mov rsi,qword ptr [r12-10h] sub r12,8 mov rdx,rdi mov rcx,rsi call qword ptr [rax+r13*8+3E7A70h] mov qword ptr [rsp+8],rbx push rdi sub rsp,30h xor r8d,r8d mov rdi,rdx mov rbx,rcx call binary_op1 mov qword ptr [rsp+10h],rbp mov qword ptr [rsp+18h],rsi mov qword ptr [rsp+20h],rdi push r14 sub rsp,20h mov rsi,rdx movsxd r9,r8d mov rdx,qword ptr [rcx+8] mov rbp,rcx mov rdi,qword ptr [rdx+60h] test rdi,rdi je binary_op1+2Fh mov rdi,qword ptr [rdi+r9] mov rcx,qword ptr [rsi+8] mov qword ptr [rsp+30h],rbx cmp rcx,rdx je binary_op1+55h xor ebx,ebx lea r14,[_Py_NotImplementedStruct] test rdi,rdi je binary_op1+0ADh test rbx,rbx je binary_op1+90h mov rdx,rsi mov rcx,rbp call rdi mov rax,qword ptr [rcx+8] test dword ptr [rax+0A8h],1000000h je long_add+24h mov rax,qword ptr [rdx+8] test dword ptr [rax+0A8h],1000000h jne _PyLong_Add sub rsp,28h mov r8,rdx mov rdx,qword ptr [rcx+10h] lea rax,[rdx+1] cmp rax,3 jae _PyLong_Add+3Eh mov r9,qword ptr [r8+10h] lea rax,[r9+1] cmp rax,3 jae _PyLong_Add+3Eh mov ecx,dword ptr [rcx+18h] mov eax,dword ptr [r8+18h] imul rcx,rdx imul rax,r9 --> add *rcx,rax* add rsp,28h jmp _PyLong_FromSTwoDigits push rdi sub rsp,20h lea rax,[rcx+5] mov rdi,rcx cmp rax,105h ja _PyLong_FromSTwoDigits+2Fh lea rax,[rcx+3FFFFFFFh] cmp rax,7FFFFFFFh jae _PyLong_FromSTwoDigits+48h add rsp,20h pop rdi jmp _PyLong_FromMedium mov qword ptr [rsp+10h],rbx push rsi sub rsp,20h movsxd rsi,ecx mov edx,20h mov rcx,qword ptr [_PyObject] call qword ptr [_PyObject+8h] push rbx sub rsp,20h mov rbx,rdx call pymalloc_alloc sub rsp,28h lea rax,[rdx-1] cmp rax,1FFh jbe pymalloc_alloc+17h mov qword ptr [rsp+30h],rbx mov qword ptr [rsp+38h],rsi mov qword ptr [rsp+40h],rdi lea edi,[rdx-1] shr edi,4 mov qword ptr [rsp+20h],r14 lea r14,[__ImageBase] lea eax,[rdi+rdi] lea rsi,[rax*8+4C7120h] mov rdx,qword ptr [rsi+r14] mov rcx,qword ptr [rdx+10h] cmp rdx,rcx je pymalloc_alloc+9Fh mov r9,qword ptr [rdx+8] inc dword ptr [rdx] mov rax,qword ptr [r9] mov qword ptr [rdx+8],rax test rax,rax jne pymalloc_alloc+1C1h mov r14,qword ptr [rsp+20h] mov rax,r9 mov rdi,qword ptr [rsp+40h] mov rsi,qword ptr [rsp+38h] mov rbx,qword ptr [rsp+30h] add rsp,28h ret test rax,rax jne _PyObject_Malloc+46h add rsp,20h pop rbx ret
mov rbx,rax test rax,rax jne _PyLong_FromMedium+4Ah mov qword ptr [rsp+30h],rdi mov eax,esi cdq mov rcx,rsi sar rcx,3Fh mov edi,eax and rcx,0FFFFFFFFFFFFFFFEh lea rax,[PyLong_Type] xor edi,edx mov qword ptr [rbx+8],rax inc rcx sub edi,edx mov qword ptr [rbx+10h],rcx test dword ptr [PyLong_Type+0A8h],200h je _PyLong_FromMedium+88h cmp dword ptr [_Py_tracemalloc_config+4h],0 je _PyLong_FromMedium+99h mov dword ptr [rbx+18h],edi mov rax,rbx mov rdi,qword ptr [rsp+30h] mov qword ptr [rbx],1 mov rbx,qword ptr [rsp+38h] add rsp,20h pop rsi ret mov rcx,rax cmp rax,r14 jne binary_op1+0D9h mov rbx,qword ptr [rsp+30h] mov rbp,qword ptr [rsp+38h] mov rsi,qword ptr [rsp+40h] mov rdi,qword ptr [rsp+48h] add rsp,20h pop r14 ret mov rcx,rax lea rax,[_Py_NotImplementedStruct] cmp rcx,rax je PyNumber_Add+35h mov rax,rcx mov rbx,qword ptr [rsp+40h] add rsp,30h pop rdi ret sub qword ptr [rsi],1 mov r15,rax jne _PyEval_EvalFrameDefault+58AFh sub qword ptr [rdi],1 jne _PyEval_EvalFrameDefault+58C6h mov qword ptr [r12-8],r15 test r15,r15 mov r15,qword ptr [rsp+30h] je _PyEval_EvalFrameDefault+161h add r14,2 jmp _PyEval_EvalFrameDefault+59FCh
@@davidgildegomezperez4364*C#/C++:* lea *Python:* mov add jmp _PyEval_EvalFrameDefault mov lea mov sub mov mov call mov push sub xor mov mov call mov mov mov push sub mov movsxd mov mov mov test je mov mov mov cmp je xor lea _Py_NotImplementedStruct test je test je mov mov call mov test je mov test jne _PyLong_Add sub mov mov lea cmp jae _PyLong_Add mov lea cmp jae _PyLong_Add mov mov imul imul → add *rcx,rax* add jmp _PyLong_FromSTwoDigits push sub lea mov cmp ja _PyLong_FromSTwoDigits lea cmp jae _PyLong_FromSTwoDigits add pop jmp _PyLong_FromMedium mov push sub movsxd mov mov _PyObject call _PyObject push sub mov call sub lea cmp jbe mov mov mov lea shr mov lea lea lea mov mov cmp je mov inc mov mov test jne mov mov mov mov mov add ret test jne _PyObject_Malloc add pop ret
mov test jne _PyLong_FromMedium mov mov cdq mov sar mov and lea xor mov inc sub mov test je _PyLong_FromMedium cmp _Py_tracemalloc_config je _PyLong_FromMedium mov mov mov mov mov add pop ret mov cmp jne mov mov mov mov add pop ret mov lea _Py_NotImplementedStruct cmp je mov mov add pop ret sub mov jne _PyEval_EvalFrameDefault sub jne _PyEval_EvalFrameDefault mov test mov je _PyEval_EvalFrameDefault add jmp _PyEval_EvalFrameDefault
I mean. I still like the idea of Lua as an interface for ameteur programmers to add recipes and stuff to the game like Factorio. Minecraft could've done with a lightweight interpreter/api for some simple entities and crafting systems.
@@someonesomewhere3817 Do you actually think JITing Lua for game content would be faster than an in game visual editor directly saving data as game assets? I think I'm being pretty clear about the suggestion, and it seems unfathomable that even C++ code could be faster than directly loading serialized data.
@@someonesomewhere3817 Well yeah it's way easier to throw in script hooks. There's a difference between "what's a cheap solution I can cobble together with freely available tools" and "what does a good solution to the problem look like". I prefer to focus on the second question.
@@someonesomewhere3817 I'm aware of Lua's simplicity, I've written game engines that use it as a scripting language. I'm not sure what you mean by needing to reserialize, serializing data should be incredibly fast. If you have enormous amounts of data then you're going to be breaking it into chunks anyways, so just save the edited chunks. There's no performance to be gained, loading and saving game assets is part of the game, if that's slow then you probably need to fix it. You'd almost always rather have a visual editor, you could use lua scripts to create a particle config or tilemap. But it'd be incredibly unproductive to specify a tilemap as text, it's better to have a visual editor where you can tweak stuff and serialize it. You keep using phrases like "more convenient". It is convenient for programmers because it's basically plug and play. But it's inconvenient to modders and designers that want to create content. It's obviously too much work to make a visual editor for everything, but to say it's somehow better to not any seems silly.
The game I am writing uses a scripting language, in the form of WASI. It's only for user-generated content, the two issues for why I am using it is because: 1. It's really hard to properly sandbox native code, yes I know there's a billion ways to do so but they always sacrifice something. 2. Cross-platform is really hard, by using WASI I can let users bundle a sandboxed multiplatform module that other users can safely execute. I do honestly really hate the syntax and the garbage collectors of most scripting languages though, so even when I write modules I tend to do them in Rust haha.
Scripting languages might be the single biggest reason for losing my sanity as a programmer. For the 10 years of me writing code primarily in scripting languages, I've tried solving the problem of good design without compromising things like performance, readability AND MODULARITY. I'm starting to think this is not possible with scripting languages. Maybe scripting languages would solve problems of compiled languages only if they had zero-cost abstractions, idk...
My own personal opinion(borne out of experience, but just an opinion nonetheless) I beleive the reason why Scripting Languages aren't particularly suited for non-trivial projects is that they simply were not designed for such tasks, but because of their low barrier of entry, they are often selected for every task imaginable, and then as time goes on, the same people who where told Python or JavaScript weren't suited for in the first place then go on to try to make Python and JavaScript into a poor man's Java, C#, C++, etc without gaining any self awareness whatsoever.
@@thecollector6746 yet there is something to be said for usability, user base and ecosystem health. The cutting edge of web dev is what it is for a reason.
@@BusinessWolf1 That's fair. I think we are at a place now where we can achieve both via compiled languages that provide the option of "scripti-ness" like Groovy Kotlin, Scala, Go, and Rust, and their quasi derivatives like Odin, and Zig.
I think it's not so much a criticism on scripting language generally. This is more about scripting language in the context of game making. Basically it's a bad idea to use a different language for different teams to build the same program
It is near impossible to make a game using a single language tho. At least Cpu and Gpu (shaders and compute) will use different languages and if it is online or multiplayer the backend server program will often be different from the frontend.
@@esbensloth Yeah you're describing programming different services for a game. But even gl shader language forces you to enforce single responsibilities. Your code can get messy otherwise. For Lua scripting, it's basically a hook for existing gameplay code. The problem here is that you're using two languages to code the same mechanism at the same time, which can get messy. It's the same if you use GL and high order languages at the same time to draw the same shapes.
I've been working in a mainstream game studio for 2 years now and we use lua for gameplay code. I was apprehensive at first but honestly it is very convenient. As with all scripting languages that I know of there IS a debugger, I don't know what John was talking about on that one. The dynamic type system does sometimes cause type-related bugs but honestly its just a lot more convenient. Things that would be a 100 lines in c++ are only a few lines in lua because of a lack of boilerplate. All the lua code hotreloads in 1 second making iteration times really quick. The thing that John said about having to write hooks to c++ and back is true but the bulk of that work is just done once and any future hooks can be added in seconds. We don't allow artists to write code, that is silly. We make editors that generate code for them. The only real issue is performance. We don't jit our lua, we interpret it in the most basic way. That being said the number of times things have had to be rewritten in c++ for adequate performance I can count on one hand. 98% of the time lua does the job, 1% of the time we export 1 or 2 functions to c++ to avoid frequent memory allocations and the other 1% is a full refactoring in c++. Something that John didn't mention is just how far you can take the flexibility of a dynamic language (I assume because he hasn't used one too much). Lua doesn't have a class system but we have made an in-house one that ia significantly more flexible than any class system in mainstream static languages. Classes frequently inherit more than 50 other classes and it works great. We have a system that automatically resolves complex inheritance of methods by calling them all and accumulating their result in some way. The UI and many other systems are all in lua and are easy to work with. There are many other nice things about lua that I can't fit inside a single youtube comment. TL;DR There are many things that I agree with John about but scripting languages is not one of them.
I don't think he'd disagree in the current landscape if you're trying to get stuff done fast, but you're suck thinking in current C++. There's nothing about compiled languages that mandate lots of boilerplate and very slow compile time with no hotloading. If C++ compiled and hotloaded in under 1sec would you still have that opinion? Also, I wouldn't insult Jon, by implying that he hasn't worked extensively with Lua and been writing interpreters for 30+ years.
"Classes frequently inherit more than 50 other classes and it works great. We have a system that automatically resolves complex inheritance of methods by calling them all and accumulating their result in some way." Oh my god that sounds like a nightmare to understand/debug. Reminds me of Tom + JDSL.
@@jzargowinterhold1942 We are talking about game development here; not your Python tutorial programs that you learned how to write reading Medium posts.
i think a scripting language has it's place in making a game extensible by giving the end user ability to add levels, missions, puzzles, etc. i wouldn't expect the end user to understand compilers and a complex language (not even one like lua) nor would i want to ship an entire compiler with the game. the scripting language should be something simple that hooks directly into the game by specific functionality.
I agree with this, but that's pretty much the only case in which a scripting language makes sense. Problem is that too often developers have used them with this notion that you could have "non programmers" doing scripting... as if scripting wasnt programming. It is, and like Jon says, you actually get more complexity, not less. Instead of one language, now you have two. Maintainability suffers. Debugging suffers. Optimization suffers. And you divide your programmers by language, so you segment your engineering effort and who can look at what code and who cant.
@@zeejenkins making a DLL requires the end user to understand compilers and a complex language. sure the user could use plugins, but that requires someone else to make the plugin.
@@dinobotpwnz Uh, depends on who? The world isn't about your idealistic views. Someone not knowing anything about programming should be able to make mods because that means potentially more content, potentially more enjoyment, potentially more profit for the company. Simple as that.
John is fascinating to listen to, but "it's a disaster, don't ever do it" feels narrow-minded. Interesting to hear another perspective, but ultimately I don't agree with him here. And how many of John Blow's games have mods of any kind? No one's managed to mod his games by hacking stuff onto his compiled code. He wants people to extend games by editing the compiled code? Fine, he should add a well defined modding interface or open-source his code. This entire video is devoid of any nuance. He compares unlike things as equivalent, like shipping a compiler vs shipping an embedded script engine. He suggests emacs would be better if you could configure it by editing the native code. But guess what? EMACS IS OPEN SOURCE AND YOU CAN ALREADY CONFIGURE IT BY EDITING THE C CODE AND RECOMPILING, AND NO ONE DOES. Has he seen the garbage C code for xwindows in the emacs source tree? Working with Elisp is way better. And he wholly ignores the problem of security, that any user can just hack stuff onto native code without creating security vulnerabilities. Want to extend a game? Just download a mod in the form of some random compiled C++ code from the internet, what could go wrong?. Scripting languages give you a sandboxed environment, at least to some extent. I could go on, but it seems John has some pretty strong opinions about scripting and is overly dismissive of the problems that scripting was created to solve.
Would you say these problems are intrinsic to compiled languages? Or could they theoretically be solved if all systems and components were written in language other than C++? Like Rust for instance?
@@sasuke2910 Some of the problems go away I guess, it's less likely that a user would introduce security vulnerabilities if an extension to a program was written in Rust for sure. But let's suppose that you download a natively-compiled extension from the internet, whether it's written in rust, or something else, there's always the risk that someone nefarious messed with the executable code after it was compiled. Extending an application by scripting, on the other hand, allows a program to run scripts in a, theoretically, hermetically sealed sandboxed environment, where scripts don't have access to memory, files on the computer, etc.. Furthermore, John Blow suggests that shipping a compiler with your application is comparable to shipping an embedded scripting language, which is not the case. Bundling rustc and llvm with a program is simply not the same as integrating Lua for example, a tiny 20,000 line extensively-tested scripting engine. Overall, I was just arguing that John Blow dismisses scripting languages without providing a viable alternative. Allowing people to extend applications using native code isn't a viable solution if you only distribute closed-source programs, as John Blow does. Rust is a great language, but still not something that ordinary users can use to extend software. While safer than C++, Rust is still a complex systems language. Maybe Rust will replace C++, but scripting will still be useful and necessary. But, now that basically all scripting languages compile to bytecode, the line between programming language and scripting language is extremely blurred. The performance issues aren't as severe as Blow suggests. Programming language vs scripting language isn't as meaningful a distinction as it was in 2005, when, according to Blow, people supposedly abandoned scripting languages (he doesn't cite data, of course), so I'm surprised that John makes such a big deal out of it. Providing only native code as a way to introduce extensions to a program assumes that it's perfectly fine to give user code access to an application's memory, but there are plenty of scenarios where, partly for security, you don't want to do this.
@@evanbowman4065 Well, if the OS was better sandboxed with applications not having access to the full disk, if applications could partition their memory space safely, and all applications shipped with header-file equivalents would all those problems not be solved? If your main issue that he doesn't provide a current alternative, then I guess that's legitimate complaint, but he and his team have been working on a new compiler and toolchain for about 6 years now. If you're limited on time/money and you only need your application to survive for 10 years, then making something with Lua makes a lot of sense. But this Jon is talking about the ideal design for the next generations of software.
@@sasuke2910 "Well, if the OS was better sandboxed with applications not having access to the full disk" Yeah, that could be done, but don't expect clueless end-users to actually do it. "if applications could partition their memory space safely" If you're loading foreign code into a process, e.g. with dlopen or similar, how do you propose to partion memory space to prevent access? You could run code as separate processes and communicate via shared memory, but then you need to create a protocol for communicating with the application, and this sounds not altogether different than building a api, and in the video John Blow dismisses api endpoints for an application (script apis in particular) tedious and error prone. He seems to want a monolithic unified codebase, which implies loading user code into a single process, unless I'm missing something? "If you're limited on time/money and you only need your application to survive for 10 years, then making something with Lua makes a lot of sense. But this Jon is talking about the ideal design for the next generations of software." 10 years is generous, most code doesn't even survive that long. But I see no reason why script extensions written in Lua or some other scripting language would survive less long than ones written in natively compiled languages. I've seen plenty of natively-compiled C executables that no longer run after OS upgrades, but ancient Java/C#/Lua/etc. programs still seem to run fine, as they're hosted on a VM. Would you care to explain why native code would survive past ten years while scripts would not?
@@evanbowman4065 "John Blow dismisses api endpoints for an application (script apis in particular)" I think the key distinction is a "native" endpoint, not a scripting one. Native in this case meaning whatever the host language/ABI is. "which implies loading user code into a single process, unless I'm missing something" I don't think so, right now OS's isolate memory using processes, so it makes sense to use them if you can't isolate dlls in another way. Although it's not very hard to imagine a feature to flag memory for access from dlls. "Would you care to explain why native code would survive past ten years while scripts would not?" It's not about being native to the OS architecture, it's about being native to your own system. The extreme added complexity in your runtime environment and tooling cause systems to rot more quickly. For example, systems that require multiple debuggers rot faster than systems that can make use of a single unified debugger. If your game is in Python (god forbid), extensions to it should come in the form of Python modules that interact with your existing api. If your game code is Lua dynamically loaded into the Unity C# CLR, that gets loaded from the Unity C++ framework. Then your whole toolchain and future is very shaky compared to unified projects where you just dump a million lines into rustc.
After being impressed by the AngelScript fork of UE5 and wanting to use AngelScript for all my UE5 stuff instead of C++, I came here to listen to the Devil's Advocate stating his case.
I think the most useful thing about scripting languages is to store some value that need to be changed frequently, and sometimes you need a data markup language like XML or JSON, but you want them to have some programming ability like simply generating a table, which is quite convenient. People think scripting language is bad, it's because some people decide to use it to do complicate things as Jonathan Blow mentions.
What about a language that can be compiled AND interpreted and has an interpreter that can run scripts that can change the state of already compiled and running programs written in that language? So basically you'd get lots of iterations AND you'd be able to compile your scripts as object files if you want them as binaries (Yes I'm thinking of Lisp)
Late to the game here but was Jon running some kind of end-to-end testing on his game here? Seems like wouldn't be something he'd be super thrilled about doing, but I can't tell what else could be doing.
So I am not in the gaming industry, so when I think of scripting languages I probably think about it a bit differently than Jon. I use scripting languages when I am debugging problems that are larger than one specific corefile. When you have to gain quick insight from a lot of data (logs, counters, ...). When you need to pipe together some output from some small programs - that kind of stuff. For most other stuff I am really hesitant about using a dynamic / scripting language. I understand why people use them in build systems (since that problem looks like the same thing I mentioned before - connecting together the output of a few smaller programs) but to me it feels really scary how shaky everything is. If you need something to last long you should build it with robust parts. My small observability one liners only live until I understand/solve that specific issue. I only use a dynamic language because atleast it is saner than Bash, and in a perfect world these small programs would get replaced by some real piece of code that would provide real and more ergonomic observability of our system. (btw, I know it is an old clip and I have already commented here ages ago - but I like coming back to these clips and reviewing how I feel about them)
can you mention an example of when using a scriping language might be a bad idea? also "If you need something to last long you should build it with robust parts" can you explain more, i can see a lot of companies using Javascript/Typescript (scriping language) to create desktop apps and web apps, for example VS Code was made using Electron.JS and for me its been great to write programs in.
It took me 2 secs to go from rust to C. Then as soon as i try to do smtg in lua its sooo painful because of unintuitive syntax, other abstractions etc. If i wanted a specialised language for specialised tasks then fine, script me. But for anyhting general C is sooo easy
ive heard the refrain often that with a scripting language you dont have a debugger and im confused what everyone means by that? you *can* write a debugger for a bytecode vm
You can, but Lua and many other systems don't ship with one because it kinda needs to be custom to properly interact with your own engine code. The time and complexity cost of building/maintaining/using a internal debugger and toolchain is almost certainly higher than building an "in-game editor" equivalent that serialized level data directly.
There is one use for scripting languages, writing scripts, as in dialogue or story. While you can use ini or other formats it is more convenient to write branching dialogue with a more code like syntax, that said you don’t need a full language. Logical storage format I suppose.
That's more a task for a DSL (domain specific language). Which is comparable to the visual scripting he talks about in the video: they're limited so there's less room to do stupid things and less complexity that may degrade performance.
Just do like terry, and make your own OS too... Or even better, your own computer and parts ... Your own tools, like the guy of that channel doing a iron knife from the mud, wood and jungle...
Emacs would be so much better if it were simply a Common Lisp library and a standard implementation, e.g. SBCL. It would suddenly be - Fully compiled. - Easy to debug. - Fast.
Theres a reason why you separate performance-critical simulation things and gameplay things. C++ has massive compilation times, especially for things like large games with tons of external libraries. You need to quickly iterate these things to get a functioning product quickly. Also languages generally aren't flat out interpreted, they're put into more efficient JIT bytecode first. C#, which *does* have debugging and type checking, I count as a scripting language that compiles to JIT bytecode. This whole take is confusing.
He is extremely biased here, since he has not worked in a big game studio... Generally, there are gameplay programmers that work on the scripting, and engine programmers that work on the C++ codebase. Yes, it's a lot more work for the engine programmers to support the script language, but it pays off during the gameplay testing and codding. You can generally hire people with lower language understanding, or even give the script to the designers. It's hard to find competent C++ programmers for everything. It's good idea to not mix the languages, since scripting requires completely different approach then wring in C++. Yes, there is extra work, but the engine lifecycle is much bigger then the game lifecycle. So the investment pays off. It's far from a "failed paradigm". But there is a right way to do it, and many wrong ways. It's like saying - JavaScript failed, which is absurd. It's something very handy, but yes, it can also get very messy if you are doing it wrong.
@@insidiousmaximusno. He dropped out of college. Started his own indie groups and they failed then made braid. Dude has a code god complex. He’s smart but he’s very biased towards his own opinions on things. He knows how things work but of course he always thinks he’s correct.
@@Calypso694he mr jonathan blow has ported game to setupbox or whatever you call them alone in his late 20s or early 30s and for that project he probably used server for the data streaming and the box itself as a renderer, then input handling and other stuff, this mad man know his stuff (You know nvidia streaming, Netflix game streaming, ps4 ps5 game streaming, probably xbox streaming and amazon game streaming is also a thing now). Learn to judge people talents and credibility in specific fields outside of politics. And i also dont quite agree/ understand his takes. I also dont get yet another new lang jai from blow either, Does he care well i believe he do but i cant fully grasp / understand. And wish himnGood luck.
I kinda love working with LÖVE2D and LÖVR, but if the project gets big enough, refactoring does become a pain. Still, seems WoW used Lua in a pretty decent way for UI plug-ins, wonder what Jon's opinion is on that. Also, Warcraft 3 and Starcraft 2 have used Lua to script AI and such, if I am not mistaken. Again, seems to me a pretty decent approach, allowed easier level/scenario creation by 3rd parties it seems.
I'm an addon developer for wow (AuraBreak Notify and others) and I would have had a much easier time with static types But relaunching the game for every change? Reconnecting? Relogging, loading? Fuck that, Jonathan
I dunno. Naughty Dog, Valve, Blizzard and many other studios seems to be doing pretty well with scripting languages. Most of their titles are purely written in some form of scripting language, whether it being Lisp (Naughty Dog), Squirrel (Valve), Statescript (Blizzard)... you name it. I think the points the Jon brings up are very valid. But some of the pitfalls he mentions, such as designers writing bad code, can be solved with teaching, communication, team management and documentation. Things you should have in any company, even if you don't use scripting languages for your games. Being able to iterate on design choices quickly is what can make a game better, because decisions can be made in less time. Regarding speed; sure it's not as quick as your inline assembly code which runs quicker than any compiler can fathom. But there are ways, using static analysis, to provide information about complexity and warn about it. Depending on your scripting language of choice, you can introduce linting and formatters which can help clean up your diffs for the team to review.
I once worked with multiple designers who had been briefed about code commit guidelines from the company. They usually write the initial code and commit it once and never touch, fix or refactor the code ever again. As long as it works, and looks the way they want it to, its good enough - which causes hassles down the line. Its not about them writing bad code, since they can fix that problem if they give it enough attention, its usually the attention they give it - the good old "if it works, it works"
@@dealloc maybe it is a management problem, but that's how policies prohibiting designers from touching code get implemented. Same as how security departments aren't allowed to touch or look at code. Well, in most of the companies in my country that is.
You have no idea what you're talking about. None of these titles are "purely" written in a scripting language, they all use a mix of compiled languages and a bit of scripting languages.
@@michaelzomsuv3631 There's a distinction between gameplay (99% of what you do in a game) and engine-most gameplay is written in a scripting language which uses underlying systems. Everything from AI, dialogue, missions, cut scenes, etc. can be executed effectively through scripting, whether it being high-level (i.e. node graphs) or not (code).
Emacs is 100% Lisp, any customization will have to be done in Lisp... For a C programmer that must be very painful :) IMO his development style would probably be served best by vanilla vim, tbh.
@@berkano_plays pedantic correction: Emacs itself is almost entirely C, including a lisp interpreter. It's still customized and extended using lisp however, similar to the games jon's comparing it to.
Why not do the Id Software thing and do both? Id Software, for Quake III, used C as the scripting language! Thing is, Id Software implemented a compiler that outputs stack-based bytecode. Perhaps in this case, a regular C interpreter reading source code would be more beneficial.
Great idea, but while we're at it, why not precompile it? And why not C++? Same reason, the compiler and toolchain are heinously complicated. But this does seem like the general solution. We just need a nicer language that compiles faster, is less memory error prone, has a simpler toolchain, and strong metaprogramming facilities.
@@sasuke2910 that's not a bad idea, problem is that it makes modding more difficult. More complex the programming language, the more people you turn away. Why not C++? Because C++ is way more complex than C, especially when doing game logic, and its simplicity makes C alot easier to debug compared to C++. IMO, the perfect language would've been Golang but if only Golang didn't have trash ABI to where it's really slow to interface with C libraries. Toolchain for using a C interpreter isn't hard either. If I had my own game company + active game project, I'd most likely pick the latest Python or Lua for scripting since they're both very widespread. I'd lean towards Python since that's used alot more than Lua IMO.
if you're going to be compiling to machine code to extend an application you may as well compile to a dynamically loaded library using a separately installed compiler but with headers included in the distribution. I do think luaJIT is a pretty good option if you want to have a simple 'scripting language' for extension but also 'compiled'
Scripting languages make sense in meta programming, when you want to generate code files from a config file. CMake like software, Automated Testing, source control, or just to write things like switch cases faster, linting rules, compiler flags, turning lists into enums or constants or combining sections of text shuffling them together. Cutscenes with animated dialogue should often get a scripting language that lets you stylize text color, control the camera, character expressions, etc...
While performance, accuracy and strictness are important aspects, he misses the fact that moddable games become WAY more popular than non moddable ones. Terraria, Minecraft, Warcraft 3, World of Warcraft (UI, mostly), Skyrim, etc. Massively popular *also* because they're moddable. Sometimes you just have different goals.
Consider that Counter Strike and Dota are both mods of games that do not have scripting systems, scripting is not a requirement for modding. Also, isn't Minecraft a counter example? Most Minecraft mods are implemented in Java, the same language as Minecraft, not a separate scripting language.
@@화성-v4g > it’s written in java which you can easily decompile and modify it’s code. That wouldn't be a scripting language... "Scripting language" in this context means using a **different** language than what was originally used to create the game. "Scripting" does not mean "interpreted" or "non-C++".
@@화성-v4g Maybe spend some time researching what these terms mean before trying to have a conversation about them. You really don't know even the basics of what you're talking about if you think The Witness and Braid didn't require a powerful machine to run when they were released.
@@sasuke2910could just use C++ and have the engine load libraries (.dll or .so) as and you have the benefit of high performance code and installable mods
I just see scripting languages as being useful for easy gameplay mod support. Granted you could hot reload assemblies in C# for example, but then comes the challenge of sandboxing out system critical libraries so mod developers can't easily make malware. It comes at the cost of having to deal with memory management and more challenging debugging, but I can see why it still exists.
normally i think jblow mostly talks nonsense but this snippet is so true and makes me miserable day in day out, scripting is such a pandoras box that has caused nothing but trouble on projects i've been on.
hard disagree on the visual scripting take though, i'll let it go cause it was relatively new when this clip was made but visual scripting has become as bloated and load bearing as ye olde scripts were, is just as annoying to debug and has exactly the same problems as scripting languages do.
I disagree with jon here. If done well and you have a solid and fast API, scripting languages can be monumentally helpful in developing your game even if it's a standalone game with a bare bones engine. It allows for extremely fast iteration, it abstracts away game logic from the engine which is crucial for debugging and code maintenance and it allows you to actually focus on the GAME development rather that messy c++ engine code
There's nothing wrong with initially developnig your game using a scripting language. As long as there's that final step of saying "now that the logic has been prototyped, we will convert it back to a language that isn't slow and hackish".
lol, i came here after watching a whole gdc talk by naughty dog on the combat system of the original the last of us game, which, news flash, was built completely using scripting, written by designers, not programmers
@@ducksoop.x He’s no boomer, which is easy to find if you bothered. Besides, just because X does something, doesn’t make it the wisest choice. Just because X doesn’t do it doesn’t have anything different: they both have tradeoffs, and the question is, what tradeoffs are you willing and able to make? Context matters.
I was with him until he mentioned visual scripting. It's everything he complained about but worse. Blueprints in unreal on large projects turns into an absolute shitshow. It's just code except you can't search it, tracking it with version control is annoying, it's binary so it's unmergable (you can kind of do it visually but it's an absolute pain, and merging across diverging branches is literally impossible). The last game I shipped had networking code implemented in blueprints. The fact that any of that is the case absolutely blew my mind in the worst way possible. Oh, and it runs like absolute shit. The exact same naiive implementation in c++ runs literally 10 orders of magnitude faster in almost every case, but since it's a proper language there's all sorts of better tricks you can do, too.
Do you mind me asking how it would work in the animations in Unreal? I am currently writing a game in Unreal and am using blueprints with the given knowledge that at some point I will have to rewrite each blueprint in C++ and have started already. My only question is does your same viewpoint apply to animations? Like are you advocating for rewriting the animation state machines etc. in C++? Cause I don't know if I am willing to do that part
I mean, I think that's a simple case of the feature being mis-used. It's possible to shoot yourself in the foot with every new tool that is created, that doesn't mean it's necessarily bad. I think scripting languages or scripting-like layers work well when they are a thin flexible layer built on top of a robust core. Networking should be part of the core, not the scripting layer. And similarly, I think if you've gotten to the point where you want to re-use scripting-layer code, then the shared parts should probably be moved to the core instead.
I really disagree with a lot of what he says - it's hard not to be inflammatory toward him. Even when he makes a good point, it's buried in so much bull, it's ultimately pointless. Edit: OK, after a Socratic discussion with a friend, I've come to the conclusion that my reaction might be too strong - he's basically dissing on something that I've spent a lot of time developing, so it hits a little too hard.
I completely agree with Jon that scripting language can become bug prone and its slow. For my perspective the num of reasons to embed scripting language in the engine could be: - To be productive (i.e Do a hot reload within the engine running). - As Interface to only allow a set of functions in the engine.
You can make hot reload work in a compiled language with a little bit of work (not much work at all in the scope of a game). What it enables is easy access for modders with limited skillsets, like kids, which is awesome.
First of all, scripting languages are used so game developers don't have to go through the pain of writing their entire game in C++ (which is already a messy complex language to work with). It also lessens development time, and the performance really depends on how you implement the code so that it doesn't get affected by things like garbage collection. It's also possible to write an entire game in C++, but have completely bad performance because of bad coding style. Second of all, how do you define a "real programming language"? I define a programming language as one that solves problems and expresses a solution in which a computer system can understand and execute. If your definition of a "real" programming language is interfacing with the computer hardware, then the only "real" programming language is Assembly. Assembly is the only language where it allows users to completely interact with machine instructions, complete manipulation of memory, etc. Compiled languages such as C and C++ only generate machine code, but you never actually interface, nor completely control the code actually generated by the C/C++ compiler. EDIT: Also, just a history lesson, C++ wasn't always the "lingua franca" of video gaming. Back then, Assembly and C (though in many engines, C was mainly used for scripting while the entire engine was made in Assembly) were pretty much the dominant languages of video gaming until games got more complex and hardware got more advanced, then C++ started becoming dominant, especially around 2005. After that, C++ became hard to work with because of its complexity, thus game development took longer. That's why scripting languages are used in the first place, to ease development time.
The assumption here is that the only alternative is to write their entire game in C++ when that patently isn't true. Java, C#, and D(Remedy Games are among the very few outfits that have used D in their games) are all compiled, strongly typed languages that are demonstrably and significantly fasters than scripting languages and prehaps more importantly...THEY SCALE
@@thecollector6746 yes, but unlike Java, C++ doesn't force you to OOP. It is still mostly procedure, unless the person is using Unreal or Unity. So there is a difference between using classes and having everything being a class.
Or, the thinking goes "We'll give them a scripting interface so they can customize it to suit their tastes" except they never do know what it is they want and they want YOU to customize it, not them. So it ends up making more work for you that's mostly not needed.
Scripting languages were a great way games in the 2000-2010s allowed people to create custom content, Gmod being a prime example. Clearly this is different from creating and shipping a game.
Personally I wouldnt mind a scripting language to manage things like item/enemy placements or game events, but for ai code, gameplay code etc I definitely prefer to write It in a "real" programming language.
i like engines with scripting languages for very, VERY simple prototypes, but anything beyond that is just a huge mess, sometimes i work in games with very non-trivial mechanics, that are just simpler to quickly prototype if i have a semi-solid foundation for rendering stuff in a 3d scene.
Late to the party, but this is tricky. Having the engine built on a different language introduces a lot of complexity for both the Unity team and for us. The Unity team has to make sure every new feature plays nice with the C++ editor/player, while also making sure nothing breaks or bugs out on the C# side. We, on the other hand, have to deal with the technical quirks that comes with that interop, from writing lots of boiler plate to compensate for stuff like poor encapsulation (thanks to serialization), a lack of constructors (since the engine has to create our objects), and to jumping through hoops to make sure we don't over or under use the main thread (since the update loops is single threaded on the C++ side). On the other hand, C# is a powerful full on industry language, and since C# can be JIT compiled, we don't have to compile the entire engine or editor every time we modify our game logic, and with the IL2CPP compiler, it all compiles down to C++ in the final build when we do so C# performance isn't a concern. So its a give and take with Unity.
Scripting languages are fine, for the reasons he states as the "why" at the beginning. Currently, the best reason for scripting languages is to allow community modding, but the original reasons are still valid because compile times can still be onerous. Most of the reasons he gives against scripting languages still apply to the game without the scripting language, and as always developer discipline is critical to achieving best performance.
With the way C# is structured we really shouldn't be calling it a scripting language. I only ever heard it being called scripting back in college when we were taught server-side scripting in C# with ASP. NET. and my professors called C# files as scripts, but I think that's from the legacy of programming anything server-side being called "scripting".
scripting languages CAN be fast, it just needs to be very well optimized. also, what is he talking about by "no debuggers"?? what language doesn't have a debugger?
The utter disregard for the end user is absurd. I can't just send them my code if my engine is encumbered by third-party middleware like so many engines are.
The difference between Blows take in this video and PirateSoftwares Thor praising Hades 2 for its use of well commented Lua for all the game logic is crazy. Gotta say I agree more with Thor.
" if I use C++ then I have to wait an eternity for recompiles " "I don't know anything about C++; because if I did I would be aware that you don't have to recompile the entire source, and my programming skills are questionable to begin with because I just admitted that I don't compile in increments because I don't test modifications as I make them"
Embedding a scripting language is very Unixy but a terrible idea if you have to cross the programmer / artist barrier. Don't make programmers do art and don't make artists write code. It's just not the way they're wired. Bad results inevitably ensue. "The Art of Unix Programming" is by programmers, for programmers. Visual scripting is good for artists and gameplay programmers. You can have issues with performance. I'd treat it as a prototyping tool.
And yet Hades and Hades 2 - both that were almost entirely scripted in Lua - have come out as critically acclaimed games in a shorter span than The Witness took to develop. I get that “your art team can now script games with this too!” is bad, since it’s still under the same software design scrutinies as other pieces of software in the game’s codebase. But scripting languages are extremely powerful on the right hands and on the right situations.
Welcome to 3 hour long Unreal Engine 4.26 game builds outputting 300GB of binary data. And assets are all binary because why should someone actually want to edit assets outside of a fullblown GUI game editor with thousands of buttons 😂
scripting languages are more useful for mods. easier to implement and let other people interface with without exposing the whole code base. if its slow, that's for the mod developer to deal with.
I see a lot of C# comments, probably because Unity uses it. But how often is Unity used for triple A games? UE4 is much more prevalent in AAA and only provides (hot reloadable) C++ and Blueprint. I think the whole flow of creating the engine in C++ and hooking up Mono is only done because computers have gotten very fast and we can get away with unoptimized solutions.
Not sure why everything is measured in terms of how many "A"s they have. Plenty of games, created by independent studios, have been made (written in C# either XNA or Unity) that feels like AAA. AAA titles is not a good measurement for how good an engine is, nor even how good those games and studios are.
Unreal is super annoying to learn for me due to blueprints and the elitist community. I learned Unity super easily because of the amazing documentation and the plentiful tutorials that still mostly work. Unreal I find it hard to find good tutorials in c++ because most are in blueprints (why even use unreal if you are using blueprints?) and the documentation is laughable compared to Unity's.
I think, main benefit of scripting languages that they allows players make mods to the games. Mods often improve base game experience (see Paradox Games, Warcraft 3, Skyrim or Dwarf Fortress for examples). With scripting languages is it even possible for players to fix bugs themselves (for example, there is a bugfix mods for Dragon Age Origins that fix combat, AI and/or quests). If you ask players to use write a DLL in some serious programming language to make mod, that would not happen.
I don't really think blueprint/unity's node scripting thing are good as scripting languages because blueprint exposes a ton of engine stuff by default that you can't turn off, and unity's thing exposes everything that's already exposed to C# Being able to know everything designer will interact with in advance is imo a pretty important part of scripting languages and those don't tick that checkmark
There's a lot of stuff Jon says is outright bad which is actually a trade-off. Scripting languages can be worthwhile to use depending on your experience and use-case, but they aren't very useful at all for someone like Jon for all the reasons he listed.
i disagree.. you don't use scripting language to code your gameplay or whatever. you need to use scripting languages to create content. core mechanics can remain in the core, be it C++ or any other language. the content is really entity scripts, world events, interactions, and all things that won't be executed constantly, most likely just once
Scripting Languages are good for Game Modding in my opinion. For example Garry's Mod has scripting done PERFECTLY, it has made many people start and learn how to code. It is also easy to use and more fun. I somewhat agree that if a game is entirely made in a Scripting Language it is gonna be very slow but for modding it has a positive effect.
The point is, you could do the same and just not use the scripting language, just use the real language, like how gmod was made. It's an HL2 mod, but wasn't made with scripting, same with Portal and Counter-Strike.
@@sasuke2910 yes but scripting adds ease of use. Source engine takes AGES to compile and it would mean that you will have to remake a game for modding... but Lua here saves the day.
@@alphenex8974 Compiling being slow is a fixable problem. I'm not sure what you mean by needing to "remake a game", you can use the same api that any Lua system uses.
@@sasuke2910 Yes, stuff can escape from sandbox environments, but can't a c/c++ DLL have malicious stuff implemented easily? Putting that responsibility on the players and not providing a safer way of modding feels treachery to your players imo.
@@kulkalkul It might be slightly easier, but any sufficiently advanced mod system will be able to exploit or crash the host game in some way. Sandboxing helps, but doesn't require you use two different languages. You can sandbox C++, C#, or whatever your main language is.
I mean, Emacs Lisp has a full blown IDE, debugger and more built right into it. I don't think Blow is correct on the difficulty on debugging scripting languages.
I kinda disagree. A well-made scripting language can save you a lot of development time. Not every scripting language is tied to an interpreter or virtual machine, scripting languages can be compiled to machine code as well. The real problem I see is that scripting languages in almost general is the lack of a smarter object/class creation system, like an embedded object pooling or something like that, to prevent users from allocating stuff during runtime.
For gameplay I couldn't imagine using a scripting language, but for cutscenes, a scripting language is much better than using some tool provided by an engine for making cutscenes, you can go way way faster.
I've been coding for half my life and I don't even know what makes a language a scripting language, I just assume the ones with script on the end are scripting languages
It is not about programming language it's about how it's used, for example Javascript is used to manipulate browser objects so it's used as a scripting language in that context, VBA is used to manipulate Word, Excell, AutoCad and so on, so VBA is used a scripting language. Most of early implementation of programming languages that wear designed to be used for scripting like Javascript are built as an interpreters but recent versions are usually generate machine code, but due to semantics of Javascript it may be harder to produce machine instructions, for example function add(a, b) { return a + b; } may operate on strings, numbers, dates so compiler may need to add checks to ensure that compiled block operates with correct types.
@@VolcanicPenguin Haha, you know what? I was gonna say something about the fact that you've been coding half your life and you don't know that. But, it's refreshing to see programmers who don't pretend like they know everything. Anyways, I guess the main difference is, compiled code is turned into machine code whereas scripted code is fed into a sort of virtual machine that performs all the instructions. That's a very brief overview but I definitely recommend you read about it, it's an interesting topic.
@@noahfletcher3019 That can be a problematic distinction because even interpreted languages often have preprocessing, compilation to bytecode etc. going on in the background to improve performance. How I understand it "scripting language" means it's used as a secondary language for configuration or extensions for some software that doesn't require recompiling the whole thing. I think it makes sense in many situations, but Jonathan Blow is also correct in that properly implementing a scripting language in an engine may not be worth the trouble.
Waiting 15 minutes for your game to build? Oh baby. I work in AAA game development. For some changes my end-to-end compile/build time is 4 hours. Fucking shoot me.
whats a scripting language? like python, bash/ powershell, lua, lisp, gdscript; what else? is mojo, julia, kotlin, zig, octave a scripting lang? why not? just 'cz of type checking?
It's not black and white. It's a combination of features, and every language makes different choices on the tradeoffs. You could say a scripting language is really just anything people happen to use to write scripts rather than applications. But then there isn't a hard line between a script and an application.
Programmers will always disagree on programming. However he has, produced and most importantly SHIPPED very successful games. The result always outways the method. Many ways to do something but shipping far outweighs any particular method or paradugm
I have a friend who plays a wargame called "Dominions 5" and writes extensive mods using their scripting language, it's quite impressive and people seem to be happy with it. Personally if I had to build a (2d) game with a non-programmer and that this person needed to be able to add content, I'd give them the possibility to add stuff using json or something like that but it would be really constrained. Making a GUI tool would better their own "DX" but the constraints would be the same... It's not scripting per say because I could very well compile everything once we ship a beta/production build and keep it as "scripts" only for the dev build... Just talking outta my ass, tho.
Ask Square Enix how relying on scripting for FF14 worked out for them. The story ultimately has a happy ending, but that's because they dumped a ton of money into totally rewriting the entire game to relaunch it while keeping the old one patched enough for ppl to play for 2 years.
www.quora.com/Why-do-game-companies-all-use-C++-rather-than-say-Lua-or-Java-Are-they-shifting-away-from-C++ Seems like we are all scrubs. This would explain however why I'm running into performance issues coding in C#. Basically scripting laguages have automated garbage collectors. You cant control the gc so you get unpredictable performance spikes. While in C++ there is no gc - so no unpredictable behaviour. But you have to take control of the lifetime of your object in memory yourself. It seems you only can code in c# when using unity. Sooo i'll stay with c# for a while i guess.
@Scholar of the first sin I promise you that there is nothing fundamentally different between a Python "interpreter" and a Java or C# "virtual machine". You are just wrong trying to see C# as a compiled language.
@@nandoflorestan the plain ignorance of not explaining yourself is showing. @scholar please don't listen to this fool. Here is a better way of explaining it cs.stackexchange.com/questions/23951/are-java-and-c-also-purely-interpreted-languages
If you use javascript these days though, granted your rendering isn't heavy, you can deploy to pretty much everything very easy using an embedded browser. With that said, for 3D games, heavy rendering, and consoles that's no good.
The way I see it, you're gonna need a DSL either way, so might as well make it a part of the engine. I mean, eventually, every serious game will need to represent some _ongoing process_ that some object is performing, which has to be _pausable at any moment_ and _persistable to a save file._ If you have a DSL that can do all that - that's already a scripting language.
I'm not sure I buy this. The things that people have made with Lua are phenomenal. I've done Lua game dev for years as a hobby and haven't had a big issue with it. Saying that Blueprints works but scripting languages dont work just sounds like he's out of touch. I'm not willing to listen to someone who says Lua is "not a real programming language." Lua has created some of the most easily maintainable libraries I have ever laid eyes on.
The primary issue here I think is that because of their low barrier to entry, people forget that scripting languages where designed specifically to implement the automation of well understood, but routinely occurring multi-step tasks; as opposed to building fairly large, non-trivial, carefully engineered and maintainable projects.
That is why we don't build large maintainable projects. Certainly not well engineered ones.
not really. It's just one of the big obvious downsides of scripting languages.
if you step back for a second and say, give scripting languages to a bunch of profeccient long-time programmers, you get other issues.
Many issues he brought up in this video, like debuggability, bug-prone interpretation, lack of strict type checking (this is literally a bug generator marketed as a feature).
I understand the idea and benefit of accepting any type by default but its absolutely insane to not check for a function paramter type until runtime by default. Another is tool fragmentation, like compilers and build systems, limited feature support, weak interoperability between lower level languages, having to write bindings all the time, being dog slow.
Scripting languages can just be a pain all around and ironically none of them having anything to do with being "interpreted". Java, C# and C++ all have interpreters, you don't see them having issues with performance or strict type checking. Arguably C# is a bit *too* strict with type checking
@@Mallchad No...the fundamental issues with scripting languages within the context of using them in use cases they aren't suited for is because they are interpreted and all that is associated with that. This is by simple definition.
@@thecollector6746
I don't understand what interpreters have to do with debuggers, strict typing, or anything else.
x86 assembly instructions can be interpreted. What does that have to do with making good code? and how does that shape what the language can be good for?
@@Mallchad ..that's because you are rebutting an argument I never made. Scripting Languages were not designed for building non-trivial, scaled, performant applications. FULL STOP. This is a FACT. I didn't bother reading the rest past your open because why bother ?
Tldr use the right tool for your job. Don't use python to write a raytracing program and don't use c to write a web scraper you'll use once a week. Ffs this is common sense
Sure it's common sense, but programmers will argue about anything, especially when it comes to defending their hammer of choice.
No one should ever use Python...
@@RadovanPalik what an obtuse statement with no reason to back it up.
Just to prove you wrong, I'm going to write a raytracing program in javascript.
@@RadovanPalik absolutes = bad advice
Jon Blow lives in the future.
he can rewind and forward his life like in his game Braid
Perpetually*
0:06 2020? Jo Blow living in the future?
I am living in the future (hello)
if so, jon could've fucking told us about the thing
@@slash213That would've been spoilers!
The integration tests running in the background 👁️👄👁️
A problem with compiling is it often means rebooting the game/editor and reloading your map, which can make tweaking gameplay numbers a chore.
You can store static variables in a config file and implement a way to hot reload them
@@mathmage420
You can hot reload only the bits you want in several languages. Lisp and Java being perhaps the most famous ones for it.
It CAN mean that, but it doenst HAVE to mean that. You can compile to a dynamically linked library and reload it at runtime. This way you can write that C++ code in the editor and compile it, then bring it into the game as the game is running. If it fails to compile, for any reason, then you dont and the game keeps running without problem.
When working in Unreal Engine, I make such things a editable property (e.g. public UPROPERTY) so they can be edited in a editor. I don't see any reason why any game shouldn't be able to support such functionality.
You can hot reload C++ if you know what you're doing
The value of scripting language is not its performance, but in community making the game content. I can provide some games where modding gave more to the game then devs themselves
There's no reason you can't make mods without scripting languages. Counter Strike is probably the most well known mod ever created, but it did *not* use a scripting language.
@@sasuke2910 He's probably not talking about the possibility of making mods, but the ease of a modding community being formed around the game
I still think that Blow's point that modding it with the same language that the game is built in solves many many problems.
But I think you also have a solid point that a _community_ forms and grows much much better when it's even a little bit easier or more accessible. If the goal is quality community mods, excitement about modding is extremely beneficial, no matter how bad the actual experience of modding is. Most people (unlike Blow) get excited about the surface level and not the little details that matter in the long run.
If your own team members can't use the tools very well, how good a game can you possibly make? The point JB was making was simply that as a tool scripting language is always a worse choice compared to real programming language (for coders) or a custom made tool (for other members of dev team) like Blueprints. If your team has good tools, you can always provide those for modding.
@@sasuke2910 sure, you CAN, but the barrier to entry is much higher than just edit text file and rerun game
If only people would let Jon get past the first parts of his discussion so we would be able to have someone as experienced as him discuss the more interesting part underneath this which is where do you draw the line between how much dynamic you let the data for you game become between how much you keep in gameplay code. If you make your data dynamic enough (let it define complex behavior) you could easily end up with having almost a badly implemented scripting language. But you still want a data oriented design and have things be dynamic through data. That is a balance act and I would love to have Jon discuss how he approaches that problem.
This is a trash take, it's undefensible... he makes generalizations that are total BS, talking about scripting languages as a whole, where there's scripting languages with type checking, for example... you can definitely have a full blown debugger, for example Python has a full debugger... etc. It is just an awful take.
@@davidgildegomezperez4364Python is also 100x-180x slower than C++ with the exact same code (simply due to its interpreter), so that'll instantly be your game's bottleneck
@@Muskar2 not necessarily, there are many people programming games in interpreted or bytecoded languages (C# in Unity, for example)
@@davidgildegomezperez4364 What are you even saying? Do you agree that an instruction takes cycles for the CPU to do?
Take *LEA C,[A+B]* (c = a+b), which is an instruction that takes at worst 1 cycle to complete (uops dot info). Comparing that to 180 instructions that average out to 100 cycles, with cache misses etc. - do you agree that it's only logical for it to take longer? You can go measure and get the same result like I did, but my statement should be obvious and logical even without measuring.
In C# it just turns into 1 LEA instruction. But in Python the same LEA turned into:
mov qword ptr [r11+38h],r14
add r14,2
jmp _PyEval_EvalFrameDefault+5872h
mov rdi,qword ptr [r12-8]
lea rax,[__ImageBase]
mov rsi,qword ptr [r12-10h]
sub r12,8
mov rdx,rdi
mov rcx,rsi
call qword ptr [rax+r13*8+3E7A70h]
mov qword ptr [rsp+8],rbx
push rdi
sub rsp,30h
xor r8d,r8d
mov rdi,rdx
mov rbx,rcx
call binary_op1
mov qword ptr [rsp+10h],rbp
mov qword ptr [rsp+18h],rsi
mov qword ptr [rsp+20h],rdi
push r14
sub rsp,20h
mov rsi,rdx
movsxd r9,r8d
mov rdx,qword ptr [rcx+8]
mov rbp,rcx
mov rdi,qword ptr [rdx+60h]
test rdi,rdi
je binary_op1+2Fh
mov rdi,qword ptr [rdi+r9]
mov rcx,qword ptr [rsi+8]
mov qword ptr [rsp+30h],rbx
cmp rcx,rdx
je binary_op1+55h
xor ebx,ebx
lea r14,[_Py_NotImplementedStruct]
test rdi,rdi
je binary_op1+0ADh
test rbx,rbx
je binary_op1+90h
mov rdx,rsi
mov rcx,rbp
call rdi
mov rax,qword ptr [rcx+8]
test dword ptr [rax+0A8h],1000000h
je long_add+24h
mov rax,qword ptr [rdx+8]
test dword ptr [rax+0A8h],1000000h
jne _PyLong_Add
sub rsp,28h
mov r8,rdx
mov rdx,qword ptr [rcx+10h]
lea rax,[rdx+1]
cmp rax,3
jae _PyLong_Add+3Eh
mov r9,qword ptr [r8+10h]
lea rax,[r9+1]
cmp rax,3
jae _PyLong_Add+3Eh
mov ecx,dword ptr [rcx+18h]
mov eax,dword ptr [r8+18h]
imul rcx,rdx
imul rax,r9
--> add *rcx,rax*
add rsp,28h
jmp _PyLong_FromSTwoDigits
push rdi
sub rsp,20h
lea rax,[rcx+5]
mov rdi,rcx
cmp rax,105h
ja _PyLong_FromSTwoDigits+2Fh
lea rax,[rcx+3FFFFFFFh]
cmp rax,7FFFFFFFh
jae _PyLong_FromSTwoDigits+48h
add rsp,20h
pop rdi
jmp _PyLong_FromMedium
mov qword ptr [rsp+10h],rbx
push rsi
sub rsp,20h
movsxd rsi,ecx
mov edx,20h
mov rcx,qword ptr [_PyObject]
call qword ptr [_PyObject+8h]
push rbx
sub rsp,20h
mov rbx,rdx
call pymalloc_alloc
sub rsp,28h
lea rax,[rdx-1]
cmp rax,1FFh
jbe pymalloc_alloc+17h
mov qword ptr [rsp+30h],rbx
mov qword ptr [rsp+38h],rsi
mov qword ptr [rsp+40h],rdi
lea edi,[rdx-1]
shr edi,4
mov qword ptr [rsp+20h],r14
lea r14,[__ImageBase]
lea eax,[rdi+rdi]
lea rsi,[rax*8+4C7120h]
mov rdx,qword ptr [rsi+r14]
mov rcx,qword ptr [rdx+10h]
cmp rdx,rcx
je pymalloc_alloc+9Fh
mov r9,qword ptr [rdx+8]
inc dword ptr [rdx]
mov rax,qword ptr [r9]
mov qword ptr [rdx+8],rax
test rax,rax
jne pymalloc_alloc+1C1h
mov r14,qword ptr [rsp+20h]
mov rax,r9
mov rdi,qword ptr [rsp+40h]
mov rsi,qword ptr [rsp+38h]
mov rbx,qword ptr [rsp+30h]
add rsp,28h
ret
test rax,rax
jne _PyObject_Malloc+46h
add rsp,20h
pop rbx
ret
mov rbx,rax
test rax,rax
jne _PyLong_FromMedium+4Ah
mov qword ptr [rsp+30h],rdi
mov eax,esi
cdq
mov rcx,rsi
sar rcx,3Fh
mov edi,eax
and rcx,0FFFFFFFFFFFFFFFEh
lea rax,[PyLong_Type]
xor edi,edx
mov qword ptr [rbx+8],rax
inc rcx
sub edi,edx
mov qword ptr [rbx+10h],rcx
test dword ptr [PyLong_Type+0A8h],200h
je _PyLong_FromMedium+88h
cmp dword ptr [_Py_tracemalloc_config+4h],0
je _PyLong_FromMedium+99h
mov dword ptr [rbx+18h],edi
mov rax,rbx
mov rdi,qword ptr [rsp+30h]
mov qword ptr [rbx],1
mov rbx,qword ptr [rsp+38h]
add rsp,20h
pop rsi
ret
mov rcx,rax
cmp rax,r14
jne binary_op1+0D9h
mov rbx,qword ptr [rsp+30h]
mov rbp,qword ptr [rsp+38h]
mov rsi,qword ptr [rsp+40h]
mov rdi,qword ptr [rsp+48h]
add rsp,20h
pop r14
ret
mov rcx,rax
lea rax,[_Py_NotImplementedStruct]
cmp rcx,rax
je PyNumber_Add+35h
mov rax,rcx
mov rbx,qword ptr [rsp+40h]
add rsp,30h
pop rdi
ret
sub qword ptr [rsi],1
mov r15,rax
jne _PyEval_EvalFrameDefault+58AFh
sub qword ptr [rdi],1
jne _PyEval_EvalFrameDefault+58C6h
mov qword ptr [r12-8],r15
test r15,r15
mov r15,qword ptr [rsp+30h]
je _PyEval_EvalFrameDefault+161h
add r14,2
jmp _PyEval_EvalFrameDefault+59FCh
@@davidgildegomezperez4364*C#/C++:*
lea
*Python:*
mov
add
jmp _PyEval_EvalFrameDefault
mov
lea
mov
sub
mov
mov
call
mov
push
sub
xor
mov
mov
call
mov
mov
mov
push
sub
mov
movsxd
mov
mov
mov
test
je
mov
mov
mov
cmp
je
xor
lea _Py_NotImplementedStruct
test
je
test
je
mov
mov
call
mov
test
je
mov
test
jne _PyLong_Add
sub
mov
mov
lea
cmp
jae _PyLong_Add
mov
lea
cmp
jae _PyLong_Add
mov
mov
imul
imul
→ add *rcx,rax*
add
jmp _PyLong_FromSTwoDigits
push
sub
lea
mov
cmp
ja _PyLong_FromSTwoDigits
lea
cmp
jae _PyLong_FromSTwoDigits
add
pop
jmp _PyLong_FromMedium
mov
push
sub
movsxd
mov
mov _PyObject
call _PyObject
push
sub
mov
call
sub
lea
cmp
jbe
mov
mov
mov
lea
shr
mov
lea
lea
lea
mov
mov
cmp
je
mov
inc
mov
mov
test
jne
mov
mov
mov
mov
mov
add
ret
test
jne _PyObject_Malloc
add
pop
ret
mov
test
jne _PyLong_FromMedium
mov
mov
cdq
mov
sar
mov
and
lea
xor
mov
inc
sub
mov
test
je _PyLong_FromMedium
cmp _Py_tracemalloc_config
je _PyLong_FromMedium
mov
mov
mov
mov
mov
add
pop
ret
mov
cmp
jne
mov
mov
mov
mov
add
pop
ret
mov
lea _Py_NotImplementedStruct
cmp
je
mov
mov
add
pop
ret
sub
mov
jne _PyEval_EvalFrameDefault
sub
jne _PyEval_EvalFrameDefault
mov
test
mov
je _PyEval_EvalFrameDefault
add
jmp _PyEval_EvalFrameDefault
I mean. I still like the idea of Lua as an interface for ameteur programmers to add recipes and stuff to the game like Factorio. Minecraft could've done with a lightweight interpreter/api for some simple entities and crafting systems.
Do you think Lua is better than a visual programming interface for recipe creation?
@@sasuke2910 Yes.
@@someonesomewhere3817 Do you actually think JITing Lua for game content would be faster than an in game visual editor directly saving data as game assets?
I think I'm being pretty clear about the suggestion, and it seems unfathomable that even C++ code could be faster than directly loading serialized data.
@@someonesomewhere3817 Well yeah it's way easier to throw in script hooks. There's a difference between "what's a cheap solution I can cobble together with freely available tools" and "what does a good solution to the problem look like". I prefer to focus on the second question.
@@someonesomewhere3817 I'm aware of Lua's simplicity, I've written game engines that use it as a scripting language.
I'm not sure what you mean by needing to reserialize, serializing data should be incredibly fast. If you have enormous amounts of data then you're going to be breaking it into chunks anyways, so just save the edited chunks. There's no performance to be gained, loading and saving game assets is part of the game, if that's slow then you probably need to fix it.
You'd almost always rather have a visual editor, you could use lua scripts to create a particle config or tilemap. But it'd be incredibly unproductive to specify a tilemap as text, it's better to have a visual editor where you can tweak stuff and serialize it.
You keep using phrases like "more convenient". It is convenient for programmers because it's basically plug and play. But it's inconvenient to modders and designers that want to create content. It's obviously too much work to make a visual editor for everything, but to say it's somehow better to not any seems silly.
The game I am writing uses a scripting language, in the form of WASI.
It's only for user-generated content, the two issues for why I am using it is because:
1. It's really hard to properly sandbox native code, yes I know there's a billion ways to do so but they always sacrifice something.
2. Cross-platform is really hard, by using WASI I can let users bundle a sandboxed multiplatform module that other users can safely execute.
I do honestly really hate the syntax and the garbage collectors of most scripting languages though, so even when I write modules I tend to do them in Rust haha.
Scripting languages might be the single biggest reason for losing my sanity as a programmer. For the 10 years of me writing code primarily in scripting languages, I've tried solving the problem of good design without compromising things like performance, readability AND MODULARITY. I'm starting to think this is not possible with scripting languages. Maybe scripting languages would solve problems of compiled languages only if they had zero-cost abstractions, idk...
My own personal opinion(borne out of experience, but just an opinion nonetheless) I beleive the reason why Scripting Languages aren't particularly suited for non-trivial projects is that they simply were not designed for such tasks, but because of their low barrier of entry, they are often selected for every task imaginable, and then as time goes on, the same people who where told Python or JavaScript weren't suited for in the first place then go on to try to make Python and JavaScript into a poor man's Java, C#, C++, etc without gaining any self awareness whatsoever.
@@thecollector6746 yet there is something to be said for usability, user base and ecosystem health. The cutting edge of web dev is what it is for a reason.
@@BusinessWolf1 That's fair. I think we are at a place now where we can achieve both via compiled languages that provide the option of "scripti-ness" like Groovy Kotlin, Scala, Go, and Rust, and their quasi derivatives like Odin, and Zig.
I think it's not so much a criticism on scripting language generally. This is more about scripting language in the context of game making. Basically it's a bad idea to use a different language for different teams to build the same program
It is near impossible to make a game using a single language tho. At least Cpu and Gpu (shaders and compute) will use different languages and if it is online or multiplayer the backend server program will often be different from the frontend.
@@esbensloth Yeah you're describing programming different services for a game. But even gl shader language forces you to enforce single responsibilities. Your code can get messy otherwise. For Lua scripting, it's basically a hook for existing gameplay code. The problem here is that you're using two languages to code the same mechanism at the same time, which can get messy. It's the same if you use GL and high order languages at the same time to draw the same shapes.
I've been working in a mainstream game studio for 2 years now and we use lua for gameplay code. I was apprehensive at first but honestly it is very convenient.
As with all scripting languages that I know of there IS a debugger, I don't know what John was talking about on that one.
The dynamic type system does sometimes cause type-related bugs but honestly its just a lot more convenient. Things that would be a 100 lines in c++ are only a few lines in lua because of a lack of boilerplate.
All the lua code hotreloads in 1 second making iteration times really quick.
The thing that John said about having to write hooks to c++ and back is true but the bulk of that work is just done once and any future hooks can be added in seconds.
We don't allow artists to write code, that is silly. We make editors that generate code for them.
The only real issue is performance. We don't jit our lua, we interpret it in the most basic way. That being said the number of times things have had to be rewritten in c++ for adequate performance I can count on one hand. 98% of the time lua does the job, 1% of the time we export 1 or 2 functions to c++ to avoid frequent memory allocations and the other 1% is a full refactoring in c++.
Something that John didn't mention is just how far you can take the flexibility of a dynamic language (I assume because he hasn't used one too much). Lua doesn't have a class system but we have made an in-house one that ia significantly more flexible than any class system in mainstream static languages. Classes frequently inherit more than 50 other classes and it works great. We have a system that automatically resolves complex inheritance of methods by calling them all and accumulating their result in some way.
The UI and many other systems are all in lua and are easy to work with.
There are many other nice things about lua that I can't fit inside a single youtube comment.
TL;DR There are many things that I agree with John about but scripting languages is not one of them.
Python codding time is like 1/10 of c++ codding. Python debuggers are better than c++ ones.
I don't think he'd disagree in the current landscape if you're trying to get stuff done fast, but you're suck thinking in current C++. There's nothing about compiled languages that mandate lots of boilerplate and very slow compile time with no hotloading. If C++ compiled and hotloaded in under 1sec would you still have that opinion?
Also, I wouldn't insult Jon, by implying that he hasn't worked extensively with Lua and been writing interpreters for 30+ years.
"Classes frequently inherit more than 50 other classes and it works great. We have a system that automatically resolves complex inheritance of methods by calling them all and accumulating their result in some way."
Oh my god that sounds like a nightmare to understand/debug. Reminds me of Tom + JDSL.
Okay so half of Jon takes that sligthly deviate his field all sound disastrous imho. The first five seconds of this clip is enough to cringe me
@@jzargowinterhold1942 We are talking about game development here; not your Python tutorial programs that you learned how to write reading Medium posts.
i think a scripting language has it's place in making a game extensible by giving the end user ability to add levels, missions, puzzles, etc. i wouldn't expect the end user to understand compilers and a complex language (not even one like lua) nor would i want to ship an entire compiler with the game. the scripting language should be something simple that hooks directly into the game by specific functionality.
I agree with this, but that's pretty much the only case in which a scripting language makes sense. Problem is that too often developers have used them with this notion that you could have "non programmers" doing scripting... as if scripting wasnt programming. It is, and like Jon says, you actually get more complexity, not less. Instead of one language, now you have two. Maintainability suffers. Debugging suffers. Optimization suffers. And you divide your programmers by language, so you segment your engineering effort and who can look at what code and who cant.
A user who can't figure out how to download a compiler shouldn't be modding a game to begin with.
Dlls do exist?
Edit: To clarify, you could probably implement a moding system that can load a user DLL.
@@zeejenkins making a DLL requires the end user to understand compilers and a complex language.
sure the user could use plugins, but that requires someone else to make the plugin.
@@dinobotpwnz Uh, depends on who? The world isn't about your idealistic views. Someone not knowing anything about programming should be able to make mods because that means potentially more content, potentially more enjoyment, potentially more profit for the company. Simple as that.
John is fascinating to listen to, but "it's a disaster, don't ever do it" feels narrow-minded. Interesting to hear another perspective, but ultimately I don't agree with him here. And how many of John Blow's games have mods of any kind? No one's managed to mod his games by hacking stuff onto his compiled code. He wants people to extend games by editing the compiled code? Fine, he should add a well defined modding interface or open-source his code. This entire video is devoid of any nuance. He compares unlike things as equivalent, like shipping a compiler vs shipping an embedded script engine. He suggests emacs would be better if you could configure it by editing the native code. But guess what? EMACS IS OPEN SOURCE AND YOU CAN ALREADY CONFIGURE IT BY EDITING THE C CODE AND RECOMPILING, AND NO ONE DOES. Has he seen the garbage C code for xwindows in the emacs source tree? Working with Elisp is way better. And he wholly ignores the problem of security, that any user can just hack stuff onto native code without creating security vulnerabilities. Want to extend a game? Just download a mod in the form of some random compiled C++ code from the internet, what could go wrong?. Scripting languages give you a sandboxed environment, at least to some extent. I could go on, but it seems John has some pretty strong opinions about scripting and is overly dismissive of the problems that scripting was created to solve.
Would you say these problems are intrinsic to compiled languages? Or could they theoretically be solved if all systems and components were written in language other than C++? Like Rust for instance?
@@sasuke2910 Some of the problems go away I guess, it's less likely that a user would introduce security vulnerabilities if an extension to a program was written in Rust for sure. But let's suppose that you download a natively-compiled extension from the internet, whether it's written in rust, or something else, there's always the risk that someone nefarious messed with the executable code after it was compiled. Extending an application by scripting, on the other hand, allows a program to run scripts in a, theoretically, hermetically sealed sandboxed environment, where scripts don't have access to memory, files on the computer, etc.. Furthermore, John Blow suggests that shipping a compiler with your application is comparable to shipping an embedded scripting language, which is not the case. Bundling rustc and llvm with a program is simply not the same as integrating Lua for example, a tiny 20,000 line extensively-tested scripting engine.
Overall, I was just arguing that John Blow dismisses scripting languages without providing a viable alternative. Allowing people to extend applications using native code isn't a viable solution if you only distribute closed-source programs, as John Blow does. Rust is a great language, but still not something that ordinary users can use to extend software. While safer than C++, Rust is still a complex systems language. Maybe Rust will replace C++, but scripting will still be useful and necessary.
But, now that basically all scripting languages compile to bytecode, the line between programming language and scripting language is extremely blurred. The performance issues aren't as severe as Blow suggests. Programming language vs scripting language isn't as meaningful a distinction as it was in 2005, when, according to Blow, people supposedly abandoned scripting languages (he doesn't cite data, of course), so I'm surprised that John makes such a big deal out of it. Providing only native code as a way to introduce extensions to a program assumes that it's perfectly fine to give user code access to an application's memory, but there are plenty of scenarios where, partly for security, you don't want to do this.
@@evanbowman4065 Well, if the OS was better sandboxed with applications not having access to the full disk, if applications could partition their memory space safely, and all applications shipped with header-file equivalents would all those problems not be solved?
If your main issue that he doesn't provide a current alternative, then I guess that's legitimate complaint, but he and his team have been working on a new compiler and toolchain for about 6 years now.
If you're limited on time/money and you only need your application to survive for 10 years, then making something with Lua makes a lot of sense. But this Jon is talking about the ideal design for the next generations of software.
@@sasuke2910 "Well, if the OS was better sandboxed with applications not having access to the full disk"
Yeah, that could be done, but don't expect clueless end-users to actually do it.
"if applications could partition their memory space safely"
If you're loading foreign code into a process, e.g. with dlopen or similar, how do you propose to partion memory space to prevent access? You could run code as separate processes and communicate via shared memory, but then you need to create a protocol for communicating with the application, and this sounds not altogether different than building a api, and in the video John Blow dismisses api endpoints for an application (script apis in particular) tedious and error prone. He seems to want a monolithic unified codebase, which implies loading user code into a single process, unless I'm missing something?
"If you're limited on time/money and you only need your application to survive for 10 years, then making something with Lua makes a lot of sense. But this Jon is talking about the ideal design for the next generations of software."
10 years is generous, most code doesn't even survive that long. But I see no reason why script extensions written in Lua or some other scripting language would survive less long than ones written in natively compiled languages. I've seen plenty of natively-compiled C executables that no longer run after OS upgrades, but ancient Java/C#/Lua/etc. programs still seem to run fine, as they're hosted on a VM. Would you care to explain why native code would survive past ten years while scripts would not?
@@evanbowman4065
"John Blow dismisses api endpoints for an application (script apis in particular)"
I think the key distinction is a "native" endpoint, not a scripting one. Native in this case meaning whatever the host language/ABI is.
"which implies loading user code into a single process, unless I'm missing something"
I don't think so, right now OS's isolate memory using processes, so it makes sense to use them if you can't isolate dlls in another way. Although it's not very hard to imagine a feature to flag memory for access from dlls.
"Would you care to explain why native code would survive past ten years while scripts would not?"
It's not about being native to the OS architecture, it's about being native to your own system. The extreme added complexity in your runtime environment and tooling cause systems to rot more quickly. For example, systems that require multiple debuggers rot faster than systems that can make use of a single unified debugger.
If your game is in Python (god forbid), extensions to it should come in the form of Python modules that interact with your existing api. If your game code is Lua dynamically loaded into the Unity C# CLR, that gets loaded from the Unity C++ framework. Then your whole toolchain and future is very shaky compared to unified projects where you just dump a million lines into rustc.
After being impressed by the AngelScript fork of UE5 and wanting to use AngelScript for all my UE5 stuff instead of C++, I came here to listen to the Devil's Advocate stating his case.
I think the most useful thing about scripting languages is to store some value that need to be changed frequently, and sometimes you need a data markup language like XML or JSON, but you want them to have some programming ability like simply generating a table, which is quite convenient. People think scripting language is bad, it's because some people decide to use it to do complicate things as Jonathan Blow mentions.
What about a language that can be compiled AND interpreted and has an interpreter that can run scripts that can change the state of already compiled and running programs written in that language?
So basically you'd get lots of iterations AND you'd be able to compile your scripts as object files if you want them as binaries
(Yes I'm thinking of Lisp)
You are thinking of Mun.
Late to the game here but was Jon running some kind of end-to-end testing on his game here? Seems like wouldn't be something he'd be super thrilled about doing, but I can't tell what else could be doing.
Integration tests != Unit tests
@@sasuke2910 Ah fair enough. I thought maybe that his spite towards testing was universal. Fun to know he's fond of those in particular.
@@sasuke2910 He's not against unit tests either. He's just against strict TDD
So I am not in the gaming industry, so when I think of scripting languages I probably think about it a bit differently than Jon. I use scripting languages when I am debugging problems that are larger than one specific corefile. When you have to gain quick insight from a lot of data (logs, counters, ...). When you need to pipe together some output from some small programs - that kind of stuff. For most other stuff I am really hesitant about using a dynamic / scripting language. I understand why people use them in build systems (since that problem looks like the same thing I mentioned before - connecting together the output of a few smaller programs) but to me it feels really scary how shaky everything is. If you need something to last long you should build it with robust parts. My small observability one liners only live until I understand/solve that specific issue. I only use a dynamic language because atleast it is saner than Bash, and in a perfect world these small programs would get replaced by some real piece of code that would provide real and more ergonomic observability of our system.
(btw, I know it is an old clip and I have already commented here ages ago - but I like coming back to these clips and reviewing how I feel about them)
can you mention an example of when using a scriping language might be a bad idea? also "If you need something to last long you should build it with robust parts" can you explain more, i can see a lot of companies using Javascript/Typescript (scriping language) to create desktop apps and web apps, for example VS Code was made using Electron.JS and for me its been great to write programs in.
It took me 2 secs to go from rust to C. Then as soon as i try to do smtg in lua its sooo painful because of unintuitive syntax, other abstractions etc. If i wanted a specialised language for specialised tasks then fine, script me. But for anyhting general C is sooo easy
ive heard the refrain often that with a scripting language you dont have a debugger and im confused what everyone means by that? you *can* write a debugger for a bytecode vm
You can, but Lua and many other systems don't ship with one because it kinda needs to be custom to properly interact with your own engine code. The time and complexity cost of building/maintaining/using a internal debugger and toolchain is almost certainly higher than building an "in-game editor" equivalent that serialized level data directly.
There is one use for scripting languages, writing scripts, as in dialogue or story. While you can use ini or other formats it is more convenient to write branching dialogue with a more code like syntax, that said you don’t need a full language. Logical storage format I suppose.
Your right. That is what I did for my dialogue tool for Unreal.
This isn't programming, this is data entry. We really should start seperating the two
That's more a task for a DSL (domain specific language). Which is comparable to the visual scripting he talks about in the video: they're limited so there's less room to do stupid things and less complexity that may degrade performance.
I feeling like to making my own compiler after watching this. LOL
Just do like terry, and make your own OS too...
Or even better, your own computer and parts ... Your own tools, like the guy of that channel doing a iron knife from the mud, wood and jungle...
I hear C compiler is easy to make. Why not give it a try?
Emacs would be so much better if it were simply a Common Lisp library and a standard implementation, e.g. SBCL. It would suddenly be
- Fully compiled.
- Easy to debug.
- Fast.
Theres a reason why you separate performance-critical simulation things and gameplay things. C++ has massive compilation times, especially for things like large games with tons of external libraries. You need to quickly iterate these things to get a functioning product quickly.
Also languages generally aren't flat out interpreted, they're put into more efficient JIT bytecode first. C#, which *does* have debugging and type checking, I count as a scripting language that compiles to JIT bytecode.
This whole take is confusing.
He is extremely biased here, since he has not worked in a big game studio... Generally, there are gameplay programmers that work on the scripting, and engine programmers that work on the C++ codebase. Yes, it's a lot more work for the engine programmers to support the script language, but it pays off during the gameplay testing and codding. You can generally hire people with lower language understanding, or even give the script to the designers. It's hard to find competent C++ programmers for everything. It's good idea to not mix the languages, since scripting requires completely different approach then wring in C++. Yes, there is extra work, but the engine lifecycle is much bigger then the game lifecycle. So the investment pays off. It's far from a "failed paradigm". But there is a right way to do it, and many wrong ways. It's like saying - JavaScript failed, which is absurd. It's something very handy, but yes, it can also get very messy if you are doing it wrong.
Didn't he work for 10 years at game companies before going at it alone?
@@insidiousmaximusno. He dropped out of college. Started his own indie groups and they failed then made braid. Dude has a code god complex. He’s smart but he’s very biased towards his own opinions on things. He knows how things work but of course he always thinks he’s correct.
@@Calypso694He worked on games like Deus Ex and Theif as a contractor. He has seen his fair share of big companies as well.
@@torgnyandersson403 ah thanks for the info. Still a dick.
@@Calypso694he mr jonathan blow has ported game to setupbox or whatever you call them alone in his late 20s or early 30s and for that project he probably used server for the data streaming and the box itself as a renderer, then input handling and other stuff, this mad man know his stuff (You know nvidia streaming, Netflix game streaming, ps4 ps5 game streaming, probably xbox streaming and amazon game streaming is also a thing now). Learn to judge people talents and credibility in specific fields outside of politics. And i also dont quite agree/ understand his takes. I also dont get yet another new lang jai from blow either, Does he care well i believe he do but i cant fully grasp / understand. And wish himnGood luck.
I kinda love working with LÖVE2D and LÖVR, but if the project gets big enough, refactoring does become a pain. Still, seems WoW used Lua in a pretty decent way for UI plug-ins, wonder what Jon's opinion is on that. Also, Warcraft 3 and Starcraft 2 have used Lua to script AI and such, if I am not mistaken. Again, seems to me a pretty decent approach, allowed easier level/scenario creation by 3rd parties it seems.
I'm an addon developer for wow (AuraBreak Notify and others) and I would have had a much easier time with static types
But relaunching the game for every change? Reconnecting? Relogging, loading? Fuck that, Jonathan
I dunno. Naughty Dog, Valve, Blizzard and many other studios seems to be doing pretty well with scripting languages. Most of their titles are purely written in some form of scripting language, whether it being Lisp (Naughty Dog), Squirrel (Valve), Statescript (Blizzard)... you name it.
I think the points the Jon brings up are very valid. But some of the pitfalls he mentions, such as designers writing bad code, can be solved with teaching, communication, team management and documentation. Things you should have in any company, even if you don't use scripting languages for your games. Being able to iterate on design choices quickly is what can make a game better, because decisions can be made in less time.
Regarding speed; sure it's not as quick as your inline assembly code which runs quicker than any compiler can fathom. But there are ways, using static analysis, to provide information about complexity and warn about it. Depending on your scripting language of choice, you can introduce linting and formatters which can help clean up your diffs for the team to review.
I once worked with multiple designers who had been briefed about code commit guidelines from the company. They usually write the initial code and commit it once and never touch, fix or refactor the code ever again. As long as it works, and looks the way they want it to, its good enough - which causes hassles down the line. Its not about them writing bad code, since they can fix that problem if they give it enough attention, its usually the attention they give it - the good old "if it works, it works"
@@araa5184 thats a management problem in the company. This doesn't only apply to code.
@@dealloc maybe it is a management problem, but that's how policies prohibiting designers from touching code get implemented. Same as how security departments aren't allowed to touch or look at code. Well, in most of the companies in my country that is.
You have no idea what you're talking about. None of these titles are "purely" written in a scripting language, they all use a mix of compiled languages and a bit of scripting languages.
@@michaelzomsuv3631 There's a distinction between gameplay (99% of what you do in a game) and engine-most gameplay is written in a scripting language which uses underlying systems. Everything from AI, dialogue, missions, cut scenes, etc. can be executed effectively through scripting, whether it being high-level (i.e. node graphs) or not (code).
what does emacs 4:50 has to do with all this?
Emacs is 100% Lisp, any customization will have to be done in Lisp... For a C programmer that must be very painful :) IMO his development style would probably be served best by vanilla vim, tbh.
@@berkano_plays I thought Blow hated editors that don't have a sufficient "W" per minute...
@@berkano_plays pedantic correction: Emacs itself is almost entirely C, including a lisp interpreter. It's still customized and extended using lisp however, similar to the games jon's comparing it to.
Why not do the Id Software thing and do both? Id Software, for Quake III, used C as the scripting language! Thing is, Id Software implemented a compiler that outputs stack-based bytecode. Perhaps in this case, a regular C interpreter reading source code would be more beneficial.
Great idea, but while we're at it, why not precompile it? And why not C++? Same reason, the compiler and toolchain are heinously complicated. But this does seem like the general solution. We just need a nicer language that compiles faster, is less memory error prone, has a simpler toolchain, and strong metaprogramming facilities.
@@sasuke2910 that's not a bad idea, problem is that it makes modding more difficult. More complex the programming language, the more people you turn away.
Why not C++? Because C++ is way more complex than C, especially when doing game logic, and its simplicity makes C alot easier to debug compared to C++.
IMO, the perfect language would've been Golang but if only Golang didn't have trash ABI to where it's really slow to interface with C libraries.
Toolchain for using a C interpreter isn't hard either. If I had my own game company + active game project, I'd most likely pick the latest Python or Lua for scripting since they're both very widespread. I'd lean towards Python since that's used alot more than Lua IMO.
C# is a scripting language for Unity
if you're going to be compiling to machine code to extend an application you may as well compile to a dynamically loaded library using a separately installed compiler but with headers included in the distribution.
I do think luaJIT is a pretty good option if you want to have a simple 'scripting language' for extension but also 'compiled'
Scripting languages make sense in meta programming, when you want to generate code files from a config file. CMake like software, Automated Testing, source control, or just to write things like switch cases faster, linting rules, compiler flags, turning lists into enums or constants or combining sections of text shuffling them together. Cutscenes with animated dialogue should often get a scripting language that lets you stylize text color, control the camera, character expressions, etc...
While performance, accuracy and strictness are important aspects, he misses the fact that moddable games become WAY more popular than non moddable ones.
Terraria, Minecraft, Warcraft 3, World of Warcraft (UI, mostly), Skyrim, etc. Massively popular *also* because they're moddable.
Sometimes you just have different goals.
Consider that Counter Strike and Dota are both mods of games that do not have scripting systems, scripting is not a requirement for modding.
Also, isn't Minecraft a counter example? Most Minecraft mods are implemented in Java, the same language as Minecraft, not a separate scripting language.
@@화성-v4g > it’s written in java which you can easily decompile and modify it’s code.
That wouldn't be a scripting language... "Scripting language" in this context means using a **different** language than what was originally used to create the game.
"Scripting" does not mean "interpreted" or "non-C++".
@@화성-v4g Maybe spend some time researching what these terms mean before trying to have a conversation about them.
You really don't know even the basics of what you're talking about if you think The Witness and Braid didn't require a powerful machine to run when they were released.
You don't need scripting languages for things to be moddable.
@@sasuke2910could just use C++ and have the engine load libraries (.dll or .so) as and you have the benefit of high performance code and installable mods
I enjoy Jon's opinions, but I've made several games that run fine in JavaScript with very few bugs 🤷♂
I think scripting lnaguages work if you are going to make an addon/workshop feature
I just see scripting languages as being useful for easy gameplay mod support. Granted you could hot reload assemblies in C# for example, but then comes the challenge of sandboxing out system critical libraries so mod developers can't easily make malware.
It comes at the cost of having to deal with memory management and more challenging debugging, but I can see why it still exists.
normally i think jblow mostly talks nonsense but this snippet is so true and makes me miserable day in day out, scripting is such a pandoras box that has caused nothing but trouble on projects i've been on.
hard disagree on the visual scripting take though, i'll let it go cause it was relatively new when this clip was made but visual scripting has become as bloated and load bearing as ye olde scripts were, is just as annoying to debug and has exactly the same problems as scripting languages do.
I disagree with jon here. If done well and you have a solid and fast API, scripting languages can be monumentally helpful in developing your game even if it's a standalone game with a bare bones engine. It allows for extremely fast iteration, it abstracts away game logic from the engine which is crucial for debugging and code maintenance and it allows you to actually focus on the GAME development rather that messy c++ engine code
Its so convenient to have scripting languages along with engine.
There's nothing wrong with initially developnig your game using a scripting language. As long as there's that final step of saying "now that the logic has been prototyped, we will convert it back to a language that isn't slow and hackish".
@@dinobotpwnz if you are willing to go through all that trouble for an extra 10fps, kodus to you.
lol, i came here after watching a whole gdc talk by naughty dog on the combat system of the original the last of us game, which, news flash, was built completely using scripting, written by designers, not programmers
Jon Blow probably thinks the folks at Naughty Dog aren't "serious programmers" for not using "real" (seriously, wtf?) languages
Thank you so much for your comment. Not sure why Jon Blow is so opinionated and can't acknowledge technical progress...
He's just a boomer who doesn't have any experience working on anything modern, I don't doubt his skills but his mindset is something else.
@@ducksoop.x He’s no boomer, which is easy to find if you bothered.
Besides, just because X does something, doesn’t make it the wisest choice. Just because X doesn’t do it doesn’t have anything different: they both have tradeoffs, and the question is, what tradeoffs are you willing and able to make? Context matters.
I was with him until he mentioned visual scripting. It's everything he complained about but worse. Blueprints in unreal on large projects turns into an absolute shitshow. It's just code except you can't search it, tracking it with version control is annoying, it's binary so it's unmergable (you can kind of do it visually but it's an absolute pain, and merging across diverging branches is literally impossible). The last game I shipped had networking code implemented in blueprints. The fact that any of that is the case absolutely blew my mind in the worst way possible. Oh, and it runs like absolute shit. The exact same naiive implementation in c++ runs literally 10 orders of magnitude faster in almost every case, but since it's a proper language there's all sorts of better tricks you can do, too.
Do you mind me asking how it would work in the animations in Unreal? I am currently writing a game in Unreal and am using blueprints with the given knowledge that at some point I will have to rewrite each blueprint in C++ and have started already.
My only question is does your same viewpoint apply to animations? Like are you advocating for rewriting the animation state machines etc. in C++? Cause I don't know if I am willing to do that part
networking code in blue prints is crazy
I mean, I think that's a simple case of the feature being mis-used. It's possible to shoot yourself in the foot with every new tool that is created, that doesn't mean it's necessarily bad. I think scripting languages or scripting-like layers work well when they are a thin flexible layer built on top of a robust core. Networking should be part of the core, not the scripting layer. And similarly, I think if you've gotten to the point where you want to re-use scripting-layer code, then the shared parts should probably be moved to the core instead.
I really disagree with a lot of what he says - it's hard not to be inflammatory toward him. Even when he makes a good point, it's buried in so much bull, it's ultimately pointless.
Edit: OK, after a Socratic discussion with a friend, I've come to the conclusion that my reaction might be too strong - he's basically dissing on something that I've spent a lot of time developing, so it hits a little too hard.
2:14
YOU KNOW WHO ELSE TENDS TO HAVE SEDUCTIVE PROPERTIES
MY MOM!
🤨
I completely agree with Jon that scripting language can become bug prone and its slow. For my perspective the num of reasons to embed scripting language in the engine could be:
- To be productive (i.e Do a hot reload within the engine running).
- As Interface to only allow a set of functions in the engine.
You can make hot reload work in a compiled language with a little bit of work (not much work at all in the scope of a game). What it enables is easy access for modders with limited skillsets, like kids, which is awesome.
@@Jutastre Thanks for this response. I'm thinking about compile and reload dlls at runtime but I'm not sure if it could be consistent.
First of all, scripting languages are used so game developers don't have to go through the pain of writing their entire game in C++ (which is already a messy complex language to work with). It also lessens development time, and the performance really depends on how you implement the code so that it doesn't get affected by things like garbage collection. It's also possible to write an entire game in C++, but have completely bad performance because of bad coding style.
Second of all, how do you define a "real programming language"? I define a programming language as one that solves problems and expresses a solution in which a computer system can understand and execute. If your definition of a "real" programming language is interfacing with the computer hardware, then the only "real" programming language is Assembly. Assembly is the only language where it allows users to completely interact with machine instructions, complete manipulation of memory, etc. Compiled languages such as C and C++ only generate machine code, but you never actually interface, nor completely control the code actually generated by the C/C++ compiler.
EDIT: Also, just a history lesson, C++ wasn't always the "lingua franca" of video gaming. Back then, Assembly and C (though in many engines, C was mainly used for scripting while the entire engine was made in Assembly) were pretty much the dominant languages of video gaming until games got more complex and hardware got more advanced, then C++ started becoming dominant, especially around 2005. After that, C++ became hard to work with because of its complexity, thus game development took longer. That's why scripting languages are used in the first place, to ease development time.
The assumption here is that the only alternative is to write their entire game in C++ when that patently isn't true. Java, C#, and D(Remedy Games are among the very few outfits that have used D in their games) are all compiled, strongly typed languages that are demonstrably and significantly fasters than scripting languages and prehaps more importantly...THEY SCALE
but still, even though C++ became more used to develop games, it was still a "C flavoured C++" most of the time.
@@thecollector6746 but they all use annoying OOP.
@@trex511ft The entire reason why the game dev industry switched en masse from C to C++ was exactly because C++ had the OOP features C lacked.
@@thecollector6746 yes, but unlike Java, C++ doesn't force you to OOP. It is still mostly procedure, unless the person is using Unreal or Unity. So there is a difference between using classes and having everything being a class.
Or, the thinking goes "We'll give them a scripting interface so they can customize it to suit their tastes" except they never do know what it is they want and they want YOU to customize it, not them. So it ends up making more work for you that's mostly not needed.
Scripting languages were a great way games in the 2000-2010s allowed people to create custom content, Gmod being a prime example. Clearly this is different from creating and shipping a game.
I find it funny that if the problem is compilers are slow, the solution was to make a whole other slow language instead of unfucking the compiler.
🤔 can a workflow engine be considered as a sort of scripting language interpreter?
Personally I wouldnt mind a scripting language to manage things like item/enemy placements or game events, but for ai code, gameplay code etc I definitely prefer to write It in a "real" programming language.
Lua is great, what you talking bout willis
What about writing mods then?
meanwhile bash and powershell hold up the world
i like engines with scripting languages for very, VERY simple prototypes, but anything beyond that is just a huge mess, sometimes i work in games with very non-trivial mechanics, that are just simpler to quickly prototype if i have a semi-solid foundation for rendering stuff in a 3d scene.
Where does C# with Unity and Godot fit in ?
Things would be a lot simpler if Unity was written in C# and Godot in Python/GDScript. Hybrid systems introduce many complexities.
Late to the party, but this is tricky. Having the engine built on a different language introduces a lot of complexity for both the Unity team and for us. The Unity team has to make sure every new feature plays nice with the C++ editor/player, while also making sure nothing breaks or bugs out on the C# side. We, on the other hand, have to deal with the technical quirks that comes with that interop, from writing lots of boiler plate to compensate for stuff like poor encapsulation (thanks to serialization), a lack of constructors (since the engine has to create our objects), and to jumping through hoops to make sure we don't over or under use the main thread (since the update loops is single threaded on the C++ side).
On the other hand, C# is a powerful full on industry language, and since C# can be JIT compiled, we don't have to compile the entire engine or editor every time we modify our game logic, and with the IL2CPP compiler, it all compiles down to C++ in the final build when we do so C# performance isn't a concern.
So its a give and take with Unity.
GOTY 2024 was made in Lua
Scripting languages are fine, for the reasons he states as the "why" at the beginning. Currently, the best reason for scripting languages is to allow community modding, but the original reasons are still valid because compile times can still be onerous.
Most of the reasons he gives against scripting languages still apply to the game without the scripting language, and as always developer discipline is critical to achieving best performance.
So Unity named C# programs as "scripting".
With the way C# is structured we really shouldn't be calling it a scripting language. I only ever heard it being called scripting back in college when we were taught server-side scripting in C# with ASP. NET. and my professors called C# files as scripts, but I think that's from the legacy of programming anything server-side being called "scripting".
because it is. any language can be a scripting language it only depends on the context. everyone in here is missing the point
scripting languages CAN be fast, it just needs to be very well optimized. also, what is he talking about by "no debuggers"?? what language doesn't have a debugger?
What engine is he talking about at the beginning?
Godot I'm pretty sure.
@@sasuke2910 I mean, the scripting language is optional, just recommended.
The utter disregard for the end user is absurd. I can't just send them my code if my engine is encumbered by third-party middleware like so many engines are.
The difference between Blows take in this video and PirateSoftwares Thor praising Hades 2 for its use of well commented Lua for all the game logic is crazy. Gotta say I agree more with Thor.
What abour code injection? I mean you compile your objects and then the engine load this obj and inject it into the "gameplay zone code"
Malware.
@@profande Nop is not malware is game loading
Are unmanaged languages the only legitimate kind of language to build games with according to this guy or did I misunderstand?
You misunderstood.
He's not talking about legitimacy, but efficiency and reducing programming errors.
" if I use C++ then I have to wait an eternity for recompiles " "I don't know anything about C++; because if I did I would be aware that you don't have to recompile the entire source, and my programming skills are questionable to begin with because I just admitted that I don't compile in increments because I don't test modifications as I make them"
the xi text editor allows extensions in any language using ipc
aaand it's dead
xi jingping xiao puao sisidlo
wtf hahaha
I've been saying this ever since I first encountered a scripting language, honestly
#honest 🤣
I was using lua on my engine. Not any more. Next PR will remove that HAHAHAHAH
Embedding a scripting language is very Unixy but a terrible idea if you have to cross the programmer / artist barrier. Don't make programmers do art and don't make artists write code. It's just not the way they're wired. Bad results inevitably ensue. "The Art of Unix Programming" is by programmers, for programmers. Visual scripting is good for artists and gameplay programmers. You can have issues with performance. I'd treat it as a prototyping tool.
And yet Hades and Hades 2 - both that were almost entirely scripted in Lua - have come out as critically acclaimed games in a shorter span than The Witness took to develop.
I get that “your art team can now script games with this too!” is bad, since it’s still under the same software design scrutinies as other pieces of software in the game’s codebase. But scripting languages are extremely powerful on the right hands and on the right situations.
Why is he using emacs if he doesn't like the tool?
He'd probably say "There's nothing better enough to be worth switching to."
Welcome to 3 hour long Unreal Engine 4.26 game builds outputting 300GB of binary data. And assets are all binary because why should someone actually want to edit assets outside of a fullblown GUI game editor with thousands of buttons 😂
Which is why Godot is winning
scripting languages are more useful for mods.
easier to implement and let other people interface with without exposing the whole code base.
if its slow, that's for the mod developer to deal with.
I see a lot of C# comments, probably because Unity uses it. But how often is Unity used for triple A games? UE4 is much more prevalent in AAA and only provides (hot reloadable) C++ and Blueprint. I think the whole flow of creating the engine in C++ and hooking up Mono is only done because computers have gotten very fast and we can get away with unoptimized solutions.
I mean. A lot of popular titles have used Unity and been very successful. While it's true most AAA games don't, that doesn't mean popular games don't
Not sure why everything is measured in terms of how many "A"s they have. Plenty of games, created by independent studios, have been made (written in C# either XNA or Unity) that feels like AAA. AAA titles is not a good measurement for how good an engine is, nor even how good those games and studios are.
Unreal is super annoying to learn for me due to blueprints and the elitist community. I learned Unity super easily because of the amazing documentation and the plentiful tutorials that still mostly work.
Unreal I find it hard to find good tutorials in c++ because most are in blueprints (why even use unreal if you are using blueprints?) and the documentation is laughable compared to Unity's.
I'd say about 60-70% of my steam library games are made with Unity and many of them are very popular and large games
I think, main benefit of scripting languages that they allows players make mods to the games. Mods often improve base game experience (see Paradox Games, Warcraft 3, Skyrim or Dwarf Fortress for examples). With scripting languages is it even possible for players to fix bugs themselves (for example, there is a bugfix mods for Dragon Age Origins that fix combat, AI and/or quests).
If you ask players to use write a DLL in some serious programming language to make mod, that would not happen.
I don't really think blueprint/unity's node scripting thing are good as scripting languages because blueprint exposes a ton of engine stuff by default that you can't turn off, and unity's thing exposes everything that's already exposed to C#
Being able to know everything designer will interact with in advance is imo a pretty important part of scripting languages and those don't tick that checkmark
Is he a big proponent of the Suckless software community?
There's a lot of stuff Jon says is outright bad which is actually a trade-off. Scripting languages can be worthwhile to use depending on your experience and use-case, but they aren't very useful at all for someone like Jon for all the reasons he listed.
i disagree.. you don't use scripting language to code your gameplay or whatever. you need to use scripting languages to create content. core mechanics can remain in the core, be it C++ or any other language. the content is really entity scripts, world events, interactions, and all things that won't be executed constantly, most likely just once
"Serious game developers". Says the guy that published a small indie game.
Scripting Languages are good for Game Modding in my opinion. For example Garry's Mod has scripting done PERFECTLY, it has made many people start and learn how to code. It is also easy to use and more fun. I somewhat agree that if a game is entirely made in a Scripting Language it is gonna be very slow but for modding it has a positive effect.
The point is, you could do the same and just not use the scripting language, just use the real language, like how gmod was made. It's an HL2 mod, but wasn't made with scripting, same with Portal and Counter-Strike.
@@sasuke2910 yes but scripting adds ease of use. Source engine takes AGES to compile and it would mean that you will have to remake a game for modding... but Lua here saves the day.
@@alphenex8974 Compiling being slow is a fixable problem. I'm not sure what you mean by needing to "remake a game", you can use the same api that any Lua system uses.
@@sasuke2910 Yes, stuff can escape from sandbox environments, but can't a c/c++ DLL have malicious stuff implemented easily? Putting that responsibility on the players and not providing a safer way of modding feels treachery to your players imo.
@@kulkalkul It might be slightly easier, but any sufficiently advanced mod system will be able to exploit or crash the host game in some way.
Sandboxing helps, but doesn't require you use two different languages. You can sandbox C++, C#, or whatever your main language is.
I mean, Emacs Lisp has a full blown IDE, debugger and more built right into it. I don't think Blow is correct on the difficulty on debugging scripting languages.
I kinda disagree. A well-made scripting language can save you a lot of development time. Not every scripting language is tied to an interpreter or virtual machine, scripting languages can be compiled to machine code as well. The real problem I see is that scripting languages in almost general is the lack of a smarter object/class creation system, like an embedded object pooling or something like that, to prevent users from allocating stuff during runtime.
For gameplay I couldn't imagine using a scripting language, but for cutscenes, a scripting language is much better than using some tool provided by an engine for making cutscenes, you can go way way faster.
I've been coding for half my life and I don't even know what makes a language a scripting language, I just assume the ones with script on the end are scripting languages
It is not about programming language it's about how it's used, for example Javascript is used to manipulate browser objects so it's used as a scripting language in that context, VBA is used to manipulate Word, Excell, AutoCad and so on, so VBA is used a scripting language.
Most of early implementation of programming languages that wear designed to be used for scripting like Javascript are built as an interpreters but recent versions are usually generate machine code, but due to semantics of Javascript it may be harder to produce machine instructions, for example function add(a, b) { return a + b; } may operate on strings, numbers, dates so compiler may need to add checks to ensure that compiled block operates with correct types.
Its a scripting language if its interpreted and not compiled. Simple.
@@noahfletcher3019 this assumes I know the difference between interpretation and compilation lol
@@VolcanicPenguin Haha, you know what? I was gonna say something about the fact that you've been coding half your life and you don't know that. But, it's refreshing to see programmers who don't pretend like they know everything. Anyways, I guess the main difference is, compiled code is turned into machine code whereas scripted code is fed into a sort of virtual machine that performs all the instructions. That's a very brief overview but I definitely recommend you read about it, it's an interesting topic.
@@noahfletcher3019 That can be a problematic distinction because even interpreted languages often have preprocessing, compilation to bytecode etc. going on in the background to improve performance.
How I understand it "scripting language" means it's used as a secondary language for configuration or extensions for some software that doesn't require recompiling the whole thing. I think it makes sense in many situations, but Jonathan Blow is also correct in that properly implementing a scripting language in an engine may not be worth the trouble.
Waiting 15 minutes for your game to build? Oh baby. I work in AAA game development. For some changes my end-to-end compile/build time is 4 hours. Fucking shoot me.
whats a scripting language? like python, bash/ powershell, lua, lisp, gdscript; what else?
is mojo, julia, kotlin, zig, octave a scripting lang?
why not? just 'cz of type checking?
I imagine he means anything that's not ahead-of-time compiled?..
It's not black and white. It's a combination of features, and every language makes different choices on the tradeoffs. You could say a scripting language is really just anything people happen to use to write scripts rather than applications. But then there isn't a hard line between a script and an application.
Programmers will always disagree on programming. However he has, produced and most importantly SHIPPED very successful games. The result always outways the method. Many ways to do something but shipping far outweighs any particular method or paradugm
He does not know about Java?
I have a friend who plays a wargame called "Dominions 5" and writes extensive mods using their scripting language, it's quite impressive and people seem to be happy with it.
Personally if I had to build a (2d) game with a non-programmer and that this person needed to be able to add content, I'd give them the possibility to add stuff using json or something like that but it would be really constrained.
Making a GUI tool would better their own "DX" but the constraints would be the same... It's not scripting per say because I could very well compile everything once we ship a beta/production build and keep it as "scripts" only for the dev build... Just talking outta my ass, tho.
Blow would be interesting in a debate, but he's too one-sided to do interesting monologues.
"...too one sided...", I think that's what it means to have an opinion on something. 😂
"one sided" - I think this is exactly what interesting means. You seem to confuse interesting with pleasant.
"today in the year 2020" *uploaded jun 2019*
...The problem with Starfield.
Ask Square Enix how relying on scripting for FF14 worked out for them.
The story ultimately has a happy ending, but that's because they dumped a ton of money into totally rewriting the entire game to relaunch it while keeping the old one patched enough for ppl to play for 2 years.
Is C# ok??
www.quora.com/Why-do-game-companies-all-use-C++-rather-than-say-Lua-or-Java-Are-they-shifting-away-from-C++
Seems like we are all scrubs. This would explain however why I'm running into performance issues coding in C#. Basically scripting laguages have automated garbage collectors. You cant control the gc so you get unpredictable performance spikes. While in C++ there is no gc - so no unpredictable behaviour. But you have to take control of the lifetime of your object in memory yourself.
It seems you only can code in c# when using unity. Sooo i'll stay with c# for a while i guess.
@Scholar of the first sin I promise you that there is nothing fundamentally different between a Python "interpreter" and a Java or C# "virtual machine". You are just wrong trying to see C# as a compiled language.
Everything you just said is plain wrong and it shows you know nothing about the CLR.
@@nandoflorestan the plain ignorance of not explaining yourself is showing. @scholar please don't listen to this fool. Here is a better way of explaining it cs.stackexchange.com/questions/23951/are-java-and-c-also-purely-interpreted-languages
@@nandoflorestan moron
If you use javascript these days though, granted your rendering isn't heavy, you can deploy to pretty much everything very easy using an embedded browser. With that said, for 3D games, heavy rendering, and consoles that's no good.
The way I see it, you're gonna need a DSL either way, so might as well make it a part of the engine.
I mean, eventually, every serious game will need to represent some _ongoing process_ that some object is performing, which has to be _pausable at any moment_ and _persistable to a save file._ If you have a DSL that can do all that - that's already a scripting language.
I'm not sure I buy this. The things that people have made with Lua are phenomenal. I've done Lua game dev for years as a hobby and haven't had a big issue with it. Saying that Blueprints works but scripting languages dont work just sounds like he's out of touch. I'm not willing to listen to someone who says Lua is "not a real programming language." Lua has created some of the most easily maintainable libraries I have ever laid eyes on.
Imagine how good would Emacs be if it didn't use a toy language like ELisp for everything.
What do you consider the deficiencies of Emacs Lisp to be then?
it should have adopted VimScript