[Cogl] Release Cogl 1.10.0 (release)

Neil Roberts neil at linux.intel.com
Tue Mar 20 10:29:41 PDT 2012


Good news, everyone!

A new Cogl release (1.10.0) is now available:

LATEST NEWS
-------------------------------------------------------------------------------

Cogl 1.10.0                                                        2012-03-20

  • List of changes since Cogl 1.9.8

  » Add cogl_framebuffer_draw_[*_]rectangle functions. These can be
    used as a replacement for cogl_rectangle in the 2.0 API to avoid
    the global framebuffer stack.
  » Fixed flushing the point size with the GL driver when using GLSL.
  » Added the missing cogl_is_onscreen and cogl_is_framebuffer functions.
  » Added cogl_quaternion_init_from_quaternion and
    cogl_quaternion_init_from_matrix to the public headers.
  » Make cogl_has_feature available when only
    COGL_ENABLE_EXPERIMENTAL_API is defined.
  » Add cogl_framebuffer_read_pixels. This is a convenience wrapper
    around cogl_framebuffer_read_pixels_into_bitmap to read directly
    into an application's buffer.
  » Added a public cogl_bitmap_new_for_data function. This can be used
    for example to call cogl_framebuffer_read_pixels_into_bitmap to
    read directly into an application's buffer with an unusual
    rowstride.
  » Visual Studio build fixes
  » Translation updates

  • List of bugs fixed since Cogl 1.9.8

    https://bugzilla.gnome.org:

    #669122 - Clipped redraws and tearing
    #671984 - cogl glyph cache uses uninitialised variable.
    #671985 - cogl matrix stack has a use after realloc
    #672038 - Move the fallback define for GL_PACK_INVERT_MESA
    #672174 - cogl_path_curve_to second parameter ignored
    #672243 - Drive by leak fix when code spelunking

Many thanks to:

  Chun-wei Fan
  Robert Bragg
  Dave Airlie
  Matej Urbančič
  Adam Matoušek
  Adel Gadllah
  Alexander Shopov
  Bruce Cowan
  Daniel Nylander
  Dénes Almási
  Duarte Loreto
  Enrico Nicoletto
  Fran Diéguez
  Khoem Sokhem
  Nilamdyuti Goswami
  Piotr Drąg
  Ray Strode
  Ryan Lortie
  Yuri Myasoedov
  甘霖

FETCHING THE RELEASE
-------------------------------------------------------------------------------

Tarballs can be downloaded from:

  http://source.clutter-project.org/sources/cogl/1.10/
  http://download.gnome.org/sources/cogl/1.10/

SHA256 Checksum:

23a5dbb15028600a8e4c1adf20a1e29b0e1255bc0455b25a4dfe16f3832ebfd3
  cogl-1.10.0.tar.bz2

Additionally, a git clone of the source tree:
  git clone git://git.gnome.org/cogl

will include a signed 1.10.0 tag which points to a commit named:
  724609f945f1d4864057086e73d6ca562f8ee323

which can be verified with:
  git verify-tag 1.10.0

and can be checked out with a command such as:
  git checkout -b build 1.10.0

DESCRIPTION
-------------------------------------------------------------------------------

Cogl is a small open source library for using 3D graphics hardware for
rendering. The API departs from the flat state machine style of OpenGL and is
designed to make it easy to write orthogonal components that can render without
stepping on each others toes.

As well as aiming for a nice API, we think having a single library as opposed
to an API specification like OpenGL has a few advantages too; like being
able to paper over the inconsistencies/bugs of different OpenGL
implementations in a centralized place, not to mention the myriad of OpenGL
extensions. It also means we are in a better position to provide utility
APIs that help software developers since they only need to be implemented
once and there is no risk of inconsistency between implementations.

Having other backends, besides OpenGL, such as drm, Gallium or D3D are
options we are interested in for the future.


REQUIREMENTS
-------------------------------------------------------------------------------

Cogl currently only requires:

  • GLib ≥ 2.28.0
  • OpenGL ≥ 1.3 (or 1.2 + multitexturing), or OpenGL ES 2.0 (or 1.1)
  • GLX, AGL, WGL or an EGL implementation

Cogl also has optional dependencies:

  • GDK-Pixbuf ≥ 2.0
     - for image loading
  • Cairo ≥ 1.10
     - for debugging texture atlasing (debug builds only)

The optional Cogl Pango library requires:
  • Cairo ≥ 1.10
  • PangoCairo ≥ 1.20

On X11, Cogl depends on the following extensions

  • XComposite ≥ 0.4
  • XDamage
  • XExt
  • XFixes ≥ 3

When running with OpenGL, Cogl requires at least version 1.3
or 1.2 with the multitexturing extension. However to build Cogl
you will need the latest GL headers which can be obtained from:

  http://www.khronos.org

If you are building the API reference you will also need:

  • GTK-Doc ≥ 1.13

If you are building the additional documentation you will also need:

  • xsltproc
  • jw (optional, for generating PDFs)

If you are building the Introspection data you will also need:

  • GObject-Introspection ≥ 0.9.5

GObject-Introspection is available from:

  git://git.gnome.org/gobject-introspection

If you want support for profiling Cogl you will also need:

  • UProf ≥ 0.3

UProf is available from:

  git://github.com/rib/UProf.git



DOCUMENTATION
-------------------------------------------------------------------------------

The 1.x API is documented here:
  http://docs.clutter-project.org/docs/cogl/1.10
The experimental 2.0 API is documented here:
  http://docs.clutter-project.org/docs/cogl-2.0-experimental/1.10


RELEASE NOTES
-------------------------------------------------------------------------------
  - This Cogl release exports a 1.x API (For third-party Clutter
    developers to write custom actors) and an experimental 2.0 API which
    allows standalone application development.

  - Internally Clutter depends on the Cogl 2.0 experimental API so we maintain
    runtime compatibility between the 1.x API and experimental 2.0 APIs, which
    means developers can mix-and-match their use of the APIs in the same
    process.  API selection is done per-file by including a line like: '#define
    COGL_ENABLE_EXPERIMENTAL_2_0_API' before including cogl.h or clutter.h.

  - We recommend using the 2.0 API if you don't mind updating your code once in
    a while as this API evolves and stabilizes. We promise not to break the 2.0
    API during a 1.x stable cycle and hope that will encourage people to
    experiment with it and give critical feedback! For example after releasing
    1.8, the 2.0 API will be stable for 1.8.1, 1.8.2, 1.8.3 etc, but may update
    for 1.9/1.10.

  - Because we export the 1.x and 2.0 APIs from one libcogl.so the library
    versioning, and thus ABI, can only be considered as stable as our 2.0 API - 
    i.e. during a stable release 1.x cycle.

  - Please report bugs using the Cogl Bugzilla product, at:
    http://bugzilla.gnome.org/enter_bug.cgi?product=cogl


More information about the Cogl mailing list