Gordon Dry Posted June 18, 2018 Share Posted June 18, 2018 @blowfish thanks... I hope that's all for now ... Then it will be: @PART[*]:HAS[@MODULE[ModuleGimbal],~gimbalResponseSpeed[]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { %useGimbalResponseSpeed = true %gimbalResponseSpeed = 6 } } @PART[*]:HAS[@MODULE[ModuleGimbal],@MODULE[ModuleEngines]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { @gimbalRange /= #$/mass$ temp = #$gimbalRange$ tempb = #$../MODULE[ModuleEngines]/maxThrust$ @gimbalRange /= #$tempb$ @gimbalRange *= 100 @gimbalRange /= #$temp$ @gimbalResponseSpeed /= #$/mass$ } } @PART[*]:HAS[@MODULE[ModuleGimbal],@MODULE[ModuleEnginesFX]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { @gimbalRange /= #$/mass$ temp = #$gimbalRange$ tempb = #$../MODULE[ModuleEnginesFX]/maxThrust$ @gimbalRange /= #$tempb$ @gimbalRange *= 100 @gimbalRange /= #$temp$ @gimbalResponseSpeed /= #$/mass$ } } @PART[*]:HAS[@MODULE[ModuleGimbal],#gimbalResponseSpeed[>15]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { @gimbalResponseSpeed = 15 } } @PART[*]:HAS[@MODULE[ModuleGimbal],#gimbalResponseSpeed[<6]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { @gimbalResponseSpeed = 6 } } @PART[*]:HAS[@MODULE[ModuleGimbal],@MODULE[ModuleEngines]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { !temp = delete !tempb = delete } } @PART[*]:HAS[@MODULE[ModuleGimbal],@MODULE[ModuleEnginesFX]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal] { !temp = delete !tempb = delete } } // Ferram Aerospace Research // // ATTENTION: // You have to delete the following config: // GameData\FerramAerospaceResearch\stockEngineGimbalIncrease.cfg // // @PART[*]:HAS[@MODULE[ModuleGimbal]]:NEEDS[!RealismOverhaul,FerramAerospaceResearch]:FINAL // { // @MODULE[ModuleGimbal] // { // @gimbalResponseSpeed *= 1.5 // } // } Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 21, 2018 Share Posted June 21, 2018 (edited) Why are all three of these saying "[ModuleManager] Error - pass specifier detected on an insert node (not a patch):" ? I learned that BEFORE, FOR or AFTER is not okay, but FINAL? PART[*]:HAS[@MODULE[TacSelfDestruct]]:NEEDS[TacSelfDestruct]:FINAL { @MODULE[TacSelfDestruct] { @timeDelay = 10.0 } } PART[Tank*,tank*,*Tank*,*tank*]:HAS[!MODULE[TacSelfDestruct]]:NEEDS[TacSelfDestruct]:FINAL { MODULE { name = TacSelfDestruct timeDelay = 10.0 canStage = false } } PART[*]:HAS[!MODULE[TacSelfDestruct],@MODULE[ModuleCommand]]:NEEDS[TacSelfDestruct]:FINAL { MODULE { name = TacSelfDestruct timeDelay = 10.0 canStage = false } } Edit: Removing FINAL works, but I still wonder why. Should work with it. IMHO. Edited June 21, 2018 by Gordon Dry Quote Link to comment Share on other sites More sharing options...
blowfish Posted June 21, 2018 Share Posted June 21, 2018 On 6/21/2018 at 3:21 PM, Gordon Dry said: Why are all three of these saying "[ModuleManager] Error - pass specifier detected on an insert node (not a patch):" ? I learned that BEFORE, FOR or AFTER is not okay, but FINAL? Reveal hidden contents PART[*]:HAS[@MODULE[TacSelfDestruct]]:NEEDS[TacSelfDestruct]:FINAL { @MODULE[TacSelfDestruct] { @timeDelay = 10.0 } } PART[Tank*,tank*,*Tank*,*tank*]:HAS[!MODULE[TacSelfDestruct]]:NEEDS[TacSelfDestruct]:FINAL { MODULE { name = TacSelfDestruct timeDelay = 10.0 canStage = false } } PART[*]:HAS[!MODULE[TacSelfDestruct],@MODULE[ModuleCommand]]:NEEDS[TacSelfDestruct]:FINAL { MODULE { name = TacSelfDestruct timeDelay = 10.0 canStage = false } } Edit: Removing FINAL works, but I still wonder why. Should work with it. IMHO. Expand I think you want @PART - just PART creates a new one Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 21, 2018 Share Posted June 21, 2018 (edited) @blowfish darn it - I haven taken this from the README of the TacSelfDestruct mod and didn't realize this ... Edit: Working on 3 construction sites the same time is not a good idea though ... Edited June 21, 2018 by Gordon Dry Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 22, 2018 Share Posted June 22, 2018 (edited) Is this possible? @PART[*]:HAS[@MODULE[ModuleGimbal],@MODULE[ModuleEngines]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal]:HAS[#gimbalRange[>0]] { temp = #$gimbalRange$ @gimbalRange /= #$/mass$ tempa = #$gimbalRange$ tempb = #$/MODULE[ModuleEngines]/maxThrust$ @gimbalRange /= #$tempb$ @gimbalRange *= 500 @gimbalRange /= #$tempa$ @gimbalRange *= #$/mass$ @gimbalResponseSpeed /= #$/mass$ } } @PART[*]:HAS[@MODULE[ModuleGimbal],@MODULE[ModuleEngines]]:NEEDS[!RealismOverhaul]:FINAL { @MODULE[ModuleGimbal]:HAS[#gimbalRange[>#$temp$]] { @gimbalRange = #$temp$ } } Especially this portion in the 2nd patch: HAS[#gimbalRange[>#$temp$]] Edit: or even this variant: HAS[#gimbalRange[>#temp]] Edited June 22, 2018 by Gordon Dry Quote Link to comment Share on other sites More sharing options...
PiezPiedPy Posted June 22, 2018 Share Posted June 22, 2018 (edited) @sarbian Would you be able to add temp variables syntax to MM that are internal/local to a patch but are not added to a node, key , value etc eg: @PART[*]:HAS[@MODULE[ModuleGimbal]] { `temp = 23 // this would not be added to the part but only for temporary storage of a value @range *= `temp `somevalue = #$speed$ `somevalue += 200 `somevalue /= `temp @topspeed = `somevalue } I hope you understand what I'm trying to explain btw I used the ` character as just an example, any other character that is not already used in syntax could be used. Also an If-Then-Else type of syntax would be nice. Edited June 22, 2018 by PiezPiedPy Quote Link to comment Share on other sites More sharing options...
blowfish Posted June 23, 2018 Share Posted June 23, 2018 On 6/22/2018 at 10:26 PM, Gordon Dry said: Is this possible? ... Expand Not currently possible. But you can use the fact that x > y is equivalent to x - y > 0 (store the difference in another variable and check whether it's greater than zero) Quote Link to comment Share on other sites More sharing options...
FreeThinker Posted June 24, 2018 Share Posted June 24, 2018 (edited) I know you can modify a setting in Physics.cfg using @PHYSICSGLOBALS { @seting = True } But how to achieve the same for a setting in setting.cfg? Edited June 24, 2018 by FreeThinker Quote Link to comment Share on other sites More sharing options...
linuxgurugamer Posted June 24, 2018 Share Posted June 24, 2018 I'm working on a small issue here. I have a mod which makes some changes. currently, the part line looks like: @PART[InlineBallute062]:NEEDS[RealChute]:BEFORE[FerramAerospaceResearch] But this also makes it require Ferram to be there. I want the patch applied either way, but IF Ferram is there, then to apply it BEFORE Ferram. I'm looking into this now, so far I don't have a good solution other than to have two copies, one for FAR and one without Quote Link to comment Share on other sites More sharing options...
blowfish Posted June 24, 2018 Share Posted June 24, 2018 (edited) On 6/24/2018 at 9:50 AM, FreeThinker said: But how to achieve the same for a setting in setting.cfg? Expand You can’t. Physics.cfg has special handling to allow this. Modifying settings in a patch would be problematic anyway since it’s contents can be modified by the game. On 6/24/2018 at 3:56 PM, linuxgurugamer said: But this also makes it require Ferram to be there. I want the patch applied either way, but IF Ferram is there, then to apply it BEFORE Ferram. I'm looking into this now, so far I don't have a good solution other than to have two copies, one for FAR and one without Expand Is there a specific reason it needs to be applied right before FAR and not earlier? Edited June 24, 2018 by blowfish Quote Link to comment Share on other sites More sharing options...
linuxgurugamer Posted June 24, 2018 Share Posted June 24, 2018 On 6/24/2018 at 3:56 PM, blowfish said: On 6/24/2018 at 3:56 PM, linuxgurugamer said: But this also makes it require Ferram to be there. I want the patch applied either way, but IF Ferram is there, then to apply it BEFORE Ferram. I'm looking into this now, so far I don't have a good solution other than to have two copies, one for FAR and one without Expand Is there a specific reason it needs to be applied right before FAR and not earlier? Expand Probably not Quote Link to comment Share on other sites More sharing options...
linuxgurugamer Posted June 24, 2018 Share Posted June 24, 2018 On 12/27/2017 at 9:52 PM, Drew Kerman said: Yup that did it, thanks. I will inform the mod author Expand The error is actually that those lines are in the wrong location. I'm updating it now Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 26, 2018 Share Posted June 26, 2018 @blowfish this does not work as intended: HAS[@MODULE[ModuleReactionWheel],!MODULE[ModuleCommand],#CrewCapacity[<1]|~CrewCapacity[*]] Could it be I should do it like this? HAS[@MODULE[ModuleReactionWheel],!MODULE[ModuleCommand]]:HAS[#CrewCapacity[<1]|~CrewCapacity[*]] Quote Link to comment Share on other sites More sharing options...
theJesuit Posted June 26, 2018 Share Posted June 26, 2018 @blowfish, I too have a MM question for the B9_TANK_TYPE. Is it possible to remove them with module manager? I am setting up my own configs for Extraplanetary Launchpads, but I keep having the conflicts with the EL vanilla resources that aren't used as I don't have CRP installed either. I tried this morning with variations on: !B9_TANK_TYPE[SSPXMetalOre] {} I use this alongside removed the B9 modules from the containers as well, @PART[sspx-cargo-container*] { !MODULE[ModuleB9PartSwitch] {} } as an example, but it didn't seem to work. The container patch works fine and ready to put in my own tank types etc, but I'm uncertain whether I can (or need a different work around like having but hiding unused resources and just removing any mention of them from elsewhere). Thanks! Quote Link to comment Share on other sites More sharing options...
blowfish Posted June 26, 2018 Share Posted June 26, 2018 On 6/26/2018 at 1:48 AM, theJesuit said: @blowfish, I too have a MM question for the B9_TANK_TYPE. Is it possible to remove them with module manager? I am setting up my own configs for Extraplanetary Launchpads, but I keep having the conflicts with the EL vanilla resources that aren't used as I don't have CRP installed either. I tried this morning with variations on: !B9_TANK_TYPE[SSPXMetalOre] {} I use this alongside removed the B9 modules from the containers as well, @PART[sspx-cargo-container*] { !MODULE[ModuleB9PartSwitch] {} } as an example, but it didn't seem to work. The container patch works fine and ready to put in my own tank types etc, but I'm uncertain whether I can (or need a different work around like having but hiding unused resources and just removing any mention of them from elsewhere). Thanks! Expand Sorry, exactly which piece isn't having the intended result. Also unused B9_TANK_TYPE entries won't really affect anything. Quote Link to comment Share on other sites More sharing options...
theJesuit Posted June 26, 2018 Share Posted June 26, 2018 On 6/26/2018 at 4:33 AM, blowfish said: Sorry, exactly which piece isn't having the intended result. Also unused B9_TANK_TYPE entries won't really affect anything. Expand Your advice did work wonders, and a day at work gave me a chance to reflect and come back with fresh eyes! Got it sorted. I was actually trying to be clever and do !B9_TANK_TYPE[SSPX*] {} instead. Which wasn't working - knocking the EPL resources out sorted it! Thanks and Peace! Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 28, 2018 Share Posted June 28, 2018 (edited) @blowfish I tried to find good examples how to use indices, but besides the MM syntax wiki page I didn't find anything worthy... I try to check for all parts with ModuleEngines* and ModuleRCS* which also have the propellant ElectricCharge, then add a module. I tried variants of this: // ionized gas propelled engines need EC @PART[*]:HAS[@MODULE[ModuleEngines*]:HAS[@PROPELLANT[ElectricCharge],*]]:AFTER[Kerbalism] { MODULE { name = PlannerController } } // ionized gas propelled RCS thrusters also need EC @PART[*]:HAS[@MODULE[ModuleRCS*]:HAS[@PROPELLANT[ElectricCharge],*]]:AFTER[Kerbalism] { MODULE { name = PlannerController } } And this: // ionized gas propelled engines need EC @PART[*]:HAS[@MODULE[ModuleEngines*]:HAS[@PROPELLANT[*]:HAS[#name[ElectricCharge]]],*]:AFTER[Kerbalism] { MODULE { name = PlannerController } } // ionized gas propelled RCS thrusters also need EC @PART[*]:HAS[@MODULE[ModuleRCS*]:HAS[@PROPELLANT[*]:HAS[#name[ElectricCharge]]],*]:AFTER[Kerbalism] { MODULE { name = PlannerController } } I tried moving the ,* to one side of a bracket or the other etc. pp. Because of engines or RCS thrusters that also use ElectricCharge as a 2nd propellant, I try it with the index... This patch should be as generic as possible to avoid overlooking parts where the propellant ElectricCharge is not on the 2nd position or even parts with more than 2 propellants in total incl. EC. Edited June 28, 2018 by Gordon Dry Quote Link to comment Share on other sites More sharing options...
blowfish Posted June 28, 2018 Share Posted June 28, 2018 @Gordon Dry you can't use indices in a HAS clause. I'm confused about your use case though ... :HAS[@PROPELLANT[ElectricCharge]] will be true for anything that has any PROPELLANT node with name = ElectricCharge, it does not have to be the first one. So why does the position matter at all? And why would you want to rely on things being in a particular order? Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 28, 2018 Share Posted June 28, 2018 @blowfish I tried it with a simple HAS[@PROPELLANT[ElectricCharge]] in the beginning, that didn't work ... So I started to fiddle with indices... Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted June 28, 2018 Share Posted June 28, 2018 I started from scratch with a fresh approach, this time it's allright - perhaps I should have started with all of it at a later time of day Quote Link to comment Share on other sites More sharing options...
Apaseall Posted July 3, 2018 Share Posted July 3, 2018 I thought I would post this here; Reveal hidden contents @PART[CT250?]:HAS[@MODULE[InterstellarResourceConverter]]:NEEDS[InterstellarFuelSwitch]:FINAL { @MODULE[InterstellarResourceConverter]:HAS[#primaryResourceNames[LqdXenon]] { %MYMMmaxPowerMul = 10 // create variable my_mm maxPower Multiplier 1.0 = same as stock IFS @maxPowerPrimary *= #$MYMMmaxPowerMul$ @maxPowerSecondary *= #$MYMMmaxPowerMul$ !MYMMmaxPowerMul // delete variable } } Why? Well after reading the available docs and 38 pages of this thread I just winged it and hoped. Please Please update the docs with an example of nested :HAS. Also and example with multiple instances of the same module name within a part, where like above only a key pair within those modules differentiates them. Yes I was patient up to a point, hope you will make the changes so that others will have a shorter hunt. Thanks. Oh yes, the code is tested and works. Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted July 7, 2018 Share Posted July 7, 2018 And again - this patch does not apply: @PART[*]:HAS[@MODULE[ModuleScienceExperiment]]:NEEDS[Bluedog_DB]:AFTER[Kerbalism] { @MODULE[ModuleScienceExperiment]:HAS[#experimentID[bd?GeigerCounter]] { @experimentID = geigerCounter @experimentActionName = Log Radiation Data @resetActionName = Discard Radiation Data @reviewActionName = Review Radiation Data @dataIsCollectable = True @collectActionName = Take Data @usageReqMaskInternal = 1 @usageReqMaskExternal = -1 } MODULE { name = Sensor type = radiation pin = pinanim } } The original experimentID is bd_GeigerCounter, which also does not apply. Is a ? not allowed in a HAS with a # in it? And a _ is even not allowed, so this part CAN NOT be patched as long as the experimentID is not renamed in the original config? Quote Link to comment Share on other sites More sharing options...
blowfish Posted July 7, 2018 Share Posted July 7, 2018 @Gordon Dry that seems right to me, and bd_GeigerCounter should work too. I don't see anything wrong there, I'd look for other reasons why it might not be applying. Quote Link to comment Share on other sites More sharing options...
Gordon Dry Posted July 8, 2018 Share Posted July 8, 2018 @blowfish issue solved - there was a closing bracked commented out in a patch block before that - and no MM error because somehow it fitted ... I just have seen it by "accident", it was not my patch ... Quote Link to comment Share on other sites More sharing options...
Apaseall Posted July 10, 2018 Share Posted July 10, 2018 Hi folks. I am looking for some guidance with how to handle variables. I have this patch; Reveal hidden contents // ----------------------------------------------------------- MM Patched Here ---------------------------------------------------------------------------------------------- // This patch adds changes the rate at which a liquid turns into a gas in IFS Cryogenic Tanks // needs to run after InterstellarFuelSwitch as it alters parts created by it // InterstellarFuelSwitch runs at some point @PART[CT250?]:HAS[@MODULE[InterstellarResourceConverter]]:NEEDS[InterstellarFuelSwitch]:AFTER[WildBlueTools] { @MODULE[InterstellarResourceConverter]:HAS[#primaryResourceNames[LqdXenon]] { %MYMMmaxPowerMul = 1000 // create variable my_mm maxPower Multiplier 1.0 = same as stock IFS @maxPowerPrimary *= #$MYMMmaxPowerMul$ @maxPowerSecondary *= #$MYMMmaxPowerMul$ } } @PART[CT250?]:HAS[@MODULE[InterstellarResourceConverter]]:NEEDS[InterstellarFuelSwitch]:AFTER[WildBlueTools] { @MODULE[InterstellarResourceConverter]:HAS[#primaryResourceNames[LqdXenon]] { !MYMMmaxPowerMul // delete variable } } // ----------------------------------------------------------- Just Notes Below Here ---------------------------------------------------------------------------------------- // Notes MODULE // Notes { // Notes name = InterstellarResourceConverter // Notes primaryResourceNames = LqdXenon // Notes secondaryResourceNames = XenonGas // Notes maxPowerPrimary = 10 // Notes maxPowerSecondary = 10 // Notes primaryConversionEnergyCost = 95.586 // Notes secondaryConversionEnergyCost = 17.2958 // 108.099 * 0.16 // Notes } // Notes // Notes :FINAL is a cop out and should be avoided if possible // Notes :AFTER[InterstellarFuelSwitch] ? Do we need to wait for anything else to act upon IFS before this patch? // Notes :AFTER[WildBlueTools] Assuming any WBI mod is installed, WildBlueTools is processed near the end of the mod processing list The present problem is that MYMMmaxPowerMul is present in ModuleManager.ConfigCache I am wondering why that is? Another question is, if I move the creation of MYMMmaxPowerMul up one node, like; Reveal hidden contents @PART[CT250?]:HAS[@MODULE[InterstellarResourceConverter]]:NEEDS[InterstellarFuelSwitch]:AFTER[WildBlueTools] { %MYMMmaxPowerMul = 1000 // create variable my_mm maxPower Multiplier 1.0 = same as stock IFS @MODULE[InterstellarResourceConverter]:HAS[#primaryResourceNames[LqdXenon]] { @maxPowerPrimary *= #$MYMMmaxPowerMul$ @maxPowerSecondary *= #$MYMMmaxPowerMul$ } } @PART[CT250?]:HAS[@MODULE[InterstellarResourceConverter]]:NEEDS[InterstellarFuelSwitch]:AFTER[WildBlueTools] { !MYMMmaxPowerMul // delete variable } Would creating MYMMmaxPowerMul in such a place allow the variable to be used in the sub node? Or is it bound into the node level it was created in? I am considering moving the variable to such a place, because I may wish to use the conversion factor for more that just XenonGas. This is not critical for the moment and I am quite happy to expand out the code on a case by case basis for any additional gas conversion rates that I wish to change. I want to avoid using :FINAL as a means of forcing the deletion, is :FINAL the only way to ensure the variable is removed. Does anyone have some helpful comments that can share? Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.