5 commits
Author | SHA1 | Message | Date | |
---|---|---|---|---|
dholland
|
41c6e246f4 | Add patch comments. | ||
dholland
|
983d2f5b0c |
This package for some reason thinks MacOS comes with DOS <conio.h>. It
doesn't. |
||
joerg
|
2cc673208f | Add DragonFly support. | ||
abs
|
6eecbcf89a |
Update brandybasic to 1.0.16. Changes since 1.10:
Version 1.11 17/09/2001 Darren Salt (ds@youmustbejoking.demon.co.uk) contributed a number of the changes in this version of the program. - Added support for reading Acorn five byte floating point values (Darren Salt). - Improved support for reading and writing Acorn eight byte floating point values on machines that use a different format for this sort of number to what Acorn use (Darren Salt). - Added support for reading gzip'ed files under Linux (Darren Salt). - The Linux version of the program can be installed using 'configure' (Darren Salt). - Added code to detect the format of eight byte floating point numbers on the platform on which the interpreter is running. This is used when reading and writing such values (DD, based on original code by Darren Salt). - The first line of a program in text form is now ignored if it starts with a '#' in all versions of the interpreter. This only used to be supported in the NetBSD and Linux versions. - Changed handling of syntax errors detected when a line is tokenised. The interpreter now puts out a slightly more meaningful 'syntax error' message if a program with such an error in it is run instead of 'STOP'. - DIM statements of the form 'DIM abc%!8 100' are now dealt with correctly. Previously the code always wanted a variable as the location at which to store the address of the byte array and did not allow the use of an indirected expression. This was an oversight in the code and has now been fixed. - Fixed bug where the string memory management was not being reset under certain conditions when a program was edited. The program was being corrupted if a string expression was evaluated immediately prior to editing the program and then again immediately afterwards. - Fixed bug in ERROR statement code where ERROR 0,<text> was not being treated as a fatal error, that is, the error could be trapped by ON ERROR. Also fixed problem where ERR was not returning the user-supplied error number after an ERROR statement. - Fixed bug in handling of ON ERROR LOCAL where a storage overwrite was causing the interpreter to abort with a 'interpreter has gone wrong' message when restoring LOCAL variables to their original values when dealing with an ENDPROC after branching to the statements after the ON ERROR LOCAL. - Fixed bug in READ statement that affected the reading of strings in cases such as 'READ a$,b$: DATA abcd,', that is, there is nothing after the last comma in the DATA statement. It should return a null string, but the code was skipping to the next DATA statement instead. Version 1.12 01/12/2001 - Split interpreter.c into four files and moved some stuff around. Renamed some files. Version 1.13 28/11/2002 - Included new RND code written by Crispian Daniels. - Included fixes for various graphics problem written by Crispian Daniels. - Incorporated new MacOS target written by Crispian Daniels. - Incorporated new FreeBSD target written by Dirk Engling. - Removed limit on the number of command line arguments returned by ARGV$. - Fixed problem in Unix version of program where screen output was not being displayed before using OSCLI. - Added new VDU function. This returns the value of the specified RISC OS VDU variable. - Added new function COLOUR. This returns a value that represents the closest colour to the colour with the specified colour components in the current screen mode. - Added missing GCOL <red>,<green>,<blue> statement - Added extended form of GCOL statement: GCOL OF ... ON - Added extended form of COLOUR statement: COLOUR OF ... ON - Added extended MODE statement: MODE <x>,<y>,<bpp>,<rate> - Extended the DIM statement to support the DIM <variable> LOCAL <size> version of the statement. - Checked program compiled and worked using the Castle C compiler. Version 1.14 28/07/2003 - Quick hack to fix DIM ... LOCAL problem. The problem was that the code to check that writes using indirection operators were to legal addresses blew away writes to byte arrays on the stack. I have removed this check so that the stack can written to. Version 1.15 16/08/2003 - Added '*key' to allow strings to be defined for function keys as on a BB Micro or RISC OS machine. Version 1.16 25/01/2004 - Added OpenBSD target (changes supplied by Julian Smith). - Added Amiga target (changes supplied by Stefan Haubenthal). - Fixed bug in tokenisation code where any keyword immediately followed by a '.' was taken as abbreviated and the '.' always skipped. This should not have been happening when the full keyword was supplied. The '.' in this case is the start of a floating point number. - Changed the handling of the function 'TOP'. Brandy used to have a token for this function but it is not how the RISC OS Basic interpreter treats it. It uses the token for 'TO' followed by the letter 'P'. This means that the interpreter determines from the context whether this is the function 'TOP' or the keyword 'TO' followed by a variable name starting with 'P'. Brandy now works the way the RISC OS interpreter does. - Fixed bug in handling of 'ERR'. The number of the last error was not being saved so that it could be referenced using ERR except in the case of errors raised via 'ERROR'. This bug was introduced in 1.11 when the *opposite* problem was fixed! - Added '*' command emulation to versions running Unix-type operating system. Previously it was DOS only. - Changed handling of OS commands to that leading blanks and '*' are removed first. - Added new command line option '-nostar' to stop program checking all '*' commands to see if they are emulated by the interpreter. - Tidied up the output on 'help' which shows the where the Basic program and variables are. |
||
abs
|
f83b36600f |
Updated brandybasic to 1.0.10
Changes since 1.05: Version 1.06 15/12/2000 - Bug where functions could be used as procedures (and vice versa) fixed. - Fixed bug in the VAL function where it would sometimes return the wrong result as the string being converted was not terminated properly. - Fixed bug in BPUT introduced in 1.05. - HIMEM can now be changed. - Blank lines in files are no longer discarded when loading a program. - The initial value and step used if the lines of a program are renumbered when loading a program have been changed to 1 and 1 respectively, the idea being that they will match the numbers of the lines of the program in the file in an editor. - Under RISC OS, the 'edit' command can now invoke editors such as StrongED and Zap. - Added limited support for making BBC MOS calls via USR and CALL so that OS_Byte 0 could be used to determine the type of the machine on which the interpreter is being run. Version 1.07 01/01/2001 - Fixed bug in function SUM when the argument was a string array. The function should return all of the strings in the array concatenated together but it was producing rubbish. - Fixed bug in function SUM LEN. This was failing with the error message 'type mismatch: array wanted'. - Fixed bugs in the EOF and EXT functions that show up when the file is not a disk file but, for example, a serial port. - Sorted out some more portability issues, but at a cost of making the program about 10% slower. - The code for the OSCLI ... TO statement has been improved. - The RISC OS version of the program has been changed to use direct OS calls in fileio.c instead of C library functions. This allows Basic programs to carry out I/O operations on a file using a mixture of Basic statements and SWIs. - The INPUT# code has been tidied up. - Typing in token values directly on the command line is now handled correctly, for example, typing in the hex value &F1 no longer gives the error 'The interpreter has gone wrong'. - Under NetBSD and Linux, the handling of I/O redirection on the program's command line has been sorted out. It is now possible to invoke the program so that it takes input from or directs output to a file instead of using the keyboard for input and screen for output. - The QUIT command can now optinally be followed by a value that the interpreter passes back to the underlying operating system as a return or status code. Version 1.08 19/04/2001 - Fixed 'big endian' bug in code that checks if a file contains a tokenised Basic program. The test was failing on big endian machines. - Changed code that writes the four byte start marker at the start of a Basic program so that it is always written in the same order, that is, fixed another endian bug. - Extended the WAIT statement so that the time to wait can be supplied. The time interval is in centiseconds. Version 1.09 29/04/2001 - Fixed bug in INSTR where the end of the string being searched was missed when the first character of the wanted string occured a number of times in the search string. - Tidied up STR function so that STR$~ produced the same results as PRINT~, for 'STR$~255' now produced 'FF' instead of 'ff'. Also changed the format for floating point values so that an exponent is marked with an 'E' instead of an 'e'. - Fixed bug in INPUT statement where INPUT ' cleared the screen instead of skipping to the next line. - Fixed bug in INPUT statement where 'INPUT TAB() <variable>' printed a '?' prompt when it should not have done so. - Fixed a problem in EVAL where the pointer to the expression that contained the EVAL function was being corrupted if the string being evaluated contained a reference to a function that had not been called before. 'EVAL(EVAL(a$))' now works as well. Version 1.10 28/05/2001 - Fixed bug in EDIT introduced fixing EVAL in version 1.09. A 'bad token' error message was being produced when editing a single line with EDIT <line> under DOS and Unix. The amended line was being saved correctly but the error message was then being displayed. - Tidied up handling of @% in PRINT and STR$ when the number of digits to print is zero. '@%=0: PRINT PI' now produces 3.141592654 instead of 3, as per the Acorn interpreter. - Added function XLATE$. This either translates a string using a user-supplied translate table or translates it to lower case if no translate table is supplied. - Added function VERIFY. This is used to check that a string contains only specific characters. - Changed EDIT and EDITO so that EDIT uses the last EDITO value instead of LISTO when converting the program to text when it is edited. If EDITO has not been used, the LISTO value is used instead. |