Google Summer of Code Ideas

This page lists our project ideas for Google Summer of Code 2014.

Before applying for a project
When applying for a project
  • Include your IRC nick in your application, so that we recognise you. We strongly recommend that you communicate with us on #netsurf before submitting an application.
  • Tell us about yourself, your experience, and why you want to work with us.
  • Describe the project you want to do, and how you plan to go about doing it. Do not simply copy the project description from the ideas page.
  • Create a set of project milestones (ranging from a couple to maximum 10) with expected completion dates. This will be useful for you as guidance and for us to set our expectations right.
  • Describe how you will test your contributions.
  • We expect GSoC to be mostly equivalent to a full-time job. Therefore, please tell us if you have any other demands on your time.
During the project
  • Most of NetSurf team communication happens via #netsurf IRC during evenings and nights (CET). We expect you to join in on a regular basis for help, discussions and project updates. Note that you're not restricted to speaking to your assigned mentor; the whole development team are willing to help wherever they can.
  • Keep NetSurf's project goals in mind, especially the first point.

There is some more information in the GSoC section of our wiki. Note particularly the student guidelines.

Please get in touch our project idea appeals to you or if you have your own idea for either NetSurf or one of NetSurf's libraries. Come and chat to the developers in the NetSurf IRC channel or post to the developer mailing list.

Update Core Web Technology Libraries

This is a project to improve and add features to the NetSurf project's core web-technology libraries. These libraries are MIT licenced and are available to, and used by, other projects. The libraries in question are:

Note that this is a single project, and both phases are part of it.

Project Outline

Phase 1

LibDOM: Implement missing specialisations of HTMLElement

HTMLElement is the base class for representing HTML elements in the DOM. It contains the common data which applies to all HTML elements. Most elements, however, contain additional data or have specialised data processing requirements (for example, a Form element has an action attribute). These elements are represented in the DOM by specialised subclasses of HTMLElement.

In the LibDOM implementation, many of these specialised subclasses have not been implemented. This means that many elements are still represented by the base HTMLElement class and the specialised data and behaviours are not available.

The task in this phase, then, is to identify the missing/unimplemented HTMLElement specialisations in the LibDOM source tree, and provide implementations for them. The DOM Level2 specification defines the expected attributes and behaviours of the HTMLElement subclasses and should be used as a reference for the implementation.

We consider this task to be fairly easy to complete. The number of missing specialisations is quite large, so do not be surprised if it takes longer than expected! We do not expect this phase to fill an entire summer, however.

Expected outcome: a complete implementation of the HTMLElement DOM classes, which enable the HTMLElement tests in the LibDOM testsuite to pass.

Existing code: libdom/src/html.
Specification: Level 2 Document Object Model HTML, DOM Standard

Phase 2

Either one of the following options. We expect the decision on the direction of this phase to be made by the student and mentors, depending upon the interests of the student, the ability demonstrated in completing Phase 1, and the time remaining. We do not anticipate that there will be time for a student to complete both items listed here, but the work is there if a gifted student makes good progress.

LibHubbub: Update to match current specification

LibHubbub is the NetSurf project's HTML parser. It is designed to implement the HTML5 parsing algorithm.

The current implementation of LibHubbub, however, is out-of-date with respect to the specification. This means that the DOM tree produced by parsing an HTML document using LibHubbub is not equivalent to that produced by a fully-conformant HTML5 parser.

This task involves identifying the differences between the behaviour implemented in LibHubbub and the expected behaviour defined by the specification. Once these differences have been identified, the implementation in LibHubbub should be brought in line with the specification.

We expect this task to require a great deal of attention to detail. The initial stage of identifying the places where LibHubbub's implementation does not match the specification is crucial to the success of this task.

Expected outcome: a detailed summary of the deficiencies in the LibHubbub implementation and a decent amount of progress towards rectifying them, with passing tests in the testsuite.

Existing code: libhubbub/src
Specification: HTML5 Parsing

LibCSS: add support for CSS 3 properties

LibCSS is the NetSurf project's CSS parser and style selection engine. It currently has support for parsing and selecting:

  • CSS 2.1
  • CSS 3 Namespaces
  • CSS 3 Selectors
  • CSS 3 Color
  • CSS 3 Multi-column Layout (parsing only)
  • CSS 3 Writing Modes (writing-mode property only)

This task involves adding support for parsing and selecting properties defined in other CSS 3 module specifications. As CSS 3 is comprised of a very broad suite of components, the precise selection of which modules to target will be decided as part of the task definition with the student.

Expected outcome: a decision about which CSS 3 component modules to implement; an implementation of the relevant property parsing and selection rules, along with passing test cases for the LibCSS testsuite.

Existing code: libcss/src
Specification: CSS Specs

Skills required: Experience of the C programming language
Skills desirable: HTML, DOM, CSS

Mentors

For mentors we have five of NetSurf's core developers: