|   |   | 
| (101 intermediate revisions by 7 users not shown) | 
| Line 1: | Line 1: | 
|  | ==Documentation==
 |  | [[Category:Voyager]] | 
|  | ===IBM Redbooks===
 |  | 
|  | * SG24-4630-00 OS/2 Warp (PowerPC Edition) A First Look
 |  | 
|  | * SG24-4639-00 OS/2 Warp (PowerPC Edition) Graphical Subsystem
 |  | 
|  | 
 |  | 
 | 
|  | We do have thefirst one digitaly,but not the second one. In case anyone finds that,let us know.
 |  | Please ignore this pages for the moment, this is old content about Voyager and we will replace that soon by some serious stuff :) | 
|  |  | [[User:Ktk|Ktk]] 13:39, 10 November 2008 (CET) | 
|  | 
 |  | 
 | 
|  | ===Darwin Documentation===
 |  | We currently discuss about the design on Voyager. This is separated into the following parts: | 
|  | There is plenty of documentation available about Darwin, a good start is [http://developer.apple.com/documentation/Darwin/Kernel-date.html Kernel Programming], which gives a nice overview about the designof thekernel.
 |  | 
|  | 
 |  | 
 | 
|  | ==Technologies to study==
 |  | 
|  | 
 |  | 
 | 
|  | * [http://www.freedesktop.org/wiki/Software_2fglitz glitz] - OpenGL interface for Cairo, so one could run Cairo directly on OpenGL, see [http://www.freedesktop.org/wiki/Xegl Xegl] for a diagram. |  | * [[Voyager_Discussion|Voyager Discussion]] - contains the ideas which evolved from quite some discussions | 
|  | * [http://www.usenix.org/events/usenix04/tech/freenix/nilsson.html Glitz: Hardware Accelerated Image Compositing Using OpenGL] and as [http://www.cs.umu.se/~c99drn/opengl_freenix04.pdf PDF]
 |  | 
|  | * [http://dri.freedesktop.org/~jonsmirl/graphics.html The State of Linux Graphics], [http://lwn.net/Articles/149917 comments] and more [http://groups.google.com/group/linux.kernel/browse_frm/thread/c2f4978ce450ed9a/2d8842acb180b581 comments]
 |  | 
|  | * [http://people.redhat.com/mclasen/Usenix04/notes.pdf Current gtk+ development]-among other topics about cairo integration and a new theme system
 |  | 
|  | * [http://people.freedesktop.org/~ajax/ddc2005.pdf X on GL] states very clearly, what has still to be done
 |  | 
|  | * [http://www.directfb.org DirectFB] with [http://www.directfb.org/index.php?path=Development/Projects/XDirectFB rootless XServer], [http://www.directfb.org/index.php?path=Development/Projects/DirectFBGL hardware accelerated OpenGL], [http://www.directfb.org/index.php?path=Development/Projects/GTK%2B GTK+ backend], [http://www.directfb.org/index.php/viewcvs.cgi/cairodfb an experimental Cairo backend], Qt backend, DirectVNC, SDL backend
 |  | 
|  | *[http://enlightenment.org/Main/Home/index.html enlightenment] and thecontained support libs
 |  | 
|  | * [http://www.gnustep.org/ GNUstep.org]
 |  | 
|  | 
 |  | 
 | 
|  | == Design Decisions ==
 |  | * [[Voyager_API_Basics|The Voyager API Basics]] - contains the basic ideas for the Voyager API | 
|  | Creating a binary compatible OS/2 clone may be tempting but is not strictly necessary. Important is theuser experience. Which toolkit should be used forprimary development?
 |  | 
|  | 
 |  | 
 | 
|  | ===2D API===
 |  | * [[Voyager_API_Design|The Voyager API Design]] - contains the design/coverage of the upcoming Voyager specific API | 
|  | * [http://cairographics.org Cairo]. Cairo has a PDF-like engine which seems to be inspired by Quartz ofMacOS X. |  | ** [[Desktop_class_list|Preliminary list of desktop classes]] - contains a separate (yet incomplete!) list of Desktop Classes | 
|  | * Cairo runs on almost everything, including OS/2 and X but also directly on OpenGL hardware with Glitz. So one could use it as acomplete GPI replacement without the need ofX one day. |  | 
|  | * To make things easier 24Bit screens should be the primary target. Hell it's 2005 today...
 |  | 
|  | 
 |  | 
 | 
|  | === MM ===
 |  | * [[Voyager_API_Design_Guide|The Voyager API Design and Implementation Guide]] - contains the methods and rules for implementing the Voyager API | 
|  | * The concept of IO procedures should be retained at least forfile IO and format converting. |  | 
|  | 
 |  | 
 | 
|  | ===Toolkits===
 |  | * [[Voyager_API_Roadmap|The Voyager API Roadmap]] - contains a list of issues/todos | 
|  |   |  | 
|  | *GTK+
 |  | 
|  | *GnuStep (look at Apples programs to see what's possible. Yes I know Apple uses Cocoa not Gnustep)
 |  | 
|  | *other?
 |  | 
|  |   |  | 
|  | ===SOM===
 |  | 
|  |   |  | 
|  | Dropping SOM for something better? Creating a poor mans SOM kernel isn't too difficult (Cinc: there's already a working prototype for the basic funtionality).
 |  | 
|  |   |  | 
|  | === WPS ===
 |  | 
|  | * The WPS should be designed with REXX scriptability in mind (like WPS-wizard addon)
 |  | 
|  |   |  | 
|  | === REXX ===
 |  | 
|  | * REXX should be implemented like AppleScript so controlling of applications from other apps is possible (commands not tied to one process).
 |  | 
|  | * [http://regina-rexx.sourceforge.net/ Regina] may be used as an interpreter. |  | 
|  |   |  | 
|  | === Backward Compatibility ===
 |  | 
|  | The question about backward compatibility is indeed a good one, it's risky to break with the current OS/2 APIfor religious reasons but one should have a look at that more from a technical point of view. The OS/2 API is not really modern anymore, programming directly on PM is much more work than using a modern toolkit like GTK+. |  | 
|  |   |  | 
|  | At the moment it's unfortunately unlikely that PM and WPS source get released by IBM.
 |  | 
|  |   |  | 
|  | Options:
 |  | 
|  |   |  | 
|  | * implement parts of PM and GPI on top of the new 2D API and try to integrate it with the toolkit choosen (same look & feel, clipboard support, D&D, etc. That's a lot of work, the question is if this is really necessary. We would have to do the same for supporting other toolkits like qt (which is a requirement). 
 |  | 
|  | * Use a VM and run OS/2 or eCS inside the VM. There are very promising opensource VMs like
 |  | 
|  | ** [http://www.cl.cam.ac.uk/Research/SRG/netos/xen/ XEN]
 |  | 
|  | ** [http://fabrice.bellard.free.fr/qemu/ QEMU]
 |  | 
|  |   |  | 
|  | XEN seems to be the most promising one at the moment because it will support dual core CPUs in the future so one can run the guest OS on a separate CPU core. So far one had to alter the guest OS in sourcecode but that changes at the moment because they integrate parts of QEMU sourcecode inside XEN to emulate those parts (memory allocation and such stuff).
 |  | 
|  |   |  | 
|  | == Questions==
 |  | 
|  | * the Xegl diagram mentioned above only shows the path of the graphics; the path of e.g. mouse and keyboard input is missing; that's not as trivial as it sounds (it has been [http://lwn.net/Articles/149783 missing in Xegl], when that was stopped); will we use OS/2-like driver model or wait for x.org 7.0 (currently RC1!) and take out the input system from there? Other sources (hotplug, ...)?
 |  | 
|  | * one good thing about OS/2 are the fast interactions when you click somewhere, like opening a folder or getting the focus on awindow. Why is that like this? We should try to keep that stuff fast.
 |  | 
|  | * do we want the traditional window manager<->application scheme? With the Gnome/KDE interfaces? Then we are deep in X again ...
 |  | 
|  | ** the question is if we can incooperate the WM functionality in GTK somehow. As far as I remember [http://fresco.org/ Fresco] implemented GTK API as well so one might have a look at that.
 |  | 
|  | ** IMO GTK runs on top ofa WM. The WM just gives GTK a surface to work with but manages where on screen this surface will be painted. Even OS/2 has something like a WM managing the windows for us.
 |  | 
Please ignore this pages for the moment, this is old content about Voyager and we will replace that soon by some serious stuff :)
Ktk 13:39, 10 November 2008 (CET)
We currently discuss about the design on Voyager. This is separated into the following parts: