Microsoft Small Basic

Microsoft Small Basic is a programming language, interpreter and associated IDE. Microsoft's simplified variant of BASIC, it is designed to help students who have learnt visual programming languages such as Scratch learn text-based programming.[8] The associated IDE provides a simplified programming environment with functionality such as syntax highlighting, intelligent code completion, and in-editor documentation access.[9] The language has only 14 keywords.[10]

Microsoft Small Basic
ParadigmStructured, imperative, object-oriented
Designed byMicrosoft, Vijaye Raji[1][2]
DeveloperMicrosoft
First appearedOctober 23, 2008; 15 years ago (2008-10-23)[3][4]
Stable release
v1.2 / October 1, 2015; 8 years ago (2015-10-01)[5]
Typing disciplineDynamic, weak
Platform.NET Framework 4.5[5]
OSSmall Basic Desktop: Windows XP (up to version 1.0), Windows Vista, Windows 7, Windows 8, Windows 8.1, Windows 10, Windows Server 2008 R2[6]
Small Basic Online: web browser
LicenseMIT License[7]
Filename extensions.sb, .smallbasic
Websitesmallbasic-publicwebsite.azurewebsites.net
Influenced by
Logo, QBasic, Visual Basic .NET

History

edit
VersionRelease date
Old version, no longer maintained: v0.1October 23, 2008[3]
Old version, no longer maintained: v0.2December 17, 2008[11]
Old version, no longer maintained: v0.3February 10, 2009[12]
Old version, no longer maintained: v0.4April 14, 2009[13]
Old version, no longer maintained: v0.5June 16, 2009[14]
Old version, no longer maintained: v0.6August 19, 2009[15]
Old version, no longer maintained: v0.7October 23, 2009[4]
Old version, no longer maintained: v0.8February 4, 2010[16]
Old version, no longer maintained: v0.9June 11, 2010[17]
Old version, no longer maintained: v0.91November 17, 2010[18]
Old version, no longer maintained: v0.95February 8, 2011[19]
Older version, yet still maintained: v1.0July 12, 2011[20]
Old version, no longer maintained: v1.1March 27, 2015[21]
Current stable version: v1.2October 1, 2015[5]
Legend:
Old version
Older version, still maintained
Latest version
Latest preview version
Future release
Legend:
Old version
Older version, still maintained
Latest version
Latest preview version
Future release

Microsoft announced Small Basic in October 2008,[3] and released the first stable version for distribution on July 12, 2011,[20] on a Microsoft Developer Network (MSDN) website, together with a teaching curriculum[22] and an introductory guide.[23] Between announcement and stable release, a number of Community Technology Preview (CTP) releases were made.

On March 27, 2015, Microsoft released Small Basic version 1.1,[21] which fixed a bug and upgraded the targeted .NET Framework version from version 3.5 to version 4.5, making it the first version incompatible with Windows XP.

Microsoft released Small Basic version 1.2 on October 1, 2015.[5] Version 1.2 was the first update after a four-year hiatus to introduce new features to Small Basic. The update added classes for working with Microsoft's Kinect motion sensors,[5] increased the number of languages supported by the included Dictionary object, and fixed a number of bugs.[6]

On February 19, 2019, Microsoft announced Small Basic Online (SBO). It is open source software released under MIT License on GitHub.[24][25]

Language

edit

In Small Basic, one writes the illustrative "Hello, World!" program as follows:

TextWindow.WriteLine("Hello, World!")

Microsoft Small Basic is Turing complete. It supports conditional branching, loop structures, and subroutines for event handling. Variables are weakly typed and dynamic with no scoping rules.

Conditional branching

edit

The following example demonstrates conditional branching. It ask the user for Celsius or Fahrenheit and then comments on the answer in the appropriate temperature unit.

' A Program that gives advice at a requested temperature.TextWindow.WriteLine("Do you use 'C'elsius or 'F'ahrenheit for temperature?")TextWindow.WriteLine("Enter C for Celsius and F for Fahrenheit:")question_temp: ' Label to jump back to input if wrong input was giventempunit = TextWindow.Read()' Temperature Definitions in Celsius:tempArray["hot"] = 30     ' 30 °C equals 86 °FtempArray["pretty"] = 20  ' 20 °C equals 68 °FtempArray["cold"]= 15     ' 15 °C equals 59 °FIf tempunit = "C" OR tempunit = "c" Then  TextWindow.WriteLine("Celsius selected!")  tempunit = "C" ' Could be lowercase, thus make it uppercaseElseIf tempunit = "F" OR tempunit = "f" Then  TextWindow.WriteLine("Fahrenheit selected!")  ' We calculate the temperature values for Fahrenheit based on the Celsius values  tempArray["hot"] = ((tempArray["hot"] * 9)/5) + 32  tempArray["pretty"] = ((tempArray["pretty"] * 9)/5) + 32  tempArray["cold"] = ((tempArray["cold"] * 9)/5) + 32  tempunit = "F" ' Could be lowercase, thus make it uppercaseElse  GOTO question_temp ' Wrong input, jump back to label "question_temp"EndIfTextWindow.Write("Enter the temperature today (in " + tempunit +"): ")temp = TextWindow.ReadNumber()If temp >= tempArray["hot"] Then  TextWindow.WriteLine("It is pretty hot.")ElseIf temp >= tempArray["pretty"] Then  TextWindow.WriteLine("It is pretty nice.")ElseIf temp >= tempArray["cold"] Then  TextWindow.WriteLine("Don't forget your coat.")Else  TextWindow.WriteLine("Stay home.")EndIf

Small Basic does not support an inline If statement as does Visual Basic, for example:

If temp > 50 Then TextWindow.WriteLine("It is pretty nice.")

Looping

edit

This example demonstrates a loop. Starting from one and ending with ten, it multiplies each number by four and displays the result of the multiplication.

TextWindow.WriteLine("Multiplication Tables")For i = 1 To 10  TextWindow.Write(i * 4)EndFor

While loops are also supported, and the demonstrated For loop can be augmented through the use of the Step keyword. The Step keyword is used in setting the value by which the counter variable, i, is incremented each iteration.

Data types

edit

Small Basic supports basic data types, like strings, integers and decimals, and will readily convert one type to another as required by the situation. In the example, both the Read and ReadNumber methods read a string from the command line, but ReadNumber rejects any non-numeric characters. This allows the string to be converted to a numeric type and treated as a number rather than a string by the + operator.

TextWindow.WriteLine("Enter your name: ")name = TextWindow.Read()TextWindow.Write("Enter your age: ")age = TextWindow.ReadNumber()TextWindow.WriteLine("Hello, " + name + "!")TextWindow.WriteLine("In 5 years, you shall be " + ( age + 5 ) + " years old!")

As Small Basic will readily convert among data types, numbers can be manipulated as strings and numeric strings as numbers. This is demonstrated through the second example.

TextWindow.WriteLine(Math.log("100")) 'Prints 2TextWindow.WriteLine("100" + "3000") ' Prints 3100TextWindow.WriteLine("Windows " + 8) ' Prints Windows 8TextWindow.WriteLine(Text.GetLength(1023.42)) ' Prints 7 (length of decimal representation including decimal point)

In the second example, both strings are treated as numbers and added together, producing the output 3100. To concatenate the two values, producing the output 1003000, it is necessary to use the Text.Append(text1, text2) method.

Libraries

edit

Standard library

edit

The Small Basic standard library includes basic classes for mathematics, string handling, and input/output, as well as more exotic classes that are intended to make using the language more fun for learners. Examples of these include a Turtle graphics class, a class for retrieving photos from Flickr, and classes for interacting with Microsoft Kinect sensors.[26]

To make the classes easier to use for learners, they have been simplified. This simplification is demonstrated through the code used to retrieve a random mountain-themed image from Flickr:

For i = 1 To 10  pic = Flickr.GetRandomPicture("mountains")  Desktop.SetWallPaper(pic)  Program.Delay(10000)EndFor

Turtle graphics

edit

Small Basic includes a "Turtle" graphics library that borrows from the Logo family of programming languages. For example, to draw a square using the turtle, the turtle is moved forward by a given number of pixels and rotated 90 degrees in a given direction. This action is then repeated four times to draw the four sides of the square.

For i = 1 to 4  Turtle.Move(100) ' Forward 100 pixels  Turtle.Turn(90) ' Turn 90 degrees rightEndFor

More complex drawings are possible by altering the turning angle of the turtle and the number of iterations of the loop. For example, one can draw a hexagon by setting the turn angle to 60 degrees and the number of iterations to six.

Third-party libraries

edit

Small Basic allows the use of third-party libraries. These libraries must be written in a CLR-compatible language, and the compiled binaries must target a compatible .NET Framework version. The classes provided by the library are required to be static, flagged with a specific attribute, and must use a specific data type.

An example of a class to be used in Small Basic is provided below, written in C#.

[SmallBasicType]public static class ExampleClass{    public static Primitive Add(Primitive A, Primitive B) => A + B;    public static Primitive SomeProperty    {        get;        set;    }    public static Primitive Pi => (Primitive)3.14159;}

If available, the Small Basic development environment will display documentation for third-party libraries. The development environment accepts documentation in the form of an XML file, which can be automatically generated from source code comments by tools such as Microsoft Visual Studio and MonoDevelop.[27]

References

edit

Further reading

edit
edit