/Grease

The Grease Portability Library

Primary LanguageSmalltalk

IMPORTANT: Since version 1.3.0, this is the main repository of Grease. Versions older than 1.1.9 can only be found in the Smalltalkhub repository. Check out the releases list for all version numbers in this repository.

The Grease Portability Library

Grease enhances the ANSI Smalltalk standard. With only a few exceptions, we assume platforms are fully ANSI-compliant. Platforms want to support Seaside and standardization makes this easier for the project’s developers and its porters.

Grease defines expected APIs with unit tests. Platforms can quickly determine if they are compatible and users can examine the tests to determine exactly which behaviours they can count on.

Grease takes a pragmatic approach to compatibility. Sometimes a method behaves so differently on two platforms, for example, that we are forced to avoid it or to standardize on a new selector. To get standard exception signaling on all platforms, Grease is forced to provide special exception classes that can be subclassed. Sometimes we need to put “right” aside and settle, instead, on a solution that can be implemented everywhere.

Grease tries to be concise and consistent. Despite its pragmatic approach, we still want to be “right” as much as possible. Because it’s hard to remove functionality once it has been added, we need to carefully consider each addition before proceeding. We’re moving slowly and looking for methods that are commonly used and that have clear names and semantics.

Grease does not try to solve all problems. We are not testing Sockets or HTTP clients. We don’t expect platforms to have standard SSL or graphics libraries. Its scope may grow over time, but for now we’re focusing on extending the functionality of the core classes defined in the ANSI standard (collections, exceptions, streams, blocks, etc.) and on other pieces of functionality that are critical to the Seaside project (e.g. random number generation and secure hashing).

Grease is widely adopted. Implementations exist already for all platforms that support Seaside 3.x. As well as Seaside, new versions of Magritte, Pier, and Monticello are already being implemented on top of Grease.

Platform compatibility and Travis builds

The latest Grease version is supported on the following platforms and versions, which are tested using Travis CI builds:

Squeak Pharo GemStone
Build status: Squeak-5.2 Build status: Pharo64-9.0 Build status: Gemstone-3.6.0
Build status: Squeak-5.1 Build status: Pharo64-8.0 Build status: Gemstone-3.5.5
Build status: Pharo64-7.0 Build status: Gemstone-3.4.5
Build status: Pharo-6.1 Build status: Gemstone-3.3.9
Build status: Gemstone-3.2.17
Build status: Gemstone-3.1.0.6

Builds via github actions: smalltalkCI

Installation

Prerequisite on Squeak

Make sure you have the MetacelloPreview version, otherwise the load will not work.

Squeak and Pharo (6.0 or newer)

Load the latest code from master (i.e. stable):

Metacello new
    baseline: 'Grease';
    githubUser: 'SeasideSt' project: 'Grease' commitish: 'master' path: 'repository';
    load

-or-

Load a specific version: (See Releases for a list of versions)

Metacello new
    baseline: 'Grease';
    githubUser: 'SeasideSt' project: 'Grease' commitish: 'v1.3.0' path: 'repository';
    load

-or-

Legacy: load older versions from Smalltalkhub:

Metacello new
    configuration: 'Grease';
    repository: 'http://www.smalltalkhub.com/mc/Seaside/MetacelloConfigurations/main';
    version: '1.0.0';
    load

GemStone

Grease is part of the GLASS setup. You can upgrade your version of Grease using GsUpgrader. GsUpgrader works on all versions of GemStone against all versions of GLASS:

Gofer new
  package: 'GsUpgrader-Core';
  url: 'http://ss3.gemtalksystems.com/ss/gsUpgrader';
  load.
(Smalltalk at: #GsUpgrader) upgradeGrease.

Pharo (5.0 or older)

The compatibility for Pharo < 6.0 is not maintained for new releases. If you need grease in Pharo < 6, we recommend to either update your pharo version or reference the latest release compatible with your version of Pharo:

  • Pharo <4: v1.4.1
  • Pharo 5 & 6: v1.6.1

For Pharo versions < 3.0, make sure you have the MetacelloPreview version, otherwise the load will not work.

Load the latest compatible release:

Metacello new
    baseline: 'Grease';
    githubUser: 'SeasideSt' project: 'Grease' commitish: 'v1.4.1' path: 'repository';
    load

-or-

Legacy: load older versions from Smalltalkhub:

Metacello new
    configuration: 'Grease';
    repository: 'http://www.smalltalkhub.com/mc/Seaside/MetacelloConfigurations/main';
    version: '1.0.0';
    load

In case you need a specific feature for an older version, it is still possible to create a new release by branching starting from the tagged commit of the compatible version.