2021-11-17 05:20 PM - last edited 2 weeks ago by Doreena Deng
Hi everyone,
This is not a noob question.
Basically, I have created a Library part that reads a text file containing values that will drive the modeling of my object.
It's structured that it reads a predefined column, extract the unique values of that column and puts it in an array, then repeats that operation a multiple of times until it reaches to the last predefined column that have all the final unique values (about 4-5 times in total).
The problem arises after the third 3 column to be read, it simple does not update its values.
And the funny part is, the Variable arrays that are being used to update the Parameter Arrays, do get the updates, but the Parameter arrays do not get updated.
How do you overcome that ??
PS: There are not nested ifs...then...endif that exceeds the 3 level.
Solved! Go to Solution.
2021-11-24 07:09 PM
Hello everyone,
First of all, I want to thank you all for your effort and suggestions.
Second, I would like to give you the only answer I was able to reach with my limited knowledge and tools that I can master at the moment, after a lot of testing different methods, trial and errors, head scratching, and head banging against the wall.
We can simply put it this way ...
GDL have a limited capacity for nested IF ... Then ... Endif
Whether we like it or not, it's like that, there is no other way round, in fact I believe I have tested the maximum limits, which are:
2021-11-29 09:14 AM
I doubt this should be the final conclusion, let's investigate further.
Can you just read the file in one go, do all your modifications in memory, then write to parameters once?
2022-03-11 10:07 AM
I have to admit you were right. I managed to re-create the problem with an array parameter. Without arrays the result is as expected.
We are inspecting this as a bug.
2021-11-17 05:32 PM
Reading from a text file is always problematic, because GDL will try to guess the type, thus leading to very nasty errors (think of a room schedule with the room numbers; you'd want e.g. "1.2345" to be text, not a number).
So I've mostly given up reading from text files, since it is so unreliable and impossible to control.
Also GDL arrays don't like to have mixed type in them.
If the first item in an array is text, the rest will be text, if the first is a number, the rest will be, too.
So my guess is: Your text file has different types as content which trips up Archicad.
Use XML instead.
2021-11-17 05:37 PM
I was aware of that, so I have seperated the operation in multiple simple ones, and it will not continue if the read values doesn't correspond to the parameter type (ie: text for text parameters, numeric for numeric parameters)
2021-11-17 05:42 PM
Now I have a very strange behaviour
The 4 th parameter gets updated, but it only shows the values of the previous selection operation, not the updated one 😕😕😕😕😕😕😕😕😕 ???!!!!!*#
2021-11-17 07:09 PM
Update:
I believe that somehow I'm near to the cause of my problems in GDL, it have to do with if...then..endif, number of Parameter Script execution and Branching decisions at the binary level not GDL
2021-11-17 11:27 PM
Last Update:
I broke the GDL .... no seriously I really broke it.
Proof:
I have created an array variable ... filled it with string (after initiation)
Passed the values to corresponding parameter arrays in memory
Implemented change to the Parameters using Parameters Param=Variable
used Values{2} to get the results ... and bam The GDL editor refused it, saying that the String Parameter Array is a numeric Paramaeter
2021-11-22 11:00 AM
Try to set the array type prior to load (something[1]="" or something[1]=0) - it may help because avoids the "guessing" part.
Sometimes I try to lad the all as text and then further phrase....(I have to relay on some database export which is set to export as text so I have extra work..and I deal with 6000x60 or something csv)
2021-11-22 02:45 PM
Already done that
2021-11-22 03:35 PM
I had stepped on something - maybe it is also Your case:
My scheme was to load data in macro which was called using returned_parameters, and when I had it in master script the call did not work. I had to move part of the script to the parameter script and it started to work as a charm.
2021-11-22 03:38 PM
Nope