2.1 Environment variables
Okay, let's be honest, the program we wrote in the first section was pretty boring. Let's try something that isn't hard-coded to just say "Hello world." Let's make the program actually greet us by name.
The way we will do this is by reading a value from the operating system which should contain our username. Here is the program:
println$ "Hello " + Env::getenv "USER";
We notice the following:
getenvis a function that will retrieve a value from the system's environment variables.
getenvtakes one input (the name of the variable to lookup) and uses that to query the operating system. Also, it can't fail. If the variable doesn't exist on the system it will just return an empty string. (We will get to smarter methods for handling invalid input later.)
Envis the class (you can think of it as a namespace or module, if you like) that contains the
getenvprocedure. Classes make life nice because they allow us to group associated behavior together. The
::operator allows us to "reach into" a class to get to the contents inside. Its functionality and notation is borrowed from C++, however--just as a warning--classes in Felix differ from those in C++.
The infix operator
+you see is string concatenation. It takes two strings as inputs and returns one "joined" string as an output. So, in our example above, if
"Jim"then concatenation would produce a new string containing