Jump to content

Is this Mac/PC Doom source code on ebay legit?


Light37

Recommended Posts

*Lump already discovered in Doom 0.4*

*Delete please*

 

Edited by viti95

Share this post


Link to post
On 9/19/2023 at 2:17 PM, viti95 said:

OUTOFMEM.DOG

 

outofmem.png.59f9ca5feedd5fdfb6a814ede942af17.png

 

After some investigation, this looks like an early version of DOOMERR found in Doom 0.4 (April 2, 1993)

 

Alpha_ANSI_DOOMERR.gif

Edited by viti95

Share this post


Link to post
3 hours ago, Roebloz said:

Honestly though, if you're scared of touching the leak, keep in mind the only ones that are at any risk (If any) are those hosting the files up for download. And if there's anything the Nintendo Gigaleak told us, is that even Nintendo (Who abuse their copyright whenever possible) haven't taken down the Gigaleak on archive.org.

 

So honestly I'd say to not worry too much.

 

Nintendo has taken down multiple copies of that data from archive.org. If there's any still up there then their legal team just aren't aware of it.

Share this post


Link to post

Last night I backported Killough's hashtable implementation for W_CheckNumForName (minus the namespacing) into Mac Doom II 1.0.2 and got a nice little bump in performance on my 68040 Mac II. (Still much room for improvement, but The Living End is noticeably less choppy compared to retail 1.0.3!) I don't think many other people on Doomworld have old 68040 Macs to try this on, but I've attached an archive containing the application and the modified w_wad.c file in any case.

 

It looks like the 68k asm routines might have potential for optimization as well, though that one's a bit out of my depth. The 68k asm routines for column and span drawing were seemingly used as-is from a Carmack email in which he mentions that he didn't spend much time on them, that he doesn't consider himself a 68k expert, and that they "could certainly be improved". For anyone feeling particularly adventurous, that might be an interesting direction to dig deeper into.

DoomHashtablePatch.sit.hqx.zip

Share this post


Link to post
8 hours ago, viti95 said:

 

After some investigation, this looks like an early version of DOOMERR found in Doom 0.4 (April 2, 1993)

 

Alpha_ANSI_DOOMERR.gif

Commander Keen 4

keen4e.png

Share this post


Link to post
8 hours ago, Frenkel said:

Commander Keen 4

keen4e.png

 

So ID Software reused the Commander Keen 4 error page, and modified it a bit replacing "Commander Keen" for "DOOM, bonepie". That's why it's talking about EMS, when DOOM doesn't use EMS memory at all.

Share this post


Link to post

What I find weird is that I remember Wolfenstein had a screen that looked like the DOOMERR screen in Alpha 0.4/5. So they must have had a few different iterations of it.

 

no idea why they even bothered updating the screen when every extant version of Doom used protected mode where most of this doesn't matter, but they did.

Edited by SaladBadger

Share this post


Link to post
20 minutes ago, SaladBadger said:

What I find weird is that I remember Wolfenstein had a screen that looked like the DOOMERR screen in Alpha 0.4/5. So they must have had a few different iterations of it.

 

no idea why they even bothered updating the screen when every extant version of Doom used protected mode where most of this doesn't matter, but they did.

 

True, it's very weird they were modifying/using an older version of this screen in Doom development. Wolf3D memory error screen is really similar to Doom 0.4:

 

1566456101_2023-09-2110_06_15-86box-86Box4.0build4755.png.83e2186d97ce45cbfb0fcefde0659efc.png

Share this post


Link to post
2 hours ago, SaladBadger said:

no idea why they even bothered updating the screen when every extant version of Doom used protected mode where most of this doesn't matter, but they did.

 

The Doom Wiki suggests Doom started as a real mode DOS program.

Share this post


Link to post

Honestly I wonder if there's any evidence of that. The particular message didn't exist in any of the alphas except for the press release beta, I think, and every alpha was running in protected mode. It is still a really weird thing to have an error message for, though, and I can potentially understand thinking it would be to ensure any texture can fit in a EMS page.

Share this post


Link to post

That Doomwiki entry could just be an idea by whoever added it. There is no source, nor is it discussed on the discussion page. The Doomwiki is great, but it does contain some obvious errors and other problems. This sounds like one of those additions. Doom has plenty of limits, often without any reason given. the 65.5k limit is most likely one of those static limits they added, which they thought was more than enough. I don't think people has claimed the same for the way the blockmap is addressed. The idea is most likely that if a texture is that big (64kib+), something has gone wrong. Getting errors fixed can be a bit of a chore since it often involves removing 'information' from the wiki.

Share this post


Link to post

I think it's more likely that someone quickly cooked up that error screen under the assumption it would be needed. I can't quite see Carmack getting so far into the engine production that he wanted nice error screens made, but still used a 16bit memory model. When they looked at the specs they would target Doom at, they must have chosen 4 megabyte pretty early. I'm no DOS programmer, but 4 meg of ram and EMS sounds like a horrible idea. Carmack was fairly forward looking when it came to tech and used Nexts to develop on. Choosing 32bit and protected mode seems the logical choice. Maybe early in the dev. someone tried to anticipate what they would need, and made that screen instead of just twiddling their thumbs. Who knows, it's all guess work from my side.

Share this post


Link to post
16 hours ago, zokum said:

That Doomwiki entry could just be an idea by whoever added it. There is no source, nor is it discussed on the discussion page. The Doomwiki is great, but it does contain some obvious errors and other problems. This sounds like one of those additions. Doom has plenty of limits, often without any reason given. the 65.5k limit is most likely one of those static limits they added, which they thought was more than enough. I don't think people has claimed the same for the way the blockmap is addressed. The idea is most likely that if a texture is that big (64kib+), something has gone wrong. Getting errors fixed can be a bit of a chore since it often involves removing 'information' from the wiki.

That line is from me, and there is not any actual limit there. It would allocate more than 64 KB if it didn't literally check, "is this going to be 64K?" and error out if it would be. Nothing about the code wouldn't work otherwise. I don't know that Doom itself was ever fully compiled as real mode and that probably deserves clarification, but it's quite likely this code was imported from somewhere (Shadowcaster/Raven Engine???) that was.

Share this post


Link to post

Looking at the code to try to figure out exactly what's happening, so please tell me if I'm getting something wrong here:

//
// R_GenerateLookup
//
void R_GenerateLookup (int texnum)
{
    texture_t*		texture;
    byte*		patchcount;	// patchcount[texture->width]
    texpatch_t*		patch;	
    patch_t*		realpatch;
    int			x;
    int			x1;
    int			x2;
    int			i;
    short*		collump;
    unsigned short*	colofs;
	
    texture = textures[texnum];

    // Composited texture not created yet.
    texturecomposite[texnum] = 0;
    
    texturecompositesize[texnum] = 0;
    collump = texturecolumnlump[texnum];
    colofs = texturecolumnofs[texnum];
    
    // Now count the number of columns
    //  that are covered by more than one patch.
    // Fill in the lump / offset, so columns
    //  with only a single patch are all done.
    patchcount = (byte *)alloca (texture->width);
    memset (patchcount, 0, texture->width);
    patch = texture->patches;
		
    for (i=0 , patch = texture->patches;
	 i<texture->patchcount;
	 i++, patch++)
    {
	realpatch = W_CacheLumpNum (patch->patch, PU_CACHE);
	x1 = patch->originx;
	x2 = x1 + SHORT(realpatch->width);
	
	if (x1 < 0)
	    x = 0;
	else
	    x = x1;

	if (x2 > texture->width)
	    x2 = texture->width;
	for ( ; x<x2 ; x++)
	{
	    patchcount[x]++;
	    collump[x] = patch->patch;
	    colofs[x] = LONG(realpatch->columnofs[x-x1])+3;
	}
    }
	
    for (x=0 ; x<texture->width ; x++)
    {
	if (!patchcount[x])
	{
	    printf ("R_GenerateLookup: column without a patch (%s)\n",
		    texture->name);
	    return;
	}
	// I_Error ("R_GenerateLookup: column without a patch");
	
	if (patchcount[x] > 1)
	{
	    // Use the cached block.
	    collump[x] = -1;	
	    colofs[x] = texturecompositesize[texnum];
	    
	    if (texturecompositesize[texnum] > 0x10000-texture->height)
	    {
		I_Error ("R_GenerateLookup: texture %i is >64k",
			 texnum);
	    }
	    
	    texturecompositesize[texnum] += texture->height;
	}
    }	
}

From my understanding, it goes through each column of the texture, and if there's at least one patch for this column, it adds the texture's height to the total size. When that rolling counter would exceed 65536, the error message triggers.

 

Now the problem is that we know there are some 1024x128 sky textures, e.g. in Final Doom, and they work, and 1024 × 128 is 131072, i.e. twice the 65536 limit. But they work just fine.

Share this post


Link to post
  • 2 weeks later...

Now that multiple people have been able to dig through the hundreds of files on that CD, is what's been posted in this thread the only unique material found that wasn't available before, or are there a lot more undocumented things that just haven't been reported here yet or someone taken the time to peruse? Thanks.

Share this post


Link to post
  • 2 weeks later...

Jesus Christ how the hell did I MISS THIS???? This is some BIG news, I never thought we'd see an actual leak of the actual DOS source code.

 

 

...Oh, and the Mac source is nice too, I guess.

 

Mac Doom is fucking weird lmao

Share this post


Link to post
  • 4 weeks later...

I've forked it off to my own 1.7 branch. Ans I plan to clean up a bit and possibly back port some 1.10 changes.

Edited by zokum

Share this post


Link to post
  • 1 month later...

From the sold listings, it looks like that seller listed another DOOM source code disc but the auction ended without any bids. Similiar contents I think, but with some additional Hexen code? Is the Hexen code something that hasn't been released? Does anyone know enough if anything looks different or wasn't included in the previous disc that was listed for sale from this guy?

https://www.ebay.com/itm/204589321124

Share this post


Link to post

AFAIK Raven didn't "sanitize" the Heretic/Hexen code they released to the same degree that id did with the Doom code, so there's probably less likelihood of any lost code to the game itself, though I suppose there could be things like cut WAD content or auxiliary libraries (though I believe DMX has also been recovered as far as missing libraries goes.)  Maybe Mac code since I don't think we ever got any of that for any of the games.

Edited by ETTiNGRiNDER

Share this post


Link to post
57 minutes ago, ETTiNGRiNDER said:

AFAIK Raven didn't "sanitize" the Heretic/Hexen code they released to the same degree that id did with the Doom code, so there's probably less likelihood of any lost code to the game itself, though I suppose there could be things like cut WAD content or auxiliary libraries (though I believe DMX has also been recovered as far as missing libraries goes.)  Maybe Mac code since I don't think we ever got any of that for any of the games.

The file listing on the page only has C and header files of the game, no libraries or Hexen assets.

The rest appears to be mostly the same as the one that was put on archive.org, so probably didn't miss too much.

Share this post


Link to post

Regarding the described Hexen source tree - thanks to @nukeykt for checking:

 

The timestamps show this revision was last edited on Oct 15 1995. This date is also in the timestamp of CD version 1.0's executable, currently identified as "1.0r2" here: https://doomwiki.org/w/index.php?title=HEXEN.EXE&amp;section=2#Older_versions_2

 

A separate source reconstruction of this version should exist in gamesrc-ver-recreation as of now. The main technical advantage of having access to the original sources would probably be ensuring BSS variables got ordered exactly as in the original 1995 executable; Albeit, it's probably possible to do the same with the reconstructed sources by manipulating extern symbol definitions, if one knows how to. Other than that, it's mainly about knowing more of the original code, if in variable names or source code comments.

 

https://www.doomworld.com/forum/topic/114031-restoration-of-differing-doom-engine-exe-revisions-also-done-for-other-games/

 

 

Share this post


Link to post

Now if only someone could try and remaster/remake/reimagine, the five extra WADs that came with the source code leak, these are ENTERPRZ.WAD, G50.WAD, NEW.WAD, OOPS.WAD and TMPLDOOM.WAD, which were user-created maps that were presumably downloaded for the purposes of testing out the -file parameter and probably perhaps used to test the performance and features of the Classic Mac OS version developed by Lion Entertainment. 

Share this post


Link to post
  • 2 months later...
On 1/9/2024 at 3:31 PM, NY00123 said:

Regarding the described Hexen source tree - thanks to @nukeykt for checking:

 

The timestamps show this revision was last edited on Oct 15 1995. This date is also in the timestamp of CD version 1.0's executable, currently identified as "1.0r2" here: https://doomwiki.org/w/index.php?title=HEXEN.EXE&amp;section=2#Older_versions_2

 

A separate source reconstruction of this version should exist in gamesrc-ver-recreation as of now. The main technical advantage of having access to the original sources would probably be ensuring BSS variables got ordered exactly as in the original 1995 executable; Albeit, it's probably possible to do the same with the reconstructed sources by manipulating extern symbol definitions, if one knows how to. Other than that, it's mainly about knowing more of the original code, if in variable names or source code comments.

 

https://www.doomworld.com/forum/topic/114031-restoration-of-differing-doom-engine-exe-revisions-also-done-for-other-games/

 

 

 

I noticed that Hexen/Doom CD-ROM is back up on Ebay again, a little cheaper this time. I'm guessing no one bought it or had any sort of deal behind the scenes. Are you sure there's nothing useful on it? Still too high price for me, especially if there's nothing useful.

https://www.ebay.com/itm/204674362048

Either way, I'm going to keep watching his items, because if he's had that previous Doom source code CD-ROM and this one, there's no guarentee that he might not have something else in the future... It's just annoying sifting through all the other appliances parts and stuff each week just to spot something like this.

Share this post


Link to post

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...