pkg/transforms/publish
changeset 970 272328fe1b4a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/pkg/transforms/publish	Fri Jul 02 21:03:57 2010 -0700
@@ -0,0 +1,38 @@
+#
+# Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
+#
+# Permission is hereby granted, free of charge, to any person obtaining a
+# copy of this software and associated documentation files (the "Software"),
+# to deal in the Software without restriction, including without limitation
+# the rights to use, copy, modify, merge, publish, distribute, sublicense,
+# and/or sell copies of the Software, and to permit persons to whom the
+# Software is furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice (including the next
+# paragraph) shall be included in all copies or substantial portions of the
+# Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+# DEALINGS IN THE SOFTWARE.
+#
+
+#
+# Only publish packages for the currently specified architecture
+#
+# This is somewhat nonintuitive.  In English:
+#
+#	For any action of type "set",
+#	if the "name" property matches the regex "variant.arch",
+#	and *every* occurrence of the "value" property does not match
+#		$ARCH, then don't publish it.
+#
+# ...in other words, if *any* occurrence of "value" matches $(ARCH),
+# then the negative lookahead assertion in the regex will fail, and we
+# won't abort based on the action.
+#
+<transform set name=variant.arch value=^(?!$(ARCH)).+$ -> abort>