I am reposting this just to make sure the thread is there for people reporting bugs. I am not reposting the entire thread, just the intro by catwhowalksbyhimself and my primer for bug reporting.
Quote from: catwhowalksbyhimselfReport all bugs here. For further instructions, see Stumpy's post below.
List of previously reported bugs:
Still live
1. Superleapers teleporting instead of jumping? Needs further reports and confirmation.
2. Groups of characters under M25 AI occasionally just stand around and take a coffee break.
3. Bleeding state swap is unfinished and needs to be either fixed or removed.
4. All of things that I coded were never tested and need to be tested and removed if not working and unfixable.
5. alert: CFastHeap::allocate failed, Out of main memory message, followed by a game-breaking crash. The cause of this problem is unknown. It does not appear to happen to all users and not even consistently to those it does.
Fixed for next version
1. Missing string and attribute.dat entries for Enchanter
2. Unfinished attribute Sound Absorber activated.
If you are having trouble with the beta:
- Run the FFX Control Centre for this mod after you install, before you start the game. It needs to brand any custom heroes you have and any built-ins you have merged using FFEdit.
- When you create a new custom character (either from scratch or by copying another character), make sure that you have used the FFX Control Centre for that mod so that the character is "branded". Then restart the game.
- If you are creating several customs, you don't have to do the Quit - Run FFX CC - Restart branding routine for each of them, just create them all, then quit and run the FFX CC and then they will all be branded at once.
- Remember that you also have to run the FFX CC when you use FFEdit to create a new built-in character and when you import built-ins (merge DATs) from other mod folders.
- If you are seeing an AI problem (e.g. "I tried to run a character in the Rumble Room but he isn't doing anything or he never uses his main power", etc.), then make sure you have run the character through the Rumble Room's M25 AI Generator.
- If it is an issue with a power swap (e.g. "I tried to set up a hex beam to crystal cage swap"), make sure you have run the character through the Rumble Room "Generate Power IDs" mission.
When reporting problems in the FFX beta (and this generally applies to getting a wide variety of technical help in the game), please:
- Character Type
Mention whether you have the problem with a built-in character or a custom (HERO file) character.
- Mission Type
Mention whether you have tested in a campaign mission or a Rumble Room mission.
- Descriptive topic Titles
(This may apply more to bug reported in other threads. Nevertheless...)
Use descriptive topic titles for your post that give readers some specific idea what you will be describing in the message. To wit, "need help" or "ffx not working" may be true for you, but it isn't letting someone know that he ought to read your post because he had the same problem, which is usually the quickest way to get an answer. Instead "FFX 3.2 beta: SUPERLEAPER problem with customs?" is both useful for people trying to help and useful for others who may have the same trouble, who can now read your thread (and maybe add some detail that helps in finding a fix) instead of starting a new thread.
- Give Details
Be detailed and exact in your description of what is going wrong. In other words,
Quote from: MrCoolidgeSUPERLEAPER isn't working.
is a poor bug report and it's tough for anyone to help you.
But,
Quote from: DrDetails"I am having trouble with SUPERLEAPER. When I give it to a custom character (MrGreen in this case) and try it in the second campaign mission (the Cuban airfield), the hand appears over objects and I have the "leap to" command in the right-click menu, but nothing happens when I click on it. Here is my script.log...
In general, if you can give a step-by-step approach to duplicating your problem, you are that much closer to having it solved.
- Report Special or Limiting Circumstances
Do a little testing before you post and mention if you found anything, even if it may not seem that important. If the problem happens only in a certain situations, be sure to mention it. For instance, I noticed a problem with swaps in the mission where Entropy sends several waves of subterrestrials and wraiths against the squad. At first it seemed like the swaps just stopped working after a while, but then I noticed that it only stopped after a couple waves had spawned and that lead me to the solution.
- Try to Post Log Files
This is a biggy: post your script.log file! This file is located in the root directory for the game (the same folder that has the game executable (the ffvt3r.exe file). If you can't locate the right folder, right-click on the shortcut you use to start the game and choose Properties, then click on Find Target. The folder that opens up will have the script.log file.
Open that file (in NotePad, for example) and copy-paste its contents into your message in between the code tags. To use the tags, just select the code you have pasted and click on the code tag button, (http://home.graffiti.net/stumpyanker:graffiti.net/images/BBCodeTagButton.gif).
This might be a somewhat long text file. To keep it relatively short, play a mission, wait a few seconds for FFX to kick into gear, then get the problem you are experiencing to happen as soon as you can. At that point, pause the game and get the script.log at that time.
- Edit Too-Long Log Files
If you really can't post the whole script.log because the problem only happens late in a mission and the file is too big by that point, you can still post parts of it. This is a little trickier because you have to decide what parts are worth posting. Generally,
- Post the beginning of the file, down to and including the section where the characters have their attributes initialized. That section will look something like
QuoteinitAttribsForChar: working on hero_3 (microwave)
initAttribsForChar (microwave): looking at attribute cybernetic brain
initAttribsForChar (microwave): looking at attribute radioactive
initAttribsForChar (microwave): looking at attribute vulnerability
execInitAttrib: init vulnerability attribute
on hero_3 of template microwave (microwave)
initAttribsForChar (microwave): looking at attribute powerscan
execInitAttrib: init powerscan attribute
on hero_3 of template microwave (microwave)
- Post any sections that have errors or traceback messages in them (search for error and traceback in the file). A traceback message will be several lines telling where the problem was in the script files and then the exception message. It is a good idea to post a line or two before the traceback as well. Something like the following
QuoteMLOG_WatchDamage: error in Object_GetAttr('eye_minor4', 'minForce'), Object_Exists('eye_minor4')=0
words=['04:43:14.01:', 'FF:', 'Damage:(eye_minor3)', '', '(resolve)', 'dmg:', '47,', 'stun', 'time:', '0,', 'KB:', '6450\012'] MLOG_DAMAGE_PREVIOUSLINE=['04:43:14.01:', 'FF:', 'Damage:(eye_minor3)', '', 'eye_minor4', '(calc', 'pwr)dmg:', '33,', 'stun', 'pct:', '0,', 'KB:', '4500\012']
Traceback (innermost last):
File "C:\Program Files\Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\mlogreader.py", line 722, in OnMLOG_Read
MLOG_Read()
File "C:\Program Files\Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\mlogreader.py", line 768, in MLOG_Read
found = MLOG_WatchDamage(thisLine)
File "C:\Program Files\Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\mlogreader.py", line 1930, in MLOG_WatchDamage
if ( knockback - Object_GetAttr(target, 'minForce') ) < 0:
SystemError: NULL result without error in call_object
- Post ff.err For Errors right at startup
When an error occurs right when the game starts (before a mission has started up, the game sends some error information to a file called ff.err, located next to the other log files. It is almost always short and it will tend to be empty after the game has run a short while because later errors are sent to script.log. Anyway, if this file is not empty, post it, too.
Some of those suggestions will seem pretty basic and some will not, but they will generally let the people who try to help you diagnose what is going on faster and in fewer post-and-reply steps here on the board. That can be especially handy as people sometimes have a little time to help with a problem, but if they can't figure out what it is and have to ask for more info, they may not be able to look into it again right away after the new info is posted. The more and better information you get out in the first place, the more likely someone will be able to help you out the first time through.
Okay, feel free to add to the thread. Some people had significant problems that I think mostly were fixable with a clean powers.dat, but please don't hesitate to add those questions (and answers!) or new ones to this thread so that others can try them out.
If the old thread is resurrected, I may merge these posts to keep things in one place.
Okay, I've gotten to the point where the game isn't freezing up every time I try to play it. Now I'm encountering multiple problems using custom characters in a Rumble Room mission.
I made two custom characters--Hulk and Abomination. I gave both of them an "invulnerable" attribute, plus one or more of TaskmasterX's combo attributes--"hulk" for Hulk (imagine that) as well as "lesserregeneration plus," and (for Abomination) "strong jumper."
I shut down the game and "branded" both files using the FFX Control Center. Then I fired the game up again and tried to run them through the M25 AI Generator. The mission started, but there was no evidence that AI was being computed for either of them. After a few minutes I ended that mission and started a typical "Battle in the Rumble Room" mission, with me controlling Abomination. None of the attributes seemed to work. There was no jumping, no regeneration on Hulk's part, and no apparent invulnerability. Here's the script.log:
Quote>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.251000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 9; branch = Public Beta 1
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Traceback (innermost last):
File "C:\Documents and Settings\jmoser1\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py", line 6, in ?
from ffx import *
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 29, in ?
import m25ai
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 60, in ?
import m25generateai
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25generateai.py", line 35, in ?
import ffxmulti
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffxmulti.py", line 61
['negativezoneruler','fastflier','heavylifter','invulnerable','shakeitoff','metabolic','privatearmy3','summoner2'],
^
SyntaxError: invalid syntax
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\jmoser1\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', ))
try to spawn custom_vil_0
sk.SpawnEnemy: energy for _skcustom_vil_001 (hulk) changed from 9 to 6
Traceback (innermost last):
File "C:\Documents and Settings\jmoser1\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py", line 15, in OnPostInit
FFX_InitSkirmish()
NameError: FFX_InitSkirmish
Any idea what's going on?
How do you clean up powers.dat?
Quote from: jmoser on January 31, 2007, 06:12:46 PMI made two custom characters--Hulk and Abomination. I gave both of them an "invulnerable" attribute, plus one or more of TaskmasterX's combo attributes--"hulk" for Hulk (imagine that) as well as "lesserregeneration plus," and (for Abomination) "strong jumper."
I shut down the game and "branded" both files using the FFX Control Center. Then I fired the game up again and tried to run them through the M25 AI Generator. The mission started, but there was no evidence that AI was being computed for either of them. After a few minutes I ended that mission and started a typical "Battle in the Rumble Room" mission, with me controlling Abomination. None of the attributes seemed to work. There was no jumping, no regeneration on Hulk's part, and no apparent invulnerability. Here's the script.log:
Quote
import ffxmulti
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffxmulti.py", line 61
['negativezoneruler','fastflier','heavylifter','invulnerable','shakeitoff','metabolic','privatearmy3','summoner2'],
^
SyntaxError: invalid syntax
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
Any idea what's going on?
The negativezoneruler attribute has a syntax error in ffxmulti.py, from what I can see:
'heavylifter' should be preceded by a straight quote, not an accent.
Quote from: Dreaded Porcupine on January 31, 2007, 07:18:37 PM
How do you clean up powers.dat?
Not too sure when we can release a Public Beta 2.
So, for the moment, PM me an e-mail address and I'll send you the updated powers.dat. I hope it will make your FFX 3.2 experience a bit more enjoyable.
Quote from: stumpy on January 31, 2007, 02:58:27 PM
I am reposting this just to make sure the thread is there for people reporting bugs. I am not reposting the entire thread, just the intro by catwhowalksbyhimself and my primer for bug reporting.
Quote from: catwhowalksbyhimselfReport all bugs here. For further instructions, see Stumpy's post below.
List of previously reported bugs:
Still live
1. Superleapers teleporting instead of jumping? Needs further reports and confirmation.
2. Groups of characters under M25 AI occasionally just stand around and take a coffee break.
3. Bleeding state swap is unfinished and needs to be either fixed or removed.
4. All of things that I coded were never tested and need to be tested and removed if not working and unfixable.
5. alert: CFastHeap::allocate failed, Out of main memory message, followed by a game-breaking crash. The cause of this problem is unknown. It does not appear to happen to all users and not even consistently to those it does.
Fixed for next version
1. Missing string and attribute.dat entries for Enchanter
2. Unfinished attribute Sound Absorber activated.
I can help out with some of these since I was probably the reporter...and a bad reporter at a few times :(.
1) Using grens hexed Juggernaut for the Hulk mesh, the AI appears to be using superleap, but there are no animations for "jumping", the Hulk just teleports to the new location.
2) The clumps of guys (or at least my clumps of guys) bug wasn't a bug, but instead by a freakish event caused my odd method of systemic character creation. I gave everyone...everyone!...an attack arc of 120 degrees for all melee attacks. Well, the AI generator assigns these attacks a an "area" attack and won't use them when friends are near. Since all the characters in the battle were hand-to-hand guys, they sort of locked up. They wanted to throw a punch but could not because friendly models were near. No problem, but interesting for reference. Thsi wasn't a bug.
5) I had this problem, but it was solved by Taskmaster X's fix posted on the yahoo group.
Hope that helps. :thumbup:
I asked this before but recieved no answer. What happened to the SOLAR STORES attribute?
Quote from: stumpy on January 31, 2007, 02:58:27 PM
Quote from: catwhowalksbyhimself
Fixed for next version
1. Missing string and attribute.dat entries for Enchanter
2. Unfinished attribute Sound Absorber activated.
1. I checked the strings entries and they were there. It was just the entries in attributes.dat that needed fixing. Just want to make sure no extra data gets put in the strings.txt
2. This should be "Unfinished attribute Sound Absorber DE-activated."
Jmoser, Ep, is right, looks like a typo in the ffxmulti.py. I'll dbl-check for any others and make sure it's in the public beta2. Sorry about that.
Quote from: Shazam on January 31, 2007, 11:48:53 PM
I asked this before but recieved no answer. What happened to the SOLAR STORES attribute?
Hey Shaz, I don't know what's up with Solar Stores but I see a manual entry, strings.txt lines and ffx.py code for it but nothing in attributes.dat. I checked FFX3.1 and it's the same way. Is this the way you had it set up? Like my combo attributes have all the code and strings but have to be "turned on" by adding the entries to attributes.dat? Have you tried adding solarstores to the attributes.dat and testing it in-game?
QuoteThe negativezoneruler attribute has a syntax error in ffxmulti.py, from what I can see:
'heavylifter' should be preceded by a straight quote, not an accent.
Thanks for catching these, but would this really be responsible for causing the problems I'm having? After all, neither the Hulk nor the Abomination hero files used the "negativezoneruler" attribute.
Quote from: jmoser on February 01, 2007, 06:55:39 AM
QuoteThe negativezoneruler attribute has a syntax error in ffxmulti.py, from what I can see:
'heavylifter' should be preceded by a straight quote, not an accent.
Thanks for catching these, but would this really be responsible for causing the problems I'm having? After all, neither the Hulk nor the Abomination hero files used the "negativezoneruler" attribute.
Yes, it will prevent everything else from working - not to say you won't have other problems with the game, but this is an important one. The game is basically choking on that error and can't get past it. Nothing else is getting loaded properly.
The list posted at the top is not the latest one. That one was wiped out. This should be the most current one:
List of previously reported bugs:
Still live
1. Superleapers teleporting instead of jumping.
2. ffxmulti.py entry causes system to crash.
Fixed for next version
1. Missing string and attribute.dat entries for Enchanter
2. Unfinished attribute Sound Absorber activated.
3. All of things that I coded were never tested and need to be tested and removed if not working and unfixable.
4. alert: CFastHeap::allocate failed, Out of main memory message, followed by a game-breaking crash.
5. Bleeding state swap is unfinished and needs to be either fixed or removed.
Not a true bug
1. Groups of characters under M25 AI occasionally just stand around and take a coffee break.
Quote from: catwhowalksbyhimself on February 01, 2007, 08:20:20 AM
2. ffxmulti.py entry causes system to crash.
After looking at the publicbeta1 ffxmulti.py I didn't see the accent in the negativezoneruler line and I'm not getting this error in my script.log. So, this seems to be happening only to jmoser as we're not seeing this particular error in any of the other script.logs. Jmoser, did you re-type in those lines in ffxmulti.py or edit this file in some other way after installing the publicbeta?
I was playing around with my Dryad hero file yesterday and I switched her back to having a projectile Exile attack with a Transmute swap (to Bizarre type). I Ran FFX CC and ran her through the Power ID Generator then took her into a Rumble Room session (Instant Action FFVTTR). Unfortunately, although the new object appeared (for example, lab equipment) the opponent did not disappear, was completely unaffected and continued attacking Dryad.
QuoteFixed for next version
alert: CFastHeap::allocate failed, Out of main memory message, followed by a game-breaking crash.
Did the CFastHeap problem get solved? Did I miss out on something?
It's certainly great news though.
Is it anything I can fix myself or is it most advisably a matter for people who actually know what they are doing?
Bear with me if the answers to these questions are starring me right in the face, from somewhere on this page. :unsure:
Thanks for the reply TMX. SOLAR STORES used to be in FFX prior to FFX3.1 and was shown in the manual. Now I can't see it in the manual, which made me think it had been scrapped. The code is in there as you say, but isn't in the attributes DAT it would seem. I never had it setup that way. I believe Epimethee setup all my attributes originally.
Quote
Did the CFastHeap problem get solved? Did I miss out on something?
It's certainly great news though.
Is it anything I can fix myself or is it most advisably a matter for people who actually know what they are doing?
Yep, it's just a corrupted powers.dat. Delete it and rename powers.dat.bak to powers.dat.
Quote from: Shazam on February 01, 2007, 02:54:31 PM
Thanks for the reply TMX. SOLAR STORES used to be in FFX prior to FFX3.1 and was shown in the manual. Now I can't see it in the manual, which made me think it had been scrapped. The code is in there as you say, but isn't in the attributes DAT it would seem. I never had it setup that way. I believe Epimethee setup all my attributes originally.
I don't know for sure what happened either; there's nothing is the version history file... OK, actually there is no such file (or an exhaustive version at least). I figure it was simply an error due to a bad DAT update; not an unlikely occurence with that cumbersome format. However, there migt be a very good reason why it was removed (Dr. Mike?), so at first glance, I'd tend to say let's wait for FFX 3.3 – which hopefully won't take a year –; maybe you could enable it and run some tests, checking for compatibility with stuff like Battery Powered, Body Aura and Energy Tanks?
Thanks.
RE: CFastHeap.
wait a sec, i still had problems after deleting the new file and renaming the old one. it wasn't until i dl'd taskmaster's fix on the yahoo group that things worked properly again. now, i may have not shut off my computer after deleting the new file and renaming the old file and the bug lingered.
QuoteJmoser, did you re-type in those lines in ffxmulti.py or edit this file in some other way after installing the publicbeta?
Yes, I did some editing using Word. Unfortunately Word reads single quotation marks differently than Notebook does. I thought I'd fixed all of those, but apparently I missed one. Sorry, I should've let you know earlier, and saved you the trouble of consulting your file. It was clearly my screw-up, not yours.
QuoteRE: CFastHeap.
wait a sec, i still had problems after deleting the new file and renaming the old one. it wasn't until i dl'd taskmaster's fix on the yahoo group that things worked properly again. now, i may have not shut off my computer after deleting the new file and renaming the old file and the bug lingered.
Okay, so you need the other fix. Point is, it's in the next version, so it's on the fixed list.
Probably redundant as heck but yeah, the replacement DAT fixed my problems as well.
Now Im off to break the game! We will see if a 7 Justice Leagers vs a whole bunch of X-Men rematch dosent somehow crash it or uncover some problems...
Quote from: Shazam on February 01, 2007, 02:54:31 PM
Thanks for the reply TMX. SOLAR STORES used to be in FFX prior to FFX3.1 and was shown in the manual. Now I can't see it in the manual, which made me think it had been scrapped. The code is in there as you say, but isn't in the attributes DAT it would seem. I never had it setup that way. I believe Epimethee setup all my attributes originally.
I guess the link in the main page of the manual is gone for Solar Stores, but there is a solarstores.htm in the manual folder. The manual just needs the link to it. It should work if you just add it to attributes.dat since I don't think any changes we made to FFX3.2 would affect it.
QuoteNow Im off to break the game! We will see if a 7 Justice Leagers vs a whole bunch of X-Men rematch dosent somehow crash it or uncover some problems...
Please do try.
QuoteYes, it will prevent everything else from working - not to say you won't have other problems with the game, but this is an important one. The game is basically choking on that error and can't get past it. Nothing else is getting loaded properly.
Just as you said, fixing that tiny typo in the ffxmulti.py seemed to take care of all the problems. Puts me in mind of that old poem, "all for the want of a horseshoe nail." Anyway, thanks for the assist. I haven't run into any problems yet, but if I do y'all will be the first to know.
Okay I am having trouble with a hero file i edited, i didn't know where to post this so i came here. I created thor and edit his m25a1 file. The characters seems to fight at first then just goes into brain farts. Sometimes i would look into the script.log and it would point out where the syntax error is located and i would fix it. However, this time i dont know how to fix it. Here is the m25ai file and below is the error from my last RR session.
[spoiler]['thor',
["target enemy",
'not enraged',
'weakness_ranged_electrical',
'not hexed',
'weakness_melee_crushing',
'not flying',
],
["timer", 'auto',
'TUseRemedy()',
'TFleeMelee(type="any",subtype="emitting_damage",time=0.88)',
"TArea('electrical field',type='any',priority='high',situation=['swarmed or fasterthan'])",
"TRangedExplosive('hammer throw',time=2.6)",
"TRanged('hammer beam',time=3.79)",
"TDirectExplosive('electric zap',time=3.79)",
"TMelee('hammer wallop',pct=90,priority='high',situation=['strongerthan or higherhealththan or higherstrengththan or higherenergythan'],time=2.2)",
'TWeatherControlHail()',
'TWeatherControlLightning(pct=50, time=2, energy=50, mindist=0, maxdist=300, type="enemy", subtype="None", situation="None", role="None", priority="medium")',
"TMelee('melee',time=1.95)",
"TMelee('electro-nux',time=0.88)",
'TThrow(pickup_time=2.92,throw_time=2.51)',
'TMoveTo(mindist=\'medium\',time=0.88,subtype=["not emitting_damage","flying"])',
'TMoveTo(mindist="melee",subtype=["not emitting_damage","not flying"],time=0.88)',
],
['subtype',
'divine_metal',
],
]
[/spoiler] Any typos?
Heres the script.log
[spoiler]
>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Starting ffx.py v. 3.2.0 build 9; branch = Public Beta 1
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Starting System Utilities 1.3
Starting General Utilities 1.0
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Height Check module 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1170450147.010000
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25skirmish.py v.3.2.0 build 6; branch = m25 branch 2
>>> C:\Documents and Settings\Alberto\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Skirmish Watch Mode.py executed
>>> C:\Documents and Settings\Alberto\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Alberto\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Skirmish Watch Mode.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', '------------', 'custom_vil_1', 'custom_vil_2', 'custom_vil_3', ))
TIME: 0.009046 for GetMissionVar
SkirmishSpawnEnemy: custom_vil_0 (thor, 1268)
AI: SetupAI() - setting ai for custom_vil_0_1 ('thor')
CUSTOMPOWERS: using power slot 1 for thor : electrical field
CUSTOMPOWERS: using power slot 2 for thor : electro-nux
CUSTOMPOWERS: using power slot 3 for thor : hammer wallop
CUSTOMPOWERS: using power slot 4 for thor : electric zap
CUSTOMPOWERS: using power slot 5 for thor : density control
CUSTOMPOWERS: using power slot 6 for thor : hammer beam
CUSTOMPOWERS: using power slot 7 for thor : hammer throw
CUSTOMPOWERS: using power slot 8 for thor : melee
(I thought these were the major ones to paste on here as the file was long)
AI: Unable to do tactics for custom_vil_0_1
exceptions.RuntimeError Object_SetAttr(): expects args {ssf}
Traceback (innermost last):
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 485, in AICheckTimer
try: tactic_id = AIExecTactics(event)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 596, in AIExecTactics
exec tac_string
File "<string>", line 38, in ?
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 4896, in AIGenericPowerOnSelf
AISupport_DoPower(char, power, char, priority, time, carrier=carrier, level=0, desc=desc)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 4770, in AISupport_DoPower
SetAIPriority(char,priority)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 1229, in SetAIPriority
js.Object_SetAttr(char, 'ai_priority',value)
RuntimeError: Object_SetAttr(): expects args {ssf}[/spoiler]
The problem also occurs to other random characters for no reason. I already ran ffxcc and tried different maps same results. OKay I hope this helps in any way.
cosmos, the issue is that you need to use a number value for the priority= parameter. Using 'medium' or 'high' causes these problems. You should use 50 or 100 instead. I think in the AI documentation, it may mention that you can use words instead of values but not for Priority. I'll make sure the AI documentation is updated accordingly.
Okay, this is a new one (for me, at any rate). I had the game working pretty well for a while. Then I tried to set up a Rumble Room mission (Skirmish Watch Mode), with Captain America and Iron Man vs. Loki and the Enchantress. As I started it up, it began the "Loading Objects" sequence, then, when it hit "137 of 141" it just stalled out--completely froze on me.
Here's the Script.log:
[spoiler]system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.251000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 9; branch = Public Beta 1
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Rumble Room play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1170513358.328000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
Loading m25skirmish.py v.3.2.0 build 6; branch = m25 branch 2
>>> C:\Documents and Settings\jmoser1\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Skirmish Watch Mode.py executed
>>> C:\Documents and Settings\jmoser1\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\jmoser1\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Skirmish Watch Mode.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', 'custom_vil_1', '------------', 'custom_vil_2', 'custom_vil_3', ))
TIME: 0.007201 for GetMissionVar
SkirmishSpawnEnemy: custom_vil_0 (iron man mk v, 1007)
AI: SetupAI() - setting ai for custom_vil_0_1 ('iron man mk v')
CUSTOMPOWERS: using power slot 1 for iron man mk v : iron uppercut
CUSTOMPOWERS: using power slot 2 for iron man mk v : magnetic pull
CUSTOMPOWERS: using power slot 3 for iron man mk v : armor protection
CUSTOMPOWERS: using power slot 4 for iron man mk v : magnetic throw
CUSTOMPOWERS: using power slot 5 for iron man mk v : area repulsor
CUSTOMPOWERS: using power slot 6 for iron man mk v : iron man armor
CUSTOMPOWERS: using power slot 7 for iron man mk v : repulsor ray
CUSTOMPOWERS: using power slot 8 for iron man mk v : iron punch
SkirmishSpawnEnemy: custom_vil_1 (captain america, 1005)
AI: SetupAI() - setting ai for custom_vil_1_2 ('captain america')
CUSTOMPOWERS: using power slot 9 for captain america : shield smash
CUSTOMPOWERS: using power slot 10 for captain america : american punch
CUSTOMPOWERS: using power slot 11 for captain america : shield bounce
CUSTOMPOWERS: using power slot 12 for captain america : avengers assemble!
CUSTOMPOWERS: using power slot 13 for captain america : shield throw
CUSTOMPOWERS: using power slot 14 for captain america : spinning punch
CUSTOMPOWERS: using power slot 15 for captain america : shield block
SkirmishSpawnEnemy: custom_vil_2 (enchantress, 1003)
AI: SetupAI() - setting ai for custom_vil_2_3 ('enchantress')
CUSTOMPOWERS: using power slot 16 for enchantress : eldritch kiss
CUSTOMPOWERS: using power slot 17 for enchantress : eldritch bolt
CUSTOMPOWERS: using power slot 18 for enchantress : heal
CUSTOMPOWERS: using power slot 19 for enchantress : eldritch kick
CUSTOMPOWERS: using power slot 20 for enchantress : paralyzing beam
CUSTOMPOWERS: using power slot 21 for enchantress : teleport self
CUSTOMPOWERS: using power slot 22 for enchantress : eldritch shield
SkirmishSpawnEnemy: custom_vil_3 (loki, 1006)
AI: SetupAI() - setting ai for custom_vil_3_4 ('loki')
CUSTOMPOWERS: using power slot 23 for loki : asgardian melee
CUSTOMPOWERS: using power slot 24 for loki : eldritch bolt
CUSTOMPOWERS: using power slot 25 for loki : teleportation
CUSTOMPOWERS: using power slot 26 for loki : asgardian punch
[/spoiler]
Okay, now it's gotten worse. Every time I try to start the game I just get a black screen, and everything freezes. No error message or anything. I have to reboot.
FF.log:
00:00:00.78: FF: --------------------------------------------------------------------------------
00:00:00.78: FF: Starting FFVTTR
00:00:00.78: FF: Build: SHIP, Version: 1.73396
00:00:00.78: FF: --------------------------------------------------------------------------------
00:00:01.45: FF: CInterpreter::init() completed
00:00:01.45: FF: Py_GetPath(.\System;.\System\PythonLib;.\Data\Missions\Scripts;)
00:00:01.45: FF: Py_GetProgramFullPath(C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\ffvt3r.exe)
00:00:03.71: FF: CRender: creating DX9 renderer
00:00:03.71: FF: CRender: trying to render in 32 bits
00:00:05.17: FF: DepthStencil is D3DFMT_D24S8
Script.log:
>>> system/startup.py executed
>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
okay thanks taskmaster that did helped! But later on my iron spider man AI was not working properly and I did not edit his m25ai file at all.So i ran him in the AI generator. I pit him against captain America and they had no problem finding each other in the park map. Spider man launched a sewer top at the captain. Spider man then decided to flee.Thats when my game froze up. I have been having this problem since the version prior to this. I gave him ropeswinger, he takes off, then he suddenly vanishes and the game crashes! I then looked into the script.log and see the errors coming from the captain? But as you can see the script ends when spider mans flees away, thats where the crash occurred heres what i got form my script.log [spoiler]
>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Starting ffx.py v. 3.2.0 build 9; branch = Public Beta 1
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Starting System Utilities 1.3
Starting General Utilities 1.0
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Height Check module 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1170517414.146000
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25skirmish.py v.3.2.0 build 6; branch = m25 branch 2
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.002921 for ai for avenger capamerica
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003772 for ai for iron spider-man
---- TIME: 0.015055 for AI_UpdateMapInfoStatic
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.004120 for ai for avenger capamerica
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003757 for ai for iron spider-man
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetHeight() non-fatal error:
template 'custom_vil_0' not found in list of template heights.
To detect approximate height, use
checkHeight(templateList, precise = 'no', repeat = 0, replace = 0, giants = 1, campaign = 0)
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.002933 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003294 for ai for iron spider-man
---- TIME: 0.014901 for AI_UpdateMapInfoStatic
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003769 for ai for iron spider-man
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.003662 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003809 for ai for iron spider-man
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.003782 for ai for avenger capamerica
---- TIME: 0.014464 for AI_UpdateMapInfoStatic
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003433 for ai for iron spider-man
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.003227 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003887 for ai for iron spider-man
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.003718 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
---- TIME: 0.029748 for AI_UpdateMapInfoStatic
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.004413 for ai for iron spider-man
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.002894 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
---- TIME: 0.016828 for ai for iron spider-man
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
---- TIME: 0.018507 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
TIME: 0.003927 for ai for iron spider-man
Template_GetMesh() fatal error: template 'custom_vil_0' not found
---- TIME: 0.027757 for AI_UpdateMapInfoStatic
AI: custom_vil_0_1:'avenger capamerica' hunting 'custom_vil_1_2'
TIME: 0.003574 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' hunting 'custom_vil_0_1'
---- TIME: 0.017251 for ai for iron spider-man
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' preparing to throw
TIME: 0.005892 for ai for iron spider-man
AI: custom_vil_0_1 overpowers his/her/its attack!
AI: custom_vil_0_1:'avenger capamerica' zzz4 attack on 'custom_vil_1_2'
TIME: 0.003024 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2 picking up _impobj_547
TIME: 0.002689 for ai for iron spider-man
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
---- TIME: 0.021591 for AI_UpdateMapInfoStatic
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_0_1:'avenger capamerica' move to 'custom_vil_1_2'
TIME: 0.009601 for ai for avenger capamerica
AI: custom_vil_1_2 pickup success on _impobj_547
AI: custom_vil_1_2 finding target 'custom_vil_0_1'
AI: custom_vil_1_2 tracking target 'custom_vil_0_1'
AI: custom_vil_1_2 throwing at custom_vil_0_1
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_0_1 overpowers his/her/its attack!
AI: custom_vil_0_1:'avenger capamerica' zzz4 attack on 'custom_vil_1_2'
TIME: 0.002764 for ai for avenger capamerica
Template_GetMesh() fatal error: template 'custom_vil_0' not found
---- TIME: 0.036918 for AI_UpdateMapInfoStatic
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' 'custom_vil_0_1'
TIME: 0.006238 for ai for iron spider-man
Template_GetMesh() fatal error: template 'custom_vil_0' not found
Template_GetMesh() fatal error: template 'custom_vil_0' not found
AI: custom_vil_1_2:'iron spider-man' ffx.OnLeapTo(target,char) travel away to 'custom_vil_0_1'
TIME: 0.005615 for ai for iron spider-man
[/spoiler]
I really think that requests for help with the AI should go in a different thread. This is distracting us from our task of removing bugs from this release.
Quote from: jmoser on February 03, 2007, 08:11:51 AM
Okay, now it's gotten worse. Every time I try to start the game I just get a black screen, and everything freezes. No error message or anything. I have to reboot.
FF.log:
00:00:00.78: FF: --------------------------------------------------------------------------------
00:00:00.78: FF: Starting FFVTTR
00:00:00.78: FF: Build: SHIP, Version: 1.73396
00:00:00.78: FF: --------------------------------------------------------------------------------
00:00:01.45: FF: CInterpreter::init() completed
00:00:01.45: FF: Py_GetPath(.\System;.\System\PythonLib;.\Data\Missions\Scripts;)
00:00:01.45: FF: Py_GetProgramFullPath(C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\ffvt3r.exe)
00:00:03.71: FF: CRender: creating DX9 renderer
00:00:03.71: FF: CRender: trying to render in 32 bits
00:00:05.17: FF: DepthStencil is D3DFMT_D24S8
Script.log:
>>> system/startup.py executed
>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
It's probably a corrupted powers.dat file. If you look in the ffx3 directory, there should be a powers.dat.bak file. Use that to replace the powers.dat file.
Quote from: Epimethee on January 31, 2007, 07:52:38 PM
Quote from: Dreaded Porcupine on January 31, 2007, 07:18:37 PM
How do you clean up powers.dat?
Not too sure when we can release a Public Beta 2.
So, for the moment, PM me an e-mail address and I'll send you the updated powers.dat. I hope it will make your FFX 3.2 experience a bit more enjoyable.
I tried the new powers.dat and the game still crashed. I was able to play 4 on 4 in AI skirmish watch mode for awhile before it crashed though (twice). I can start the game up again at least. It's better than it was. At least I didn't get that alert message this time.
Quote from: cosmos123 on February 03, 2007, 08:21:46 AM
okay thanks taskmaster that did helped! But later on my iron spider man AI was not working properly and I did not edit his m25ai file at all.So i ran him in the AI generator. I pit him against captain America and they had no problem finding each other in the park map. Spider man launched a sewer top at the captain. Spider man then decided to flee.Thats when my game froze up. I have been having this problem since the version prior to this. I gave him ropeswinger, he takes off, then he suddenly vanishes and the game crashes! I then looked into the script.log and see the errors coming from the captain? But as you can see the script ends when spider mans flees away, thats where the crash occurred heres what i got form my script.log
Is this a one time thing or does it happen all the time?
QuoteIt's probably a corrupted powers.dat file. If you look in the ffx3 directory, there should be a powers.dat.bak file. Use that to replace the powers.dat file.
I already did that, to fix the dreaded "CFastHeap" problem. Granted, it did seem to solve that problem, but now I'm not getting any kind of error message at all.
Quoteit wasn't until i dl'd taskmaster's fix on the yahoo group that things worked properly again.
Maybe I should try that. What yahoo group is it on?
Quote from: jmoser on February 03, 2007, 09:27:16 AM
QuoteIt's probably a corrupted powers.dat file. If you look in the ffx3 directory, there should be a powers.dat.bak file. Use that to replace the powers.dat file.
I already did that, to fix the dreaded "CFastHeap" problem. Granted, it did seem to solve that problem, but now I'm not getting any kind of error message at all.
Quoteit wasn't until i dl'd taskmaster's fix on the yahoo group that things worked properly again.
Maybe I should try that. What yahoo group is it on?
It looks like the game crashed on you while writing out the powers.dat file, so you now have a corrupted or incomplete version. Restoring the backup should temporarily fix the problem.
The yahoo group is FreedomForceX
I sent jmoser a copy of taskmaster's fix from the yahoo group. Lets see if that solves his problems. I suspect it will. I think he is having the same problems I was a few days ago.
Sorry I just thought this was the right place to post this. M25 yes this happens often, with characters with the attributes super-leaper and ropeswinger together. It usually happens when either the character leaps or ropeswings i think, they disappear into thin air. but i once was able to have the cinematic cam on them, they leap all the way to the top of the map and further until the buildings were as small as ants. weird huh?
Alright, to make getting hold of the fix easier, I've uploaded it to my own webspace and am making it available here (http://libertybay.freedomforceforever.com/ffx32publicbeta_dat_update.zip).
YAY! Thanks CWWBH! :thumbup: ffx3.2 is working like a charm now!
I believe I found a bug. I was playing just now the Allies mini-mod with a squad composed of Supercollider, Deja Vu, Man-Bot and a custom character. I used Deja Vu's irradiating beam to make Supercollider assume his temporary form. Everything working just fine up until then. However, after the sixty seconds passed, Supercollider, instead of morphing back to his normal form, simply disappeared. Even his portrait on the lower left side disappeared, like he was never on the squad to begin with.
Oh, still on the Accidental Change/Temporary Form topic, could anyone please explain to me how do I make it work? I made two custom characters just now (one with Accidental Change and the other with Temporary Form) and, when I accessed the FFXCC to adjust the Accidental Change character's form accordingly, the character with the Temporary Form wasn't selectable on the list. Only supercollider1 could be chosen.
Thanks.
Edit: Sorry for the lack of script.log. It's just that it's too long, therefore surpassing the maximum number of characters. I tried posting it on a second message but it still just won't fit.
I already PM'ed Xenolith on this, but I wanted to let everyone else know that the fixed attributes.dat and powers.dat files took care of all the problems I was having. In fact, I must say that with FFX 3.2 the game is working better than it ever has for me (although my completely uninstalling and reinstalling everything--twice--probably has something to do with that as well).
Quote from: guts on February 04, 2007, 08:07:55 AM
Oh, still on the Accidental Change/Temporary Form topic, could anyone please explain to me how do I make it work? I made two custom characters just now (one with Accidental Change and the other with Temporary Form) and, when I accessed the FFXCC to adjust the Accidental Change character's form accordingly, the character with the Temporary Form wasn't selectable on the list. Only supercollider1 could be chosen.
Thanks.
Accidental change uses the Involuntary Form attribute, not the Temporary Form attribute.
Shapeshifter => Temporary Form => Changes to another form or the original
Accidental Change => Involnutary Form => Reverts to Accidental Change form (your primary form)
I'm glad "the fix" worked, jmoser.
Here's a bug I don't remember seeing reported. I made a hero file for Doctor Doom, and gave him the attribute Private Army 3 (I don't know if this is relevant, but it was part of a combo attribute I created, one that also includes invulnerable 10, grim resolve, fast flier, level-headed, cosmic awareness and enhanced senses). I opened up the FFX Control Center and customized the "Minion" line so that he would always be surrounded with a group of Doombots (a separately created character). Then I went into the Rumble Room to play a game using him and, lo and behold, he had a private army of cops. I went back into the Control Center and there it said "cop" under "Minion." I changed it back to "doombot", did some other stuff with the game, and closed the Control Center, but next time I opened the Center there is was again--"cop."
By the way, I didn't have this problem with my hero file for Red Skull. I gave him the same attribute (not as part of a combo, though), and in the Control Center put "nazi_rifleman" in the "Minion" line, and I never had any problems with it. Might that be because the Nazi Rifleman is a built-in character instead of a custom?
This sounds a little like you might have had a different mod selected in the Control Centre when you selected doombots and saved. Check that first. It has to be the same one that is after the -game flag in the Target field for the shortcut you are using to start the game.
Meanwhile, post your script.log. Play just long enough for the miniors to show up and a few seconds to go by after. If it is still too long, there are instructions near the top of this thread on how to find the parts that will let us help you.
Okay, I managed to fix all of my previous FFX 2.3 errors by following examples here and reinstalling my FFvsT3R game and add-ons. Even used the .dat fix that was posted earlier which I never saw before until a few nights ago.
However, I never used the Trick Shot attribute before tonight and when I entered the Rumble Room I saw this:
(http://i30.photobucket.com/albums/c303/crimsonquill/error2.jpg)
Now the attribute works fine in game and the "items" disappear when you touch them like normal.. but I somehow can't figure out where the arrow nifs got mislinked to the wrong items. :blink: Anyone else encounter this before? And how can I fix this myself?
- CrimsonQuill
Wow! That's strange! This WAS working when I re-enabled the attribute.
I just checked, and the arrow1, arrow2, and arrow3 .nifs are the wrong ones. The arrow .nif that I added from Yellow Lantern is gone and I can't find another copy.
I guess someone will have to ask YL for another copy.
Do you merge the fixed .dats or copy them over the existing ones?
PS-- my current .dats are clean installs with EZFX and a few custom objects from maps. i have no custom characters, attributes or powers on them.
They copy over the ones in the FFX3 folder.
Hi guys and gals.
I started an arrow but never finished it. I did do the new nifs for the utility belt attribute. I believe Tommyboy did the arrow NIFs. Sorry I can't be of more help.
Sorry, I though it was you.
All I know is that SOMEBODY gave them to me.
Howdy guys, I'm happy to report that I haven't had any problems of note yet. The only thing that hasn't worked like a charm for me is a state swap. I set exile to be teleport for Dr. Fate, and every time he uses his power, the villans get exiled. I know that those things never work perfectly, so it's not a big deal.
The real reason I'm posting, is because I've been watching this thread, and I noticed something about a 'corrupted powers dat.' I downloaded the fixed files, but I have a question. I have already started work on something that I had been putting off until this release. I have already spent a good deal of time entering new powers and such. Cat said that these files can't be merged in, they have to replace the old ones. So, I suppose my question is, how vital is this fix? I'd lose a good deal of work if I had to overwrite. Thanks guys!
If you merge keep a copy of your old one, you should be able to merge you changes from the fix. Since the FROM .dat over rides the TO, you should go to the old one from the new one. The fixed powers SHOULD over write the corrupted ones.
Another, probably safer solution is to take the old file and strip away all the power except for the ones you added. You can safely merge that piece in with the corrected ones, as the corrupted powers should have gotten erased.
However, if you haven't had any problems with the game crashing on you, you may be able to put this fix off and just use the corrupted files. It's probably better if you fix them anyway.
Quote from: catwhowalksbyhimself on February 09, 2007, 01:30:48 PM
Sorry, I though it was you.
All I know is that SOMEBODY gave them to me.
Ahhhh-haaa! Took some digging thru my old cd-roms piled in my drawer here but I found an old archieve disc which happened to have the file we have been looking for.
Trick Shot Arrow.Nif Fix by Tommyboy - Available here: http://www.4shared.com/file/10378310/770d8ba2/arrow_ffx.html (http://www.4shared.com/file/10378310/770d8ba2/arrow_ffx.html)
That should allow you to scatch this issue off your list, Cat... as well as the FFX Team.
- Crimsonquill
Thanks Cat!
Thanks for the files, CromsonQuill. :)
I'm not sure if this was addressed, so I'll say it here.
I created my custom character, Madrox, the Multiple Man, with Accidental Cloning and the special Clone Self.
I can create clones just fine. However, there will be a point where they all lay flat on their face and continue to 'walk' that way. Their shadows look fine, but my character is literally dragging his face on the ground.
Also, (custom) characters with the same mesh end up doing the same thing together, synchronized. They all fall on their face together, or they all punch at the same time, or they all run in place.
I've only played rumble.
Any ideas on how to maybe fix that?
That isn't really an FFX issue. It's related to how the new game deals with meshes from the old game (and maybe graphics cards...). See this thread (http://freedomreborn.net/archive/index.php?topic=41056.0) for more on this and a couple potential workarounds.
Quote from: laughing paradox on February 11, 2007, 12:10:37 AM
Any ideas on how to maybe fix that?
As the community has talked about in the Technical Issues area... It's an error of the FFvsT3R graphics which causes these phantoms if multiple versions of the same character is used. You need to enter your Graphic Settings area and shut off all of the Building Shadows and reduce your Character shadow to 'blob'. That seems to solve this problem. Apparently, It's an issue with certain Graphics Cards that occured in the initial release.. however since there was no fix patch of any type released it's just a error that we work around (and hatefully live with).
- CrimsonQuill
Okay, after much fiddling around with several different characters it seems clear that, when used as part of a combo attribute, the various "Private Army" and "Summoner" attributes don't work as they should. That is, the minions involved keep reverting to their default positions ("cop" in the case of Private Army, various green things in the case of Summoner) every time the FFX Control Center is shut down.
As a test, in a Rumble Room battle using "Skirmish Watch Mode" I put Doctor Doom up against Dormammu. Doom has "Private Army 3" as part of a combo, and is supposed to be accompanied by a group of Doombots. Dormammu has "Summoner 4" as part of a combo, and is supposed to summon Mindless Ones. As usual, Doom was accompanied by an army of cops. Dormammu didn't use his summoning power.
Anyway, this is what I hope is the relevant portion of the script.log:
[spoiler]
=====================================
AI: custom_vil_1_2 overpowers his/her/its attack!
AI: custom_vil_1_2:'doctor doom' zzz16 attack on 'custom_vil_0_1'
####################### TIME: 0.497316 for ai for doctor doom
clearCarrierRegistration: clearing attribute 'powernulltoknockoutgascustom_vil_0_1' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_1_2' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'powernulltoknockoutgascustom_vil_0_1' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_1_2' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'powernulltoknockoutgascustom_vil_0_1' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_1_2' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'powernulltoknockoutgascustom_vil_0_1' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_1_2' for destroyed object 'mapinfocaliper3'
initAttribsForChar: working on custom_vil_0_1 (dormammu)
initAttribsForChar (dormammu): looking at attribute disciplined
initAttribsForChar (dormammu): looking at attribute dormammu
execInitAttrib: init ffqimmortal attribute inside ['dormammu', 'ffqimmortal', 'summoner4', 'firecontrol', 'sensitive', 'levelheaded'] combo
on custom_vil_0_1 of template custom_vil_0 (dormammu)
execInitAttrib: init summoner4 attribute inside ['dormammu', 'ffqimmortal', 'summoner4', 'firecontrol', 'sensitive', 'levelheaded'] combo
on custom_vil_0_1 of template custom_vil_0 (dormammu)
execInitAttrib: init firecontrol attribute inside ['dormammu', 'ffqimmortal', 'summoner4', 'firecontrol', 'sensitive', 'levelheaded'] combo
on custom_vil_0_1 of template custom_vil_0 (dormammu)
execInitAttrib: init sensitive attribute inside ['dormammu', 'ffqimmortal', 'summoner4', 'firecontrol', 'sensitive', 'levelheaded'] combo
on custom_vil_0_1 of template custom_vil_0 (dormammu)
execInitAttrib: init levelheaded attribute inside ['dormammu', 'ffqimmortal', 'summoner4', 'firecontrol', 'sensitive', 'levelheaded'] combo
on custom_vil_0_1 of template custom_vil_0 (dormammu)
initAttribsForChar (dormammu): looking at attribute puppetn
execInitAttrib: init puppetn attribute
on custom_vil_0_1 of template custom_vil_0 (dormammu)
initAttribsForChar (dormammu): looking at attribute puppetu
execInitAttrib: init puppetu attribute
on custom_vil_0_1 of template custom_vil_0 (dormammu)
initAttribsForChar (dormammu): looking at attribute unbeliever
initAttribsForChar: working on hero_0 (------------)
initAttribsForChar (------------): looking at attribute density control
initAttribsForChar: working on custom_vil_1_2 (doctor doom)
initAttribsForChar (doctor doom): looking at attribute flier
initAttribsForChar (doctor doom): looking at attribute doctordoom
execInitAttrib: init sensitive attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
execInitAttrib: init telepathy attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
execInitAttrib: init invulnerable2 attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
execInitAttrib: init grimresolve attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
execInitAttrib: init fastflier attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
execInitAttrib: init levelheaded attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
execInitAttrib: init privatearmy3 attribute inside ['doctordoom', 'sensitive', 'telepathy', 'invulnerable2', 'grimresolve', 'fastflier', 'levelheaded', 'privatearmy3'] combo
on custom_vil_1_2 of template custom_vil_1 (doctor doom)
initprivatearmy: custom_vil_1_2
initAttribsForChar (doctor doom): looking at attribute charged
initAttribsForChar (doctor doom): looking at attribute strange visitor
initAttribsForChar (doctor doom): looking at attribute temperature control
AI: SetupAI() - setting ai for custom_vil_1_2min0 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min1 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min2 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min3 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min4 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min5 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min6 ('cop')
AI: SetupAI() - setting ai for custom_vil_1_2min7 ('cop')
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
initAttribsForChar: working on custom_vil_1_2min0 (cop)
initAttribsForChar: working on custom_vil_1_2min1 (cop)
initAttribsForChar: working on custom_vil_1_2min2 (cop)
initAttribsForChar: working on custom_vil_1_2min3 (cop)
initAttribsForChar: working on custom_vil_1_2min4 (cop)
initAttribsForChar: working on custom_vil_1_2min5 (cop)
initAttribsForChar: working on custom_vil_1_2min6 (cop)
initAttribsForChar: working on custom_vil_1_2min7 (cop)[/spoiler]
Thanks for the report JMoser (well, actually, I'd really like to say "no thanks; we refuse this bug, it doesn't exist":P ). If you edit ffxcustom.py manually in Notepad (as usual, backup first) – and don't run the FFX Control Centre afterward – does it work?
Ex:
FFX_PRIVATEARMY_CUSTOM=[
["default","cop","",""],
["types","UMinion","UMinion2","UMinion3"],
["pan","bacchite_green","bacchite_red","bacchite_silver"],
["mistral","estelle","",""],
["recombatant","recombatant","",""],
]
Should now read
FFX_PRIVATEARMY_CUSTOM=[
["default","cop","",""],
["types","UMinion","UMinion2","UMinion3"],
["pan","bacchite_green","bacchite_red","bacchite_silver"],
["mistral","estelle","",""],
["recombatant","recombatant","",""],
["doctor doom","dejavu_extra","darkman_extra","dominion_extra"],
]
should get you the D-league of baddies.
Note: You may find that there is more than one FFX_PRIVATEARMY_CUSTOM list; this should be fixed in the next beta (due real soon, fingers crossed); edit either each one or just the last one.
All grades of Private Army should be working in and out of Combo attibutes, at least it is on my PC. There's a combo in the ffxmulti.py called negativezoneruler that has both summoner2 and privatearmy3. The character with that attribute keeps the privatearmy customizations after closing FFXCC and works in game. Try what Epimethee said and see if that works.
The problem is with Summoner. If you have summoner2 or 3 in a combo it doesn't even appear in FFXCC. But 1 or 4, yes. The reason is because there's only a summoner1 and summoner4 list in ffxattribs.py. This is related to the issue of the FFXCC limit. I found that summoner1 is only needed if summoner is not in a combo. But you need an entry for each grade in ffxattribs.py for it to appear in FFXCC if in a combo. summoner4, because it's new, needed it's own entry to even appear in FFXCC, even not included in a combo.
So, to be able to see Summoner in FFXCC if you have 2 or 3 in a combo, you can make an exact copy of the summoner1 line in ffxattribs.py, and put it right below the original summoner1 line (between summoner1 and summoner4), and change the 1 to the grade you need(2 or 3), and Save. Open FFXCC and you can make your changes, Export the File, and Save. You'll notice that the last line before the State Swaps customizations, Explosion Power ffx_strobe is missing. That's because the newly added summoner2 line exceeds the limit of things in FFXCC. If you remove the summoner2 line, it comes back. So we need to decide if it's worth replacing 2 existing customizable attribs with summoner2 and 3 so they can appear in FFXCC, if in combo attribs.
Once you add summoner2 or summoner3 to ffxattribs.py, 4 entries for summoner are made in ffxcustom.py 1 for each grade, even though they're all just called FFX_SUMMONER_CUSTOM. The same goes for FFX_PRIVATEARMY_CUSTOM, one for each grade. That's because there's privatearmy1, 2 and 3 in ffxattribs.py. Somehow, FFX knows which Private Army list to look at in ffxcustom.py depending on the grade. So the the duplicate PrivateArmy and Summoner entries in ffxcustom.py can't be removed because they'll just be created again when FFXCC is run.
Ouch.
Private army: Isn't it because there's only one common customization list for it?
And if that's the case (warning: Ép.'s being-right success ratio is currently at 0.001%, rounded down), shouldn't we do the same for Summoner? The benefit of having specific customizations for each grade of Summoner doesn't seem to outweight the added customization headache, IMO. Or is the Backward-Compatibility Man again rearing his head here?
Private Army: Yes. There's only one list in ffxdefault.py for these attribs. But, when FFXCC is run and saved, one list is created in ffxcustom.py for each entry in ffxattribs.py. But the character's customizations get saved to all lists in ffxcustom.py. I guess you could create a FFX_PRIVATEARMY1_CUSTOM, FFX_PRIVATEARMY2_CUSTOM, etc. (and the same for summoner) in ffxdefault.py and then you might get the customizations organized better in ffxcustom.py and not get duplicate character customizations, but that would require doing alot of work in ffx.py to edit the code for these attribs to look in the appropriate lists with alot of if statements depending on grade.
I can add summoner2 and 3 into ffxattribs.py and move the customizations for 2 attribs to ffxcustom2.py.
Quote from: TaskMasterX on February 14, 2007, 07:05:16 AMPrivate Army: Yes. There's only one list in ffxdefault.py for these attribs. But, when FFXCC is run and saved, one list is created in ffxcustom.py for each entry in ffxattribs.py. But the character's customizations get saved to all lists in ffxcustom.py. I guess you could create a FFX_PRIVATEARMY1_CUSTOM, FFX_PRIVATEARMY2_CUSTOM, etc. (and the same for summoner) in ffxdefault.py and then you might get the customizations organized better in ffxcustom.py and not get duplicate character customizations, but that would require doing alot of work in ffx.py to edit the code for these attribs to look in the appropriate lists with alot of if statements depending on grade.
I haven't really looked at the code, but I doubt the attribute supports multiple concurrent P.A. attributes, so grades would be useless, unless that aspect is also rewritten. Anyway, I don't see any reason to have different grades on the same character, except for campaign mode, when you might buy an improved attribute to get a better army.
I could see the rationale behind having different grades for Summoner, though, as one might potentially want to have a short-lived summon and a long-lived one (I'd still wouldn't think it worth the added complexity, but that's just me). However, from a quick glance, the code doesn't seem to support concurrent summoning levels:
def initsummoner(char,update,prestige,deathresponse):
if isMP():
return
FFX_ObjectSetAttr(char,'summonType',deathresponse)
FFX_ObjectSetAttr(char,'summonses',0)
FFX_ObjectSetAttr(char,'summonLevel',prestige)
(...)
Since every level is stored in the same variable, AFAIK, there ought to be only one FFX_SUMMONER_CUSTOM, in theory at least.
Here's an interesting one for y'all. I staged a Rumble Room battle in Skirmish Watch Mode between Spider-man and Sandman. It started off just fine, but after a while Spidey, while swinging away on his webline, just vanished. The game froze for between 30 seconds and a minute, then he reappeared. Then the same thing happened about a minute later. This went on for a while, then he vanished, this time for good, and the game froze completely (well, I got impatient and shut down after a few minutes had passed).
Here's the relevant detail from the script.log. [spoiler]####################### TIME: 0.186801 for ai for sandman
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_0_1' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_0_1' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_0_1' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'powernulltopullcustom_vil_0_1' for destroyed object 'mapinfocaliper3'
initAttribsForChar: working on hero_0 (------------)
initAttribsForChar (------------): looking at attribute density control
initAttribsForChar: working on custom_vil_1_2 (sandman)
initAttribsForChar (sandman): looking at attribute trueinvulnerability10
execInitAttrib: init invulnerable2 attribute inside ['trueinvulnerability10', 'invulnerable2', 'grimresolve'] combo
on custom_vil_1_2 of template custom_vil_1 (sandman)
execInitAttrib: init grimresolve attribute inside ['trueinvulnerability10', 'invulnerable2', 'grimresolve'] combo
on custom_vil_1_2 of template custom_vil_1 (sandman)
initAttribsForChar (sandman): looking at attribute fast healing
initAttribsForChar (sandman): looking at attribute solid skeleton
initAttribsForChar (sandman): looking at attribute heat sensitive
initAttribsForChar (sandman): looking at attribute slippery
execInitAttrib: init slippery attribute
on custom_vil_1_2 of template custom_vil_1 (sandman)
initAttribsForChar: working on custom_vil_0_1 (spider-man)
initAttribsForChar (spider-man): looking at attribute danger sense
initAttribsForChar (spider-man): looking at attribute wall climbing
initAttribsForChar (spider-man): looking at attribute jumper
initAttribsForChar (spider-man): looking at attribute spider
execInitAttrib: init acrobatic attribute inside ['spider', 'acrobatic', 'nimble', 'superleaper', 'heavylifter', 'ffqropeswinger', 'webslinger'] combo
on custom_vil_0_1 of template custom_vil_0 (spider-man)
execInitAttrib: init nimble attribute inside ['spider', 'acrobatic', 'nimble', 'superleaper', 'heavylifter', 'ffqropeswinger', 'webslinger'] combo
on custom_vil_0_1 of template custom_vil_0 (spider-man)
execInitAttrib: init superleaper attribute inside ['spider', 'acrobatic', 'nimble', 'superleaper', 'heavylifter', 'ffqropeswinger', 'webslinger'] combo
on custom_vil_0_1 of template custom_vil_0 (spider-man)
execInitAttrib: init heavylifter attribute inside ['spider', 'acrobatic', 'nimble', 'superleaper', 'heavylifter', 'ffqropeswinger', 'webslinger'] combo
on custom_vil_0_1 of template custom_vil_0 (spider-man)
execInitAttrib: init ffqropeswinger attribute inside ['spider', 'acrobatic', 'nimble', 'superleaper', 'heavylifter', 'ffqropeswinger', 'webslinger'] combo
on custom_vil_0_1 of template custom_vil_0 (spider-man)
execInitAttrib: init webslinger attribute inside ['spider', 'acrobatic', 'nimble', 'superleaper', 'heavylifter', 'ffqropeswinger', 'webslinger'] combo
on custom_vil_0_1 of template custom_vil_0 (spider-man)
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
2
1
AI: custom_vil_1_2:'sandman' hunting 'custom_vil_0_1'
TIME: 0.003836 for ai for sandman
AI: custom_vil_0_1:'spider-man' hunting 'custom_vil_1_2'
TIME: 0.003224 for ai for spider-man
---- TIME: 0.017126 for AI_UpdateMapInfoStatic
AI: custom_vil_0_1:'spider-man' ffx.OnLeapTo(target,char) travel away to 'custom_vil_1_2'
TIME: 0.005221 for ai for spider-man
[/spoiler]
Major Ouch. Loks like a critical bug in the Leaper code.
Is that what's going on? It seems we've heard about this before, but I don't recall if it was ever found to be an issue with superleaping or ropeswinging, or some interaction between them, or some interaction between them and the AI.
I would strongly suggest holding off any further reports until later today, because some of them could suddenly become obsolete.
(hint, hint)
And Beta two is now out! Please install that version before making any further bug reports.
Quote from: catwhowalksbyhimself on February 18, 2007, 01:35:02 PM
And Beta two is now out! Please install that version before making any further bug reports.
Thank you Catwhowalksbyhimself!!
uninstall previous beta?
I'm pretty sure that you can safely install on top of the old one. If I'm wrong, I'm sure someone will come around and correct me.
And Epi did all the work. I just uploaded it.
Quote from: stumpy on February 17, 2007, 04:25:11 PM
Is that what's going on? It seems we've heard about this before, but I don't recall if it was ever found to be an issue with superleaping or ropeswinging, or some interaction between them, or some interaction between them and the AI.
It may be the AI generating bad coordinates, though the coordinates of an enemy character should be safe. It may be that trying to superleap while in mid-air is a bad thing.
jmoser - if you are comfortable with it, try opening the m25ai file for the character and changing
'TSuperLeap()',
to
'TSuperLeap(situation="not flying")',
It's not a permanent fix, but it'll give us more information.
To clarify my last post, installing FFX 3.2 Beta 2 on top of 3.1 or earlier is a BAD idea.
Installing FFX 3.2 Beta 2 on top of Beta 1, on the other hand, is fine, and should pose no problems.
Quote from: catwhowalksbyhimself on February 19, 2007, 02:54:59 PM
To clarify my last post, installing FFX 3.2 Beta 2 on top of 3.1 or earlier is a BAD idea.
Installing FFX 3.2 Beta 2 on top of Beta 1, on the other hand, is fine, and should pose no problems.
Actually, you can install on top of 3.0 or 3.1. :) I've run tests installing from scratch, over 3.0 and over 3.2 Public Beta 1; the worst which should happen is some obsolete files being kept. Note that you'll have to merge back your customizations.
DISCLAIMER: Of course, I STRONGLY suggest you backup your FFX3 folder first, just in case. Remember that this is a beta and that the installer is done by a complete amateur. :wacko:
Alright then. The problem must be from people merging things, or trying to do so, from previous versions. That's not so easy to do, and often leads to problems.
Indeed; hence the EZFX auto-detection in the new beta; it should help at least those who never merged anything *manually*. (As an aside, it means that I don't need to keep the game's DATs so clean anymore... I can finally play the game with EZFX!)
Still, merging is a &?%$!
Quotejmoser - if you are comfortable with it, try opening the m25ai file for the character and changing
'TSuperLeap()',
to
'TSuperLeap(situation="not flying")',
It's not a permanent fix, but it'll give us more information.
Thanks, m25. I did as you suggested, and it seemed to take care of the problem. Apparently your suspicions are correct--it's a problem of getting superleaper and the various flight attributes to work together.
Sorry, but you kinda lost me... :wacko:
I have no custom attributes, powers, or resources. I have EZFX. I have LOTS of custom characters and objects.
I also install FFX to its main directory, then copy that as my working directory to maintain a clean install of FFX everytime it's updated.
As long as I back up my character.dat and object.dat (I keep copies anyway), I should be able to replace everything else?
In terms of EZFX, I can just use fx.dat.ezfx60.new and sounds.dat.ezfx60.new (without the "ezfx60.new" part)?
Sorry to come at you with such basic questions. The team has done an incredible job with this. Thanks in advance.
JM
Hi all, i backed all my my files prior to installing the new ffx patch. However, when i go to ffxCC i lost all my custom hero data. I remember it had something to do with ffxcustom.old or something but i can no longer find the thread here. Can someone help me?
QuoteSorry, but you kinda lost me... wacko
I have no custom attributes, powers, or resources. I have EZFX. I have LOTS of custom characters and objects.
I also install FFX to its main directory, then copy that as my working directory to maintain a clean install of FFX everytime it's updated.
As long as I back up my character.dat and object.dat (I keep copies anyway), I should be able to replace everything else?
In terms of EZFX, I can just use fx.dat.ezfx60.new and sounds.dat.ezfx60.new (without the "ezfx60.new" part)?
Sorry to come at you with such basic questions. The team has done an incredible job with this. Thanks in advance.
The new installer will automatically install the merged EZFX .dats if EZFX is already installed, so no need worry about that.
As for the rest, it sounds like you are doing things the right way, as far as trying to update things. A lot of people don't. So just keep doing what you're doing. If you were using the first beta, there shouldn't be any problems.
hey um, how can i restore my hero data in ffxCC? I Cannot find the answer to the problem anywhere. Since the old posts are down i cannot find my answer. It had something to do with the conversion code in the console or something like that. Does anyone know what im talking about?
What do you mean by hero data? FFX 3.2 doesn't make any changes to your HERO files themselves and doesn't change any of your old DAT files, which is where your built-in character info is stored, but it does rename some of those files as .old files and use newer versions. It also doesn't change any of your saved games (although mid-mission saves from older versions may not work in 3.2).
Be a bit more specific (and maybe give an example of a changed hero) and perhaps someone can help you.
He means customizations.
cosmos, did you Import All your customizations in FFXCC? Another possibility is that you need to run Stumpy's converter mentioned earlier if Public Beta2 is the first FFX3.2 beta you've installed.
Sorry i meant customizations. I imported all my customizations and everything is still blank on all characters. I installed beta 2 over beta 1. I remember there was a way to get the old customizations to work with the new ones. ffxcustom.old? am i supposed to do something to that file?
I think I found a few bugs.
The optional rules Minimum Range and Disable Player AI don't work. In Disable Player AI's case, it was said in the manual that it might not work, so it doesn't really count. Another optional rule that doesn't work very well is Clone Commands. Although it's possible to transfer control from a clone to another, the Gather command is not present.
Also, the isBuilding TargetType for Urban Dweller doesn't work for me.
Okay guys, a couple of things here: First, I'm trying to set up Sinestro for the DCU, and I've copied all of the FFX green objects, and renamed them 'ffx_yellow_whatever,' having identified a yellow skin or object. HOWEVER, when I go in to customize his plasma sculptor, they don't show up as options. I copied the FFX entries, so I'm not sure what I'm missing here.
Secondly, I have a custom attribute 'Power Ring,' and I imagine you can guess what it does. It includes plasma sculptor and summoner3. However, and I realize that this is a function of the limit on customization slots, I can only customize plasma sculptor and not summoner. This seems like it would be one of the more used and useful combinations, so perhaps it would be better served in one of the coveted slots. Just my two cents.
Barring that, should I just de-incorporate summoner, and include it seperately?
Quote from: cosmos123 on February 22, 2007, 04:31:51 AM
Sorry i meant customizations. I imported all my customizations and everything is still blank on all characters. I installed beta 2 over beta 1. I remember there was a way to get the old customizations to work with the new ones. ffxcustom.old? am i supposed to do something to that file?
ffxcustom.py.old is the backup file of your ffxcustom.py. To convert your customizations, load the game and open the console and then type:
import convertffxcustomdata
convertffxcustomdata.ConvertCustomizations()
Then quit the game, load FFXCC, and check and see if your customizations are there.
Quote from: guts on February 22, 2007, 05:19:00 AM
I think I found a few bugs.
The optional rules Minimum Range and Disable Player AI don't work. In Disable Player AI's case, it was said in the manual that it might not work, so it doesn't really count. Another optional rule that doesn't work very well is Clone Commands. Although it's possible to transfer control from a clone to another, the Gather command is not present.
Also, the isBuilding TargetType for Urban Dweller doesn't work for me.
I'll see if I can test these issues out and get back to you, guts.
Quote from: BentonGrey on February 23, 2007, 09:22:51 AM
Okay guys, a couple of things here: First, I'm trying to set up Sinestro for the DCU, and I've copied all of the FFX green objects, and renamed them 'ffx_yellow_whatever,' having identified a yellow skin or object. HOWEVER, when I go in to customize his plasma sculptor, they don't show up as options. I copied the FFX entries, so I'm not sure what I'm missing here.
Secondly, I have a custom attribute 'Power Ring,' and I imagine you can guess what it does. It includes plasma sculptor and summoner3. However, and I realize that this is a function of the limit on customization slots, I can only customize plasma sculptor and not summoner. This seems like it would be one of the more used and useful combinations, so perhaps it would be better served in one of the coveted slots. Just my two cents.
Barring that, should I just de-incorporate summoner, and include it seperately?
Not sure what's happening in the first issue, BG (I'll look into it as well) but the second issue will be solved by final release. Summoner will be in FFXCC if in a combo attrib. For now, you could temporarily, give him the Summoner attrib seperately, exit the game, load FFXCC and make the customizations and Save. Then load the game back up and remove the Summoner attrib but just make sure he still has the combo w/ Summoner and it should work.
Ahh, thanks for the workaround Taskmaster, and let me know if you figure out the first issue.
:EDIT: I just remembered that Summoner4 works, in combos, so nevermind, I would say that it's not really necessary to bump anything else off so that lesser grades will work.
:EDIT2: Ooookay, this has probably already been addressed, but if so, I have yet to see it. I've customized Sinestro's summoned minions, but every time I open up FFXedit, it reverts to the default. Is this a function of Summoner4 being part of a multi?
hey taskmasterx it worked! thanx!
Hello there, everyone! New here. I've been this lurking here for a while and never actually though about registering because I usually don't have much to say, but decided to make an exception here. Please watch over me from now on. =]
Anyway, staying on-topic, I just came across a bug with one of the stat-swaps.
I made a character (built-in, not custom) and gave him a 360 degree melee attack that inflicts low damage and has a very high chance of stunning the opponent. I then opened the FFXCC and made it so that attacks that cause stun, instead of stunning (duh!) the opponents, knocks them out. So, basically, I changed stun for knockout gas.
I then started a Rumble Room session to test this character's new attack.
The thing is, although the opponents indeed were knocked out when the attack succefully stunned them, they wouldn't get up no matter how much time I waited. I actually waited over fifteen minutes before I convinced myself that they wouldn't get up. Some enemies do get up if I get close to them; however, for some reason, they can't move anymore after getting up. They just stay stuck in the same place, and could only attack me if I walked close to them or they had ranged attacks and I was within range. Also, when I distanced myself from them, they stayed completelly still. Not even their idle animation played.
I hope I don't have to post the script.log, because this one is freaking huge.
Anyway, regardless of this problem, I'm loving the mod. I just can't stop playing it. Congratulatios to the developers and thanks a lot for your hard work.
Thanks for the report and the kind words, Blitzgott... and welcome aboard! :)
Knockout Gas:
OK, I've run some tests (and patched a rather obvious bug), but can't reproduce the locking issue you're experiencing, Blitzgott. Can you post the parts of your script.log which begin with a "Traceback error:" and the lines just before them?
(Mind you, this power swap currently seems to suffers from quite a few problems; I'm not sure if we should release it with the final 3.2.)
That's a pity. I rather like it, but do what you think best, Epi.
Epimethee: Thanks for the welcoming me! =] Anyway, regarding the .log, there is no "Traceback: error" writen on it. The closest thing is "Traceback (innermost last)". I'm posting the whole thing (which I though wouldn't fit, but did. WOHOO!) just so that nothing important is missed.
Here you go:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.249000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 7; branch = stumpy + TMX tweaks
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1172484184.609000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Campaign_ReadObjects() warning: object template <pat_dream_fog_effect> has more than one entry for attribute <animated>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <nazihq_storage_crate> has more than one entry for attribute <castShadow>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <ffx_limpetmine> has more than one entry for attribute <avoid>, values 0.000000 and 1000.000000
Campaign_ReadObjects() warning: object template <ffx_flames> has more than one entry for attribute <minForce>, values -1.000000 and 1000000.000000
Campaign_ReadObjects() warning: object template <dark_shaman> has more than one entry for attribute <prestige>, values 30.000000 and 50.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('thug_with_bat', 'thug_with_bat', 'thug_with_bat', 'thug_with_bat', ))
try to spawn thug_with_bat
sk.SpawnEnemy: energy for _skthug_with_bat01 (thug_with_bat) changed from 0 to 0
try to spawn thug_with_bat
sk.SpawnEnemy: energy for _skthug_with_bat02 (thug_with_bat) changed from 0 to 0
try to spawn thug_with_bat
sk.SpawnEnemy: energy for _skthug_with_bat03 (thug_with_bat) changed from 0 to 0
try to spawn thug_with_bat
sk.SpawnEnemy: energy for _skthug_with_bat04 (thug_with_bat) changed from 0 to 0
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=53
storing hero_0: id_1,-53
TIME: 0.006926 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skthug_with_bat01 ('thug_with_bat')
AI: SetupAI() - setting ai for _skthug_with_bat02 ('thug_with_bat')
AI: SetupAI() - setting ai for _skthug_with_bat03 ('thug_with_bat')
AI: SetupAI() - setting ai for _skthug_with_bat04 ('thug_with_bat')
AI: SetupAI() - setting ai for hero_0 ('durandel (rr)')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skthug_with_bat01 0 0
---- TIME: 0.016007 for AI_UpdateMapInfoStatic
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_0'
TIME: 0.006312 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_0'
TIME: 0.006428 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.006243 for ai for thug_with_bat
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.006173 for ai for thug_with_bat
AI: AISetRunning hero_0 to 0
TIME: 0.002820 for AI_UpdateMapInfoDynamic
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object 'mapinfocaliper3'
initAttribsForChar: working on _skthug_with_bat01 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on _skthug_with_bat02 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on _skthug_with_bat03 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on _skthug_with_bat04 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on hero_0 (durandel (rr))
initAttribsForChar (durandel (rr)): looking at attribute beautiful
initAttribsForChar (durandel (rr)): looking at attribute danger sense
initAttribsForChar (durandel (rr)): looking at attribute wall climbing
initAttribsForChar (durandel (rr)): looking at attribute combatskill
execInitAttrib: init combatskill attribute
on hero_0 of template custom_template_53 (durandel (rr))
initAttribsForChar (durandel (rr)): looking at attribute peakathl
execInitAttrib: init nimble attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on hero_0 of template custom_template_53 (durandel (rr))
execInitAttrib: init acrobatic attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on hero_0 of template custom_template_53 (durandel (rr))
execInitAttrib: init ffqlowjumper attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on hero_0 of template custom_template_53 (durandel (rr))
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001186 for ai for thug_with_bat
TIME: 0.001402 for ai for thug_with_bat
TIME: 0.001091 for ai for thug_with_bat
TIME: 0.001136 for ai for thug_with_bat
---- TIME: 0.013117 for AI_UpdateMapInfoStatic
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_0'
TIME: 0.003664 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_0'
TIME: 0.003272 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.002854 for ai for thug_with_bat
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003402 for ai for thug_with_bat
TIME: 0.001185 for ai for thug_with_bat
TIME: 0.001127 for ai for thug_with_bat
TIME: 0.001076 for ai for thug_with_bat
TIME: 0.001066 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_0'
TIME: 0.003719 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_0'
TIME: 0.003507 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.003863 for ai for thug_with_bat
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003569 for ai for thug_with_bat
---- TIME: 0.012854 for AI_UpdateMapInfoStatic
TIME: 0.001469 for ai for thug_with_bat
TIME: 0.001367 for ai for thug_with_bat
TIME: 0.001145 for ai for thug_with_bat
TIME: 0.001213 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_0'
TIME: 0.003634 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_0'
TIME: 0.003386 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.003189 for ai for thug_with_bat
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003461 for ai for thug_with_bat
---- TIME: 0.013131 for AI_UpdateMapInfoStatic
TIME: 0.002138 for ai for thug_with_bat
TIME: 0.001009 for ai for thug_with_bat
TIME: 0.001176 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_0'
TIME: 0.003356 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_0'
TIME: 0.003338 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.002817 for ai for thug_with_bat
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003386 for ai for thug_with_bat
TIME: 0.001383 for ai for thug_with_bat
TIME: 0.001154 for ai for thug_with_bat
---- TIME: 0.013544 for AI_UpdateMapInfoStatic
TIME: 0.001204 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_0'
TIME: 0.003211 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.003087 for ai for thug_with_bat
TIME: 0.001162 for ai for thug_with_bat
TIME: 0.001234 for ai for thug_with_bat
TIME: 0.001076 for ai for thug_with_bat
---- TIME: 0.012834 for AI_UpdateMapInfoStatic
TIME: 0.001384 for ai for thug_with_bat
TIME: 0.001288 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.002983 for ai for thug_with_bat
TIME: 0.001220 for ai for thug_with_bat
TIME: 0.001313 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.002751 for ai for thug_with_bat
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\liberty_bay\missions\scripts\ffx.py", line 27948, in makeknockedoutb
RegTimer('makeunknockedout',knockoutpower,0,char) #Chage the 20 to a different number for different lengths of knocked out
NameError: knockoutpower
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003198 for ai for thug_with_bat
TIME: 0.001211 for ai for thug_with_bat
TIME: 0.001149 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.003315 for ai for thug_with_bat
---- TIME: 0.016578 for AI_UpdateMapInfoStatic
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003452 for ai for thug_with_bat
TIME: 0.001365 for ai for thug_with_bat
TIME: 0.001126 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_0'
TIME: 0.003086 for ai for thug_with_bat
TIME: 0.001256 for ai for thug_with_bat
TIME: 0.001211 for ai for thug_with_bat
TIME: 0.001097 for ai for thug_with_bat
TIME: 0.001371 for ai for thug_with_bat
---- TIME: 0.013209 for AI_UpdateMapInfoStatic
TIME: 0.001243 for ai for thug_with_bat
TIME: 0.001172 for ai for thug_with_bat
TIME: 0.001366 for ai for thug_with_bat
addArrow _sk_arrow _skthug_with_bat02 0 0
TIME: 0.001325 for ai for thug_with_bat
TIME: 0.001100 for ai for thug_with_bat
TIME: 0.001060 for ai for thug_with_bat
TIME: 0.001168 for ai for thug_with_bat
TIME: 0.001101 for ai for thug_with_bat
TIME: 0.001404 for ai for thug_with_bat
---- TIME: 0.013201 for AI_UpdateMapInfoStatic
TIME: 0.001174 for ai for thug_with_bat
TIME: 0.001140 for ai for thug_with_bat
TIME: 0.001090 for ai for thug_with_bat
addArrow _sk_arrow _skthug_with_bat03 0 0
TIME: 0.001141 for ai for thug_with_bat
TIME: 0.001073 for ai for thug_with_bat
---- TIME: 0.013400 for AI_UpdateMapInfoStatic
TIME: 0.001369 for ai for thug_with_bat
TIME: 0.001073 for ai for thug_with_bat
TIME: 0.001531 for ai for thug_with_bat
TIME: 0.001076 for ai for thug_with_bat
addArrow _sk_arrow _skthug_with_bat04 0 0
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object '_skthug_with_bat01'
TIME: 0.001084 for ai for thug_with_bat
---- TIME: 0.013700 for AI_UpdateMapInfoStatic
TIME: 0.001425 for ai for thug_with_bat
AI: _skthug_with_bat04:'thug_with_bat' hunting 'hero_0'
TIME: 0.003242 for ai for thug_with_bat
---- TIME: 0.013265 for AI_UpdateMapInfoStatic
TIME: 0.001095 for ai for thug_with_bat
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object '_skthug_with_bat02'
TIME: 0.001079 for ai for thug_with_bat
TIME: 0.001138 for ai for thug_with_bat
---- TIME: 0.013246 for AI_UpdateMapInfoStatic
TIME: 0.001083 for ai for thug_with_bat
clearCarrierRegistration: clearing attribute 'stuntoknockoutgashero_0' for destroyed object '_skthug_with_bat03'
TIME: 0.001075 for ai for thug_with_bat
---- TIME: 0.013409 for AI_UpdateMapInfoStatic
TIME: 0.001090 for ai for thug_with_bat
TIME: 0.001217 for ai for thug_with_bat
TIME: 0.001142 for ai for thug_with_bat
---- TIME: 0.013398 for AI_UpdateMapInfoStatic
TIME: 0.001078 for ai for thug_with_bat
FFX_SkirmishCheck: calling BadGuys fn
cshelper: Cutscene [unknown] submitted for playing
cshelper: Now playing cutscene [unknown]
Step 1 of 2
---- TIME: 0.013399 for AI_UpdateMapInfoStatic
Step 2 of 2
cshelper: Cutscene [unknown] has ended
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed[/spoiler]
Quote from: guts on February 22, 2007, 05:19:00 AM
I think I found a few bugs.
The optional rules Minimum Range and Disable Player AI don't work. In Disable Player AI's case, it was said in the manual that it might not work, so it doesn't really count. Another optional rule that doesn't work very well is Clone Commands. Although it's possible to transfer control from a clone to another, the Gather command is not present.
Also, the isBuilding TargetType for Urban Dweller doesn't work for me.
Minimum Range works for me. I tested both the built-in Alien Warrior and my custom Hawkeye and they both used their ranged powers at point blank. Although I did see them attack other targets sometimes when I wasn't controlling them so, yes the Disable Player AI does seem to not be consistent, but as you said, it doesn't count, for now.
With Clone Commands, I never saw one clone command. Not Target nor Gather. I got no errors in my script.log either. I don't know what's up there.
isBuilding works for me as well. I used drawHealth as the effect and when I got close to a building, I'd heal. Are you sure it's not the effect that may not be working rather than the Type:isBuilding?
Quote from: BentonGrey on February 23, 2007, 09:22:51 AM
Okay guys, a couple of things here: First, I'm trying to set up Sinestro for the DCU, and I've copied all of the FFX green objects, and renamed them 'ffx_yellow_whatever,' having identified a yellow skin or object. HOWEVER, when I go in to customize his plasma sculptor, they don't show up as options. I copied the FFX entries, so I'm not sure what I'm missing here.
:EDIT: I just remembered that Summoner4 works, in combos, so nevermind, I would say that it's not really necessary to bump anything else off so that lesser grades will work.
:EDIT2: Ooookay, this has probably already been addressed, but if so, I have yet to see it. I've customized Sinestro's summoned minions, but every time I open up FFXedit, it reverts to the default. Is this a function of Summoner4 being part of a multi?
To see the new objects that you created in FFEdit Templates, you need to also add them to the FFX_COMMON_OBJECTS=[] list in ffxdefault.py. This will allow them to be in the drop-lists in FFXCC.
As for Summoner4 not keeping the customizations, I think I found the problem. Since there is more than one FFX_SUMMONER list in ffxcustom.py your summoner4 customizations are being saved in the last list and FFXCC is looking in the first list and therefore not displaying your customizations. The fix is to make your customizations and then Export the customizations. Save and Close FFXCC. Then re-open FFXCC, select the character and then Import the customizations. Importing seems to import the customizations to all lists of the same name in ffxcustom.py so this will copy the customizations to all Summoner lists and it should stay there in FFXCC. The only other way to fix it would be to make a seperate list for each Summoner grade and then have to edit ffx.py Summoner code to point to the right list. Much easier if you just exported and imported. I always Export my customizations everytime I make a change. Those py files aren't just for making distributing your hero files eaiser, but they are backups of your customizations.
Thanks for the log, Blitzgott (and you'd think that after a few years of creating countless Tracebacks, I'd have learned the exact label :P ). Very useful! I just realized the reason I couldn't reproduce your locking issue is that the bug I mentionned fixing earlier was in fact the one causing it: If you're swapping from a primary state attack (i.e., stun, hypnosis, panic, exile, rage, blank), the function calling the end of the gas state is aborted since the required global variable is missing.
Re: Summoner: Looks like a job for... a startup plugin. (where's that diamond-shaped "S" emoticon when you need it?) ;)
I.E.: If the second or third FFX_SUMMONER_CUSTOM lists contains an entry not in the first, copy it to the first. Obviously, this doesn't cover the issue of changing the values of an existing entry; or should we assume that the third list should always overwrite the first?
Quote from: Epimethee on February 26, 2007, 05:01:45 PM
Re: Summoner: Looks like a job for... a startup plugin. (where's that diamond-shaped "S" emoticon when you need it?) ;)
I.E.: If the second or third FFX_SUMMONER_CUSTOM lists contains an entry not in the first, copy it to the first. Obviously, this doesn't cover the issue of changing the values of an existing entry; or should we assume that the third list should always overwrite the first?
Sounds good. I think the the customizations in the 2nd - 4th lists would all be newer than what's in the 1st. The first list will only contain customizations for Summoner1 and whatever customizations that were copied over from one of the other lists using said plugin. When existing customizations are changed, it will be changed only in the appropriate list. So, those customizations would then be newer than what's in the 1st.
Question: would this plugin work nicely with the Import function of FFXCC? Since using the Import copies the customizations to all lists of the same name, will the plugin know which list is the right one and not make duplicate entries in the 1st list?
If import copies the customizations to each list, then that's great news as we'd only need to make every Summoner list indentical to the fourth. Unless I'm missing something?
Epimethee: Glad I could help. =]
I hope you will be able to fix all the problems knockout gas is having. I really like this feature and wouldn't like to see it gone. =/
And I found yet another bug!
I made a character with the field commander attribute set to give all allies an additional hero point and, if he died, his allies would be blanked to simulate that, without their field commander, they are clueless about what to do.
I then started a Rumble Room session to test it.
At first, it worked perfectly - all the allies gained the additional hero point like they were supposed to. However, when the field commander died, they didn't suffer any penatly other than the loss of the additional hero point. They weren't blanked or anything.
Other than blank, I tested this attribute with the blind and power nulled penalty, and it worked. I'll test the other penatlies later and let you now if there's a problem with any of them.
Meanwhile, the .log of the problem:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.249000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 7; branch = stumpy + TMX tweaks
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1172598189.562000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Campaign_ReadObjects() warning: object template <pat_dream_fog_effect> has more than one entry for attribute <animated>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <nazihq_storage_crate> has more than one entry for attribute <castShadow>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <ffx_limpetmine> has more than one entry for attribute <avoid>, values 0.000000 and 1000.000000
Campaign_ReadObjects() warning: object template <ffx_flames> has more than one entry for attribute <minForce>, values -1.000000 and 1000000.000000
Campaign_ReadObjects() warning: object template <dark_shaman> has more than one entry for attribute <prestige>, values 30.000000 and 50.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('darkman_blue', ))
try to spawn darkman_blue
sk.SpawnEnemy: energy for _skdarkman_blue01 (darkman_blue) changed from 3 to 3
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=53
storing hero_0: id_1,-53
numberStr=54
storing hero_1: id_2,-54
numberStr=55
storing hero_2: id_3,-55
TIME: 0.006856 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skdarkman_blue01 ('darkman_blue')
AI: SetupAI() - setting ai for hero_0 ('blitzgott')
AI: SetupAI() - setting ai for hero_1 ('durandel (rr)')
AI: SetupAI() - setting ai for hero_2 ('mister britain (rr)')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skdarkman_blue01 0 0
---- TIME: 0.016892 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.006630 for ai for darkman_blue
AI: AISetRunning hero_0 to 0
AI: AISetRunning hero_1 to 0
AI: AISetRunning hero_2 to 0
clearCarrierRegistration: clearing attribute 'powernulltoweakenhero_1' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'powernulltoweakenhero_1' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'powernulltoweakenhero_1' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'powernulltoweakenhero_1' for destroyed object 'mapinfocaliper3'
initAttribsForChar: working on _skdarkman_blue01 (darkman_blue)
initAttribsForChar (darkman_blue): looking at attribute charged
initAttribsForChar (darkman_blue): looking at attribute grim resolve
initAttribsForChar (darkman_blue): looking at attribute rapid metabolism
initAttribsForChar (darkman_blue): looking at attribute unbeliever
initAttribsForChar: working on hero_0 (blitzgott)
initAttribsForChar (blitzgott): looking at attribute rapid metabolism
initAttribsForChar (blitzgott): looking at attribute wall climbing
initAttribsForChar: working on hero_1 (durandel (rr))
initAttribsForChar (durandel (rr)): looking at attribute beautiful
initAttribsForChar (durandel (rr)): looking at attribute danger sense
initAttribsForChar (durandel (rr)): looking at attribute wall climbing
initAttribsForChar (durandel (rr)): looking at attribute combatskill
execInitAttrib: init combatskill attribute
on hero_1 of template custom_template_54 (durandel (rr))
initAttribsForChar (durandel (rr)): looking at attribute peakathl
execInitAttrib: init nimble attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on hero_1 of template custom_template_54 (durandel (rr))
execInitAttrib: init acrobatic attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on hero_1 of template custom_template_54 (durandel (rr))
execInitAttrib: init ffqlowjumper attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on hero_1 of template custom_template_54 (durandel (rr))
initAttribsForChar: working on hero_2 (mister britain (rr))
initAttribsForChar (mister britain (rr)): looking at attribute hot tempered
initAttribsForChar (mister britain (rr)): looking at attribute fearless
execInitAttrib: init fearless attribute
on hero_2 of template custom_template_55 (mister britain (rr))
initAttribsForChar (mister britain (rr)): looking at attribute density control
initAttribsForChar (mister britain (rr)): looking at attribute ffqfieldcommander
execInitAttrib: init ffqfieldcommander attribute
on hero_2 of template custom_template_55 (mister britain (rr))
initheroic('hero_0', update=0)
initheroic('hero_1', update=0)
initAttribsForChar (mister britain (rr)): looking at attribute invulnerable
execInitAttrib: init invulnerable attribute
on hero_2 of template custom_template_55 (mister britain (rr))
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001432 for ai for darkman_blue
---- TIME: 0.013165 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.003209 for ai for darkman_blue
TIME: 0.001432 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.003175 for ai for darkman_blue
---- TIME: 0.012723 for AI_UpdateMapInfoStatic
TIME: 0.001291 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.003555 for ai for darkman_blue
---- TIME: 0.013466 for AI_UpdateMapInfoStatic
TIME: 0.001466 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.002973 for ai for darkman_blue
TIME: 0.001325 for ai for darkman_blue
---- TIME: 0.016482 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.002927 for ai for darkman_blue
TIME: 0.001348 for ai for darkman_blue
---- TIME: 0.013878 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_2'
TIME: 0.003055 for ai for darkman_blue
TIME: 0.001322 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003028 for ai for darkman_blue
---- TIME: 0.013551 for AI_UpdateMapInfoStatic
TIME: 0.001399 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.002959 for ai for darkman_blue
---- TIME: 0.013451 for AI_UpdateMapInfoStatic
TIME: 0.001259 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003128 for ai for darkman_blue
TIME: 0.001278 for ai for darkman_blue
---- TIME: 0.013318 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.002946 for ai for darkman_blue
TIME: 0.001262 for ai for darkman_blue
---- TIME: 0.013223 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003328 for ai for darkman_blue
TIME: 0.001276 for ai for darkman_blue
---- TIME: 0.013373 for AI_UpdateMapInfoStatic
TIME: 0.001279 for ai for darkman_blue
TIME: 0.001154 for ai for darkman_blue
---- TIME: 0.013205 for AI_UpdateMapInfoStatic
TIME: 0.001405 for ai for darkman_blue
TIME: 0.001424 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003251 for ai for darkman_blue
---- TIME: 0.013270 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003716 for ai for darkman_blue
TIME: 0.001196 for ai for darkman_blue
---- TIME: 0.013634 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003258 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003804 for ai for darkman_blue
---- TIME: 0.015821 for AI_UpdateMapInfoStatic
TIME: 0.001557 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003713 for ai for darkman_blue
---- TIME: 0.013325 for AI_UpdateMapInfoStatic
TIME: 0.001242 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003320 for ai for darkman_blue
TIME: 0.001419 for ai for darkman_blue
---- TIME: 0.012994 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003344 for ai for darkman_blue
TIME: 0.001240 for ai for darkman_blue
---- TIME: 0.013453 for AI_UpdateMapInfoStatic
TIME: 0.001434 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003820 for ai for darkman_blue
TIME: 0.001260 for ai for darkman_blue
---- TIME: 0.013311 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003119 for ai for darkman_blue
TIME: 0.001229 for ai for darkman_blue
---- TIME: 0.013095 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003283 for ai for darkman_blue
TIME: 0.001394 for ai for darkman_blue
---- TIME: 0.012945 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003054 for ai for darkman_blue
TIME: 0.001346 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003858 for ai for darkman_blue
---- TIME: 0.012727 for AI_UpdateMapInfoStatic
TIME: 0.001338 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_1'
TIME: 0.003385 for ai for darkman_blue
---- TIME: 0.013039 for AI_UpdateMapInfoStatic
TIME: 0.001247 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002883 for ai for darkman_blue
TIME: 0.001266 for ai for darkman_blue
---- TIME: 0.013063 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003007 for ai for darkman_blue
TIME: 0.001226 for ai for darkman_blue
---- TIME: 0.013141 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002955 for ai for darkman_blue
TIME: 0.001262 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002984 for ai for darkman_blue
---- TIME: 0.013342 for AI_UpdateMapInfoStatic
TIME: 0.001480 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003131 for ai for darkman_blue
---- TIME: 0.012895 for AI_UpdateMapInfoStatic
TIME: 0.001221 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003273 for ai for darkman_blue
TIME: 0.001343 for ai for darkman_blue
---- TIME: 0.014121 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003712 for ai for darkman_blue
TIME: 0.001389 for ai for darkman_blue
---- TIME: 0.013323 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003160 for ai for darkman_blue
TIME: 0.001321 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003157 for ai for darkman_blue
---- TIME: 0.013319 for AI_UpdateMapInfoStatic
TIME: 0.001253 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003307 for ai for darkman_blue
---- TIME: 0.012883 for AI_UpdateMapInfoStatic
TIME: 0.001244 for ai for darkman_blue
TIME: 0.001269 for ai for darkman_blue
---- TIME: 0.013038 for AI_UpdateMapInfoStatic
TIME: 0.001168 for ai for darkman_blue
TIME: 0.001100 for ai for darkman_blue
---- TIME: 0.013159 for AI_UpdateMapInfoStatic
TIME: 0.001180 for ai for darkman_blue
TIME: 0.001135 for ai for darkman_blue
TIME: 0.001309 for ai for darkman_blue
---- TIME: 0.013102 for AI_UpdateMapInfoStatic
TIME: 0.001138 for ai for darkman_blue
TIME: 0.001149 for ai for darkman_blue
---- TIME: 0.012979 for AI_UpdateMapInfoStatic
TIME: 0.001142 for ai for darkman_blue
TIME: 0.001147 for ai for darkman_blue
TIME: 0.001136 for ai for darkman_blue
---- TIME: 0.013489 for AI_UpdateMapInfoStatic
TIME: 0.001356 for ai for darkman_blue
TIME: 0.001129 for ai for darkman_blue
---- TIME: 0.012889 for AI_UpdateMapInfoStatic
TIME: 0.001286 for ai for darkman_blue
TIME: 0.001255 for ai for darkman_blue
TIME: 0.001173 for ai for darkman_blue
---- TIME: 0.013080 for AI_UpdateMapInfoStatic
TIME: 0.001160 for ai for darkman_blue
TIME: 0.001137 for ai for darkman_blue
---- TIME: 0.013552 for AI_UpdateMapInfoStatic
TIME: 0.001097 for ai for darkman_blue
TIME: 0.001242 for ai for darkman_blue
TIME: 0.001334 for ai for darkman_blue
---- TIME: 0.013250 for AI_UpdateMapInfoStatic
TIME: 0.001057 for ai for darkman_blue
TIME: 0.001242 for ai for darkman_blue
---- TIME: 0.012949 for AI_UpdateMapInfoStatic
TIME: 0.001245 for ai for darkman_blue
TIME: 0.001407 for ai for darkman_blue
---- TIME: 0.013317 for AI_UpdateMapInfoStatic
TIME: 0.001190 for ai for darkman_blue
TIME: 0.001495 for ai for darkman_blue
TIME: 0.001276 for ai for darkman_blue
---- TIME: 0.013136 for AI_UpdateMapInfoStatic
TIME: 0.001147 for ai for darkman_blue
TIME: 0.001145 for ai for darkman_blue
---- TIME: 0.013279 for AI_UpdateMapInfoStatic
TIME: 0.001151 for ai for darkman_blue
TIME: 0.001521 for ai for darkman_blue
TIME: 0.001257 for ai for darkman_blue
---- TIME: 0.013157 for AI_UpdateMapInfoStatic
TIME: 0.001352 for ai for darkman_blue
TIME: 0.001328 for ai for darkman_blue
---- TIME: 0.013049 for AI_UpdateMapInfoStatic
TIME: 0.001165 for ai for darkman_blue
TIME: 0.001318 for ai for darkman_blue
TIME: 0.001150 for ai for darkman_blue
---- TIME: 0.013236 for AI_UpdateMapInfoStatic
TIME: 0.001169 for ai for darkman_blue
TIME: 0.001171 for ai for darkman_blue
---- TIME: 0.012797 for AI_UpdateMapInfoStatic
---- TIME: 0.013052 for AI_UpdateMapInfoStatic
FFX_SkirmishCheck: calling BadGuys fn
cshelper: Cutscene [unknown] submitted for playing
cshelper: Now playing cutscene [unknown]
Step 1 of 2
---- TIME: 0.013004 for AI_UpdateMapInfoStatic
Step 2 of 2
cshelper: Cutscene [unknown] has ended
---- TIME: 0.012806 for AI_UpdateMapInfoStatic[/spoiler]
Man... I just found out the strangest bug ever...
After reading the first post about characters with the super-leaper ability teleporting insead of jumping, I decided to make a few tests.
I used the Black_Panther_Gren, Male_Hulking_Thing and male_Hulking_Juggernaut meshes, and also the built-in Minuteman.
Since I was only testing, the only thing I gave to my custom characters (BP, Thing and Jugg) was Speed 10, Jumper and Super-Leaper.
I made the test on the city map.
Anyway, I tested the three custom characters first. After several tests, including jumping to top of bulding, to car, to posts and what have you, none of the three customs showed any problem. They would always walk towards the targed until they were within jumping range, and then jump. The jumping animation would play normally.
I then tested the Minuteman. Like all the other characters, I targeted an object that was very far from the character, just so that he would have to walk towards it before jumping. Minuteman, unlike the custom characters, didn't walk towards the targeted object until he reached jumping range before jumping; instead, he teleported to jumping range and then jumped. The jumping animation played normally, though.
I then, suspecting that it might be an attribute incompatibility problem, gave all the custom characters the same attributes as minuteman. Nothing. Only Minuteman teleported.
I then gave all of them the same stats of Minuteman. Now they started to teleport. I then started messing with the stats and, finally, what I found out is that characters with three or more points in strength teleport instead of jumping.
Call me crazy, but that's how it's going here.
Here's the .log of a test I made a strength 2 Black Panther:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.249000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 7; branch = stumpy + TMX tweaks
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1172616228.265000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Campaign_ReadObjects() warning: object template <pat_dream_fog_effect> has more than one entry for attribute <animated>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <nazihq_storage_crate> has more than one entry for attribute <castShadow>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <ffx_limpetmine> has more than one entry for attribute <avoid>, values 0.000000 and 1000.000000
Campaign_ReadObjects() warning: object template <ffx_flames> has more than one entry for attribute <minForce>, values -1.000000 and 1000000.000000
Campaign_ReadObjects() warning: object template <dark_shaman> has more than one entry for attribute <prestige>, values 30.000000 and 50.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('darkman_blue', ))
try to spawn darkman_blue
sk.SpawnEnemy: energy for _skdarkman_blue01 (darkman_blue) changed from 3 to 3
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=53
storing hero_0: id_1,-53
TIME: 0.007353 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skdarkman_blue01 ('darkman_blue')
AI: SetupAI() - setting ai for hero_0 ('black panther')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skdarkman_blue01 0 0
---- TIME: 0.016809 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.006167 for ai for darkman_blue
AI: AISetRunning hero_0 to 0
initAttribsForChar: working on _skdarkman_blue01 (darkman_blue)
initAttribsForChar (darkman_blue): looking at attribute charged
initAttribsForChar (darkman_blue): looking at attribute grim resolve
initAttribsForChar (darkman_blue): looking at attribute rapid metabolism
initAttribsForChar (darkman_blue): looking at attribute unbeliever
initAttribsForChar: working on hero_0 (black panther)
initAttribsForChar (black panther): looking at attribute superleaper
execInitAttrib: init superleaper attribute
on hero_0 of template custom_template_53 (black panther)
initAttribsForChar (black panther): looking at attribute jumper
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001094 for ai for darkman_blue
---- TIME: 0.012930 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003026 for ai for darkman_blue
TIME: 0.001205 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002917 for ai for darkman_blue
---- TIME: 0.012955 for AI_UpdateMapInfoStatic
TIME: 0.001049 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003096 for ai for darkman_blue
---- TIME: 0.013188 for AI_UpdateMapInfoStatic
TIME: 0.001184 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003374 for ai for darkman_blue
TIME: 0.001249 for ai for darkman_blue
---- TIME: 0.013353 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002856 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002867 for ai for darkman_blue
---- TIME: 0.014179 for AI_UpdateMapInfoStatic
TIME: 0.001065 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003121 for ai for darkman_blue
---- TIME: 0.013754 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002938 for ai for darkman_blue
---- TIME: 0.012899 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002922 for ai for darkman_blue
TIME: 0.001076 for ai for darkman_blue
TIME: 0.001690 for ai for darkman_blue
---- TIME: 0.013624 for AI_UpdateMapInfoStatic
TIME: 0.001311 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002758 for ai for darkman_blue
---- TIME: 0.013704 for AI_UpdateMapInfoStatic
TIME: 0.001268 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003342 for ai for darkman_blue
TIME: 0.001118 for ai for darkman_blue
---- TIME: 0.013156 for AI_UpdateMapInfoStatic[/spoiler]
And here's the .log of Black Panther with strength 3:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.249000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 7; branch = stumpy + TMX tweaks
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1172616429.234000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Campaign_ReadObjects() warning: object template <pat_dream_fog_effect> has more than one entry for attribute <animated>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <nazihq_storage_crate> has more than one entry for attribute <castShadow>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <ffx_limpetmine> has more than one entry for attribute <avoid>, values 0.000000 and 1000.000000
Campaign_ReadObjects() warning: object template <ffx_flames> has more than one entry for attribute <minForce>, values -1.000000 and 1000000.000000
Campaign_ReadObjects() warning: object template <dark_shaman> has more than one entry for attribute <prestige>, values 30.000000 and 50.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('darkman_blue', ))
try to spawn darkman_blue
sk.SpawnEnemy: energy for _skdarkman_blue01 (darkman_blue) changed from 3 to 3
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=53
storing hero_0: id_1,-53
TIME: 0.007971 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skdarkman_blue01 ('darkman_blue')
AI: SetupAI() - setting ai for hero_0 ('black panther')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skdarkman_blue01 0 0
---- TIME: 0.016676 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.005820 for ai for darkman_blue
AI: AISetRunning hero_0 to 0
initAttribsForChar: working on _skdarkman_blue01 (darkman_blue)
initAttribsForChar (darkman_blue): looking at attribute charged
initAttribsForChar (darkman_blue): looking at attribute grim resolve
initAttribsForChar (darkman_blue): looking at attribute rapid metabolism
initAttribsForChar (darkman_blue): looking at attribute unbeliever
initAttribsForChar: working on hero_0 (black panther)
initAttribsForChar (black panther): looking at attribute superleaper
execInitAttrib: init superleaper attribute
on hero_0 of template custom_template_53 (black panther)
initAttribsForChar (black panther): looking at attribute jumper
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001062 for ai for darkman_blue
---- TIME: 0.014007 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002715 for ai for darkman_blue
TIME: 0.001050 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003165 for ai for darkman_blue
---- TIME: 0.013435 for AI_UpdateMapInfoStatic
TIME: 0.001059 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003437 for ai for darkman_blue
---- TIME: 0.013432 for AI_UpdateMapInfoStatic
TIME: 0.001222 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002958 for ai for darkman_blue
TIME: 0.001454 for ai for darkman_blue
---- TIME: 0.012923 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003361 for ai for darkman_blue
TIME: 0.001053 for ai for darkman_blue
---- TIME: 0.013629 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003526 for ai for darkman_blue
TIME: 0.001084 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003273 for ai for darkman_blue
---- TIME: 0.013545 for AI_UpdateMapInfoStatic
TIME: 0.001575 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003425 for ai for darkman_blue
---- TIME: 0.013200 for AI_UpdateMapInfoStatic
TIME: 0.001161 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003340 for ai for darkman_blue
TIME: 0.001295 for ai for darkman_blue
---- TIME: 0.015040 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003341 for ai for darkman_blue
TIME: 0.001140 for ai for darkman_blue
---- TIME: 0.013053 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003201 for ai for darkman_blue
TIME: 0.001003 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003048 for ai for darkman_blue
---- TIME: 0.013507 for AI_UpdateMapInfoStatic
TIME: 0.001051 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002702 for ai for darkman_blue
---- TIME: 0.014027 for AI_UpdateMapInfoStatic
TIME: 0.001046 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003746 for ai for darkman_blue
TIME: 0.001159 for ai for darkman_blue
---- TIME: 0.013583 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003599 for ai for darkman_blue
TIME: 0.001568 for ai for darkman_blue
---- TIME: 0.013333 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003364 for ai for darkman_blue
TIME: 0.001088 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003661 for ai for darkman_blue
---- TIME: 0.013692 for AI_UpdateMapInfoStatic
TIME: 0.001042 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.004728 for ai for darkman_blue
---- TIME: 0.013932 for AI_UpdateMapInfoStatic
TIME: 0.001235 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003353 for ai for darkman_blue
TIME: 0.001089 for ai for darkman_blue
---- TIME: 0.013730 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.004226 for ai for darkman_blue
TIME: 0.001058 for ai for darkman_blue
---- TIME: 0.013600 for AI_UpdateMapInfoStatic
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003321 for ai for darkman_blue
TIME: 0.001078 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002761 for ai for darkman_blue
---- TIME: 0.013065 for AI_UpdateMapInfoStatic
TIME: 0.001047 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.003146 for ai for darkman_blue
---- TIME: 0.013317 for AI_UpdateMapInfoStatic
TIME: 0.001110 for ai for darkman_blue
AI: _skdarkman_blue01:'darkman_blue' hunting 'hero_0'
TIME: 0.002746 for ai for darkman_blue
TIME: 0.001322 for ai for darkman_blue
---- TIME: 0.012767 for AI_UpdateMapInfoStatic[/spoiler]
Another issue I'm having is that stat-swaps don't work for AI-controlled characters. I made a character (adequadelly named "guinea pig") with everything in one except endurance and speed, only a single attack that does no damage, and glass jaw, thin skinned and both the heroic and superheroic attributes, and started a Rumble Room session with Rogue (from the Liberty Bay mod) as my enemy and had him attacking me.
The times he hit me with Cripple and it was succeful, my character was hexed instead of suffering vertigo.
Here's the log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.249000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 7; branch = stumpy + TMX tweaks
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1172616890.687000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Campaign_ReadObjects() warning: object template <pat_dream_fog_effect> has more than one entry for attribute <animated>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <nazihq_storage_crate> has more than one entry for attribute <castShadow>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <ffx_limpetmine> has more than one entry for attribute <avoid>, values 0.000000 and 1000.000000
Campaign_ReadObjects() warning: object template <ffx_flames> has more than one entry for attribute <minForce>, values -1.000000 and 1000000.000000
Campaign_ReadObjects() warning: object template <dark_shaman> has more than one entry for attribute <prestige>, values 30.000000 and 50.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', ))
try to spawn custom_vil_0
sk.SpawnEnemy: energy for _skcustom_vil_001 (therogue_rumble) changed from 9 to 2
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=53
storing hero_0: id_1,-53
TIME: 0.007441 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skcustom_vil_001 ('therogue_rumble')
AI: SetupAI() - setting ai for hero_0 ('guinea pig')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skcustom_vil_001 0 0
---- TIME: 0.014847 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'therogue_rumble' hunting 'hero_0'
TIME: 0.006228 for ai for therogue_rumble
AI: AISetRunning hero_0 to 0
clearCarrierRegistration: clearing attribute 'stuntoweakspot_skcustom_vil_001' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hextovertigo_skcustom_vil_001' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'stuntoweakspot_skcustom_vil_001' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hextovertigo_skcustom_vil_001' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'stuntoweakspot_skcustom_vil_001' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hextovertigo_skcustom_vil_001' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'stuntoweakspot_skcustom_vil_001' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'hextovertigo_skcustom_vil_001' for destroyed object 'mapinfocaliper3'
initAttribsForChar: working on _skcustom_vil_001 (therogue_rumble)
initAttribsForChar (therogue_rumble): looking at attribute symbiote
execInitAttrib: init symbiote attribute
on _skcustom_vil_001 of template custom_vil_0 (therogue_rumble)
initAttribsForChar (therogue_rumble): looking at attribute cosmic chump
initAttribsForChar (therogue_rumble): looking at attribute wall climbing
initAttribsForChar (therogue_rumble): looking at attribute peakathl
execInitAttrib: init nimble attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on _skcustom_vil_001 of template custom_vil_0 (therogue_rumble)
execInitAttrib: init acrobatic attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on _skcustom_vil_001 of template custom_vil_0 (therogue_rumble)
execInitAttrib: init ffqlowjumper attribute inside ['peakathl', 'nimble', 'acrobatic', 'ffqlowjumper'] combo
on _skcustom_vil_001 of template custom_vil_0 (therogue_rumble)
initAttribsForChar (therogue_rumble): looking at attribute danger sense
initAttribsForChar: working on hero_0 (guinea pig)
initAttribsForChar (guinea pig): looking at attribute glassjaw
execInitAttrib: init glassjaw attribute
on hero_0 of template custom_template_53 (guinea pig)
initAttribsForChar (guinea pig): looking at attribute thin skinned
initAttribsForChar (guinea pig): looking at attribute heroic
initAttribsForChar (guinea pig): looking at attribute extra heroic
initAttribsForChar (guinea pig): looking at attribute blitzkrieg
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001083 for ai for therogue_rumble
---- TIME: 0.013187 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'therogue_rumble' hunting 'hero_0'
TIME: 0.003396 for ai for therogue_rumble
TIME: 0.001059 for ai for therogue_rumble
TIME: 0.001226 for ai for therogue_rumble
---- TIME: 0.012995 for AI_UpdateMapInfoStatic
TIME: 0.001255 for ai for therogue_rumble
TIME: 0.001179 for ai for therogue_rumble
---- TIME: 0.013286 for AI_UpdateMapInfoStatic
TIME: 0.001183 for ai for therogue_rumble
TIME: 0.001067 for ai for therogue_rumble
TIME: 0.001064 for ai for therogue_rumble
---- TIME: 0.012879 for AI_UpdateMapInfoStatic
TIME: 0.001064 for ai for therogue_rumble
TIME: 0.001551 for ai for therogue_rumble
---- TIME: 0.014402 for AI_UpdateMapInfoStatic
TIME: 0.001189 for ai for therogue_rumble
TIME: 0.001151 for ai for therogue_rumble
TIME: 0.001119 for ai for therogue_rumble
---- TIME: 0.013766 for AI_UpdateMapInfoStatic
TIME: 0.001061 for ai for therogue_rumble
TIME: 0.001451 for ai for therogue_rumble
---- TIME: 0.013138 for AI_UpdateMapInfoStatic
TIME: 0.001204 for ai for therogue_rumble
TIME: 0.001153 for ai for therogue_rumble
TIME: 0.001169 for ai for therogue_rumble
---- TIME: 0.013511 for AI_UpdateMapInfoStatic
TIME: 0.001248 for ai for therogue_rumble
TIME: 0.001071 for ai for therogue_rumble
---- TIME: 0.013429 for AI_UpdateMapInfoStatic
TIME: 0.001070 for ai for therogue_rumble
TIME: 0.001179 for ai for therogue_rumble
TIME: 0.001453 for ai for therogue_rumble
---- TIME: 0.013320 for AI_UpdateMapInfoStatic
TIME: 0.001082 for ai for therogue_rumble
TIME: 0.001075 for ai for therogue_rumble
---- TIME: 0.013201 for AI_UpdateMapInfoStatic
TIME: 0.001200 for ai for therogue_rumble
TIME: 0.001190 for ai for therogue_rumble
TIME: 0.001333 for ai for therogue_rumble
---- TIME: 0.013113 for AI_UpdateMapInfoStatic
TIME: 0.001266 for ai for therogue_rumble
TIME: 0.001061 for ai for therogue_rumble
---- TIME: 0.014614 for AI_UpdateMapInfoStatic
TIME: 0.001160 for ai for therogue_rumble
TIME: 0.001154 for ai for therogue_rumble
TIME: 0.001160 for ai for therogue_rumble
---- TIME: 0.013636 for AI_UpdateMapInfoStatic
TIME: 0.001297 for ai for therogue_rumble
TIME: 0.001136 for ai for therogue_rumble
---- TIME: 0.012889 for AI_UpdateMapInfoStatic
TIME: 0.001072 for ai for therogue_rumble
TIME: 0.001080 for ai for therogue_rumble
TIME: 0.001072 for ai for therogue_rumble
---- TIME: 0.012950 for AI_UpdateMapInfoStatic
TIME: 0.001068 for ai for therogue_rumble
TIME: 0.001266 for ai for therogue_rumble
---- TIME: 0.012766 for AI_UpdateMapInfoStatic
TIME: 0.001304 for ai for therogue_rumble
TIME: 0.001066 for ai for therogue_rumble
TIME: 0.001310 for ai for therogue_rumble
---- TIME: 0.013509 for AI_UpdateMapInfoStatic
TIME: 0.001064 for ai for therogue_rumble
TIME: 0.001198 for ai for therogue_rumble
---- TIME: 0.013321 for AI_UpdateMapInfoStatic
TIME: 0.001109 for ai for therogue_rumble
TIME: 0.001167 for ai for therogue_rumble
---- TIME: 0.013790 for AI_UpdateMapInfoStatic
TIME: 0.001190 for ai for therogue_rumble
TIME: 0.001252 for ai for therogue_rumble
TIME: 0.001213 for ai for therogue_rumble
---- TIME: 0.013339 for AI_UpdateMapInfoStatic
TIME: 0.001195 for ai for therogue_rumble
TIME: 0.001084 for ai for therogue_rumble
---- TIME: 0.012896 for AI_UpdateMapInfoStatic
TIME: 0.001097 for ai for therogue_rumble
TIME: 0.001225 for ai for therogue_rumble
TIME: 0.001155 for ai for therogue_rumble
---- TIME: 0.013281 for AI_UpdateMapInfoStatic
TIME: 0.001288 for ai for therogue_rumble
TIME: 0.001176 for ai for therogue_rumble
---- TIME: 0.012855 for AI_UpdateMapInfoStatic
TIME: 0.001197 for ai for therogue_rumble
TIME: 0.001156 for ai for therogue_rumble
TIME: 0.001074 for ai for therogue_rumble
---- TIME: 0.013152 for AI_UpdateMapInfoStatic
TIME: 0.001076 for ai for therogue_rumble
TIME: 0.001156 for ai for therogue_rumble
---- TIME: 0.013018 for AI_UpdateMapInfoStatic
TIME: 0.001426 for ai for therogue_rumble
TIME: 0.001192 for ai for therogue_rumble[/spoiler]
And no, it's not a problem with the stat-swap because I tested it by choosing Rogue as my character and guinea pig as my enemy and it worked.
Well, that's all I have for now. I'll keep playing and let y'all know if I find anything else.
Note: Sorry for the triple post, but everything wouldn't fit in just one.
Quote from: Epimethee on February 27, 2007, 07:14:29 AM
If import copies the customizations to each list, then that's great news as we'd only need to make every Summoner list indentical to the fourth. Unless I'm missing something?
Here's the test I ran:
1st, I created a ffx3 folder that is v3.12a and then imported my customizations so the ffxcustom.py would have them.
2nd, I installed FFX3.2PB2 on top of the ffx3 folder. I did not open FFXCC.
3rd, I loaded the game, opened the console, and ran Stumpy's conversion. Then I quit the game.
4th, I opened FFXCC and saw that my customizations were there for Summoner. I then clicked Save and closed FFXCC.
5th, I looked at the ffxcustom.py after each step to see what was changed and after Saving in FFXCC (Step 4), 2 FFX_SUMMONER_CUSTOM=[] lists were created, both being identical. In each step prior, there was only one list. The first list is for Summoner1-3, while the last is for Summoner4.
Now, if someone changes their customizations for Summoner4 or creates a new character with Summoner4 and customizes them in FFXCC and Saves, it saves the new customizations to the last list. When FFXCC is opened back up it reads from the 1st list and therefore it seems like FFXCC didn't save the data, even though it did.
Another issue has come up about Summoner 2 and 3 not appearing in FFXCC if they are in a Combo Attribute. To make them appear I added them to the ffxattribs.py along with summoner1 and summoner4, but now instead of just 2 FFX_SUMMONER_CUSTOM=[] lists, there are 4 created when you Save in FFXCC. Now, if I want to create or change a character's customizations that has Summoner 2 or 3 (whether there in a combo attrib or not) in FFXCC, it saves the changes to the appropriate list (the 2nd or 3rd). So, now the ffxcustom.py has 4 Summoner lists with all four having the customizations for my character, but only one of them has the most recent info. How will the plugin determine which one of the 4 lists has the data to copy to the 1st list, overwriting the one that might already be there.
I found that after you make the customizations to your Summoner2, 3, or 4 character in FFXCC, you only need to click the Export File, then the Import File, and Save. You don't need to close and reopen FFXCC after Exporting like I mentioned in the previous post. This copies the newly changed or created customizations to all lists in ffxcustom.py. Only two extra clicks to get your customizations for only these attibutes (Summoner2-4) saved correctly.
Another bug If found:
Characters with the combat skill attribute, if they happen to be ko'd, lose the attack bonus when they regain consciouness by way of spending an hero point.
I won't be posting the script.log because, unfortunately, it doesn't fit. =/
The script isn't really necessary in this case. The code's working exactly as it was meant to, but we didn't put anything in there to account for resurrections.
I'm getting a crash-to-desktop every time I try to run a Rumble Room session. It's quite likely I've messed something up myself, since I did a lot of tinkering and DAT-merging to get all my old customizations transferred over. But if someone can figure out the specific cause, I'd be grateful. Here's my script.log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1173118692.937000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
>>> C:\Documents and Settings\J. Kevin Carrier\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\J. Kevin Carrier\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\J. Kevin Carrier\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', 'custom_vil_1', ))
try to spawn custom_vil_0
try to spawn custom_vil_1
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_BERLIN'
initialising FFX: skirmish=1
numberStr=93
storing hero_0: id_1,-93
ReadHeroIndexData: trouble reading or evaluating data from <c:\program files\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex: Making index <c:\program files\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex: Complex not set for kid. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex: Complex not set for nick_craft_civ. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex: Complex not set for kid2. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex warning: <sky2> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex: Complex not set for clint_coltrane_civ. Run datfiles.Campaign_SetMissingComplexAttribs()
[/spoiler]
Okay guys, this has been remarkably stable for me, and I have had zero errors until I started tinkering, so I imagine that whatever is going on with my game is my fault. I've been working on converting FF1 maps, and the first couple crashes I had were on those, so I figured that they were the results of my incompetence, or other things that I have since fixed. So, today I was playing through the EZScript 'On Patrol' (which is an absolute BLAST, by the way guys!) and after a good long time playing, it crashed on me as I faced the Joker. I can't do as you asked, and post the first part of the log down to the attributes, as it is over the post limit, but here is the error:
[spoiler]initAttribsForChar: working on m25obj_12 (killer_croc)
initAttribsForChar (killer_croc): looking at attribute claws
initAttribsForChar (killer_croc): looking at attribute weak minded
initAttribsForChar (killer_croc): looking at attribute cold blooded
initAttribsForChar (killer_croc): looking at attribute reptile
execInitAttrib: init unheroic attribute inside ['reptile', 'unheroic', 'jumper', 'bezerker', 'fasthealing'] combo
on m25obj_12 of template custom_vil_0 (killer_croc)
execInitAttrib: init jumper attribute inside ['reptile', 'unheroic', 'jumper', 'bezerker', 'fasthealing'] combo
on m25obj_12 of template custom_vil_0 (killer_croc)
Traceback (innermost last):
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 938, in initAttribsEvent
initAttribsForChar(event.object,event.user)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 892, in initAttribsForChar
execInitAttrib(char, component, update, combo=attribute, multi=multi)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 920, in execInitAttrib
execInitAttrib2(char, attribute, init)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 930, in execInitAttrib2
exec init
File "<string>", line 1, in ?
NameError: initjumper
initAttribsForChar: working on m25obj_14 (civilian_female)
AI: AISetRunning m25obj_12 to 0
AI: AISetRunning m25obj_14 to 0[/spoiler]
If I'm understanding this right, there's some kind of problem with Killer Crock?
Quote from: JKCarrier on March 05, 2007, 10:36:08 AM
I'm getting a crash-to-desktop every time I try to run a Rumble Room session. It's quite likely I've messed something up myself, since I did a lot of tinkering and DAT-merging to get all my old customizations transferred over. But if someone can figure out the specific cause, I'd be grateful. Here's my script.log:
You can try
- running the control centre again
- running datfiles.Campaign_SetMissingComplexAttribs() from the console
- running the 'power id' rumble room mission (whose name escapes me at the moment)
Unfortunately, it is likely a problem with the dat file merging you did, and you'll have to start again. Do them one at a time if necessary and keep backups.
<bad fix removed>
Also, can JUMPER be part of a combo attrib? I didn't think it could...
I'm afraid that was over my head, M25. Let me make sure I understand, I am to open FFX.py, and find that function, replacing what is there with the code you have?
Stumpy, the text includes it, but says that 'it's only a rough approximation, since it uses clumsy jumper.' So, should I have clumsy jumper included instead of jumper?
Quote from: BentonGrey on March 06, 2007, 02:57:55 PM
I'm afraid that was over my head, M25. Let me make sure I understand, I am to open FFX.py, and find that function, replacing what is there with the code you have?
Stumpy, the text includes it, but says that 'it's only a rough approximation, since it uses clumsy jumper.' So, should I have clumsy jumper included instead of jumper?
Actually, stumpy's right. I removed the code I posted since it might have caused other problems.
It looks like jumper inside of a combo is not supported. Give him jumper outside of a combo or use one of the other jumper-style attributes.
Quote from: M25 on March 06, 2007, 02:15:17 PM
Unfortunately, it is likely a problem with the dat file merging you did, and you'll have to start again. Do them one at a time if necessary and keep backups.
I figured as much. Thanks!
Okey doke M25, I gotcha' loud and clear.
On merging: If you use the usual method for merging (i.e., copy your old customized DAT and merge from it to the new default DAT, you're bound to have problems, as old invalid entries in your customized DAT will overwrite things changed/corrected in the new default DAT. It is better to merge FROM the new file TO your old customized file.
(The ideal would be to create a backup file including only the entries you customized so merging won't carry over obsolete entries, but for most DAT types that's usually not big enough an issue to bother with.)
After much trial and error, I think I've isolated the cause of my problem. Apparently, there's something in Renegade's pack of converted FF1 maps that FFX doesn't like. I can install & play them fine in regular FFVTTR, but if I merge the objects.dat into FFX, I get the crash-to-the-desktop (even if I'm not trying to play on one of the converted maps). And yes, I was using the method Epimethee describes above, where you merge "backwards" and then "forwards".
Has anyone else run into this problem?
Yeah, I have JKC, but after doing the full conversion that his tutorial describes, I didn't have that problem.
Okay, got another CTD playing 'On Patrol.' I was playing with two built-ins against a number of built-in villains. The first odd thing that happened was, after hitting the first enemy just once (with a stasis attack) he disappeared and the next encounter triggered. Here is my script.log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Loading m25minimod.py v.3.2.0 build 6; branch = m25 branch 2
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1141782544.656000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Loading m25story.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25pstory.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25skirmish.py v.3.2.0 build 6; branch = m25 branch 2
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\MiniMod On Patrol.py executed
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
MISSION: EZScript MiniMod/Campaign Precache.
PSTORY: {'name': 'On Patrol', 'encounters': [{'marker': 'encounter', 'type': 'None', 'timeofday': 'none', 'required_map': [], 'trigger': [], 'next': ['Random Encounter', 'Random Encounter', 'Random Encounter'], 'objectives': [], 'parameters': [], 'name': 'Random Start', 'cutscenes': [], 'pre': []}, {'marker': 'encounter', 'type': 'None', 'timeofday': 'none', 'required_map': [], 'trigger': [], 'next': ["Story_RandomListElement(['Fight', 'Fight', 'Fight', 'Fight', 'Mugging', 'Hunt', 'Snatch and Grab'])"], 'objectives': [], 'parameters': [], 'name': 'Random Encounter', 'cutscenes': [], 'pre': []}, {'marker': 'encounter', 'type': 'Fight', 'timeofday': 'none', 'required_map': [], 'trigger': [], 'next': ['Random Encounter'], 'objectives': [], 'parameters': [], 'name': 'Fight', 'villains': ['Random'], 'cutscenes': [{'replace': [['villain', 'villain']], 'name': 'Alert', 'required': [], 'priority': 1, 'cutscene': ["CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'villain\', "You\'ve interferred with me for the last time.", force=0)']}, {'replace': [['hero', 'hero']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('hero', 'And here I thought this would be a nice quiet night.', force=0)"]}, {'replace': [['hero', 'hero'], ['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'hero\', "I\'m afraid I\'m going to have to take you in.", force=0)', 'CS_Speak(\'villain\', "You\'re welcome to try.", force=0)']}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'villain\', "Can\'t a villain get a moment\'s peace?", force=0)']}, {'replace': [['hero', 'hero']], 'name': 'End', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'hero\', "And that\'s why evil never wins.", force=0)']}, {'replace': [['hero', 'hero']], 'name': 'End', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('hero', 'Thanks for the workout.', force=0)"]}, {'replace': [['hero', 'hero']], 'name': 'End', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'hero\', "I\'m taking you in.", force=0)']}, {'replace': [['hero', 'hero']], 'name': 'End', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'hero\', "I\'ll just leave you for the police.", force=0)']}], 'pre': []}, {'marker': 'encounter', 'type': 'Save Civilian', 'timeofday': 'none', 'required_map': [], 'trigger': [], 'next': ['Random Encounter'], 'objectives': [], 'parameters': [['allies', 'civilian_female']], 'name': 'Mugging', 'villains': ['Random'], 'cutscenes': [{'replace': [['villain', 'villain']], 'name': 'Alert', 'required': [], 'priority': 1, 'cutscene': ["CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]}, {'replace': [['villain', 'villain'], ['ally', 'ally'], ['hero', 'hero']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('villain', 'Why do you always have to interfere?', force=0)", "CS_TurnTo('ally', 'hero')", "CS_Speak('ally', 'Help!', force=0)", "CS_Speak('hero', 'Unhand her at once!', force=0)"]}, {'replace': [['ally', 'ally']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'ally\', "They\'re after me! Do something!", force=0)']}, {'replace': [['villains', 'villain'], ['ally', 'ally']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('villains', 'Just hand it over and no one gets hurt.', force=0)", 'CS_Speak(\'ally\', "Won\'t someone save me?", force=0)']}, {'replace': [['ally', 'ally']], 'name': 'AllyThanksHero', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('ally', 'Thank you.', force=0)"]}], 'pre': []}, {'marker': 'encounter', 'type': 'Hunt', 'timeofday': 'none', 'required_map': [], 'trigger': [], 'next': ['Random Encounter'], 'objectives': [], 'parameters': [], 'name': 'Hunt', 'villains': ['Random'], 'cutscenes': [{'replace': [['villain', 'villain']], 'name': 'Alert', 'required': [], 'priority': 1, 'cutscene': ["CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Start()', "CS_Camera('villain', dist=-160, yaw=0)", "CS_Speak('villain', 'There you are.', force=0)", 'CS_End()']}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('villain', 'You will suffer my wrath.', force=0)"]}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('villain', 'Well hellllloooo.', force=0)"]}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'villain\', "I\'ve been looking for you, hero.", force=0)']}], 'pre': []}, {'marker': 'encounter', 'type': 'Snatch', 'timeofday': 'none', 'required_map': [], 'trigger': [], 'next': ['Random Encounter'], 'objectives': [], 'parameters': [['allies', 'civilian_female']], 'name': 'Snatch and Grab', 'villains': ['Random'], 'cutscenes': [{'replace': [['villain', 'villain']], 'name': 'Alert', 'required': [], 'priority': 1, 'cutscene': ["CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'villain\', "I\'ve got the goods. Now to make my getaway.", force=0)']}, {'replace': [['hero', 'hero'], ['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('hero', 'Hold it right there.', force=0)", "CS_Speak('villain', 'You think you can catch me, hero?', force=0)"]}, {'replace': [['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'villain\', "What\'s a little petty larceny?", force=0)']}, {'replace': [['hero', 'hero'], ['villain', 'villain']], 'name': 'Start', 'required': [], 'priority': 1, 'cutscene': ['CS_Speak(\'hero\', "Crime doesn\'t pay.", force=0)', 'CS_Speak(\'villain\', "Not with you around it doesn\'t.", force=0)']}, {'replace': [['hero', 'hero']], 'name': 'HeroGetsItem', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('hero', 'I should return this to its rightful owner.', force=0)"]}, {'replace': [['ally', 'ally']], 'name': 'ItemReturned', 'required': [], 'priority': 1, 'cutscene': ["CS_Speak('ally', 'Thank you so much.', force=0)"]}], 'pre': []}], 'start': []}
PSTORY: {'On Patrol': {'encounters': {'Fight': {'next': ['Random Encounter'], 'required_map': [], 'timeofday': 'none', 'action': ['DoEncFight(villains = [\'Story_GetRandomUserEnemy()\'], cutscenes = [[\'alertcs\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', "CS_AddArrow(\'villainarrow\', \'villain\', arrow_type=js.ARROW_YELLOW)"]]], [\'startcs\', [\'cslist\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'villain\\\', "You\\\'ve interferred with me for the last time.", force=0)\']], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\']], [\'cutscene\', "CS_Speak(\'hero\', \'And here I thought this would be a nice quiet night.\', force=0)"]], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\'], [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'hero\\\', "I\\\'m afraid I\\\'m going to have to take you in.", force=0)\', \'CS_Speak(\\\'villain\\\', "You\\\'re welcome to try.", force=0)\']], [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'villain\\\', "Can\\\'t a villain get a moment\\\'s peace?", force=0)\']]]], [\'endcs\', [\'cslist\', [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\']], [\'cutscene\', \'CS_Speak(\\\'hero\\\', "And that\\\'s why evil never wins.", force=0)\']], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\']], [\'cutscene\', "CS_Speak(\'hero\', \'Thanks for the workout.\', force=0)"]], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\']], [\'cutscene\', \'CS_Speak(\\\'hero\\\', "I\\\'m taking you in.", force=0)\']], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\']], [\'cutscene\', \'CS_Speak(\\\'hero\\\', "I\\\'ll just leave you for the police.", force=0)\']]]]], marker = \'encounter\')']}, 'Random Encounter': {'timeofday': 'none', 'next': ["Story_RandomListElement(['Fight', 'Fight', 'Fight', 'Fight', 'Mugging', 'Hunt', 'Snatch and Grab'])"], 'required_map': []}, '__end__': {'action': ["ff.Story_SetStoryEnded('On Patrol')"]}, 'Hunt': {'next': ['Random Encounter'], 'required_map': [], 'timeofday': 'none', 'action': ['DoEncHunt(villains = [\'Story_GetRandomUserEnemy()\'], cutscenes = [[\'alertcs\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', "CS_AddArrow(\'villainarrow\', \'villain\', arrow_type=js.ARROW_YELLOW)"]]], [\'startcs\', [\'cslist\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', \'CS_Start()\', "CS_Camera(\'villain\', dist=-160, yaw=0)", "CS_Speak(\'villain\', \'There you are.\', force=0)", \'CS_End()\']], [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', "CS_Speak(\'villain\', \'You will suffer my wrath.\', force=0)"]], [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', "CS_Speak(\'villain\', \'Well hellllloooo.\', force=0)"]], [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'villain\\\', "I\\\'ve been looking for you, hero.", force=0)\']]]]], marker = \'encounter\')']}, 'Mugging': {'next': ['Random Encounter'], 'required_map': [], 'timeofday': 'none', 'action': ['DoEncSavecivilian(villains = [\'Story_GetRandomUserEnemy()\'], cutscenes = [[\'alertcs\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', "CS_AddArrow(\'villainarrow\', \'villain\', arrow_type=js.ARROW_YELLOW)"]]], [\'startcs\', [\'cslist\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\'], [\'ally\', \'ally\'], [\'hero\', \'hero\']], [\'cutscene\', "CS_Speak(\'villain\', \'Why do you always have to interfere?\', force=0)", "CS_TurnTo(\'ally\', \'hero\')", "CS_Speak(\'ally\', \'Help!\', force=0)", "CS_Speak(\'hero\', \'Unhand her at once!\', force=0)"]], [[\'priority\', 1], [\'replace\', [\'ally\', \'ally\']], [\'cutscene\', \'CS_Speak(\\\'ally\\\', "They\\\'re after me! Do something!", force=0)\']], [[\'priority\', 1], [\'replace\', [\'villains\', \'villain\'], [\'ally\', \'ally\']], [\'cutscene\', "CS_Speak(\'villains\', \'Just hand it over and no one gets hurt.\', force=0)", \'CS_Speak(\\\'ally\\\', "Won\\\'t someone save me?", force=0)\']]]], [\'allythanksherocs\', [[\'priority\', 1], [\'replace\', [\'ally\', \'ally\']], [\'cutscene\', "CS_Speak(\'ally\', \'Thank you.\', force=0)"]]]], marker = \'encounter\', allies = [\'civilian_female\'])']}, 'Random Start': {'timeofday': 'none', 'next': ['Random Encounter', 'Random Encounter', 'Random Encounter'], 'trigger': ['start'], 'required_map': []}, '__lose__': {'action': ['ff.Story_LoseMission()']}, '__win__': {'action': ['ff.Story_WinMission()']}, 'Snatch and Grab': {'next': ['Random Encounter'], 'required_map': [], 'timeofday': 'none', 'action': ['DoEncSnatch(villains = [\'Story_GetRandomUserEnemy()\'], cutscenes = [[\'alertcs\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', "CS_AddArrow(\'villainarrow\', \'villain\', arrow_type=js.ARROW_YELLOW)"]]], [\'startcs\', [\'cslist\', [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'villain\\\', "I\\\'ve got the goods. Now to make my getaway.", force=0)\']], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\'], [\'villain\', \'villain\']], [\'cutscene\', "CS_Speak(\'hero\', \'Hold it right there.\', force=0)", "CS_Speak(\'villain\', \'You think you can catch me, hero?\', force=0)"]], [[\'priority\', 1], [\'replace\', [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'villain\\\', "What\\\'s a little petty larceny?", force=0)\']], [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\'], [\'villain\', \'villain\']], [\'cutscene\', \'CS_Speak(\\\'hero\\\', "Crime doesn\\\'t pay.", force=0)\', \'CS_Speak(\\\'villain\\\', "Not with you around it doesn\\\'t.", force=0)\']]]], [\'herogetsitemcs\', [[\'priority\', 1], [\'replace\', [\'hero\', \'hero\']], [\'cutscene\', "CS_Speak(\'hero\', \'I should return this to its rightful owner.\', force=0)"]]], [\'itemreturnedcs\', [[\'priority\', 1], [\'replace\', [\'ally\', \'ally\']], [\'cutscene\', "CS_Speak(\'ally\', \'Thank you so much.\', force=0)"]]]], marker = \'encounter\', allies = [\'civilian_female\'])']}}}}
TIME: 0.007270 for GetMissionVar
PSTORY: precaching Story_GetRandomUserEnemy()
PSTORY: precaching civilian_female[/spoiler]
and more:
[spoiler]! GetMapInfo
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\MiniMod On Patrol.py executed
>>> OnReceiveSelectedEnemies(('cluemaster', 'count_vertigo', 'doctor_light', 'heat_wave', 'mirror_master', 'psycho_pirate', ))
MISSION: On Post Init... start.
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'LIBERTY PARK'
initialising FFX: skirmish=0
mapinfocaliper0 is not a valid explosion object
mapinfocaliper1 is not a valid explosion object
mapinfocaliper2 is not a valid explosion object
mapinfocaliper3 is not a valid explosion object
numberStr=93
storing hero_0: id_1,-93
numberStr=94
storing hero_1: id_2,-94
MISSION: On Post Init... complete; starting story.
0 [] []
Random Encounter
Random Encounter
Random Encounter
AI: SetupAI() - setting ai for hero_0 ('atom')
AI: SetupAI() - setting ai for hero_1 ('elongated_man')
0 [] []
Story_RandomListElement(['Fight', 'Fight', 'Fight', 'Fight', 'Mugging', 'Hunt', 'Snatch and Grab'])
0 [] []
Story_RandomListElement(['Fight', 'Fight', 'Fight', 'Fight', 'Mugging', 'Hunt', 'Snatch and Grab'])
ENCOUNTER: Setting up encounter 1
ENCOUNTER: Start marker found for ['encounter'] 4
RANDOMENC: Random user enemy selected doctor_light
AI: SetupAI() - setting ai for m25obj_2 ('doctor_light')
ENCOUNTER: Encounter spawn complete for 1
ENCOUNTER: Encounter cutscenes complete for 1
ENCOUNTER: Encounter goals complete for 1
ENCOUNTER: Encounter objectives complete for 1
ENCOUNTER: Encounter parameters complete for 1
ENCOUNTER: Encounter post function 'EncStartOnEnterMarker_Setup'
ENCOUNTER: Encounter post complete for 1
ENCOUNTER: Saving encounter data for 1
ENCOUNTER: PlayEncCutscene(): 'alertcs' : None
ENCOUNTER: PlayCutsceneFromList(): [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', "CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]] : None ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_AddArrow('m25obj_2arrow', 'm25obj_2', arrow_type=js.ARROW_YELLOW)
CUTSCENE: calling PlayCurrentCutscene 1
CUTSCENE: playing ff.CS_AddArrow(1,'m25obj_2arrow', 'm25obj_2', arrow_type=js.ARROW_YELLOW)
addArrow m25obj_2arrow m25obj_2 1 1
---- TIME: 0.022174 for PlayEncCutscene
ENCOUNTER: Encounter setup complete for 1
####################### TIME: 0.270223 for Encounter Setup for 1
0 [] []
Story_RandomListElement(['Fight', 'Fight', 'Fight', 'Fight', 'Mugging', 'Hunt', 'Snatch and Grab'])
CUTSCENE: calling cutscene return function.
CUTSCENE: no return function to call.
ENCOUNTER: Setting up encounter 2
ENCOUNTER: Start marker found for ['encounter'] 8
RANDOMENC: Random user enemy selected mirror_master
AI: SetupAI() - setting ai for m25obj_4 ('mirror_master')
ENCOUNTER: Encounter spawn complete for 2
ENCOUNTER: Encounter cutscenes complete for 2
ENCOUNTER: Encounter goals complete for 2
ENCOUNTER: Encounter objectives complete for 2
ENCOUNTER: Encounter parameters complete for 2
ENCOUNTER: Encounter post function 'EncStartOnEnterMarker_Setup'
ENCOUNTER: Encounter post complete for 2
ENCOUNTER: Saving encounter data for 2
ENCOUNTER: PlayEncCutscene(): 'alertcs' : None
ENCOUNTER: PlayCutsceneFromList(): [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', "CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]] : None ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_AddArrow('m25obj_4arrow', 'm25obj_4', arrow_type=js.ARROW_YELLOW)
CUTSCENE: calling PlayCurrentCutscene 2
CUTSCENE: playing ff.CS_AddArrow(2,'m25obj_4arrow', 'm25obj_4', arrow_type=js.ARROW_YELLOW)
addArrow m25obj_4arrow m25obj_4 1 1
TIME: 0.002817 for PlayEncCutscene
ENCOUNTER: Encounter setup complete for 2
####################### TIME: 0.322622 for Encounter Setup for 2
ENCOUNTER: Setting up encounter 3
ENCOUNTER: Start marker found for ['encounter'] 11
ENCOUNTER: No markers for 3 [['allyleave', 'encounter11_allyleave', 'dist500'], ['end', 'encounter11_end', 'edge'], ['end', 'encounter11_end', 'edge']]
RANDOMENC: Random user enemy selected psycho_pirate
AI: SetupAI() - setting ai for m25obj_6 ('psycho_pirate')
Campaign_MakeHeroIndex: Making index <c:\program files\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex warning: <time_master> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_radn_hero> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_elec> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_elec_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_enrg_hero> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_playable> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_elec_hero> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_energy> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <riddle_puzzle_thug> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_radn_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_enrg_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <ironox_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_radiation> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <ironox> likely missing entry in objects.dat; skipping.
AI: SetupAI() - setting ai for m25obj_8 ('civilian_female')
ENCOUNTER: Encounter spawn complete for 3
ENCOUNTER: Encounter cutscenes complete for 3
ENCOUNTER: Encounter goals complete for 3
ENCOUNTER: Encounter objectives complete for 3
ENCOUNTER: Encounter parameters complete for 3
ENCOUNTER: Encounter post function 'EncStartOnEnterMarker_Setup'
ENCOUNTER: Encounter post function 'FleeToMarker_Setup'
Snatch_CheckEnd
ENCOUNTER: 3 - registering Snatch_CheckEnd on variable _fled
LeaderDropObject_Escaped
ENCOUNTER: 3 - registering LeaderDropObject_Escaped on variable _fled
ENCOUNTER: Encounter post function 'FleeToMarker_Setup'
Snatch_CheckEnd
ENCOUNTER: 3 - registering Snatch_CheckEnd on variable _fled
LeaderDropObject_Escaped
ENCOUNTER: 3 - registering LeaderDropObject_Escaped on variable _fled
ENCOUNTER: Encounter post function 'LeaderDropObject_Setup'
ENCOUNTER: 3 - registering Snatch_HeroPickup on variable on_hero_pickup
ENCOUNTER: Encounter post complete for 3
ENCOUNTER: Saving encounter data for 3
ENCOUNTER: PlayEncCutscene(): 'alertcs' : None
ENCOUNTER: PlayCutsceneFromList(): [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', "CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]] : None ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_AddArrow('m25obj_6arrow', 'm25obj_6', arrow_type=js.ARROW_YELLOW)
CUTSCENE: calling PlayCurrentCutscene 3
CUTSCENE: playing ff.CS_AddArrow(3,'m25obj_6arrow', 'm25obj_6', arrow_type=js.ARROW_YELLOW)
addArrow m25obj_6arrow m25obj_6 1 1
TIME: 0.002676 for PlayEncCutscene
ENCOUNTER: Encounter setup complete for 3
####################### TIME: 1.558748 for Encounter Setup for 3
CUTSCENE: the current cutscene was interrupted... skipping it.
CUTSCENE: calling cutscene return function.
CUTSCENE: no return function to call.
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-100.0, 70.0, 0.5, 0.5, (0.699999988079, 0.600000023842, 0.600000023842))
---- TIME: 0.016782 for AI_UpdateMapInfoStatic
AI: AISetRunning hero_0 to 0
AI: AISetRunning hero_1 to 0
clearCarrierRegistration: clearing attribute 'hextoteleportm25obj_4' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hextoteleportm25obj_4' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hextoteleportm25obj_4' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hextoteleportm25obj_4' for destroyed object 'mapinfocaliper3'
AI: AISetRunning m25obj_2 to 0
AI: AISetRunning m25obj_4 to 0
initAttribsForChar: working on hero_0 (atom)
initAttribsForChar (atom): looking at attribute nimble
initAttribsForChar (atom): looking at attribute jumper
initAttribsForChar (atom): looking at attribute masscontrol
execInitAttrib: init masscontrol attribute
on hero_0 of template custom_template_93 (atom)
initAttribsForChar: working on hero_1 (elongated_man)
initAttribsForChar (elongated_man): looking at attribute nimble
initAttribsForChar (elongated_man): looking at attribute jumper
initAttribsForChar: working on m25obj_2 (doctor_light)
initAttribsForChar (doctor_light): looking at attribute light speed
initAttribsForChar (doctor_light): looking at attribute flier
initAttribsForChar (doctor_light): looking at attribute lightcontrol
execInitAttrib: init lightcontrol attribute
on m25obj_2 of template doctor_light (doctor_light)
initAttribsForChar (doctor_light): looking at attribute solarpowered
execInitAttrib: init solarpowered attribute
on m25obj_2 of template doctor_light (doctor_light)
solar powered characterm25obj_2 has base energy 5
initAttribsForChar: working on m25obj_4 (mirror_master)
initAttribsForChar (mirror_master): looking at attribute jumper
initAttribsForChar (mirror_master): looking at attribute nimble
initAttribsForChar (mirror_master): looking at attribute accidentclone
execInitAttrib: init accidentclone attribute
on m25obj_4 of template mirror_master (mirror_master)
initAttribsForChar (mirror_master): looking at attribute livinglaser
execInitAttrib: init livinglaser attribute
on m25obj_4 of template mirror_master (mirror_master)
initAttribsForChar (mirror_master): looking at attribute unheroic
initAttribsForChar: working on m25obj_6 (psycho_pirate)
initAttribsForChar (psycho_pirate): looking at attribute disciplined
initAttribsForChar (psycho_pirate): looking at attribute timid
initAttribsForChar (psycho_pirate): looking at attribute jumper
initAttribsForChar (psycho_pirate): looking at attribute unheroic
initAttribsForChar: working on m25obj_8 (civilian_female)
AI: AISetRunning m25obj_6 to 0
AI: AISetRunning m25obj_8 to 0
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()[/spoiler]
Darn character limit...here is the end of it. I wouldn't have posted all of it like this, but I couldn't find any errors or tracebacks in it like your intro says to look for:
[spoiler]---- TIME: 0.017137 for AI_UpdateMapInfoStatic
---- TIME: 0.016745 for AI_UpdateMapInfoStatic
---- TIME: 0.016923 for AI_UpdateMapInfoStatic
---- TIME: 0.017626 for AI_UpdateMapInfoStatic
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
---- TIME: 0.017488 for AI_UpdateMapInfoStatic
---- TIME: 0.016786 for AI_UpdateMapInfoStatic
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
---- TIME: 0.018283 for AI_UpdateMapInfoStatic
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
ENCOUNTER: Enc_CheckStart starting 3
AI: AIRun is restarting m25obj_6
AI: AISetRunning m25obj_6 to 1
AI: AIRun is restarting m25obj_8
AI: AISetRunning m25obj_8 to 1
ENCOUNTER: PlayEncCutscene(): 'startcs' : 'Enc_StandardStartEnable(3)'
ENCOUNTER: PlayCutsceneFromList(): ['cslist', [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', 'CS_Speak(\'villain\', "I\'ve got the goods. Now to make my getaway.", force=0)']], [['priority', 1], ['replace', ['hero', 'hero'], ['villain', 'villain']], ['cutscene', "CS_Speak('hero', 'Hold it right there.', force=0)", "CS_Speak('villain', 'You think you can catch me, hero?', force=0)"]], [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', 'CS_Speak(\'villain\', "What\'s a little petty larceny?", force=0)']], [['priority', 1], ['replace', ['hero', 'hero'], ['villain', 'villain']], ['cutscene', 'CS_Speak(\'hero\', "Crime doesn\'t pay.", force=0)', 'CS_Speak(\'villain\', "Not with you around it doesn\'t.", force=0)']]] : 'Enc_StandardStartEnable(3)' ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_Speak('m25obj_6',"I've got the goods. Now to make my getaway.", force=0)
CUTSCENE: calling PlayCurrentCutscene 4
CUTSCENE: playing ff.CS_Speak(4,'m25obj_6',"I've got the goods. Now to make my getaway.", force=0)
####################### TIME: 0.284544 for PlayEncCutscene
TIME: 0.003492 for ai for psycho_pirate
TIME: 0.002683 for ai for civilian_female
CUTSCENE: calling cutscene return function.
---- TIME: 0.016709 for AI_UpdateMapInfoStatic
AI: m25obj_6:'psycho_pirate' goal move to marker 'encounter11_end1'
TIME: 0.005064 for ai for psycho_pirate
AI: m25obj_6:'psycho_pirate' goal move to marker 'encounter11_end1'
TIME: 0.004586 for ai for psycho_pirate
---- TIME: 0.017257 for AI_UpdateMapInfoStatic
TIME: 0.002510 for ai for psycho_pirate
ENCOUNTER: PlayEncCutscene(): 'villainescapescs' : "FleeToMarker_FleeMap2(3,'m25obj_6')"
ENCOUNTER: PlayCutsceneFromList(): None : "FleeToMarker_FleeMap2(3,'m25obj_6')" ... [['m25obj_6', 'villain']]
TIME: 0.003687 for ai for psycho_pirate
clearCarrierRegistration: clearing attribute 'hextoteleportm25obj_4' for destroyed object 'm25obj_6'
ENCOUNTER: 3 - event callback _fled has value ['Snatch_CheckEnd', 'LeaderDropObject_Escaped', 'Snatch_CheckEnd', 'LeaderDropObject_Escaped']
ENCOUNTER: 3 - event callback _fled calling Snatch_CheckEnd
ENCOUNTER: 3 - event callback _fled calling LeaderDropObject_Escaped
ENCOUNTER: 3 - event callback _fled calling Snatch_CheckEnd
ENCOUNTER: PlayEncCutscene(): 'itemlostcs' : "Enc_CleanUp(3,['item lost', 'end', 'allies saved'])"
ENCOUNTER: PlayCutsceneFromList(): None : "Enc_CleanUp(3,['item lost', 'end', 'allies saved'])" ... []
enc_cleanup called
enc end called 0
ENCOUNTER: Encounter ended 3 with ['item lost', 'end', 'allies saved']
3 ['item lost', 'end', 'allies saved'] []
Random Encounter
---- TIME: 0.060194 for PlayEncCutscene
ENCOUNTER: 3 - event callback _fled calling LeaderDropObject_Escaped
0 [] []
Story_RandomListElement(['Fight', 'Fight', 'Fight', 'Fight', 'Mugging', 'Hunt', 'Snatch and Grab'])
ENCOUNTER: Setting up encounter 4
ENCOUNTER: Start marker found for ['encounter'] 1
RANDOMENC: Random user enemy selected heat_wave
AI: SetupAI() - setting ai for m25obj_10 ('heat_wave')
ENCOUNTER: Encounter spawn complete for 4
ENCOUNTER: Encounter cutscenes complete for 4
ENCOUNTER: Encounter goals complete for 4
ENCOUNTER: Encounter objectives complete for 4
ENCOUNTER: Encounter parameters complete for 4
ENCOUNTER: Encounter post function 'EncStartOnEnterMarker_Setup'
ENCOUNTER: Encounter post complete for 4
ENCOUNTER: Saving encounter data for 4
ENCOUNTER: PlayEncCutscene(): 'alertcs' : None
ENCOUNTER: PlayCutsceneFromList(): [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', "CS_AddArrow('villainarrow', 'villain', arrow_type=js.ARROW_YELLOW)"]] : None ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_AddArrow('m25obj_10arrow', 'm25obj_10', arrow_type=js.ARROW_YELLOW)
CUTSCENE: calling PlayCurrentCutscene 5
CUTSCENE: playing ff.CS_AddArrow(5,'m25obj_10arrow', 'm25obj_10', arrow_type=js.ARROW_YELLOW)
addArrow m25obj_10arrow m25obj_10 1 1
---- TIME: 0.022785 for PlayEncCutscene
ENCOUNTER: Encounter setup complete for 4
####################### TIME: 0.356586 for Encounter Setup for 4
CUTSCENE: calling cutscene return function.
CUTSCENE: no return function to call.
AI: m25obj_8:'civilian_female' goal move to marker 'encounter11_allyleave1'
TIME: 0.003771 for ai for civilian_female
---- TIME: 0.016761 for AI_UpdateMapInfoStatic
initAttribsForChar: working on m25obj_10 (heat_wave)
initAttribsForChar (heat_wave): looking at attribute volcanic
initAttribsForChar (heat_wave): looking at attribute unheroic
initAttribsForChar (heat_wave): looking at attribute firecontrol
execInitAttrib: init firecontrol attribute
on m25obj_10 of template heat_wave (heat_wave)
initAttribsForChar (heat_wave): looking at attribute temperature control
initAttribsForChar (heat_wave): looking at attribute jumper
AI: AISetRunning m25obj_10 to 0
AI: m25obj_8:'civilian_female' goal move to marker 'encounter11_allyleave1'
TIME: 0.003434 for ai for civilian_female
AI: m25obj_8:'civilian_female' goal move to marker 'encounter11_allyleave1'
TIME: 0.004007 for ai for civilian_female
---- TIME: 0.017809 for AI_UpdateMapInfoStatic
AI: m25obj_8:'civilian_female' goal move to marker 'encounter11_allyleave1'
TIME: 0.003538 for ai for civilian_female
AI: m25obj_8:'civilian_female' goal move to marker 'encounter11_allyleave1'
TIME: 0.003630 for ai for civilian_female
clearCarrierRegistration: clearing attribute 'hextoteleportm25obj_4' for destroyed object 'm25obj_8'
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
---- TIME: 0.016378 for AI_UpdateMapInfoStatic
---- TIME: 0.016130 for AI_UpdateMapInfoStatic
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
---- TIME: 0.017298 for AI_UpdateMapInfoStatic
ENCOUNTER: Enc_CheckStart starting 4
AI: AIRun is restarting m25obj_10
AI: AISetRunning m25obj_10 to 1
ENCOUNTER: PlayEncCutscene(): 'startcs' : 'Enc_StandardStartEnable(4)'
ENCOUNTER: PlayCutsceneFromList(): ['cslist', [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', 'CS_Speak(\'villain\', "You\'ve interferred with me for the last time.", force=0)']], [['priority', 1], ['replace', ['hero', 'hero']], ['cutscene', "CS_Speak('hero', 'And here I thought this would be a nice quiet night.', force=0)"]], [['priority', 1], ['replace', ['hero', 'hero'], ['villain', 'villain']], ['cutscene', 'CS_Speak(\'hero\', "I\'m afraid I\'m going to have to take you in.", force=0)', 'CS_Speak(\'villain\', "You\'re welcome to try.", force=0)']], [['priority', 1], ['replace', ['villain', 'villain']], ['cutscene', 'CS_Speak(\'villain\', "Can\'t a villain get a moment\'s peace?", force=0)']]] : 'Enc_StandardStartEnable(4)' ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_Speak('m25obj_10',"You've interferred with me for the last time.", force=0)
CUTSCENE: calling PlayCurrentCutscene 6
CUTSCENE: playing ff.CS_Speak(6,'m25obj_10',"You've interferred with me for the last time.", force=0)
---- TIME: 0.039849 for PlayEncCutscene
CUTSCENE: calling cutscene return function.
TIME: 0.003562 for ai for heat_wave
TIME: 0.001148 for ai for heat_wave
---- TIME: 0.017104 for AI_UpdateMapInfoStatic
TIME: 0.001597 for ai for heat_wave
TIME: 0.001737 for ai for heat_wave
---- TIME: 0.017069 for AI_UpdateMapInfoStatic
TIME: 0.001977 for ai for heat_wave
TIME: 0.001443 for ai for heat_wave
TIME: 0.001451 for ai for heat_wave
---- TIME: 0.039008 for AI_UpdateMapInfoStatic
TIME: 0.001480 for ai for heat_wave
TIME: 0.001413 for ai for heat_wave
---- TIME: 0.060001 for AI_UpdateMapInfoStatic
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
TIME: 0.001523 for ai for heat_wave
TIME: 0.001441 for ai for heat_wave
TIME: 0.001099 for ai for heat_wave
---- TIME: 0.016864 for AI_UpdateMapInfoStatic
TIME: 0.001134 for ai for heat_wave
TIME: 0.001487 for ai for heat_wave
ENCOUNTER: PlayEncCutscene(): 'bantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
---- TIME: 0.016966 for AI_UpdateMapInfoStatic
TIME: 0.001497 for ai for heat_wave
TIME: 0.001306 for ai for heat_wave
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
TIME: 0.001574 for ai for heat_wave
---- TIME: 0.039962 for AI_UpdateMapInfoStatic
TIME: 0.001349 for ai for heat_wave
TIME: 0.001150 for ai for heat_wave
---- TIME: 0.017810 for AI_UpdateMapInfoStatic
TIME: 0.001642 for ai for heat_wave
TIME: 0.001309 for ai for heat_wave
TIME: 0.001104 for ai for heat_wave
---- TIME: 0.016604 for AI_UpdateMapInfoStatic
TIME: 0.001675 for ai for heat_wave
TIME: 0.001272 for ai for heat_wave
---- TIME: 0.017571 for AI_UpdateMapInfoStatic
TIME: 0.001697 for ai for heat_wave
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
---- TIME: 0.041417 for AI_UpdateMapInfoStatic
TIME: 0.001413 for ai for heat_wave
ENCOUNTER: PlayEncCutscene(): 'bantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
ENCOUNTER: PlayEncCutscene(): 'enroutebantercs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
TIME: 0.001841 for ai for heat_wave
---- TIME: 0.017657 for AI_UpdateMapInfoStatic
TIME: 0.001396 for ai for heat_wave
TIME: 0.001557 for ai for heat_wave
ENCOUNTER: PlayEncCutscene(): 'm25obj_10kocs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... [['m25obj_10', 'fallen']]
ENCOUNTER: PlayEncCutscene(): 'heat_wavekocs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... [['m25obj_10', 'fallen']]
ENCOUNTER: PlayCutsceneFromList(): None : None ... [['m25obj_10', 'fallen']]
ENCOUNTER: PlayEncCutscene(): 'alliessavedcs' : "Fight_Over(4,'allies saved')"
ENCOUNTER: PlayCutsceneFromList(): None : "Fight_Over(4,'allies saved')" ... []
ENCOUNTER: PlayCutsceneFromList(): ['cslist', [['priority', 1], ['replace', ['hero', 'hero']], ['cutscene', 'CS_Speak(\'hero\', "And that\'s why evil never wins.", force=0)']], [['priority', 1], ['replace', ['hero', 'hero']], ['cutscene', "CS_Speak('hero', 'Thanks for the workout.', force=0)"]], [['priority', 1], ['replace', ['hero', 'hero']], ['cutscene', 'CS_Speak(\'hero\', "I\'m taking you in.", force=0)']], [['priority', 1], ['replace', ['hero', 'hero']], ['cutscene', 'CS_Speak(\'hero\', "I\'ll just leave you for the police.", force=0)']]] : "Enc_CleanUp(4,['allies saved', 'end'])" ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_Speak('hero_0',"And that's why evil never wins.", force=0)
CUTSCENE: calling PlayCurrentCutscene 7
CUTSCENE: playing ff.CS_Speak(7,'hero_0',"And that's why evil never wins.", force=0)[/spoiler]
Quote from: BentonGrey on March 07, 2007, 03:51:32 PM
Yeah, I have JKC, but after doing the full conversion that his tutorial describes, I didn't have that problem.
I'm not sure what you mean. I followed the instructions that came with the pack. Is there something else I need to do?
You're getting messages about items missing from objects.dat. There may be a mismatch between the characters and templates in FFEdit, or worse, you may have a bad objects.dat file.
Perhaps the others have more insight.
Quote from: BentonGrey on March 07, 2007, 05:57:43 PM
AI: SetupAI() - setting ai for m25obj_6 ('psycho_pirate')
Campaign_MakeHeroIndex: Making index <c:\program files\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex warning: <time_master> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_radn_hero> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_elec> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_elec_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_enrg_hero> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_playable> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_elec_hero> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_energy> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <riddle_puzzle_thug> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_radn_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_mast_enrg_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <ironox_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_extra> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <time_master_radiation> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <ironox> likely missing entry in objects.dat; skipping.
AI: SetupAI() - setting ai for m25obj_8 ('civilian_female')
Yes. What those warnings mean is that the character mentioned has an entry in the Characters tab in
FFEdit but no entry in the Templates tab. Oftentimes, this won't stop game play, which is why it's just a warning, but it
can be indicative of a bad or incomplete DAT merge.
Given the seriousness of the crash, I am concerned that some bad DAT entries are in the mix again. Does the same crash happen when you play On Patrol with other characters or when you play with the DATs as they come in the 3.2 release (before any merging)?
Well, I had the crash before with Batman and his villains, but I assumed it was because of Crock. I will do some testing tomorrow, see if I can get any more data for you.
However....looking over those missing objects, I've deleted several of those myself. The only one who SHOULD be there is the Riddle Thug. I asked in my mod thread if it was safe to delete the built in characters, could it be that there is more danger in it than I realized?
I think this thing that happened to me just now is more like me having done something stupid rather than a real bug.
I made a combo for my Superman character called "last son of krypton". It consisted of enhanced senses, physical resistance, acrobatic (amateur) and flier.
I started a rumble room session to test it and most of the ffx attributes I put on it were working, except enhanced senses. Then I quit the game and erased the "telepathy" in the ffxmulti.py file from my combo and, instead, gave enhanced senses to my Supes separately.
When I started another rumble room session to test it, not only enhanced senses didn't work, but all the other attributes weren't working either. My Supes couldn't even fly. Also, the screen was very bright for some reason. And it is not only the ffx attributes from Superman that aren't working anymore; the ffx attributes I gave to other characters aren't working either.
Here's the log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.251000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Traceback (innermost last):
File "C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py", line 6, in ?
from ffx import *
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 29, in ?
import m25ai
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25ai.py", line 60, in ?
import m25generateai
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\m25generateai.py", line 35, in ?
import ffxmulti
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffxmulti.py", line 58
['superman', 'acrobaticamateur', 'flier', 'toughguy2', vulnerability'],
^
SyntaxError: invalid token
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('darkman_blue', ))
try to spawn darkman_blue
sk.SpawnEnemy: energy for _skdarkman_blue01 (darkman_blue) changed from 3 to 3
Traceback (innermost last):
File "C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py", line 15, in OnPostInit
FFX_InitSkirmish()
NameError: FFX_InitSkirmish[/spoiler]
Edit: By the way, when I removed enhanced senses from the combo, I forgot to merge the language files. Could it have been what caused the problem?
It looks like something happened to your ffxmulti.py. Make sure you typed everything correctly and have the correct names for each attribute. As for the Enhanced Senses not working, it was one of the attributes that had it's FFXCC entries combined to make room for more customizations, so make sure you run Stumpy's ffxcustom conversion as mentioned previously in this thread.
You're right. I typed something wrong there.
I hadn't considered this possibility because, when I removed enhanced senses from the combo, all I did was remove "telepathy", so it couldn't (I thought) have been a syntax problem. However, I acidentally ended up removing a comma and hadn't noticed it. I fixed it now and it's working perfectly.
Thanks for you help!
On a side note, Taskmaster, did my flying melee method work for you?
has anybody else been having a screen freeze when the rumble room loads up? FFVTTr just freezes on the loading screen when its a full bar.
i have no clue whats causing it... :blink:
I thought I had that, but it was just taking an inordinate amount of time to load up.
Hey guys, I'm still curious if I need to go back and re-merge some .dats to get back the buit-ins that I deleted. Any ideas about that?
If you are really getting a freeze, post your script.log.
BG, you can either add the characters back manually or re-merge. The merge process carries with it the risk if merging in the corrupt DATs that some people have. I would create abridged DATs with just the powers, characters, and objects entries for those heroes and then use the double merge process Épiméthée described.
Okay, so it IS necessary to keep the built-in characters? I'll remerge with my backup copy of FFX.
Maybe I am not understanding the question. If you have added your own built-ins to the DATs, then then only way to get them back after upgrading to the latest beta is via a merge process or manually adding them back using FFEdit.
Hmm, I see that I am not being clear enough, sorry Stumpy! I had those errors during 'On Patrol.' You pointed out that the game was finding missing objects and suggested it might be the result of a bad .dat. However, I said that I had removed those myself. They consisted of several built in characters. I have removed all of the FF built-in heroes and villains myself. I was asking if that causes trouble. If so, I'll merely re-merge with a back-up I made. I removed the Irrational heroes and villains to save space and cut down on confusion, but I can deal with it if it's going to cause problems. Is that more clear?
I didn't read back far enough in the thread. :oops: I thought you were referring to the same thing detourne_me was.
You should not have to add back in any built-ins you have added and then deleted. If you want to get rid of those messages, you can finish removing those heroes from the Characters tab that you removed from the Templates tab. The messages are just there because they appear in characters.dat but not objects.dat.
I am still not sure what is behind the CTD you are seeing. I didn't see anything really suspicious in your script.log, but I don't know too much about the EZScript missions either.
Well, that's good to know at least. Like Holmes said, knowning what the answer isn't is nearly as important as knowning what it is!
Well, I just had another CTD, but this one was bizarre. I was playing 'Spygames,' and it crashed on me because I didn't have a head.nif in the right folder, my mistake, I fixed it. Now, I go back to play it again, and THIS happens:
[spoiler]TIME: 0.007833 for GetMissionVar
PSTORY: precaching nazi_gunner
PSTORY: precaching nazi_rifleman
PSTORY: precaching berlin_male
PSTORY: precaching nazi_grenadier
PSTORY: precaching nazihq_lab_machine_4
PSTORY: precaching nazi_general
! GetMapInfo
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\MiniMod Spy Games.py executed
MISSION: On Post Init... start.
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'CITY LANDMARKS'
initialising FFX: skirmish=0
mapinfocaliper0 is not a valid explosion object
mapinfocaliper1 is not a valid explosion object
mapinfocaliper2 is not a valid explosion object
mapinfocaliper3 is not a valid explosion object
numberStr=93
storing hero_0: id_1,-93
numberStr=94
storing hero_1: id_2,-94
MISSION: On Post Init... complete; starting story.
ENCOUNTER: Setting up encounter 1
ENCOUNTER: Start marker found for ['encounter'] 7
ENCOUNTER: Encounter spawn complete for 1
ENCOUNTER: Encounter cutscenes complete for 1
ENCOUNTER: Encounter goals complete for 1
ENCOUNTER: Encounter objectives complete for 1
ENCOUNTER: Encounter parameters complete for 1
ENCOUNTER: Encounter post function 'SingleCutscene_Setup'
ENCOUNTER: PlayEncCutscene(): 'startcs' : 'SingleCutscene_End(1,"end")'
ENCOUNTER: PlayCutsceneFromList(): [['priority', 1], ['replace', ['hero1', 'hero']], ['cutscene', 'CS_Start()', "CS_Lighting('night')", "CS_CinematicCamera('hero1')", "CS_Speak('hero1', 'My contact said to meet him near here.', force=0)", 'CS_End()']] : 'SingleCutscene_End(1,"end")' ... []
CUTSCENE: request to play cutscene.
CUTSCENE: - CS_Start()
CUTSCENE: - CS_Lighting('night')
CUTSCENE: - CS_CinematicCamera('hero_1')
CUTSCENE: - CS_Speak('hero_1','My contact said to meet him near here.', force=0)
CUTSCENE: - CS_End()
CUTSCENE: calling PlayCurrentCutscene 1
CUTSCENE: playing ff.CS_Start(1)
---- TIME: 0.025713 for PlayEncCutscene
ENCOUNTER: Encounter post complete for 1
ENCOUNTER: Saving encounter data for 1
ENCOUNTER: PlayEncCutscene(): 'alertcs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
ENCOUNTER: Encounter setup complete for 1
---- TIME: 0.050399 for Encounter Setup for 1
RANDOMENC: selected nazi_gunner : total prestige 1
RANDOMENC: selected nazi_gunner : total prestige 2
RANDOMENC: selected nazi_gunner : total prestige 3
RANDOMENC: selected nazi_gunner : total prestige 4
RANDOMENC: selected nazi_rifleman : total prestige 5
RANDOMENC: selected nazi_gunner : total prestige 6
ENCOUNTER: Setting up encounter 2
ENCOUNTER: Start marker found for ['encounter'] 1
AI: SetupAI() - setting ai for m25obj_2 ('nazi_gunner')
AI: SetupAI() - setting ai for m25obj_4 ('nazi_gunner')
AI: SetupAI() - setting ai for m25obj_6 ('nazi_gunner')
AI: SetupAI() - setting ai for m25obj_8 ('nazi_gunner')
AI: SetupAI() - setting ai for m25obj_10 ('nazi_rifleman')
AI: SetupAI() - setting ai for m25obj_12 ('nazi_gunner')
ENCOUNTER: Encounter spawn complete for 2
ENCOUNTER: Encounter cutscenes complete for 2
ENCOUNTER: Encounter goals complete for 2
ENCOUNTER: Encounter objectives complete for 2
ENCOUNTER: Encounter parameters complete for 2
ENCOUNTER: Encounter post function 'Hunt_Setup'
ENCOUNTER: Encounter post function 'EncStartOnEnterMarker_Setup'
ENCOUNTER: Encounter post complete for 2
ENCOUNTER: Saving encounter data for 2
ENCOUNTER: PlayEncCutscene(): 'alertcs' : None
ENCOUNTER: PlayCutsceneFromList(): None : None ... []
ENCOUNTER: Encounter setup complete for 2
####################### TIME: 0.206583 for Encounter Setup for 2
AI: SetupAI() - setting ai for hero_1 ('doctor_midnight')
AI: SetupAI() - setting ai for hero_0 ('atom_I')
CUTSCENE: playing ff.CS_Lighting(1,'night')
CS_SetLights cannot set orientation of o_impobj_37
CS_SetLights cannot set orientation of o_impobj_38
CS_SetLights cannot set orientation of o_impobj_39
CS_SetLights cannot set orientation of o_impobj_40
CS_SetLights cannot set orientation of o_impobj_90
CS_SetLights cannot set orientation of o_impobj_91
CS_SetLights cannot set orientation of o_impobj_95
CS_SetLights cannot set orientation of o_impobj_96
CS_SetLights cannot set orientation of o_impobj_97
CS_SetLights cannot set orientation of o_impobj_98
CS_SetLights cannot set orientation of o_impobj_99
CUTSCENE: playing ff.CS_CinematicCamera(1,'hero_1')
Template_GetMesh() fatal error: template 'custom_template_94' not found
Template_GetHeight() non-fatal error:
template 'custom_template_94' not found in list of template heights.
To detect approximate height, use
checkHeight(templateList, precise = 'no', repeat = 0, replace = 0, giants = 1, campaign = 0)
initialising FFQ_initialiseExtras()
TIME: 0.009366 for AI_UpdateMapInfoStatic
Template_GetMesh() fatal error: template 'custom_template_94' not found
CUTSCENE: playing ff.CS_Speak(1,'hero_1','My contact said to meet him near here.', force=0)[/spoiler]
That's the second half of the script.log, after the huge chunk of stuff about the mission. FR doesn't like that, as it's too long. I'll post it if needed. This section includes the error there at the bottom, but I'm afraid I don't know what it means.
On an unreleated note, are FFX customizations not available for area attacks?
Looks like some of the code in heightcheck.py couldn't find the template for one of your characters. That's not really my area of expertise, but it sounds like the kind of thing that would happen if a character isn't branded. Are you sure you have run the FFX Control Centre to brand the characters?
If that's not the issue, post what happens when you enter the following at the console (this is all one line):
for o in Mission_GetDynamicObjects(): print '%s: %s %s %d %s' % (o,Object_GetTemplate(o),GetCharacterData(o).get('charName'),Object_GetAttr(o,'complex'),GetCharacterData(o).get('NIF'))
BentonGrey,
Er, what happened? The log doesn't really show anything too unusual. I believe when that part of the script can't find the height of a character, it uses a default value (I don't know why it is labeled as a fatal error though).
About the dat files. In theory it shouldn't be a problem if you remove things, but I think in practice it is better to leave the built-ins from the game alone. It doesn't add a significant amount of space to your mod. There seems to be a fair amount of trouble with bad dat files in this version of the game.
Hmm, yep, I've run FFX, even done the power ID thing (which is part of my other question about customizing area attacks). I don't know what that could have been about.
And you are still getting a crash? I would still like to see the output from the console that I suggested...
This may all be in the FFX manual (in your FFvT3R folder as ..\ffx3\manual\index.html), so I would check there, but, as far as I know, power swaps don't work with area attacks because of the way the game engine handles event 21 sinks. To my recollection, you have to stick to melees, beams, and (non-explosive) projectiles. And I don't know about cones or area melee (arc) attacks.
Cones work fine. Doc uses a cone swap for Blackbird in the FFX campaign.
You can also simulate area attacks by swapping a self ability for the effect you want.
Thanks Cat, if I understand you correctly, you mean something like 'clone' or 'displace image'?
Stumpy, I haven't had a crash since then (including running the same scenario again), but I will do that console thing later on to check on it.
As Stumpy and Cat said, melee, non-explosive projectiles, beams, cones and some specials (empathy, invisibility, displace image) are fine. hHowever, the special don't map to every type of swap.
Quote from: M25 on March 12, 2007, 01:17:21 PMEr, what happened? The log doesn't really show anything too unusual. I believe when that part of the script can't find the height of a character, it uses a default value (I don't know why it is labeled as a fatal error though).
I suppose I should be able to give you the answer, but as I wrote that code two years ago... :huh: (Hmmm... somewhere on my to do list, I'm supposed to replace the code in heightcheck with a completely different method. Life is too short.)
Hey guys, I have a quick question (I doubt its a bug). I just Installed FFX3.2 and I noticed that when I run the control center none of my state swaps are there any more for any of my hero files, the lines are completely blank as if I never did a state swap, but when I remove 3.2 and reinstall 3.0 the state swaps are back again. I did a quick search for any issues like this but didnt come up with anything.
Did you run the FFX customization converter? Are your other FFX customizations there?
I seen in the trouble shooting info that it said to run the FFX CC , but I didnt see that any converter got installed with the mod, so no I didnt run any converter. Where would this converter be at if I may ask?
And no none of the other customizations are there either in the control center.
Hey Agent, do this:
To convert your customizations, load the game and open the console and then type:
import convertffxcustomdata
convertffxcustomdata.ConvertCustomizations()
Then quit the game, load FFXCC, and check and see if your customizations are there.
Thanks Stumpy and Task, that did the trick. I must of missed that instruction at the last meeting
I was running a character with Weapon Master in the Rumble Room. After the session started, he received commands to allow him to draw various weapons as he should. Unfortunately, when he drew the various weapons the wrong objects displayed. For example, drawing the pistol attached a fire hydrant to the character's hand.
DEATH
Quote from: DEATH on March 14, 2007, 08:56:20 AMFor example, drawing the pistol attached a fire hydrant to the character's hand.
:lol: :lol: :lol:
(Sorry, but that sounded pretty funny!)
I just tried adding WEAPONS MASTER to a character and used her in the RR. I saw goofy behavior, too. For me, there were two problems. One was a duplicate default entry in
FFX_WEAPONMASTER_CUSTOM in ffxcustom.py where I had
FFX_WEAPONMASTER_CUSTOM=[
["default","CUSTOM_DRAWPISTOL","ffx_flamethrower","CUSTOM_DRAWFLAMETHROWER","ffx_flamethrower","CUSTOM_DRAWRAYGUN","ffx_raygun"],
["types","CCommand#1","wWeapon#1","CCommand#2","wWeapon#2","CCommand#3","wWeapon#3"],
["default","CUSTOM_DRAWPISTOL","ffx_handgun","CUSTOM_DRAWFLAMETHROWER","ffx_flamethrower","CUSTOM_DRAWRAYGUN","ffx_raygun"],
]
when I should have had
FFX_WEAPONMASTER_CUSTOM=[
["default","CUSTOM_DRAWPISTOL","ffx_handgun","CUSTOM_DRAWFLAMETHROWER","ffx_flamethrower","CUSTOM_DRAWRAYGUN","ffx_raygun"],
["types","CCommand#1","wWeapon#1","CCommand#2","wWeapon#2","CCommand#3","wWeapon#3"],
]
The other thing is that the library\area_specific\weapons\handgun.nif is the mesh for a fire hydrant. I don't know how that got messed up and I don't have a handgun mesh handy, but I would imagine replacing that file with the one for an actual gun would help. (I was able to fire the hydrant as a gun, though.)
Unless someone enabled Weapon Master for 3.2 without mentioning it, the attribute was never really made available in FFX 3.x; the reason it's displayed (along with Time Master and probably some others) is because we made an error we releasing the Public Betas and merged with an old attributes.dat including old FFX 2.6 entries.
Hee. I like it. This is neither a bug nor a feature. It doesn't exist. :P (Shades of The Wizard of Oz: "Pay no attention to the man behind the curtain..." :D)
Or "Sorry if the attribute doesn't work perfectly. It wasn't meant to work at all." :P
Okay. I don't even know if it shows up in the in-game editor; I selected it creating a built-in with the editor. Guess I'll just have to find a mesh/skin combo that does what I need after all...
DEATH
Don't worry, you had no way to know it wasn't yet an "official" FFX attribute. If it shows up in FFEdit, it shows up in the in-game editor. What Épiméthée said is what's going on here: we added it to the attribute list to test for inclusion in a future version of FFX, but forgot to remove it when preparing the beta for release.
Quote from: stumpy on March 14, 2007, 06:53:26 PM
Don't worry, you had no way to know it wasn't yet an "official" FFX attribute. If it shows up in FFEdit, it shows up in the in-game editor.
Yeah, I didn't want to sound flippant. :)
QuoteWhat Épiméthée said is what's going on here: we added it to the attribute list to test for inclusion in a future version of FFX, but forgot to remove it when preparing the beta for release.
Actually, that's not what I said or meant – unless Stumpy is saying a
political truth; in that case... err, what the man said. ;)
Quote from: Epimethee on March 14, 2007, 07:02:04 PM
QuoteWhat Épiméthée said is what's going on here: we added it to the attribute list to test for inclusion in a future version of FFX, but forgot to remove it when preparing the beta for release.
Actually, that's not what I said or meant – unless Stumpy is saying a political truth; in that case… err, what the man said. ;)
Oops! I missed the "2.6" and got what you said confused with a conversation a while ago on the dev group about new attributes. My bad. I actually committed one of my own pet peeves: misquoting what someone just said. :oops:
I made a custom character and gave him a direct attack that causes mental blank.
I then swaped it from blank to mental damage, but when I use it, it just causes blank. There's no damage whatsoever. I tested it with panic and it didn't work either. I even run the power ID generator, but it still doesn't work.
Here's the script.log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.251000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1173961962.156000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> OnReceiveSelectedEnemies(('custom_vil_0', ))
try to spawn custom_vil_0
Campaign_MakeHeroIndex: Making index <e:\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
sk.SpawnEnemy: energy for _skcustom_vil_001 (cuban_male) changed from 9 to 0
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=46
storing hero_0: id_1,-46
numberStr=47
storing hero_1: id_2,-47
TIME: 0.007649 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for hero_0 ('aquaman (water)')
AI: SetupAI() - setting ai for _skcustom_vil_001 ('cuban_male')
AI: SetupAI() - setting ai for hero_1 ('thug_with_bat')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skcustom_vil_001 0 0
---- TIME: 0.017069 for AI_UpdateMapInfoStatic
AI: AISetRunning hero_0 to 0
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.006438 for ai for cuban_male
AI: AISetRunning hero_1 to 0
initAttribsForChar: working on hero_0 (aquaman (water))
initAttribsForChar (aquaman (water)): looking at attribute atlantianwater
execInitAttrib: init fastflier attribute inside ['atlantianwater', 'fastflier', 'fasthealing', 'invulnerable', 'acrobatic'] combo
on hero_0 of template custom_template_46 (aquaman (water))
execInitAttrib: init fasthealing attribute inside ['atlantianwater', 'fastflier', 'fasthealing', 'invulnerable', 'acrobatic'] combo
on hero_0 of template custom_template_46 (aquaman (water))
execInitAttrib: init invulnerable attribute inside ['atlantianwater', 'fastflier', 'fasthealing', 'invulnerable', 'acrobatic'] combo
on hero_0 of template custom_template_46 (aquaman (water))
execInitAttrib: init acrobatic attribute inside ['atlantianwater', 'fastflier', 'fasthealing', 'invulnerable', 'acrobatic'] combo
on hero_0 of template custom_template_46 (aquaman (water))
initAttribsForChar (aquaman (water)): looking at attribute telepathy
execInitAttrib: init telepathy attribute
on hero_0 of template custom_template_46 (aquaman (water))
initAttribsForChar (aquaman (water)): looking at attribute flier
initAttribsForChar (aquaman (water)): looking at attribute heavy hitter
initAttribsForChar (aquaman (water)): looking at attribute level headed
initAttribsForChar: working on _skcustom_vil_001 (cuban_male)
initAttribsForChar: working on hero_1 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001176 for ai for cuban_male
---- TIME: 0.012879 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002967 for ai for cuban_male
TIME: 0.001440 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.003275 for ai for cuban_male
---- TIME: 0.013396 for AI_UpdateMapInfoStatic
TIME: 0.001450 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002773 for ai for cuban_male
---- TIME: 0.013182 for AI_UpdateMapInfoStatic
TIME: 0.001190 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002928 for ai for cuban_male
TIME: 0.001164 for ai for cuban_male
---- TIME: 0.012937 for AI_UpdateMapInfoStatic[/spoiler]
Blitz, I don't see any errors in your log. Check ffxcustom.py and see if there's an entry for your character near the bottom in FFX_CARRIERS, like this:
["my hero's name","blank","mentaldamage","all"],
If it's not there, then that is probably the issue. Make sure you run the conversion and check FFXCC to make sure your swap is getting saved.
Blitzgott, damage state swaps dont work with direct attacks (or area or ranged explosive), state swaps only work with beam, melee, and ranged (non explosive) attacks.
I have another hopefully easy question (concern). Now this might of been covered before, and ive done a quick search, but this thread has grown quite long and I havnt came across it specificly yet.
My M25 AI controlled custom characters lack what they used to have in the previous version (DR Mikes last one), Watching a rumble room (watch mode) used to be very action orientated, now its alot of .....nothing. A character will use his active defense, hover around for awhile and activate it again, and again, and again, while normally aggressive characters will fire off a projectile, and stand there (or run away, but mostly stand there) until he finally gets energy to do something else. Now, all my characters have at least a zero energy melee, but they hardly use it
One thing I did notice was that the energy recharge rate was fixed, will take away alot of the watch mode action, but there is too much standing around and ...waiting. Is there anyway to unfix the recharge rate?
Also these are all characters that were run through the custom ai generator prevously, and not the current FFX3.2 version, but that shouldnt make any difference. The more I think about it I think If I can get the energy recharge rate back to the fast unfixed version that should do the trick.
There may be some other issue with the AI for your characters, but if they aren't using their zero-EP powers, then it's not likely to be just their energy stats that are wrong. I don't know if this is the solution, but an obvious thing is to do what you mentioned and run some characters through the new AI generator and see if that helps.
By the way the fix for the energy recharge rate was because, as released by IG, it really was broken. If your custom characters should all have an energy stat of 10 (which is what the bug caused for the enemies list characters). You can break it again by changing two or three files, but that's not really a good solution to this....
Quote from: USAgent on March 15, 2007, 06:21:42 PM
I have another hopefully easy question (concern). Now this might of been covered before, and ive done a quick search, but this thread has grown quite long and I havnt came across it specificly yet.
My M25 AI controlled custom characters lack what they used to have in the previous version (DR Mikes last one), Watching a rumble room (watch mode) used to be very action orientated, now its alot of .....nothing. A character will use his active defense, hover around for awhile and activate it again, and again, and again, while normally aggressive characters will fire off a projectile, and stand there (or run away, but mostly stand there) until he finally gets energy to do something else. Now, all my characters have at least a zero energy melee, but they hardly use it
One thing I did notice was that the energy recharge rate was fixed, will take away alot of the watch mode action, but there is too much standing around and ...waiting. Is there anyway to unfix the recharge rate?
Also these are all characters that were run through the custom ai generator prevously, and not the current FFX3.2 version, but that shouldnt make any difference. The more I think about it I think If I can get the energy recharge rate back to the fast unfixed version that should do the trick.
It sounds like the AIs are starved for energy.
There are a few things you could try...
Bump up the energy the characters get. If you were happy with them when they had a higher recharge rate, give them a higher recharge rate.
Give ranged characters a zero energy ranged attack. This will go a long way towards keeping the action up. The AI produced by the AI generator divides characters into ranged and melee types. Ranged types will try to stay away from the enemy, and they will not run up to use a melee attack, but they will happily use zero-cost ranged attacks. Melee types will use a zero energy melee attack.
Slightly more complicated: change the AI - the AI produced by the generator isn't sacred by any means. If it doesn't do what you want, change it. Ranged characters could be told to charge into melee when they have no energy if you like. It would look something like this:
['my_character',
["timer", 'auto',
"TFleeMelee(mindist='medium',movetype='move',time=0.87, situation='higherenergy 33')",
'TFleeMelee(type="any",subtype="emitting_damage",time=0.87)',
"TMelee('default Punch',time=1.03)",
"TRanged('high energy attack', time=2.88)",
'TMoveTo(mindist=\'long\' ,subtype="not emitting_damage",time=0.87)',
"TMoveTo(situation='lowerenergy 33', time=0.87)",
],
],
The key lines are TFleeMelee which keeps a character away from melee and the last TMoveTo. TFleeMelee has situation='higherenergy 33' added to it so the character will only move away when I have at least one bar of energy. The last TMoveTo has been added to encourage the AI to move towards the enemy when they have less than one bar of energy (getting them in range for a melee attack).
Finally, for characters that only use their active defense, either give them more energy, lower the cost of the defense, or modify their AI (this one is simple). The AI generator forces characters to maintain a minimum reserve of energy so that they have enough to use their active defense when they need it. You can get rid of that section and they won't store up energy.
Look in the AI for the lines:
['energy reserve',
'medium',
],
and remove them.
Quote from: USAgent on March 15, 2007, 02:20:31 PM
Blitzgott, damage state swaps dont work with direct attacks (or area or ranged explosive), state swaps only work with beam, melee, and ranged (non explosive) attacks.
I see.
Thanks.
Quote from: M25 on March 16, 2007, 09:14:06 AM
It sounds like the AIs are starved for energy.
Yes, the more I think about it that seems to be the case (instead of a new bug), the "ranged" types seem to be running or flying away until their energy recharges, and the characters with active defences arnt doing anything because they are waiting for thier "energy reserve" to be made, where as before when the characters energy were all at 10 they never had to wait for any reserve or energy charging.
Quote
The key lines are TFleeMelee which keeps a character away from melee and the last TMoveTo. TFleeMelee has situation='higherenergy 33' added to it so the character will only move away when I have at least one bar of energy. The last TMoveTo has been added to encourage the AI to move towards the enemy when they have less than one bar of energy (getting them in range for a melee attack).
I'm gonna use that for characters who are known for melee's as well as ranged attacks
Also I removed the "energy reserve" from one of my characters that use their active defense over and over, and it help out quite a bit.
Thanks for the help!
.......now back to stuff actually FFX3.2 related....
I'm not sure if it's a bug or something I overlooked, but built-in attributes simply don't work when I include them in combos. So far, I tested berserk, grim resolve and heavy lifter, and none of them seem to work. BTW, I tested grim resolve and berserk by letting a custom character hit another one to see how long it would take for him to recover from stun and if he would be enraged.
Could anyone help me out?
Thanks in advance.
Indeed a simple case of overlooking. ;)
Sadly, built-in attributes can't be included in combos. However the built-ins which could be simluated through scripting have been; those can be used in combos. For details, please check the "Combination Attributes (Power Cosmic and Thoughtform)" under Attributes in the manual. Available built-in attributes with scripted versions are listed in the Attributes Table page.
Heavy Lifter should be working, although it's the only one of those that should be.
Quote from: Epimethee on March 23, 2007, 04:41:17 PM
Indeed a simple case of overlooking. ;)
Sadly, built-in attributes can't be included in combos. However the built-ins which could be simluated through scripting have been; those can be used in combos. For details, please check the "Combination Attributes (Power Cosmic and Thoughtform)" under Attributes in the manual. Available built-in attributes with scripted versions are listed in the Attributes Table page.
Hmm...
I checked just now the attribute table like you told me to, and, according to it, both berserk and grim resolve should work with combo attributes. Heavy lifter too. However, they don't work for me, like I wrote in my last post. Is my manual outdated or something?
Touché. If it's not because the attributes are invalid, then the most likely cause are a typo in writing the combo attribute. Please paste your ffxmulti.py entry and script.log. Thanks.
And yes, there are parts of the manual which are outdated, but it shouldn't be an issue here.
I tested some more and I think grim resolve is working. Not sure, though. Kinda hard to tell only from watching heroes recover from stun.
I tested berserk again and it worked, if weirdly (triggers all the time and the hero takes forever to return back to normal state, if he returns).
Here are what you asked me:
ffxmulti entry: ['wolverine','ffqtracking','lesserregeneration','grimresolve','heavylifter'],
Script.log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.251000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1174734036.343000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> OnReceiveSelectedEnemies(('custom_vil_0', ))
try to spawn custom_vil_0
sk.SpawnEnemy: energy for _skcustom_vil_001 (cuban_male) changed from 9 to 0
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=46
storing hero_0: id_1,-46
TIME: 0.007671 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skcustom_vil_001 ('cuban_male')
AI: SetupAI() - setting ai for hero_0 ('wolverine (CC)')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skcustom_vil_001 0 0
---- TIME: 0.016660 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.006209 for ai for cuban_male
AI: AISetRunning hero_0 to 0
initAttribsForChar: working on _skcustom_vil_001 (cuban_male)
initAttribsForChar: working on hero_0 (wolverine (CC))
initAttribsForChar (wolverine (CC)): looking at attribute claws
initAttribsForChar (wolverine (CC)): looking at attribute hirsute
initAttribsForChar (wolverine (CC)): looking at attribute alkaline
initAttribsForChar (wolverine (CC)): looking at attribute wall climbing
initAttribsForChar (wolverine (CC)): looking at attribute wolverine
execInitAttrib: init ffqtracking attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'heavylifter'] combo
on hero_0 of template custom_template_46 (wolverine (CC))
execInitAttrib: init lesserregeneration attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'heavylifter'] combo
on hero_0 of template custom_template_46 (wolverine (CC))
execInitAttrib: init grimresolve attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'heavylifter'] combo
on hero_0 of template custom_template_46 (wolverine (CC))
execInitAttrib: init heavylifter attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'heavylifter'] combo
on hero_0 of template custom_template_46 (wolverine (CC))
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001080 for ai for cuban_male
---- TIME: 0.013187 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002640 for ai for cuban_male
TIME: 0.001105 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002756 for ai for cuban_male
---- TIME: 0.013077 for AI_UpdateMapInfoStatic
TIME: 0.001293 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.003075 for ai for cuban_male
---- TIME: 0.013033 for AI_UpdateMapInfoStatic
TIME: 0.001107 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.003092 for ai for cuban_male
TIME: 0.001083 for ai for cuban_male
---- TIME: 0.013378 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002817 for ai for cuban_male
TIME: 0.001073 for ai for cuban_male
---- TIME: 0.013432 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002705 for ai for cuban_male
TIME: 0.001106 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.003307 for ai for cuban_male
---- TIME: 0.013216 for AI_UpdateMapInfoStatic
TIME: 0.001097 for ai for cuban_male
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_0'
TIME: 0.002800 for ai for cuban_male
[/spoiler]
Your entries are fine and get initialised properly; no issue there. Just to cover the bases:
Grim Resolve: the scripted version should remove stun 50% of the time and print out to script.log "wolverine resisted the primary state attack!"
Berserk: since it's not part of the combo, I can't say. The code is quite simple and shouldn't behave like that. You were really using the scripted version? What were the other attributes on the character?
Tracking: There isn't a TRACK (or something similar) custom command on Wolvie?
Lesser Regen: So, Wolvie never regains HP?
Heavy Lifter: Assuming Wolverine is the first hero in the squad in Rumble Room mode: From the console, if you enter removeFFXAttrib('hero_0','heavylifter'), can he still lift all the same objects? (The attribute basically gives +3 strength to the characters for lifting objects.)
Quote from: Epimethee on March 24, 2007, 06:27:16 AM
Grim Resolve: the scripted version should remove stun 50% of the time and print out to script.log "wolverine resisted the primary state attack!"
Oh, I see... I'll see later if this message appears on my script.log.
Quote from: Epimethee on March 24, 2007, 06:27:16 AM
Berserk: since it's not part of the combo, I can't say. The code is quite simple and shouldn't behave like that. You were really using the scripted version? What were the other attributes on the character?
It was part of the combo, but I had to remove it because the hero went berserk almost as soon as the rumble room session started, and, therefore, didn't let me test the other attributes. But, as I mentioned earlier, it somewhat works.
Quote from: Epimethee on March 24, 2007, 06:27:16 AM
Tracking: There isn't a TRACK (or something similar) custom command on Wolvie?
There is. I didn't complain about this one.
Quote from: Epimethee on March 24, 2007, 06:27:16 AM
Lesser Regen: So, Wolvie never regains HP?
No issues with this one either. Just included there because you told me to paste my ffxmulti entry, so I just pasted the entire combo.
Quote from: Epimethee on March 24, 2007, 06:27:16 AM
Heavy Lifter: Assuming Wolverine is the first hero in the squad in Rumble Room mode: From the console, if you enter removeFFXAttrib('hero_0','heavylifter'), can he still lift all the same objects? (The attribute basically gives +3 strength to the characters for lifting objects.)
This one wasn't meant to be part of the combo. I gave it to Wolverine for testing purposes only and because I didn't felt like creating another combo attribute. And no, it's not working for me. I gave Wolverine a strength score of 4. With this much strength, cars cannot be lift from he ground. With heavy lifter, his strength, for lifting purposes, should be 7. With this much strength, he should be able to lift a car, but he can't.
Another script.log. In this one, the issue with berserk manifested again. As soon as the mission started, Wolverine went berserk and started attacking his teammates. One of them ("generic") had the Wolverine combo attribute too, so I kept watching Wolverine pound on him until he got stunned. I let it happen a few times and then I quit and opened the script.log. Yes, grim resolve works on combo attributes.
Berserk still is kind of weird. Wolverine went berserk as soon as the mission started and never returned to normal, while the generic (who also has the Wolverine attribute) didn't went berserk even after taking over a dozen blows from Wolverine. If it helps, the Wolverine mesh I'm using is Wolverine_TJ and generic used the alien warrior mesh.
Script.log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.251000
loading cshelper ...
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1174747743.937000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'heightcheck_sampling_default': (1, 8), '_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\sk.py importing FFX
ffx3\missions\scripts\sk.py loaded
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Felipe\Configurações locais\Dados de aplicativos\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', ))
try to spawn custom_vil_0
sk.SpawnEnemy: energy for _skcustom_vil_001 (cuban_male) changed from 9 to 0
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_CITY'
initialising FFX: skirmish=1
numberStr=46
storing hero_0: id_1,-46
numberStr=47
storing hero_1: id_2,-47
numberStr=48
storing hero_2: id_3,-48
TIME: 0.007592 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for _skcustom_vil_001 ('cuban_male')
AI: SetupAI() - setting ai for hero_0 ('generic')
AI: SetupAI() - setting ai for hero_1 ('generic2')
AI: SetupAI() - setting ai for hero_2 ('wolverine (CC)')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skcustom_vil_001 0 0
---- TIME: 0.016998 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.005985 for ai for cuban_male
AI: AISetRunning hero_0 to 0
AI: AISetRunning hero_1 to 0
AI: AISetRunning hero_2 to 0
initAttribsForChar: working on _skcustom_vil_001 (cuban_male)
initAttribsForChar: working on hero_0 (generic)
initAttribsForChar (generic): looking at attribute wolverine
execInitAttrib: init ffqtracking attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_0 of template custom_template_46 (generic)
execInitAttrib: init lesserregeneration attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_0 of template custom_template_46 (generic)
execInitAttrib: init grimresolve attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_0 of template custom_template_46 (generic)
execInitAttrib: init bezerker attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_0 of template custom_template_46 (generic)
initAttribsForChar: working on hero_1 (generic2)
initAttribsForChar: working on hero_2 (wolverine (CC))
initAttribsForChar (wolverine (CC)): looking at attribute claws
initAttribsForChar (wolverine (CC)): looking at attribute hirsute
initAttribsForChar (wolverine (CC)): looking at attribute alkaline
initAttribsForChar (wolverine (CC)): looking at attribute wall climbing
initAttribsForChar (wolverine (CC)): looking at attribute wolverine
execInitAttrib: init ffqtracking attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_2 of template custom_template_48 (wolverine (CC))
execInitAttrib: init lesserregeneration attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_2 of template custom_template_48 (wolverine (CC))
execInitAttrib: init grimresolve attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_2 of template custom_template_48 (wolverine (CC))
execInitAttrib: init bezerker attribute inside ['wolverine', 'ffqtracking', 'lesserregeneration', 'grimresolve', 'bezerker'] combo
on hero_2 of template custom_template_48 (wolverine (CC))
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001401 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013517 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002888 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001627 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002939 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division[/spoiler]
[spoiler]---- TIME: 0.013417 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001453 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003394 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013379 for AI_UpdateMapInfoStatic
TIME: 0.001581 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003003 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001304 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013663 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003059 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001281 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013527 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003090 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001471 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002946 for ai for cuban_male
---- TIME: 0.013443 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001494 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002925 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013362 for AI_UpdateMapInfoStatic
TIME: 0.001303 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003193 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001381 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013253 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003146 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
hero_0 resisted the primary state attack!
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001268 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013384 for AI_UpdateMapInfoStatic
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002976 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001286 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.003009 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013461 for AI_UpdateMapInfoStatic
hero_0 resisted the primary state attack!
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001286 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002729 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.014016 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001158 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002647 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013602 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
AI: _skcustom_vil_001:'cuban_male' hunting 'hero_2'
TIME: 0.002815 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001333 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
---- TIME: 0.013475 for AI_UpdateMapInfoStatic
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
TIME: 0.001198 for ai for cuban_male
Traceback (innermost last):
File "E:\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 21565, in updatefasthealer
percentage=Object_GetAttr(char,'energyPoints')/Object_GetAttr(char,'maxEnergyPoints')
ZeroDivisionError: float division
[/spoiler]
Sorry. It didn't fit in one post.
Thanks, I'll run some tests on Berserk and try to fix the updatefasthealer issue.
OK, I did some testing.
Berserk:
>Wolverine went berserk as soon as the mission started and never returned to normal, while the generic (who also has the Wolverine attribute) didn't went berserk even after taking over a dozen blows from Wolverine.
That could very well be normal; Berserk has 1/10 chance of occuring, so it might have happened the first time on Wolverine and might not have occured aftermore than ten hits on Generic. Otherwise, I'm lost – everything works perfectly on my computer. :dunno:
Lesser Regeneration: Solved (the code was merged with Regenerative, which already had the fix, and uppdated). BTW, the error was caused by Wolvie having no energy, which made the attribute useless anyway, as it requires energy.
Heavy Lifter: Looks like I've fixed it. Had an issue with the Ant's (which has the built-in version) speed once, but couldn't reproduce the issue. Touching wood.
Quote from: Epimethee on March 24, 2007, 02:22:27 PM
That could very well be normal; Berserk has 1/10 chance of occuring, so it might have happened the first time on Wolverine and might not have occured aftermore than ten hits on Generic. Otherwise, I'm lost – everything works perfectly on my computer. :dunno:
I don't think it's that. I tested several times, actually, and in all of them Wolverine and whoever else had the wolverine attribute went berserk a few seconds on the mission and would stay at it for a long time. I actually even spent an hero point to bring them back, but they'd go berserk again shortly after.
Edit: By the way, they went berserk on their own, if that's no clear. I'm not really sure, but I heroes with the built-in version of berserk only went berserk after taking damage.
Quote from: Epimethee on March 24, 2007, 02:22:27 PM
Lesser Regeneration: Solved (the code was merged with Regenerative, which already had the fix, and uppdated). BTW, the error was caused by Wolvie having no energy, which made the attribute useless anyway, as it requires energy.
Oh, I'm not having any problems with lesser regeneration, if that's the impression I gave. The hero files I used weren't even finished, so I might have forgotten to give them dots in energy, but there's no issue here. I've been using this attribute for a long time and nothing wrong ever happened.
Quote from: Epimethee on March 24, 2007, 02:22:27 PM
Heavy Lifter: Looks like I've fixed it. Had an issue with the Ant's (which has the built-in version) speed once, but couldn't reproduce the issue. Touching wood.
The Ant's? Well, heavy lifter works normally for me when given separatelly. When included on a combo, though, it don't work. I don't think the issue you had is related to mine, but, then again, I'm no expert. I hope you can fix it.
Quote from: Blitzgott on March 24, 2007, 02:52:44 PMI don't think it's that. I tested several times, actually, and in all of them Wolverine and whoever else had the wolverine attribute went berserk a few seconds on the mission and would stay at it for a long time. I actually even spent an hero point to bring them back, but they'd go berserk again shortly after.
Edit: By the way, they went berserk on their own, if that's no clear. I'm not really sure, but I heroes with the built-in version of berserk only went berserk after taking damage.
Definitively weird. :huh:
QuoteOh, I'm not having any problems with lesser regeneration, if that's the impression I gave. The hero files I used weren't even finished, so I might have forgotten to give them dots in energy, but there's no issue here. I've been using this attribute for a long time and nothing wrong ever happened.
Well, all the traceback errors in your logs were related to that. But it wouldn't have visible effect, as it breaks the attribute only for characters where it's not supposed to work anyway. :)
Quote from: Epimethee on March 24, 2007, 02:22:27 PM
The Ant's? Well, heavy lifter works normally for me when given separatelly. When included on a combo, though, it don't work. I don't think the issue you had is related to mine, but, then again, I'm no expert. I hope you can fix it.
Sorry, I was unclear. When testing the fix I wrote, I checked if it caused issues in charcters with the built-in version of the attribute (i.e., The Ant). During these tests, I once had the above bug.
Hey guys, just a quick question. When a character with vulnerability meets a toxic character, and the effect is set on 'the works,' is he supposed to lose invulnerability as well as speed and strength? If not, is there another way to simulate this?
It's supposed to remove invulnerability. Looking at the code however, I think there's a line missing. From your post, I take it Invulnerability doesn't seem to disappear, right?
Correct, I've tested it (admittedly, only with Supes and Luthor) and I can confirm that invulnerability stays in place.
I've already communicated with M25 about this in another thread (thanks for the help M25), but I thought it might be a good idea to mention it in the bug-reporting thread, just to make sure it doesn't fall through the cracks.
There is no ezscriptcampaign folder in the ffx\missions folder with the current install of FFX 3.2
DEATH
Thanks, but there's no need to report it here, as m25 has already submitted the fix.
I just tried to merge the dat files for EZFX and FFX. Now when I try to start the game I get a message saying that something "doesn't match header, objects.dat" or something.
What did I do wrong?
Kindly post this in a separate thread. This thread is for bug reporting, and that is not a bug.
It's not a bug, but it's such a small thing I don't think it deserves it's own thread.
Anyway, I was just wondering if that feature of changing the heroes weights via FFXCC will be included on FFX 3.2, and when.
Thanks.
We have no way of changing or updating the Control Centre, so this, or any other CC change, will not be happening in the near future.
QuoteIt's not a bug, but it's such a small thing I don't think it deserves it's own thread.
Things like that get their own threads all the time. We need to keep this thread focused.
Feature requests, but the way, shouldn't be in this thread either. It should be for bug reports ONLY.
Here's a head-scratcher. I created some custom zombie characters and set them up with very basic carrier substitutions for stun in melee attacks. Here they are from ffcustom.py:
["vz fresh zombie","stun","stasis","all"],
["vz rotting zombie","stun","strengthdrain","all"],
I ran 'em through AI Generator Rumble Room, then tried the zombies out as enemies in a regular Battle In The Rumble Room session. And while they stunned just fine, the carrier substituions never kicked in. Stun stayed stun.
I then tried the zombies as player-controlled good guys ... and now the carrier substitutions worked.
The only unusual thing about my FFX installation is that I applied M25's April 5 EZScript patch.
(Nothing from the log files because there's nothing like an error message in 'em.)
EDIT: I tried deleting the .M25AI files and then running the zombies as computer-controlled enemies. Lo and behold the carrier attacks worked again! So I guess it's some conflict between the carrier system and M25AI.
Follow-up: my problems with power swaps using the latest EZScript patch seem to apply to built-ins as well. According to ffxcustom.py, the Bard's blind is supposed to be swapped with transmute. But he's just doing blind.
The patch didn't do anything with swaps.
At any rate, it's working on my end, so it should work. You may need to rerun the ffx control centre to make absolutely sure the IDs are setup correctly.
Other than that, there's a line in m25aiopt.py
AIOPTPRINTCODE = 0
Set that to 1, run a session with blackbird and your custom and then send me a script.log file to see if the carrier indices are being generated correctly. Send it as a PM so as not to clutter up this thread.
I'm needing some help with the absorb materials attribute. I've got my Absorbing Man hero file set up with the attribute and have additional hero files set up for him to transform into:
Absorbman
Absorbman (stone)
Absorbman (metal)
The attribute works; i.e. I can see his resistances change when he absorbs stone or metal and he gains the Super Leaper attribute when he absorbs rubber, but he doesn't convert to the corresponding hero file. I've double checked the manual and a previous thread on the absorber attribute, but just can't seem to get this to work. I figure I've got something wrong since this is such a cool attribute and no one else has reported having any trouble. Thanks for any help you can give and thanks for this mod.
Check the format of your alternate forms. Is there supposed to be a space before the parenthesis, for instance?
From what you're describing it sounds like the game isn't recognizing that you have alternate hero files to transform into. I made it so that it will still work if you don't have alternate templates. If you don't have AbsorbMan (rubber) in the Heroes folder along with the AbsorbMan hero file, then the code just changes the material and gives the SuperLeaper command to the character when they absorb Rubber. It looks like you've named your hero files correctly, though, so I'm not sure why they're not shapeshifting. If you could send me your hero files, I could try it out and see what the problem is.
Okay, after getting your hero files, I see the problem is that the filenames aren't named correctly. You have them named:
Absorbman.hero
Absorbman__metal_.hero
Absorbman__stone_.hero
etc.
It should be like this:
Absorbman.hero
Absorbman (metal).hero
Absorbman (stone).hero
You do have the name of the heroes correctly but it's the name of the actual file that matters. It looks like you gave the the hero the proper name but you later renamed the hero file.
Thanks for the help TaskmasterX. I was looking for the incorrect names that you pointed out when I came across the fact that I had capitalized my material hero files and left my original hero file uncapitalized. :doh: It works fine now. I'm sorry that I'm an idiot.
Howdy guys, I've been experimenting with my invulnerable characters, trying alternate methods of toughening them up, but I've run into a bit of trouble. I wanted to use physical resistance combined with a low invulnerability, but it doesn't seem to be working.
I tested a copy of my superman built-in renamed superdude and edited to have phsyical resistance and invul. 05. He took full damage, minus teh 5 points. Then I tested him without the invul, and he took full damage, no reduction. The funny thing is I was fighting White Martians with physical resistance as a built-in, and I sort of think that they were only taking half damage. Here is my log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1177265477.875000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('thug_with_bat', 'thug_with_bat', 'thug_with_bat', 'white_martian', 'white_martian', ))
try to spawn thug_with_bat
try to spawn thug_with_bat
try to spawn thug_with_bat
try to spawn white_martian
try to spawn white_martian
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_PARK'
initialising FFX: skirmish=1
numberStr=93
storing hero_0: id_1,-93
numberStr=94
storing hero_1: id_2,-94
numberStr=95
storing hero_2: id_3,-95
TIME: 0.008018 for GetMissionVar
! GetMapInfo
AI: SetupAI() - setting ai for hero_2 ('green_arrow')
AI: SetupAI() - setting ai for hero_1 ('generic_hero')
AI: SetupAI() - setting ai for hero_0 ('animal_man')
AI: SetupAI() - setting ai for _skwhite_martian05 ('martian_manhunter')
AI: SetupAI() - setting ai for _skwhite_martian04 ('martian_manhunter')
AI: SetupAI() - setting ai for _skthug_with_bat03 ('thug_with_bat')
AI: SetupAI() - setting ai for _skthug_with_bat02 ('thug_with_bat')
AI: SetupAI() - setting ai for _skthug_with_bat01 ('thug_with_bat')
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skwhite_martian05 0 0
---- TIME: 0.031206 for AI_UpdateMapInfoStatic
AI: AISetRunning hero_2 to 0
AI: AISetRunning hero_1 to 0
AI: AISetRunning hero_0 to 0
AI: _skwhite_martian05:'martian_manhunter' hunting 'hero_2'
TIME: 0.007976 for ai for martian_manhunter
AI: _skwhite_martian04:'martian_manhunter' hunting 'hero_2'
TIME: 0.007242 for ai for martian_manhunter
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_2'
=====================================
Code for _skthug_with_bat03
-----
energy=js.Object_GetAttr(char,"energyPoints")
target=Target_GetCurrentTarget(char)
range=Target_GetDistance(char)
done=0
reserve=0
if js.Object_GetSecondaryStates(char) & js.SCSTATE_POWER_NULLIFICATION: energy=0
if (not done):
if (not done):
done = ff.AIGenericFleeOpt(tactic_id,event.object,event.string,event.float,event.user, pct = 60, type = "any", energy = 0, maxdist = 200, time = 0.87, mindist = 50, subtype = 1)
if (not done) and range >= 61 and range <= 105:
if (not done):
done = ff.AIGenericPowerOnTarget(tactic_id,event.object,event.string,event.float,event.user, pct = 100, energy = 0, time = 4.03, power = "thug with bat Club", subtype = 2, carrier = -1, mindist = 0, maxdist = 70)
elif (not done) and range <= 60:
if (not done):
done = ff.AIGenericPowerOnTarget(tactic_id,event.object,event.string,event.float,event.user, pct = 100, energy = 0, time = 4.03, power = "thug with bat Club", subtype = 2, carrier = -1, mindist = 0, maxdist = 70)
else: pass
if (not done):
if (not done):
done = ff.AIGenericMoveOpt(tactic_id,event.object,event.string,event.float,event.user, pct = 100, energy = 0, maxdist = 400, time = 0.87, mindist = 50, subtype = 3)
=====================================
####################### TIME: 0.331201 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_2'
TIME: 0.008368 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_2'
TIME: 0.008161 for ai for thug_with_bat
initAttribsForChar: working on hero_2 (green_arrow)
initAttribsForChar (green_arrow): looking at attribute crack shot
initAttribsForChar (green_arrow): looking at attribute grim resolve
initAttribsForChar (green_arrow): looking at attribute hot tempered
initAttribsForChar (green_arrow): looking at attribute acrobatic
execInitAttrib: init acrobatic attribute
on hero_2 of template custom_template_95 (green_arrow)
initAttribsForChar (green_arrow): looking at attribute battery
execInitAttrib: init battery attribute
on hero_2 of template custom_template_95 (green_arrow)
initAttribsForChar: working on hero_1 (generic_hero)
initAttribsForChar: working on hero_0 (animal_man)
initAttribsForChar (animal_man): looking at attribute jumper
initAttribsForChar (animal_man): looking at attribute hirsute
initAttribsForChar (animal_man): looking at attribute danger sense
initAttribsForChar (animal_man): looking at attribute flier
initAttribsForChar: working on _skwhite_martian05 (martian_manhunter)
initAttribsForChar (martian_manhunter): looking at attribute martian
execInitAttrib: init disciplined attribute inside ['martian', 'disciplined', 'invulnerable3', 'guardianm'] combo
on _skwhite_martian05 of template white_martian (martian_manhunter)
execInitAttrib: init invulnerable3 attribute inside ['martian', 'disciplined', 'invulnerable3', 'guardianm'] combo
on _skwhite_martian05 of template white_martian (martian_manhunter)
execInitAttrib: init guardianm attribute inside ['martian', 'disciplined', 'invulnerable3', 'guardianm'] combo
on _skwhite_martian05 of template white_martian (martian_manhunter)
initAttribsForChar (martian_manhunter): looking at attribute flier
initAttribsForChar (martian_manhunter): looking at attribute heat sensitive
initAttribsForChar (martian_manhunter): looking at attribute masscontrol
execInitAttrib: init masscontrol attribute
on _skwhite_martian05 of template white_martian (martian_manhunter)
initAttribsForChar: working on _skwhite_martian04 (martian_manhunter)
initAttribsForChar (martian_manhunter): looking at attribute martian
execInitAttrib: init disciplined attribute inside ['martian', 'disciplined', 'invulnerable3', 'guardianm'] combo
on _skwhite_martian04 of template white_martian (martian_manhunter)
execInitAttrib: init invulnerable3 attribute inside ['martian', 'disciplined', 'invulnerable3', 'guardianm'] combo
on _skwhite_martian04 of template white_martian (martian_manhunter)
execInitAttrib: init guardianm attribute inside ['martian', 'disciplined', 'invulnerable3', 'guardianm'] combo
on _skwhite_martian04 of template white_martian (martian_manhunter)
initAttribsForChar (martian_manhunter): looking at attribute flier
initAttribsForChar (martian_manhunter): looking at attribute heat sensitive
initAttribsForChar (martian_manhunter): looking at attribute masscontrol
execInitAttrib: init masscontrol attribute
on _skwhite_martian04 of template white_martian (martian_manhunter)
initAttribsForChar: working on _skthug_with_bat03 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on _skthug_with_bat02 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on _skthug_with_bat01 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.001793 for ai for martian_manhunter
TIME: 0.001401 for ai for martian_manhunter
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004837 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.003907 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004708 for ai for thug_with_bat
---- TIME: 0.015985 for AI_UpdateMapInfoStatic
AI: _skwhite_martian05:'martian_manhunter' hunting 'hero_1'
TIME: 0.003972 for ai for martian_manhunter
AI: _skwhite_martian04:'martian_manhunter' hunting 'hero_1'
TIME: 0.004081 for ai for martian_manhunter
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004381 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004582 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004977 for ai for thug_with_bat
TIME: 0.001565 for ai for martian_manhunter
TIME: 0.001236 for ai for martian_manhunter
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.003894 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004678 for ai for thug_with_bat
TIME: 0.002031 for ai for martian_manhunter
AI: _skwhite_martian04:'martian_manhunter' hunting 'hero_1'
TIME: 0.003428 for ai for martian_manhunter
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004586 for ai for thug_with_bat
---- TIME: 0.016498 for AI_UpdateMapInfoStatic
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004679 for ai for thug_with_bat
TIME: 0.001256 for ai for martian_manhunter
TIME: 0.001418 for ai for martian_manhunter
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004595 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004788 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004767 for ai for thug_with_bat
TIME: 0.001219 for ai for martian_manhunter
TIME: 0.001087 for ai for martian_manhunter
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004258 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004776 for ai for thug_with_bat
---- TIME: 0.016114 for AI_UpdateMapInfoStatic
TIME: 0.001228 for ai for martian_manhunter
TIME: 0.001597 for ai for martian_manhunter
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004580 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004543 for ai for thug_with_bat
TIME: 0.001233 for ai for martian_manhunter
TIME: 0.001540 for ai for martian_manhunter
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004671 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004658 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004994 for ai for thug_with_bat
TIME: 0.001232 for ai for martian_manhunter
TIME: 0.001235 for ai for martian_manhunter
---- TIME: 0.016160 for AI_UpdateMapInfoStatic
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004631 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004844 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004413 for ai for thug_with_bat
TIME: 0.001570 for ai for martian_manhunter
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004632 for ai for thug_with_bat
TIME: 0.001233 for ai for martian_manhunter
TIME: 0.001051 for ai for martian_manhunter
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004780 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004385 for ai for thug_with_bat
---- TIME: 0.016016 for AI_UpdateMapInfoStatic
TIME: 0.001828 for ai for martian_manhunter
TIME: 0.001015 for ai for martian_manhunter
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004494 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004612 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004976 for ai for thug_with_bat
TIME: 0.001237 for ai for martian_manhunter
TIME: 0.001058 for ai for martian_manhunter
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004921 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004433 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.003856 for ai for thug_with_bat
TIME: 0.001242 for ai for martian_manhunter
TIME: 0.001067 for ai for martian_manhunter
---- TIME: 0.016221 for AI_UpdateMapInfoStatic
TIME: 0.001558 for ai for martian_manhunter
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004068 for ai for thug_with_bat
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.004076 for ai for thug_with_bat
AI: _skthug_with_bat02:'thug_with_bat' hunting 'hero_1'
TIME: 0.004521 for ai for thug_with_bat
TIME: 0.001280 for ai for martian_manhunter
TIME: 0.001283 for ai for martian_manhunter
AI: _skthug_with_bat01:'thug_with_bat' hunting 'hero_1'
TIME: 0.003962 for ai for thug_with_bat
AI: _skthug_with_bat03:'thug_with_bat' hunting 'hero_1'
TIME: 0.004791 for ai for thug_with_bat
[/spoiler]
Kryptonite strikes again. :/
There's no Superman or Superdude shown in this log. He just didn't get recognized at all by FFX.
<Head-scratching>
I'd suggest re-trying to run the FFX Control Centre on him. If it still doesn't work, please check if he's listed in the HeroIndexData.txt at the root of your mod.
D'oh! Thanks Em, I just was a moron and forgot to run FFX, I think that everything's working now. Ohh, did you ever get around to fixing the code for vulnerability as pertains to invulnerable? I have a suggestion if you're still tinkering with it, you should set it to remove physical resistance too.
Quote from: BentonGrey on April 22, 2007, 12:20:16 PMD'oh! Thanks Em, I just was a moron and forgot to run FFX, I think that everything's working now.
No probleme; I'm just happy it was that simple. :)
QuoteOhh, did you ever get around to fixing the code for vulnerability as pertains to invulnerable? I have a suggestion if you're still tinkering with it, you should set it to remove physical resistance too.
The issue you reported is fixed (thanks!)
Removing Physical Resistance, however won't get be done for the final 3.2 release. At this point, only I-installed-FFX-and-it-ate-my-computer problems will be considered...* hey, got to leave some stuff to do for the next versions. ;) Beside, since it's not really a bug per se, I'll leave it to the attribute's co-author/maintainer, Stumpy, to decide how he wants to handle it.
*Still, keep reporting bugs, please!
Fair enough! Just for my two-cents, I think it'd be a good idea to have incorporated one of these days. ;) I'm looking forward to the final version of this Em.
I think the "sonic_scream" subtype is faulty.
When an Absorb Power character absorbs from a character with a "sonic_scream" subtype, the term "sonic screa," comes out...with the comma where the m should be. The power does not work at all.
I'm sure it's an easy fix, but I'm really new with scripting,
Thanks, laughing paradox. I see the problem. I mispelled the name of the power in the line:
Trigger_Power(char,target,'ffx_sonicsream','')
in ffx.py
If you add the "c", then it should work. Sorry about that. :banghead:
Ep, is that something that can be changed or is it too late?
It's too late, sorry.
...Ah, let's do it.
;)
Em...you're the man.
Quote from: BentonGrey on April 24, 2007, 07:03:54 PM
Em...you're the man.
Thanks! But, let us not forget that this is very, very much a team project... everyone involved is "the man". :)
(And, to tell the truth, I've been the one who slowed down the project in the last few months, a problem compounded by being in charge of the installer, i.e., the final bottleneck. So you know who to blame for the lateness of FFX. :P )
Ok, I've got something mysteriously weird going on.... FFvsT3R has been working fine as far as I can tell until today. I just made my Ultimate_Wasp and Ultimate_Wasp_Small characters in the character creator and gave my main character the Shapeshifting attribute. I shut down the main program and then open the FFX Control Center to make sure they are properly tagged and then set my Shapeshifting forms there. I go back into the main game and try to use the FFX Power ID Generator - It doesn't show any text at all and then hangs the game completely. I try to use the FFX AI Generator and it shows that it's recognizing the character I put into the Rumble Room but then hangs up completely.
I shut down the game and open the script.log like you requested and found this:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Loading m25ai.py v. 3.2.0 build 8; branch = m25 branch 1
Loading m25event.py v.3.2.0 build 6; branch = m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25report.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25timestamp.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25getset.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25string.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25distance.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25template.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25missionover.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25energy.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25generateai.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25aigeneratedata.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25team.py v.3.2.0 build 6; branch = m25 branch 2
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25custompowers.py v.3.2.0 build 6; branch = m25 branch 2
Starting System Utilities 1.3
Starting General Utilities 1.0
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
Loading m25gametype.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamdata.py v.3.2.0 build 6; branch = m25 branch 2
FREEROAM_KBD: initialized
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
Loading m25aiconstants.py v.3.2.0 build 6; branch = m25 branch 2
Starting Height Check module 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 build 8; branch = m25 branch 1
Loading m25name.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25cutscene.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25customheads.py v.3.2.0 build 6; branch = m25 branch 2
CustomHeadCurrentTime 1177635490.156000
Loading m25randomenc.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25objective.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25freeroamally.py v.3.2.0 build 6; branch = m25 branch 2
Loading m25spawn.py v.3.2.0 build 6; branch = m25 branch 2
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
Loading m25aiopt.py v.3.2.0 build 6; branch = m25 branch 2
>>> C:\Documents and Settings\Stewards\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Generate PowerIDs.py executed
>>> C:\Documents and Settings\Stewards\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Stewards\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Generate PowerIDs.py executed
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_AIRFIELD'
initialising FFX: skirmish=1
numberStr=42
storing hero_0: id_1,-42
Traceback (innermost last):
File "C:\Documents and Settings\Stewards\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\cM25 Generate PowerIDs.py", line 34, in OnPostInit
FFX_InitSkirmish()
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 269, in FFX_InitSkirmish
initialise(1)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 406, in initialise
FFX_Transformers = getBuiltinTransformers()
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 740, in getBuiltinTransformers
fxDat = datfiles.Campaign_ReadFX()
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\datfiles.py", line 1242, in Campaign_ReadFX
pType = ord(npr[375])
IndexError: string index out of range
TIME: 0.003949 for GetMissionVar
! GetMapInfo
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-40.0, 30.0, 1.20000004768, 1.0, (0.800000011921, 0.5, 0.20000000298))
Traceback (innermost last):
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 665, in initAttribs
object=initialiseChar(object)
File "C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\.\ffx3\missions\scripts\ffx.py", line 800, in initialiseChar
for temp in FFX_Transformers:
NameError: FFX_Transformers
TIME: 0.003483 for AI_UpdateMapInfoStatic
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
TIME: 0.003366 for AI_UpdateMapInfoStatic
TIME: 0.003367 for AI_UpdateMapInfoStatic
TIME: 0.003409 for AI_UpdateMapInfoStatic[/spoiler]
Okay, Where did the FFX_Transformers error come from? I don't remember it before and it just suddenly appeared as a problem today but was working fine yesterday when I was making new hero files.
I'm stumped... anyone willing to help?
- CrimsonQuill
First of all, are these hero files? If they are, the Power ID Generator is not even necessary. In fact, in the case of HF, it does absolutely nothing anyway.
And you did run them through the Control Centre of course?
other than that, I don't know.
It looks like datfiles.py is having trouble reading fx.dat Have you made any changes to it recently?
Quote from: M25 on April 26, 2007, 06:52:58 PM
It looks like datfiles.py is having trouble reading fx.dat Have you made any changes to it recently?
Actually, yeah, I just added a the Classic_Cap_Shield and Patriot_Spinning_Star FX by using the FFEdit program.. but I don't think I messed up any other coding other then what the readme.txt files said to do.
Edit: Wait! I do remember that when I added optic_blast_lefthand that I might have accidently hit the rename button on the optic_blast_hand fx and that might have created the error.
Edit: Ahhh!! Ok, I renamed the deleted the old fx.dat file and renamed the fx.dat.old file to take it's place. And then I checked my saved copy of the bad .dat file and low and behold I added a / in the optic_blast_hand name by mistake. D'OH! :banghead:
- CrimsonQuill
:thumbup: :balloons: :yipee
The official release of FFX 3.2 is at long last available!
http://ffx.freedomforceforever.com/
Cheers! :D
As I said in the other thread, Hooray!!!!
My would-be favorite feature ("No Minimum Range") doesn't seem to work even on Gold. I don't get any errors on my script.log. Is there something that cane be done?
I don't think it ever worked perfectly all the time anyways. I'd like to hear if anyone else is having problems, though.
NO MINIMUM RANGE: As far as I can tell, it doesn't do anything, probably because the FF variable this should change cannot be changed on the fly, i.e., must be set before FFX loads. Sadly, even startup plugins don't work . So you'll need to open your C:\Program Files\Irrational Games\Freedom Force vs The 3rd Reich\System\localinit.py file in Notepad and add the line
ff.RANGD_MIN = 0
I'm having a problem with Carriers not working in my Mod.
If I have a hypnosis to magnetize swap, I just get hypnosis, etc.
I've taken M25's Firelight Mod, merged my Dats with it, copied in scripts, meshes etc etc etc.
Everything seems set up in FFXCustom.py, and I've checked the swaps in the FFX control centre.
All other FFX stuff is fine, powers, AI etc etc.
The script.log doesn't seem to show an error, just this:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Starting ffx.py v. 3.2.0 build 10; branch = Public Beta 2
Loading m25ai.py v. 3.2.0 build 10; branch = beta 2: m25 branch 1
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0 alpha 17
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
CustomHeadCurrentTime 1178886959.083000
Starting Height Check module 1.4
Starting System Utilities 1.3
Starting General Utilities 1.0
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Campaign_ReadObjects() warning: object template <pat_dream_fog_effect> has more than one entry for attribute <animated>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <nazihq_storage_crate> has more than one entry for attribute <castShadow>, values 1.000000 and 1.000000
Campaign_ReadObjects() warning: object template <ffx_limpetmine> has more than one entry for attribute <avoid>, values 0.000000 and 1000.000000
Campaign_ReadObjects() warning: object template <ffx_flames> has more than one entry for attribute <minForce>, values -1.000000 and 1000000.000000
Campaign_ReadObjects() warning: object template <dark_shaman> has more than one entry for attribute <prestige>, values 30.000000 and 50.000000
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_opendoor' imported
FFX Mission Plugin 'cutscene_power' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'zombie' imported
FFX Mission Plugin 'firehydrant' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
then various other stuff...........
then:
clearCarrierRegistration: clearing attribute 'hypnosistocrystallisehero_1' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'stuntomagnetisem25obj_10' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hypnosistomagnetisem25obj_10' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'stuntohypnosism25obj_22' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'stuntogravityincreasem25obj_28' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hypnosistogravityincreasem25obj_28' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hypnosistocrystallisehero_1' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'stuntomagnetisem25obj_10' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hypnosistomagnetisem25obj_10' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'stuntohypnosism25obj_22' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'stuntogravityincreasem25obj_28' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hypnosistogravityincreasem25obj_28' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hypnosistocrystallisehero_1' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'stuntomagnetisem25obj_10' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hypnosistomagnetisem25obj_10' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'stuntohypnosism25obj_22' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'stuntogravityincreasem25obj_28' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hypnosistogravityincreasem25obj_28' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hypnosistocrystallisehero_1' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'stuntomagnetisem25obj_10' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'hypnosistomagnetisem25obj_10' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'stuntohypnosism25obj_22' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'stuntogravityincreasem25obj_28' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'hypnosistogravityincreasem25obj_28' for destroyed object 'mapinfocaliper3'
and later:
clearCarrierRegistration: clearing attribute 'hypnosistocrystallisehero_1' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'stuntomagnetisem25obj_10' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'hypnosistomagnetisem25obj_10' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'stuntohypnosism25obj_22' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'stuntogravityincreasem25obj_28' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'hypnosistogravityincreasem25obj_28' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'OnKBhero_3' for destroyed object 'm25obj_24'
clearCarrierRegistration: clearing attribute 'OnKBm25obj_40' for destroyed object 'm25obj_24'
which crops up a couple of times.
[/spoiler]
Now, it's possible not all the powers have been registered (or whatever it's called), but the carriers used to work at some earlier point, and I hadn't done the powerID thing then.
Should I be using the "official" FFX (I note that the beta is in Firelight)?
This is happening with human control of the characters (though I AM "swapping" in to control them, so maybe they don't get initialised correctly?)
Any help gratefully accepted.
I had the same problem when trying to upgrade LB to FFX 3.2. Upgrading is VERY tricky and usually results in the whole thing breaking. In fact, in the end, m25 did it for me. I never could get it to work.
OK, I ran the characters in question through the generate power IDs danger room mission, and now alls well. So that was the problem. I must have added enough new powers to break something, and they needed to be re-integrated (or whatever it does).
Hooray for FFX! Boo for my ignorance!
Not a bug report but a quick question: Why are there multiple entries for some attribs (e.g. summoner) in FFX 3.2? Is it t represent the different grades?
Quote from: apfarmakis on May 11, 2007, 10:37:01 AM
Not a bug report but a quick question: Why are there multiple entries for some attribs (e.g. summoner) in FFX 3.2? Is it t represent the different grades?
Yes. It was necessary to seperate the grades to make them viewable in FFX Control Center if the attribute were part of a Combo Attribute.
Rumble Room
Custom character
Receiving a message informing me that Absorb Materials can not be initialized.
Rumble Room
Custom character
Receiving message that can not initialize pheromones in combo attribute.
And these are coming up withOUT opening the console. :blink:
How do I make a vehicle as a built-in? I've been trying with no success for a while now. I've given the built-in character the driver attribute, created the built-in vehicle (both in the character and template tab) and set them up in ffxcustom2.py.
Could I get a walk-through because all I'm getting is the vehicle appearing but it cannot be controlled and the script.log doesn't show any errors.
Sorry, Driver/Vehicle is still rather broken (has always been, I think); we should have added a note about it.
Quote from: Epimethee on May 12, 2007, 05:34:01 PM
Sorry, Driver/Vehicle is still rather broken (has always been, I think); we should have added a note about it.
Does the old code for driver/vehicle work at least? It's such a shame to let such a great attribute go to waste.
The old code is still there. That attribute is, as far as I know, unaltered from its original release. Dr. Mike said himself that it wasn't quite finished.
Actually, I patched a couple of bugs (in 3.1.1 or whatever it was named and in FFX 3.2), but the AI bug... well, the 3.2 release was getting quite late by then and AI is not my forte, so I put it on the "too bad" list. :(
sorry if this came up before - didn;t see it...
My rumble room sessions never end. I kill the bad guys and it doesn;t end - or in the case of iron man mode, I kill baddie #1 and no second wave comes. Just a red arrow where the poor bugger fell to Superman's heat vision :(
ok bit of an update - I wasn't using the ffx rumble room entries - THEY work fine... new problem.. :)
None of the 4 mini-mods works at all. I pick characters and bad guys and wander around a conflict-less map. No script ever fires. Should I be doing something to get it all working?
Probably the first thing to try is a fresh install of FFX3.2. It sounds like something isn't initializing properly.
reinstalled ffx and ffvttr and everything is fine! thanks m25
Make sure you don't have any old head.nif files from FF1 in with your meshes.
Quote from: ips on May 31, 2007, 01:37:32 PM
hmmm i don't think any of them have head nifs... where is it looking? just my character's main mesh folder right? copying from there?
Yes, it is looking in the mesh folder for a character.
How many installed FX does FFX 3.2 support?
I just added some FX and tried Battle In The Rumble Room. FFX gave out and failed to initialize the session. There was an error message in the log (that I foolishly failed to save :doh:) about some index being out of bounds when initializing FX.
I deleted some unused FX in FFEdit (*not* the FX I had just installed,) tried Battle In The Rumble Room with the same charcters, and everything worked fine again.
My guess is that I hit some limit on the number of FX--if so it would be nice to know what that number is.
FFX has nothing to do with the number of FX the engine supports. Any limit, if that was indeed your problem, has to do with the game engine itself, not FFX.
I think somone mentioned recently about the same problem when using something like 800 entries in fx.dat, IIRC. So yes, you might be hitting the max FX limit. But, as Cat pointed out, it has nothing to do with FFX as far as we can see.
Although I must point out that FFX does add a few FX of its own, so if you are having this problem only with FFX, then the extra FXs are likely the deciding factor.
Thanks for the info!
When I read that I thought, "800 FX? That's crazy! I don't have anywhere near that many!" Then I started counting and um, well.... (cough)
I guess it's time to start weeding out the ones I don't use ....
I'll try to have a look at Russian Doll. IIRC, I already did, but didn't have the time to solve it or got sidetracked.
I'll leave the AI and control issues to teammates more competent in this aspect.
I'm not sure if anyone noticed this but when I pick up a vehicle and throw it on the fire hydrant, even in full health it immedietely explodes? Was this intentional or it was missed?
I always set up my AI enemies to walk towards the fire hydrant and throw the car and boom! :thumbup: It's fun, but I think it's overpowered, perhaps the car shouldn't explode immedietely? What do you guys think?
Is this a problem with FFX 3.2 or with the game engine generally?
I'm pretty sure that's an engine issue. I don't think we did anything with that.
EDIT: On second thought, FFX adds a water explosion if the fire hydrant is damaged and it goes off VERY easily. Since it's a plugin, you can just remove it.
If it happens only with fire hydrants, it certainly looks like the plugin is the culprit (my fault!); still, it's a bit puzzling, as the added explosion does onl very low cold damage and low knockback – it shouldn't have anywhere this much effect. Sigh...
To disable the plugin, move the "ffq_firehydrant" folder under "ffx3\Missions\Scripts\ffxplugins\active\" to "ffx3\Missions\Scripts\ffxplugins\inactive\"
Enemies don't do anything while enraged--they just stand there.
(Looking at the readme I realize this is technically a known issue, but I figured you guys might want a little reminder!)
Quote from: Indigo on July 18, 2007, 09:30:00 AM
I'm not sure if anyone noticed this but when I pick up a vehicle and throw it on the fire hydrant, even in full health it immedietely explodes? Was this intentional or it was missed?
I always set up my AI enemies to walk towards the fire hydrant and throw the car and boom! :thumbup: It's fun, but I think it's overpowered, perhaps the car shouldn't explode immedietely? What do you guys think?
Quote from: Epimethee on July 18, 2007, 06:13:06 PM
If it happens only with fire hydrants, it certainly looks like the plugin is the culprit (my fault!); still, it's a bit puzzling, as the added explosion does onl very low cold damage and low knockback – it shouldn't have anywhere this much effect. Sigh...
To disable the plugin, move the "ffq_firehydrant" folder under "ffx3\Missions\Scripts\ffxplugins\active\" to "ffx3\Missions\Scripts\ffxplugins\inactive\"
I can't reproduce the bug. Anyone else can?
The disrupt attack can make trees explode...aren't they only supposed to have an effect on metallic stuffs (cars, lightposts, fire hydrants)? :D
Disrupt can make most objects explode besides characters and buildings. There is no limit based on material.
BTW, was there an FFX 3.2 bug-related aspect to the question?
Disrupt Object: Excites target non-organic molecules resulting in an explosion
or·gan·ic : of, relating to, or derived from living organisms.
in·or·gan·ic : forming or belonging to the inanimate world b : not arising from natural growth.
Is there a difference between inorganic and non-organic (besides its spelling and pronunciation)?
The description text is inaccurate, as it is in other instances. The game makes no distinction between organic and inorganic materials for purposes of powers like disruption. It will work on trees and bushes and even on objects made of flesh, if they aren't characters or buildings. Similarly, it won't work on characters or buildings even if they are made of metal, stone, etc.
Feel free to edit the strings.txt file to better reflect the power.
And, again, did this involve an FFX 3.2 bug somehow?
Quote from: IndigoThe disrupt attack can make trees explode...aren't they only supposed to have an effect on metallic stuffs (cars, lightposts, fire hydrants)?
I think I'm probably asking if this was a bug, not making a statement that this is a bug. It seems you're part of the FFX team so I'll take your word that this is not a bug.
Hmm. Whether the power doesn't work correctly or the description is wrong is a judgment call, I suppose. As sort of a practically-minded person and knowing that there is nothing we can do to change how the power works, I prefer to think the folks at IG were off in the description. Something we can easily do is change the description to read OVERLOADS MOST INANIMATE OBJECTS WITH ENERGY-X, CAUSING THEM TO EXPLODE!
The power has worked that way since the first game and I am pretty sure it hasn't been modified by FFX.
I hope that clears things up a bit. :)
Sorry, perhaps this question is already answered but I can't find it with search function.
I have the German edition of FFvt3R and made a fresh Installation. Now I figured out that there are many mods but they need FFX 3.2 and EZFX. I installed first EZFX and then FFX 3.2. That's all I did. Now I can start the game with "play FFX3" but there is a Problem.
All new attributes appear like:
"attrib_toxic" or "attrib_weathercontrol"
and on the right where the detailed description should be, there's only on word.
Like "attrib_toxic_desc" or "attrib_weathercontrol_desc"
What's wrong? Thanks for help!
In FreedoForce1 there where no such problems with mike's FFX. There where the descriptions or names of new attributes like they should be.
I assume that by German edition you mean that the descriptions of powers, objects, etc are all in German, right? Unless you are looking to write them yourself, you aren't going to get the new attribute names and descriptions in German.
But, you can get the English versions to show up by 1) making a copy of the ..\data\Lang\German folder as ..\ffx3\Lang\German and then 2) grabbing the FFX-specific stuff from the English strings.txt file in ..\ffx3\Lang\English and adding them to the German version and using FFEdit to generate the language files again. I don't have the German language stuff, so I can't be sure (and make sure to make a backup of everything in your ..\Lang\German folder!), but it should work.
To find the FFX stuff in the ..\ffx3\Lang\English\strings.txt file, do a search for ------------1_01, -------------------- FFX STARTS HERE. Everything from that point to the end of the file should be stuff you can copy to the strings.txt file in the German tree. Then use the "Generate Language Files" button in FFEdit to recompile the files. (Make sure to quit the game before regenerating anything in FFEdit.)
If you haven't used FFEdit to generate the language files before, ask in this thread and I or someone else can walk you through it.
Let us know how it works.
It works! I remember the time 3 years ago with all the *.ff extracting to get the editor to work and such things and this community is still as nice as then! Thank you very much!
O, and here a very important link for all users of UK or other European versions of FFvt3R:
http://files.filefront.com/Freedom+Force+vs+The+3rd+Reich+UK+Mod+Tools/;3942762;/fileinfo.html (http://files.filefront.com/Freedom+Force+vs+The+3rd+Reich+UK+Mod+Tools/;3942762;/fileinfo.html)
These are the patched mod tools, there was a problem at the release with the copy protection, so these were developed. Whithout these mod tools the ffedit2 will not work for european versions. Perhaps somebody can put this link in a adequate thread if not already happened ;)
I have another problem. When I'm running the game with ffx3, you can use every power with one less energy field than normally. For example: I create a power which needs 3 bars (costs: "high") and in Rumble Room it shows up with 2 bars needed. Or powers with "low" costs show up with zero energy bars needed. Strange. And medium powers need one energy bar. Any idea? It's also the same issue in the campaign. Alchemiste's shield only needs 1 bar. Normal should be 2.
When I start the game without ffx the problem is gone.
That's deliberate so that you can use a power that nominally requires more energy than you have, but there is a chance of stun, just as you couldin the first game. I prefer it, but you can disable it in the FFX Control Centre.
Just to clarify, the powers actually do use the same amount of the energy that you set, but the game is fooled into thinking it costs one less.
Here's an odd one: when Weaken expires, it KOs the affected character instead just removing the state.
(If you use Heroic Revival to bring the character back, the character is KO'd again a few seconds later as if he had taken progressive damage.)
This is happening with both my .hero file characters that use Weaken, as well as with the built-in Shurales.
That's an issue with the game itself. I've seen that one for the last 2 years. The state drains health for some reason and it will KO your character before it wears off then it carries over if you revive before the state times out. You can see it with a character that has lesser regeneration after he gets KO'd, watch the health bar, it's very interesting. Bottom line is: wait longer then use heroic revival.
Quote from: yell0w_lantern on August 11, 2007, 10:03:44 AM
That's an issue with the game itself. I've seen that one for the last 2 years. The state drains health for some reason and it will KO your character before it wears off then it carries over if you revive before the state times out. You can see it with a character that has lesser regeneration after he gets KO'd, watch the health bar, it's very interesting. Bottom line is: wait longer then use heroic revival.
Yep, you're right that progressive damage continuing to be applied after the character is KO'd is be an issue with the original game!
The actual Weaken problem itself is unique to FFX, though ... I just fought a bunch of Shurales in plain FFVTR with no FFX, and Weaken works fine there. If I fight 'em in FFX, though, anyone who gets weakened is KO'd the instant the effect wears off, regardless of how many hit points they had at the time.
Mass Control doesn't work for me. Neither in Liberty Bay, nor with a custom FFX Char. All other (tested) custom attributes work.
I can confirm that Mass Control does work in LB, if purchased by Doc A in the campaign. Haven't tested it in the RR though.
Quote from: guts on February 21, 2007, 02:54:21 AM
Oh, by the way, I still can't use Doc Astounding's Mass Control attribute in the campaing for some reason; which is quite strange, really, since I made a custom character with this same attribute and used it in Liberty Bay's Rumble Room and it worked.
Edit: In Mission 3 Mass Control started working once again. However, I still can't use it in Mission 2 despiste having bought it at the end of Mission 1. Is it intentional that a character's new powers only manifest themselves a mission after having been bought or is it a bug indeed?
Same with me. Mission 3 I have not tested yet. I purchased it after Mission 1 and it didn't work in Mission 2. And it works not (for me) with usual custom chars I created in FFX.
It could be a glitch with the way FFX works in campaigns. Interesting enough, in my tests, I don't buy it until Mission 3 and it works fine there.
Hmm, I'm not entirely sure that this is an issue with FFX as I haven't tested vanilla, but I don't recall having this problem before. When I go to play a match in RR (standard rumble match, nothing fancy) and have random heroes and enemies selected, the game freezes. It happens just after I choose the prestige amount for the heroes and hit the next button. I discovered it today while doing balance testing for the DCU.
I'm constantly having an issue with the green bubbles that are associated with flying attributes constantly active rather than active and then fade away but the attribute is still active. Is there a fix for this?
AfghanAnt (sorry for the late answer, it seems we're all too busy for FFX testing), I've looked into the issue a bit and couldn't reproduce it at all. IIRC, you had the same problem a year ago, but I can't remember much, except that I did have the problem from time to time too.
Does it happens systematically with attributes using the scripted version of flight? Does it happen on an unmodified FFX 3.2 (say, a fresh install in a separate folder)?
To test it directly, in the Rumble Room, open the FF console and type addFlight('hero_0')
I've just realized that some (perhaps all if I look more closely) of my heroes melee powers that cost 0 energy are actually sucking up 1 energy bar. I checked the AI files and the powers in Alex's Hero Editor, and in both situations there is nothing to suggest that energy should be used with the attack. I'm not sure where to go from here. Any ideas?
It's ok. It seems that if you restart the level it fixes the problem.
No real idea, but a couple questions, just in case:
1) Did you check if it happens it plain FFvsTTR? With FFX 3.0/3.1-based mods?
2) Does the problem still occurs if you uncheck the mod's "Overspend energy w/ stun risk" option in the FFX CC?
3) Does it occur only with AI characters? Only with player-controlled ones?
EDIT: Ninja'ed by AA! I'd still like to know what is going on, though. :huh:
Well, I went and restarted the level and the problem went away. I was using team mode with the AI running all heroes. Very odd. Thanks all.
Has anyone had their left click button taken over by one of your attributes? Let me explain. Normally, your cursor will be an arrow when your just hovering over empty ground, and if you left click, your character will move to that spot. Now, if I add megablast as an attribute for my character and start and danger room session, the cursor will always be a yellow hand, and if i left click on empty ground, he'll try to use megablast.
The same thing will happen on different characters for jumper and utility belt (after i choose my items). I'm sure it's something I did, but i can't think of what! :doh:
PS - sorry for the long post, and i can include my logs in a few hours if it'll help!
It's nothing you did. That's been a long complaint about the custom action function of the game. Some of the FFX attributes let you choose an object as a target, destination, et cetera and the custom action tool is the only tool we have for letting you do that. Unfortunately, the "dread hand" becomes the default action for a character with one of those attributes and there is no nice way around it, aside from not giving those attributes to characters.
One of the wish list items for scripting has been an option in the custom action code to specify whether or not the hand is the default left-click action. No dice, though.
interesting. It's weird because it didn't start happening until a few days ago. Anywho, thanks for the heads up!
Oops. I wasn't paying close enough attention to your post. :doh:
The issue of the hand over empty sections of the terrain is map-specific. You'll probably notice that it doesn't happen on all maps. At one point, I thought we had fixed this by excluding the map object from the objects the hand registers over. Maybe there was a reason it couldn't be fixed for all maps, but I don't recall right now. If you can post which maps were giving you the problem, maybe we can see what's going on with them.
The only map I play is the City map in the rumble room. It's the forth one down. I love blowing up the building!
when i try and run any scripting examples in the rumble room, my pc freezes and crashes.
this was the last log. keep up the great work.
Starting General Utilities 1.0
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
CustomHeadCurrentTime 1192855693.687000
Starting Height Check module 1.4
Starting System Utilities 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'cutscene_power' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_opendoor' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
>>> C:\Documents and Settings\CATMANEXE\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\MiniMod Example - Allies.py executed
>>> C:\Documents and Settings\CATMANEXE\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
! GetMapInfo
>>> C:\Documents and Settings\CATMANEXE\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\MiniMod Example - Allies.py executed
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'CITY LANDMARKS'
initialising FFX: skirmish=0
mapinfocaliper0 is not a valid explosion object
mapinfocaliper1 is not a valid explosion object
mapinfocaliper2 is not a valid explosion object
mapinfocaliper3 is not a valid explosion object
numberStr=42
storing hero_0: id_1,-42
ReadHeroIndexData: trouble reading or evaluating data from <c:\program files\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex: Making index <c:\program files\irrational games\freedom force vs the 3rd reich\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex: Complex not set for kid. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex warning: <sky2> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex: Complex not set for nick_craft_civ. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex: Complex not set for kid2. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex: Complex not set for clint_coltrane_civ. Run datfiles.Campaign_SetMissingComplexAttribs()
script.log would be helpful too. I personally can't see anything here, but that one is usually far more helpful.
That was the script.log.
It looks like maybe the FFX Control Centre wasn't started before the game was. There are a couple of errors that look related to proper branding. With the game off, run FFX CC, the quit FFX CC, then start the game and (if you are still having trouble) post your script.log from there, along with notes on which characters you were trying to play.
Your ff.log would be useful too.
Mind you, FFX shouldn't be able to completely crash your PC. :ph34r:
QuoteThat was the script.log.
Sorry, didn't look like most of the script.logs I've seen. Maybe I've just been away from modding for way too long.
Howdy guys, I'm having a problem with my built in villains damage swaps not working. It's only when they are enemies, not when I'm controlling them myself. It's a hex to mental damage swap. Here's the log:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Starting ffx.py v. 3.2.0 build 11; branch = Gold / Release
Loading m25ai.py v. 3.2.0 build 10; branch = beta 2: m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0.18 release
Starting General Utilities 1.0
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
CustomHeadCurrentTime 1196360816.531000
Starting Height Check module 1.4
Starting System Utilities 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Campaign_ReadObjects() warning: object template <water> has more than one entry for attribute <mass>, values 650.000000 and 650.000000
Campaign_ReadObjects() warning: object template <jm_pad_white> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad_green> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad_brown> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <bigwater> has more than one entry for attribute <mass>, values 650.000000 and 650.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'cutscene_power' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_opendoor' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('gorilla_grodd', 'the_shark', ))
try to spawn gorilla_grodd
try to spawn the_shark
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_PARK'
initialising FFX: skirmish=1
numberStr=67
storing hero_0: id_1,-67
numberStr=68
storing hero_1: id_2,-68
numberStr=69
storing hero_2: id_3,-69
numberStr=70
storing hero_3: id_4,-70
! GetMapInfo
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 70.0, 1.0, 0.800000011921, (0.699999988079, 0.600000023842, 0.600000023842))
addArrow _sk_arrow _skgorilla_grodd01 0 0
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skgorilla_grodd01' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skthe_shark02' for destroyed object 'mapinfocaliper0'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skgorilla_grodd01' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skthe_shark02' for destroyed object 'mapinfocaliper1'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skgorilla_grodd01' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skthe_shark02' for destroyed object 'mapinfocaliper2'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skgorilla_grodd01' for destroyed object 'mapinfocaliper3'
clearCarrierRegistration: clearing attribute 'hextomentaldamage_skthe_shark02' for destroyed object 'mapinfocaliper3'
initAttribsForChar: working on hero_0 (airstryke)
initAttribsForChar (airstryke): looking at attribute thanagarian
execInitAttrib: init ffqnimbleflier attribute inside ['thanagarian', 'ffqnimbleflier', 'fastflier', 'grimresolve', 'fasthealing'] combo
on hero_0 of template custom_template_67 (airstryke)
execInitAttrib: init fastflier attribute inside ['thanagarian', 'ffqnimbleflier', 'fastflier', 'grimresolve', 'fasthealing'] combo
on hero_0 of template custom_template_67 (airstryke)
execInitAttrib: init grimresolve attribute inside ['thanagarian', 'ffqnimbleflier', 'fastflier', 'grimresolve', 'fasthealing'] combo
on hero_0 of template custom_template_67 (airstryke)
execInitAttrib: init fasthealing attribute inside ['thanagarian', 'ffqnimbleflier', 'fastflier', 'grimresolve', 'fasthealing'] combo
on hero_0 of template custom_template_67 (airstryke)
initAttribsForChar (airstryke): looking at attribute flier
initAttribsForChar (airstryke): looking at attribute temperature control
initAttribsForChar (airstryke): looking at attribute solid skeleton
initAttribsForChar (airstryke): looking at attribute claws
initAttribsForChar: working on hero_1 (ambush_bug)
initAttribsForChar (ambush_bug): looking at attribute wall climbing
initAttribsForChar (ambush_bug): looking at attribute bedevilled
initAttribsForChar (ambush_bug): looking at attribute weak minded
initAttribsForChar (ambush_bug): looking at attribute lesserregeneration
execInitAttrib: init lesserregeneration attribute
on hero_1 of template custom_template_68 (ambush_bug)
initAttribsForChar (ambush_bug): looking at attribute invulnerable0
execInitAttrib: init invulnerable0 attribute
on hero_1 of template custom_template_68 (ambush_bug)
initAttribsForChar: working on _skgorilla_grodd01 (gorilla_grodd)
initAttribsForChar (gorilla_grodd): looking at attribute solid skeleton
initAttribsForChar (gorilla_grodd): looking at attribute mindless
execInitAttrib: init mindless attribute
on _skgorilla_grodd01 of template gorilla_grodd (gorilla_grodd)
initAttribsForChar (gorilla_grodd): looking at attribute claws
initAttribsForChar (gorilla_grodd): looking at attribute unheroic
initAttribsForChar (gorilla_grodd): looking at attribute wall climbing
initAttribsForChar: working on _skthe_shark02 (the_shark)
initAttribsForChar (the_shark): looking at attribute rapid metabolism
initAttribsForChar (the_shark): looking at attribute claws
initAttribsForChar (the_shark): looking at attribute cybernetic brain
initAttribsForChar (the_shark): looking at attribute solid skeleton
initAttribsForChar (the_shark): looking at attribute mutatedshark
execInitAttrib: init unheroic attribute inside ['mutatedshark', 'unheroic', 'fasthealing', 'hatemonger'] combo
on _skthe_shark02 of template the_shark (the_shark)
execInitAttrib: init fasthealing attribute inside ['mutatedshark', 'unheroic', 'fasthealing', 'hatemonger'] combo
on _skthe_shark02 of template the_shark (the_shark)
execInitAttrib: init hatemonger attribute inside ['mutatedshark', 'unheroic', 'fasthealing', 'hatemonger'] combo
on _skthe_shark02 of template the_shark (the_shark)
initAttribsForChar: working on hero_2 (atom_smasher)
initAttribsForChar (atom_smasher): looking at attribute jumper
initAttribsForChar (atom_smasher): looking at attribute solid skeleton
initAttribsForChar (atom_smasher): looking at attribute radioactive
initAttribsForChar (atom_smasher): looking at attribute strange visitor
initAttribsForChar (atom_smasher): looking at attribute heavyfooted
execInitAttrib: init heavyfooted attribute
on hero_2 of template custom_template_69 (atom_smasher)
initAttribsForChar: working on hero_3 (black_manta)
initAttribsForChar (black_manta): looking at attribute tough guy
initAttribsForChar (black_manta): looking at attribute solid skeleton
initAttribsForChar (black_manta): looking at attribute temperature control
initAttribsForChar (black_manta): looking at attribute alkaline
initAttribsForChar (black_manta): looking at attribute jumper
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'cutscene_power' has no OnPostInit()
Plugin 'm25enc_opendoor' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
hero_0 resisted the primary state attack!
[/spoiler]
Is it all damage swaps, or just that one in particular?
It's not all swaps, because Baron Vertigo's attacks cause vertigo when I play against him, but I haven't tested widely. I suppose I should just try a different kind of damage, huh?
If you set M25_USE_REPORTS=1 in m25config.py you should be able to see if the character is even trying to use the swap.
Also, do the usual - run the FFX control centre to make sure the character is branded correctly.
There is a rare bug in the interface between the AI and FFX where at times the AI will call for a damage swap, but FFX doesn't execute it.
Okay, just had a CTD. I don't have a clue what caused it. Everything was working fine (a complete first of a mission I wrote working right one the very first outing!) and the game spawned a bunch of baddies, then crashed. I don't see anything in the script log, but here ya' go:
[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Starting ffx.py v. 3.2.0 build 11; branch = Gold / Release
Loading m25ai.py v. 3.2.0 build 10; branch = beta 2: m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0.18 release
Starting General Utilities 1.0
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
CustomHeadCurrentTime 1197789802.890000
Starting Height Check module 1.4
Starting System Utilities 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Campaign_ReadObjects() warning: object template <water> has more than one entry for attribute <mass>, values 650.000000 and 650.000000
Campaign_ReadObjects() warning: object template <jm_pad_white> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad_green> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad_brown> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <bigwater> has more than one entry for attribute <mass>, values 650.000000 and 650.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'cutscene_power' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_opendoor' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\coldcorner.py executed
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
! GetMapInfo
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_hut' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_military_outpost' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'jm_bldg_mil_cold' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
>>> C:\Documents and Settings\Owner\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\coldcorner.py executed
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'GLACIER_MAIN'
initialising FFX: skirmish=0
mapinfocaliper0 is not a valid explosion object
mapinfocaliper1 is not a valid explosion object
mapinfocaliper2 is not a valid explosion object
mapinfocaliper3 is not a valid explosion object
numberStr=67
storing hero_1: id_1,-67
numberStr=68
storing hero_2: id_2,-68
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-140.0, 40.0, 1.0, 0.800000011921, (0.40000000596, 0.300000011921, 0.899999976158))
initAttribsForChar: working on hero_1 (batman)
initAttribsForChar (batman): looking at attribute heroic
initAttribsForChar (batman): looking at attribute wall climbing
initAttribsForChar (batman): looking at attribute danger sense
initAttribsForChar (batman): looking at attribute capedcrusaderbat
execInitAttrib: init disciplined attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
execInitAttrib: init presence attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
execInitAttrib: init utilitybelt attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
execInitAttrib: init nimble attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
execInitAttrib: init acrobatic attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
execInitAttrib: init grimresolve attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
execInitAttrib: init ffqtracking attribute inside ['capedcrusaderbat', 'disciplined', 'presence', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_1 of template custom_template_67 (batman)
initAttribsForChar: working on hero_2 (robin)
initAttribsForChar (robin): looking at attribute capedcrusader
execInitAttrib: init disciplined attribute inside ['capedcrusader', 'disciplined', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_2 of template custom_template_68 (robin)
execInitAttrib: init utilitybelt attribute inside ['capedcrusader', 'disciplined', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_2 of template custom_template_68 (robin)
execInitAttrib: init nimble attribute inside ['capedcrusader', 'disciplined', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_2 of template custom_template_68 (robin)
execInitAttrib: init acrobatic attribute inside ['capedcrusader', 'disciplined', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_2 of template custom_template_68 (robin)
execInitAttrib: init grimresolve attribute inside ['capedcrusader', 'disciplined', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_2 of template custom_template_68 (robin)
execInitAttrib: init ffqtracking attribute inside ['capedcrusader', 'disciplined', 'utilitybelt', 'nimble', 'acrobatic', 'grimresolve', 'ffqtracking'] combo
on hero_2 of template custom_template_68 (robin)
initAttribsForChar (robin): looking at attribute wall climbing
initAttribsForChar (robin): looking at attribute nimble
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'cutscene_power' has no OnPostInit()
Plugin 'm25enc_opendoor' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
initAttribsForChar: working on m25obj_8 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_6 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_4 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_2 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_10 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_12 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_14 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_16 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_24 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
initAttribsForChar: working on m25obj_18 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_22 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
initAttribsForChar: working on m25obj_26 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_20 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_28 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
initAttribsForChar: working on m25obj_30 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_32 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
initAttribsForChar: working on m25obj_34 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_36 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
initAttribsForChar: working on m25obj_38 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_40 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
initAttribsForChar: working on m25obj_42 (freeze_lackey)
initAttribsForChar (freeze_lackey): looking at attribute weak minded
initAttribsForChar (freeze_lackey): looking at attribute bedevilled
initAttribsForChar: working on m25obj_44 (league_assassin)
initAttribsForChar (league_assassin): looking at attribute danger sense
hero_2 resisted the primary state attack!
[/spoiler]
Like you said, there don't appear to be any obvious errors in the script.log. The problem may not necessarily be with FFX. Is something else going on that makes you think it's FFX related? Is this a normally scripted mission or an EZScript mission?
It looks like Batman and Robin spawned correctly, then a bunch of freeze_lackeys and league_assassins. Were there any other characters set to spawn? If so, what powers and attributes did they have?
It may be useful to post the ff.log and mission.py files.
I find that the game crashes if there are any FF1 head.nifs in the mesh directories of the characters and they try to speak.
Whoops, yeah, sorry. I should have provided more details. This was an EZScript Batman mission, #7 to be exact. There were three encounters involved here, or rather, three groups of encounters. However, they were all the same, just using different markers. So, the first two ran fine (each one following a different "if" path) but when the third one started, the game crashed. It could also have been caused by the end of the second encounter, because Batman was taking out the last guy right when the third one started up. Here is the pertinent area of the script:
[spoiler]#----------------------------------
Encounter: Guard1
Type: Flee the Scene
Villains: freeze_lackey
Marker: compound1
Primary Objective: "Sneak past the guards."
Next: If All Escaped: Raise the Alarm1
Next: If Some Escaped: Raise the Alarm1
Start Cutscene:
Hero1 says, "We've been spotted! We have to take them out before they can alert the others!"
Villain Escapes:
Villain says, "It's the Bat! Raise the alarm!"
None Escaped Cutscene:
Hero1 says, "That was too close..."
#----------------------------------
Encounter: Raise the Alarm1
Type: Hunt
Villains: freeze_lackey, league_assassin, freeze_lackey, league_assassin, freeze_lackey, league_assassin, freeze_lackey, league_assassin, freeze_lackey, league_assassin
Minions: freeze_lackey, league_assassin,
Marker: compound1_alarm1
Next: None
Start Cutscene:
Minion says, "Get them!"
#----------------------------------[/spoiler]
I have already moved on and was testing other missions, but I'll try and reproduce the crash soon.
If it's not indeed a case of a minion's head.nif., don't forget to post that ff.log, at least the last few lines before the world comes to a booming end. :)
Just like to ask, how many bugs have been found already that hasn't been fixed yet for FFX 3.2? If any.
I saw a list of bugs that were fixed in the first page of this thread. Not really sure if it's updated though. :unsure:
Well, just curious on how things have progressed so far. :)
I know M25 has made a ton of EZScript fixes and extensions since May....
Im not sure where to put this, but my ffx3 has not been initiating lately. Not to sound vague, but i havent done anything different or messed with any scripts or dat files. Now when i start up the rumble room, none of the ffx attributes initiate. Any ideas?
Monkeyman, make sure you are starting up from the right shortcut (it says something like "Play FFX 3.2"). That's always the first thing to check. If you aren't sure you have the right one, take a peek at this post in the Game FAQ (http://freedomreborn.net/archive/index.php?topic=41006.msg572263#msg572263).
Otherwise, we will need more detail to help you out. Make sure you read the second post in this thread (http://freedomreborn.net/archive/index.php?topic=40930.msg571594#msg571594) for some hints on how to give the information that will get you the quickest answers.
A documentation omission--the Guardian attributes aren't mentioned in the table of attributes or the sidebar. (There's a guardian.htm page, but nothing links to it.)
I think that the guardian attributes were considered obsolete when FFvT3R came out because it had remote active defenses built into the game engine. But, they don't consistently work right. We probably ought to uncomment out that part of the attribute list in the docs.
Meanwhile, the power swaps are still there in the FFX Control Centre (e.g. swap to shield).
Quote from: stumpy on January 01, 2008, 05:54:52 PM
I think that the guardian attributes were considered obsolete when FFvT3R came out because it had remote active defenses built into the game engine. But, they don't consistently work right. We probably ought to uncomment out that part of the attribute list in the docs.
Meanwhile, the power swaps are still there in the FFX Control Centre (e.g. swap to shield).
Yes, Dr. Mike removed the attribute from ffx 2.X and reinstated it in ffx 2.4 for that reason, iirc; but, he always left the code active JIC (just-in-case) a character had the attribute.
For the record, the attribute was made obsolete by some FFX 2.0's swaps doing the same job in a more elegant way. I guess these indeed got removed (they did, right?) since FFvsTTR was supposed to have a betterversion, if it had worked correctly.
(Hopefully, I should finally install FFvsTTR on my Mac in the next couple of days... I won't feel quite as vague and clueless. :P )
How do you brand a character?
After creating a new custom character, just quit the game and open the FFX Control Centre and make sure it's pointed to the mod you are using (e.g. ffx3, patcity, liberty_bay, etc.). The CC will brand all of the custom heroes and all of the built-in heroes in that mod. It's that simple and there are a couple notes about it in the second post of this thread.
Quote from: M25 on February 03, 2007, 09:56:54 AM
Quote from: jmoser on February 03, 2007, 09:27:16 AM
QuoteIt's probably a corrupted powers.dat file. If you look in the ffx3 directory, there should be a powers.dat.bak file. Use that to replace the powers.dat file.
I already did that, to fix the dreaded "CFastHeap" problem. Granted, it did seem to solve that problem, but now I'm not getting any kind of error message at all.
Quoteit wasn't until i dl'd taskmaster's fix on the yahoo group that things worked properly again.
Maybe I should try that. What yahoo group is it on?
It looks like the game crashed on you while writing out the powers.dat file, so you now have a corrupted or incomplete version. Restoring the backup should temporarily fix the problem.
The yahoo group is FreedomForceX
Man, I just got the "dreaded CFastHeap" problem today, more than a year after the above was posted, and a Google search that could have taken me anywhere took me right back to Freedom Reborn with the exact fix I needed. This game's fans are lucky it has such learned devotees. Thanks to all the wise folks of this site ... you know who you are, right?
I got a message saying that quick learner could not be initiated.
QUICK/SLOW LEARNER don't work. I think they were added as concept attributes, but they aren't fully coded, at least as of the FFX 3.2 release I am looking at (v3.2.0.11).
I'll have to look at them. I thought they were working. They were simple enough.
They should look something like the code below, though my opportunities to test are limited right now.
########################### CATWHOWALKSBYHIMSELF'S ATTRIBUTES ETC. #########################################
### Some very simple attributes by catwhowalksbyhimself, intended for campaigns only
# stumpy 2008-03-22: we should prevent them being run more than once
# per character to prevent chaos with FFX re-spawns (via SHAPESHIFTER,
# etc.), cloning, etc.
def initquicklearner(char,update=0,remove=0):
if update==1:
return
temp = Object_GetTemplate(char)
if remove:
CPBonus = FFX_ObjectGetAttr(temp,'CPBonus',0)
Campaign_AddCP(temp,-CPBonus)
else:
if FFX_ObjectGetAttr(temp,'CPBonus',0) == 0:
Campaign_AddCP(temp,75)
FFX_ObjectSetAttr(temp,'CPBonus',75)
def initslowlearner(char,update=0,remove=0):
if update==1:
return
temp = Object_GetTemplate(char)
if remove:
CPPenalty = FFX_ObjectGetAttr(temp,'CPPenalty',0)
Campaign_AddCP(temp,-CPPenalty)
else:
if FFX_ObjectGetAttr(temp,'CPPenalty',0) == 0:
Campaign_AddCP(temp,-50)
FFX_ObjectSetAttr(temp,'CPPenalty',-50)
def initpopular(char,update=0,remove=0):
if update==1:
return
temp = Object_GetTemplate(char)
if remove:
PPBonus = FFX_ObjectGetAttr(temp,'PPBonus',0)
Campaign_AddPrestige(-PPBonus)
else:
if FFX_ObjectGetAttr(temp,'PPBonus',0) == 0:
Campaign_AddPrestige(300)
FFX_ObjectSetAttr(temp,'PPBonus',300)
def initfamous(char,update=0,remove=0):
if update==1:
return
temp = Object_GetTemplate(char)
if remove:
CPPenalty = FFX_ObjectGetAttr(temp,'PPPenalty',0)
Campaign_AddPrestige(-PPPenalty)
else:
if FFX_ObjectGetAttr(temp,'PPPenalty',0) == 0:
Campaign_AddPrestige(-200)
FFX_ObjectSetAttr(temp,'PPPenalty',-200)
BTW, I suspect that the ability to lower XP (and maybe PP) (either as a primary function or as part of the remove functionality) is not going to work. I just don't think that Campaign_AddCP() (and possibly Campaign_AddPP()) will reliably remove CP (or PP).
BTW, is INFAMOUS already taken? I know that is corrected in the string table, but I was just curious.
I just made the upgrade to FFX 3.2 after quite awhile away from actually playing FF, and I've run into a bit of a snag. Whenever I try to go into the Rumble Room, the loading progress bar will seem to complete, but the level will never actually load, and I end up having to forcibly end Freedom Force to get back to windows. I added a bunch of my own modifications back in before actually trying to play, so I've probably screwed something up and done this to myself, but I can't tell what. Here's my script.log, hopefully someone wiser than myself can shed some light on this.
>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
Starting ffx.py v. 3.2.0 build 11; branch = Gold / Release
Loading m25ai.py v. 3.2.0 build 10; branch = beta 2: m25 branch 2
importing missionobjvar.py v1.18
loading datfiles version 0.251000
importing MLOG Reader 1.0.18 release
Starting General Utilities 1.0
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
CustomHeadCurrentTime 1206381138.562000
Starting Height Check module 1.4
Starting System Utilities 1.4
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'cutscene_power' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_opendoor' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
>>> C:\Documents and Settings\Jeff Woodman\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Jeff Woodman\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Jeff Woodman\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', ))
try to spawn custom_vil_0
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'BROADWAY'
initialising FFX: skirmish=1
numberStr=46
storing hero_0: id_1,-46
ReadHeroIndexData: trouble reading or evaluating data from <c:\ffvt3r\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex: Making index <c:\ffvt3r\ffx3\HeroIndexData.txt>
Campaign_MakeHeroIndex: Complex not set for kid. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex: Complex not set for nick_craft_civ. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex warning: <ffx_hedge_ant> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <jffxtester> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex: Complex not set for kid2. Run datfiles.Campaign_SetMissingComplexAttribs()
Campaign_MakeHeroIndex warning: <sky2> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex warning: <piotr> likely missing entry in objects.dat; skipping.
Campaign_MakeHeroIndex: Complex not set for clint_coltrane_civ. Run datfiles.Campaign_SetMissingComplexAttribs()
Talavar, did you run the FFX Control Centre? This might be the first problem, althrough that shouldn't cause the game to hang. Otherwise, it could be caused by a corrupt .dat file, maybe. You should try to post the last few lines of your ff.log too.
Does a clean install of FFX 3.2 works correctly? (Just rename your existing folder or select a different install folder name; beware of loading the correct mod though, using the right "-modname" in the shortcut.)
I ran the Control Centre before hand, and since a clean install of 3.2 works fine, all signs point to me screwing something up by merging in the .dat files for my custom FX, sounds, etc.
Before I attempt that again, is there a way to limit my chances of simply causing the same problem over again?
Not much of a tip, but for new entries, it's better to merge from the FFX DATs than to them; otherwise if your custom dat has content from older versions, the fixes done in FFX 3.2 will be overwritten by the older invalid values. Of course, if your customizations modify existing entries, it's a no go. FWIW, DATs to be merged should ideally be pruned of any unnecessary entry (I suggest every modder to distribute their mergeable files like this); doing otherwise usually adds junk (such as the "kid2" entry you've got).
Still curious to see your ff.log – with a bit of luck, we might be able to guess which .dat file is the culprit, if any.
Some others have had similar issues in this thread:
Quote from: M25 on March 06, 2007, 02:15:17 PM
Quote from: JKCarrier on March 05, 2007, 10:36:08 AM
I'm getting a crash-to-desktop every time I try to run a Rumble Room session. It's quite likely I've messed something up myself, since I did a lot of tinkering and DAT-merging to get all my old customizations transferred over. But if someone can figure out the specific cause, I'd be grateful. Here's my script.log:
You can try
- running the control centre again
- running datfiles.Campaign_SetMissingComplexAttribs() from the console
- running the 'power id' rumble room mission (whose name escapes me at the moment)
Unfortunately, it is likely a problem with the dat file merging you did, and you'll have to start again. Do them one at a time if necessary and keep backups.
Since you've already done the first suggestion from M25, try running the other suggestions and see what happens.
I got FFX 3.2 running (I reinstalled it, pruned my .dat files down to just my customizations, merged to my .dats from the FFX 3.2 ones, then copied the merged ones over to the correct directory) but I've run into another snag: the characters aren't using their m25 ai files. I've run the Control Centre a number of times, I've done some trials with the Rumble Room Power & AI generators, none of which has done any good. Should I still post my script.log? FFX is working otherwise properly, the characters are just using the default behaviour instead.
I seem to have missed this. Go ahead and post your script.log.
Fast Learner does not seem to work. I haven't tried slow learner.
Quote from: yell0w_lantern on May 30, 2008, 04:50:11 PM
Fast Learner does not seem to work. I haven't tried slow learner.
Did you make the edits posted a few posts above (http://freedomreborn.net/archive/index.php?topic=40930.msg639865#msg639865.)? If so, post your script.log from 5 or 10 seconds after a mission has started and maybe we can see if there is an error or what else is happening.
BTW, It may be helpful to you (and us) to use the
ShowXP() command at the console at the start of a campaign mission, and then at the base of the next mission, to see where the characters are, as regard XP.
BTBTW, as mentioned earlier, I expect that SLOW LEARNER will not work. The game engine doesn't really accommodate removing XP.
I had added it but looking again, it's gone. I'll paste it back in and see if it works.
this is an ffx control centre question:
Does it have a problem with capital letters with built in characters? I was looking at one of my older mods and I realized that certain state swaps stopped working or the powers wouldn't even show up in the power list if the power started with a number or a capital letter.
I think it is case-sensitive. I remember some of my custom characters weren't working until I editted the ffxcustom.py and/or ffxcustom2.py to match the name of my hero file exactly with capital letters.
EDIT: I discovered this when I had to put my custom swaps in the ffxcustom.py for the grapple swaps. Because you can't use FFXCC to setup the grapple swaps for a character, I had to enter them manually and I didn't use the exact capitalization and they failed to work. So if anyone is having problems using the grapple swaps for some characters, this may be the reason.
No, it's all areas.
I find that swaps usually breakdown for a couple of reasons:
1) the customization doesn't carry over into ffxcustom.py - the special swaps seem to have this problem a lot; you'll have to fix it manually possibly every time you run the character through the control center.
2) a character has the same damage type swapped for different stuff - even the built-in characters can have this problem
> 2) a character has the same damage type swapped for different stuff - even the built-in characters can have this problem
Interesting, as this shouldn't be a problem for built-ins, as their individual powers can be differentiated – which is not the case for hero file-based characters.
Quote from: Epimethee on July 10, 2008, 07:27:15 PM
> 2) a character has the same damage type swapped for different stuff - even the built-in characters can have this problem
Interesting, as this shouldn't be a problem for built-ins, as their individual powers can be differentiated – which is not the case for hero file-based characters.
Even built-ins suffer from this if they are on the enemies list in the Rumble Room. It IG's custom_template_# hack biting us again. In that situation, we have to treat built-ins just like customs, and they are limited to the same swap affecting all powers with the swapped state. <_<
Try playing the character in a campaign mission or in the Rumble Room on the squad list and see if he behaves any differently.
Yes it can happen in Campaign too.
IPS, are they hero files or built-in?
Sometimes with built-ins I have to run the Power ID generator a couple times after I add new built-ins.
Quote from: yell0w_lantern on July 11, 2008, 07:56:25 AMYes it can happen in Campaign too.
It shouldn't be happening for built-ins in the campaign unless the power ID generation goes awry, which can happen. That latter should be fixable by re-running it. To me, the most obvious sign that the ID generation worked is that you here an odd audio effect of several FX playing at the same time. Without that, there has been a problem and I can check my ffxpowerids.py and there will be lots of zeros.
ips, unless I am mistaken, the power ID generation doesn't do anything for custom heroes, so I wouldn't expect that to fix anything. You probably want to post your script.log file for a short run where the swap didn't work. Take in the character as a solo in your squad and have him try the swap after a short while. It would be worth describing the power that was supposed to swap, or just enter the following at the console and it will show up in the log.
datfiles.ShowPower(GetCharacterData(getAllHeroes()[0])['powers']['swap power name'])
where swap power name is the name of the power you are testing (e.g. stamina of atlas). It needs to be exact (spelling, caps, spaces, etc.), just as it would be in your ffxcustom.py data.
Oops. I didn't know the console wasn't available under bootcamp.
A quick 'n' dirty workaround is to add the following to the bottom of your cshelper.py
def HeroPrint(object, char):
import chardata
datfiles.ShowHero(chardata.GetCharacterData(char))
Mission_StatusText('%s sent to log' % chardata.GetCharacterData(char).get('charName'))
def SetupHeroPrint(event):
for hero in getAllHeroes():
Mission_CustomAction('send to log', hero, hero, 'HeroPrint',100,1)
regTimer('SetupHeroPrint', 1.0)
Then choose the "SEND TO LOG" command that should be available when a hero clicks on himself. A message will pop up when the character data was sent to the log.
Hmm. I just restarted the game and tested it again and it works here. Are you playing the FFX3 mod (3.2.x)? Is the cshelper you added the code to located at ..\ffx3\Missions\Scripts\cshelper.py? I'm not sure why it wouldn't be working and that character information would help, but it's worth posting your script.log anyway.
That's good news, IPS. Although, to my knowledge, there never was an Area Blind to Mental Dmg Swap. For a Swap to have an area effect, you can only use Cloak, Empathy, and Displace Image. All other swaps have to be melee, beam or projectiles.
Quote from: ips on July 11, 2008, 11:28:20 AM
hmmm that's not good cause... i'm using my mac in bootcamp and the ~ character (along with number keypad) is not useable in the windows environment with bootcamps drivers... lol
In the better later than never dept.:
:huh: Works for me, and I believe we both have the same basic model, you should be able to get it working. My setup: Bootcamp'ed XP SP2/OS X 10.5, USB alu keyboard (are you using the Bluetooth version, maybe?) with the keyboard language mapping set to "Canadian Multilingual (Apple)" (not that it should matter) – the key to the left of the "1" does the trick. PM me if it doesn't work so we may do a few comparative tests.
Yep, you need to add the line import ff
ff.CON_ENABLE = 1
to your system\localinit.py.
The FR Wiki (http://frworld.wikispaces.com/Scripting+for+Dummies) is our friend. ;)
the absorbing attribute in 3.3 has trouble if you absorb fire. the fire will never leave after it is absorbed. even if you try absorbing something else
Hi - I'm new to FFX3 (only played vanilla until recently). Generally most things seem to be working out fine after I made sure I'd 'branded' properly. However, I don't seem to be able to get the utility belt attribute to work. Details below
Tested in standard Rumble Room battle
Custom character 'Captain'
Symptom is that no objects appear at scenario start
Script attached[spoiler]>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.256000
loading cshelper ...
Starting ffx.py v. 3.3.1 build 0; branch = main release update
Loading m25ai.py v. 3.3.0 build 3; branch = Gold v.3.3 with Patch
importing missionobjvar.py v1.20
importing MLOG Reader 1.0.23
Starting General Utilities 1.0.1
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Campaign play.
Loading m25cutscene.py v.3.2.0 final; May 27, 2007
CustomHeadCurrentTime 1223100528.062000
Starting Height Check module 1.4
Starting System Utilities 1.5
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 final; branch = swingman 4
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'cutscene_power' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.2.0 July 27, 2008
FFX Mission Plugin 'm25enc_opendoor' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
sk: missionobjvar already loaded; resetting mission type to skirmish for mission and object vars
missionobjvar.SetFunctionsByMissionType: isCampaignMission=0, long variable cache has already been written to.
__MISSIONVARS = {'_event_freeroam_initmission': [['FreeroamKBD_StartMission', 0]], '_event_pstory_cutsceneline': [['CutscenePower_CheckPower', 1]], 'heightcheck_sampling_default': (1, 8), '_event_freeroam_exitmission': [['FreeroamKBD_EndMission', 0]]}
__OBJECTVARS = {}
missionobjvar defining functions for Rumble Room play.
ffx3\Missions\Scripts\sk.py importing FFX
ffx3\Missions\Scripts\sk.py loaded
>>> C:\Documents and Settings\Chris\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> C:\Documents and Settings\Chris\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\danger.py executed
>>> C:\Documents and Settings\Chris\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\battle.py executed
>>> OnReceiveSelectedEnemies(('custom_vil_0', 'thug_with_bat', 'schmidt', 'custom_vil_1', ))
try to spawn custom_vil_0
sk.SpawnEnemy: energy for _skcustom_vil_001 (ice_sergeant_extra) changed from 9 to 9
try to spawn thug_with_bat
sk.SpawnEnemy: energy for _skthug_with_bat02 (thug_with_bat) changed from 0 to 0
try to spawn schmidt
sk.SpawnEnemy: energy for _skschmidt03 (schmidt) changed from 0 to 0
try to spawn custom_vil_1
sk.SpawnEnemy: energy for _skcustom_vil_104 (cuban_male) changed from 9 to 0
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'MP_AIRFIELD'
initialising FFX: skirmish=1
numberStr=39
storing hero_0: id_1,-39
numberStr=40
storing hero_1: id_2,-40
! GetMapInfo
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-40.0, 30.0, 1.20000004768, 1.0, (0.800000011921, 0.5, 0.20000000298))
addArrow _sk_arrow _skcustom_vil_001 0 0
initAttribsForChar: working on _skcustom_vil_001 (ice_sergeant_extra)
initAttribsForChar (ice_sergeant_extra): looking at attribute crack shot
initAttribsForChar (ice_sergeant_extra): looking at attribute light speed
initAttribsForChar (ice_sergeant_extra): looking at attribute clumsy
initAttribsForChar (ice_sergeant_extra): looking at attribute ponderous
initAttribsForChar: working on _skcustom_vil_104 (cuban_male)
initAttribsForChar: working on _skthug_with_bat02 (thug_with_bat)
initAttribsForChar (thug_with_bat): looking at attribute timid
initAttribsForChar (thug_with_bat): looking at attribute weak minded
initAttribsForChar: working on _skschmidt03 (schmidt)
initAttribsForChar: working on hero_0 (captain)
initAttribsForChar (captain): looking at attribute utilitybelt
execInitAttrib: init utilitybelt attribute
on hero_0 of template custom_template_39 (captain)
initAttribsForChar (captain): looking at attribute bodyarmor05
execInitAttrib: init bodyarmor05 attribute
on hero_0 of template custom_template_39 (captain)
initAttribsForChar (captain): looking at attribute ffqfieldcommander
execInitAttrib: init ffqfieldcommander attribute
on hero_0 of template custom_template_39 (captain)
initheroic('hero_1', update=0)
initAttribsForChar (captain): looking at attribute acrobaticamateur
execInitAttrib: init acrobaticamateur attribute
on hero_0 of template custom_template_39 (captain)
initAttribsForChar (captain): looking at attribute nimble
initAttribsForChar: working on hero_1 (alchemoid)
initAttribsForChar (alchemoid): looking at attribute adaptive2
execInitAttrib: init adaptive2 attribute
on hero_1 of template custom_template_40 (alchemoid)
initAttribsForChar (alchemoid): looking at attribute bedevilled
initAttribsForChar (alchemoid): looking at attribute ffqhighjumper
execInitAttrib: init ffqhighjumper attribute
on hero_1 of template custom_template_40 (alchemoid)
initAttribsForChar (alchemoid): looking at attribute earthcontrol2
execInitAttrib: init earthcontrol2 attribute
on hero_1 of template custom_template_40 (alchemoid)
initAttribsForChar (alchemoid): looking at attribute invulnerable
execInitAttrib: init invulnerable attribute
on hero_1 of template custom_template_40 (alchemoid)
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'cutscene_power' has no OnPostInit()
Plugin 'm25enc_opendoor' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
(638.270263672, -244.798492432, 0.027690436691)
(637.375732422, -220.819168091, 0.0100154355168)
(639.164794922, -268.777801514, -0.0189311113209)
(636.481262207, -196.83984375, 1.45865881443)
(640.059265137, -292.757141113, 0.0114045739174)
[/spoiler]
Am I doing something dumb?
Legemaine
legemaine, first let me say that was an excellent bug report; you included many important details and the script.log that sometimes take two or three posts to get out of people.
Unfortunately, I don't really see what the problem is. I don't have much experience with UTILITY BELT myself, but I can say that there is nothing in the script.log that looks like an obvious error. I just created a character with the attribute and tested it in the RR (using the battle mode on the prison yard map, alone and with an ally) and it seemed to work fine. There may be some interaction between this attribute and the others that character has, but I don't see what they would be. I gave my test character all the attributes that 'captain' has and it still worked for me.
I assume the other FFX attributes are working for that character and for other characters. Does this work on other maps? If you give the attrib to other characters, does it work?
Don't know if this was reported but...
when M25_USE_SKXCAMERA is set to 1, it does some weird things with a few camera commands such as:
Camera_LookAtObject('minute_man', 50, 100, 100, 0, CPM_HOMING, CA_TRACK)
The height check isn't a problem, but it's the random camera movements (IE: when a character talks, it'll swing around by itself even if another camera command is called) and the lagging behind that makes the function annoying in cutscene situations. Perhaps there's a fix for it or did I do something incorrectly?
Just to be sure, is this with FFX 3.2 or 3.3?
latest version: 3.3.1
Anyone ever experienced such a debilatating problem? The game becomes unplayably choppy(seemingly frozen) while a message comes up saying: "New civilian/tank: girl run datfiles.campaig
character found with duplicate "complex value" quit and run FFX control centre". And so I did, to no avail multiple times over. One of the older versions never had this problem. New TANK? wtf?
Previsionary: that is what the kuertee's skx camera functions do. I think it was intended to give a more dynamic feel to cutscenes.
qazwsx: You have two or more civilian characters with the same 'complex' value. It's an old problem that running the control centre won't fix, unfortunately. stumpy had a fix for this... I'll have to dig it up.
Edit: OK, here it is:
# From the console, enter
# import datfiles
# datfiles.Campaign_SetMissingComplexAttribs()
# and that should do it.
To get to the console, make sure you have
import ff
ff.CON_ENABLE=1
in your Freedom Force vs The 3rd Reich\System\localinit.py file, then press the tilde (~) key. Type in those lines and it should fix the issue.
yeah, I know what it was meant for...but it kinda wrecked a few cutscenes or made the game super lag with the camera movement commands, so I'm just throwing a warning out there for future reference.
Quote from: M25 on October 23, 2008, 11:16:59 AM
Previsionary: that is what the kuertee's skx camera functions do. I think it was intended to give a more dynamic feel to cutscenes.
qazwsx: You have two or more civilian characters with the same 'complex' value. It's an old problem that running the control centre won't fix, unfortunately. stumpy had a fix for this... I'll have to dig it up.
Edit: OK, here it is:
# From the console, enter
# import datfiles
# datfiles.Campaign_SetMissingComplexAttribs()
# and that should do it.
To get to the console, make sure you have
import ff
ff.CON_ENABLE=1
in your Freedom Force vs The 3rd Reich\System\localinit.py file, then press the tilde (~) key. Type in those lines and it should fix the issue.
Thanks M, the cinematic camera is fantastic, though I wonder why it's able to zoom in beyond -300. By the way, for timed encounters, does the timer take into account pauses?
I didn't write the cinematic camera, but I believe the camera isn't really zooming, its being moved within the program.
The timer should pause if the game pauses.
>>> system/init.py executed
>>> system/localinit.py executed
>>> system\tredir.py executed
loading datfiles version 0.256000
loading cshelper ...
Starting ffx.py v. 3.3.1 build 0; branch = main release update
Loading m25ai.py v. 3.3.0 build 3; branch = Gold v.3.3 with Patch
importing missionobjvar.py v1.20
importing MLOG Reader 1.0.23
Starting General Utilities 1.0.1
missionobjvar(FixLongs): Fixing overflow issue with <SCSTATE_BUOYANT>
missionobjvar defining functions for Rumble Room play.
Loading m25cutscene.py v.3.2.0 final; May 27, 2007
CustomHeadCurrentTime 1227268267.640000
Starting Height Check module 1.4
Starting System Utilities 1.5
OBJECTS_HEIGHT: 604 entries
NIF_OBJECTS: 482 entries
BUILDINGS_IN_OBJECTS_DAT: 30 entries
BUILDING_DIMENSIONS: 30 entries
Starting skXMapInfo.py v 0.79 beta
skXMapInfo: m25ai available
Loading m25aiopt.py v.3.2.0 final; branch = swingman 4
Campaign_ReadObjects() warning: object template <waterbig> has more than one entry for attribute <mass>, values 650.000000 and 650.000000
Campaign_ReadObjects() warning: object template <water> has more than one entry for attribute <mass>, values 650.000000 and 650.000000
Campaign_ReadObjects() warning: object template <jm_pad_white> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad_green> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad_brown> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
Campaign_ReadObjects() warning: object template <jm_pad> has more than one entry for attribute <canPickUp>, values 0.000000 and 0.000000
FFX Mission Plugin 'firehydrant' imported
FFX Mission Plugin 'zombie' imported
Loading freeroam_keepbuildingdamage.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'freeroam_keepbuildingdamage' imported
FFX Mission Plugin 'm25ai_lowjumper' imported
FFX Mission Plugin 'm25ai_realitymanipulation' imported
FFX Mission Plugin 'cutscene_power' imported
Loading m25enc_OPENDOOR.py v.1.0.0 build 0; branch = main
Loading m25enc.py v.3.3.04 November 19, 2008
FFX Mission Plugin 'm25enc_opendoor' imported
Loading m25enc_simplechoice.py v.1.0.0 build 0; branch = main
FFX Mission Plugin 'm25enc_simplechoice' imported
Loading m25pstory.py v.3.3.1; Sept 28, 2008
FFX Mission Plugin 'm25encstory' imported
Starting Built-In Function Wrapper 1.5
('Object_CalcPrestige', 'js')
ffx3\Missions\Scripts\sk.py importing FFX
ffx3\Missions\Scripts\sk.py loaded
>>> C:\Documents and Settings\euge\Local Settings\Application Data\Irrational Games\Freedom Force vs the 3rd Reich\temp\mission.py executed
! GetMapInfo
Building_GetDimensions() non-fatal error:
template 'sky_croatia' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'ff_door' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'sky_croatia' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
Building_GetDimensions() non-fatal error:
template 'ff_door' not found in list of building dimensions.
To detect approximate dimensions, use
getBuildingDimensions ()
MLOG_Init(keepRunningModules=0): starting up
mlogreader.MLOG_Init: current mission = 'CROATIA'
initialising FFX: skirmish=0
mapinfocaliper0 is not a valid explosion object
mapinfocaliper1 is not a valid explosion object
mapinfocaliper2 is not a valid explosion object
mapinfocaliper3 is not a valid explosion object
storing hero_1: id_1,123
Campaign_ReadCharactersFromSavedGame: character <ultimate_beast> has no corresponding object template.
blackbird blackbird blackbird1_object1
hank beast encounter1_ally1
piotr colossus encounter1_ally2
initialising FFQ_initialiseExtras()
FFX_UpdateSun: getting default sun
FFX_UpdateSun: setting = (-45.0, 45.0, 1.0, 0.800000011921, (1.0, 1.0, 1.0))
initAttribsForChar: working on hero_1 (ultimate_cyclops)
initAttribsForChar (ultimate_cyclops): looking at attribute solarpowered
execInitAttrib: init solarpowered attribute
on hero_1 of template ultimate_cyclops (ultimate_cyclops)
solar powered characterhero_1 has base energy 3
initAttribsForChar (ultimate_cyclops): looking at attribute crack shot
initAttribsForChar (ultimate_cyclops): looking at attribute ffqlowjumper
execInitAttrib: init ffqlowjumper attribute
on hero_1 of template ultimate_cyclops (ultimate_cyclops)
initAttribsForChar: working on hank (beast)
initAttribsForChar (beast): looking at attribute acrobatic
execInitAttrib: init acrobatic attribute
on hank of template beast (beast)
initAttribsForChar (beast): looking at attribute ffqtracking
execInitAttrib: init ffqtracking attribute
on hank of template beast (beast)
initAttribsForChar (beast): looking at attribute jumper
initAttribsForChar: working on blackbird (blackbird)
initAttribsForChar (blackbird): looking at attribute rapid metabolism
initAttribsForChar (blackbird): looking at attribute beautiful
initAttribsForChar (blackbird): looking at attribute level headed
initAttribsForChar (blackbird): looking at attribute danger sense
initAttribsForChar: working on piotr (colossus)
initAttribsForChar (colossus): looking at attribute solid skeleton
initAttribsForChar (colossus): looking at attribute temperature control
initAttribsForChar (colossus): looking at attribute shake it off
initAttribsForChar (colossus): looking at attribute armoured
Plugin 'firehydrant' OnPostInit() called
Plugin 'zombie' has no OnPostInit()
Plugin 'freeroam_keepbuildingdamage' OnPostInit() called
Plugin 'm25ai_lowjumper' has no OnPostInit()
Plugin 'm25ai_realitymanipulation' has no OnPostInit()
Plugin 'cutscene_power' has no OnPostInit()
Plugin 'm25enc_opendoor' has no OnPostInit()
Plugin 'm25enc_simplechoice' has no OnPostInit()
Plugin 'm25encstory' has no OnPostInit()
I keep getting a ctd with the beast character. Anyone know where the fault lies?
You're looking for the FFX 3.3 thread. This is the one for the obsolete 3.2, which you aren't even using.
I had no idea mate