DesktopTextArea.HasHorizontalScrollbar in code is ignored

But there’s more! It seems that setting DesktopTextArea.HasHorizontalScrollbar to be True in code is ignored.

I have added an Issue for this, but does anyone know a workaround?

https://tracker.xojo.com/xojoinc/xojo/-/issues/70383

Could it be that this can only be set in the iDE ?

HasHorizontalScrollBar and HasVerticalScrollBar in the old documentation, this property is mentioned as read-only.

1 Like

Doesn’t say read only in my new documentation, and it compiles OK when I try to reset the Boolean:

It may compile OK but does it actually do anything? If it was read-only in previous doc then presumably that means it was not designed to be changed at runtime. If so, then that is not something that can be “fixed” just because you wish it to be.

There are lots of inaccuracies in the new docs which need, simply, to be reported.

No, it doesn’t do anything, and this is my complaint! If the compiler complained when I tried to change its value, I would assume the documentation was wrong.

I am not sure why both HasHorizontalScrollbar and AllowTabs should not be changeable on the fly when other such items as font, font size, font colour, spellchecking, line height and line spacing can be changed just fine.

The new documentation is often incomplete.

If you try to set a read only property, you won’t get an error. It will simply do nothing.

Didn’t you used to get a compile error if you try to set a read-only property?

No, it did not trigger any compile error. Just tested in 2019R3.2 same thing.

You should. If you don’t, probably it is due to some bad design introducing a bad behavior/bug like:

Private mReadonly As Integer

Public Property readonly As Integer
  Get
    Return mReadonly
  End Get
  Set
    // mReadonly = value
  End Set
End Property

:point_up:t2: dummy setter, don’t do that! It hides bad behaviors.

Solutions:

Remove the setter, it will become a real read-only property.

Let’s imagine that the language you are using does not allow removing the setter, then change the property to a method returning the value like:

Private mReadonly As Integer

Public Function readonly As Integer
  Return mReadonly
End Function

In both cases trying to set the pseudo property readonly to some value will raise an error.

So, it’s not a case of bad documentation. It needs a bug report and fixing.

And Xojo needs to allow any mix of property accessors. Getter+Setter, Getter only, Setter only.