public inbox for gentoo-pms@lists.gentoo.org
 help / color / mirror / Atom feed
Search results ordered by [date|relevance]  view[summary|nested|Atom feed]
thread overview below | download: 
* Re: [gentoo-pms] License for code snippets included in PMS
  @ 2011-03-13 16:40 99%       ` Brian Harring
  0 siblings, 0 replies; 1+ results
From: Brian Harring @ 2011-03-13 16:40 UTC (permalink / raw
  To: Ulrich Mueller; +Cc: Petteri Räty, gentoo-pms


[-- Attachment #1.1: Type: text/plain, Size: 822 bytes --]

On Sun, Mar 13, 2011 at 03:10:55PM +0100, Ulrich Mueller wrote:
> >>>>> On Sun, 13 Mar 2011, Petteri Räty wrote:
> 
> >>> Could we put all code snippets under some unrestrictive license
> >>> please? Like CC0-1.0-Universal?
> 
> > To be on the safe side I think we should get permission from
> > everyone who has worked on the code snippets before applying this
> > patch.
> 
> Here's the complete list from git history:
>    env-saving.listing (21 lines):
>       Ciaran McCreesh

This section wasn't accurate, as such I threw it out- attached is a 
brain dump of exactly what characteristics can be relied on for
env saving, and should be reasonably complete.

Could stand to have some comments added though.

As for license, CC0-1.0-universal/public domain/whatever floats your 
boat.

~harring

[-- Attachment #1.2: 0001-correct-env-saving.listing-to-be-accurate-complete.patch --]
[-- Type: text/plain, Size: 3805 bytes --]

From a02ba65376e463818aa3d7abc2f845bd5ca745ff Mon Sep 17 00:00:00 2001
From: Brian Harring <ferringb@gmail.com>
Date: Sun, 13 Mar 2011 09:09:43 -0700
Subject: [PATCH] correct env-saving.listing to be accurate/complete

Version that was in place wasn't particularly accurate nor complete.
As such, and to cover copyright/licensing concerns, a from-scratch
version was written covering array behaviours, functions, unset behaviour,
and exports.

Signed-off-by: Brian Harring <ferringb@gmail.com>
---
 env-saving.listing |   84 +++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 64 insertions(+), 20 deletions(-)

diff --git a/env-saving.listing b/env-saving.listing
index 1650aa7..4391553 100644
--- a/env-saving.listing
+++ b/env-saving.listing
@@ -1,27 +1,71 @@
-GLOBAL_VARIABLE="a"
-
-src_compile()
-{
-    GLOBAL_VARIABLE="b"
-    DEFAULT_VARIABLE="c"
-    export EXPORTED_VARIABLE="d"
-    local LOCAL_VARIABLE="e"
+GLOBAL_SCOPE_VARIABLE="initial"
+VAR_TO_WIPE=initial
+declare -a ARRAY_VARIABLE=( a b )
+
+my_function() {
+	echo "exists"
+}
+
+src_compile() {
+	[[ ${GLOBAL_SCOPE_VARIABLE} == initial ]] || \
+		die "GLOBAL_SCOPE_VARIABLE must be preserved"
+
+	export GLOBAL_SCOPE_VARIABLE=set_twice
+
+	[[ ${VAR_TO_WIPE} == initial ]] || \
+		die "VAR_TO_WIPE must be preserved"
+
+	# now we wipe the var, to ensure that the env saving doesn't preserve it.
+	unset VAR_TO_WIPE
+
+	local LOCAL_SCOPE_VARIABLE=unseen
+
+	DEFAULT_SCOPE_VARIABLE=set
+
+	{ [[ ${#ARRAY_VARIABLE[@]} == 2 ]] && \
+		[[ ${ARRAY_VARIABLE[0]} == a ]] &&  \
+		[[ ${ARRAY_VARIABLE[1]} == b ]]; \
+	} || \
+		die "ARRAY_VARIABLE contents must be preserved exactly, and accessible"
+	ARRAY_VARIABLE[2]=c
+
+	[[ $(my_function 2> /dev/null) == exists ]] || \
+		die "'my_function' must be preserved"
 }
 
-src_install(){
-    [[ ${GLOBAL_VARIABLE} == "a" ]] \
-        || [[ ${GLOBAL_VARIABLE} == "b" ]] \
-        || die "broken env saving for globals"
 
-    [[ ${DEFAULT_VARIABLE} == "c" ]] \
-        || die "broken env saving for default"
+src_install() {
+	[[ ${GLOBAL_SCOPE_VARIABLE} == set_twice ]] || \
+		die "GLOBAL_SCOPE_VARIABLE modifications in src_compile must be preserved"
+
+	[[ -n $(declare -xp GLOBAL_SCOPE_VARIABLE 2> /dev/null) ]] || \
+		die "GLOBAL_SCOPE_VARIABLE must be exported due to src_compile exporting it"
+
+	[[ ${LOCAL_SCOPE_VARIABLE-unset} == unset ]] || \
+		die "a local defined variable should be impossible to propagate"
+
+	[[ ${VAR_TO_WIPE-unset} == unset ]] || \
+		die "VAR_TO_WIPE was unset during src_compile; this wiping must be preserved"
+
+	[[ ${DEFAULT_SCOPE_VARIABLE} == set ]] || \
+		die "DEFAULT_SCOPE_VARIABLE must be preserved"
+
+	[[ -n $(declare -xp DEFAULT_SCOPE_VARIABLE 2> /dev/null) ]] || \
+		die "DEFAULT_SCOPE_VARIABLE wasn't exported; environment saving must be preserved that fact."
+
+	[[ ${ARRAY_VARIABLE-unset} != unset ]] || \
+		die "ARRAY_VARIABLE must be preserved"
 
-    [[ ${EXPORTED_VARIABLE} == "d" ]] \
-        || die "broken env saving for exported"
+	[[ -n $(declare -ap ARRAY_VARIABLE 2> /dev/null) ]] || \
+		die "ARRAY_VARIABLE created during src_compile, must have it's array type preserved"
 
-    [[ $(printenv EXPORTED_VARIABLE ) == "d" ]] \
-        || die "broken env saving for exported"
+	{ [[ ${#ARRAY_VARIABLE[@]} == 3 ]] && \
+		[[ ${ARRAY_VARIABLE[0]} == a ]] &&  \
+		[[ ${ARRAY_VARIABLE[1]} == b ]]; \
+		[[ ${ARRAY_VARIABLE[2]} == c ]]; \
+	} || \
+		die "ARRAY_VARIABLE contents must be preserved exactly"
 
-    [[ -z ${LOCAL_VARIABLE} ]] \
-        || die "broken env saving for locals"
+	[[ $(my_function 2> /dev/null) == exists ]] || \
+		die "'my_function' must be preserved"
 }
-- 
1.7.4


[-- Attachment #2: Type: application/pgp-signature, Size: 198 bytes --]

^ permalink raw reply related	[relevance 99%]

Results 1-1 of 1 | reverse | options above
-- pct% links below jump to the message on this page, permalinks otherwise --
2011-02-20  0:15     [gentoo-pms] License for code snippets included in PMS Ulrich Mueller
2011-02-24  7:49     ` Ulrich Mueller
2011-03-13 10:30       ` Petteri Räty
2011-03-13 14:10         ` Ulrich Mueller
2011-03-13 16:40 99%       ` Brian Harring

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox