Verse Deprecation Messaging

Hello Verse Users!

In the 28.10 release of UEFN, we’re introducing Verse language versions, and deprecating some behavior that will change in a future version of the language. When your code uses deprecated behavior, it will still compile and work as it did before, but with a Verse compiler warning about the deprecated behavior.

As of 28.10, you can only target language version “0”. However, you might start to see some Verse warnings for code that uses deprecated behavior. While you do not need to immediately act on these warnings, we recommend that you do fix them, so that when we release a new language version, you will be ready to benefit from it. The idea is that if your project compiles without any warnings on an old language version, that you can upgrade it to the latest stable version of the language without anything breaking.

There are two classes of Verse code that we’re deprecating:

Failure of the right-hand subexpression of a ‘set e0 = e1’ expression.
This currently unwinds the failure to an outer failure context, but we would like to reserve this for situations where the left-hand subexpression’s fallibility can be mutated to unify e0 = e1. You can preserve the deprecated behavior by lifting the potential failure outside the set. e.g.:

set Map[Key] = FallibleCall[]

becomes:

Value := FallibleCall[]
set Map[Key] = Value

Failure of a key subexpression in a map literal expression.
This currently unwinds the failure to an outer failure context, but this is inconsistent with the meaning of => in other contexts, which is the notation for an anonymous function value. We would like to reserve failure in a key subexpression for interpretation by the map macro. You can preserve the deprecated behavior by lifting the potential failure outside the map macro. e.g.:

MyMap := map{FallibleCall[] => Value}

becomes:

Key := FallibleCall[]
MyMap := map{Key=>Value}

The Verse team will continue to make improvements to the Verse language that do not require updating to a new language version to benefit from. Only changes that require deprecating existing behavior will require upgrading to a new language version.

Best,

The Verse Team

6 Likes

Love to see that you’re improving the language!
Hope to see some efficient native/inbuilt functions for handling arrays (and maps) in the future :wink:

I don’t feel very positively about this, the change seems to address something that could be a problem in such rare cases that in my opinion it does not warrant the loss of convenient syntax.

It’s a shame, and somewhat infuriating, considering the amount of utils and methods my studio developed around that specific syntax, that now have to be edited or completely rethinked.

2 Likes

I see this change to turn the code more verbose. If we have the question mark to have optionals, why we simply can’t use it to ignore fails as we do in Kotlin with let and question marks, for example. We could simply have:

set Map[Key] = FallibleCall[]?

Instead of having to move a fallible call outside a status writing more code.
I mean, what language is verse based on? I really would like to understand its background to help community to improve this more and more.

For anyone running into issues, and you were using an if statement to avoid using decides you will need to initialize “Value” in an if statement. Example:

Your original code with a warning:

if (set Map[Key] = FallibleCall[]):

New code with same function and no warning:

if (Value := FallibleCall[]):
    set Map[Key] = Value
2 Likes

Verse Definition: The most verbotic language that decides to reverse the common coding conventions for no clear reason.

Warning: It’s claimed to be easy to learn but you will have a hell of time to learn other languages if Verse is your first language because everything is reversed.

IMHO, there should be some explanations as to why you decided on the syntax before you start shoving it to us.

ps. The only thing I like about it are coroutines. Thanks to Skookum guys.

1 Like