You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@flex.apache.org by ah...@apache.org on 2013/05/25 00:33:49 UTC

[1/6] git commit: [flex-sdk] [refs/heads/develop] - ignore mustellarunner working files

Updated Branches:
  refs/heads/develop 5eae818fc -> 9c1627092


ignore mustellarunner working files


Project: http://git-wip-us.apache.org/repos/asf/flex-sdk/repo
Commit: http://git-wip-us.apache.org/repos/asf/flex-sdk/commit/4afac174
Tree: http://git-wip-us.apache.org/repos/asf/flex-sdk/tree/4afac174
Diff: http://git-wip-us.apache.org/repos/asf/flex-sdk/diff/4afac174

Branch: refs/heads/develop
Commit: 4afac1746efbfcb28e3d5fc77d0a8206bfb8b0e0
Parents: 5eae818
Author: Alex Harui <ah...@apache.org>
Authored: Fri May 24 23:14:40 2013 +0100
Committer: Alex Harui <ah...@apache.org>
Committed: Fri May 24 23:27:24 2013 +0100

----------------------------------------------------------------------
 .gitignore |    7 ++++++-
 1 files changed, 6 insertions(+), 1 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/4afac174/.gitignore
----------------------------------------------------------------------
diff --git a/.gitignore b/.gitignore
index 617cb7e..6b7eb41 100644
--- a/.gitignore
+++ b/.gitignore
@@ -116,4 +116,9 @@ _ReSharper*/
 *.rar
 *.tar
 
-/asdoc-output/
\ No newline at end of file
+/asdoc-output/
+
+#mustellarunner
+*.patch
+*.reply
+mailbody.txt


[6/6] git commit: [flex-sdk] [refs/heads/develop] - fix issue in script

Posted by ah...@apache.org.
fix issue in script


Project: http://git-wip-us.apache.org/repos/asf/flex-sdk/repo
Commit: http://git-wip-us.apache.org/repos/asf/flex-sdk/commit/9c162709
Tree: http://git-wip-us.apache.org/repos/asf/flex-sdk/tree/9c162709
Diff: http://git-wip-us.apache.org/repos/asf/flex-sdk/diff/9c162709

Branch: refs/heads/develop
Commit: 9c16270924ad9aa5c22ef945a02afbb9fd7d49ec
Parents: a72cefc
Author: Alex Harui <ah...@apache.org>
Authored: Fri May 24 23:31:10 2013 +0100
Committer: Alex Harui <ah...@apache.org>
Committed: Fri May 24 23:31:10 2013 +0100

----------------------------------------------------------------------
 test_patch_by_email.sh |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/9c162709/test_patch_by_email.sh
----------------------------------------------------------------------
diff --git a/test_patch_by_email.sh b/test_patch_by_email.sh
index b0f2dcc..e245ece 100644
--- a/test_patch_by_email.sh
+++ b/test_patch_by_email.sh
@@ -36,9 +36,9 @@ git pull --rebase
 
 for file in *.patch
 do
-d = dirname $file
-b = basename $file .patch
-r = $d/$.reply 
+d=dirname $file
+b=basename $file .patch
+r=$d/$.reply 
 read replyAddr < $r
 echo "Testing In Progress" >mailbody.txt
 mutt -s "Patch Received" $replyAddr <mailbody.txt


[2/6] git commit: [flex-sdk] [refs/heads/develop] - first attempt at email driven testing

Posted by ah...@apache.org.
first attempt at email driven testing


Project: http://git-wip-us.apache.org/repos/asf/flex-sdk/repo
Commit: http://git-wip-us.apache.org/repos/asf/flex-sdk/commit/f02bc3e1
Tree: http://git-wip-us.apache.org/repos/asf/flex-sdk/tree/f02bc3e1
Diff: http://git-wip-us.apache.org/repos/asf/flex-sdk/diff/f02bc3e1

Branch: refs/heads/develop
Commit: f02bc3e1751f098a1fa4e25fae762a9fa17ed27c
Parents: 4afac17
Author: Alex Harui <ah...@apache.org>
Authored: Fri May 24 23:15:31 2013 +0100
Committer: Alex Harui <ah...@apache.org>
Committed: Fri May 24 23:27:25 2013 +0100

----------------------------------------------------------------------
 test_patch_by_email.sh |   46 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 46 insertions(+), 0 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/f02bc3e1/test_patch_by_email.sh
----------------------------------------------------------------------
diff --git a/test_patch_by_email.sh b/test_patch_by_email.sh
new file mode 100644
index 0000000..a775b73
--- /dev/null
+++ b/test_patch_by_email.sh
@@ -0,0 +1,46 @@
+#!/bin/bash
+################################################################################
+##
+##  Licensed to the Apache Software Foundation (ASF) under one or more
+##  contributor license agreements.  See the NOTICE file distributed with
+##  this work for additional information regarding copyright ownership.
+##  The ASF licenses this file to You under the Apache License, Version 2.0
+##  (the "License"); you may not use this file except in compliance with
+##  the License.  You may obtain a copy of the License at
+##
+##      http://www.apache.org/licenses/LICENSE-2.0
+##
+##  Unless required by applicable law or agreed to in writing, software
+##  distributed under the License is distributed on an "AS IS" BASIS,
+##  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+##  See the License for the specific language governing permissions and
+##  limitations under the License.
+##
+################################################################################
+##
+## test_patch_by_email.sh gets email, finds patches, saves them to files 
+## runs test_patch
+##
+
+## rm /var/spool/mail/mustellarunner
+fetchmail
+cd mustella/utilities/PatchExtractor/src
+"$AIR_HOME/bin/adl" -runtime "$AIR_HOME/runtimes/air/win" PatchExtractor-app.xml -- c:/cygwin/var/spool/mail/mustellarunner
+rc=$?
+if [[ $rc != 0 ]] ; then
+    cd ../../../..
+    exit $rc
+fi
+cd ../../../..
+git pull --rebase
+
+for file in *.patch
+do
+d = dirname $file
+b = basename $file .patch
+r = $d/$.reply 
+read replyAddr < $r
+echo "Testing In Progress" >mailbody.txt
+mutt -s "Patch Received" $replyAddr <mailbody.txt
+sh test_patch $file
+done


[4/6] git commit: [flex-sdk] [refs/heads/develop] - Utility to extract patch files from fetchmail

Posted by ah...@apache.org.
Utility to extract patch files from fetchmail


Project: http://git-wip-us.apache.org/repos/asf/flex-sdk/repo
Commit: http://git-wip-us.apache.org/repos/asf/flex-sdk/commit/f7807e49
Tree: http://git-wip-us.apache.org/repos/asf/flex-sdk/tree/f7807e49
Diff: http://git-wip-us.apache.org/repos/asf/flex-sdk/diff/f7807e49

Branch: refs/heads/develop
Commit: f7807e49416fc1ecd2dbd40cec9cb12e83cb01d2
Parents: 611ddeb
Author: Alex Harui <ah...@apache.org>
Authored: Fri May 24 23:17:47 2013 +0100
Committer: Alex Harui <ah...@apache.org>
Committed: Fri May 24 23:27:28 2013 +0100

----------------------------------------------------------------------
 .../PatchExtractor/src/PatchExtractor-app.xml      |  250 +++++++++++++++
 .../PatchExtractor/src/PatchExtractor.mxml         |  247 ++++++++++++++
 2 files changed, 497 insertions(+), 0 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/f7807e49/mustella/utilities/PatchExtractor/src/PatchExtractor-app.xml
----------------------------------------------------------------------
diff --git a/mustella/utilities/PatchExtractor/src/PatchExtractor-app.xml b/mustella/utilities/PatchExtractor/src/PatchExtractor-app.xml
new file mode 100644
index 0000000..52ad512
--- /dev/null
+++ b/mustella/utilities/PatchExtractor/src/PatchExtractor-app.xml
@@ -0,0 +1,250 @@
+<?xml version="1.0" encoding="utf-8" standalone="no"?>
+<!--
+
+  Licensed to the Apache Software Foundation (ASF) under one or more
+  contributor license agreements.  See the NOTICE file distributed with
+  this work for additional information regarding copyright ownership.
+  The ASF licenses this file to You under the Apache License, Version 2.0
+  (the "License"); you may not use this file except in compliance with
+  the License.  You may obtain a copy of the License at
+
+      http://www.apache.org/licenses/LICENSE-2.0
+
+  Unless required by applicable law or agreed to in writing, software
+  distributed under the License is distributed on an "AS IS" BASIS,
+  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+  See the License for the specific language governing permissions and
+  limitations under the License.
+
+-->
+<application xmlns="http://ns.adobe.com/air/application/3.1">
+
+<!-- Adobe AIR Application Descriptor File Template.
+
+	Specifies parameters for identifying, installing, and launching AIR applications.
+
+	xmlns - The Adobe AIR namespace: http://ns.adobe.com/air/application/3.1
+			The last segment of the namespace specifies the version 
+			of the AIR runtime required for this application to run.
+			
+	minimumPatchLevel - The minimum patch level of the AIR runtime required to run 
+			the application. Optional.
+-->
+
+	<!-- A universally unique application identifier. Must be unique across all AIR applications.
+	Using a reverse DNS-style name as the id is recommended. (Eg. com.example.ExampleApplication.) Required. -->
+	<id>PatchExtractor</id>
+
+	<!-- Used as the filename for the application. Required. -->
+	<filename>PatchExtractor</filename>
+
+	<!-- The name that is displayed in the AIR application installer. 
+	May have multiple values for each language. See samples or xsd schema file. Optional. -->
+	<name>PatchExtractor</name>
+	
+	<!-- A string value of the format <0-999>.<0-999>.<0-999> that represents application version which can be used to check for application upgrade. 
+	Values can also be 1-part or 2-part. It is not necessary to have a 3-part value.
+	An updated version of application must have a versionNumber value higher than the previous version. Required for namespace >= 2.5 . -->
+	<versionNumber>0.0.0</versionNumber>
+		         
+	<!-- A string value (such as "v1", "2.5", or "Alpha 1") that represents the version of the application, as it should be shown to users. Optional. -->
+	<!-- <versionLabel></versionLabel> -->
+
+	<!-- Description, displayed in the AIR application installer.
+	May have multiple values for each language. See samples or xsd schema file. Optional. -->
+	<!-- <description></description> -->
+
+	<!-- Copyright information. Optional -->
+	<!-- <copyright></copyright> -->
+
+	<!-- Publisher ID. Used if you're updating an application created prior to 1.5.3 -->
+	<!-- <publisherID></publisherID> -->
+
+	<!-- Settings for the application's initial window. Required. -->
+	<initialWindow>
+		<!-- The main SWF or HTML file of the application. Required. -->
+		<!-- Note: In Flash Builder, the SWF reference is set automatically. -->
+		<content>PatchExtractor.swf</content>
+		
+		<!-- The title of the main window. Optional. -->
+		<!-- <title></title> -->
+
+		<!-- The type of system chrome to use (either "standard" or "none"). Optional. Default standard. -->
+		<!-- <systemChrome></systemChrome> -->
+
+		<!-- Whether the window is transparent. Only applicable when systemChrome is none. Optional. Default false. -->
+		<!-- <transparent></transparent> -->
+
+		<!-- Whether the window is initially visible. Optional. Default false. -->
+		<!-- <visible></visible> -->
+
+		<!-- Whether the user can minimize the window. Optional. Default true. -->
+		<!-- <minimizable></minimizable> -->
+
+		<!-- Whether the user can maximize the window. Optional. Default true. -->
+		<!-- <maximizable></maximizable> -->
+
+		<!-- Whether the user can resize the window. Optional. Default true. -->
+		<!-- <resizable></resizable> -->
+
+		<!-- The window's initial width in pixels. Optional. -->
+		<!-- <width></width> -->
+
+		<!-- The window's initial height in pixels. Optional. -->
+		<!-- <height></height> -->
+
+		<!-- The window's initial x position. Optional. -->
+		<!-- <x></x> -->
+
+		<!-- The window's initial y position. Optional. -->
+		<!-- <y></y> -->
+
+		<!-- The window's minimum size, specified as a width/height pair in pixels, such as "400 200". Optional. -->
+		<!-- <minSize></minSize> -->
+
+		<!-- The window's initial maximum size, specified as a width/height pair in pixels, such as "1600 1200". Optional. -->
+		<!-- <maxSize></maxSize> -->
+
+        <!-- The initial aspect ratio of the app when launched (either "portrait" or "landscape"). Optional. Mobile only. Default is the natural orientation of the device -->
+
+        <!-- <aspectRatio></aspectRatio> -->
+
+        <!-- Whether the app will begin auto-orienting on launch. Optional. Mobile only. Default false -->
+
+        <!-- <autoOrients></autoOrients> -->
+
+        <!-- Whether the app launches in full screen. Optional. Mobile only. Default false -->
+
+        <!-- <fullScreen></fullScreen> -->
+
+        <!-- The render mode for the app (either auto, cpu, gpu, or direct). Optional. Default auto -->
+
+        <!-- <renderMode></renderMode> -->
+
+		<!-- Whether or not to pan when a soft keyboard is raised or lowered (either "pan" or "none").  Optional.  Defaults "pan." -->
+		<!-- <softKeyboardBehavior></softKeyboardBehavior> -->
+	<autoOrients>false</autoOrients>
+        <fullScreen>false</fullScreen>
+        <visible>false</visible>
+    </initialWindow>
+
+	<!-- We recommend omitting the supportedProfiles element, -->
+	<!-- which in turn permits your application to be deployed to all -->
+	<!-- devices supported by AIR. If you wish to restrict deployment -->
+	<!-- (i.e., to only mobile devices) then add this element and list -->
+	<!-- only the profiles which your application does support. -->
+	<!-- <supportedProfiles>desktop extendedDesktop mobileDevice extendedMobileDevice</supportedProfiles> -->
+
+	<!-- The subpath of the standard default installation location to use. Optional. -->
+	<!-- <installFolder></installFolder> -->
+
+	<!-- The subpath of the Programs menu to use. (Ignored on operating systems without a Programs menu.) Optional. -->
+	<!-- <programMenuFolder></programMenuFolder> -->
+
+	<!-- The icon the system uses for the application. For at least one resolution,
+	specify the path to a PNG file included in the AIR package. Optional. -->
+	<!-- <icon>
+		<image16x16></image16x16>
+		<image32x32></image32x32>
+		<image36x36></image36x36>
+		<image48x48></image48x48>
+		<image57x57></image57x57>
+		<image72x72></image72x72>
+		<image114x114></image114x114>
+		<image128x128></image128x128>
+	</icon> -->
+
+	<!-- Whether the application handles the update when a user double-clicks an update version
+	of the AIR file (true), or the default AIR application installer handles the update (false).
+	Optional. Default false. -->
+	<!-- <customUpdateUI></customUpdateUI> -->
+	
+	<!-- Whether the application can be launched when the user clicks a link in a web browser.
+	Optional. Default false. -->
+	<!-- <allowBrowserInvocation></allowBrowserInvocation> -->
+
+	<!-- Listing of file types for which the application can register. Optional. -->
+	<!-- <fileTypes> -->
+
+		<!-- Defines one file type. Optional. -->
+		<!-- <fileType> -->
+
+			<!-- The name that the system displays for the registered file type. Required. -->
+			<!-- <name></name> -->
+
+			<!-- The extension to register. Required. -->
+			<!-- <extension></extension> -->
+			
+			<!-- The description of the file type. Optional. -->
+			<!-- <description></description> -->
+			
+			<!-- The MIME content type. -->
+			<!-- <contentType></contentType> -->
+			
+			<!-- The icon to display for the file type. Optional. -->
+			<!-- <icon>
+				<image16x16></image16x16>
+				<image32x32></image32x32>
+				<image48x48></image48x48>
+				<image128x128></image128x128>
+			</icon> -->
+			
+		<!-- </fileType> -->
+	<!-- </fileTypes> -->
+
+    <!-- iOS specific capabilities -->
+	<!-- <iPhone> -->
+		<!-- A list of plist key/value pairs to be added to the application Info.plist -->
+		<!-- <InfoAdditions>
+            <![CDATA[
+                <key>UIDeviceFamily</key>
+                <array>
+                    <string>1</string>
+                    <string>2</string>
+                </array>
+                <key>UIStatusBarStyle</key>
+                <string>UIStatusBarStyleBlackOpaque</string>
+                <key>UIRequiresPersistentWiFi</key>
+                <string>YES</string>
+            ]]>
+        </InfoAdditions> -->
+        <!-- A list of plist key/value pairs to be added to the application Entitlements.plist -->
+		<!-- <Entitlements>
+            <![CDATA[
+                <key>keychain-access-groups</key>
+                <array>
+                    <string></string>
+                    <string></string>
+                </array>
+            ]]>
+        </Entitlements> -->
+	<!-- Display Resolution for the app (either "standard" or "high"). Optional. Default "standard" -->
+	<!-- <requestedDisplayResolution></requestedDisplayResolution> -->
+	<!-- </iPhone> -->
+
+	<!-- Specify Android specific tags that get passed to AndroidManifest.xml file. -->
+    <!--<android> -->
+    <!--	<manifestAdditions>
+		<![CDATA[
+			<manifest android:installLocation="auto">
+				<uses-permission android:name="android.permission.INTERNET"/>
+				<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
+				<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
+				<uses-feature android:required="true" android:name="android.hardware.touchscreen.multitouch"/>
+				<application android:enabled="true">
+					<activity android:excludeFromRecents="false">
+						<intent-filter>
+							<action android:name="android.intent.action.MAIN"/>
+							<category android:name="android.intent.category.LAUNCHER"/>
+						</intent-filter>
+					</activity>
+				</application>
+            </manifest>
+		]]>
+        </manifestAdditions> -->
+	    <!-- Color depth for the app (either "32bit" or "16bit"). Optional. Default 16bit before namespace 3.0, 32bit after -->
+        <!-- <colorDepth></colorDepth> -->
+    <!-- </android> -->
+	<!-- End of the schema for adding the android specific tags in AndroidManifest.xml file -->
+
+</application>

http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/f7807e49/mustella/utilities/PatchExtractor/src/PatchExtractor.mxml
----------------------------------------------------------------------
diff --git a/mustella/utilities/PatchExtractor/src/PatchExtractor.mxml b/mustella/utilities/PatchExtractor/src/PatchExtractor.mxml
new file mode 100644
index 0000000..53bf2d6
--- /dev/null
+++ b/mustella/utilities/PatchExtractor/src/PatchExtractor.mxml
@@ -0,0 +1,247 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!--
+
+Licensed to the Apache Software Foundation (ASF) under one or more
+contributor license agreements.  See the NOTICE file distributed with
+this work for additional information regarding copyright ownership.
+The ASF licenses this file to You under the Apache License, Version 2.0
+(the "License"); you may not use this file except in compliance with
+the License.  You may obtain a copy of the License at
+
+http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+
+-->
+<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009" 
+					   xmlns:s="library://ns.adobe.com/flex/spark" 
+					   xmlns:mx="library://ns.adobe.com/flex/mx"
+                       invoke="checkArgs(event)">
+	<fx:Declarations>
+		<!-- Place non-visual elements (e.g., services, value objects) here -->
+	</fx:Declarations>
+	<fx:Script>
+		<![CDATA[
+			import mx.utils.Base64Decoder;
+			
+			private var mailFile:File = new File();
+			private var fs:FileStream;
+			private var flexDir:String;
+			private var gotone:Boolean = false;
+
+            private function checkArgs(event:InvokeEvent):void
+            {
+                var args:Array = event.arguments;
+                if (args.length > 0)
+                {
+					var wd:File = event.currentDirectory;
+					flexDir = wd.nativePath;
+					var c:int = flexDir.indexOf(File.separator + "mustella" + File.separator + "utilities");
+					if (c != -1)
+					{
+						flexDir = flexDir.substr(0, c);
+					}
+                    mailFile.nativePath = dir.text = args[0];
+                    callLater(autoStep2, [flexDir]);
+                }
+				else
+					nativeApplication.exit(-1);
+            }
+            
+            private function autoStep2(flexDir:String):void
+            {
+                fs = new FileStream();
+                fs.open(mailFile, FileMode.READ);
+                statusLog.text = fs.readUTFBytes(fs.bytesAvailable);
+                fs.close();
+                callLater(autoStep3);
+            }
+            
+            private function autoStep3():void
+            {
+                computePatches();
+                callLater(autoStep4);    
+            }
+            
+            private function autoStep4():void
+            {
+                this.nativeApplication.exit(gotone ? 0 : 2);   
+            }
+			
+			private function browse():void
+			{
+				mailFile.addEventListener(Event.SELECT, selectHandler);
+				mailFile.browseForOpen("Mail File");
+			}
+			
+			private function selectHandler(event:Event):void
+			{
+				dir.text = mailFile.nativePath;	
+			}
+			
+			private var SEARCH_MODE:int = 0;
+			private var FROM_SEARCH_MODE:int = 1;
+			private var PART_SEARCH_MODE:int = 2;
+			private var DELIMITER_SEARCH_MODE:int = 3;
+			private var PART_HEADER_MODE:int = 4;
+			private var PART_MODE:int = 5;
+			private var ATTACHMENT_MODE:int = 6;
+			private var PART_TYPE_MODE:int = 7;
+			
+			private function computePatches():void
+			{
+				mailFile.nativePath = dir.text;
+			
+				var replyAddr:String;
+				var partDelimiter:String;
+				var contentEncoding:String;
+				var contentType:String;
+				var part:String;
+				var c:int;
+				var c2:int;
+				var mode:int = SEARCH_MODE;
+				var lines:Array = statusLog.text.split("\n");
+				var modFiles:Array = [];
+				var n:int = lines.length;
+				for (var i:int = 0; i < n; i++)
+				{
+					var line:String = lines[i];
+					switch (mode)
+					{
+						case SEARCH_MODE:
+						{
+							if (line.indexOf("Content-Type") == 0)
+							{
+								mode = PART_TYPE_MODE;
+								i--;
+							}
+							else if (line.indexOf("From") == 0)
+							{
+								mode = FROM_SEARCH_MODE;
+							}
+							break;
+						}
+						case FROM_SEARCH_MODE:
+						{
+							if (line.indexOf("From: ") == 0)
+							{
+								c = line.indexOf("<");
+								c2 = line.indexOf(">");
+								replyAddr = line.substring(c+1, c2);
+								mode = DELIMITER_SEARCH_MODE;
+							}
+							break;
+						}
+						case DELIMITER_SEARCH_MODE:
+						{
+							if (line.indexOf("Content-Type: multipart/alternative") == 0
+								|| line.indexOf("Content-Type: multipart/mixed") == 0)
+							{
+								c = line.indexOf("boundary=");
+								partDelimiter = line.substr(c + 9);
+								if (partDelimiter.charAt(0) == '"')
+									partDelimiter = partDelimiter.substr(1, partDelimiter.length - 2);
+								mode = PART_SEARCH_MODE;
+								break;
+							}
+							break;	
+						}
+						case PART_SEARCH_MODE:
+						{
+							if (line.indexOf("--" + partDelimiter) == 0)
+							{
+								mode = PART_TYPE_MODE;
+							}
+							break;
+						}
+						case PART_TYPE_MODE:
+						{
+							part = "";
+							if (line.indexOf("Content-Type") == 0)
+							{
+								c = line.indexOf(";");
+								contentType = line.substring(14, c);
+								if (contentType == "application/octet-stream")
+									mode = ATTACHMENT_MODE;
+								else
+									mode = PART_MODE;
+							}
+							break;
+						}
+						case ATTACHMENT_MODE:
+						{
+							if (line.indexOf("Content-Transfer-Encoding") == 0)
+							{
+								contentEncoding = line.substring(27);
+								mode = PART_MODE;
+							}
+							break;
+						}
+						case PART_MODE:
+						{
+							if (line.indexOf("--" + partDelimiter) == 0)
+							{
+								mode = SEARCH_MODE;
+								if (contentType == "application/octet-stream" &&
+									contentEncoding == "base64")
+								{
+									var decoder:Base64Decoder = new Base64Decoder();
+									decoder.decode(part);
+									var ba:ByteArray = decoder.toByteArray();
+									ba.position = 0;
+									part = ba.readUTFBytes(ba.bytesAvailable);
+								}
+								c = part.indexOf("diff --git");
+								if (c != -1)
+								{
+									gotone = true;
+									part = part.substring(c);
+									var timeString:String = new Date().time.toString();
+									var fileName:String = replyAddr + timeString + ".patch";
+									fileName = flexDir + File.separator + fileName;
+									var file:File = new File(fileName);
+									var fs:FileStream = new FileStream();
+									fs.open(file, FileMode.WRITE);
+									fs.writeUTFBytes(part);
+									fs.close();
+									fileName = replyAddr + timeString + ".reply";
+									fileName = flexDir + File.separator + fileName;
+									file = new File(fileName);
+									fs = new FileStream();
+									fs.open(file, FileMode.WRITE);
+									fs.writeUTFBytes(replyAddr);
+									fs.close();
+								}
+							}
+							else
+								part += line + "\n";
+						}							
+						break;
+					}
+					
+				}
+				
+			}
+			
+		]]>
+	</fx:Script>
+	<s:layout>
+		<s:VerticalLayout />
+	</s:layout>
+	<s:HGroup width="100%">
+		<s:Label text="Mail File:" />
+		<s:TextInput id="dir" width="100%" toolTip="The mustella dir, not the tests dir"/>
+		<s:Button label="Browse..." click="browse()" />
+	</s:HGroup>
+	<s:Label text="Copy and paste Git Status below" />
+	<s:TextArea id="statusLog" width="100%" change="doneLabel.visible=false"/>
+	<s:HGroup>
+		<s:Button label="Compute Tests" enabled="{statusLog.text.length > 0}" click="callLater(computePatches)" />
+		<s:Label id="doneLabel" visible="false" text="Wrote changes.txt. Use mini_run.sh -changes" />
+	</s:HGroup>
+	<s:TextArea id="output" width="100%" editable="false" lineBreak="explicit" horizontalScrollPolicy="auto" />
+</s:WindowedApplication>


[5/6] git commit: [flex-sdk] [refs/heads/develop] - fix issue in script

Posted by ah...@apache.org.
fix issue in script


Project: http://git-wip-us.apache.org/repos/asf/flex-sdk/repo
Commit: http://git-wip-us.apache.org/repos/asf/flex-sdk/commit/a72cefca
Tree: http://git-wip-us.apache.org/repos/asf/flex-sdk/tree/a72cefca
Diff: http://git-wip-us.apache.org/repos/asf/flex-sdk/diff/a72cefca

Branch: refs/heads/develop
Commit: a72cefca1a82c8321e723b9608510143ca2ac959
Parents: f7807e4
Author: Alex Harui <ah...@apache.org>
Authored: Fri May 24 23:18:56 2013 +0100
Committer: Alex Harui <ah...@apache.org>
Committed: Fri May 24 23:27:29 2013 +0100

----------------------------------------------------------------------
 test_patch_by_email.sh |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/a72cefca/test_patch_by_email.sh
----------------------------------------------------------------------
diff --git a/test_patch_by_email.sh b/test_patch_by_email.sh
index a775b73..b0f2dcc 100644
--- a/test_patch_by_email.sh
+++ b/test_patch_by_email.sh
@@ -42,5 +42,5 @@ r = $d/$.reply
 read replyAddr < $r
 echo "Testing In Progress" >mailbody.txt
 mutt -s "Patch Received" $replyAddr <mailbody.txt
-sh test_patch $file
+sh test_patch $file $replyAddr
 done


[3/6] git commit: [flex-sdk] [refs/heads/develop] - modify scripts to output email if needed

Posted by ah...@apache.org.
modify scripts to output email if needed


Project: http://git-wip-us.apache.org/repos/asf/flex-sdk/repo
Commit: http://git-wip-us.apache.org/repos/asf/flex-sdk/commit/611ddebf
Tree: http://git-wip-us.apache.org/repos/asf/flex-sdk/tree/611ddebf
Diff: http://git-wip-us.apache.org/repos/asf/flex-sdk/diff/611ddebf

Branch: refs/heads/develop
Commit: 611ddebf71fddfdc47443a20dfa1efc7ca6d9d2e
Parents: f02bc3e
Author: Alex Harui <ah...@apache.org>
Authored: Fri May 24 23:16:27 2013 +0100
Committer: Alex Harui <ah...@apache.org>
Committed: Fri May 24 23:27:27 2013 +0100

----------------------------------------------------------------------
 mustella/test_changes.sh |   23 +++++++++++++++++++----
 test_patch.sh            |    9 +++++++--
 2 files changed, 26 insertions(+), 6 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/611ddebf/mustella/test_changes.sh
----------------------------------------------------------------------
diff --git a/mustella/test_changes.sh b/mustella/test_changes.sh
index 1e20877..92f9081 100755
--- a/mustella/test_changes.sh
+++ b/mustella/test_changes.sh
@@ -31,15 +31,30 @@ then
 sh ./mini_run.sh -failures
 fi
 else
-	echo "no changes.txt or nothing in it"
+        if [ $# -lt 1 ]
+        then
+    	    echo "no changes.txt or nothing in it"
+        else
+            mutt -s "No Tests Found" $1 <$2
+        fi
 	exit
 fi
 if [ -s failures.txt ]
 then
     numlines=`wc -l failures.txt | awk {'print $1'}`
-    echo "$numlines tests failed"
+    if [ $# -lt 1 ]
+    then
+        echo "$numlines tests failed"
+    else
+        mutt -s "$numlines tests failed" $1 <failures.txt
+    fi
 else
     numlines=`wc -l results.txt | awk {'print $1'}`
 	let "numlines = $numlines - 19"
-    echo "$numlines tests passed"
-fi
\ No newline at end of file
+    if [ $# -lt 1 ]
+    then
+        echo "$numlines tests passed"
+    else
+         mutt -s "$numlines tests passed" $1 <$2
+    fi
+fi

http://git-wip-us.apache.org/repos/asf/flex-sdk/blob/611ddebf/test_patch.sh
----------------------------------------------------------------------
diff --git a/test_patch.sh b/test_patch.sh
index d591d84..fca3634 100755
--- a/test_patch.sh
+++ b/test_patch.sh
@@ -30,7 +30,7 @@ fi
 git apply $1
 git status >gitstatus.txt
 cd mustella/utilities/MustellaTestChooser/src
-"$AIR_HOME/bin/adl" -runtime "$AIR_HOME/runtimes/air/mac" MustellaTestChooser-app.xml -- -file
+"$AIR_HOME/bin/adl" -runtime "$AIR_HOME/runtimes/air/win" MustellaTestChooser-app.xml -- -file
 cd ../../../..
 if [ -s mustella/changes.txt ]
 then
@@ -40,7 +40,12 @@ then
 		exit $rc
 	fi
 	cd mustella
-	sh ./test_changes.sh
+        if [ $# -lt 2 ]
+        then
+	    sh ./test_changes.sh
+        else
+            sh ./test_changes.sh $2 $1
+        fi
 	cd ..
 fi
 git checkout .