| BRANCH | STATUS | 
|---|---|
| v2.1 | |
| v2 | |
| v1.1.1 | 
Greatly simplified version of GsDevKit_home
- bin directory of scripts implemented with superDoit and 3.7.0 for solo scripts and GsHostProcess.
- Stone directory modeled after GsDevKit_home, but configurable for folks with different needs. There a varient of templates that are used to specify directory structure for stones, git repositories, etc.
- Registry of stones so that stones and git repositories can be located anywhere.
- If you are using tODE I think you should continue using GsDevKit_home
Recommended for use with GemStone 3.7.1 and 3.7.2, including a number of bugfixes. Uses 3.7.1 with superDoit:v4.2. Includes support for using Rowan V3. tests/test_rowanV3.sh is an (evolving) example that can be used to setup an environement for using Rowan V3 and JadeiteForPharo for development.
Note that Rowan V3 and JadeiteForPharo are still undergoing heavy development.
Stable version intended for use with superDoit:v4.1, smalltalkci:master; GemStone 3.7.0 is used for .solo scripts, allowing v2 to support stones as old as 3.6.0.
Supported Rowan v3 stone versions 3.7.0 and newer. Tested against 3.7.0_rowanv3-Alpha Supported non-Rowan stone versions 3.6.0 though 3.7.0
Development version intended for use with superDoit:v4.1 and GemStone 3.7.0 for .solo scripts. Supported Rowan v2 stone versions 3.6.4 and newer, tested through 3.7.0. Supported Rowan v3 stone versions 3.7.0 and newer. tested through 3.7.0 Supported non-Rowan stone versions 3.5.3 and older (with 20.04 the limiting factor)
Greatly simplified version of GsDevKit_home
- bin directory of scripts implemented with superDoit and 3.6.5 for solo scripts and GsHostProcess ala the .solo battery test drivers used internally
- stone directory modeled after GsDevKit_home, but configurable for folks with different needs … some sort of template for definition of directory structure
- registry of stones so that stones can be located anywhere
- standard location for git repos
- if you are using tODE I think you should continue using GsDevKit_home
Shell script:
# Run that in a base directory where all of your GemStone stuff will be placed
# Get the source code, and checkout the needed branch (newest is v2.1 at the time of writing)
git clone [email protected]:GsDevKit/GsDevKit_stones.git -b v2.1
# Run the installation script from within the base directory
./GsDevKit_stones/bin/install.sh
# Setup your environment (you might want to persist that in /etc/profile.d/... or similar)
export PATH=`pwd`/superDoit/bin:`pwd`/GsDevKit_stones/bin:$PATH
export STONES_DATA_HOME=$XDG_DATA_HOME
if [ "$STONES_DATA_HOME" = "" ] ; then
	# on Mac ensure the directory you choose exists
	export STONES_DATA_HOME=$HOME/.local/share
fi
# First check, if installation is all good. You will get a report of some GemStone installation facts
versionReport.soloGsDevKit_stones maintains a registry data structure based on the XDG Base Directory Specification. On Linux machines, the default location for application specific data is $HOME/.local/share and $XDG_DATA_HOME can be used to optionally define an alternate location. On Mac machines, the XDG Base Directory Specification is not defined.
Therefore to simplify the coding and allow for the creation of short-leved registry structures, The environment variable STONES_DATA_HOME is used to define the root directory for GsDevKit_STONES applications. On Linux, STONES_DATA_HOME defaults to $HOME/.local/share. On Mac, STONES_DATA_HOME must be defined.
Pseudo shell script (go through it manually and read the comments):
# Setup some config values (use your own here!)
registryName=`hostname`
projectSetName="devkit"
gemstoneProductsDirectory="/home/dhenrich/_stones/gemstone"
projectsDirectory="/home/dhenrich/_stones/git/"
stonesDirectory="/home/dhenrich/_stones/stones"
todeHome="/home/dhenrich/_stones/tode"
# Print those config values (Just for the beauty of viewing all at once)
echo "
 registry:    $registryName
 project set: $projectSetName 
 products:    $gemstoneProductsDirectory
 projects:    $projectsDirectory 
 stones:      $stonesDirectory
 tode:        $todeHome"
# Create a (first) registry. You can define multiple registries. Each one is like a global namespace for your GemStone projects.
createRegistry.solo $registryName
# Create a (first) empty project set, one for SSH and one for HTTPS connections
createProjectSet.solo --registry=$registryName --projectSet=$projectSetName --ssh --empty
createProjectSet.solo --registry=$registryName --projectSet=${projectSetName}_https --https --empty
# Save the project directory in the registry, where the git repositories will be stored
registerProjectDirectory.solo --registry=$registryName --projectDirectory=$projectsDirectory
# Get the project sources for a set of projects, through git clone. (Which is empty initially, so no need for that really)
cloneProjectsFromProjectSet.solo --registry=$registryName --projectSet=$projectSetName 
# Save the directory, where the "products" (= The actual GemStone software) will be downloaded to.
registerProductDirectory.solo --registry=$registryName \
                              --productDirectory=$gemstoneProductsDirectory
# Download a GemStone version. Use your GemStone version(s) here.
downloadGemStone.solo --registry=$registryName 3.7.2
# ... or if you already have (multiple) downloaded GemStone products (e.g. from a GsDevKit_home installation):
# Register full set of previously downloaded product trees
registerProduct.solo --registry=$registryName \
                     --fromDirectory=$GS_HOME/shared/downloads/products
# ... or if you have a single GemStone product at some other location:
# register named GemStone version using path to product tree
registerProduct.solo --registry=$registryName \
                     --productPath=/bosch1/users/dhenrich/_work/d_37x/noop50/gs/product 3.7.0
# Save default stones directory in the registry. That's where your stone data will be stored.
registerStonesDirectory.solo --registry=$registryName \
                             --stonesDirectory=$stonesDirectory
# register shared tODE directory
registerTodeSharedDir.solo --registry=$registryName  \
                           --todeHome=$todeHome \
                           --populate
# View the list of all registries
registryReport.solo
# View one particular registry details
registryReport.solo --registry=$registryName
Shell script:
# create stone in default stones directory
createStone.solo --registry=$registryName --template=default --start gs_366 3.6.6
# create stone in custom stones directory
createStone.solo --root=/bosch1/users/dhenrich/_stones/stones --registry=$registryName --template=default --start cust_3.6.6 3.6.6 
# create a tode stone in default stones directory (tODE loaded)
createStone.solo --registry=rogue --force --template=default_tode --start seaside_370 3.7.0
# create a rowan_v3 stone in default stones directory
createStone.solo --registry=rogue --template=minimal_rowan --start rowan_370_v3 3.7.0_rowanv3
registryReport.solo --registry=$registryNameBash script:
createProjectSet.solo --registry=rogue --projectSet=rowan --empty
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=Rowan --revision=masterV3.0 \
                      [email protected]:GemTalk/Rowan.git
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=Rowan --revision=masterV3.0 \
                      --remote=gs [email protected]:Rowan
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=RemoteServiceReplication --revision=main \
                      [email protected]:GemTalk/RemoteServiceReplication.git
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=RowanClientServices --revision=eric_component_V3.0 \
                      [email protected]:GemTalk/RowanClientServices.git
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=RowanClientServices --revision=eric_component_V3.0 \
                      --remote=gs [email protected]:RowanClientServices
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=PharoGemStoneFFI \
                      [email protected]:GemTalk/PharoGemStoneFFI.git --revision=main
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=JadeiteForPharo \
                      [email protected]:GemTalk/JadeiteForPharo.git --revision=main
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=Announcements \
                      [email protected]:GemTalk/Announcements.git --revision=main
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=GsDevKit_stones \
                      [email protected]:GsDevKit/GsDevKit_stones.git --revision=v1.1.1
updateProjectSet.solo --registry=rogue --projectSet=rowan --projectName=GsDevKit_stones \
                      --remote=gs [email protected]:GsDevKit_stones --revision=v1.1.1Bash script:
GDKStonesRegistry {
	#name : 'rogue',
	#parentRegistryName : 'rogue',
	#parentRegistryPath : '$STONES_DATA_HOME/gsdevkit_stones/registry.ston',
	#stones : {
		'seaside_370' : '$STONES_DATA_HOME/gsdevkit_stones/stones/rogue/seaside_370.ston',
		'gs_366' : '$STONES_DATA_HOME/gsdevkit_stones/stones/rogue/gs_366.ston',
		'rowan_370_v3' : '$STONES_DATA_HOME/gsdevkit_stones/stones/rogue/rowan_370_v3.ston'
	},
	#todeHome : '/home/dhenrich/_stones/tode',
	#stonesDirectory : '/home/dhenrich/_stones/stones',
	#sessions : { },
	#productDirectory : '/home/dhenrich/_stones/gemstone',
	#projectDirectory : '/home/dhenrich/_stones/git',
	#products : {
		'3.7.0' : '/secure/users/dhenrich/work/l_37x/noop50/gs/product',
		'3.6.6' : '/home/dhenrich/_homes/rogue/_home/shared/downloads/products/GemStone64Bit3.6.6-x86_64.Linux',
		'3.6.5' : '/home/dhenrich/_stones/git/superDoit/gemstone/products/GemStone64Bit3.6.5-x86_64.Linux',
		'3.7.0_rowanv3' : '/home/dhenrich/_homes/rogue/_home/shared/downloads/products/GemStone64Bit3.7.0_rowanv3-x86_64.Linux'
	},
	#projectSets : {
		'devkit' : '$STONES_DATA_HOME/gsdevkit_stones/projectSets/rogue/devkit.ston'
	},
	#templates : {
		'default_tode' : '$STONES_DATA_HOME/gsdevkit_stones/templates/default_tode.ston',
		'minimal_rowan' : '$STONES_DATA_HOME/gsdevkit_stones/templates/minimal_rowan.ston',
		'default_rowan' : '$STONES_DATA_HOME/gsdevkit_stones/templates/default_rowan.ston',
		'default' : '$STONES_DATA_HOME/gsdevkit_stones/templates/default.ston',
		'minimal_seaside' : '$STONES_DATA_HOME/gsdevkit_stones/templates/minimal_seaside.ston',
		'minimal' : '$STONES_DATA_HOME/gsdevkit_stones/templates/minimal.ston'
	}
}
Used by smalltalkCI.
Development aimed at smalltalkCI ... namely fixing issue #322.
- vX
- vX.Y
- vX.Y.Z or vX.Y.Z-id
Stable production branch.
X is incremented whenever there is a breaking change. vX.Y and vX.Y.Z branches are merged into the VX branch, when development is complete on the feature or patch.
Stable feature/bugfix candidate branch.
Y is incremented whenever work on a new feature or bugfix is started. vX.Y branches are merged into the VX branch when development is complete.
Primary work takes place on a vX.Y.Z branch and the VX.Y.Z branch is merged into the VX.Y branch at stable points, so if you want to have early access to a feature or bugfix, it is relatively safe to use this branch in production.
Unstable development branch.
Z is incremented whenever work on a new feature or bugfix is started. A pre-release may be used to further identify the purpose of the work.
Primary work takes place on this branch and cannot be depended upon to be stable.