summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Maw <richard.maw@codethink.co.uk>2014-01-22 13:39:34 +0000
committerRichard Maw <richard.maw@codethink.co.uk>2014-01-22 15:47:52 +0000
commit52e2b4aa1463e0247b6d1ef1653bbacc5dc0e02c (patch)
tree37256d62a12b00635ef7f76dd9af56a0731d5611
parent11894bcd780ff0134b142c34c8c7fbf421c4d921 (diff)
downloadmorph-52e2b4aa1463e0247b6d1ef1653bbacc5dc0e02c.tar.gz
yarns: Move system artifact inclusion implementation
This moves the GIVEN system $system uses $artifacts from $source to the generic implements section, and the Python implementation into the edit-morph helper script.
-rwxr-xr-xscripts/edit-morph29
-rw-r--r--yarns/implementations.yarn12
-rw-r--r--yarns/splitting.yarn17
3 files changed, 42 insertions, 16 deletions
diff --git a/scripts/edit-morph b/scripts/edit-morph
index 967bbc13..acb33b7e 100755
--- a/scripts/edit-morph
+++ b/scripts/edit-morph
@@ -1,5 +1,5 @@
#!/usr/bin/env python
-# Copyright (C) 2013 Codethink Limited
+# Copyright (C) 2013-2014 Codethink Limited
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@@ -18,6 +18,7 @@
import cliapp
import os
import re
+import yaml
import morphlib
@@ -200,4 +201,30 @@ class EditMorph(cliapp.Application):
return result
+ def cmd_set_system_artifact_depends(self, args):
+ '''Change the artifacts used by a System.
+
+ Usage: MORPHOLOGY_FILE STRATUM_NAME ARTIFACTS
+
+ ARTIFACTS is an English language string describing which artifacts
+ to include, since the primary use of this command is to assist
+ yarn tests.
+
+ Example: edit-morph set-system-artifact-depends system.morph \
+ build-essential "build-essential-minimal,
+ build-essential-runtime and build-essential-devel"
+
+ '''
+
+ file_path = args[0]
+ stratum_name = args[1]
+ artifacts = re.split(r"\s+and\s+|,?\s*", args[2])
+ with open(file_path, "r") as f:
+ d = yaml.load(f)
+ for spec in d["strata"]:
+ if spec.get("alias", spec["name"]) == stratum_name:
+ spec["artifacts"] = artifacts
+ with open(file_path, "w") as f:
+ yaml.dump(d, f)
+
EditMorph().run()
diff --git a/yarns/implementations.yarn b/yarns/implementations.yarn
index 89f30c3e..7e9b7275 100644
--- a/yarns/implementations.yarn
+++ b/yarns/implementations.yarn
@@ -797,3 +797,15 @@ Implementations for tarball inspection
IMPLEMENTS THEN tarball (\S+) doesn't contain (.*)
! tar -tf "$DATADIR/$MATCH_1" | grep -Fe "$MATCH_2"
+
+Implementations for morphology manipulation
+==========================================
+
+Altering morphologies in their source repositories
+--------------------------------------------------
+
+ IMPLEMENTS GIVEN system (\S+) uses (.+) from (\S+)
+ "$SRCDIR/scripts/edit-morph" set-system-artifact-depends \
+ "$DATADIR/gits/morphs/$MATCH_1.morph" "$MATCH_3" "$MATCH_2"
+ run_in "$DATADIR/gits/morphs" git add "$MATCH_1.morph"
+ run_in "$DATADIR/gits/morphs" git commit -m "Make $MATCH_1 only use $MATCH_2"
diff --git a/yarns/splitting.yarn b/yarns/splitting.yarn
index e55d5ed0..40da5fb4 100644
--- a/yarns/splitting.yarn
+++ b/yarns/splitting.yarn
@@ -40,7 +40,7 @@ libraries.
The only change we need to make is to add a field to the system morphology
to select which artifact to use in the system.
- AND system test-system only uses test-stratum-runtime from test-stratum
+ AND system test-system uses test-stratum-runtime from test-stratum
WHEN the user checks out the system branch called master
The best way to test that only using some stratum artifacts works is
@@ -75,7 +75,7 @@ so we know that if the system successfully builds, then we only built
chunks that were needed.
AND stratum test-stratum has chunks that aren't used in test-stratum-minimal
- AND system test-system only uses test-stratum-minimal from test-stratum
+ AND system test-system uses test-stratum-minimal from test-stratum
WHEN the user checks out the system branch called master
THEN morph build the system test-system of the branch master
@@ -168,19 +168,6 @@ Implementations
run_in "$DATADIR/gits/morphs" git add "$MATCH_1.morph"
run_in "$DATADIR/gits/morphs" git commit -m 'Add default splitting rules'
- IMPLEMENTS GIVEN system (\S+) only uses (\S+) from (\S+)
- python -c 'import sys, yaml
- with open(sys.argv[1], "r") as f:
- d = yaml.load(f)
- for spec in d["strata"]:
- if spec["name"] == sys.argv[3]:
- spec["artifacts"] = [sys.argv[2]]
- with open(sys.argv[1], "w") as f:
- yaml.dump(d, f)
- ' "$DATADIR/gits/morphs/$MATCH_1.morph" "$MATCH_2" "$MATCH_3"
- run_in "$DATADIR/gits/morphs" git add "$MATCH_1.morph"
- run_in "$DATADIR/gits/morphs" git commit -m "Make $MATCH_1 only use $MATCH_2"
-
IMPLEMENTS GIVEN stratum (\S+) has chunks that aren't used in (\1-\S+)
# Create an extra chunk that will never successfully build
cat >"$DATADIR/gits/test-chunk/unbuildable-chunk.morph" <<EOF