Rebol2 and Red both have a console property that when the console sees an UNSET!, it prints nothing:
>> block: reduce [<a> #[unset!] <b>]
== [<a> unset <b>] ; bad rendering, conflates #[unset!] with the word `unset`
>> first block
== <a>
>> second block
>> third block
== <b>
This doesn't provide the best grounding in the console, especially considering that in their world an UNSET! is a reified value that can be found in a block.
However, returning an UNSET! is how functions like PRINT avoid outputting anything with ==
in the console:
rebol2>> print "Notice no == result"
Notice no == result
rebol2>> type? print "Test"
Test
== unset!
But What Result Should Ren-C Suppress?
Ren-C has the concept of VOID which has an isotopic form known as "NONE", that is used as the unfriendly contents of an unset variable.
For educational purposes, I feel it makes the most sense to have voids not print anything, and nones print out the standard isotopic form:
>> void
>> quote void
== '
>> quasi void
== ~
>> ~
== ~ ; isotope
Looking at this it might seem to make a lot of sense to have functions like PRINT and HELP return VOID.
But as I explain in "Why doesn't PRINT return VOID or NIHIL", there is a bit of a pitfall. Voids are friendly in terms of opting out of things:
>> append [a b c] print "If PRINT returned void..."
If PRINT returned void...
== [a b c]
This seems too friendly to me. There's another possibility of returning NIHIL, which would be void if no other expressions were in play...and would prohibit use as an argument. But it would let previous results fall out:
>> print "If PRINT returned nihil"
If PRINT returned nihil
>> append [a b c] "If PRINT returned nihil"
If PRINT returned nihil
** Error: APPEND is missing its VALUE argument
>> 1 + 2 print "If PRINT returned nihil"
If PRINT returned nihil
== 3
So returning NONE mechanically feels like it makes the most sense...it has the right amount of ornery-ness:
>> print "Mechanically this works best"
Mechanically this works best
== ~ ; isotope
But it's ugly to have that == ~ ; isotope after every HELP or PRINT or other function.
Previously I had it so that voids printed out a comment, and nones printed nothing:
>> ~
>> void
; void
But this is making the console pretty at the cost of obfuscation. I'll point out that the web console can make the == ~ ; isotope some kind of light gray so it's less noticeable.
People Always Bend To Get What They Want...
I might not like the idea of returning a "friendly" void to get invisibility, and try forcing everyone to use NONE for console commands. But if they see VOID/NIHIL as the better way to get what they want, they'll choose that in their own commands to cut down on the clutter.
It seems there's at least a rationale here for why isotopic void would output nothing, while void would give a comment. If you consider the fact that isotopic void is "less than" a void, then giving it the special nothing-printed status makes some amount of sense.