[Info] Allowable Classes for "set_attribute"
-
Thanks for the list!
-
Does "allowable" also mean these types are converted back into their original object types by
get_attribute
?(I know it does, but didn't see that explicitly mentioned in the topic.)
-
Yes, they should. But there might be some quirks in the underlying implementation of storage, where Windows stores to the registry and OSX saves to a plist. I think I recall some escape character issues on one of the platforms - though I don't recall the details. Might have been fixed.
-
@tt_su said:
But there might be some quirks in the underlying implementation of storage, where Windows stores to the registry and OSX saves to a plist.
We were talking about attributes, not
read_default
,write_default
. Do they act similarly? -
@jim said:
We were talking about attributes, not
read_default
,write_default
. Do they act similarly?Duh! That's just my brain not coping with the jet-lag properly. You're correct - it was read/write_default that had that issue.
...gonna go and lie down for another nap...
-
@tt_su said:
Christina is correct, any Point3d and Vector3d stored in an Entity's attribute will be transformed along with the entity itself.
What a quirky thing. Is this a side-effect of some other code, or an explicitly designed behavior? If designed, for what purpose?
-
It's explicitly coded, though the code doesn't mention the historical reason..
-
@tt_su said:
It's explicitly coded, though the code doesn't mention the historical reason..
OK now I understand what Christina was saying.
I agree with Jim. I can think of a situation, whee I'd save some point in the model (which is relative to the world origin, and I would be rather ticked if SketchUp applied a transform to MY attribute without MY permission.
How would / should SketchUp know what the value of my attribute was for ?
-
If you want to ensure the data isn't transformed, convert the Point3d or Vector3d to an array.
-
I know this. It does not negate what I said. If I store a point that is inside the group, relative to the group's origin, and move the group, ... I would not want the point to be transformed.
WHO decided that this should happen, WHEN and WHY ? (If this was for DCs, then it should only happen to attributes in the "dynamic_attributes" dictionary.)
This is the first I am hearing of this. Is it documented anywhere ?
It would be nice to specify things as absolute (world co-ords,) or relative (local co-ords.)
Thinking, what if we had subclasses:LocalPoint
&WorldPoint
? -
@dan rathbun said:
I know this. It does not negate what I said. If I store a point that is inside the group, relative to the group's origin, and move the group, ... I would not want the point to be transformed.
Just saying, that is the existing behaviour. It caught me off guard as well and initially I wondered if it was a bug, but when looking at the code it was made deliberately. There are use cases for and against this.
@dan rathbun said:
WHO decided that this should happen, WHEN and WHY ? (If this was for DCs, then it should only happen to attributes in the "dynamic_attributes" dictionary.)
I don't know when, why or who. As far as I can tell this code goes way back and it doesn't mention these details.
@dan rathbun said:
This is the first I am hearing of this. Is it documented anywhere ?
It came to the attention to us (the Extensibility Team) just recently. I'm not sure if it's mentioned anywhere.
For all intent and purposes, it is what it is. We cannot change the behaviour now without probably breaking things. We do need to document it though, make it clear that Point3d and Vector3d will be transformed, but arrays will not.
-
... ya know how much we hate these "secret behaviors"!
-
@dan rathbun said:
... ya know how much we hate these "secret behaviors"!
I sure do. Unfortunately some of this is very old code going way back before what the source control system has any info about. Occasionally someone who's been around long enough from the early days will recall why something was made the way it was - other times it's one of them mysteries.
-
My railroad plugin relies heavily on these data being transformed. When a track is manually moved the bezier control points are moved with it and read by the extension so it knows where the track is located and trains can run on it. I was quite worried how to code this until I accidentally ran into this behavior. It can be really useful and if you don't want it it's easy to store the coordinates in an array instead of Point3d or Vector3d (which is what I do in another part of the plugin).
However this really really really should be documented!
-
@eneroth3 said:
However this really really really should be documented!
Indeed. I'll look into this next week to check out what you indicated to be inconsistencies. That worries me.
-
If I understand it right, an attribute with the same Point3d object that an entity uses (for example directly obtained from the entity
face.vertices.first.position
) will move with the entity.
A clone/copy of such a Point3d (like point + [0,0,0]) might have initially the same position, but does not show this behavior.If this behavior is documented, then it's fine. If it is decided to cleanup/simplify it by removing that behavior, we could (?) still use a Point3d relative to the entity/group's boundingbox origin, which will move with the entity. Does that make sense, Christina?
-
All points and vectors change, even if you add Geom::Point3d.new to the attribute, not just those that refers to a moved vertex.
I suppose a change in the behavior would affect more plugins than just mine. Also it would break backward compability unless you write separate code for older versions which will be much harder to maintain. Also the bounding box is always aligned with the coordinate axes so rotating entity would break the relation between the bounding box origin and a point relative to the entity.
-
I'm very new at this, so pardon if I'm terribly mistaken, but....
Small, additional quirks worth mentioning:
Directly storing / recovering Point3ds and Vector3ds in hashes will fail via Dan's method, as the inspection string will not have proper constructors for them. This is Ruby-specific, not Sketchup. That, and I'm assuming the recently noted entity-attributes-auto-transformation will not apply, as Sketchup will only see a string stored as the attribute.
The hash creation failure:
point = Geom;;Point3d.new(0,0,0) hash = {;origin => point} hash_str = hash.inspect new_hash = eval(hash_str) # Will fail
hash.inspect will return => {:origin=>Point3d(0, 0, 0)}
If you eval that it will throw the error: #<NoMethodError: undefined method `Point3d' for main:Object>
Simple, quick solution? Store Point3ds and Vector3ds as arrays, of course.
hash = {;origin => point.to_a}
Or, alternatively, if you were dead set on keeping them as Geoms...
hash_str = hash.inspect hash_str.gsub!("Point3d", "Geom;;Point3d.new") # Same for vectors if needed
This will successfully eval to a new hash containing a Point3d (though, as previously mentioned, the point will not auto-transform with the entity it is attached to... I assume).
-
Good point(s) (pun intended!)
hash_str.gsub!("Point3d", "Geom::Point3d.new")
is effectively fixing flawedinspect
methods for API classes. (The hash's method callsinspect
upon it's members.)inspect strings should be evaluable!
.. but someone got lazy, and decided to use
inspect
for specially formatted output. -
I just discovered empty arrays cannot be saved as attributes between sessions in SU 6-2015 (tested on windows 7). However it works just as expected within sessions o.0. Bug report has been submitted.
Advertisement