From 80054366413552b21edb514b3afb279df983dc2d Mon Sep 17 00:00:00 2001 From: blitz-research Date: Thu, 23 Jan 2014 11:55:51 +1300 Subject: [PATCH] Added docs. --- doc/bmxstyle.css | 126 ++++ .../Advanced topics/Interfacing with C.bbdoc | 80 +++ .../Advanced topics/Memory management.bbdoc | 43 ++ .../Language/Advanced topics/Pointers.bbdoc | 36 ++ docs/src/Language/Advanced topics/index.bbdoc | 5 + docs/src/Language/Arrays.bbdoc | 75 +++ docs/src/Language/BASIC Compatibility.bbdoc | 107 ++++ docs/src/Language/Collections.bbdoc | 30 + docs/src/Language/Comments.bbdoc | 18 + docs/src/Language/Conditional compiling.bbdoc | 39 ++ docs/src/Language/Constants.bbdoc | 25 + docs/src/Language/Data types.bbdoc | 68 +++ docs/src/Language/Debugging.bbdoc | 22 + docs/src/Language/Exceptions.bbdoc | 28 + docs/src/Language/Expressions.bbdoc | 103 ++++ docs/src/Language/Functions.bbdoc | 38 ++ docs/src/Language/Identifiers.bbdoc | 40 ++ docs/src/Language/Literals.bbdoc | 54 ++ docs/src/Language/Modules.bbdoc | 55 ++ docs/src/Language/Objects.bbdoc | 35 ++ docs/src/Language/Program flow.bbdoc | 118 ++++ docs/src/Language/Projects.bbdoc | 49 ++ docs/src/Language/Slices.bbdoc | 22 + docs/src/Language/Strings.bbdoc | 81 +++ docs/src/Language/User defined types.bbdoc | 158 +++++ docs/src/Language/Variables.bbdoc | 72 +++ docs/src/Language/index.bbdoc | 10 + docs/src/Licenses/bssc.bbdoc | 35 ++ docs/src/Licenses/ftl.bbdoc | 171 ++++++ docs/src/Licenses/glx.bbdoc | 206 +++++++ docs/src/Licenses/oggvorbis.bbdoc | 61 ++ docs/src/Licenses/sgi.bbdoc | 42 ++ docs/src/Licenses/zlibpng.bbdoc | 35 ++ docs/src/Tutorials/BlitzMax overview.bbdoc | 422 ++++++++++++++ docs/src/Tutorials/MaxGUI overview.bbdoc | 546 ++++++++++++++++++ docs/src/Tutorials/index.bbdoc | 0 docs/src/Tutorials/nehe_01.bmx | 14 + docs/src/Tutorials/nehe_02.bmx | 42 ++ docs/src/Tutorials/nehe_03.bmx | 46 ++ docs/src/Tutorials/nehe_04.bmx | 56 ++ docs/src/Tutorials/nehe_05.bmx | 108 ++++ docs/src/Tutorials/style.css | 126 ++++ docs/src/Tutorials/upperstream.bmx | 89 +++ docs/src/User Guide/bmk.bbdoc | 84 +++ docs/src/User Guide/error1.png | Bin 0 -> 4588 bytes docs/src/User Guide/error2.png | Bin 0 -> 5155 bytes docs/src/User Guide/index.bbdoc | 28 + docs/src/User Guide/maxide.bbdoc | 155 +++++ docs/src/_credits.html | 33 ++ docs/src/bmax120.png | Bin 0 -> 13680 bytes docs/src/brllogo.png | Bin 0 -> 3751 bytes docs/src/index.html | 36 ++ docs/src/styles/fredborg.css | 129 +++++ 53 files changed, 4001 insertions(+) create mode 100644 doc/bmxstyle.css create mode 100644 docs/src/Language/Advanced topics/Interfacing with C.bbdoc create mode 100644 docs/src/Language/Advanced topics/Memory management.bbdoc create mode 100644 docs/src/Language/Advanced topics/Pointers.bbdoc create mode 100644 docs/src/Language/Advanced topics/index.bbdoc create mode 100644 docs/src/Language/Arrays.bbdoc create mode 100644 docs/src/Language/BASIC Compatibility.bbdoc create mode 100644 docs/src/Language/Collections.bbdoc create mode 100644 docs/src/Language/Comments.bbdoc create mode 100644 docs/src/Language/Conditional compiling.bbdoc create mode 100644 docs/src/Language/Constants.bbdoc create mode 100644 docs/src/Language/Data types.bbdoc create mode 100644 docs/src/Language/Debugging.bbdoc create mode 100644 docs/src/Language/Exceptions.bbdoc create mode 100644 docs/src/Language/Expressions.bbdoc create mode 100644 docs/src/Language/Functions.bbdoc create mode 100644 docs/src/Language/Identifiers.bbdoc create mode 100644 docs/src/Language/Literals.bbdoc create mode 100644 docs/src/Language/Modules.bbdoc create mode 100644 docs/src/Language/Objects.bbdoc create mode 100644 docs/src/Language/Program flow.bbdoc create mode 100644 docs/src/Language/Projects.bbdoc create mode 100644 docs/src/Language/Slices.bbdoc create mode 100644 docs/src/Language/Strings.bbdoc create mode 100644 docs/src/Language/User defined types.bbdoc create mode 100644 docs/src/Language/Variables.bbdoc create mode 100644 docs/src/Language/index.bbdoc create mode 100644 docs/src/Licenses/bssc.bbdoc create mode 100644 docs/src/Licenses/ftl.bbdoc create mode 100644 docs/src/Licenses/glx.bbdoc create mode 100644 docs/src/Licenses/oggvorbis.bbdoc create mode 100644 docs/src/Licenses/sgi.bbdoc create mode 100644 docs/src/Licenses/zlibpng.bbdoc create mode 100644 docs/src/Tutorials/BlitzMax overview.bbdoc create mode 100644 docs/src/Tutorials/MaxGUI overview.bbdoc create mode 100644 docs/src/Tutorials/index.bbdoc create mode 100644 docs/src/Tutorials/nehe_01.bmx create mode 100644 docs/src/Tutorials/nehe_02.bmx create mode 100644 docs/src/Tutorials/nehe_03.bmx create mode 100644 docs/src/Tutorials/nehe_04.bmx create mode 100644 docs/src/Tutorials/nehe_05.bmx create mode 100644 docs/src/Tutorials/style.css create mode 100644 docs/src/Tutorials/upperstream.bmx create mode 100644 docs/src/User Guide/bmk.bbdoc create mode 100644 docs/src/User Guide/error1.png create mode 100644 docs/src/User Guide/error2.png create mode 100644 docs/src/User Guide/index.bbdoc create mode 100644 docs/src/User Guide/maxide.bbdoc create mode 100644 docs/src/_credits.html create mode 100644 docs/src/bmax120.png create mode 100644 docs/src/brllogo.png create mode 100644 docs/src/index.html create mode 100644 docs/src/styles/fredborg.css diff --git a/doc/bmxstyle.css b/doc/bmxstyle.css new file mode 100644 index 0000000..5c10080 --- /dev/null +++ b/doc/bmxstyle.css @@ -0,0 +1,126 @@ +body{ + color: #000000; + background: #ffffff; + font: 9pt helvetica; +} +body.navbar{ + color: #000000; + background: #ffffff; + font: 10pt helvetica; + padding: 2px; +} +h1{ + font: 14pt helvetica; + font-weight: bold; +} +h2{ + font: 12pt helvetica; + font-weight: bold; +} +h3{ + font: 10pt helvetica; + font-weight: bold; +} +table{ + background: #ffffff; + font: 10pt helvetica; +} +th{ + padding: 4px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + text-align: left; +} +td{ + padding: 4px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; +} +td.blank{ + padding: 0px; + background: #ffffff; + border: none; +} +td.small{ + padding: 2px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; + font: 8pt helvetica; +} +td.doctop{ + padding: 10px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + font: 10pt helvetica; + vertical-align: text-top; + font-weight: bold; +} +td.docleft{ + padding: 10px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + font: 8pt helvetica; + vertical-align: text-top; + width: 10%; +} +td.docright{ + padding:10px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; + font: 10pt helvetica; + vertical-align: text-top; + width: 90%; +} +pre{ + font: 10pt courier; + background: #eef8ff; + padding: 8px; +} +font.token{ + font-weight: bold; +} +font.syntax{ + color: #005555; +} +div.ref{ + border: 1px solid #000000; +} +div.indent{ + padding-left: 8px; +} +div.syntax{ + color: #005555; + padding: 8px; +} +a{ + color: #000088; + font: 10pt helvetica; + text-decoration: underline; +} +a.navbig{ + color: #000088; + font: 9pt helvetica; + text-decoration: none; +} +a.navsmall{ + color: #000088; + font: 8pt helvetica; + text-decoration: none; +} +a:hover{ + color: #000088; +} +a.small{ + color: #000088; + font: 8pt helvetica; +} +a.token{ + color: #000088; + text-decoration: underline; +} +a.null{ + text-decoration: none; +} +div.entries{ + display: none; +} diff --git a/docs/src/Language/Advanced topics/Interfacing with C.bbdoc b/docs/src/Language/Advanced topics/Interfacing with C.bbdoc new file mode 100644 index 0000000..7496e5a --- /dev/null +++ b/docs/src/Language/Advanced topics/Interfacing with C.bbdoc @@ -0,0 +1,80 @@ + ++Interfacing with C and other languages + +You can use the #Import command to add certain non-BlitzMax source files to your projects, and the #Extern command to make the functions in those files available to BlitzMax applications. + +The currently supported non-BlitzMax source file types are: .c (C); .cpp (C++); .cxx (C++); .m (ObjectiveC); and .s (Assembler). + +BlitzMax will use the GNU compiler tools to compile C, C++ and ObjectiveC files, and either the 'fasm' assembler for x86 assembly or GNU assembler for PowerPC assembly. + +Here is a simple example of importing C source code into your project and accessing a C function: +{{ +//----- file: c_funcs.c ----- +int Doubler( int x ){ + return x+x; +} + +'----- file: app.bmx ----- +Import "c_funcs.c" + +Extern + Function Doubler( x ) +End Extern + +Print Doubler(10) +}} + +You can also use #Import to add a C compiler 'include' directory. To do this, use an import path that ends in "*.h", for example: +{{ +Import "include/*.h" +}} + +#Extern can also be used to work with C++ style objects from within BlitzMax. To do this, simply place a user-defined type declaration within an extern block. For example: +{{ +//----- file: mytype.cpp ----- +#include + +class MyType{ +public: + virtual ~MyType(){} + virtual void Test(){ printf( "Hello World!\n" ); } +}; + +extern "C"{ + +MyType *CreateMyType(){ + return new MyType; +} + +void DestroyMyType( MyType *t ){ + delete t; +} + +'----- File: app.bmx ----- +Import "mytype.cpp" + +Extern + +Type TMyType + Method _pad1() 'padding for virtual destructors + method _pad2() + Method Test() +End Type + +Function CreateMyType:TMyType() +Function DestroyMyType( t:TMyType ) + +End Extern + +Local t:TMyType=CreateMyType() +t.Test +DestroyMyType t +}} + +Note that there are several limits on the use of extern types: +[ +* Methods declared in an extern type must be declared @virtual in the C++ class. +* Objects of extern type cannot be created with #New. Instead, such objects must be created by an extern function. +* Extern types can extend other extern types, but can not extend standard BlitzMax types. Similarly, BlitzMax types can not extend extern types. +* Objects of extern type cannot be cast to 'Object'. +] diff --git a/docs/src/Language/Advanced topics/Memory management.bbdoc b/docs/src/Language/Advanced topics/Memory management.bbdoc new file mode 100644 index 0000000..fe69a18 --- /dev/null +++ b/docs/src/Language/Advanced topics/Memory management.bbdoc @@ -0,0 +1,43 @@ + ++Memory management issues + +BlitzMax currently uses an optimized form of reference counting to implement memory management. + +However, there is one situation where you need to be a bit careful about memory management and that is when you are dealing with %{cyclic data structures}. + +A cyclic data structure is a data structure (in BlitzMax, a user defined type) that can potentially 'point to itself'. The most extreme example of a cyclic data structure is something like: +{{ +Type TCyclic + Field cycle:TCyclic=Self +End Type + +For k=1 To 10 + Local cyclic:TCyclic=New TCyclic + GCCollect + Print GCMemAlloced() +Next +}} +If you run this program, you will notice that memory is slowly leaking. This is happening because the reference count for each TCyclic object never reaches 0, thanks to the objects 'cyclic' field. + +It is therefore necessary to ensure such cyclic data structures are cleanly handled. This can be achieved by adding a method to 'unlink' any such cycles. For example: +{{ +Type TCyclic + Field cycle:TCyclic=Self + + Method Remove() + cycle=Null + End Method + +End Type + +For k=1 To 10 + Local cyclic:TCyclic=New TCyclic + GCCollect + Print GCMemAlloced() + cyclic.Remove +Next +}} + +In real world use this problem seldom arises, and when it does it's typically when designing container types. + +If you are at all worried about this, you can easily track memory usage with the GCMemAlloced() function from the BlitzMax runtime library. diff --git a/docs/src/Language/Advanced topics/Pointers.bbdoc b/docs/src/Language/Advanced topics/Pointers.bbdoc new file mode 100644 index 0000000..2df5f8f --- /dev/null +++ b/docs/src/Language/Advanced topics/Pointers.bbdoc @@ -0,0 +1,36 @@ + ++Pointers + +BlitzMax supports 'C' style pointers for use by code that must perform low level interaction with the operating system and/or speed sensitive code. + +Pointers are not recommended for general use, as misuse of pointers can easily result in memory corruption causing all sorts of bugs and headaches! + +Pointers may be declared by appending @Ptr to the type of a variable or function declaration. For example: +{{ +Local int_Ptr:Int Ptr +}} +Note the pointers are only supported for the primitive numeric types: Byte, Short, Int, Long, Float and Double. + +The #Varptr operator allows you to find the address of a variable, yielding a pointer. For example: +{{ +Local an_int:Int=10 +Local int_ptr:Int Ptr=Varptr an_int +}} +Array style indexing is used to dereference pointers: +{{ +Local an_int:Int=10 +Local int_ptr:Int Ptr=Varptr an_int +Print int_ptr[0] +}} +BlitzMax will automatically convert any pointer type to a byte pointer for you. In addition, objects and arrays may be assigned to byte pointers. In the case of objects, the pointer will contain the address of the first field of the object. In the case of arrays, the pointer will contain the address of the first element of the array. + +Be very careful when assigning objects to pointers, as there is a danger that the garbage collector will 'reclaim' the object before you have finished with the pointer! It is recommended that you use #GCSuspend and #GCResume around code that converts objects to pointers. + +You may also explictily cast pointers to and from other pointers, and to and from Int. For example: +{{ +Local an_int:Int=10 +Local int_ptr:Int Ptr=Varptr an_int +Local float_ptr:Float Ptr=Float Ptr int_ptr +Local var_address:Int=Int float_ptr +}} + diff --git a/docs/src/Language/Advanced topics/index.bbdoc b/docs/src/Language/Advanced topics/index.bbdoc new file mode 100644 index 0000000..63458a0 --- /dev/null +++ b/docs/src/Language/Advanced topics/index.bbdoc @@ -0,0 +1,5 @@ + ++Advanced topics + +This section covers some of the trickier topics involved when using BlitzMax. + diff --git a/docs/src/Language/Arrays.bbdoc b/docs/src/Language/Arrays.bbdoc new file mode 100644 index 0000000..bbf12da --- /dev/null +++ b/docs/src/Language/Arrays.bbdoc @@ -0,0 +1,75 @@ + ++Arrays + +Arrays are used to store sequences of variables, or %elements. An element within an array is accessed by %indexing the array with an integer offset. + +The general syntax for indexing an array is: +{ +%ArrayExpression @[ %index1 @, %index2 etc... @] +} + ++Creating Arrays + +The most common way to create an array is when declaring a variable: +{{ +Local int_array[10] +}} +This will initialize the int_array variable with a 10 element array. You can declare an 'empty' array by using []: +{{ +Local int_array[] +}} +An empty array is identical to an array with 0 elements. + +Arrays may also be created 'on the fly' using the syntax: +{ +@New @[ %Dimension1 @, %Dimension2 etc... @] +} +This returns an array of the specified dimension(s) with each element initialized to #Null. For example: +{{ +Local int_array:Int[] +int_array=New Int[10] +}} +'Auto arrays' may be created using the syntax: +{ +@[ %Element1 @, %Element2 etc... @] +} +This returns a 1 dimensional array containing the specified elements, for example: +{{ +Local int_array[]=[1,2,3,4,5] +}} +Each element of an auto array must have exactly the same type. If necessary, you can use type conversions to enforce this. + +Arrays also provide the following methods: + +[ @Method | @Description +* Sort( ascending=True ) | Sort the array. +* Dimensions:Int[]() | Get array dimensions. +] + +Arrays also provide a read-only @length field that returns the total number of elements in the array. + +Here are some examples of using array methods: +{{ +Strict + +Local arr:String[]=["some","random","strings","in","a","string","array"] + +arr.Sort 'sort ascending +Print "Array in ascending order..." +For Local t:String=EachIn arr + Print t +Next + +arr.Sort False 'sort descending +Print "Array in descending order..." +For Local t:String=EachIn arr + Print t +Next + +Local arr2[10,20,30,40] + +'Dump array dimensions +For Local i=EachIn arr2.Dimensions() + Print i +Next +}} diff --git a/docs/src/Language/BASIC Compatibility.bbdoc b/docs/src/Language/BASIC Compatibility.bbdoc new file mode 100644 index 0000000..be3ae76 --- /dev/null +++ b/docs/src/Language/BASIC Compatibility.bbdoc @@ -0,0 +1,107 @@ + ++BASIC Compatibility + +This section covers some of the differences between BlitzMax and 'classic' BASIC, and introduces features that help overcome some of classic BASIC's shortcomings. + ++Strict mode + +Classic BASIC allows you to declare variables 'on the fly'. For example, consider a program consisting of: +{{ +For k=1 To 10 + sum=sum+k +Next +Print sum +}} +This program automatically creates 2 local variables: 'k' and 'sum'. However, this behaviour can often lead to unexpected bugs. For example, if you mistyped one of the 'sum' variables, the program would not work as expected. No error would be given - a new variable would simply be created. + +By default, BlitzMax will allow you to automatically declare variables like this. However, you can use the @Strict command to override this behaviour. + +#Strict must appear at the top of your program before any actual program code and puts your program into 'strict mode'. Strict mode forces you to declare all variables before use. For example, rewriting the above program in strict mode results in: +{{ +Strict +Local sum,k +For k=1 To 10 + sum=sum+k +Next +Print sum +}} +If you were to mistype one of the variable names in this program, you would receive an 'identifier not found' error when compiling, allowing you to easily find and correct the problem. + ++Arrays + +Blitzmax does not support the Dim statement for array creation. Instead, arrays in BlitzMax are real types - they can be passed to functions, returned from functions and placed in variables. + +To create a classic BASIC style array in BlitzMax, use a global variable. For example: +{{ +Global my_array$[100] 'create a 100 element string array +}} +Also note that arrays in BlitzMax are not '1 bigger' than their dimensioned size - the 100 element array above contains 100 elements, numbered 0 through 99 inclusive. + +BlitzMax also does not support a 'Redim' operation. Instead, you can use #slices. For example: +{{ +Global my_array$[100] 'create a 100 element string array +my_array=my_array[..200] 'now a 200 element array! +}} + ++Goto and Gosub + +BlitzMax does not support the Gosub command. Use #functions instead. + +The Goto command is supported, but only in non-strict mode. Goto labels should be prefixed with a ~# character. For example: +{{ +For k=1 To 10 + a=Rand(10) + If a<5 Then Goto LessThan5 + If a>5 Then Goto GreaterThan5 + Print "a is equal to 5" + Goto AllDone +#LessThan5 + Print "a is less than 5" + Goto AllDone +#GreaterThan5 + Print "a is greater than 5" +#AllDone +Next +}} + ++Data, Read and Restore + +Data, Read and Restore are supported but have been renamed to #DefData, #ReadData and #RestoreData. Data labels must also be prefixed with a ~# character. + ++Object handles + +BlitzMax allows objects to be assigned to integer variables, and integer variables to be passed to functions expecting objects. This is mainly for the benefit of beginners, as it reduces the size and complexity of code, but is also great for lazy pro's! For example: +{{ +Graphics 640,480 +image=LoadImage( "an_image.png" ) 'returned object is converted to an integer handle +DrawImage image,0,0 'integer image parameter is converted back to an object +Flip +WaitKey +}} +This is achieved using an %{object handle} system, and such handles should be released using the #Release command when they are no longer needed. For example: +{{ +Graphics 640,480 +image=LoadImage( "an_image.png" ) 'returned object is converted to an integer handle +DrawImage image,0,0 'integer image parameter is converted back to an object +Release image 'image no longer needed - release it +Flip +WaitKey +}} +Failing to release an object handle will result in memory leaks. However, all objects are released at program exit anyway, so for quick 'n' dirty jobs you don't have to bother. + ++Type tag shortcuts + +When declaring variables and function return types, BlitzMax allows you to use BASIC style 'type tags'. These are as follows: + +[ @{Type tag} | @{Equivalent type} +* ~% | Int +* ~# | Float +* ~! | Double +* ~$ | String +] +For example, a string variable can be declared in two ways: +{{ +Local a_string:String +Local another_string$ +}} +Mac users whose keyboards do not feature the ~# character should use 'Alt 3'. diff --git a/docs/src/Language/Collections.bbdoc b/docs/src/Language/Collections.bbdoc new file mode 100644 index 0000000..f62aa50 --- /dev/null +++ b/docs/src/Language/Collections.bbdoc @@ -0,0 +1,30 @@ + ++Collections + +BlitzMax offers simple support for managing %collections of objects, and for visiting each object in a %collections using a special form of For/Next loop. + +The simplest kind of collection is an array: +{{ +Local a[]=[1,2,3,4,5] +For Local k=EachIn a + Print k +Next +}} +Each iteration of such a loop will assign the next array element (starting with element 0) to the index variable before executing the body of the loop. This allows you to 'visit' each array element in turn. + +It is also possible to create your own kind of collection with user defined types. + +To do this, you must create a user defined type with a method named @ObjectEnumerator which takes no parameters and returns an object. The object returned by this method must itself have the following methods: +{{ +Method HasNext:Int() 'returns true if there's a next object +Method NextObject:Object() 'returns the next object +}} +You can then use the object in a For/Next loop: +{{ +Local list:TList=New TList +list.AddLast "Hello" +list.AddLast "World!" +For Local t$=EachIn list + Print t +Next +}} diff --git a/docs/src/Language/Comments.bbdoc b/docs/src/Language/Comments.bbdoc new file mode 100644 index 0000000..85ffa83 --- /dev/null +++ b/docs/src/Language/Comments.bbdoc @@ -0,0 +1,18 @@ + ++Comments + +Comments are chunks of text in your program code that are ignored by the compiler, but are there to remind you how the code works. + +BlitzMax support single line comments using the @' character - for example: +{{ +Print "Comment Test" 'Everything from the apostrophe (') character to the end of line is ignored. +}} + +Multiline comments are also supported, using @Rem and @{End Rem} - for example: +{{ +Rem +Blitzmax rocks! +An example of a multiline comment... +Multiline comments are useful for documenting and maintaining your code +End Rem +}} diff --git a/docs/src/Language/Conditional compiling.bbdoc b/docs/src/Language/Conditional compiling.bbdoc new file mode 100644 index 0000000..30695d2 --- /dev/null +++ b/docs/src/Language/Conditional compiling.bbdoc @@ -0,0 +1,39 @@ + ++Conditional compiling + +Conditional compiling allows you to turn compiling on or off from within your program depending on the environment the program is being compiled for. + +Conditional compiling works a bit like an @If statement, but takes the form: +{ +@{?}%Identifier +} + +The @? must appear at the start of a new line, and %Identifier should be one of the following: + +[ @Name | @Meaning +* Debug | True if program is being compiled in debug mode. +* Threaded | True if program is being compiled in threaded mode. +* Win32 | True if program is being compiled for the Windows operating system. +* MacOS | True if program is being compiled for the MacOS operating system. +* Linux | True if program is being compiled for the Linux operating system. +* X86 | True if program is being compiled for the Intel CPU. +* PPC | True if program is being compiled for the PowerPC CPU. +* MacOSX86 | True if program is being compiled for an Intel Mac. +* MacOSPPC | True if program is being compiled for a PowerPC Mac. +* BigEndian | True if program is being compiled for a big endian CPU. +* LittleEndian | True if program is being compiled for a little endian CPU. +] + +%Identifier may also be preceded by @Not to invert the result. + +An @? on its own always turns compiling on. + +For example: +{{ +?Debug + 'Any code here is only compiled in debug mode. +?Not Debug + 'Any code here is only compiled in release mode. +? + 'Code here is always compiled. +}} diff --git a/docs/src/Language/Constants.bbdoc b/docs/src/Language/Constants.bbdoc new file mode 100644 index 0000000..fe39d17 --- /dev/null +++ b/docs/src/Language/Constants.bbdoc @@ -0,0 +1,25 @@ + ++Constants + +Constants can be used to store values that don't change during the execution of your program. + +Constants must be declared in your program before use with the #Const command. Declaring a constant means defining a name, type and initial value for it. + +The general syntax for declaring a constant is: +{ +@Const %Identifier @: %Type @= %ConstantExpression +} + +For example: +{{ +Const STARTUP_SIZE=1000 +Const SCREEN_WIDTH=640,SCREEN_HEIGHT=480 +Const SCREEN_AREA=SCREEN_WIDTH*SCREEN_HEIGHT +Const SCALE_FACTOR:Float=1.5 +Const DEFAULT_TITLE:String="Mark Sibly" +}} +Multiple constants may be declared per Const statement using the comma separator. + +If no type is provided for a constant, the constant defaults to being of type #Int. + +The initial value for a constant may be an expression, but the expression must itself be constant - it may only use other constants or literals and may not use any variables. diff --git a/docs/src/Language/Data types.bbdoc b/docs/src/Language/Data types.bbdoc new file mode 100644 index 0000000..01c0cf3 --- /dev/null +++ b/docs/src/Language/Data types.bbdoc @@ -0,0 +1,68 @@ + ++Types + +All constants, variables, functions and expressions have an associated type. BlitzMax supports the following types: + +[ @Description | @Syntax | @{Minimum value} | @{Maximum value} +* 8 bit unsigned integer | Byte | 0 | 255 +* 16 bit unsigned integer | Short | 0 | 65535 +* 32 bit signed integer | Int | -2^31 | +2^31-1 +* 64 bit signed integer | Long | -2^63 | +2^63-1 +* 32 bit floating point | Float | (+/-)10^-38 | (+/-)10^38 +* 64 bit floating point | Double | (+/-)10^-308 | (+/-)10^308 +* 16 bit unicode string | String | - | - +* Object | %Typename | - | - +* Array | %ElementType [ ] | - | - +* Function | %ReturnType ( %Parameters ) | - | - +* Pointer | %ValueType Ptr | - | - +* Variable | %VariableType Var | - | - +] + +Integers are used to store simple numeric data without any fractional part. Unsigned integers can only store positive values, while signed integers can store both positive and negative values. + +Floating point values are used to store numeric data which may have a fractional part. + +Strings are used to store sequences of characters: letters, punctuation, digits and so on. Use strings for storing non-numeric data such as names. + +Arrays are used to store sequences of variables. A variable within an array is accessed by 'indexing' the array with an integer offset. Please refer to the arrays sections for more information on arrays. + +Objects are instances of user-defined types. Please refer to the user-defined types section. + ++Type conversions + +The following type conversions are performed automatically by BlitzMax when necessary - for example, when assigning an expression to a variable, or when passing an expression to a function: + +[ @{Source type} | @{Target type} +* Integer | Floating point, String +* Floating point | Integer, String +] + +You can also convert types explicitly using a %cast operation. This takes the form of a type specifier followed by an expression in brackets. + +Explicit casting allows you to perform the following extra conversions: + +[ @{Source type} | @{Target type} +* String | Integer, Floating point +] + +For example: +{{ +Local n:Int=10 +Local t:String="20" +Print Int( t ) +Print String( n ) +}} + ++Type balancing + +When performing arithmetic operations such as addition or multiplication, it is possible to provide mismatched argument types. For example, the addition operator may be used to add an integer value to a floating point value. But what type should the result be? + +BlitzMax decides the result type by %balancing the argument types. Both arguments are then converted to the result type before the operator is applied. + +The rules governing type balancing are: + +[ If either argument is @Double, then result is @Double +* else if either argument is @Float, then result is @Float +* else if either argument is @Long, then result is @Long +* else result is @Int +] diff --git a/docs/src/Language/Debugging.bbdoc b/docs/src/Language/Debugging.bbdoc new file mode 100644 index 0000000..0655d1b --- /dev/null +++ b/docs/src/Language/Debugging.bbdoc @@ -0,0 +1,22 @@ + ++Debugging + +BlitzMax provides several commands to help with debugging your programs: + +[ #DebugStop - In debug mode, causes the program to stop executing and activates the debugger. In release mode, no effect. + +* #DebugLog %StringExpression - In debug mode, causes %StringExpression to be printed to the debugger output window. In release mode, no effect. + +* #RuntimeError %StringExpression - Causes a runtime error exception (see: #exceptions) to be thrown with the specified string. + +* #Assert %Expression @Else %StringExpression - In debug mode, causes a @RuntimeError if %Expression evaluates to false. No effect in release mode. +] + +@Assert is particularly useful for validating function arguments. For example: +{{ +Function SetAlpha( alpha# ) + Assert alpha>=0 And alpha<=1 Else "Alpha value out of range" + 'rest of function here... +End Function +}} +However, since asserts are taken out in release mode, be careful that your asserts don't have any 'side effects' - code that may affect the execution of the program. diff --git a/docs/src/Language/Exceptions.bbdoc b/docs/src/Language/Exceptions.bbdoc new file mode 100644 index 0000000..6338f13 --- /dev/null +++ b/docs/src/Language/Exceptions.bbdoc @@ -0,0 +1,28 @@ + ++Exceptions + +BlitzMax provides a mechanism for handling runtime errors known as %{exception handling} + +An exception is actually just an object. You can %throw and %catch exceptions using the #Throw command and a #Try / #Catch block. Here is a simple example: +{{ +Function ExTest() + Throw "Bingo!" +End Function + +Try + ExTest() +Catch ex:Object + Print ex.ToString() +End Try +}} +Throwing an exception causes the program to jump to the most recent #Catch block. You can provide multiple catch blocks for catching exceptions of different types. If there is no appropriate #Catch block for the exception, then the program jumps to the %next most recent #Catch block. If no catch block can be found to deal with the exception, the program will end. + +BlitzMax has several built-in exception types, all of which extend type TBlitzException. These are: + +[ @Exception | @Cause +* TNullMethodException | Thrown when a program attempts to call an abstract method. +* TNullFunctionException | Thrown when a program attempts to call a null function. +* TNullObjectException | Thrown when a program attempts to access a null object (only thrown in debug mode). +* TArrayBoundsException | Thrown when a program attempts to access an array element outside of an array's bounds (only thrown in debug mode). +* TRuntimeException | Thrown by the #RuntimeError or #Assert commands. +] diff --git a/docs/src/Language/Expressions.bbdoc b/docs/src/Language/Expressions.bbdoc new file mode 100644 index 0000000..5b83519 --- /dev/null +++ b/docs/src/Language/Expressions.bbdoc @@ -0,0 +1,103 @@ + ++Expressions + ++Operators + +BlitzMax supports the following operators. Operators are grouped into levels of precedence, starting with the highest precedence operators: + +[ @Operator | @Syntax +* Sub expression | @( %Expression @) +* New object | @New %Typename +* Literal | %Value +* Identifier | %Value +* Self object | @Self +* Super object | @Super +* Null value | @Null +* Pi | @Pi +* True | @True +* False | @False +* Minumum | @Min @( %Expression1 @, %Expression2 @) +* Maximum | @Max @( %Expression1 @, %Expression2 @) +* +* +* Member | %Expression @{.} %Identifier +* Index | %Expression @[ %IndexExpressions @] +* Call | %Expression @( %Parameters @) +* +* +* Negate | @- %Expression +* Posate | @+ %Expression +* Bitwise complement | @{~~} %Expression +* Boolean not | @Not %Expression +* Absolute value | @Abs %Expression +* Sign | @Sgn %Expression +* Value byte size | @SizeOf %Expression +* Variable address | @Varptr %Variable +* Convert type expression | %Type %Expression +* +* +* Power | %Expression @^ %Expression +* +* +* Multiply | %Expression @* %Expression +* Divide | %Expression @/ %Expression +* Remainder | %Expression @Mod %Expression +* Bitwise shift left | %Expression @Shl %Expression +* Bitwise shift right | %Expression @Shr %Expression +* Arithmetic shift right | %Expression @Sar %Expression +* +* +* Add | %Expression @+ %Expression +* Subtract | %Expression @- %Expression +* +* +* Bitwise and | %Expression @& %Expression +* Bitwise or | %Expression @| Expression +* Bitwise exclusive or | %Expression @{~~} %Expression +* +* +* Equal | %Expression @= %Expression +* Not equal | %Expression @{~<~>} %Expression +* Less than | %Expression @{~<} %Expression +* Greater than | %Expression @{~>} %Expression +* Less than or equal | %Expression @{~<=} %Expression +* Greater than or equal | %Expression @{~>=} %Expression +* +* +* Conditional and | %Expression @And %Expression +* Conditional or | %Expression @Or %Expression +] + +In addition, the following built in functions are also supported: +[ @Function | @Syntax +* Character code | @Asc @( %Expression @) +* Character | @Chr @( %Expression @) +* Value length | @Len @( %Expression @) +] + +#Null returns 0, an empty string, an empty array, the null object or a pointer to 0 depending on context. + +#True and #False are integer constants with the values 1 and 0, respectively. + +The index operator can be used on either arrays or strings. If used on an array, the element at the specified index is returned. If used on a string, the character code of the character at the specified index is returned. + +The #Not operator 'inverts' the logic of a boolean expression. If the expression evaluates to true, #Not returns false and vice versa. + +#Asc returns the character value of the first character of a string, or -1 if the length of the string is 0. + +#Chr constructs a 1 character string with the specified character value. + +#Len can be used with either a string or array. When used with a string, #Len returns the number of characters in the string. When used with an array, #Len returns the number of elements in the array. In the case of multidimensional arrays, #Len returns the total number of elements. + ++Boolean expressions + +It is frequently necessary to consider an expression as 'true' or 'false', for example, for use with an #If statement. + +The rules for determining whether an expression is true or false are: + +[ @{Expression Type} | @{Truth condition} +* Numeric | True if value is not equal to 0 +* Object | True if object is not equal to #Null +* String | True if length is not equal to 0 +* Array | True if length is not equal to 0 +] diff --git a/docs/src/Language/Functions.bbdoc b/docs/src/Language/Functions.bbdoc new file mode 100644 index 0000000..46d07eb --- /dev/null +++ b/docs/src/Language/Functions.bbdoc @@ -0,0 +1,38 @@ + ++Functions + +A function is a self contained block of code that can be called from multiple points in your program. + +Functions are declared using the syntax: +{ +@Function %Identifier @: %ReturnType @( %Parameters @)\ + %{Function statements...}\ +@{End Function} +} + +If %ReturnType is omitted, the function defaults to returning an #Int. + +%Parameters is a comma separated list of parameters for the function. The syntax of each parameter is similar to a variable declaration: %Identifier @: %Type. Function parameters may be used inside a function in the same way as local variables. + +The #Return statement is used to return a value from a function. + +Here is an example of a simple function that adds 2 integers and returns their sum: +{{ +Function AddInts:Int( x:Int,y:Int ) + Return x+y +End Function +}} +This function can then be called by other code: +{{ +Print AddInts( 10,20 ) 'prints 30! +}} +Function parameters can be assigned constant 'default values' using syntax similar to initializing a variable: %Identifier @: %Type @= %ConstantExpression. + +Default parameters can then be optionally omitted when the function is called: +{{ +Function IncInt:Int( n:Int,p:Int=1 ) + Return n+p +End Function +Print IncInt( 1 ) 'Prints 2 +Print IncInt( 1,3 ) 'Prints 4 +}} diff --git a/docs/src/Language/Identifiers.bbdoc b/docs/src/Language/Identifiers.bbdoc new file mode 100644 index 0000000..c354d69 --- /dev/null +++ b/docs/src/Language/Identifiers.bbdoc @@ -0,0 +1,40 @@ + ++Identifiers + +Identifiers are used to name constants, variables, functions and user defined types. + +Identifiers start with a letter or underscore and can be followed by any combination of letters, digits or underscores. For example, the following are all valid identifiers: +{{ +player1_up +your_name +_hello_world_ +}} +Identifiers in BlitzMax are case-insensitive. This means that the identifiers @hello, @Hello and @HELLO are all treated as the same identifier. + +The following identifiers are reserved for use by the BlitzMax language, and can not be used as general purpose identifiers: +{{ +Strict Module ModuleInfo Framework +End Return Continue Exit Assert +Public Private +True False Pi Null Self Super +Byte Short Int Long Float Double Object String +Var Ptr VarPtr Chr Len Asc SizeOf Sgn Abs Min Max Mod +Shl Shr Sar Not And Or +New Release Delete +Incbin IncbinPtr IncbinLen +Include Import Extern EndExtern +Function EndFunction +Type EndType Extends +Method EndMethod +Local Global Const Field +Abstract Final +Rem EndRem +If Then Else ElseIf EndIf +For To Next Step EachIn +While Wend +Repeat Until Forever +Select Case Default EndSelect +Try Catch EndTry Throw +Goto DefData ReadData RestoreData +Alias +}} diff --git a/docs/src/Language/Literals.bbdoc b/docs/src/Language/Literals.bbdoc new file mode 100644 index 0000000..12446bc --- /dev/null +++ b/docs/src/Language/Literals.bbdoc @@ -0,0 +1,54 @@ + ++Literals + +Literals are simple numeric or string values. + ++Integer literals + +Integer literals may be in either decimal, hexadecimal or binary format. To specify a hexadecimal literal, prepend it with the @$ character. To specify a binary literal, prepend it with the @{~%} character. Here are some examples of integer literals: +{{ +100 'decimal literal +$CAFEBABE 'hexadecimal (base 16) literal +%10101010 'binary (base 2) literal +}} + ++Floating point literals + +Floating point literals are numeric values with a fractional part. The fractional part is specified using a decimal point. Floating point literals may also be extended using 'e notation'. For example: +{{ +.5 'one half +10.0 'ten point zero +1e6 '1 times (10 to the power of 6) +1.5e-6 '1.5 times (10 to the power of -6) +}} + ++String literals + +A string literal is a sequence of characters enclosed in quotation marks. For example: +{{ +"Hello World" +"" 'empty string +}} + +String literals can also contain %{escape sequences}. An escape sequence is a special sequence of characters used to represent another character. This is useful for including 'untypable' characters and quotation marks in strings. Escape sequences always start with the @{~~} character. The following escape sequences are supported: + +[ @{Escape sequence} | @{Equivalent character} +* ~~0 | Null character (ascii code 0) +* ~~t | Tab character (ascii code 9) +* ~~r | Return character (ascii code 13) +* ~~n | Newline character (ascii code 10) +* ~~q | Quote character (ascii code 34) +* ~~ | Tilde character (ascii code 126) +] + +For example: +{{ +Print "And then Mark said, ~qescape sequences rule!~q" +Print "Line1~nLine2~nLine3~nLine4~nLine5" +}} + +The type of a literal may also be modified by appending @:%TypeName to the literal. For example: +{{ +$8000000000000000:Long +10:Double +}} diff --git a/docs/src/Language/Modules.bbdoc b/docs/src/Language/Modules.bbdoc new file mode 100644 index 0000000..f489b3e --- /dev/null +++ b/docs/src/Language/Modules.bbdoc @@ -0,0 +1,55 @@ + ++Modules + +A module is a precompiled collection of constants, globals, functions and user defined types, that may be used by applications or other modules. + ++Creating modules + +Modules live in the 'mod' directory within the main BlitzMax directory. To create your own module, you must add a new subdirectory to 'mod' with the following format: +{{ +/mod/modscope.mod/modname.mod +}} +Modscope should be a unique name (for example, the name of your organization or company) and is used to group together modules provided by a common source. Both modscope and modname should be valid identifiers. Also, to prevent issues with case sensitive filesystems such as Linux's, it is recommended that modscope and modname be lowercase. + +You will also need to create a main module source file inside the module directory. This file must have the same name as ModuleName: +{{ +/mod/modscope.mod/modname.mod/modname.bmx +}} +Finally, your source file must include a #Module statement at the top: +{{ +Module modscope.modname +}} +Once your module is setup, #BMK can be used to build it: +{{ +bmk makemods modscope.modname +}} +Or, to build all modules in the same scope: +{{ +bmk makemods modscope +}} + ++Using modules within modules + +To use a module within another module, you simply import it with the @Import command: +{{ +Import modscope.modname +}} +This will import both the specified module %and any modules imported by that module. In other words, @Import is recursive. + ++Using modules within applications + +By default, BlitzMax imports %every module it finds in the 'brl' and 'pub' module scopes when compiling applications. However, this can result in bulky executables. You can override this default behaviour by using the @Framework command: +{ +@Framework %modscope.modname +} +@Framework should appear at the top of your main application source file. + +Specifying an application framework prevents BlitzMax from importing every module under the sun. Only the framework module and any explicitly imported modules are imported into your application. + +For example, to create a 'stripped down' BASIC application, you can use the BRL.Basic framework: +{{ +Framework BRL.Basic 'create a stripped down app + +Print "Hello World!" +}} +When a building a multifile application, the framework (if any) found in the main source file is automatically passed to all 'child' files in the application. However, if you change this 'default' framework, you will need to 'rebuild all' for the change to affect other files. diff --git a/docs/src/Language/Objects.bbdoc b/docs/src/Language/Objects.bbdoc new file mode 100644 index 0000000..d1cab58 --- /dev/null +++ b/docs/src/Language/Objects.bbdoc @@ -0,0 +1,35 @@ + ++Objects + +Strings, arrays and instances of user defined types are all different kinds of %objects. + +Objects are handled %{by reference}. This means that the actual memory used by an object to store its data is shared between all the variables that refer to that object. + +This makes objects very efficient to deal with, as assigning an object to a variable simply involves assigning a reference to the object - not an entire object. Passing objects to functions and returning objects from functions is also very efficient as again only references need to be copied. + +BlitzMax uses a technique known as %{reference counting} to keep track of objects that are in use by your program. + +The basic idea behind reference counting is that each object includes a counter reflecting the number of variables referencing that object. When an object's counter reaches 0, the object is no longer in use and its memory can be returned to the system. + +The process of returning unused objects to the system is called 'garbage collection' and, by default, is performed automatically. However, it may be desirable to 'force' a garbage collection (for example, to check for memory leaks) and this can be done using the #GCCollect command. + +Objects can also have %methods - function-like operations associated with the object. All objects, including strings and arrays, provide at least the following methods: + +[ @Method | @Description +* ToString:String() | Convert object to a string representation. +* Compare:Int( withObject:Object ) | Returns a value less than 0 if an object is less than another object, a value greater than 0 if an object is greater than another object or the value 0 if an object equals another object. +* SendMessage:Object( message:Object,context:Object ) | Used to send a generic message to an object. +] + +The default implementation of the @ToString method converts the address of the object to hexadecimal and returns this value as a string. String objects override this behaviour to the return the object itself. + +The default implementation of the @Compare method subtracts object addresses. String objects override this behaviour to return the result of a character-by-character comparison. + +The @SendMessage method provides a simple, generic messaging system available to all objects. The default implementation of @SendMessage simply returns null. + +Note that the built-in equals and not equals operators do not actually use the compare method (with one exception). Instead, these operators compare memory addresses, allowing you to determine if 2 object references actually refer to the same object. The exception to this rule is when comparisons are performed on strings, in which case a character-by-character comparison is performed instead. + +To access an object's methods, use the member access operator. For example: +{{ +Print "Hello".Compare( "Goodbye" ) +}} diff --git a/docs/src/Language/Program flow.bbdoc b/docs/src/Language/Program flow.bbdoc new file mode 100644 index 0000000..2e95124 --- /dev/null +++ b/docs/src/Language/Program flow.bbdoc @@ -0,0 +1,118 @@ + ++Program flow + +This section covers command that affect the flow of program execution. + ++While/Wend loops + +A While/Wend loop continues executing while an expression evaluates to true: +{ +@While %Expression\ + %Statements\ +@Wend +} + ++Repeat/Until loops + +A Repeat/Until loop continues executing until an expression evaluates to true: +{ +@Repeat\ + %Statements\ +@Until %Expression +} +The statements within a Repeat/Until loop will always execute at least once, since the terminating expression is only evaluated at the bottom of the loop. + ++Repeat/Forever loops + +A Repeat/Forever loop will simply continue executing forever: +{ +@Repeat\ + %Statements\ +@Forever +} + ++For/To/Next loops + +A For/To/Next loop will continue executing until the value of a numeric index variable goes beyond an exit value. The index variable is automatically updated every loop iteration by adding a step value. Note that the exit value is inclusive - the loop will typically execute once with the index variable equal to the exit value before terminating: +{ +@For %IndexVariable @{=} %FirstValue @To %LastValue @Step %StepValue\ + %Statements\ +@Next +} +The 'Step' part is optional, in which case the index variable will step in increments of 1. The step value must also be constant. + +The exit value is only evaluated once at the start of the loop. This means it is safe to use complex or 'slow' code as an exit value. + +You may also declare a new local variable to be used as the index variable, by preceding the index variable with the #Local keyword. Such local variables will not be visible outside of the loop when it terminates. + ++For/Until/Next loops + +A For/Until/Next loop operates in a similar manner to a For/To/Next loop, except that the loop will terminate when the index variables becomes equal to the last value - in other words, the exit value is exclusive. This can be useful when you need to count 'up to' a value, without actually including that value: +{ +@For %IndexVariable @{=} %FirstValue @Until %LastValue @Step %StepValue\ + %statements\ +@Next +} +The 'Step' part is optional, in which case the index variable will step in increments of 1. The step value must also be constant. + +The exit value is only evaluated once at the start of the loop. This means it is safe to use complex or 'slow' code as an exit value. + +You may also declare a new local variable to be used as the index variable, by preceding the index variable with the #Local keyword. Such local variables will not be visible outside of the loop when it terminates. + ++Exit and Continue + +The @Exit command can be used to exit from a @While, @Repeat or @For loop. The loop will be terminated, and program flow will be transferred to the first command after the loop. + +The @Continue command can be used to force a @While, @Repeat or @For loop to resume execution from the 'top' of the loop, skipping any statements remaining in the loop. + +Both @Exit and @Continue may be followed by an optional identifier. This identifer must match a previously declared %{loop label}, which allows you to exit or continue a specific loop, not necessarily the 'nearest' loop. + +To declare a loop label, use the syntax ~#Identifier immediately preceding a @While, @Repeat or @For loop. For example, this program will exit both loops when k and j both equal 5: +{{ +Strict +Local k,j +#Label1 'loop label +For k=1 To 4 + #Label2 'another loop label (unused in this example) + For j=1 To 4 + Print k+","+j + If k=3 And j=3 Exit Label1 + Next +Next +}} +Note that loop labels are only available in strict mode. In non-strict mode, use Goto instead. + ++If/Then blocks + +BlitzMax provides both the classic BASIC 'one liner' style of If/Then statement... +{ +@If %Expression @Then %Statements @Else %Statements +} +...and the more modern block equivalent... +{ +@If %Expression\ + %Statements\ +@{Else If} %Expression\ + %Statements\ +@Else\ + %Statements\ +@EndIf +} +In both forms, the @Then keyword is optional. + ++Select/Case blocks + +A Select/Case block allows you to simplify complex conditional tests. The select expression is compared with each of the case expressions and, if found to be equal, the program code within the appropriate case block is executed. If no matching case is found, the program code within the optional default block is executed: +{ +@Select %Expression\ +@Case %Expressions\ + %Statements\ +@Default\ + %Statements\ +@{End Select} +} +The @Default section is optional. + +The selected value is only evaluated once, before each case is checked. + +Multiple expressions for each case may be used by providing a comma separated sequence of expressions. diff --git a/docs/src/Language/Projects.bbdoc b/docs/src/Language/Projects.bbdoc new file mode 100644 index 0000000..9a775cf --- /dev/null +++ b/docs/src/Language/Projects.bbdoc @@ -0,0 +1,49 @@ + ++Project management + ++Importing source files + +The #Import statement provides an efficient way to split your project up into multiple files. The syntax for import is: +{ +@Import %Filename +} +%Filename must be a quote enclosed string literal with a recognized source file extension such as 'bmx'. + +Importing a file makes all the globals, consts, functions and user defined types declared in that file available to the file being currently compiled. + +Imported files can be %precompiled. This means that if you have a project split into multiple source files, only the files that are actually modified (and files those modifications affect) need to be recompiled. For example, say you have a project split into 2 source files: +{{ +'file1.bmx +Import "file2.bmx" +Print Test() + +'file2.bmx +Function Test:String() + Return "This is a test!" +End Function +}} +If file2.bmx is then modified, both files need to be recompiled because not only has file2.bmx changed, but its changes may also affect file1.bmx. + +However, if only file1.bmx is modified there is no need to recompile file2.bmx. BlitzMax's #BMK utility takes care of all this for you. + +One important limitation of @Import is that you cannot create 'cycles' of imports. + ++Including source files + +@Include is another way to split a project up into multiple files. The syntax for @Include is the same as that for @Import, however the included file is simply inserted 'verbatim' into the including file, instead of being separately compiled. + +Depending on the platform and project, @Include may be faster than @Import. It also allows you to get around the 'no cycles' restriction of @Import. + ++Including binary files + +The @Incbin statement allows you to include binary files with your programs. The syntax for @Incbin is the same as that for @Import, however any kind of file may be specified, not just 'bmx' files. + +You can access the binary data contained in an incbined file using @IncbinPtr (which returns a Byte Ptr) and @IncbinLen (which returns an Int). Both @IncbinPtr and @IncbinLen require a filename parameter. For example: +{{ +Incbin "data.bin" +Local p:Byte Ptr=IncbinPtr( "data.bin" ) +Local n:Int=IncbinLen( "data.bin" ) +For Local i=0 Until n + Print "Byte "+i+":"+p[i] +Next +}} diff --git a/docs/src/Language/Slices.bbdoc b/docs/src/Language/Slices.bbdoc new file mode 100644 index 0000000..49a4380 --- /dev/null +++ b/docs/src/Language/Slices.bbdoc @@ -0,0 +1,22 @@ + ++Slices + +Slices are sequences of characters or elements within a string or array. + +You can extract slices using the general syntax: +{ +%StringOrArray @[ %StartIndex @{..} %EndIndex @] +} +The length of the returned slice is always ( %EndIndex - %StartIndex ) elements long, even if %StartIndex is less than 0 or %EndIndex is greater than the length of the string or array. 'Missing' elements are initialized to null in the case of arrays, or the space character in the case of strings. + +Either index may be omitted. If %StartIndex is omitted, it defaults to 0. If %EndIndex is omitted, it defaults to the length of the string or array. + +This flexibility allows you to use slices to resize or copy arrays. For example: +{{ +Local a[200] 'initialize a[] to 200 elements +a=a[50..150] 'extract middle 100 elements of a[] +a=a[..50] 'extract first 50 elements of a[] +a=a[25..] 'extract elements starting from index 25 of a[] +a=a[..] 'copy all elements of a[] +a=a[..200] 'resize a[] to 200 elements +}} diff --git a/docs/src/Language/Strings.bbdoc b/docs/src/Language/Strings.bbdoc new file mode 100644 index 0000000..faa04bd --- /dev/null +++ b/docs/src/Language/Strings.bbdoc @@ -0,0 +1,81 @@ + ++Strings + +Strings are used to store sequences of characters. + +Strings are actually objects, so can be used where ever an object is expected. Strings provide the following methods: + +[ @Method | @Description + +* Find:Int( subString:String,startIndex=0 ) | Finds first occurance of a sub string. Returns -1 if @subString not found. + +* FindLast:Int( subString:String,startIndex=0 ) | Finds last occurance of a sub string. Returns -1 if @subString not found. + +* Trim:String() | Removes leading and trailing non-printable characters from a string. + +* Replace:String( subString:String,withString:String ) | Replaces all occurances of @subString with @withString. + +* StartsWith:Int( subString:String ) | Returns true if string starts with @subString. + +* EndsWith:Int( subString:String ) | Returns true if string ends with @subString. + +* Contains:Int( subString:String ) | Returns true if string contains @subString. + +* Join:String( bits:String[] ) | Joins @bits together by inserting this string between each bit. + +* Split:String[]( separator$[] ) | Splits this string into bits delimited by @separator. + +* ToLower:String() | Converts string to lowercase. + +* ToUpper:String() | Converts string to uppercase. + +* ToInt:Int() | Converts string to an integer. + +* ToLong:Long() | Converts string to a long. + +* ToFloat:Float() | Converts string to a float. + +* ToDouble:Double() | Converts string to a double. + +* ToCString:Byte Ptr() | Converts string to a null terminated sequence of 8 bit bytes. The returned memory must eventually be freed with a call to #MemFree. + +* ToWString:Short Ptr() | Converts string to a null terminated sequence of 16 bit shorts. The returned memory must eventually be freed with a call to #MemFree. +] + +Strings also provide a read-only @length field. + +Here is an example of using string methods: +{{ +Local t:String="***** HELLO *****" + +Print t.length 'return length of string: 17 +Print t.Find( "HE" ) 'returns index of substring "HE": 6 +Print t.Replace( "*","!" ) 'replaces all "*" with "!" +Print t.ToLower() 'coverts string to lowercase +Print ":".Join( ["Hello","World"] ) 'returns "Hello:World" +}} +String also provide the following functions to help with the creation of strings: + +[ @Function | @Description + +* FromInt:String( value:Int ) | Creates a string from an integer. + +* FromLong:String( value:Long ) | Creates a string from a long. + +* FromFloat:String( value:Float ) | Creates a string from a float. + +* FromDouble:String( value:Double) | Creates a string from a double. + +* FromCString:String( cString:Byte Ptr ) | Creates a string from a null terminated sequence of 8 bit bytes. + +* FromWString:String( wString:Short Ptr ) | Creates a string from a null terminated sequence of 16 bit shorts. + +* FromBytes:String( bytes:Byte Ptr,length ) | Creates a string from a sequence of @length 8 bit bytes. + +* FromShorts:String( shorts:Short Ptr,length ) | Creates a string from a sequence of @length 16 bit shorts. +] + +To call a string function, use: @String.}%Function - for example: +{{ +Print String.FromInt( 10 ) +}} diff --git a/docs/src/Language/User defined types.bbdoc b/docs/src/Language/User defined types.bbdoc new file mode 100644 index 0000000..ef6b809 --- /dev/null +++ b/docs/src/Language/User defined types.bbdoc @@ -0,0 +1,158 @@ + ++User defined types + ++defined types allow you to group related data and program code together into a single entity known as an %object. + +The general syntax for declaring a user defined type is: +{ +@Type %Typename @Extends %Typename +} +@Typename must be a valid identifier. + +The @Extends part is optional. If omitted, the user defined type extends the built in @Object type. + +Once declared, you can create %instances of such types using the @New operator. + +Within a user defined type, you can declare the following: + +[ Fields: +Fields are variables associated with each instance of a user defined type. Fields are declared in the same way as local or global variables, only using the @Field keyword. To access the fields of an object, use the @{.} operator. +* Methods: +Methods are function-like operations associated with each instance of a user defined type. Methods are declared in the same way as functions, only using the @Method keyword. To access the methods of an object, use the @{.} operator. Program code within a method can access other fields, methods, functions, consts and globals within the same object simply by referring to them by name. +* Functions: +These are declared in the same way as 'normal' functions, and can be accessed using the @{.} operator. Unlike methods, functions within a type are %not associated with instances of the type, but with the type itself. This means such functions can be used regardless of whether or not any instances of the type have been created yet. Functions within a type can access other functions, consts or globals within the same type by referring to them by name. +* Consts and Globals +These are declared in the same way as 'normal' consts and globals, and be accessed using the @{.} operator. As with type functions, these are not associated with instances of the type, but with the type itself. +] +Here is an example of a user defined type: +{{ +Type MyType + Const INC=1 + Global Counter + Field x,y,z + + Method Sum() + Counter=Counter+INC + Return x+y+z + End Method + + Function Create:MyType() + Return New MyType + End Function +End Type + +Local MyObject:MyType=MyType.Create() + +MyObject.x=10 +MyObject.y=20 +MyObject.z=30 + +Print MyObject.Sum() +Print MyType.Counter +}} +Note that the object is created indirectly by calling MyType's @Create function instead of @New. This is a frequently used technique that allows you to perform (possibly complex) initialization of an object before it is returned to the user. + ++Inheritance and polymorphism + +User defined types can %extend other user defined types using the @Extends keyword. Extending a type means adding more functionality to an existing type. The type being extended is often referred to as the %base type, while the resulting, extended type is often referred to as the %derived type: +{{ +Type BaseType + Field x,y,z + + Method Sum() + Return x+y+z + End Method +End Type + +Type DerivedType Extends BaseType + Field p,q,r + + Method Sum() + Return x+y+z+p+q+r + End Method +End Type +}} +This technique is also known as %inheritance, as the derived type is inheriting functionality from the base type (although no one had to die in the process!). Note that DerivedType actually has 6 fields - x,y,z,p,q and r. It inherits x,y,z from BaseType and adds its own fields p,q,r. + +BlitzMax allows you to use a derived type object anywhere a base type object is expected. This works because a derived type object %is a base type object - only with some 'extras'. For example, you can assign a derived type object to a base type variable, or pass a derived type object to a function expecting a base type parameter. This is really the whole point of inheritance - its not just a technique to save typing. + +This behaviour allows for a very useful technique known as %polymorphism. This means the ability of an object to behave in different ways depending on its type. This is achieved in Blitzmax by %overriding methods. + +Notice in the above example that the method 'Sum' has the same signature (parameters and return type) in both the base type and the derived type. This is not just a coincidence - it is required by the language. Whenever you add a method to a derived type with the same name as an existing method in a base type, it must have the same signature as the method in the base type. + +But now we have 2 versions of 'Sum' - which gets called? This depends on the %{runtime type} of an object. For example: +{{ +Type BaseType + Method Test:String() + Return "BaseType.Test" + End Method +End Type + +Type DerivedType Extends BaseType + Method Test:String() + Return "DerivedType.Test" + End Method +End Type + +Local x:BaseType=New BaseType +Local y:BaseType=New DerivedType + +Print x.Test() 'prints "BaseType.Test" - x's runtime type is BaseType +Print y.Test() 'prints "DerivedType.Test" - as y's runtime type is DerivedType +}} +Note that when the variable y is initialized, it is assigned a DerivedType object, even though y is a BaseType varible. This is legal because derived types can be used in place of base types. However, this means the runtime type of y is actually DerivedType. Therefore, when y.Test() is called, the DerivedType method Test() is called. + ++Self and Super +Program code inside a method can access two special variables named @Self and @Super. + +@Self refers to the object associated with the method, and its type is that of the user defined type the method is declared in. + +@Super also refers to the object associated with the method, however its type is that of the user defined type being extended. This can be very useful if you need to call the base type version of the currently executing method: +{{ +Type BaseType + Method Test() + Print "BaseType.Test" + End Method +End Type + +Type DerivedType Extends BaseType + Method Test() + Super.Test 'calls BaseType's Test() method first! + Print "DerivedType.Test" + End Method +End Type + +Local x:BaseType=New DerivedType + +x.Test +}} + ++New and Delete + +User defined types can optionally declare two special methods named @New and @Delete. Both methods must take no arguments, and any returned value is ignored. + +The @New method is called when an object is first created with the @New operator. This allows you to perform extra initialization code. + +The @Delete method is called when an object is discarded by the memory manager. Note that critical shutdown operations such as closing files etc should not be placed in the @Delete, as you can't always be sure when @Delete will be called. + ++Abstract and Final + +User defined types and methods can also be declared %abstract or %final by adding @Abstract or @Final to the appropriate declaration: +{{ +Type AbstractType Abstract + Method AbstractMethod() Abstract +End Type + +Type FinalType Final + Method FinalMethod() Final + Print "FinalType.FinalMethod" + End Method +End Type +}} +Declaring a user defined type abstract means that you can not create instances of it using @New. However, it is still possible to extend such types and create instances of these derived types. Declaring a method abstract means that the method has no implementation and must be implemented by a derived type. Any user defined type with at least one abstract method is itself abstract. + +Declaring a user defined type final means that it can not be extended. Declaring a method final means that derived types can not override the method. All methods of a final user defined type are themselves final. + +Abstract types and methods are mostly used to create 'template' types and methods that leave implementation details up to derived types. + +Final types and methods are mostly used to prevent modification to a type's behaviour. diff --git a/docs/src/Language/Variables.bbdoc b/docs/src/Language/Variables.bbdoc new file mode 100644 index 0000000..7f7f4ce --- /dev/null +++ b/docs/src/Language/Variables.bbdoc @@ -0,0 +1,72 @@ + ++Variables + +Variables are used to store values that change during the execution of your program. + +Variables should be declared in your program before use. Declaring a variable means defining a name and type for the variable and, optionally, an initial value. + +The general syntax for declaring a variable is: +{ +%Declaration @Identifier @: %Type @= %Expression +} +Multiple variables may be declared in one statement using the comma separator. + +If the type of a variable is omitted, the variable defaults to being of type @Int. If the initial value expression is omitted, the variable is assigned an initial value of @Null. + +There are 3 kinds of variable, each of which differs by how and where the variable is stored: + ++Local Variables + +Local variables are used to store temporary values that will eventually be discarded. Local variables are associated with the block of code they are declared in, and are only visible to code within that block. A block of code is represented by one of the following: +[ The body of a function or loop +* The body of an if/then/else statement +* The body of a case or default statement +] + +To declare a local variable, use a @Local declaration: +{{ +Local int_var +Local string_var:String="Str",float_var:Float=10.5 +}} + ++Global Variables + +Global variables are variables that exist for the entire lifetime of a program. + +To declare a global variable, use a @Global declaration: +{{ +Global int_var +Global string_var:String="Str",float_var:Float=10.5 +}} + ++Field Variables + +Field variables are declared within user-defined types using a @Field declaration: +{{ +Field int_var +Field string_var:String="Str",float_var:Float=10.5 +}} + +See the user-defined types section for more on field variables. + ++Assigning variables + +Once declared, a variable's value may be changed using an assignment statement: +{ +%Variable @= %Expression +} +You can also perform 'modifying' assignments, which are shorthand for %Variable @= %Variable %Operator %Expression. The syntax for modifying assignments is: +[ @Syntax | @Operator +* :+ | Addition +* :- | Subtraction +* :* | Multiplication +* :/ | Division +* :Mod | Remainder +* :& | Bitwise and +* :~| | Bitwise or +* :~~ | Bitwise exclusive or +* :Shl | Bitwise shift left +* :Shr | Bitwise shift right +* :Sar | Arithmetic shift right +] +For example, the code %{my_var:+1} can be used in place of %{my_var=my_var+1}. diff --git a/docs/src/Language/index.bbdoc b/docs/src/Language/index.bbdoc new file mode 100644 index 0000000..bb09992 --- /dev/null +++ b/docs/src/Language/index.bbdoc @@ -0,0 +1,10 @@ + ++BlitzMax language reference + +Welcome to the BlitzMax language reference. + +This document describes the core BlitzMax programming language. + +For users who already have BASIC programming experience, the #{BASIC compatibility} section highlights the major differences between BlitzMax and other BASIC dialects. + +For general command reference, please see the #modules documentation. diff --git a/docs/src/Licenses/bssc.bbdoc b/docs/src/Licenses/bssc.bbdoc new file mode 100644 index 0000000..9435cb2 --- /dev/null +++ b/docs/src/Licenses/bssc.bbdoc @@ -0,0 +1,35 @@ + + + +
+
+Blitz Shared Source Code License
+--------------------------------
+
+This source code is the property of Blitz Research Ltd.
+
+This software is provided 'as-is', without any express 
+or implied warranty. In no event will the authors be held 
+liable for any damages arising from the use of this 
+software.
+
+You may distribute executable applications built from 
+this source code under your own licensing terms. You may
+not distribute static or dynamic library files based in
+whole or in part on this source code.
+
+You may modify this source code for your own purposes and
+can choose to publish such modifications to the BlitzMax
+Community page at http://www.blitzbasic.com. You
+may not publish this source code or any modified 
+version of it elsewhere.
+
+By publishing modifications to http://www.blitzbasic.com, you 
+agree that other members of the Blitz community are free to
+use those modifications in their own projects, and that 
+Blitz Research Ltd are free to include your modifications
+in future source code releases.
+
+
+ + diff --git a/docs/src/Licenses/ftl.bbdoc b/docs/src/Licenses/ftl.bbdoc new file mode 100644 index 0000000..a2e1947 --- /dev/null +++ b/docs/src/Licenses/ftl.bbdoc @@ -0,0 +1,171 @@ + + +
+
+                    The FreeType Project LICENSE
+                    ----------------------------
+
+                            2000-Feb-08
+
+                       Copyright 1996-2000 by
+          David Turner, Robert Wilhelm, and Werner Lemberg
+
+
+
+Introduction
+============
+
+  The FreeType  Project is distributed in  several archive packages;
+  some of them may contain, in addition to the FreeType font engine,
+  various tools and  contributions which rely on, or  relate to, the
+  FreeType Project.
+
+  This  license applies  to all  files found  in such  packages, and
+  which do not  fall under their own explicit  license.  The license
+  affects  thus  the  FreeType   font  engine,  the  test  programs,
+  documentation and makefiles, at the very least.
+
+  This  license   was  inspired  by  the  BSD,   Artistic,  and  IJG
+  (Independent JPEG  Group) licenses, which  all encourage inclusion
+  and  use of  free  software in  commercial  and freeware  products
+  alike.  As a consequence, its main points are that:
+
+    o We don't promise that this software works. However, we will be
+      interested in any kind of bug reports. (`as is' distribution)
+
+    o You can  use this software for whatever you  want, in parts or
+      full form, without having to pay us. (`royalty-free' usage)
+
+    o You may not pretend that  you wrote this software.  If you use
+      it, or  only parts of it,  in a program,  you must acknowledge
+      somewhere  in  your  documentation  that  you  have  used  the
+      FreeType code. (`credits')
+
+  We  specifically  permit  and  encourage  the  inclusion  of  this
+  software, with  or without modifications,  in commercial products.
+  We  disclaim  all warranties  covering  The  FreeType Project  and
+  assume no liability related to The FreeType Project.
+
+
+Legal Terms
+===========
+
+0. Definitions
+--------------
+
+  Throughout this license,  the terms `package', `FreeType Project',
+  and  `FreeType  archive' refer  to  the  set  of files  originally
+  distributed  by the  authors  (David Turner,  Robert Wilhelm,  and
+  Werner Lemberg) as the `FreeType Project', be they named as alpha,
+  beta or final release.
+
+  `You' refers to  the licensee, or person using  the project, where
+  `using' is a generic term including compiling the project's source
+  code as  well as linking it  to form a  `program' or `executable'.
+  This  program is  referred to  as  `a program  using the  FreeType
+  engine'.
+
+  This  license applies  to all  files distributed  in  the original
+  FreeType  Project,   including  all  source   code,  binaries  and
+  documentation,  unless  otherwise  stated   in  the  file  in  its
+  original, unmodified form as  distributed in the original archive.
+  If you are  unsure whether or not a particular  file is covered by
+  this license, you must contact us to verify this.
+
+  The FreeType  Project is copyright (C) 1996-2000  by David Turner,
+  Robert Wilhelm, and Werner Lemberg.  All rights reserved except as
+  specified below.
+
+1. No Warranty
+--------------
+
+  THE FREETYPE PROJECT  IS PROVIDED `AS IS' WITHOUT  WARRANTY OF ANY
+  KIND, EITHER  EXPRESS OR IMPLIED,  INCLUDING, BUT NOT  LIMITED TO,
+  WARRANTIES  OF  MERCHANTABILITY   AND  FITNESS  FOR  A  PARTICULAR
+  PURPOSE.  IN NO EVENT WILL ANY OF THE AUTHORS OR COPYRIGHT HOLDERS
+  BE LIABLE  FOR ANY DAMAGES CAUSED  BY THE USE OR  THE INABILITY TO
+  USE, OF THE FREETYPE PROJECT.
+
+2. Redistribution
+-----------------
+
+  This  license  grants  a  worldwide, royalty-free,  perpetual  and
+  irrevocable right  and license to use,  execute, perform, compile,
+  display,  copy,   create  derivative  works   of,  distribute  and
+  sublicense the  FreeType Project (in  both source and  object code
+  forms)  and  derivative works  thereof  for  any  purpose; and  to
+  authorize others  to exercise  some or all  of the  rights granted
+  herein, subject to the following conditions:
+
+    o Redistribution  of source code  must retain this  license file
+      (`LICENSE.TXT') unaltered; any additions, deletions or changes
+      to   the  original   files  must   be  clearly   indicated  in
+      accompanying  documentation.   The  copyright notices  of  the
+      unaltered, original  files must be preserved in  all copies of
+      source files.
+
+    o Redistribution in binary form must provide a  disclaimer  that
+      states  that  the software is based in part of the work of the
+      FreeType Team,  in  the  distribution  documentation.  We also
+      encourage you to put an URL to the FreeType web page  in  your
+      documentation, though this isn't mandatory.
+
+  These conditions  apply to any  software derived from or  based on
+  the FreeType Project,  not just the unmodified files.   If you use
+  our work, you  must acknowledge us.  However, no  fee need be paid
+  to us.
+
+3. Advertising
+--------------
+
+  Neither the  FreeType authors and  contributors nor you  shall use
+  the name of the  other for commercial, advertising, or promotional
+  purposes without specific prior written permission.
+
+  We suggest,  but do not require, that  you use one or  more of the
+  following phrases to refer  to this software in your documentation
+  or advertising  materials: `FreeType Project',  `FreeType Engine',
+  `FreeType library', or `FreeType Distribution'.
+
+  As  you have  not signed  this license,  you are  not  required to
+  accept  it.   However,  as  the FreeType  Project  is  copyrighted
+  material, only  this license, or  another one contracted  with the
+  authors, grants you  the right to use, distribute,  and modify it.
+  Therefore,  by  using,  distributing,  or modifying  the  FreeType
+  Project, you indicate that you understand and accept all the terms
+  of this license.
+
+4. Contacts
+-----------
+
+  There are two mailing lists related to FreeType:
+
+    o freetype@freetype.org
+
+      Discusses general use and applications of FreeType, as well as
+      future and  wanted additions to the  library and distribution.
+      If  you are looking  for support,  start in  this list  if you
+      haven't found anything to help you in the documentation.
+
+    o devel@freetype.org
+
+      Discusses bugs,  as well  as engine internals,  design issues,
+      specific licenses, porting, etc.
+
+    o http://www.freetype.org
+
+      Holds the current  FreeType web page, which will  allow you to
+      download  our  latest  development  version  and  read  online
+      documentation.
+
+  You can also contact us individually at:
+
+    David Turner      
+    Robert Wilhelm    
+    Werner Lemberg    
+
+
+--- end of LICENSE.TXT ---
+
+ + \ No newline at end of file diff --git a/docs/src/Licenses/glx.bbdoc b/docs/src/Licenses/glx.bbdoc new file mode 100644 index 0000000..df91bcd --- /dev/null +++ b/docs/src/Licenses/glx.bbdoc @@ -0,0 +1,206 @@ +GLX PUBLIC LICENSE (Version 1.0 (2/11/99)) ("License") + +Subject to any third party claims, Silicon Graphics, Inc. ("SGI") hereby +grants permission to Recipient (defined below), under Recipient's +copyrights in the Original Software (defined below), to use, copy, +modify, merge, publish, distribute, sublicense and/or sell copies of +Subject Software (defined below), and to permit persons to whom the +Subject Software is furnished in accordance with this License to do the +same, subject to all of the following terms and conditions, which +Recipient accepts by engaging in any such use, copying, modifying, +merging, publishing, distributing, sublicensing or selling: + +1. Definitions. + + (a) "Original Software" means source code of computer software code + which is described in Exhibit A as Original Software. + + (b) "Modifications" means any addition to or deletion from the + substance or structure of either the Original Software or any + previous Modifications. When Subject Software is released as a + series of files, a Modification means (i) any addition to or + deletion from the contents of a file containing Original Software or + previous Modifications and (ii) any new file that contains any part + of the Original Code or previous Modifications. + + (c) "Subject Software" means the Original Software or Modifications + or the combination of the Original Software and Modifications, or + portions of any of the foregoing. + + (d) "Recipient" means an individual or a legal entity exercising + rights under, and complying with all of the terms of, this License. + For legal entities, "Recipient" includes any entity which controls, + is controlled by, or is under common control with Recipient. For + purposes of this definition, "control" of an entity means (a) the + power, direct or indirect, to direct or manage such entity, or (b) + ownership of fifty percent (50%) or more of the outstanding shares + or beneficial ownership of such entity. + +2. Redistribution of Source Code Subject to These Terms. Redistributions +of Subject Software in source code form must retain the notice set forth +in Exhibit A, below, in every file. A copy of this License must be +included in any documentation for such Subject Software where the +recipients' rights relating to Subject Software are described. Recipient +may distribute the source code version of Subject Software under a +license of Recipient's choice, which may contain terms different from +this License, provided that (i) Recipient is in compliance with the +terms of this License, and (ii) the license terms include this Section 2 +and Sections 3, 4, 7, 8, 10, 12 and 13 of this License, which terms may +not be modified or superseded by any other terms of such license. If +Recipient distributes the source code version under a different license +Recipient must make it absolutely clear that any terms which differ from +this License are offered by Recipient alone, not by SGI. Recipient +hereby agrees to indemnify SGI for any liability incurred by SGI as a +result of any such terms Recipient offers. + +3. Redistribution in Executable Form. The notice set forth in Exhibit A +must be conspicuously included in any notice in an executable version of +Subject Software, related documentation or collateral in which Recipient +describes the user's rights relating to the Subject Software. Recipient +may distribute the executable version of Subject Software under a +license of Recipient's choice, which may contain terms different from +this License, provided that (i) Recipient is in compliance with the +terms of this License, and (ii) the license terms include this Section 3 +and Sections 4, 7, 8, 10, 12 and 13 of this License, which terms may not +be modified or superseded by any other terms of such license. If +Recipient distributes the executable version under a different license +Recipient must make it absolutely clear that any terms which differ from +this License are offered by Recipient alone, not by SGI. Recipient +hereby agrees to indemnify SGI for any liability incurred by SGI as a +result of any such terms Recipient offers. + +4. Termination. This License and the rights granted hereunder will +terminate automatically if Recipient fails to comply with terms herein +and fails to cure such breach within 30 days of the breach. Any +sublicense to the Subject Software which is properly granted shall +survive any termination of this License absent termination by the terms +of such sublicense. Provisions which, by their nature, must remain in +effect beyond the termination of this License shall survive. + +5. No Trademark Rights. This License does not grant any rights to use +any trade name, trademark or service mark whatsoever. No trade name, +trademark or service mark of SGI may be used to endorse or promote +products derived from the Subject Software without prior written +permission of SGI. + +6. No Other Rights. This License does not grant any rights with respect +to the OpenGL API or to any software or hardware implementation thereof +or to any other software whatsoever, nor shall any other rights or +licenses not expressly granted hereunder arise by implication, estoppel +or otherwise with respect to the Subject Software. Title to and +ownership of the Original Software at all times remains with SGI. All +rights in the Original Software not expressly granted under this License +are reserved. + +7. Compliance with Laws; Non-Infringement. Recipient shall comply with +all applicable laws and regulations in connection with use and +distribution of the Subject Software, including but not limited to, all +export and import control laws and regulations of the U.S. government +and other countries. Recipient may not distribute Subject Software that +(i) in any way infringes (directly or contributorily) the rights +(including patent, copyright, trade secret, trademark or other +intellectual property rights of any kind) of any other person or entity +or (ii) breaches any representation or warranty, express, implied or +statutory, which under any applicable law it might be deemed to have +been distributed. + +8. Claims of Infringement. If Recipient at any time has knowledge of any +one or more third party claims that reproduction, modification, use, +distribution, import or sale of Subject Software (including particular +functionality or code incorporated in Subject Software) infringes the +third party's intellectual property rights, Recipient must place in a +well-identified web page bearing the title "LEGAL" a description of each +such claim and a description of the party making each such claim in +sufficient detail that a user of the Subject Software will know whom to +contact regarding the claim. Also, upon gaining such knowledge of any +such claim, Recipient must conspicuously include the URL for such web +page in the Exhibit A notice required under Sections 2 and 3, above, and +in the text of any related documentation, license agreement or +collateral in which Recipient describes end user's rights relating to +the Subject Software. If Recipient obtains such knowledge after it makes +Subject Software available to any other person or entity, Recipient +shall take other steps (such as notifying appropriate mailing lists or +newsgroups) reasonably calculated to inform those who received the +Subject Software that new knowledge has been obtained. + +9. DISCLAIMER OF WARRANTY. SUBJECT SOFTWARE IS PROVIDED ON AN "AS IS" +BASIS, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, +INCLUDING, WITHOUT LIMITATION, WARRANTIES THAT THE SUBJECT SOFTWARE IS +FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON- +INFRINGING. SGI ASSUMES NO RISK AS TO THE QUALITY AND PERFORMANCE OF THE +SOFTWARE. SHOULD ANY SOFTWARE PROVE DEFECTIVE IN ANY RESPECT, SGI +ASSUMES NO COST OR LIABILITY FOR ANY SERVICING, REPAIR OR CORRECTION. +THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS +LICENSE. NO USE OF ANY SUBJECT SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT +UNDER THIS DISCLAIMER. + +10. LIMITATION OF LIABILITY. UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL +THEORY, WHETHER TORT (INCLUDING, WITHOUT LIMITATION, NEGLIGENCE OR +STRICT LIABILITY), CONTRACT, OR OTHERWISE, SHALL SGI OR ANY SGI LICENSOR +BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR +CONSEQUENTIAL DAMAGES OF ANY CHARACTER INCLUDING, WITHOUT LIMITATION, +DAMAGES FOR LOSS OF GOODWILL, WORK STOPPAGE, LOSS OF DATA, COMPUTER +FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR +LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN INFORMED OF THE POSSIBILITY +OF SUCH DAMAGES. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO +LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM SGI's NEGLIGENCE +TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME +JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR +CONSEQUENTIAL DAMAGES, SO THAT EXCLUSION AND LIMITATION MAY NOT APPLY TO +RECIPIENT. + +11. Indemnity. Recipient shall be solely responsible for damages +arising, directly or indirectly, out of its utilization of rights under +this License. Recipient will defend, indemnify and hold harmless Silicon +Graphics, Inc. from and against any loss, liability, damages, costs or +expenses (including the payment of reasonable attorneys fees) arising +out of Recipient's use, modification, reproduction and distribution of +the Subject Software or out of any representation or warranty made by +Recipient. + +12. U.S. Government End Users. The Subject Software is a "commercial +item" consisting of "commercial computer software" as such terms are +defined in title 48 of the Code of Federal Regulations and all U.S. +Government End Users acquire only the rights set forth in this License +and are subject to the terms of this License. + +13. Miscellaneous. This License represents the complete agreement +concerning subject matter hereof. If any provision of this License is +held to be unenforceable, such provision shall be reformed so as to +achieve as nearly as possible the same economic effect as the original +provision and the remainder of this License will remain in effect. This +License shall be governed by and construed in accordance with the laws +of the United States and the State of California as applied to +agreements entered into and to be performed entirely within California +between California residents. Any litigation relating to this License +shall be subject to the exclusive jurisdiction of the Federal Courts of +the Northern District of California (or, absent subject matter +jurisdiction in such courts, the courts of the State of California), +with venue lying exclusively in Santa Clara County, California, with the +losing party responsible for costs, including without limitation, court +costs and reasonable attorneys fees and expenses. The application of the +United Nations Convention on Contracts for the International Sale of +Goods is expressly excluded. Any law or regulation which provides that +the language of a contract shall be construed against the drafter shall +not apply to this License. + +Exhibit A + +The contents of this file are subject to Sections 2, 3, 4, 7, 8, 10, 12 +and 13 of the GLX Public License Version 1.0 (the "License"). You may +not use this file except in compliance with those sections of the +License. You may obtain a copy of the License at Silicon Graphics, Inc., +attn: Legal Services, 2011 N. Shoreline Blvd., Mountain View, CA 94043 +or at http://www.sgi.com/software/opensource/glx/license.html. + +Software distributed under the License is distributed on an "AS IS" +basis. ALL WARRANTIES ARE DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY +IMPLIED WARRANTIES OF MERCHANTABILITY, OF FITNESS FOR A PARTICULAR +PURPOSE OR OF NON- INFRINGEMENT. See the License for the specific +language governing rights and limitations under the License. + +The Original Software is GLX version 1.2 source code, released February, +1999. The developer of the Original Software is Silicon Graphics, Inc. +Those portions of the Subject Software created by Silicon Graphics, Inc. +are Copyright (c) 1991-9 Silicon Graphics, Inc. All Rights Reserved. + diff --git a/docs/src/Licenses/oggvorbis.bbdoc b/docs/src/Licenses/oggvorbis.bbdoc new file mode 100644 index 0000000..f2c77cd --- /dev/null +++ b/docs/src/Licenses/oggvorbis.bbdoc @@ -0,0 +1,61 @@ + + + + + Sample Xiph.Org Variant of the BSD License + + + +

+ Please note that this is only a sample license; + authoritative license terms are included with each + software bundle. +

+
+

© year, Xiph.Org Foundation

+

+ Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: +

+
    +
  • + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +
  • + +
  • + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +
  • + +
  • + Neither the name of the Xiph.org Foundation nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. +
  • +
+ +

+This software is provided by the copyright holders and contributors +“as is” and any express or implied warranties, including, but not +limited to, the implied warranties of merchantability and fitness for +a particular purpose are disclaimed. In no event shall the foundation +or contributors be liable for any direct, indirect, incidental, +special, exemplary, or consequential damages (including, but not +limited to, procurement of substitute goods or services; loss of use, +data, or profits; or business interruption) however caused and on any +theory of liability, whether in contract, strict liability, or tort +(including negligence or otherwise) arising in any way out of the use +of this software, even if advised of the possibility of such damage. +

+
+ + + diff --git a/docs/src/Licenses/sgi.bbdoc b/docs/src/Licenses/sgi.bbdoc new file mode 100644 index 0000000..7c27328 --- /dev/null +++ b/docs/src/Licenses/sgi.bbdoc @@ -0,0 +1,42 @@ +SGI FREE SOFTWARE LICENSE B (Version 1.1 [02/22/2000]) +1. Definitions. +1.1. "Additional Notice Provisions" means such additional provisions as appear in the Notice in Original Code under the heading "Additional Notice Provisions." +1.2. "Covered Code" means the Original Code or Modifications, or any combination thereof. +1.3. "Hardware" means any physical device that accepts input, processes input, stores the results of processing, and/or provides output. +1.4. "Larger Work" means a work that combines Covered Code or portions thereof with code not governed by the terms of this License. +1.5. "Licensable" means having the right to grant, to the maximum extent possible, whether at the time of the initial grant or subsequently acquired, any and all of the rights conveyed herein. +1.6. "License" means this document. +1.7. "Licensed Patents" means patent claims Licensable by SGI that are infringed by the use or sale of Original Code or any Modifications provided by SGI, or any combination thereof. +1.8. "Modifications" means any addition to or deletion from the substance or structure of the Original Code or any previous Modifications. When Covered Code is released as a series of files, a Modification is: +A. Any addition to the contents of a file containing Original Code and/or addition to or deletion from the contents of a file containing previous Modifications. +B. Any new file that contains any part of the Original Code or previous Modifications. +1.9. "Notice" means any notice in Original Code or Covered Code, as required by and in compliance with this License. +1.10. "Original Code" means source code of computer software code that is described in the source code Notice required by Exhibit A as Original Code, and updates and error corrections specifically thereto. +1.11. "Recipient" means an individual or a legal entity exercising rights under, and complying with all of the terms of, this License or a future version of this License issued under Section 8. For legal entities, "Recipient" includes any entity that controls, is controlled by, or is under common control with Recipient. For purposes of this definition, "control" of an entity means (a) the power, direct or indirect, to direct or manage such entity, or (b) ownership of fifty percent (50%) or more of the outstanding shares or beneficial ownership of such entity. +1.12. "Recipient Patents" means patent claims Licensable by a Recipient that are infringed by the use or sale of Original Code or any Modifications provided by SGI, or any combination thereof. +1.13. "SGI" means Silicon Graphics, Inc. +1.14. "SGI Patents" means patent claims Licensable by SGI other than the Licensed Patents. +2. License Grant and Restrictions. +2.1. SGI License Grant. Subject to the terms of this License and any third party intellectual property claims, for the duration of intellectual property protections inherent in the Original Code, SGI hereby grants Recipient a worldwide, royalty-free, non-exclusive license, to do the following: (i) under copyrights Licensable by SGI, to reproduce, distribute, create derivative works from, and, to the extent applicable, display and perform the Original Code and/or any Modifications provided by SGI alone and/or as part of a Larger Work; and (ii) under any Licensable Patents, to make, have made, use, sell, offer for sale, import and/or otherwise transfer the Original Code and/or any Modifications provided by SGI. Recipient accepts the terms and conditions of this License by undertaking any of the aforementioned actions. The patent license shall apply to the Covered Code if, at the time any related Modification is added, such addition of the Modification causes such combination to be covered by the Licensed Patents. The patent license in Section 2.1(ii) shall not apply to any other combinations that include the Modification. No patent license is provided under SGI Patents for infringements of SGI Patents by Modifications not provided by SGI or combinations of Original Code and Modifications not provided by SGI. +2.2. Recipient License Grant. Subject to the terms of this License and any third party intellectual property claims, Recipient hereby grants SGI and any other Recipients a worldwide, royalty-free, non-exclusive license, under any Recipient Patents, to make, have made, use, sell, offer for sale, import and/or otherwise transfer the Original Code and/or any Modifications provided by SGI. +2.3. No License For Hardware Implementations. The licenses granted in Section 2.1 and 2.2 are not applicable to implementation in Hardware of the algorithms embodied in the Original Code or any Modifications provided by SGI . +3. Redistributions. +3.1. Retention of Notice/Copy of License. The Notice set forth in Exhibit A, below, must be conspicuously retained or included in any and all redistributions of Covered Code. For distributions of the Covered Code in source code form, the Notice must appear in every file that can include a text comments field; in executable form, the Notice and a copy of this License must appear in related documentation or collateral where the Recipient's rights relating to Covered Code are described. Any Additional Notice Provisions which actually appears in the Original Code must also be retained or included in any and all redistributions of Covered Code. +3.2. Alternative License. Provided that Recipient is in compliance with the terms of this License, Recipient may, so long as without derogation of any of SGI's rights in and to the Original Code, distribute the source code and/or executable version(s) of Covered Code under (1) this License; (2) a license identical to this License but for only such changes as are necessary in order to clarify Recipient's role as licensor of Modifications; and/or (3) a license of Recipient's choosing, containing terms different from this License, provided that the license terms include this Section 3 and Sections 4, 6, 7, 10, 12, and 13, which terms may not be modified or superseded by any other terms of such license. If Recipient elects to use any license other than this License, Recipient must make it absolutely clear that any of its terms which differ from this License are offered by Recipient alone, and not by SGI. It is emphasized that this License is a limited license, and, regardless of the license form employed by Recipient in accordance with this Section 3.2, Recipient may relicense only such rights, in Original Code and Modifications by SGI, as it has actually been granted by SGI in this License. +3.3. Indemnity. Recipient hereby agrees to indemnify SGI for any liability incurred by SGI as a result of any such alternative license terms Recipient offers. +4. Termination. This License and the rights granted hereunder will terminate automatically if Recipient breaches any term herein and fails to cure such breach within 30 days thereof. Any sublicense to the Covered Code that is properly granted shall survive any termination of this License, absent termination by the terms of such sublicense. Provisions that, by their nature, must remain in effect beyond the termination of this License, shall survive. +5. No Trademark Or Other Rights. This License does not grant any rights to: (i) any software apart from the Covered Code, nor shall any other rights or licenses not expressly granted hereunder arise by implication, estoppel or otherwise with respect to the Covered Code; (ii) any trade name, trademark or service mark whatsoever, including without limitation any related right for purposes of endorsement or promotion of products derived from the Covered Code, without prior written permission of SGI; or (iii) any title to or ownership of the Original Code, which shall at all times remains with SGI. All rights in the Original Code not expressly granted under this License are reserved. +6. Compliance with Laws; Non-Infringement. There are various worldwide laws, regulations, and executive orders applicable to dispositions of Covered Code, including without limitation export, re-export, and import control laws, regulations, and executive orders, of the U.S. government and other countries, and Recipient is reminded it is obliged to obey such laws, regulations, and executive orders. Recipient may not distribute Covered Code that (i) in any way infringes (directly or contributorily) any intellectual property rights of any kind of any other person or entity or (ii) breaches any representation or warranty, express, implied or statutory, to which, under any applicable law, it might be deemed to have been subject. +7. Claims of Infringement. If Recipient learns of any third party claim that any disposition of Covered Code and/or functionality wholly or partially infringes the third party's intellectual property rights, Recipient will promptly notify SGI of such claim. +8. Versions of the License. SGI may publish revised and/or new versions of the License from time to time, each with a distinguishing version number. Once Covered Code has been published under a particular version of the License, Recipient may, for the duration of the license, continue to use it under the terms of that version, or choose to use such Covered Code under the terms of any subsequent version published by SGI. Subject to the provisions of Sections 3 and 4 of this License, only SGI may modify the terms applicable to Covered Code created under this License. +9. DISCLAIMER OF WARRANTY. COVERED CODE IS PROVIDED "AS IS." ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS ARE DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. SGI ASSUMES NO RISK AS TO THE QUALITY AND PERFORMANCE OF THE SOFTWARE. SHOULD THE SOFTWARE PROVE DEFECTIVE IN ANY RESPECT, SGI ASSUMES NO COST OR LIABILITY FOR SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY IS AN ESSENTIAL PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT SUBJECT TO THIS DISCLAIMER. +10. LIMITATION OF LIABILITY. UNDER NO CIRCUMSTANCES NOR LEGAL THEORY, WHETHER TORT (INCLUDING, WITHOUT LIMITATION, NEGLIGENCE OR STRICT LIABILITY), CONTRACT, OR OTHERWISE, SHALL SGI OR ANY SGI LICENSOR BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, WORK STOPPAGE, LOSS OF DATA, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM SGI's NEGLIGENCE TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO THAT EXCLUSION AND LIMITATION MAY NOT APPLY TO RECIPIENT. +11. Indemnity. Recipient shall be solely responsible for damages arising, directly or indirectly, out of its utilization of rights under this License. Recipient will defend, indemnify and hold harmless Silicon Graphics, Inc. from and against any loss, liability, damages, costs or expenses (including the payment of reasonable attorneys fees) arising out of Recipient's use, modification, reproduction and distribution of the Covered Code or out of any representation or warranty made by Recipient. +12. U.S. Government End Users. The Covered Code is a "commercial item" consisting of "commercial computer software" as such terms are defined in title 48 of the Code of Federal Regulations and all U.S. Government End Users acquire only the rights set forth in this License and are subject to the terms of this License. +13. Miscellaneous. This License represents the complete agreement concerning the its subject matter. If any provision of this License is held to be unenforceable, such provision shall be reformed so as to achieve as nearly as possible the same legal and economic effect as the original provision and the remainder of this License will remain in effect. This License shall be governed by and construed in accordance with the laws of the United States and the State of California as applied to agreements entered into and to be performed entirely within California between California residents. Any litigation relating to this License shall be subject to the exclusive jurisdiction of the Federal Courts of the Northern District of California (or, absent subject matter jurisdiction in such courts, the courts of the State of California), with venue lying exclusively in Santa Clara County, California, with the losing party responsible for costs, including without limitation, court costs and reasonable attorneys fees and expenses. The application of the United Nations Convention on Contracts for the International Sale of Goods is expressly excluded. Any law or regulation that provides that the language of a contract shall be construed against the drafter shall not apply to this License. +Exhibit A +License Applicability. Except to the extent portions of this file are made subject to an alternative license as permitted in the SGI Free Software License B, Version 1.1 (the "License"), the contents of this file are subject only to the provisions of the License. You may not use this file except in compliance with the License. You may obtain a copy of the License at Silicon Graphics, Inc., attn: Legal Services, 1600 Amphitheatre Parkway, Mountain View, CA 94043-1351, or at: +http://oss.sgi.com/projects/FreeB +Note that, as provided in the License, the Software is distributed on an "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. +Original Code. The Original Code is: [name of software, version number, and release date], developed by Silicon Graphics, Inc. The Original Code is Copyright (c) [dates of first publication, as appearing in the Notice in the Original Code] Silicon Graphics, Inc. Copyright in any portions created by third parties is as indicated elsewhere herein. All Rights Reserved. +Additional Notice Provisions: [such additional provisions, if any, as appear in the Notice in the Original Code under the heading "Additional Notice Provisions"] diff --git a/docs/src/Licenses/zlibpng.bbdoc b/docs/src/Licenses/zlibpng.bbdoc new file mode 100644 index 0000000..3f1c26d --- /dev/null +++ b/docs/src/Licenses/zlibpng.bbdoc @@ -0,0 +1,35 @@ + + + +

The zlib/libpng License

+ + + +

Copyright (c) <year> <copyright holders>

+ +

This software is provided 'as-is', without any express or implied + warranty. In no event will the authors be held liable for any damages + arising from the use of this software.

+ +

Permission is granted to anyone to use this software for any purpose, + including commercial applications, and to alter it and redistribute it + freely, subject to the following restrictions:

+ +
+ +

1. The origin of this software must not be misrepresented; you must not + claim that you wrote the original software. If you use this software + in a product, an acknowledgment in the product documentation would be + appreciated but is not required.

+ +

2. Altered source versions must be plainly marked as such, and must not be + misrepresented as being the original software.

+ +

3. This notice may not be removed or altered from any source + distribution.

+ +
+ +
+ + \ No newline at end of file diff --git a/docs/src/Tutorials/BlitzMax overview.bbdoc b/docs/src/Tutorials/BlitzMax overview.bbdoc new file mode 100644 index 0000000..9109e85 --- /dev/null +++ b/docs/src/Tutorials/BlitzMax overview.bbdoc @@ -0,0 +1,422 @@ + + + + + + + +

BlitzMax tutorials and articles

+ + + +
+ +
+

BlitzMax Memory management - or, "where did Delete go?!?"

+ +As many users from a Blitz3D or BlitzPlus background have noticed, BlitzMax does not include a 'Delete' command.
+
+This appears to have caused a great deal of bemusement and head scratching in the Blitz community, which this tutorial will attempt to clear up.
+
+Note that any references to Blitz3D in the rest of this document also apply to BlitzPlus.
+
+

The BASICs

+ +First up, let's have a look at what Blitz3D's Delete command actually does. It really serves 2 purposes: +
    +
  1. The object is removed from its 'type list'. +
  2. The memory used by the object is returned to the system - this is called 'deallocating' the object. +
+Step 1 is necessary due to Blitz3D's type list system, which automatically adds all New-ed objects to an internal global type list.
+
+Step 2 is necessary to prevent memory leaks. A memory leak is when your program has allocated a chunk of memory, used it for something, and then forgotten to deallocate it when it is no longer useful. Since computers have a finite amount of memory, this will eventually cause problems if it happens often enough!
+
+The first thing about these 2 steps to note is that the global type list system is no longer present in BlitzMax, so step 1 is now completely up to the user - if you have added an object to a linked list (or lists), it is up to you to remove it.
+
+If all you are wanting to achieve is a system similar to Blitz3D's type list system, then this is as simple as using ListAddLast immediately after you have created an object using New, and using ListRemove immediately before deleting it using Delete - oops, there is no Delete! Ok, using ListRemove *instead* of Delete!
+
+This still leaves the question of deallocating the object's memory, and this is done in BlitzMax using a 'garbage collector'. A garbage collector +automatically scans for 'dead objects' every now and then and releases the memory they occupied.
+
+Note that the issue of deallocating objects is completely separate from the issue of type lists. Yes, if you forget to remove an object from a list it will remain 'live', but this is the same as forgetting to delete an object in Blitz3D!
+
+One final complicating issue: BlitzMax includes a feature that allows you to assign objects to integers. This feature exists mainly to simplify things for beginners so, instead of... +
+Local image:TImage=LoadImage( "somepic.png" ) 'normal object to object assignment...
+
+...you can just go... +
+Local image=LoadImage( "somepic.png" ) 'assigning an object to an int! What gives?
+
+However, if you are using this feature in your programs, you *must* later 'free' the object yourself using Release... +
+Release image
+
+You can therefore think of Release as being similar to Blitz3D's FreeImage (or FreeSound, FreeThis, FreeThat etc).
+
+All-in-all, it's probably best to avoid object-to-int assignments altogther if you are concerned about memory leaks.
+
+And that's it! Well, not quite, but the above should be enough information for you to be able to write leak-free programs with. I'll go into some of the nitty gritty details below...
+
+

The nitty gritty part 1 : dead objects

+ +Ok, lets have a look at the question of 'what exactly is a dead object'? Well, a dead object is an object that is no longer referred to by any live objects. In other words, dead objects are objects your program can no longer 'see' - they are therefore completely useless to your program and can be safely deallocated.
+
+Here are a few examples of when objects become 'dead':
+
+'example 1
+Local p:MyType=New MyType 'allocate object 1
+p=Null 'object 1 is now dead
+
+'example 2
+Local p:MyType=New MyType 'allocate object 1
+Local q:MyType=New MyType 'allocate object 2
+p=q 'object 1 is now dead, object 2 is still alive
+
+'example 3
+Local p:MyType[1] 'allocate object 1 (an array object)
+p[0]=New MyType 'allocate object 2
+p=Null 'object 1 and object 2 both now dead
+
+'example 4
+Local p:MyType=New MyType 'allocate object 1
+p.my_type=New MyType 'allocate object 2
+p.my_type=New MyType 'allocate object 3 - object 2 now dead
+Local q:MyType=p.my_type
+p=Null 'object 1 and object 2 dead, object 3 still alive thanks to the q assignment above
+
+After seeing this sort of thing, there is a tendancy for people to stick '=Null' code all over the place in an attempt to 'force' objects to become dead - but this is generally not necessary.
+
+Sooner or later, all variables will either be overwritten by new values, or (in the case of Locals and Fields) simply go out of scope. Both of these actions are enough to ensure that dead objects will be correctly detected and deallocated.
+
+Probably the only good reason to use '=Null' is in the case of global variables, when you know that a global variable will not be modified for a long time, but it also happens to be keeping a large chunk of memory alive that is no longer useful to your program. In this case, an '=Null' is probably the right choice.
+
+BlitzMax also provides the GCMemAlloced() function to determine the amount of memory currently used by your program.
+
+
+
+ +
+

Crash course in OO programming for Blitz coders

+ +Welcome to a crash course in OO programming for Blitz coders!
+
+OO stands for 'Object Oriented'. OO is a programming paradigm or 'way of thinking' that has taken on almost mythical proportions over the years yet, somewhat unusually for the world of computing, is actually quite useful!
+
+*Disclaimer* - OO coding means different things to different people. This article is strongly swayed by my own experience with OO coding and what I like and find useful about it. The actual 'meaning' of OO is almost as fun to argue about as whether the universe is infinite or not.
+
+First up, OO coding has spawned a bunch of initially confusing but actually quite sensible buzzwords, including such gems as:
+
+Inheritance
+Polymorphism
+Virtual
+Abstract
+Concrete
+Type
+Class
+Object
+Instance
+Base Class
+Derived Class
+Super Class
+Sub Class
+
+Scary stuff!
+
+Well, not really. Never forget that behind the scenes its all just a bunch of bits and bytes and Ifs and Adds and Gotos.
+
+As always, its easier than the guys who get paid megabucks to do it would have us think.
+
+

Part 1 : Inheritance

+ +Inheritance is a way of 'composing' objects from other objects.
+
+This is already possible in procedural Blitz. Consider the following code... +
+Type Part1
+Field x,y,z
+End Type
+
+Type Part2
+Field p1.Part1
+Field p,q,r
+End Type
+
+Function UpdatePart1( t:Part1 )
+'Do something clever with a Part1.
+End Function
+
+This is one way of composing objects. Part2 'contains' a Part1, via the p1 field.
+
+If you've got a Part2 object and want to call UpdatePart1(), you can grab the p1 field and use it in the function call, for example: +
+Local t:Part2=New Part2
+t.p1=New Part1 'need to create it!
+UpdatePart1 t.p1
+
+OO inheritance provides a different (not always better!) way to do this: +
+Type Base
+Field x,y,z
+End Type
+
+Type Derived Extends Base
+Field p,q,r
+End Type
+
+Function UpdateBase( t:Base )
+'Do something clever with a Base object.
+End Function
+
+Ok, we've already hit our first OO buzzwords - Base and Derived. These are not special keywords, they are just names I chose for these types. Bear with me and hopefully you'll get some idea of why I chose them.
+
+First up, The Base type is just the same as the procedural Part1 type - no problem there.
+
+The Derived type, however, introduces us to the Extends keyword, which is used to indicate inheritance.
+
+Extends always appears after 'Type whatever', and means that the type you are describing extends a different, existing type. So the type you are describing is composed not only of the fields and stuff you declare, but also the fields and stuff of the type you are extending!
+
+This means that the Derived type above actually has the additional fields x,y,z - these have been 'inherited' from the Base type. It is then perfectly legal for you to code up something like: +
+Local t:Derived=New Derived
+
+t.x=100 'x inherited from Base - thanks Base, you rock!
+
+Another way to think of it is the Derived type 'is a' Base type, but with some extra stuff. In fact, in OO terminology 'IsA' is often used to indicate inheritance or inheritance-like properties.
+
+Now it gets a bit interesting. Since our Derived type 'is a' Base type, its perfectly legal to use it where ever a Base type is expected - for example, the UpdateBase() function: +
+Local MyDerived:Derived=New Derived 'fine...
+UpdateBase MyDerived 'What?!?
+
+Initially, this looks *wrong* - 'Type mismatch error' looms! But in OO code its fine. Since Derived extends Base, its OK to use a Derived where ever a Base is expected - even in assignments: +
+Local MyBase:Base=New Derived 'Okay, because Derived extends (or 'Is a') Base.
+
+In addition, there could be many types extending Base, and each of these could be used interchangeably with Base.
+
+Hopefully the terms 'Base' and 'Derived' now mean something. The Derived type is derived from, or 'comes from', the Base type.
+
+Remember that Base and Derived are just names I chose for this example. In real world coding, you'd use useful names, for example: +
+Type Actor
+Field x,y,z
+End Type
+
+Type Player Extends Actor
+Field lives,score
+End Type
+
+But still, you can think of Actor as the base type, and Player as the derived type - a Player is derived from an Actor.
+
+Its also perfectly legal (and very useful!) to extend extended types, for example: +
+Type Actor
+Field x,y,z
+End Type
+
+Type Player Extends Actor
+Field lives,score
+End Type
+
+Type Enemy Extends Actor
+Field mood
+End Type
+
+Type Troll Extends Enemy
+Field grudge_quotient
+End Type
+
+Type Ghoul Extends Enemy
+Field lust_for_life
+End Type
+
+So, if you've got a function like UpdateActor( t:Actor ), you can pass it any of the above types as they are all ultimately derived from Actor.
+
+Similarly, a RethinkMood( t:Enemy ) function could be used with any of the bad guys (Enemy, Troll or Ghoul) - but not with players, as Player is not derived from Enemy.
+
+This is what is known as a 'class hierarchy' - a 'tree' of types.
+
+Stay tuned for part 2...! +
+
+
+ +
+ +

The Nehe OpenGL tutorials

+The NeHe tutorials are a popular collection of OpenGL programming tutorials.
+
+Here are the first 5 NeHe tutorials converted to BlitzMax: + +For more information on these tutorials and to learn lots about OpenGL, check out the Nehe website at +http://nehe.gamedev.net. + +
+
+
+ +
+ +

Writing custom stream handlers

+ +BlitzMax's OO design allows you to add your own kinds of streams to the system.
+
+In this tutorial we will concentrate on creating a custom stream that simply converts any text written to or read from the stream to uppercase. Not very useful, but a good starting point for your own experiments!
+
+The source code for this tutorial can be found here.
+
+To create a custom stream, you will need to create a new user type that extends the TStream type. Your type will also need to implement at least the following methods: +
+Type TMyStream extends TStream
+	Method Eof()
+		'code to return end-of-file status here...
+	End Method
+
+	Method Pos()
+		'code to return current stream position here...
+	End Method
+
+	Method Size()
+		'code to return size of stream here...
+	End Method
+
+	Method Seek( pos )
+		'code to seek to a position in a stream here...
+	End Method
+
+	Method Flush()
+		'code to flush stream output here...
+	End Method
+
+	Method Close()
+		'code to close stream here...
+	End Method
+
+	Method Read( buf:Byte Ptr,count )
+		'code to read from stream here...
+	End Method
+
+	Method Write( buf:Byte Ptr,count )
+		'code to write to a stream here...
+	End Method
+End Type
+
+Whew, that's a fair bit of work! Fortunately, BlitzMax can simplify things a bit for us in this case.
+
+Many types of stream really just modify the behaviour of an existing stream. For example, the BlitzMax endian stream works by modifying the behaviour of an existing stream - in a sense, it 'wraps' an existing stream. Our goal of creating an 'uppercase' stream also applies here.
+
+BlitzMax provides the TStreamWrapper type for exactly this situtation. TStreamWrapper extends TStream, but also maintains an internal 'underlying' stream. Whenever you call a method of TStreamWrapper, it will simply 'forward' the method call to the underlying stream.
+
+This is ideal for situations where you only want to modify the behaviour of a few of the stream methods. In our case, we want to modify the Read and Write methods to convert text to uppercase - and here's how it's done: +
+Type TUpperStream Extends TStreamWrapper
+
+	Method Read( buf:Byte Ptr,count )
+		'Read data from the underlying stream
+		count=Super.Read( buf,count )
+		'Convert the data to uppercase
+		For Local i=0 Until count
+			If buf[i]>=Asc("a") And Buf[i]<=Asc("z")
+				buf[i]=buf[i]-Asc("a")+Asc("A")
+			EndIf
+		Next
+		'Done!
+		Return count
+	End Method
+
+	Method Write( buf:Byte Ptr,count )
+		'Copy the data to a new buffer, converting to uppercase as we go
+		Local tmp:Byte[count]
+		For Local i=0 Until count
+			If buf[i]>=Asc("a") And buf[i]<=Asc("z")
+				tmp[i]=buf[i]-Asc("a")+Asc("A")
+			Else
+				tmp[i]=buf[i]
+			EndIf
+		Next
+		'Write the data to the underlying stream
+		Return Super.Write( tmp,count )
+	End Method
+
+	Function Create:TUpperStream( stream:TStream )
+		Local t:TUpperStream=New TUpperStream
+		'SetStream is a TStreamWrapper method that sets the underlying stream.
+		t.SetStream stream
+		Return t
+	End Function
+
+End Type
+
+One important note: The Read method modifies the data 'in place'. However, the Write method makes a copy of the data. This is because, although we know it's safe to modify the read buffer - in fact, it will already be modified by the time we get to it - we can't be sure it's safe to modify the write buffer. The caller of 'Write' may well be expecting the contents of the buffer to remain unchanged.
+
+Now let's see it in action: +
+'Create a tmp file and write some text to it.
+Local tmp:TStream=WriteStream( "tmp" )
+tmp.WriteLine "A little example..."
+tmp.WriteLine "of our cool TUpperStream!"
+tmp.Close
+
+'Open tmp file again, and wrap it with a TUpperStream
+tmp:TStream=ReadStream( "tmp" ) 
+Local upperizer:TUpperStream=TUpperStream.Create( tmp )
+
+'Dump file contents
+While Not upperizer.Eof()
+	Print upperizer.ReadLine()
+Wend
+
+'Close files
+upperizer.Close
+tmp.Close
+
+This demo creates a text file and reads it back through a TUpperStream, which converts the file contents to uppercase while it's being read. If you inspect the tmp file, it's still actually in mixed case - but it's just as easy to write through the TUpperCase stream and end up with an uppercase file.
+
+Finally, the icing on the cake: adding our TUpperStream to the system so that it can be used transparently: +
+Type TUpperStreamFactory Extends TStreamFactory
+
+	Method CreateStream:TUpperStream( url:Object,proto$,path$,readable,writeable )
+		If proto$<>"uppercase" Return
+		Local stream:TStream=OpenStream( path,readable,writeable )
+		If stream Return TUpperStream.Create( stream )
+	End Method
+	
+End Type
+
+New TUpperStreamFactory
+
+And a demo... +
+'Open a TUpperStream tmp file using WriteStream
+Local tmp2:TStream=WriteStream( "uppercase::tmp" )
+tmp2.WriteLine "Another little example..."
+tmp2.WriteLine "of our even cooler TUpperStream!"
+tmp2.Close
+
+'Read back and dump tmp file
+tmp2:TStream=ReadStream( "tmp" )
+While Not tmp2.Eof()
+	Print tmp2.ReadLine()
+Wend
+tmp2.Close
+
+
+ + + \ No newline at end of file diff --git a/docs/src/Tutorials/MaxGUI overview.bbdoc b/docs/src/Tutorials/MaxGUI overview.bbdoc new file mode 100644 index 0000000..07afb36 --- /dev/null +++ b/docs/src/Tutorials/MaxGUI overview.bbdoc @@ -0,0 +1,546 @@ + + + + + + +

MaxGUI Overview

+ + + +
+ +

Introduction

+ +The MaxGui module provides commands to build user interfaces +for applications programmed in BlitzMax. +

+The command set originates from the original BlitzPlus "Gadget" +based names providing a healthy amount of backward +compatability for users wishing to port code developed in +BlitzPlus. + + +

Getting Started

+ + +The following program opens a small window on the desktop +that ends when the window is closed. +

+The code beginning at "While True" is the main event loop +of the program, it repeats forever waiting for an Event +to happen, printing the event's details to the output window +and ending if the event has the ID of EVENT_WINDOWCLOSE. +

+' createwindow.bmx
+
+Strict 
+
+Import MaxGUI.Drivers
+
+Local window:TGadget
+
+window=CreateWindow("My Window",40,40,320,240)
+
+While True
+	WaitEvent 
+	Print CurrentEvent.ToString()
+	Select EventID()
+		Case EVENT_WINDOWCLOSE
+			End
+	End Select
+Wend
+
+Try moving and sizing the window while the program is running +and you will see the details of the events that occur printed +in the debug window of BlitzMax. +

+Try also modifying the "window=" line in the program with: +

+window=CreateWindow("My Window",40,40,320,240,Null,WINDOW_TITLEBAR)
+
+which will create a Window with only a title bar and no status or +menu bars. See the documentation for CreateWindow for more details +of the Window styles supported by MaxGui. +

+The MaxGui documentation contains working examples for each of +commands that create gadgets including CreateButton, CreateCanvas, +CreateComboBox, CreateHTMLView, CreateLabel, CreateListBox, +CreateMenu, CreatePanel, CreateProgBar, CreateSlider, CreateTabber, +CreateTextField, CreateToolBar and CreateTreeView. +

+ +

Gadget Layout

+

+A Gadget in MaxGui is given pixel coordinates when it is created +that positions it in it's parent's client area. The client area of +a Window gadget is inside the window's borders not including the +space used by any Status or Menu bars. +

+If a Window is resized MaxGui uses any children's layout settings +to reposition them within the new size of it's client area. +

+The SetGadgetLayout is used to control how the Gadget is repositioned +when it's parent is resized. +

+By considering each edge of the Gadget independently, the MaxGui +layout engine repositions each gadget according to each edge's +rule where the rule is +

+EDGE_CENTERED - The edge remains a fixed distance from the center of the parent
+EDGE_ALIGNED - The edge is a locked distance away from it's parent's corresponding edge
+EDGE_RELATIVE - The edge remains a proportional distance from the parent's 2 edges
+

+The following code demonstrates a common case of creating a panel +in a window the size of the window's client area and locking the +distance of each edge to the correspong edge of the parent window +(EDGE_ALIGNED rule). The result is that the panel is automatically sized by +MaxGui when the window is resized filling the entire client area. +

+Strict 
+
+Import MaxGUI.Drivers
+
+Local window:TGadget
+Local panel:TGadget
+
+window=CreateWindow("My Window",40,40,320,240)
+
+panel=CreatePanel(0,0,ClientWidth(window),ClientHeight(window),window)
+SetGadgetColor panel,200,100,100
+SetGadgetLayout panel,EDGE_ALIGNED,EDGE_ALIGNED,EDGE_ALIGNED,EDGE_ALIGNED
+
+While True
+	WaitEvent 
+	Print CurrentEvent.ToString()
+	Select EventID()
+		Case EVENT_WINDOWCLOSE
+			End
+	End Select
+Wend
+
+By removing the line of code with the SetGadetLayout command you can view the default +EDGE_CENTERED rule in effect on all edges with the panel retaining it's size +due to all it's edges being kept a fixed distance from the center +of the window. +

+To view rule EDGE_RELATIVE in effect modify the SetGadgetLayout command to read +"SetGadgetLayout panel,EDGE_RELATIVE,EDGE_RELATIVE,EDGE_RELATIVE,EDGE_RELATIVE". +

+But wait, there is no discernable change in the resizing behavior between +rule EDGE_ALIGNED and rule EDGE_RELATIVE??? +

+Unless the panel is created inset from the window client such as +the result of the following modification: +

+panel=CreatePanel(10,10,ClientWidth(window)-20,ClientHeight(window)-20,window)
+
+you will note the edges are infact being kept a proportional distance +from the parent's 2 edges when the window is resized. +

+The fact is that EDGE_ALIGNED and EDGE_RELATIVE have the same effect on Gadget +edges when the edges are created on the borders of their parent's client area. +

+ +

Crossplatform Issues

+

+In general the MaxGUI module should perform identically on Windows, +Apple and Linux machines. However some care and attention is required +when testing in regards to how your application will look on each +platform. +

+The following are a few issues that if considered should hopefully +enable you to publish programs that look and function well on a wide +variety of systems. +

+Recomended gadget dimensions. +

+

+

+Use the WINDOW_CLIENTCOORDS flag when dependent on client size. +

+If you are using a fixed size window specify it's size based on the +required client area using the WINDOW_CLIENTCOORDS style. +

+Specifying a window's size in the default frame coordinates will +result in a client area that may be different on different machines +due to a number of factors including both the version of the computer's +operating system and certain user preference outside your control. +

+

+

Using an EventHook

+

+As an alternative to developing applications that have a single +main loop that waits then processes events from an eventqueue +the AddHook command allows a callback function to be used +to process events as they happen. +

+This is important for two type of events. +

+EVENT_GADGETACTION events produced by Slider gadgets with the +original SLIDER_SCROLLBAR style and EVENT_WINDOWRESIZE events +that occur when the user is resizing a Window both require +a hooked type of event processing for best results. +In both these situations most OS's go into a "modal" +loop that means a WaitEvent command will only return once +the user releases the mouse button but with Event hooks +the code can be called directly from within the OS's own +modal loop. +

+The other type of event is EVENT_GADGETPAINT which is generated +whenever the operating system needs to redraw a Canvas gadget. +When hooked, drawing code can be executed at the time of the +event rather than later when the OS returns control to the +main program, at which time it may have already drawn other +content above the Canvas. +

+ +

Using a Canvas

+

+The following code is a simple example of using Max2D to +render dynamically into a Canvas Gadget... +

+' createcanvas.bmx
+
+Strict 
+
+Import MaxGUI.Drivers
+
+Global GAME_WIDTH=320
+Global GAME_HEIGHT=240
+
+' create a centered window with client size GAME_WIDTH,GAME_HEIGHT
+
+Local wx=(GadgetWidth(Desktop())-GAME_WIDTH)/2
+Local wy=(GadgetHeight(Desktop())-GAME_HEIGHT)/2
+
+Local window:TGadget=CreateWindow("My Canvas",wx,wy,GAME_WIDTH,GAME_HEIGHT,Null,WINDOW_TITLEBAR|WINDOW_CLIENTCOORDS)
+
+' create a canvas for our game
+
+Local canvas:TGadget=CreateCanvas(0,0,320,240,window)
+
+' create an update timer
+
+CreateTimer 60
+
+While WaitEvent()
+	Select EventID()
+		Case EVENT_TIMERTICK
+			RedrawGadget canvas
+
+		Case EVENT_GADGETPAINT
+			Local g=CanvasGraphics(canvas)
+			SetGraphics g
+			SetOrigin 160,120
+			SetLineWidth 5
+			Cls
+			Local t=MilliSecs()
+			DrawLine 0,0,120*Cos(t),120*Sin(t)
+			DrawLine 0,0,80*Cos(t/60),80*Sin(t/60)
+			Flip
+
+		Case EVENT_WINDOWCLOSE
+			FreeGadget canvas
+			End
+
+		Case EVENT_APPTERMINATE
+			End
+	End Select
+Wend
+
+The above code creates a timer that causes an event to occur +at 60hz (ticks per second). +

+Each time an EVENT_TIMERTICK is received by the program's main +event loop it calls RedrawGadget which tells the system to redraw +our canvas gadget. +

+The code following the Case EVENT_GADGETPAINT above is where +the actual drawing takes place. +

+- of interest - +

+If you remove two lines of the above code that contain the +"RedrawGadget canvas" and "Case EVENT_GADGETPAINT" the program +still appears to function normally. +

+This is because MaxGUI infact allows you to draw to a canvas +when ever you want. Drawing in response to an EVENT_GADGETPAINT +however is better behavior as no drawing code is executed if +the canvas is obscured or the application has a low refresh rate +in which case it will be still asked to redraw itself on the +event an obscured canvas is revealed by window movement from +above. +

+ +

Event Hook based Rendering

+

+As mentioned above the best way to manage redrawing a Canvas +gadget is with an EventHook. +

+The following example uses an EventHook to handle events +at the time of occurance rather than from the WaitEvent() +queue. You will notice at the bottom of the program that +infact the main loop does nothing but WaitEvent and all +the event handling is done inside the TApplet Type. +

+

+' rendering a canvas using an EventHook based Applet Type
+
+Strict
+
+Import MaxGUI.Drivers
+
+Type TApplet
+	
+	Field	window:TGadget
+	Field	canvas:TGadget
+	Field	timer:TTimer
+	
+	Method Render()
+		Local x,y,width,height,t,i
+		width=GraphicsWidth()
+		height=GraphicsHeight()
+		t=MilliSecs()
+		SetBlend ALPHABLEND
+		SetViewport 0,0,width,height
+		SetClsColor 0,0,0
+		SetOrigin width/2,height/2
+		Cls
+		For x=-width/2 To width/2 Step 2
+			y=Sin(t*0.3+x)*height/2
+			DrawLine 0,0,x,y
+		Next
+	End Method
+	
+	Method OnEvent(event:TEvent)
+		Select event.id
+		Case EVENT_WINDOWCLOSE
+			End
+		Case EVENT_TIMERTICK
+			RedrawGadget canvas
+		Case EVENT_GADGETPAINT
+			SetGraphics CanvasGraphics(canvas)
+			Render
+			Flip
+		End Select
+	End Method
+
+	Function eventhook:Object(id,data:Object,context:Object)
+		Local	event:TEvent
+		Local	app:TApplet
+		event=TEvent(data)
+		app=TApplet(context)
+		app.OnEvent event	
+	End Function
+	
+	Method Create:TApplet(name$)
+		Local	a:TApplet
+		Local	w,h
+		window=CreateWindow(name,20,20,512,512)
+		w=ClientWidth(window)
+		h=ClientHeight(window)
+		canvas=CreateCanvas(0,0,w,h,window)
+		canvas.SetLayout 1,1,1,1
+		timer=CreateTimer(100)
+		AddHook EmitEventHook,eventhook,Self
+		Return Self		
+	End Method
+	
+End Type
+
+AutoMidHandle True
+
+Local	applet:TApplet
+
+applet=New TApplet.Create("Render Applet")
+
+While True
+	WaitEvent
+Wend
+
+

+Unfortunately I have obfiscated (made obscure) the +function of the event hook by wrapping it in an +Applet object and I have started using big words in +my sentences. +

+To be as concise as possible, the TApplet Type declares +a Class that features an OnEvent Method that with some +magic in it's constructor (the Create() Method) provides +an object oriented way for our program to collect events. +

+Our TApplet implements the rendering sequence +as featured in the previous example but because +it does so based on a Hook responds in a more +well behaved manner when the OS wishes to redraw the +desktop when it is made visible by some user action +or told to refresh with the RedrawGadget command. + +

Porting from BlitzPlus

+

+The following are a few issues that you may encounter when +porting code from BlitzPlus. +

+ +

Event Codes

+

+The codes returned by the WaitEvent and EventID commands +are not the same as BlitzPlus. See the Event Objects docs +for a list of the constants used in MaxGUI. Numerical +values have not been documented in order to encourage +users to use the correct EVENT_NAMES. +

+New events in MaxGUI include +

+EVENT_HOTKEYHIT - see SetHotKeyEvent +

+EVENT_WINDOWACCEPT - a file has been dragged onto the window +

+EVENT_GADGETPAINT - a canvas gadget needs redrawing +

+EVENT_GADGETSELECT - the selected state of a TextArea has changed +

+EVENT_GADGETMENU - the user has clicked the right button on this gadget +

+EVENT_GADGETOPEN - a node in a TreeViewNode has been expanded +

+EVENT_GADGETCLOSE - a node in a TreeViewNode has been collapsed +

+EVENT_GADGETDONE - an HTMLView has finished loading a page +

+ +

TextArea filters

+

+TextAreas no longer generate Key Up, Key Down or Key Stroke events. +

+Instead the new SetGadgetFilter command can be used to install +a callback routine that is called each time the user presses +a key with the callback able to accept or reject each key +by returning either True or False respectively. +

+ +

Popup Menus

+ +There is a new PopupWindowMenu command that can be used +for implementing context menus commonly activated by the +right mouse button (reported as an EVENT_GADGETMENU for most +gadgets). + + +

The New Modules

+

+The three platform specific modules that ship with MaxGui are +Win32MaxGui.mod, CocoaMaxGui.mod and FLTKMaxGui.mod which provide +native implementations of MaxGui for Windows, Apple MacOS and +Linux platforms respectively. +

+The new Event.mod and EventQueue.mod modules are extensions +to the BlitzMax system. BlitzMax events provide the necessary +mechanics of communicating with a MaxGui based application as well +as providing all BlitzMax applications with events such as +EVENT_APPSUSPEND, EVENT_APPRESUME and EVENT_APPTERMINATE. +

+The commands WaitEvent, PeekEvent and PollEvent are the primary +commands for receiving Events in BlitzMax programs and PostEvent +can be used for generating Events. +

+ +

Under the Hood

+

+The Type TGadget is used in MaxGui to represent all 18 Gadget +types including: +

+GADGET_DESKTOP +GADGET_WINDOW +GADGET_BUTTON +GADGET_PANEL +GADGET_TEXTFIELD +GADGET_TEXTAREA +GADGET_COMBOBOX +GADGET_LISTBOX +GADGET_TOOLBAR +GADGET_TABBER +GADGET_TREEVIEW +GADGET_HTMLVIEW +GADGET_LABEL +GADGET_SLIDER +GADGET_PROGBAR +GADGET_MENUITEM +GADGET_NODE +GADGET_CANVAS +

+The TMaxGUIDriver Type defined in maxgui.driver represents the +gadget factory which is created at startup to produce platform +specific versions of TGadget on demand. +

+The type TGadget is actually an abstract class with TWin32Gadget, +TCocoaGadget and TFLTKGadget being the actual types produced +depending on the current TMaxGUIDriver. +

+The types TIconStrip, TGUIFont and TGadgetItem also provide +an abstract interface to the platform specific implementations +meaning that like TGadget itself, they are not intended to be +extended by the user. +

+

+ + +

Crossplatform vs Flexibility

+

+It is expected that most users wanting to create custom +gadgets that work well across all platforms will find +the Panel and Canvas gadgets provide adequate Event reporting +and rendering functionality from which to produce their +own uber-gadgets. +

+The cross platform nature of MaxGUI means there are +implications for those wishing to extend functionality by +taking advantage of platform specific features that have +no logical equivalent on other platforms. +

+Those wishing to do so are encouraged to implement such +features in separate modules rather than making modifications +to the BRL modules which are intended only to support the +core cross platform MaxGUI functionality. +

+This of course does not mean the the current specification +of MaxGUI is set in stone, rather, that those wanting to +interface at a lower level with the Operating System of +their choice do so in the privacy of their own modules +rather than becoming muddied in the source of the lowlevel +platform specific BRL modules. + + + diff --git a/docs/src/Tutorials/index.bbdoc b/docs/src/Tutorials/index.bbdoc new file mode 100644 index 0000000..e69de29 diff --git a/docs/src/Tutorials/nehe_01.bmx b/docs/src/Tutorials/nehe_01.bmx new file mode 100644 index 0000000..f4cf011 --- /dev/null +++ b/docs/src/Tutorials/nehe_01.bmx @@ -0,0 +1,14 @@ + +'Ok, this demo's a little pointless! +' +'All it does is show you how to open an OpenGL window +' +GLGraphics 640,480 + +While Not KeyHit( KEY_ESCAPE ) + + glClear GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT 'Clear The Screen And The Depth Buffer + + Flip + +Wend \ No newline at end of file diff --git a/docs/src/Tutorials/nehe_02.bmx b/docs/src/Tutorials/nehe_02.bmx new file mode 100644 index 0000000..b9d757d --- /dev/null +++ b/docs/src/Tutorials/nehe_02.bmx @@ -0,0 +1,42 @@ + +GLGraphics 640,480 + +glEnable GL_DEPTH_TEST 'Enables Depth Testing + +glMatrixMode GL_PROJECTION 'Select The Projection Matrix +glLoadIdentity 'Reset The Projection Matrix + +glFrustum -0.1, 0.1,-0.1, 0.1, 0.1, 100.0 'Setup The Projection Matrix Frustum + +glMatrixMode GL_MODELVIEW 'Select The ModelView Matrix +glLoadIdentity 'Reset The ModelView Matrix + +While Not KeyHit( KEY_ESCAPE ) + + glClear GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT 'Clear The Screen And The Depth Buffer + + glLoadIdentity 'Reset The ModelView Matrix + glTranslatef -1.5,0.0,-6.0 'Move Left 1.5 Units And Into The Screen 6.0 + + glBegin GL_TRIANGLES 'Drawing Using Triangles + + glVertex3f 0.0, 1.0, 0.0 'Top + glVertex3f -1.0,-1.0, 0.0 'Bottom Left + glVertex3f 1.0,-1.0, 0.0 'Bottom Right + + glEnd 'Finished Drawing The Triangle + + glTranslatef 3.0,0.0,0.0 'Move Right 3 Units + + glBegin GL_QUADS 'Draw A Quad + + glVertex3f -1.0, 1.0, 0.0 'Top Left + glVertex3f 1.0, 1.0, 0.0 'Top Right + glVertex3f 1.0,-1.0, 0.0 'Bottom Right + glVertex3f-1.0,-1.0,0.0 'Bottom Left + + glEnd 'Finished Drawing The Quad + + Flip + +Wend \ No newline at end of file diff --git a/docs/src/Tutorials/nehe_03.bmx b/docs/src/Tutorials/nehe_03.bmx new file mode 100644 index 0000000..c00ee96 --- /dev/null +++ b/docs/src/Tutorials/nehe_03.bmx @@ -0,0 +1,46 @@ + +GLGraphics 640,480 + +glEnable GL_DEPTH_TEST 'Enables Depth Testing + +glMatrixMode GL_PROJECTION 'Select The Projection Matrix +glLoadIdentity 'Reset The Projection Matrix + +glFrustum -0.1, 0.1,-0.1, 0.1, 0.1, 100.0 'Setup The Projection Matrix Frustum + +glMatrixMode GL_MODELVIEW 'Select The ModelView Matrix +glLoadIdentity 'Reset The ModelView Matrix + +While Not KeyHit( KEY_ESCAPE ) + + glClear GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT 'Clear The Screen And The Depth Buffer + + glLoadIdentity 'Reset The ModelView Matrix + glTranslatef -1.5,0.0,-6.0 'Move Left 1.5 Units And Into The Screen 6.0 + + glBegin GL_TRIANGLES 'Drawing Using Triangles + + glColor3f 1.0,0.0,0.0 'Set The Color To Red + glVertex3f 0.0, 1.0, 0.0 'Top + glColor3f 0.0,1.0,0.0 'Set The Color To Green + glVertex3f -1.0,-1.0, 0.0 'Bottom Left + glColor3f 0.0,0.0,1.0 'Set The Color To Blue + glVertex3f 1.0,-1.0, 0.0 'Bottom Right + + glEnd 'Finished Drawing The Triangle + + glTranslatef 3.0,0.0,0.0 'Move Right 3 Units + + glColor3f 0.5,0.5,1.0 'Set The Color To Blue One Time Only + glBegin GL_QUADS 'Draw A Quad + + glVertex3f -1.0, 1.0, 0.0 'Top Left + glVertex3f 1.0, 1.0, 0.0 'Top Right + glVertex3f 1.0,-1.0, 0.0 'Bottom Right + glVertex3f-1.0,-1.0,0.0 'Bottom Left + + glEnd 'Finished Drawing The Quad + + Flip + +Wend diff --git a/docs/src/Tutorials/nehe_04.bmx b/docs/src/Tutorials/nehe_04.bmx new file mode 100644 index 0000000..c607bd6 --- /dev/null +++ b/docs/src/Tutorials/nehe_04.bmx @@ -0,0 +1,56 @@ + +GLGraphics 640,480 + +glEnable GL_DEPTH_TEST 'Enables Depth Testing + +glMatrixMode GL_PROJECTION 'Select The Projection Matrix +glLoadIdentity 'Reset The Projection Matrix + +glFrustum -0.1, 0.1,-0.1, 0.1, 0.1, 100.0 'Setup The Projection Matrix Frustum + +glMatrixMode GL_MODELVIEW 'Select The ModelView Matrix +glLoadIdentity 'Reset The ModelView Matrix + +Local rtri:Float 'Angle For The Triangle ( New ) +Local rquad:Float 'Angle For The Quad ( New ) + +While Not KeyHit( KEY_ESCAPE ) + + glClear GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT 'Clear The Screen And The Depth Buffer + + glLoadIdentity 'Reset The ModelView Matrix + glTranslatef -1.5,0.0,-6.0 'Move Left 1.5 Units And Into The Screen 6.0 + + glRotatef rtri,0.0,1.0,0.0 'Rotate The Triangle On The Y axis ( New ) + + glBegin GL_TRIANGLES 'Drawing Using Triangles + + glColor3f 1.0,0.0,0.0 'Set The Color To Red + glVertex3f 0.0, 1.0, 0.0 'Top + glColor3f 0.0,1.0,0.0 'Set The Color To Green + glVertex3f -1.0,-1.0, 0.0 'Bottom Left + glColor3f 0.0,0.0,1.0 'Set The Color To Blue + glVertex3f 1.0,-1.0, 0.0 'Bottom Right + + glEnd 'Finished Drawing The Triangle + + glLoadIdentity() 'Reset The Current Modelview Matrix + glTranslatef 1.5,0.0,-6.0 'Move Right 1.5 Units And Into The Screen 6.0 + glRotatef rquad,1.0,0.0,0.0 'Rotate The Quad On The X axis ( New ) + + glColor3f 0.5,0.5,1.0 'Set The Color To Blue One Time Only + glBegin GL_QUADS 'Draw A Quad + + glVertex3f -1.0, 1.0, 0.0 'Top Left + glVertex3f 1.0, 1.0, 0.0 'Top Right + glVertex3f 1.0,-1.0, 0.0 'Bottom Right + glVertex3f-1.0,-1.0,0.0 'Bottom Left + + glEnd 'Finished Drawing The Quad + + rtri:+0.7 'Increase The Rotation Variable For The Triangle ( New ) + rquad:-0.55 'Decrease The Rotation Variable For The Quad ( New ) + + Flip + +Wend diff --git a/docs/src/Tutorials/nehe_05.bmx b/docs/src/Tutorials/nehe_05.bmx new file mode 100644 index 0000000..e28fc56 --- /dev/null +++ b/docs/src/Tutorials/nehe_05.bmx @@ -0,0 +1,108 @@ + +GLGraphics 640,480 + +glEnable GL_DEPTH_TEST 'Enables Depth Testing + +glMatrixMode GL_PROJECTION 'Select The Projection Matrix +glLoadIdentity 'Reset The Projection Matrix + +glFrustum -0.1, 0.1,-0.1, 0.1, 0.1, 100.0 'Setup The Projection Matrix Frustum + +glMatrixMode GL_MODELVIEW 'Select The ModelView Matrix +glLoadIdentity 'Reset The ModelView Matrix + +Local rtri:Float 'Angle For The Triangle ( New ) +Local rquad:Float 'Angle For The Quad ( New ) + +While Not KeyHit( KEY_ESCAPE ) + + glClear GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT 'Clear The Screen And The Depth Buffer + + glLoadIdentity 'Reset The ModelView Matrix + glTranslatef -1.5,0.0,-6.0 'Move Left 1.5 Units And Into The Screen 6.0 + + glRotatef rtri,0.0,1.0,0.0 'Rotate The Triangle On The Y axis ( New ) + + glBegin GL_TRIANGLES 'Drawing Using Triangles + + glColor3f 1.0,0.0,0.0 'Red + glVertex3f 0.0, 1.0, 0.0 'Top Of Triangle (Front) + glColor3f 0.0,1.0,0.0 'Green + glVertex3f -1.0,-1.0, 1.0 'Left Of Triangle (Front) + glColor3f 0.0,0.0,1.0 'Blue + glVertex3f 1.0,-1.0, 1.0 'Right Of Triangle (Front) + + glColor3f 1.0,0.0,0.0 'Red + glVertex3f 0.0, 1.0, 0.0 'Top Of Triangle (Right) + glColor3f 0.0,0.0,1.0 'Blue + glVertex3f 1.0,-1.0, 1.0 'Left Of Triangle (Right) + glColor3f 0.0,1.0,0.0 'Green + glVertex3f 1.0,-1.0, -1.0 'Right Of Triangle (Right) + + glColor3f 1.0,0.0,0.0 'Red + glVertex3f 0.0, 1.0, 0.0 'Top Of Triangle (Back) + glColor3f 0.0,1.0,0.0 'Green + glVertex3f 1.0,-1.0, -1.0 'Left Of Triangle (Back) + glColor3f 0.0,0.0,1.0 'Blue + glVertex3f -1.0,-1.0, -1.0 'Right Of Triangle (Back) + + glColor3f 1.0,0.0,0.0 'Red + glVertex3f 0.0, 1.0, 0.0 'Top Of Triangle (Left) + glColor3f 0.0,0.0,1.0 'Blue + glVertex3f -1.0,-1.0,-1.0 'Left Of Triangle (Left) + glColor3f 0.0,1.0,0.0 'Green + glVertex3f -1.0,-1.0, 1.0 'Right Of Triangle (Left) + + glEnd 'Finished Drawing The Pyramid + + glLoadIdentity() 'Reset The Current Modelview Matrix + glTranslatef 1.5,0.0,-7.0 'Move Right 1.5 Units And Into The Screen 7.0 + glRotatef rquad,1.0,1.0,1.0 'Rotate The Quad On The X, Y and Z axis ( New ) + + glColor3f 0.5,0.5,1.0 'Set The Color To Blue One Time Only + glBegin GL_QUADS 'Draw A Quad + + glColor3f 0.0,1.0,0.0 'Set The Color To Green + glVertex3f 1.0, 1.0,-1.0 'Top Right Of The Quad (Top) + glVertex3f -1.0, 1.0,-1.0 'Top Left Of The Quad (Top) + glVertex3f -1.0, 1.0, 1.0 'Bottom Left Of The Quad (Top) + glVertex3f 1.0, 1.0, 1.0 'Bottom Right Of The Quad (Top) + + glColor3f 1.0,0.5,0.0 'Set The Color To Orange + glVertex3f 1.0,-1.0, 1.0 'Top Right Of The Quad (Bottom) + glVertex3f -1.0,-1.0, 1.0 'Top Left Of The Quad (Bottom) + glVertex3f -1.0,-1.0,-1.0 'Bottom Left Of The Quad (Bottom) + glVertex3f 1.0,-1.0,-1.0 'Bottom Right Of The Quad (Bottom) + + glColor3f 1.0,0.0,0.0 'Set The Color To Red + glVertex3f 1.0, 1.0, 1.0 'Top Right Of The Quad (Front) + glVertex3f -1.0, 1.0, 1.0 'Top Left Of The Quad (Front) + glVertex3f -1.0,-1.0, 1.0 'Bottom Left Of The Quad (Front) + glVertex3f 1.0,-1.0, 1.0 'Bottom Right Of The Quad (Front) + + glColor3f 1.0,1.0,0.0 'Set The Color To Yellow + glVertex3f 1.0,-1.0,-1.0 'Bottom Left Of The Quad (Back) + glVertex3f -1.0,-1.0,-1.0 'Bottom Right Of The Quad (Back) + glVertex3f -1.0, 1.0,-1.0 'Top Right Of The Quad (Back) + glVertex3f 1.0, 1.0,-1.0 'Top Left Of The Quad (Back) + + glColor3f 0.0,0.0,1.0 'Set The Color To Blue + glVertex3f -1.0, 1.0, 1.0 'Top Right Of The Quad (Left) + glVertex3f -1.0, 1.0,-1.0 'Top Left Of The Quad (Left) + glVertex3f -1.0,-1.0,-1.0 'Bottom Left Of The Quad (Left) + glVertex3f -1.0,-1.0, 1.0 'Bottom Right Of The Quad (Left) + + glColor3f 1.0,0.0,1.0 'Set The Color To Violet + glVertex3f 1.0, 1.0,-1.0 'Top Right Of The Quad (Right) + glVertex3f 1.0, 1.0, 1.0 'Top Left Of The Quad (Right) + glVertex3f 1.0,-1.0, 1.0 'Bottom Left Of The Quad (Right) + glVertex3f 1.0,-1.0,-1.0 'Bottom Right Of The Quad (Right) + + glEnd 'Finished Drawing The Box + + rtri:+0.6 'Increase The Rotation Variable For The Triangle ( New ) + rquad:-0.85 'Decrease The Rotation Variable For The Quad ( New ) + + Flip + +Wend diff --git a/docs/src/Tutorials/style.css b/docs/src/Tutorials/style.css new file mode 100644 index 0000000..5c10080 --- /dev/null +++ b/docs/src/Tutorials/style.css @@ -0,0 +1,126 @@ +body{ + color: #000000; + background: #ffffff; + font: 9pt helvetica; +} +body.navbar{ + color: #000000; + background: #ffffff; + font: 10pt helvetica; + padding: 2px; +} +h1{ + font: 14pt helvetica; + font-weight: bold; +} +h2{ + font: 12pt helvetica; + font-weight: bold; +} +h3{ + font: 10pt helvetica; + font-weight: bold; +} +table{ + background: #ffffff; + font: 10pt helvetica; +} +th{ + padding: 4px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + text-align: left; +} +td{ + padding: 4px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; +} +td.blank{ + padding: 0px; + background: #ffffff; + border: none; +} +td.small{ + padding: 2px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; + font: 8pt helvetica; +} +td.doctop{ + padding: 10px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + font: 10pt helvetica; + vertical-align: text-top; + font-weight: bold; +} +td.docleft{ + padding: 10px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + font: 8pt helvetica; + vertical-align: text-top; + width: 10%; +} +td.docright{ + padding:10px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; + font: 10pt helvetica; + vertical-align: text-top; + width: 90%; +} +pre{ + font: 10pt courier; + background: #eef8ff; + padding: 8px; +} +font.token{ + font-weight: bold; +} +font.syntax{ + color: #005555; +} +div.ref{ + border: 1px solid #000000; +} +div.indent{ + padding-left: 8px; +} +div.syntax{ + color: #005555; + padding: 8px; +} +a{ + color: #000088; + font: 10pt helvetica; + text-decoration: underline; +} +a.navbig{ + color: #000088; + font: 9pt helvetica; + text-decoration: none; +} +a.navsmall{ + color: #000088; + font: 8pt helvetica; + text-decoration: none; +} +a:hover{ + color: #000088; +} +a.small{ + color: #000088; + font: 8pt helvetica; +} +a.token{ + color: #000088; + text-decoration: underline; +} +a.null{ + text-decoration: none; +} +div.entries{ + display: none; +} diff --git a/docs/src/Tutorials/upperstream.bmx b/docs/src/Tutorials/upperstream.bmx new file mode 100644 index 0000000..9bc2ba3 --- /dev/null +++ b/docs/src/Tutorials/upperstream.bmx @@ -0,0 +1,89 @@ + +Strict + +Type TUpperStream Extends TStreamWrapper + + Method Read( buf:Byte Ptr,count ) + 'Read data from the underlying stream + count=Super.Read( buf,count ) + 'Convert the data to uppercase + For Local i=0 Until count + If buf[i]>=Asc("a") And Buf[i]<=Asc("z") + buf[i]=buf[i]-Asc("a")+Asc("A") + EndIf + Next + 'Done! + Return count + End Method + + Method Write( buf:Byte Ptr,count ) + 'Copy the data to a new buffer, converting to uppercase as we go + Local tmp:Byte[count] + For Local i=0 Until count + If buf[i]>=Asc("a") And buf[i]<=Asc("z") + tmp[i]=buf[i]-Asc("a")+Asc("A") + Else + tmp[i]=buf[i] + EndIf + Next + 'Write the data to the underlying stream + Return Super.Write( tmp,count ) + End Method + + Function Create:TUpperStream( stream:TStream ) + Local t:TUpperStream=New TUpperStream + 'SetStream is a TStreamWrapper method that sets the underlying stream. + t.SetStream stream + Return t + End Function + +End Type + +Type TUpperStreamFactory Extends TStreamFactory + + Method CreateStream:TUpperStream( url:Object,proto$,path$,readable,writeable ) + If proto$<>"uppercase" Return + Local stream:TStream=OpenStream( path,readable,writeable ) + If stream Return TUpperStream.Create( stream ) + End Method + +End Type + +New TUpperStreamFactory + +'Exmaple of manually creating a TUpperStream: + +'Create a tmp file and write some text to it. +Local tmp:TStream=WriteStream( "tmp" ) +tmp.WriteLine "A little example..." +tmp.WriteLine "of our cool TUpperStream!" +tmp.Close + +'Open tmp file again, and wrap it with a TUpperStream +tmp:TStream=ReadStream( "tmp" ) +Local upperizer:TUpperStream=TUpperStream.Create( tmp ) + +'Dump file contents +While Not upperizer.Eof() + Print upperizer.ReadLine() +Wend + +upperizer.Close +tmp.Close + +'Example of automatically creating a TUpperStream: +Local tmp2:TStream=WriteStream( "uppercase::tmp" ) +tmp2.WriteLine "Another little example..." +tmp2.WriteLine "of our even cooler TUpperStream!" +tmp2.Close + +tmp2:TStream=ReadStream( "tmp" ) +While Not tmp2.Eof() + Print tmp2.ReadLine() +Wend +tmp2.Close + + + + + diff --git a/docs/src/User Guide/bmk.bbdoc b/docs/src/User Guide/bmk.bbdoc new file mode 100644 index 0000000..b210899 --- /dev/null +++ b/docs/src/User Guide/bmk.bbdoc @@ -0,0 +1,84 @@ + ++BMK + +BMK is a command line tool that drives the BlitzMax compiler and provides other general 'housekeeping' operations. + +The general syntax for BMK is: +{ +@bmk %Operation %Options %Arguments +} + +Where operation is one of @makeapp, @makemods, @zapmod, @unzampmod. + ++@Makeapp + +Makeapp builds an application from a single root source file. Building an application involves compiling source files and linking together the resultant %object files. + +Makeapp takes one argument: the root source file to be built. + +The root source file is scanned by BMK for #Import, #Include and #Incbin statements, and these files are themselves automatically built as well. + +Unless the -a option is used, only source files that have been modified since the last makeapp operation are recompiled. This can vastly improve compile times. + +Valid options for makeapp are: +[ @Option | @Effect +* @{-d} | Build debug version. This is the default. +* @{-r} | Build release version. By default, the debug version is built. +* @{-h} | Build multithreaded version. By default, the single threaded version is built. +* @{-a} | Recompile all source files regardless of timestamp. By default, only files modified since the last makeapp are recompiled. +* @{-o} %OutputFile | Specify output file. By default, the output file is placed into the same directory as the root source file. +* @{-t} %AppType | Specify application type. Should be either 'console' or 'gui' (without single quote!). +] + +Some examples of makeapp in action: +{{ +bmk makeapp myapp.bmx +bmk makeapp -a -r -o myapp_release myapp.bmx +}} + +Note that the debug, release, single threaded and multithreaded options allow for 4 'types' of applications: + +* Debug, single threaded (this is the default) +* Debug, multithreaded (use -h option) +* Release, single threaded (use -r option) +* Release, multithreaded (use -r and -h options) + ++Makemods + +The makemods operation builds a set of modules. + +Makemods takes one optional argument: a module filter. This can be a module scope name (to build a subset of modules) or a fully qualified module name (to build an individual module). If the module filter is omitted, than all module are built. + +Valid options for makemods are: +[ @Option | @Effect +* @{-d} | Build debug version only. By default, both debug and release versions are built. +* @{-r} | Build release version only. By default, both debug and release versions are built. +* @{-h} | Build multithreaded versions. By default, single threaded versions only are built. +* @{-a} | Build all modules regardless of timestamps. By default, only modules that have been modified are built. +] + +Some examples of makemods in action: +{{ +bmk makemods mymods +bmk makemods -a mymods.testmod +}} + ++Zapmod + +The Zapmod operation compresses a module into a single '.zap' file. + +Zapmod takes 2 arguments - the module to zap, and the name of the output file. + +For example: +{{ +bmk zapmod mymods.testmod testmod.zap +}} + ++UnzapMod + +Unzapmod installs a module previously zapped with 'Zapmod'. + +Unzapmod takes 1 argument - the module zap file to unzap. Note that any matching existing module will be overwritten by this operation. For example: +{{ +bmk unzapmod testmod.zap +}} diff --git a/docs/src/User Guide/error1.png b/docs/src/User Guide/error1.png new file mode 100644 index 0000000000000000000000000000000000000000..45687e716577b8fe6d6f1c60e6778ca2f3a81508 GIT binary patch literal 4588 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 EA766x0RR91 literal 0 HcmV?d00001 diff --git a/docs/src/User Guide/error2.png b/docs/src/User Guide/error2.png new file mode 100644 index 0000000000000000000000000000000000000000..d90e9320659599e55a1d45bba3f1f84dd82c7f5c GIT binary patch literal 5155 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

WyuZo2Ua8EpeK` z+z;Y)jkylg7a1MPWT#_sSeXOm5orDV)2qZq3arwTWnSD+Q4+ddm^TSRF47uj|mJ8|9tS${*rw}Y20r{F%Lw zq1Tb@ru8}3^9JZdae`fbB*_4u9(194fDU%IiH=`P_L{F8PGfDLi)7o3_o4QDp(% z;sD~e^J=wH=Y2#3rCcDrSO!N@UN~~Ffl8t^X_<}^WcwV{N;?v(J*S@_Efs0w+&eyh zr3a(@e;AP5-=J+1;2Wpz*#{mKT68C4M{|UoYmcP4kN2kzgr~$_R!=aCPKjaDN8Dfr zeoPG`bCh{4_Fyx)#>6Rt(ZF(`y@s~^Vg_DE64uPscc!~QD^1C+3|0r9%Vs#l>2dm#M8a4l-)zu-}k5S#tk6fvRM27NjMl{S8;41Qm0dkPWzt^@9JL1;NV> zOM;4*C+``0y_qr38QSb*xYFkzrMi1;{e-PJ1KnE&Zi6mc0o_RwXeTUm5 zLTRc*Y0`f5>PjqoctVfu1q9zJXZIo1hc;c_k{x-KLsxoaFOl0A>Y>`I3{x>QtQ(72 zDVD)YZR%cv_?6xu9lDYh%8Y!+W?vl6o9v=mEQ-CO1Dk9uGUs1=yu4J2GTg}X`^HWg z1#Lr_q0F)sS<|Kx9Sa?=sR~Azr0Avgof(Y$p{2#2UU&|M?44n5!tWq$={3c<9_tO& zoSf|D#XIn}-l`&Q+fV#$mCu*)>ti^mc;`4iDQ$1jW z&hz3$I^ij&RhqY57sSWB;nRM=k7QGz@{h%0XNk|lKd%q%tH49T=T8s^5yLI~u>tEmG7y{eG9_bb6#?QF^ZvHXQ{X zsi-Q;5WbvOhWadJ?Y+1~@4gHh%CpCka5Gi&K_EL76^s~z;L8K=1c&DqO@FRDd6e~N z7m^gW?}3n93BmVCxklwDJ2F8!b2$!U2Vjm2VantarA&Kfun~kHYlyjQRbjEWKtmSK zP$*k&5Y9xf{f#&itdn|f&Qz8Lo$;qbUluHdRB$w|&*eWqgpYEHtq5eX9g-xk$y_FO z<=1Vu6G<-D?&%xyP0XPK+dtQ|l()2TOrU%D%tiJV7ti|_uU!sP5?)_*PuH_twbff( zG^g?3UZ7j*OW(ies#ZFz+pT#8F(eZ`Tl94dFtXkm)EKb{+A4%k5c&oa0R&7nP#yvfUpZ@sX-Jl$J7UF!_DV5zEg-oj3yP~lo6B%w7Y zZoth1ZVP6|fUP+r@AfnOD4oumtTl!iNRwM|?}Pqv0Kl!{%DVs<#Zx)b7PJG8`n*nt zMjfu3u>>9)Iwt}rSRULD2xyf;p|bCW%1cz;dpfuTZDNx4?m8KaH_E&EI57t=bh=q+ zh6EvyR1Y`u@lEalR#AIeqq(BCE5|%ywQc)_CKO>LjUoOU3%7ww;;tPxk$HLMU~%hK z)&UO*#(!{;dzjtFwbdU{B5G7?DiownXvzXej2u*@r1que&+x=R4HM>l zCcEUk`cqIYJRTJ+H-9P2y~~|6y;?-jJL^-Jnb!v?)#BItCvRt}I~~wiN9N{-T4evw zo95=z%-S)}-S*6cE9|S@MgOl&kQpneO9bUhZ;gked5uR`EtDLsIujOm?gHd%(*C+q zkCdi4qgsPc8ES*!rv)YbUL&6?T3u+hODX>0$kIVoUWmwEK686@&|YLdOBuzyi$2J3 zQk0~N2PgLrst)B#A4cV)8D;nT6MSwu$DW#4@V_Z+xdT`+rHhK9APVuA5zXe$_gkQ% z8GD3Uax3^pg3u8v{4p}%tD5s&!-Y9l+&aPkg}(pIzyA+J#+gXuW||1{b&)`b3t}xL zGW-S;_RjA}(a6(%-zPj0S81;cQlv zsWDCr?=+|s0{Be{aeI7A>HTT#AVHVYfhB<80StPO>mEeL6JYaVepfmion?+^xSFF>H`(+ zzbPO7{q=P_-aw>L&3njWw2R1n+<#ZS$8UDbOznK@nqGXW-fu5jVuJ8Fm5N_hDuKGV d3PtFatTvHDq2!`v0auj()ReWAY7{NQ{so+C0xbXl literal 0 HcmV?d00001 diff --git a/docs/src/User Guide/index.bbdoc b/docs/src/User Guide/index.bbdoc new file mode 100644 index 0000000..f1aeb03 --- /dev/null +++ b/docs/src/User Guide/index.bbdoc @@ -0,0 +1,28 @@ + ++Welcome + +Welcome to the BlitzMax users guide. + +This document will introduce you to some of the concepts behind BlitzMax, and how to actually use it. + +BlitzMax is a computer programming language based on the popular BASIC programming language. BASIC stands for @{B}eginners @{A}ll purpose @{S}ymbolic @{I}nstruction @{C}ode. As its name would suggest, BASIC is designed to be easy to use, yet useful for a wide range of purposes. + +BlitzMax is a compiler. It takes as input text files containing the source code to a program, and produces as output a program that you can run. The final program consists of low level %{machine code} statements that are interpreted by the CPU. + +Blitzmax also includes several advanced features found in more modern programming languages. In particular, BlitzMax supports the %{object oriented} programming techniques known as %inheritance and %polymorphism. However, Blitzmax is designed so that you don't have to learn such techniques until you are ready (if ever!) + ++How BlitzMax works + +BlitzMax takes your program's %{source code} and converts it into %{executable code}. There are 2 main steps involved in this process: + +Compiling the source code: This steps involves converting each source code file in your project into a corresponding %{object code} file. An object code file contains actual machine code, but cannot be run on its own. It must first be linked with other object files... + +Linking the object code: This step involves %linking all the object code files together in order to produce a program that can actually be run. This step is necessary as object files often require information found in other object files. Linking effectively 'connects up' the object code files to each other. + +This process of compiling and linking a project is known as %building a project and must be done whenever you edit a source file or other resource in your project. + +There are 2 main ways to build projects: either using #MaxIDE or with the #BMK utility. + +MaxIDE is an %{integrated development environment}. It allows you to modify source code files and build projects. + +BMK is a lower level command line utility also used for building projects. In fact, the BlitzMax IDE uses BMK 'behind the scenes' to build projects. diff --git a/docs/src/User Guide/maxide.bbdoc b/docs/src/User Guide/maxide.bbdoc new file mode 100644 index 0000000..1d93109 --- /dev/null +++ b/docs/src/User Guide/maxide.bbdoc @@ -0,0 +1,155 @@ + ++ The BlitzMax IDE + +The BlitzMax IDE is an application used for editing source code files and building projects. IDE stands for 'integrated development environment'. + +The BlitzMax IDE operates very much like a text editor or word processor. + ++ Getting started + +Ok, time to compile and run your first program! + +First, select @New from the file menu or toolbar. This will create a new, empty source file for you to work with. + +Next, enter the following little program: +{{ +' +'My first BlitzMax program +' +Print "Hello World!" +}} +Now, its time to build and run: Select @{Build And Run} from the @Program menu. You should see the following output: +{{ +Building untitled1 +Compiling:untitled1.bmx +flat assembler version 1.51 +3 passes, 2417 bytes. +Linking:untitled1.debug.exe +Executing:untitled1.debug.exe +Hello World! + +Process complete +}} +Congratulations! You've just created your first program! + +What happens if there's an error in your program? Create a new source file and try the following program instead: +{{ +' +'My first bug! +' +rint "Hello World!" 'oops! Forgot a 'p'! +}} +This program has an error in it - there is no such command as 'rint' so attempting to build this program will produce the following error: +{ + +} + +When you return to the main source code window, the cursor will be placed at the line containing the error, allowing you to fix it. + +This type of error is known as a %{compile time} error, because the bug was detected by the compiler before you actually ran the program. However, the compiler cannot catch all possible errors - some errors are not apparent until your program is run. These kinds of errors are known as %runtime errors. Here's an example of a program with a runtime error in it: +{{ +' +' My first runtime bug! +' +Local an_array[10] + +For k=0 To 10 + Print an_array[k] +Next +}} +If you run this, you should see the following error message: +{ + +} +Note how the pane on the right has also switched to the 'Debug' pane. This means your program is in 'debug mode', +and by navigating through the debug pane you can inspect your programs variables. + ++ The File menu +[ @{Menu Item} | @Action +* New | Create a new source file. +* Open | Open an existing source file. +* Open Recent | Reopen a recently used source file. +* Close | Close current source file. +* Close All | Close all source files. +* +* +* Save | Save current source file. +* Save As | Save current source file under a different name. +* Save All | Save all open source files. +* +* +* Next File | Switch to next open source file. +* Previous File | Switch to previous open source file. +* +* +* IDE Options | Open the IDE options panel. +* Project Manager | Open the project manager panel. +* Import BB Project | Import and convert a BlitzPlus or Blitz3D project. +* +* +* Print | Print current souorce file. +* +* +* Exit | Close down and exit the IDE. +] + ++ The Edit menu +[ @{Menu Item} | @Action +* Undo | Undo most recent source file edit. +* Redo | Redo most recently undone source file edit. +* +* +* Cut | Cut selected text from current source file. +* Copy | Copy selected text from current source file. +* Paste | Paste text into current source file. +* +* +* Select All | Select all text in current source file. +* +* +* Block Indent | Indent the currently highlighted block. +* Block Outdent | Unindent the currently highlighted block. +* +* +* Find | Find text in the current source file. +* Find Next | Find next occurance of text. +* Replace | Find and replace text. +* Goto Line | Go to a line in the current source file. +] + ++ The Program menu +[ @{Menu Item} | @Action +* Build | Build the current source file (or locked build file). +* Build And Run | Build and run the current source file (or locked build file). +* Command Line | Specify command line options for BlitzMax apps. +* +* +* Step | In debug mode, step over next program statement. +* Step In | In debug mode, step into next program statement. +* Step Out | In debug mode, step out of current block or function. +* Halt | Stop current build or program run. +* Build Options:Quick Build | Enable or disable quick builds. The quick build feature causes the compiler to only recompile modified files. +* Build Options:Debug Build | Enable or disable debug builds. Debug builds performing extra error checking at runtime, at the cost of some execution speed. +* Build Options:Build GUI App | Instructs BlitzMax to build a 'GUI' application. Disable this if you are building a lightweight, text-only applications. +* +* +* Lock Build File | Lock the current source file for future @build and @{build and run} operations. This can be useful if you have a multifile project and are editing several source files but only ever rebuilding one of them. +* Unlock Build File | Unlock the currently locked build file. +* +* +* Synchronize Modules | Perform an online update of all Blitzmax modules. +* +* +* Build Modules | Build any recently modified modules. +* Rebuild All Modules | Rebuild all modules from scratch. +* Document Modules | Rebuild module documentation. +] + ++ The Help menu +[ @{Menu Item} | @Action +* Home | Go to the help home page. +* Back | Return to previous help page. +* Forward | Advance to the next help page. +* Quick Help | Jump to command reference entry for command nearest cursor. +* About BlitzMax | Show information about BlitzMax and the IDE. +] diff --git a/docs/src/_credits.html b/docs/src/_credits.html new file mode 100644 index 0000000..16eb4a7 --- /dev/null +++ b/docs/src/_credits.html @@ -0,0 +1,33 @@ + + + + + +

+ + + + + + +
 
+
+
+BlitzMax © Blitz Research Ltd
+
+Language and Compiler: Mark Sibly
+
+Modules: Mark Sibly and Simon Armstrong
+
+Documentation: Mark Sibly and Simon Armstrong
+
+Beta testers: Richard Betson; David Bird; James Boyd; Jim Brown; Mikkel Fredborg; Garrit Grandberg; Stephen Greener; Simon Harrison; Michael Hense; Rob Hutchinson; Stephen Johnson; Mikkel Lokke; Daniel Lurie; Richard Olpin; Lee Page; Richard Pearson; John Pickford; Michael Reitzenstein; Robin Shackford; Mark Tiffany
+
+FASM x86 Assembler:Tomasz Grysztar
+
+Extra thanks to: Rod Smith and Mikkel Fredborg for the cool logos and toolbar graphics; Rick, Kay, Robbie and Sarah Keam; Donna, Harley and Danni Adams and all Blitz users around the world!
+
+Last but not Least: BlitzMax would not have been possible without the indirect help of the amazing open source community. Libraries such as zlib, libpng, libjpeg, oggvorbis, freetype, FLTK and others are used by many commercial programs such as BlitzMax, and the unselfish contribution the authors of such libraries have made to the software scene is awesome. +
+ + diff --git a/docs/src/bmax120.png b/docs/src/bmax120.png new file mode 100644 index 0000000000000000000000000000000000000000..cd3a0af5b97530f403d4d02d9662cf427c177bf0 GIT binary patch literal 13680 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 + + + + +
+ + + + + + +
 
+
+Welcome to BlitzMax!
+
+To return to this page at any time, just click the Home icon in the toolbar +above.
+ +For more information on BlitzMax, visit the Blitz Research website at www.blitzbasic.com
+
+If you experience any problems running BlitzMax, please contact +support@blitzbasic.com
+
+ + diff --git a/docs/src/styles/fredborg.css b/docs/src/styles/fredborg.css new file mode 100644 index 0000000..abe7d19 --- /dev/null +++ b/docs/src/styles/fredborg.css @@ -0,0 +1,129 @@ +body{ + color: #000000; + background: #ffffff; + font: 9pt helvetica; +} +body.navbar{ + color: #000000; + background: #ffffff; + font: 10pt helvetica; + padding: 2px; +} +h1{ + font: 14pt helvetica; + font-weight: bold; +} +h2{ + font: 12pt helvetica; + font-weight: bold; +} +h3{ + font: 10pt helvetica; + font-weight: bold; +} +table{ + background: #ffffff; + font: 10pt helvetica; +} +th{ + padding: 4px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + text-align: left; +} +td{ + padding: 4px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; +} +td.blank{ + padding: 0px; + background: #ffffff; + border: none; +} +td.small{ + padding: 2px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; + font: 8pt helvetica; +} +td.doctop{ + padding: 10px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + font: 10pt helvetica; + vertical-align: text-top; + font-weight: bold; +} +td.docleft{ + padding: 10px; + background: #ccddee; + border-bottom: 1px solid #bbccdd; + font: 8pt helvetica; + vertical-align: text-top; + width: 10%; +} +td.docright{ + padding:10px; + background: #ddeeff; + border-bottom: 1px solid #ccddee; + font: 10pt helvetica; + vertical-align: text-top; + width: 90%; +} +pre{ + font: 10pt courier; + background: #eef8ff; + padding: 8px; +} +blockquote{ + color: #005555; +} +font.token{ + font-weight: bold; +} +font.syntax{ + color: #005555; +} +div.ref{ + border: 1px solid #000000; +} +div.indent{ + padding-left: 8px; +} +div.syntax{ + color: #005555; + padding: 8px; +} +a{ + color: #000088; + font: 10pt helvetica; + text-decoration: underline; +} +a.navbig{ + color: #000088; + font: 9pt helvetica; + text-decoration: none; +} +a.navsmall{ + color: #000088; + font: 8pt helvetica; + text-decoration: none; +} +a:hover{ + color: #000088; +} +a.small{ + color: #000088; + font: 8pt helvetica; +} +a.token{ + color: #000088; + text-decoration: underline; +} +a.null{ + text-decoration: none; +} +div.entries{ + display: none; +} -- 2.30.2