– OK, first get rid of the $-sign to denominate variables. We have come much further than that in the meantime. Low level programming languages like Visual Dialog Script (www.dialogscript.com), Kix, Pearl, or PHP need these parsing aids. We should not go back to that.– Next, get rid of the horrific {$._} construct, not only because the curly braces are available only together with ALT-GR on most non-US keyboards. Furthermore, it is impossible to read (for non-programmers). Programmers are accustomed to such constructs and worse ones. But if you want to gain heart and mind of the administrators, that is not the way.– Provide some kind of assistance when typing the dot after an object, simlar to Intellisense. If you want administrators NOT to read tons and tons of books, well, the only way is to provide online assistance, like Intellisense. Your presentation started gearing towards administrators but very shortly thereafter, there were hardcore programmers speaking to other hardcore programmers, in the most pure tech-talk. I assume, that you would have lost your non-hardcore programmers audience after 20-30 minutes.
- We looked at the all the mechanisms shells/scripts use and thought that most of the shell and script ones were …. well …. ummm …. inconsistent and not the strongest features of these environments.
- We wanted to provide a smooth glide path between GUI, CLI, and C#.
As such, use of {} was an easy choice for us. Now let me say a couple more words about #2. Monad is NOT C#Script. It is a distinct environment focused on distinct user scenarios that are quite different than C#. The language and environment reflect that. When we designed the language we looked at a number of different environments (SH, PERL, RUBY, VMS/DCL, AS400/CL, and C#) and took inspiration from elements of many of these. We also wanted Monad to have the widest dynamic range possible. It should be easy to start using, easy to start scripting, easy to do sophisticated scripting and you should be able to use Monad to do most everything you want to do. That said, we know that at some point Monad will not meet your needs and you’ll need to do systems programming (typically for perf reasons). When this occurs, we want to minimize your switching costs. This is why we use choose to use C# for many basic elements that do not conflict with our interactive scenarios. {} is just one of many. We think that this has worked out pretty well. Monad is a fantastic environment to explore .NET and while most of Monad is written using C#, a number of our devs do prototyping work in Monad itself and then translate it into C#.
Intellisense. I totally concur. The current system is relies too much on .NET objects and our tab completion is too weak. It is going to take a while before you can do everything using cmdlets (instead of .NET objects) however in the next drop (Next week), you’ll see that tab completion gets much better. We’ll provide tab completion for filenames, command names, command parameters, object properties and methods. Tab completion is actually a callout to a user-definable function so that the community can get as sophisticated as they’d like to. This feature has lagged because we have strongly focused on the command line experience and invested there instead of spending time on things like IDEs. We are relying on the community and third parties to fullfill this need in the V1 timeframe. That said, user feedback was strong enough on this point that we knew that we had do improve things for V1. We hope you like what you get next week.
As always, please let me know if this is not the case or if you think that there are things we should be doing better.
Raul – thanks for taking the time to organize and send me your feedback. I hope this blog provides some more context around why we made the decisions that we did.
Enjoy!
Jeffrey Snover
Monad Architect
[Edit: Monad has now been renamed to Windows PowerShell. This script or discussion may require slight adjustments before it applies directly to newer builds.]
PSMDTAG:FAQ: Why do variables start with “$” ?
PSMDTAG:FAQ: Why use “{}” vs IF/FI WHILE/WEND DO/OD etc?
PSMDTAG:FAQ: Why use -le -ge and -eq instead of < > and = ?
PSMDTAG:PHILOSOPHY: Don’t tradeoff interactive and scripting experiences – optimize for both.
PSMDTAG:PHILOSOPHY: Provide a smooth glide path between GUI, CLI, and C#
0 comments