
NetDuke32 - Enhanced Duke3D Netplay! "Netplay-centric EDuke32 fork, the successor to EDuke32-OldMP."
#91 Posted 11 October 2024 - 10:32 PM
I think some of us who spent a lot of time making build stuff are closer to your situation than we would care to admit. The years do indeed just seem to burn away. However, I do think it's time better spent than on a lot of other things, like gambling or talking with stupid people.
#92 Posted 11 October 2024 - 11:22 PM
Danukem, on 11 October 2024 - 10:32 PM, said:
I think some of us who spent a lot of time making build stuff are closer to your situation than we would care to admit. The years do indeed just seem to burn away. However, I do think it's time better spent than on a lot of other things, like gambling or talking with stupid people.
Well, my main remaining goals were:
- Figure out the last remaining sync issues (seems to be compiler-specific fuckery going on here with the collision code. No idea why it happens)
- Figure out why the netcode breaks down when the player count rises above 6 or so. (This has been the most frustrating thing so far for me)
- Move all networking code over to ENet.
- Remove all assumptions about there only being one player per client (ie. multiple local players)
- Implement rollback netcode and in-game joining.
- Fix controller support.
- Implement local splitscreen support.
- Finish my work on implementing AngelScript support.
I have started a number of these things with varying amounts of progress, but stopped due to burnout. At this point, I don't even remember where I left off with some of these, so it's going to take a lot of effort to pick them back up. Anyone can look at my branches on voidpoint.io and probably get an idea of where I was going with these if they took the time to study them, I suppose.
#93 Posted 12 October 2024 - 10:10 AM
While obviously not the same situation, I may add the following point. As I also wrote about a different project of mine last September, it might not necessarily imply I won't ever contribute code to the project in question again, but my priorities are basically elsewhere.
#94 Posted 13 October 2024 - 10:04 AM
I do however see the point of diminishing returns and especially when it comes to the audience reach of today.. Even 10 years ago Duke was ancient and the next 10 years kind of flew by since. Cool things will still happen but motivation and let alone justification is harder to come by. "Lameduke" is two months away from being 30 years old now. That's almost 10 years of world tour.
Working on Fury for so many years resulted in thing I can be proud about, while having contributions you are a part of. I got burned out as hell on that but all the more I can respect what you've done over the years with tedium like this. Build is a piece of shit engine where it's always a toxic relationship with a dose of stockholm syndrome. I know I'll always be crawling back for more one day. Thanks for the stuff you've done once again.
#95 Posted 13 October 2024 - 12:31 PM
oasiz, on 13 October 2024 - 10:04 AM, said:
100% correct
In fact I literally used that expression myself in a discord post when working on AA just 2 days ago:
To me it looks kinda cool, like the chopper is damaged and you get to see inside of it through the battle damage. But that's probably just cope due to build engine stockholm syndrome
#96 Posted 23 October 2024 - 01:44 PM
But 2 questions:
- Will you make it support Duke Nukem 3D: 20th Anniversary World Tour? You can utilize Stopgap. Or at least make it natively support the patch as the Atomic version like in regular EDuke32.
- When testing Dunebots in E1L1 they get immediately stuck on the roof. In Cooperative mode they even shoot each other despite having no enemies around. Can you fix either or both?
Thanks!
This post has been edited by lwc: 23 October 2024 - 01:46 PM
#97 Posted 23 October 2024 - 02:17 PM
lwc, on 23 October 2024 - 01:44 PM, said:
But 2 questions:
- Will you make it support Duke Nukem 3D: 20th Anniversary World Tour? You can utilize Stopgap. Or at least make it natively support the patch as the Atomic version like in regular EDuke32.
- When testing Dunebots in E1L1 they get immediately stuck on the roof. In Cooperative mode they even shoot each other despite having no enemies around. Can you fix either or both?
Thanks!
While World Tour isn't natively supported yet, you can play World Tour using StrikerDM. There's instructions on how to get it set up here: https://shadowmaveri...s/strikerdm.php
Download StrikerDM-r245.pk3 and the WT_SDM_Builder.zip file, and follow the instructions within.
#98 Posted 24 October 2024 - 03:23 AM
lwc, on 23 October 2024 - 01:44 PM, said:
I gave Dukebots another shot in various levels and spotted multiple issues:
- They completely ignore the Cooperative and Survival modes, meaning they always think they're in a deathmatch/team deathmatch.
- They completely ignore monsters.
- They can't open doors, enter tunnels, etc. so it's not just the roof they get stuck on but practically everywhere.
- They tend to stick around their opening locations and that's it.
I really like the DukePlus co-op bot, but DukePlus adds lots of stuff which have nothing to do with bots. But since Duke Plus is open source, would you consider borrowing from how Duke Plus pulled it off?
I realize NetDuke32 is more about netplay, but it's still what EDuke32 recommends for multiplayer in general...
This post has been edited by lwc: 24 October 2024 - 03:30 AM
#99 Posted 31 October 2024 - 06:10 AM
lwc, on 24 October 2024 - 03:23 AM, said:
- They completely ignore the Cooperative and Survival modes, meaning they always think they're in a deathmatch/team deathmatch.
- They completely ignore monsters.
- They can't open doors, enter tunnels, etc. so it's not just the roof they get stuck on but practically everywhere.
- They tend to stick around their opening locations and that's it.
I really like the DukePlus co-op bot, but DukePlus adds lots of stuff which have nothing to do with bots. But since Duke Plus is open source, would you consider borrowing from how Duke Plus pulled it off?
I realize NetDuke32 is more about netplay, but it's still what EDuke32 recommends for multiplayer in general...
The Dukebot code is mostly just an extension of the original DOS Atomic Edition Dukebots, and have a lot of the same limitations. They don't work in co-op, and probably never will without a lot of work that I simply don't have time and energy for anymore.
The bots can use doors, just not locked ones. They also use elevators, and can swim. They don't understand silent teleporters however, thus they get stuck on the roof in e1l1.
They don't like concave sectors, so certain maps can trip them up. But, they can usually navigate far better than the Atomic ones. Try movie set, flood zone, and hotel hell, they seem to cope well with those maps.
There's nothing from DukePlus that would apply to this. Different language, for one.
#100 Posted 01 November 2024 - 02:56 PM
Striker, on 31 October 2024 - 06:10 AM, said:
Then I think it should clearly be written in the description.
Quote
What do you mean different language? In any case, DukePlus have strictly co-op bots.
#101 Posted 03 November 2024 - 04:59 PM
#102 Posted 09 November 2024 - 02:47 PM
atmavan, on 03 November 2024 - 04:59 PM, said:
Controller support is not functional at the moment, apologies. You might be able to get something going with something like JoyToKey or some other joystick to keyboard/mouse translator.
#103 Posted 01 December 2024 - 01:25 PM
#104 Posted 01 December 2024 - 02:03 PM
#105 Posted 01 December 2024 - 03:01 PM
Striker, on 01 December 2024 - 02:03 PM, said:
Well taking care of yourself should be the first order of business, myself and others can wait until you're ready to return to work on the project. Thank you for the reply, though, I am working on a project where I want to use NetDuke32 as the main technology (instead of EDuke32) so players can enjoy both the single player and then have fun with coop or deathmatch in the time in between, NetDuke32 seems like the perfect solution for that.
Just remember to take care of yourself, I wish there was more I could do but please don't stress yourself out over things like this all good things will happen with time. I'm just thankful that you're still working on the project albeit with taking a break for your mental health and to avoid burnout. It just makes me happy knowing eventually things will work themselves out and in the meantime I can continue to use a different build that has working save/load functionality until you've had time to address it.
We love and appreciate the hell out of you and what you're accomplishing with NetDuke32, take care of yourself my friend!
#106 Posted 16 December 2024 - 11:57 PM
#107 Posted 17 December 2024 - 04:51 PM
Ninety-Six, on 16 December 2024 - 11:57 PM, said:
Probably NukemNet.
#108 Posted 25 January 2025 - 07:08 AM
This post has been edited by Overfl0w: 25 January 2025 - 07:09 AM
#109 Posted 25 February 2025 - 04:16 AM
Here are all the details I can think of.
I was host, using NetLauncher and its automatic port-forwarding function thing (I don't understand networking). WG tried to host numerous times and it always failed, but it always worked when I hosted so I was designated host. As I said we three were playing co-op, through WGMega (specifically the Pandora episode, which is episode 4), on DIG difficulty, and just trying to get through the campaign together. Though while waiting for our third man, WG and I did some tests beforehand. I will also note I streamed the test as well as the actual campaign.
Now for whatever reason, when the game first loaded it always put us into a musically silent Hollywood Holocaust for some reason, bypassing the online settings menu and also not even putting us in the first level of the mod's first episode. One of the other two would always call a vote to change to the level we had left off at, and this always worked just fine. But hitting the Nuke button, there was an 80% chance it was going to crash during the transition. Once or twice it worked and we got to the next level unscathed, but usually it was a crash.
And specifically it was a crash of my NetDuke32.exe. Theirs just disconnected once I, the host, was gone. And the crash was always a hard-lock, one that forced me to task-kill the program in order to gain control of my machine back (as only Ctrl+Alt+Delete would let me even interact with my machine). The only thing even remotely notable about the way it crashed that I can think of is that, on the "players ready" screen, as soon as all of us were green, the screen would suddenly backpedal and one of us would be red, and that is the exact same instant the game crashed.
No crash log was generated. I did look through the Netduke32.log file but didn't see anything that would explain it there either (though I will be attaching one log, as I backed up one of them before it would be overwritten by the next play session). I tried to sleuth my way through it best of my ability, but coding and networking really aren't my forte. We all were running the same latest version of ND32, and after that I was kind of out of ideas.
That said, there was one notable change. After we had finished the Pandora episode, our third guy retired for the night, leaving just myself and WG. We went and played another episode with just us, and the crashes stopped altogether. This was like when we were doing the tests. There were no crashes then, either. But I can't for the life of me understand why, if our third man was the problem, why my ND32 would crash. I know I was hosting but that still doesn't make much sense to me. Of course it's also possible that the issue wasn't who it was but instead how many. But I really don't know.
Anyway, attached is the log. The start of this video is the session this log corresponds with (first crash is at 21:55):
In fact here are the first two parts as well in case you think you might find them useful (the vod is in three parts because I didn't realize until crash #3 that xsplit had kept on going even after a crash):
https://www.youtube....ive/hUAS08upL4g
https://www.youtube....ive/94Tk6Hk_1qg
Attached File(s)
-
netduke32 - Copy (2).log (13.68K)
Number of downloads: 88
This post has been edited by Ninety-Six: 25 February 2025 - 04:22 AM
#110 Posted 25 February 2025 - 11:47 PM
I also confirmed that on their end, when the crashes occurred, they were able to load into the map; everything would just be frozen. Specifically only in regards to being in-game. That is to say, they could still quit the game normally by pulling up the menu. Meanwhile I couldn't even use Alt+tab or Alt+F4. I could only use C+A+D as previously mentioned.
#111 Posted 28 February 2025 - 07:38 PM
#112 Posted 28 February 2025 - 09:30 PM
#113 Posted 01 March 2025 - 12:41 PM
Striker, on 28 February 2025 - 09:30 PM, said:
The former was never generated and I did provide an instance of the latter.
Striker, on 28 February 2025 - 09:30 PM, said:
How can I tell the difference?
#114 Posted 03 March 2025 - 11:45 PM
Ninety-Six, on 01 March 2025 - 12:41 PM, said:
A hang is a freeze, usually caused by an infinite loop. Eduke32 will usually just stay frozen like that if its a hang unless you force quit. On a crash there is an error that stops program execution, sending you back to the desktop, usually with an error report.
#115 Posted 05 March 2025 - 12:31 AM
Ninety-Six, on 01 March 2025 - 12:41 PM, said:
Ah, apologies, missed that. Read through it, and nothing really stands out unfortunately. The only thing I can maybe ask, is trying it without any mods to see if it is reproducible.
#116 Posted 05 March 2025 - 07:23 AM
Danukem, on 03 March 2025 - 11:45 PM, said:
Sounds like a hang, then.
Going on that,
Striker, on 28 February 2025 - 09:30 PM, said:
Understandable. If we assume it's the same issue I'm running into, is there a workaround we can try until then, or is it something we'll just have to tough it out for a while?
Striker, on 05 March 2025 - 12:31 AM, said:
I'll see if I can get them together this weekend to try a vanilla run.
#117 Posted 05 March 2025 - 09:31 AM
Ninety-Six, on 05 March 2025 - 07:23 AM, said:
If it's the freeze that sometimes happens during intermissions between maps in CO-OP, it'll need to be toughed out. The way map transitions are handled, and how the "waiting for everybody" logic works, it can sometimes get stuck in an infinite loop. I once tried to resolve this, and I technically did, but had to revert it because it broke a bunch of other stuff in the process.
#118 Posted 04 April 2025 - 01:02 AM
So, as of July 2024, following earlier work, I prepared a limited-purpose maintenance test build of NetDuke32. There isn't much to add in terms of features, albeit:
* I tried fixing the game saving/loading functionality for single player games. I was using the Blast Radius episode while testing this.
* Also, at least for Windows users, this includes commits of Striker adding chat syncing with NukemNet. This code of Striker has also been used by the NotBlood port. They're not in NetDuke32 v1.2.1 since they had originally been added after its release.
It was used by at least a few players for testing beforehand, and was also used during the last TeamDUKE Flag-Tag tournament managed by Build Bros admins, but it should be more public-facing now.
To explain the existence of this test build:
* I had originally prepared merge requests for NetDuke32 after v1.2.1's release, fixing the occasional bugs that I stumbled upon.
* Additionally, I also found myself trying old Duke3D mods in multiplayer. One good example was TeamDUKE, but it was not the sole one. There were a few unintended changes from the original behaviors, so I had prepared compatibility fixes.
These changes are not yet in mainline NetDuke32 due to Striker having other priorities, including the preference (at least for now) to have a break from NetDuke32 development as of last October.
That said, as far as it comes to my changes, assume what you see here is what you'll get in practice. While I had managed to complete the Blast Radius episode (maybe with minor CON edits) using in-game saving, your mileage may vary.
Test build currently available via my fork repository: https://voidpoint.io...1.2.1-345003a8d
This post has been edited by NY00123: 04 April 2025 - 01:28 AM
#119 Posted Yesterday, 11:30 AM
I am wondering if it is possible to host a dedicated server with Netduke32? I an way, so that the server itself does not represent a player.
Are there any command line options I could make use of? I didn't find a way to launch the server with netduke32 binary, without NetLauncher.exe tool.
I was thinking about setting up a dedicated server for my group of friends on a linux box with a public IP, so my friends can just use netduke32 as a client, always connect to the same static server IP, and no one needs to take care of port forwarding / upnp etc.
Thanks!
nuku