Ultimate Amiga
Network Boards => AMOS Language Discussion => AMOS Factory => AMOS Forum => Topic started by: ebanite on September 19, 2009, 07:42:19 AM
-
After a long time, i got the idea to bring the original set of amos istruction to work directly inside windows, the first beta is almost ready, but i changed my mind, because there is somethings that i don't like in it....to be honest the questions is...Amiga got a strange kind of hardware, and to try emulate any kind of istructions i can't use the native chunchy format of graphics card, to emulate the copper with the rainbow effects i had to change solutions, now i rewritting the program to support a complete emulation of ghraphics hw, but that mines lower speed, of course faster then original, but slower then other language...
for this reason i make a new version that can run directly in native format of PC grahics, getting the most fast code, and one version devoted to compatibility...
What do you think about?
-
I think someone on this site is already attempting that, infact, 2 people are. ;)
Samurai Crow and Sidewinder.
-
Hello ebanite,
As skate said, Samurai Crow and I are working on a similar project called Mattathias BASIC. The goal of this project is to implement an extensible compiler (initially in the AMOS syntax) that targets the LLVM. This will allow portability and native execution on many different platforms. Our current efforts are in the area of parsing an extensible language without the limits imposed by the AMOS extension system. You can find the project on Source Forge (http://sourceforge.net/projects/mattathias/).
We have also run into similar problems regarding emulation of the Amiga specific graphics functions on modern hardware. Our idea was to create two different extensions to the core AMOS language, one for emulation of Amiga hardware and another for the use of only modern hardware. Very similar to your idea. Perhaps this is an area where we can collaborate?
Sidewinder
-
Hello ebanite,
If you would be interested in doing copper emulation for the PC, I think that the best way to do it would be using a fragment shader on OpenGL. (If you were going to use DirectX, you'd be just as well off using an extension for DarkBasicPro instead of reinventing the wheel.) That shader would allow the simulation of a color palette on newer graphics cards that don't support 256 color resolutions as well as allowing you to simulate the copper rainbow effects. I was considering putting some restrictions having only one copper list per color palette entry. (Eg. color 0 could only have one rainbow instead of 4 as AmosPro supports.)
If you're interested in collaborating, join us at our Yahoo group at http://tech.groups.yahoo.com/group/mattathias/ (http://tech.groups.yahoo.com/group/mattathias/) or send us a private message on this board or an email would be just as good.
If interested, then thanks for the help! If not, that's fine too.
Keep us in mind,
--Sam
-
Hello to everyone
..I know that there are other people are making a porting of Amos Syntax in other plattaform, but i'm doing that in Delphi, with some critical code in pure assembly, i want in the future use a more multi plattafrom target, but not now, i have the idea to use the Pixel shader to emulate some kind of amiga hardware but that means to exclude some platform, for the moment my project still a interpreter language like originally amos did. and after add a just in time compiler (like fkash 10)...i hope to transport my projet in web side application,making an extension like flash or silverlight..but i don't care for the moment..it's to early to plan a expansion of my project...
I wont to collaborate or to share any information to get the best, and for to see as soon as possible a real implementaion of native amos on windos(linux mac os etc...)...
for more information, now i coded a emulation of copper and hardware blitter...plus something about screen and bitmap managment,but i'm looking for more optmization, because i wont to port the new amos inside Amiga Os, and in this case retro compatibility is a must...
A particular thank to Sam and Sidewinder , i'm so interested about your project, we can share information and get the extra mile, i'm not so confidente about Shader, my emulation is pure CPU intensive usage, but still the best solution for platfom that haven't a shader HW extension.
take care...
-
Hello
It's my first beta about amos porting...it's not bug free, the editor don't work properly, and just the Help examples function ( not all of them)...is not possible to edit new file or save it..sometimes the program crash...
Please use only for demostration, use only the Help exapmples file (you can find them inside the 7z archive)..and don't excpet any kind of big speed..it's a prototype version..the new one is coming...be patience....
take care
-
Hi ebanite.
Just so I am clear, you are coding this in Delphi? How advanced is your interpreter? Does it support all of the AMOS instruction set or are you focusing on the graphics implementation details right now? Are you creating a link library for the emulation functions or are they inline with the code?
-
Your beta appears to be quite advanced. Excellent work!
-
thank's guys....
I'm coding in Delphi, the interpreter (beta version) for the moment can get around 120 istruction of the original set, but it can manage all istruction, and give the same output of amos pro ( now only for the standard extension), now i'm focusing on graphics emulation, it's is a static library because i'm working on emulation side only, but the plan is to have more dinamic library to cover different side of graphics ( emulated, native PC, enanched), that means the future version will be to able to cover any kind of solution for the user, from simple emulation of amiga HW to new graphics standards like 3d, shader and whatever.....
Now the project is start again from the root, because Amos Pro got a lot of limitatio on the sintaz (no structured type, no const, no dynamic variables etc), my next step after a good emulation is to expand the grammar of amos basic, put inside new type of object, non only simple var, but record type, class, advanced object and of course it will be able to compile it self....(but it's is so far for the moment)...
-
Hello ebanite,
Have you thought about endian dependency when developing structures and object-oriented programming? The Amos Bank format is the closest that Amos has to a structure format for using with network transmission and file buffering. Endian correction of the file formats is necessary if you want to be able to read files written with Amos in your interpreter. (Windows uses a little-endian byte ordering while Amiga uses big-endian.)
Our extension for the PC, Mac and Linux will, in the first version, use SDL Engine which is the runtime library used by sdlBasic. You can find it at http://www.sdlbasic.altervista.org (http://www.sdlbasic.altervista.org) but it's written in C. It includes network-endian (aka big endian) correction for the bank format and the Peek/Poke command sequences are tied to the bank structures so that it allows files and network packets to be cross-platform compatible.
I'm not trying to offend you and I haven't run your interpreter as I'm on my Macintosh at the moment, but if you plan on making your interpreter cross-platform, you'll need to think about some of this other stuff to make it compatible.
-
@samuraiCrow
For the moment is not matter speaking about portability of my project, my first goal is make a stable version for windows, now the interpreter translate any file that become from amos in lillte endian (only for the format that i know the structure), in automaitc way, when in the future i'll move to other plattaform i have to take care about byte rappresentaion. For unknow bank format (like custom data) the poke and peek istruction are self cognitive, they can understand if the bank is a standard amos bank or not, and choose the properly way how to read the internal data.
I developed a new amos format, that bring inside information about the native platform, in this way the interpreter will be able to convert the data structure in the corect way for the target platform , the new amos file format had a lot of new information inside, to become free from any kind of dependence, from old amos restrictions (like poor extension system), and from platform restrictions (endian format).
Another thing, i'm gonna to use less external library for my purpose, becouse sometimes the cross platfrom library had some problems in some kind of platform (sometimes they haven't the same final output, or some "call" are not implemented or not exist for a specific platform). my idea is to use when is possible native library from the target plattaform. It's done by a abstract low level library, that is coded for each platform, the rest of the code still the same for every OS.
May be when it will be time to migrate to another Os. i'm gonna to ask help to someone to porting the Low level library.
-
@ebanite
The plans you have for updating the syntax of AMOS are similar to the plans we have for Mattathias. And the plans you have for the graphics system is also similar to what we have. The major differences are that we are using C++ and LLVM to create a compiler and you are using Delphi to create an interpreter. So the real question is, can we effectively collaborate in light of these differences? It would be a shame to split the AMOS community over which new language is "the" sequel to AMOS. So at the core here is how I see it:
The things that you have that the Mattathias project could most use are:
1. A runtime library - which you already appear to have working quite well. We would need it to be portable though--possibly written in C/C++ or otherwise compiled to LLVM bit code.
2. An expanded AMOS BASIC grammar that includes object oriented features. This seems to be the reason you are doing your rewrite in the first place.
The things the Mattathias project has that you may be able to use are:
1. A portable framework.
2. A compiler with support for extensions and additional grammars.
3. Additional help working on emulating the Amiga specific bits of AMOS.
4. Additional help working out a new AMOS grammar.
5. Additional help working on making the runtime portable.
We seem to be on parallel headings. Do we join up or continue separately?
-
@sidewinder
Good question!!
The differences about ours projects are just in the programming language, and it may be is not a big problem, porting code from c/c++ to delphi and viceversa is not difficult, and of course i can do everythings alone, this project need a lot of time to become a real solid application, and becouse it, i can say yes i want joint up with your project.
But still some differences, the program style, anyone code in a self way, may be should be a big problem. Each of us start in different time and different way to porting amos to a new life. that for me sounds like a waste of time in the begining. Of course if i'm gonna join with your project. most of my work become obsolete and useless.
It's not properly simple, may be we can share information and cooperate to the same project, but i think i still to envelope my private project. I have to look about your framework, how your project is structured, and what style are you using inside code.
best regards
-
...I forgotten to put some files inside the 7z archive, some examples don't run becouse need a bob bank....
unzip this archive in the same folder where you have unzipped the last one...
take care....
-
I am glad we can work together. I look forward to seeing some of this runtime library. (Sidewinder and I was getting behind schedule as it was so having some added help is very welcome!) I can help you port your library to MacOSX and Linux but it has been years since I've programmed in Pascal and I'll have to learn the Object Pascal syntax to read your Delphi code.
-
...About translation from pascal to c/c++ can be my duty, i prefer Pascal syntax just for one reason (it's more readable then C), but i'm not scary about programming in c++...
-
@ebanite
Ok. That sounds good. I look forward to seeing it. :)
-
But still some differences, the program style, anyone code in a self way, may be should be a big problem. Each of us start in different time and different way to porting amos to a new life. that for me sounds like a waste of time in the begining. Of course if i'm gonna join with your project. most of my work become obsolete and useless.
Certainly, programming style is a unique aspect to each coder. Sam and I have different styles, but we also check eachother's work so that we are less likely to miss something. I don't believe that most of your work will become obsolete and useless. First of all, your runtime code appears to work quite well, and much of it can almos certainly be used. And secondly, I don't believe there is ever any wasted code. I can't count how many times I've restarted the Mattathias project and each time it become better and closer to being done.
It's not properly simple, may be we can share information and cooperate to the same project, but i think i still to envelope my private project. I have to look about your framework, how your project is structured, and what style are you using inside code.
You're more than welcome to continue with your private project. Our framework is structured into 3 parts:
1. The Grammar - a unique grammar is created by combining the extensions with the core language. Currently the grammar is an ASCII text file and combining grammars is a manual process, but the goal is to have this automated whenever the user adds or removed extensions. The grammar contains actions written in LLVM assembly language that output code which calls the runtime library.
2. The Parser - The grammar is compiled into a parser. This parser accepts the input file and parses it, executing the actions after each instruction is matched. It's the core of the compiler and it is what generates the code.
3. The Runtime - This is basically a library (static for now, but will probably be dynamic) that contains the code necessary for emulating the AMOS instructions. This is currently the least developed part of the project.
-
You said that you had started again different time, like me. in the early time, my interpreter was so close to the original amos, but that means no kind of expansion in the grammar was possible.
The new Project (still in beta as well)
i start again, i split like your project in 3 part my source :
the grammar/parser (it can apcet ascii or original amos source), it check the sintax and transform the source in a internal structured tokenized format (it can be run with interpreter immediactly).
the complire for the moment is missing, due to optmization on the interpreter, and i'm coding in same tyme a runtime library for original AGA amiga.
I'm coding an efficent and rich in option IDE for amos, so close to the modern IDE (like Delphi/borland c/c++ or visual family)
multieditor, monitor (debugger) included, and a lot of editor for graphics, music and other things.
My opinion is the new amos not only must have a good interpreter/compiler, it need a great IDE, the new programmer have to find comfortable the new Amos, and they don't become crazy about editor, compiler and linker, the great thing about amos was not only the huge istrusctions set, but the total integration.
My IDE is to close to become complete (when it become so stable i'll upload to show it).
let me how can hel you in your project..
-
Before we go much further, there are the few additional things to consider:
1. The Mattathias project is open source and uses the LGPL 3.0 license. In a nutshell, the liscence means that the code from the Mattathias project can be used freely by anyone in their own projects. The LGPL allows closed source projects to also use the code as long as the changes to the LGPL source code are made available. This means that you can use the Mattathias runtime library in your own project even if you do not make your own project open source. But any changes you make to the Mattathias runtime library must be released as open source.
2. What C++ compiler and environment do you use? Currently we are using GCC with the Code::Blocks IDE but we've also compiled the code with Visual Studio.
-
@ebanite
Your project certainly sounds a lot like my earlier attempts. May I ask, how does the extension system work in your latest beta?
Right now, perhaps we should take the discussion over to the Mattathias group at Yahoo (http://tech.groups.yahoo.com/group/mattathias/). Please join and we can discuss what is needed.
Also, please check your PMs. I sent you one earlier today.
-
@Sidewinder
i'm already joined with mattathias group, my yahoo Id is stefano.troncia
About how my extension system work:
The interpreter/(future compiler) had 2 way to take the sources
For native amos sources, the interpreter load a standard configuration file, where inside it, there is a complete list of amos token, the program try to match wich extension comes from original amos it has to use.
All original extension are splitted in many different dynamic library, and when the interepreter need one of those, simply load it.
The extended version (the new project) give to the programmer a new comand (uses like pascal /include like c)..
it's a examples
//
Uses Bobs,sprites,Music
//
in this way the user doesn't configure the "extension file configuration" by himself, this kind of job is done by the precompiler
Now the project can't compile and only the interpreter work just enough, it load at the begin all libraries definition are loaded, but not the code of the libraries.
When the program is tested, and it's free of error, the interpreter collect any call to the external library and load the code that it need.
The managment of extension is not properly done, because for the moment only the amos main library is supported, and all code are loaded when the interpreter is runnig. The plan is to reduce the memory usage, split any library in a series of micro routine, and make the smaller executable.
My c/c++ compiler is Borland C/C++ builder, for the simple reason it's share the same framework of delphi
-
@ebanite
I've removed the "moderated" tag on your account on the Mattathias mailing list so you can post without prior authorization. (Normally we require approval of the first post before allowing it to send in order to block spammers from getting in.)
Hopefully we'll be able to fix the parser to be able to accept extensions without requiring the "Uses" directive. What we planned to do was merge the partial parser pieces together to make the extensions part of the language transparently by using a PEG parser generator to rebuild the parser every time an extension is added. That way we can make the inclusion of libraries transparent to the programmer in much the same way as Amos does but without the problems of tokens clashing if they are defined twice in the code. Also static linking shouldn't be a problem if we use an IDE because under LGPL 3.0 statically linked libraries are independent of the license of the host application or any other libraries included.
-
After a long silence, i'm proud to show the very first picture of the new concept about Amos ( Amos for Windows), it still in beta version, but i reach those goal:
it can emulate old/fashion hardware to run any original amos program like was in a real amiga...
added aga support an rtg.
Extended syntax, OO extensions
new powerfull multieditor, class container and more
it can manage and load any amos file (configuration included)
what's is missing !!!!
a compiler (it's work but need optmization)
...for now i upload just a picture showing Amos for Windows runnig....
-
Hi
Great work, its looking great ! I cannot wait to test out Amos for Windows :-)
We only need an IDE, similar to this Java one, http://alvyn.sourceforge.net/
As a last resort, I had been thinking that if no updates to Amos occur soon, that we should look at the possibility of using Hollywood as the future language.
We would only need add functions that Hollywood is missing to make it 100% source code compatible.
If your Windows version works as you say, then this is a great achievement indeed !.
seriously, well done ! do you have a link to download ?
I am willing to do testing if need be.
cheers
-
@asymetrix
thanks a lot, but i'm so sorry about a beta version to download.
it's early to have one, i'm planning to make a demo version for tester not before the end of summer, there is lot things to do before.
I'm planning as well to uplopad some release before the pubblic 1.0 ( should be the first pubbilc version dated Later summer).
Because the project i managed only by me, that could be meaning some late on the final version.
Later on the windows version will be followed by other OS (AROS in primis,linux e macosx e 0s3.1), i'm not planning any version for morphos or amigaos4.0 due for the simple reason i don't like this flavour of amigaOs.
cross finger..
-
Its OK I understand :-)
Keep up the great work, we really do appreciate your efforts.
keep us posted
cheers,