Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Nullability #8

Open
koczkatamas opened this issue Dec 30, 2017 · 0 comments
Open

Nullability #8

koczkatamas opened this issue Dec 30, 2017 · 0 comments

Comments

@koczkatamas
Copy link
Collaborator

Nullability in target languages

In some languages any variable can be null, even primitive integer types. This is true for mostly dynamically-typed languages, eg. Ruby, Python, Perl, PHP, JavaScript.

In C# and Java most of the types (eg. String, Array, Map, user-defined types) can be null, but the primitive ones are not (in C# we can use the Nullable class / ? qualifier for that, in Java the boxed instances: eg Integer instead of int).

In the languages mentioned above there is no option the make the nullable types non-nullable.

In other languages nothing can be null by default, only if we make them nullable explicitly (eg. by using pointers in C++ and Go or the ? qualifier in Swift).

In TypeScript the default nullability depends on the strictNullChecks configuration.

Nullability in OneLang

The current implementation has a pretty adhoc nature in the nullability area. Generally primitive types (bool, int, float), string and enums are non-nullable, while everything else (Array, Map, user-defined types) is nullable.

At first string was nullable, but this leaded to some pretty ugly code eg. in C++ at string concatenation.

Nullability of Array and Map is still a question. null is a two-edged sword, it can be used as an easy way to indicate missing value, but allowing null makes the code more error-prone and can generate ugly code in languages which are non-null by default.

The best way would be a more clever compiler which can decide if a field / variable can be ever null, but this is not the goal of the PoC milestone, so we currently allow everything to be null, until this causes serious problems (even if it results in some really ugly generated code).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant