|
Posted by metlslime on 2007/08/08 04:57:56 |
This is a counterpart to the "Mapping Help" thread. If you need help with QuakeC coding, or questions about how to do some engine modification, this is the place for you! We've got a few coders here on the forum and hopefully someone knows the answer. |
|
|
Stumbling Is A Kind Of Laugh
#2606 posted by madfox on 2018/07/20 14:59:55
Appoligize my passionated reaktion, as I'm stupid enough to write down my nonsense before my smart conclusion starts reasoning.:P
Thanks Spike. Now I'm back at start with:
//=========new code===========
local float entity spot;
local entity spot;
spot = find (world,classname,"monster_xogre");
if ( spot ) {find (world,classname,"monster_xogre");
spot.think = ai_leak1;
spot.leakentity = self;
}
};
//====================end code==
client.qc:808: error: local not a type
client.qc:808: error: spot not a type
client.qc:808: error: if not a type
client.qc:808: error: self not a type
#2607 posted by Spike on 2018/07/20 16:13:14
local entity spot;
just that.
not 'local float entity spot;' - that's meaningless conflicting keywords.
#2608 posted by madfox on 2018/07/20 18:54:30
yes, but as soon as I add a line in client.qc before ClientObituary I receive the error "local" and "spot not a type".
How do I make them to a right statement?
Ah
#2609 posted by madfox on 2018/07/20 19:20:50
I changed some parms
void() ai_leak =
{
local entity spot;
spot = find (world,classname,"monster_xogre");
if ( spot ) {find (world,classname,"monster_xogre");
{
spot.think = xogre_leak1;
// spot.leakentity = self;
return;
}
}
};
if I exclude spot.leakentity it compiles well,
warning that "Local "spot" not defined with a name of a global"
Wow, I've got an ai_leak!
What should be the next step?
#2610 posted by anonymous user on 2018/07/20 21:48:54
if ( spot ) {find (world,classname,"monster_xogre");
{
local entity pissee;
spot.think = xogre_leak1;
if ( pissee ) {find (world,classname,"monster_donaldjtrump")
spot.enemy = pissee;
QuakeC Locals And Globals
#2611 posted by Qmaster on 2018/07/20 22:19:08
local makes that variable only work within the function--inside {} and ONLY after it has been declared (pretty sure about this second part).
Globals are any variable defined outside, e.g. in defs.qc (at the bottom of defs.qc anyways)
You need to define a .entity leakentity; somewhere outside a function and before you use it in client.qc.
E.g.
.entity leakentity; // entity to remember for later so the monster knows where to go take a leak
void ClientObituary() {
local entity spot; // entity to hold our axe ogre
//your find down here
...
};
I'll let you figure out how to make the monster hunt down the player location and then begin the actual taking a leak.
Ho
#2612 posted by madfox on 2018/07/21 14:43:14
I'm back in PlayerDeathThink.
spot.think = xogre_leak1;
error: xogre_leak1 unknown value.
I can make a "void() xogre_leak;" at the top of the client.qc list,
but it keeps the error.
Wait
#2613 posted by madfox on 2018/07/21 15:26:06
There is something I need to explain first. As I mentioned before I am working in the Q1Test environnement. Also I added the Dragon code, rubicon.qc as some other feathers. I also wanted to add a catapult in stead of an axe.
One thing I would like to keep original to the Q1test mod.
Sounds, conback, weapons, and monsters. Reason I add the Axe ogre and Serpent, Vormitus, as the Shalrath's queer apearance is, because that were the trivial things that were not implemented. The dragon form Megalol had a solution, but the mod from Patrick Martin I included has a more sensitive way.
So I started with the "poor" q1test src, and slowly tried to find a way through the queer qc that was forehand. No Axe, nowammu_cells plz, and other butheads, like no change_level, just the stripped down qc to deathmatch.
Now I'm at the point that I'm testing the monsters, but it gets a little tricky , when I would assume the errors I get involved in are not the ones that apear in normal vqcc106.
Enough, I've got ai_leak that compiles.
//=========================================
After ClientObituary:
local float rnum;
local string deathstring,deathstring2;
local entity spot; // entity to hold our axe ogre
if ( spot ) {find (world,classname,"monster_xogre");
{
local entity leak;
spot.think = xogre_leak1;
}
}
rnum = random();
if (targ.classname == "player")
//=========================================
I had to add a new statement at the top for xogre_leak1 as it was not a value.
How do I make it aware for the player's death?
Queer Or Queen
#2614 posted by spy on 2018/07/21 15:32:17
Um, Compile With Fteqccgui?
#2615 posted by Qmaster on 2018/07/22 02:59:38
Qmaster
#2616 posted by madfox on 2018/07/22 16:10:42
I use fteccgui as fteqccgui. I can compile the client.qc but I have no idea how to make it correspond the player's death. I think it needs some more code.
local entity spot; // entity to hold our axe ogre
if ( spot ) {find (world,classname,"player");
{
local entity leak;
spot.think = xogre_leak1;
}
}
I tried your email, but it faints.
#2617 posted by madfox on 2018/07/24 19:26:02
gimmy a hint!
#2618 posted by Qmaster on 2018/07/24 19:55:54
Set spot.goalentity to player perhaps.
#2619 posted by Spike on 2018/07/24 20:56:54
if(spot)
that does nothing. spot isn't initialised yet. if this was C you'd crash. As this is QC, it'll just always evaluate to false and do absolutely nothing.
find (world,classname,"player");
this does nothing. you're calling the function and finding a player, but as you're throwing away the result you're not getting anything out of it.
Of course, seeing as the player has just died, the return value is probably going to be equal to 'targ' anyway. You probably meant to look for a different classname, like your ogre's classname.
local entity leak;
Variable not referenced: leak
the weirdly named 'spot' variable is used, but leak totally unused...
spot.think = xogre_leak1;
You didn't check that 'spot' is actually alive.
Your dead ogre will suddenly resurrect purely to take a leak!
Lets hope its not a gibbed head. :D
Note that there's no loop, so only one entity could possibly start pissing (except that spot is always world so you're probably just going to crash the server with your assignment to world, if the if statement wasn't there).
Imho, you should shove the check somewhere in ai_run.
When a monster's enemy has died, that function decides whether the monster should resume attacking its oldenemy or whether it should resume walking/standing instead.
So when the enemy dies, delay the standing and switch to the pissy animation instead (make sure its an 'xogre' that's doing the ai_running first, and make sure it doesn't forget its enemy just yet).
That way you don't risk waking monsters from the other side of the map (which might get quite crowded, and really awkward in coop).
and then you can dupe the walking animations to have the monster walk to the player's corpse and then start to pee only when its close.
then once its done pissing, you can have it start to play some point+laugh loop, or just have a constant stream of pee until something else wakes it up by shooting it (or make the looping part call ai_stand to have it wake up if another player gets close).
Id1 Source Code Circa 2018
I've taken the plunge into cut and pasting QC. What's the "state of the art" clean id1 source code I should be using in 2018?
Links
#2621 posted by Esrael on 2018/07/25 21:09:26
The vanilla source code (version 1.06) can be found at least here:
http://icculus.org/twilight/darkplaces/files/id1qc.zip
C0burn had also linked Ultimate Regular Quake Patch's source code to me. It has a lot of fixes/workarounds for problems that may arise with the vanilla code. I borrowed some code from it for one of my maps.
http://www.quaketastic.com/files/misc/urqp106a.zip
Good luck to your plunge! :)
@Esrael
Looks like a lot of MP focus in that second link. Thank you!
Also FWIW:
#2623 posted by Joel B on 2018/07/25 21:25:54
For my own purposes I put some QuakeC onto github a while back. There's various places to get these same things, but:
For the original 1.06 QuakeC you can browse it here: https://github.com/neogeographica/quakec/tree/1.06
or download a zip of it from here: https://github.com/neogeographica/quakec/archive/1.06.zip
For Preach's cleaned-up 1.06 you can browse here: https://github.com/neogeographica/quakec/tree/1.06_Preach
or download here: https://github.com/neogeographica/quakec/archive/1.06_Preach.zip
And you can see the differences between them here: https://github.com/neogeographica/quakec/compare/1.06...1.06_Preach
#2624 posted by Joel B on 2018/07/25 21:32:04
Eh, one caveat that just occurred to me about those zipfile downloads. If you get the code that way then all the files will use Unix-style line endings. Might cause you issues depending on what text editor you're using.
#2625 posted by Joel B on 2018/07/25 21:40:55
The URQP package is neat. I didn't know that that was where the Quake Info Pool fixes ended up.
Bug Zapping
#2626 posted by c0burn on 2018/07/25 23:17:58
I've updated the QuakeWiki with a list of bugs I know about in the 1.06 code.
https://quakewiki.org/wiki/Quake_bugs
It's most of the URQP stuff, plus other bits and bobs.
Please amend or ask me to amend if anything is missing!
What About Solid Fiends?
#2627 posted by Esrael on 2018/07/25 23:36:05
Quote from your list:
Rotfish does not become non-solid until the final frame of it's death animation * this is not in line with other monsters, so it is considered a bug
Correct me if I'm wrong, but don't fiends exhibit similar behaviour, too?
@Esrael
#2628 posted by c0burn on 2018/07/25 23:41:10
They become non-solid on frame 6/9!
Glancing at some others quickly, hellknight is frame 3, as is the grunt.
I think it should be harmonised.
Some More Thoughts
#2629 posted by c0burn on 2018/07/25 23:48:23
Should we class unused content, such as the death knight grunt sound and unused animations and unused shub sounds, as a "bug"? There's other bits and pieces as well, including unused animations in the knight, soldier and ogre. Can we introduce these in a non gameplay changing manner? Should they be an optional spawnflag/worldspawn flag?
Yes
#2630 posted by madfox on 2018/07/25 23:59:56
In the ai.qc i took the ai_run part.
===
void(float dist) ai_run =
{
local vector delta;
local float axis;
local float direct, ang_rint, ang_floor, ang_ceil;
local entity spot; //xogre_leak code
movedist = dist;
// see if the enemy is dead
if (self.enemy.health <= 0)
{
self.enemy = world;
spot = find (world,classname,"monster_xogre");
if ( spot ) {find (world,classname,"monster_xogre");
{
spot.think = xogre_leak1;
spot.leakentity = self;
}
}
and the bastard lays it's blame on me!
Thanks Spike, that was right on target!
Now see if I can switch leak with laughing.
|
|
You must be logged in to post in this thread.
|
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.
|
|