Summer Of Code Ideas

From GNUstepWiki
Jump to navigation Jump to search

GNUstep is a mentoring organization of the Google Summer of Code.

In the list below you find the ideas that have been proposed as projects for the next Summer of Code. If you have a project that would be interesting, feel free to add it here.

If you find a topic that you want to work on, please apply directly through the SoC page [1]


Porting

Port WebKit (using GCC 4.x with ObjC++ support)

  • The WebKit team is willing to help whoever wants to take on this project, please see this email.
  • Implementation of CoreFoundation and CoreGraphics functions to support this
  • Implementation of WTF types in WebKit to interface with GNUstep

Difficulty: Very High; Experience needed: Expert at C/C++ and Core* Apple libraries)

General Improvements

Printing Support

  • Make printing work consistently.
    • Alpha support in printing (Cairo?)
    • Printing issues on Windows
  • Test printing on different platforms.

Difficulty: Medium; Required Experience: Familiarity with postscript and Objective-C, willingness to learn about the GNUstep backend

Finish input server

  • See this for more information

Difficulty: High; Required Experience: Objective-C, Cocoa

Finish Project Center

  • Improve integrated editor to have better support for tabs and emacs/vi like editing
  • Improve built-in debugger support on Windows and other platforms aside from Linux
  • Correct issues which exist on Windows such as:
    • make executable cannot be located unless the user changes it in PC directly.

Difficulty: Medium; Required Experience: Objective-C, Cocoa

Revamp Objective-C garbage collection and make it compatible with the Apple implementation

  • Help finish implementation of Garbage Collection in the libobjc2 runtime (tracing is the only thing left to do, per David Chisnall)

Difficulty: High; Required Experience: C

Cross-compilation from GNU/Linux to embedded devices

  • Compilation of GCC for the target architecture
  • Compilation of GNUstep frameworks for target architecture

Difficulty: Medium; Required Experience: GCC

Cross-compilation to GNU/Linux or Windows from Xcode

  • Compilation of GCC for the target architecture and OS.
  • Compilation of standard libs for the target architecture
  • Knowledge of how to build an SDK for Xcode
  • Compilation of GNUstep for target architecture and OS.

Difficulty: Medium; Required Experience: GCC, Mac OS X

GNUstepWeb

  • add script language support, etc

Difficulty: Medium; Required Experience: Web Development, Cocoa/ObjC

SimpleWebKit

  • help fix the following things:
    • event handling
    • better renderer
    • parsing quirks

Difficulty: Medium; Required Experience: Cocoa/ObjC

Screen change support

  • handle resizing of the screen etc. It's now common to run in virtual machines or with multiple displays with different sizes, so we need to gracefully handle changes of screen size while an application is running.

Difficulty: Medium; Required Experience: Cocoa/ObjC

AppKit (GUI)

  • Complete theming support ... go through each control in the gui and make sure it draws itself using the theming engine, adding methods to the theming engine as required. Update/improve Thematic.app to match by providing wysiwyg editine/cretion of themes for each control.
  • Modify save and open panel, and perhaps browsers, to support multiple roots as needed on ms-windows where the filesystem has multiple roots (eg D:\... or //host/...)
  • Fix focusing bugs/issues making sure GNUstep apps can be used with all window managers
  • Text System should be cleaned, profiled and finished. Many methods in NSLayoutManager are unfinished or unimplemented, so we currently cannot tweak the test system as much as the one provided by Cocoa. (Quentin Mathe)
  • We need NSTypeSetter, NSGlyphStorage, NSGlyphInfo, and NSGlyphGenerator implementations. If NSTypeSetter and NSLayoutManager were implemented, they would probably be used in Etoile. (Quentin Mathe)
  • NSTextTable, NSTextTableBlock, NSTextList, & NSTextBlock implementations would also bring the GNUstep text system in line with that of Cocoa as of Mac OS 10.4. The classes could be useful to build a powerful word processor. (Quentin Mathe)
  • NSOpenGL Classes could be improved, made compatible with current Cocoa implementations, and further tested. Note sure about that anymore. Feedback from people using these classes would be useful? (Quentin Mathe)
  • NSBitmapImageRep formats: Currently, we support reading and writing for TIFF, GIF, JPEG, PNG, PNM (reading-only). We would like to complete NSEPSImageRep and NSPDFImageRep (with Cairo?). SVG reading and writing support, would be nice too. (Quentin Mathe)
  • NSDatePicker (and obligatory companion NSCell subclass) implementation.
  • NSFormatter isn't working very well at this time. Not sure anymore about this one… (Quentin Mathe)
  • Backend: especially xlib but also art could use performance improvements. NSImageView scrolling on xlib comes to my mind for example. (shouldn't improvements focus on the preferred, cairo backend rather than the deprecated ones?)
  • improve our RTF parser, to be able to correctly load OO and MS-Office created RTFs. Add support for reading NeXT RTFDs. Correct loading of Apple RTFs including char encoding

Foundation (Base)

  • Improve testsuite to have regression tests cover much more of base library.
  • NSDateComponents & NSCalendar implementation.
  • Implement Apple's scripting/apple-events classes as a subproject of the base library.
  • Complete separation of gnustep specific extensions from Apple APIs and implement new Apple methods missing from existing classes for compatibility.
  • Complete implementation of Apple's latest URL handling classes based on NSStream... testing on mswindows as well as unix.
  • Implement CoreFoundation on Base
  • Now that Apple have XML based keyed coding, implement a version of Distributed Objects to talk directly to Apple applications (Nicolaus has done some work towards this in mySTEP).

Core Data

  • Saso Kiselkov started implementing this framework and now hosted here [2] as part of GNUstep. However, NSManagedObjectContext & NSPersistentStoreCoordinator have yet to be tackled according to his web page. Presumably NSPersistentDocument also needs to be implemented.
  • DataBuilder.app needs some final graphics improvements. And, should become able to read and write model files from Xcode.

Misc

  • Create an AJAX Framework for GNUstepWeb
  • There's a truck load of stuff in WO 5.4.1 that GNUstepWeb is missing: [6]
  • Create Objective-C bindings for DBUS
  • User your yacc/bison and (f)lex knowledge to finalize a source code translator for ObjC-2.0 to ObjC-1.0 [7]
  • OpenGL extensions management API: before using an OpenGL extension a program must first determine its availability. The mechanism for doing this is platform-specific and libraries such as w:GLEW and w:GLEE exist to simplify the process. The target of this project is a multiplatform Objective-C wrapper around OpenGL platform-specific functions.
  • HID API: GNUstep can only handle the usual human interface devices (HID) : keyboard and mouse. A multiplatform framework would allow GNUstep application to handle joystick, graphic tablet or 3D device.

GAP (GNUstep Application Project) Ideas

  • Debug and Complete FlexiSheet, making sure it works on Cocoa as expected and noting incompatibilities with GNUstep. Those should be either fixed for both platforms (FlexiSheet portability of code improvment) or noted as a bug or missing feature in GNUstep.
  • implement (Extract from Addresses) an iSync compatible framework, its corresponding managment application and then integrating it with AddressBook (which already has part of such framework). The goal would be to have syncronization of Addresses (but in future, perhaps calendar, Vespucci bookmarks) gnustep to gnustep, gnustep to mac and gnustep to .Mac/MobileMe by having such account.
  • porting of Applications from OpenStep or Cocoa abandonware. This needs to be checked on application-per-application: License and dependencies can be a problem as defining the scope of the project well.
  • Some miscellaneous applications that run a Cocoa GUI could be ported to GNUstep: