#2325 posted by Baker on 2017/06/01 03:10:40
pr_comp.h in the Quake engine source code
General Purpose Question
I have a couple of Quake related utilities that were made for Win95 era. They won't run in compatibility mode in Windows 7. I know I have the source for at least one of them. They are very unique programs I was going to hand off to Quaddicted as they don't have them in the archives. One is a fractal terrain generator (FraQuake) and the other is a map editor that creates maps from simple text files (Phase II).
So the question is:
Is there a way to have these simply recompiled to work on modern OSes? Does something "automagic" like this exist? Or are their services that I could use to port these to run on modern OSes? I obviously know next to nothing about coding. I've never run a virtual machine either. I would assume there's a way to scratch the itch but love to hear options. VBRUN300.dll is required for both of them So I assume written in Visual Basic... errr maybe?
#2327 posted by PRITCHARD on 2017/06/01 22:43:36
Generally speaking I find virtualization is the best way to keep using those tools. I use a win95 VM on my win10 machine for things like that (specifically, I set it up to run the QME installer).
Converting an app to run on modern windows otherwise would provably be a LOT of effort by comparison, unless perhaps the source code was already readily available...
@pritchard
Thanks, I am looking into installing Windows 7 32bit as I have a disk and license for that (note that it has 16 bit support whereas 64 bit versions don't). I have WinXP somewhere as well but lost my license. I know there are other options but I try to not "borrow" licences. ;)
I do have the source code for one of the the two proggies but in researching this it looks like VB3 is *really* freaking old and tough to find info on this stuff when you don't know what you are doing.
You Could Include The Source
#2329 posted by Qmaster on 2017/06/02 00:13:15
In your quaddicted upload. (Always and forever :) )
@Qmaster
Of course! I thought I had to email the files to Spirit. I can upload them? Will be happy to.
#2331 posted by Baker on 2017/06/02 01:03:30
Well
#2332 posted by Qmaster on 2017/06/02 03:17:40
Ya you have to email them to spirit, but I mean please package them in the same zip beforehand and sounds cool. FraQuake? Whoa. Text mapping...hmmmm
@Qmaster
PhaseII is an oddity to be sure but both of these apps have a really interesting UI and are (to me) a pretty interesting part of our collective Quake lore. They were coded by a women who was injured in a car accident and kind of fell out of the Quake scene as a result. I've never been able to track down what happened to her after her hospitalization. I will email these to Spirit but here they are for the curious. No source for PhaseII unfortunately. Well worth a look IMO. That's why I wanted to get them running again.
https://www.dropbox.com/s/plh6rsopnx3c863/fraquake.zip?dl=0
https://www.dropbox.com/s/4hgvr5ojab38xnl/phase2.zip?dl=0
BSP Parsing Code
#2334 posted by megaman on 2017/06/21 20:36:28
Can someone point me to code that parses BSP files?
Extra beer if it's in python or the like :-)
It Would Be Totally Fine To Point Me To The Relevant
#2335 posted by megaman on 2017/06/21 20:39:02
sourcecode on github or something :-)
#2336 posted by khreathor on 2017/06/21 20:46:25
Here you have add-on for blender that parses BSP. It's a python script, so very close to what you are looking for: https://github.com/andyp123/blender_io_mesh_bsp
I don't know about any other python BSP parser, but i bet there must be more of this... somewhere... :D
Quakespasm Source
#2337 posted by megaman on 2017/06/21 20:48:49
BSP Parsing Code
#2338 posted by Spike on 2017/06/21 20:51:47
https://github.com/ericwa/Quakespasm/blob/master/quakespasm/Quake/gl_model.c#L1969
if you just want a wireframe blob, walk through the faces lump, read the firstedge+numedges values and walk through the surfedges lump from that firstedge value for numedges entries. for each surfedge indicated, look up the edge entry that it indicates - if the surfedge is negative, negate it and use the second vertex from the indicated edge entry, otherwise use the first vertex from the edge.
that'll give you a loop of verticies, aka a triangle fan. get the actual vertex positions from the vertex loop.
textures come from surf->texinfo->texture. texture coords come from dotproduct(vertexcoord, surf->texinfo->vecs[S|T])-surf->texinfo->vecs[S|T][3];
lightmaps are overcomplicated. you'll need to calculate the texture coord extents, divide by 16 and round out to calculate the size of the per-surface lightmaps. then blend the up-to-four lightmaps per surface, atlas the result somehow according to the current lightstyle etc.
collision+pvs+ents+submodels are a different matter entirely, but they're half the fun.
Oh Awesome
#2339 posted by megaman on 2017/06/21 21:01:33
Thanks you two!
I was thinking about writing a map validation tool that unzips, reads bsp, checks if everything is there and parseable.
Quake Development CD 9/4/96
#2340 posted by madfox on 2017/06/25 18:18:46
I downloaded this file way back 2005. I had the impression it was able to recompile the quake.exe. By means of doing so I would be able to alter some of its components in the way I had the oppertunity to create my own "quake". The file is only 700kb large, has most of subdirectories full of *.c and *.h files.
Now I finally have it installed it looks as if I'm missing something. I knew I would get into trouble, reason I restrickted myself to qcc only.
Now I have a directory /quake/utils, tried the install.bat but get redrawn to D:QUAKE/UTILS/QCC>nmake /f "qcc.mak"CFG="qcc -WIN32 Release" The command or filename is incorrect.
Where should I start?
#2341 posted by madfox on 2017/06/25 18:21:39
I know there is a Install VC++ and MASM.
order, or use DJGPP to compile the dos version.
I'm downloading a file with 1Gb info , but I have no idea whee to begin.
@madfox
#2342 posted by Spike on 2017/06/25 18:54:43
nmake is microsoft's version of make. its kinda crap compared to gnu's [g]make. It comes bundled with msvc, I've no idea if there's any smaller bundles for it, but you'd need a c compiler anyway, so I wouldn't bother too much, just get msvc.
djgpp compiles for dos. if you're on a 64bit windows system then its almost useless (dosbox to the rescue?). Its available as a native dos compiler, or as a cross compiler from eg cygwin.
In this day and age, you should probably NOT start with the vanilla sourcecode. Its too limited and buggy. You would save yourself time by starting with eg quakespasm.
But yeah, I have to ask what you're actually trying to achieve? If its just making a quake mod then you don't need to bother with any of the above, just grab a base mod (like progs106.zip or some cleanqc thing like gnounc's) and then combine with a prebuilt qc compiler (like fteqccgui - the vanilla one is shite).
@spike
#2343 posted by madfox on 2017/06/25 19:39:40
Thanks for your reply!
First I'm on winxp32. I did some tinkering with qc and proqcc (now fteqccgui), and got a little familiar with it. That is.., spent weeks in urge to find a six lined string for the rat code from malice, before I found the malice qc and wondered what I missed. (I'm great!)
So in fact I'm more into trouble than I can get. What I tried to archive is searching in the AI Cafe, and sourceforge my curiosity is wakened about changing these *.c and *.h files.
As I look to the qc files there is nothing in it. While I do find them in this Quake developement CD.
So I know I am searching on the wrong place, but downloading the whole djggp file didn't get me any further.
What I try to do is get this cd working and see what's going on. Having V++ and MASM is a start, but I have no idea where I'm going.
Maybe the whisfull thinking of construckting a scuba gear, make reflecting water, or god knows.
A Request
It would be awesome to have a tool that can tell me the modelindex of an entity without having to compile and run the map.
Is it possible to determine this information before compilation? or is it so much work that it wouldn't be worthwhile?
#2345 posted by Baker on 2017/06/25 20:25:00
Look at the code here:
http://www.gamers.org/dEngine/quake/Qc/items.htm#item_health
And here ...
http://www.gamers.org/dEngine/quake/Qc/items.htm#item_artifact_super_damage
Do you see how the items even getting precached is dependent on what items are present in a map?
It even depends on spawnflags in some cases like health boxes. And it definitely depends on the actual order that of the entities in the map file.
So it can vary for skill level -- skill 1 vs. skill 2, etc.
Since modelindex is very hard to predict, you may ask yourself why are you using modelindex?
Which is the better question.
For sexy non-essential maphacks. I like the idea of pushing the engine / progs to its limits.
#2347 posted by Baker on 2017/06/26 02:07:02
The model name won't work?
Also are you sure you are using a model index? A brush model like "*5", that's not a model index -- that is the model name.
sorry you're correct, I mean edict number.
#2349 posted by Spike on 2017/06/26 02:28:32
model *5 will ALWAYS have modelindex 6, guaranteed. doesn't even need to be precached.
external models have pseudo-random indexes, but those inline models will always be assigned modelindexes by the engine and with reliable ordering etc.
edict numbers depend upon the max number of players. quite a few entities like walltorches will be handled with makestatic, and so will not increment edict numbers. Again it also depends upon spawnflags as to whether the entity will actually be spawned, etc.
By far the easiest way to get this sort of stuff to work is to include a custom progs.dat so that things don't have to be guessed at, but Baker won't like that either. :P
|