2024 Technology Preview Program:
Master powerful new features and shape the latest BIM-enabled innovations
2023-05-09 09:13 PM - last edited on 2023-05-23 04:33 PM by Rubia Torres
I've created an object for half a dozen types of bicycle racks. I'm scheduling these by kind to get a quantity of racks, but a couple of them are for stacking units that contain two bikes. These are technically one object that should count as two.
I created a parameter called Stall Count and created values for these based on the type of stall - also a set of values. I've tried placing this at the top of the Master Script as well as the Parameter script.
When I place or edit a stall to be a stacked bike rack, I can't get the stall count number to change automatically based on the stall type.
I've looked at GLOB_MODPAR_NAME as a possibility, but don't fully understand how it works.
I can set this manually by instance, but I've got 50 people using the part and want to make this transparent to the user.
Help!
Solved! Go to Solution.
2023-05-10 04:31 PM
Haha, thanks Aaron!
To the issue at hand: I should have put in even more info. Both parameters (the number of bikes, and the rack type) must be integers!
Then once set the value of the rack type parameter to one manually. The error will go away then. (The reason is that any new number parameter, be it float or integer, will be initialized to zero. A GDL array can't have indizes that are negative or zero (!) – that's why youre getting screamed at)
2023-05-09 10:59 PM - edited 2023-05-09 11:02 PM
Hey Aaron!
Do not forget to "push back" the values to the parameters with the same named command.
If there are a lot of different types, I'd personally do it like this:
!!! Master script
TYPE_ONE = 1
TYPE_TWO = 2
TYPE_OTHER_DESCRIPTION = 3
dim racktype[] ! used as String representation of the internal number for the racktypes
racktype[TYPE_ONE] = "First Type"
racktype[TYPE_TWO] = "Second Type, yeah"
racktype[TYPE_OTHER_DESCRIPTION] = "Also an important Type"
dim nrs[] ! helper for param script
for i=1 to vardim1(racktype)
nrs[i] = i
next i
dim n_of_bikes[]
n_of_bikes[TYPE_ONE] = 3
n_of_bikes[TYPE_TWO] = 42
n_of_bikes[TYPE_OTHER_DESCRIPTION] = 900
! set the value with the number of stored bikes
! by using the stored integer number of the other parameter
paramNumBikes = n_of_bikes[paramforracktype]
! push back the value to the parameter
parameters paramNumBikes = paramNumBikes
!!! Param script
! Here we set the whole array at once
! we can then use the number internally in the GDL scripts instead of strings
! this has a lot of benefits
values{2} "paramforracktype",
nrs, racktype
2023-05-10 03:11 PM
They don't call you 'Ace' for nothing. Thanks for your response.
I've placed your snippets in an empty file and it's throwing me errors.
I have two parameters in the Parameter List:
paramNumBikes (Integer)
paramforracktype (String)
Neither Parameter shows a value, the line "paramNumBikes = n_of_bikes[paramforracktype]" throws an error and then the Check Script button references an unknown error on compilation or execution. Pressing Save doesn't make the error messages go away.
2023-05-10 04:31 PM
Haha, thanks Aaron!
To the issue at hand: I should have put in even more info. Both parameters (the number of bikes, and the rack type) must be integers!
Then once set the value of the rack type parameter to one manually. The error will go away then. (The reason is that any new number parameter, be it float or integer, will be initialized to zero. A GDL array can't have indizes that are negative or zero (!) – that's why youre getting screamed at)
2023-05-10 04:46 PM
That did the trick, although I'd have never debugged that in a thousand years. Now I begin to understand why my MVO attempts (and your assists) were fraught with trouble. I'm not used to working with your array ideas, but will keep trying. Thanks Ace!
2023-05-10 05:00 PM
You're welcome, Aaron! Glad I was able to help.
The whole array thing might be offputting, and with a list as short as two or three items it might not be worth the hassle, and spaghetti code it is!
However the more code you write, the more elegant and more easily maintainable this solution becomes (I always try to imagine what would happen if I ever need to amend an object – I want to make my future work easier). E.g. you do not need a single IF statement here! Batteries included!