f35d1b
diff -up ./esc/coreconf/Linux3.3.mk.fix14 ./esc/coreconf/Linux3.3.mk
f35d1b
--- ./esc/coreconf/Linux3.3.mk.fix14	2012-05-10 15:09:37.298143842 -0700
f35d1b
+++ ./esc/coreconf/Linux3.3.mk	2012-05-10 15:09:37.298143842 -0700
f35d1b
@@ -0,0 +1,35 @@
f35d1b
+# BEGIN COPYRIGHT BLOCK
f35d1b
+# This Program is free software; you can redistribute it and/or modify it under
f35d1b
+# the terms of the GNU General Public License as published by the Free Software
f35d1b
+# Foundation; version 2 of the License.
f35d1b
+#
f35d1b
+# This Program is distributed in the hope that it will be useful, but WITHOUT
f35d1b
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
f35d1b
+# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
f35d1b
+#
f35d1b
+# You should have received a copy of the GNU General Public License along with
f35d1b
+# this Program; if not, write to the Free Software Foundation, Inc., 59 Temple
f35d1b
+# Place, Suite 330, Boston, MA 02111-1307 USA.
f35d1b
+#
f35d1b
+# Copyright (C) 2005 Red Hat, Inc.
f35d1b
+# All rights reserved.
f35d1b
+# END COPYRIGHT BLOCK
f35d1b
+
f35d1b
+#
f35d1b
+# Config stuff for Linux 3.3 (ELF)
f35d1b
+#
f35d1b
+
f35d1b
+include $(CORE_DEPTH)/coreconf/Linux.mk
f35d1b
+
f35d1b
+OS_REL_CFLAGS   += -DLINUX2_1
f35d1b
+MKSHLIB         = $(CC) -shared -Wl,-soname -Wl,$(@:$(OBJDIR)/%.so=%.so)
f35d1b
+ifdef BUILD_OPT
f35d1b
+            OPTIMIZER       = -O2
f35d1b
+endif
f35d1b
+
f35d1b
+ifdef MAPFILE
f35d1b
+	MKSHLIB += -Wl,--version-script,$(MAPFILE)
f35d1b
+endif
f35d1b
+PROCESS_MAP_FILE = grep -v ';-' $(LIBRARY_NAME).def | \
f35d1b
+        sed -e 's,;+,,' -e 's; DATA ;;' -e 's,;;,,' -e 's,;.*,;,' > $@
f35d1b
+
f35d1b
diff -up ./esc/coreconf/Linux3.4.mk.fix14 ./esc/coreconf/Linux3.4.mk
f35d1b
--- ./esc/coreconf/Linux3.4.mk.fix14	2012-05-10 15:09:37.298143842 -0700
f35d1b
+++ ./esc/coreconf/Linux3.4.mk	2012-05-10 15:09:37.298143842 -0700
f35d1b
@@ -0,0 +1,35 @@
f35d1b
+# BEGIN COPYRIGHT BLOCK
f35d1b
+# This Program is free software; you can redistribute it and/or modify it under
f35d1b
+# the terms of the GNU General Public License as published by the Free Software
f35d1b
+# Foundation; version 2 of the License.
f35d1b
+#
f35d1b
+# This Program is distributed in the hope that it will be useful, but WITHOUT
f35d1b
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
f35d1b
+# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
f35d1b
+#
f35d1b
+# You should have received a copy of the GNU General Public License along with
f35d1b
+# this Program; if not, write to the Free Software Foundation, Inc., 59 Temple
f35d1b
+# Place, Suite 330, Boston, MA 02111-1307 USA.
f35d1b
+#
f35d1b
+# Copyright (C) 2005 Red Hat, Inc.
f35d1b
+# All rights reserved.
f35d1b
+# END COPYRIGHT BLOCK
f35d1b
+
f35d1b
+#
f35d1b
+# Config stuff for Linux 3.4 (ELF)
f35d1b
+#
f35d1b
+
f35d1b
+include $(CORE_DEPTH)/coreconf/Linux.mk
f35d1b
+
f35d1b
+OS_REL_CFLAGS   += -DLINUX2_1
f35d1b
+MKSHLIB         = $(CC) -shared -Wl,-soname -Wl,$(@:$(OBJDIR)/%.so=%.so)
f35d1b
+ifdef BUILD_OPT
f35d1b
+            OPTIMIZER       = -O2
f35d1b
+endif
f35d1b
+
f35d1b
+ifdef MAPFILE
f35d1b
+	MKSHLIB += -Wl,--version-script,$(MAPFILE)
f35d1b
+endif
f35d1b
+PROCESS_MAP_FILE = grep -v ';-' $(LIBRARY_NAME).def | \
f35d1b
+        sed -e 's,;+,,' -e 's; DATA ;;' -e 's,;;,,' -e 's,;.*,;,' > $@
f35d1b
+
f35d1b
diff -up ./esc/coreconf/Linux3.5.mk.fix14 ./esc/coreconf/Linux3.5.mk
f35d1b
--- ./esc/coreconf/Linux3.5.mk.fix14	2012-05-10 15:09:37.299143830 -0700
f35d1b
+++ ./esc/coreconf/Linux3.5.mk	2012-05-10 15:09:37.298143842 -0700
f35d1b
@@ -0,0 +1,35 @@
f35d1b
+# BEGIN COPYRIGHT BLOCK
f35d1b
+# This Program is free software; you can redistribute it and/or modify it under
f35d1b
+# the terms of the GNU General Public License as published by the Free Software
f35d1b
+# Foundation; version 2 of the License.
f35d1b
+#
f35d1b
+# This Program is distributed in the hope that it will be useful, but WITHOUT
f35d1b
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
f35d1b
+# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
f35d1b
+#
f35d1b
+# You should have received a copy of the GNU General Public License along with
f35d1b
+# this Program; if not, write to the Free Software Foundation, Inc., 59 Temple
f35d1b
+# Place, Suite 330, Boston, MA 02111-1307 USA.
f35d1b
+#
f35d1b
+# Copyright (C) 2005 Red Hat, Inc.
f35d1b
+# All rights reserved.
f35d1b
+# END COPYRIGHT BLOCK
f35d1b
+
f35d1b
+#
f35d1b
+# Config stuff for Linux 3.5 (ELF)
f35d1b
+#
f35d1b
+
f35d1b
+include $(CORE_DEPTH)/coreconf/Linux.mk
f35d1b
+
f35d1b
+OS_REL_CFLAGS   += -DLINUX2_1
f35d1b
+MKSHLIB         = $(CC) -shared -Wl,-soname -Wl,$(@:$(OBJDIR)/%.so=%.so)
f35d1b
+ifdef BUILD_OPT
f35d1b
+            OPTIMIZER       = -O2
f35d1b
+endif
f35d1b
+
f35d1b
+ifdef MAPFILE
f35d1b
+	MKSHLIB += -Wl,--version-script,$(MAPFILE)
f35d1b
+endif
f35d1b
+PROCESS_MAP_FILE = grep -v ';-' $(LIBRARY_NAME).def | \
f35d1b
+        sed -e 's,;+,,' -e 's; DATA ;;' -e 's,;;,,' -e 's,;.*,;,' > $@
f35d1b
+
f35d1b
diff -up ./esc/src/app/xpcom/Makefile.sdk.fix14 ./esc/src/app/xpcom/Makefile.sdk
f35d1b
--- ./esc/src/app/xpcom/Makefile.sdk.fix14	2012-05-10 15:09:37.293143904 -0700
f35d1b
+++ ./esc/src/app/xpcom/Makefile.sdk	2012-05-10 15:25:17.138394220 -0700
f35d1b
@@ -106,15 +106,14 @@ endif
f35d1b
 endif
f35d1b
 
f35d1b
 ifeq ($(OS_ARCH),Darwin)
f35d1b
-GECKO_LD_LIBS=-L$(GECKO_SDK_PATH)/lib    -W1,  $(GECKO_SDK_PATH)/lib/libxpcomglue.a -L$(XUL_FRAMEWORK_BIN_PATH) -lnss3 -lssl3 -lsoftokn3 -lplds4 -lplc4 -lnssutil3
f35d1b
+GECKO_LD_LIBS=-L$(GECKO_SDK_PATH)/lib    -W1,  $(GECKO_SDK_PATH)/lib/libxpcomglue.a -L$(XUL_FRAMEWORK_BIN_PATH) -lnss3 -lssl3 -lsoftokn3 -lplds4 -lplc4 -lnssutil3 
f35d1b
 endif
f35d1b
 
f35d1b
-
f35d1b
 ifeq ($(OS_ARCH),Linux)
f35d1b
-CPPFLAGS += -fno-rtti \
f35d1b
-                -fno-exceptions \
f35d1b
-                -fshort-wchar -fPIC -std=gnu++0x
f35d1b
-GECKO_LD_LIBS=-L$(GECKO_SDK_PATH)/lib    $(GECKO_SDK_PATH)/lib/libxpcomglue.a -lnssutil3 -lnss3 -lcrmf -lssl3 -lsmime3 -lplds4 -lplc4 -lnspr4 -lpthread -ldl
f35d1b
+CPPFLAGS += -g -fno-rtti \
f35d1b
+                -DXPCOM_GLUE_USE_NSPR -fno-exceptions \
f35d1b
+                -fshort-wchar -fPIC -std=gnu++0x  
f35d1b
+GECKO_LD_LIBS=-L$(GECKO_SDK_PATH)/lib  -lnssutil3 -lnss3 -lcrmf -lssl3 -lsmime3 -lplds4 -lplc4 -lnspr4 -lpthread -ldl -L$(GECKO_SDK_PATH)/lib -lxpcomglue_s -lxpcom
f35d1b
 endif
f35d1b
 
f35d1b
 ifeq ($(OS_ARCH),WINNT)
f35d1b
@@ -128,15 +127,15 @@ endif
f35d1b
 # #include "mozilla-config.h" to each of your .cpp files. 
f35d1b
 #GECKO_CONFIG_INCLUDE = -include mozilla-config.h 
f35d1b
 
f35d1b
-GECKO_DEFINES  = -DXPCOM_GLUE  -DMOZILLA_CLIENT
f35d1b
+GECKO_DEFINES  = -DXPCOM_GLUE   -DMOZILLA_CLIENT
f35d1b
 
f35d1b
 ifdef ESC_VERSION
f35d1b
 GECKO_DEFINES += -DESC_VERSION=$(ESC_VERSION)
f35d1b
 endif
f35d1b
 
f35d1b
-ifdef GECKO_BIN_PATH
f35d1b
-GECKO_DEFINES += -DGECKO_BIN_PATH=$(GECKO_BIN_PATH)
f35d1b
-endif
f35d1b
+#ifdef GECKO_BIN_PATH
f35d1b
+#GECKO_DEFINES += -DGECKO_BIN_PATH=$(GECKO_BIN_PATH)
f35d1b
+#endif
f35d1b
 
f35d1b
 NSS_INCLUDE =  /usr/include/nss3
f35d1b
 NSPR_INCLUDE =  /usr/include/nspr4
f35d1b
@@ -162,7 +161,7 @@ COOL_LDFLAGS += -lsystemStubs  -framewor
f35d1b
 endif
f35d1b
  
f35d1b
 GECKO_LDFLAGS= -lnspr4 \
f35d1b
-	-lplds4  -lplc4 -ldl  -lpthread  -Wl -z   \
f35d1b
+	-lplds4  -lplc4 -ldl  -lpthread   -z   \
f35d1b
         $(GECKO_LD_LIBS)
f35d1b
 
f35d1b
 ifeq ($(OS_ARCH),WINNT)
f35d1b
@@ -215,7 +214,7 @@ ifeq ($(OS_ARCH),Linux)
f35d1b
 
f35d1b
 	$(CXX)   $(CPPFLAGS) -shared -o $(TARGET) $(OBJECT)  $(GECKO_DEFINES) $(GECKO_INCLUDES)  $(GECKO_LDFLAGS) $(COOL_LDFLAGS)
f35d1b
 	chmod +x $(TARGET)
f35d1b
-	strip $(TARGET)
f35d1b
+	#strip $(TARGET)
f35d1b
 endif
f35d1b
 
f35d1b
 ifeq ($(OS_ARCH),WINNT)
f35d1b
diff -up ./esc/src/app/xpcom/rhCoolKey.cpp.fix14 ./esc/src/app/xpcom/rhCoolKey.cpp
f35d1b
--- ./esc/src/app/xpcom/rhCoolKey.cpp.fix14	2012-05-10 15:09:37.294143891 -0700
f35d1b
+++ ./esc/src/app/xpcom/rhCoolKey.cpp	2012-05-10 15:09:37.300143818 -0700
f35d1b
@@ -16,7 +16,6 @@
f35d1b
  * END COPYRIGHT BLOCK **/
f35d1b
 
f35d1b
 #define FORCE_PR_LOG 1
f35d1b
-
f35d1b
 #include <stdio.h>
f35d1b
 #include "rhCoolKey.h"
f35d1b
 #include "CoolKey.h"
f35d1b
@@ -34,7 +33,7 @@
f35d1b
 #include "nsIPrefBranch.h"
f35d1b
 #include "nsIPrefService.h"
f35d1b
 #include "nsCOMPtr.h"
f35d1b
-#include "nsIProxyObjectManager.h"
f35d1b
+#include "nsThreadUtils.h"
f35d1b
 #include "nsIObserver.h"
f35d1b
 #include "nsIObserverService.h"
f35d1b
 #include "nsXPCOMGlue.h"
f35d1b
@@ -91,6 +90,7 @@ std::list<CoolKeyNode*>rhCoolKey::gASCAv
f35d1b
 std::list< nsCOMPtr <rhIKeyNotify>  > rhCoolKey::gNotifyListeners;
f35d1b
 
f35d1b
 PRLock* rhCoolKey::certCBLock=NULL;
f35d1b
+PRLock* rhCoolKey::eventLock= NULL;
f35d1b
 
f35d1b
 PRBool rhCoolKey::gAutoEnrollBlankTokens = PR_FALSE; 
f35d1b
 
f35d1b
@@ -162,6 +162,70 @@ ASCCalcBase64DecodedLength(const char *a
f35d1b
 
f35d1b
   return ((numValidChars / 4) * 3) - numEqualSigns;
f35d1b
 }
f35d1b
+class CoolKeyResultTask  : public  nsRunnable
f35d1b
+{
f35d1b
+public:
f35d1b
+  ~CoolKeyResultTask() {
f35d1b
+
f35d1b
+      char tBuff[56];
f35d1b
+      PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s ~CoolKeyResultTask thread: %p \n",GetTStamp(tBuff,56),PR_GetCurrentThread()));
f35d1b
+
f35d1b
+      if (mKeyID) {
f35d1b
+          free(mKeyID);
f35d1b
+      }
f35d1b
+
f35d1b
+      if (mStrData) {
f35d1b
+          free(mStrData);
f35d1b
+      }
f35d1b
+
f35d1b
+  }
f35d1b
+
f35d1b
+  CoolKeyResultTask(unsigned long keyType, const char *keyID, unsigned long keyState,
f35d1b
+                    unsigned long data, const char *strData, rhICoolKey *listener)
f35d1b
+    : mKeyType(keyType), mKeyState(keyState), 
f35d1b
+      mData(data), mListener(listener)
f35d1b
+  {
f35d1b
+
f35d1b
+     mStrData = NULL;
f35d1b
+     mKeyID   = NULL;
f35d1b
+
f35d1b
+     MOZ_ASSERT(!NS_IsMainThread());
f35d1b
+     
f35d1b
+     if (keyID) {
f35d1b
+         mKeyID = strdup(keyID);
f35d1b
+     }
f35d1b
+
f35d1b
+     if (strData) {
f35d1b
+         mStrData = strdup(strData);
f35d1b
+     }
f35d1b
+
f35d1b
+     char tBuff[56];
f35d1b
+
f35d1b
+     PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s CoolKeyResultTask::CoolKeyResultTask thread:   %p keyID %s \n",GetTStamp(tBuff,56),PR_GetCurrentThread(),mKeyID));
f35d1b
+
f35d1b
+  }
f35d1b
+
f35d1b
+
f35d1b
+  NS_IMETHOD Run() {
f35d1b
+    MOZ_ASSERT(NS_IsMainThread());
f35d1b
+
f35d1b
+     char tBuff[56];
f35d1b
+     PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s CoolKeyResultTask::Run thread: %p \n",GetTStamp(tBuff,56),PR_GetCurrentThread()));
f35d1b
+   
f35d1b
+     if (mListener != NULL) {
f35d1b
+         mListener->RhNotifyKeyStateChange(mKeyType, mKeyID, mKeyState, 
f35d1b
+                        mData, mStrData);
f35d1b
+     } 
f35d1b
+   }
f35d1b
+
f35d1b
+private: 
f35d1b
+   unsigned long mKeyType;
f35d1b
+   char *mKeyID;
f35d1b
+   unsigned long mKeyState;
f35d1b
+   unsigned long mData;
f35d1b
+   char *mStrData; 
f35d1b
+   rhICoolKey *mListener;
f35d1b
+};
f35d1b
 
f35d1b
 unsigned int
f35d1b
 ASCCalcBase64EncodedLength(unsigned int aDataLength)
f35d1b
@@ -200,6 +264,14 @@ rhCoolKey::rhCoolKey()
f35d1b
         exit(1);
f35d1b
     }
f35d1b
 
f35d1b
+    eventLock = PR_NewLock();
f35d1b
+
f35d1b
+    if(!eventLock) {
f35d1b
+       PR_LOG( coolKeyLog, PR_LOG_ERROR, ("%s Failed to create event lock exiting! \n", GetTStamp(tBuff,56)));
f35d1b
+       exit(1);
f35d1b
+    }
f35d1b
+
f35d1b
+
f35d1b
     PRBool res = InitInstance();
f35d1b
 
f35d1b
     if(res == PR_FALSE)
f35d1b
@@ -221,6 +293,10 @@ rhCoolKey::~rhCoolKey()
f35d1b
     if(certCBLock) {
f35d1b
         PR_DestroyLock(certCBLock);
f35d1b
     }
f35d1b
+
f35d1b
+    if(eventLock) {
f35d1b
+        PR_DestroyLock(eventLock);
f35d1b
+    }
f35d1b
 }
f35d1b
 
f35d1b
 void rhCoolKey::ShutDownInstance()
f35d1b
@@ -255,8 +331,17 @@ HRESULT rhCoolKey::Dispatch( rhICoolKey
f35d1b
     unsigned long keyType, const char *keyID, unsigned long keyState,
f35d1b
     unsigned long data, const char *strData)
f35d1b
 {
f35d1b
-    return listener->RhNotifyKeyStateChange(keyType,keyID, keyState, 
f35d1b
-			data, strData);
f35d1b
+
f35d1b
+    char tBuff[56];
f35d1b
+
f35d1b
+    PR_Lock(eventLock);
f35d1b
+    PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s rhCoolKey::Dispatch: thead:  %p \n",GetTStamp(tBuff,56),PR_GetCurrentThread()));
f35d1b
+    nsCOMPtr<nsIRunnable>  result = new CoolKeyResultTask(keyType, keyID,keyState, data, strData, listener);
f35d1b
+
f35d1b
+    NS_DispatchToMainThread(result);
f35d1b
+
f35d1b
+    PR_Unlock(eventLock);
f35d1b
+    return  1;  
f35d1b
 }
f35d1b
 
f35d1b
 HRESULT rhCoolKey::Reference( rhICoolKey *listener )
f35d1b
@@ -536,34 +621,6 @@ PRBool rhCoolKey::InitInstance()
f35d1b
 
f35d1b
     PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s rhCoolKey::InitInstance %p \n",GetTStamp(tBuff,56),this));
f35d1b
 
f35d1b
-    char xpcom_path[4096];
f35d1b
-    xpcom_path[0] = 0;
f35d1b
-/*
f35d1b
-    static const GREVersionRange greVersion = 
f35d1b
-    {
f35d1b
-    "1.9", PR_TRUE,
f35d1b
-    "9.9", PR_TRUE
f35d1b
-    };
f35d1b
-
f35d1b
-    nsresult rv = GRE_GetGREPathWithProperties(&greVersion, 1, nsnull, 0, xpcom_path, 4096);
f35d1b
-    if (NS_FAILED(rv)) {
f35d1b
-        return PR_FALSE;
f35d1b
-    }
f35d1b
-
f35d1b
-*/
f35d1b
-
f35d1b
-    char *grePath = (char *) GETSTRING(GECKO_BIN_PATH);
f35d1b
-
f35d1b
-    
f35d1b
-    snprintf(xpcom_path,4096,"%s%s",grePath,"libxpcom.so");
f35d1b
-
f35d1b
-    char *lib_name =(char *) XPCOM_LIB_NAME ;
f35d1b
-
f35d1b
-  
f35d1b
-    PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s rhCoolKey::xpcom_path %s \n",GetTStamp(tBuff,56),xpcom_path)); 
f35d1b
-
f35d1b
-    XPCOMGlueStartup("/usr/lib/xulrunner-2/libxpcom.so");
f35d1b
-
f35d1b
     nssComponent
f35d1b
     = do_GetService(PSM_COMPONENT_CONTRACTID); 
f35d1b
 
f35d1b
@@ -640,23 +697,8 @@ PRBool rhCoolKey::InitInstance()
f35d1b
 
f35d1b
 rhICoolKey* rhCoolKey::CreateProxyObject()
f35d1b
 {
f35d1b
-    char tBuff[56];
f35d1b
-    rhICoolKey *proxyObject = NULL;
f35d1b
-
f35d1b
-    PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s rhCoolKey::CreateProxyObject: \n",GetTStamp(tBuff,56)));
f35d1b
-
f35d1b
-    nsCOMPtr<nsIProxyObjectManager> manager =
f35d1b
-            do_GetService(NS_XPCOMPROXY_CONTRACTID);
f35d1b
-
f35d1b
-    PR_ASSERT(manager);
f35d1b
-
f35d1b
-
f35d1b
-    manager->GetProxyForObject(NULL, NS_GET_IID(rhICoolKey), this, NS_PROXY_SYNC | NS_PROXY_ALWAYS, (void**)&proxyObject);
f35d1b
-
f35d1b
-    PR_LOG( coolKeyLog, PR_LOG_DEBUG, ("%s rhCoolKey::CreateProxyObject: original: %p proxy %p  \n",GetTStamp(tBuff,56),this,proxyObject));
f35d1b
-
f35d1b
-    return proxyObject;
f35d1b
-   
f35d1b
+    // Now we are using nsRunnable, no more proxy object manager.
f35d1b
+    return this;
f35d1b
 }
f35d1b
 
f35d1b
 CoolKeyNode* rhCoolKey::GetCoolKeyInfo(unsigned long aKeyType, const char * aKeyID)
f35d1b
diff -up ./esc/src/app/xpcom/rhCoolKey.h.fix14 ./esc/src/app/xpcom/rhCoolKey.h
f35d1b
--- ./esc/src/app/xpcom/rhCoolKey.h.fix14	2012-05-10 15:09:37.274144142 -0700
f35d1b
+++ ./esc/src/app/xpcom/rhCoolKey.h	2012-05-10 15:09:37.300143818 -0700
f35d1b
@@ -120,6 +120,7 @@ protected:
f35d1b
     static std::list< nsCOMPtr <rhIKeyNotify> > gNotifyListeners;
f35d1b
 
f35d1b
     static PRLock* certCBLock;
f35d1b
+    static PRLock* eventLock;
f35d1b
 
f35d1b
     rhICoolKey* mProxy;
f35d1b
 
f35d1b
diff -up ./esc/src/app/xul/esc/application.ini.fix14 ./esc/src/app/xul/esc/application.ini
f35d1b
--- ./esc/src/app/xul/esc/application.ini.fix14	2012-05-10 15:09:37.295143878 -0700
f35d1b
+++ ./esc/src/app/xul/esc/application.ini	2012-05-10 15:09:37.300143818 -0700
f35d1b
@@ -25,11 +25,11 @@ Vendor=RedHat
f35d1b
 Name=ESC
f35d1b
 ;
f35d1b
 ; This field specifies your application's version.  This field is optional.
f35d1b
-Version=1.1.0-15
f35d1b
+Version=1.1.0-16
f35d1b
 ;
f35d1b
 ; This field specifies your application's build ID (timestamp).  This field is
f35d1b
 ; required.
f35d1b
-BuildID=0000001016
f35d1b
+BuildID=0000001017
f35d1b
 ;
f35d1b
 ; This ID is just an example.  Every XUL app ought to have it's own unique ID.
f35d1b
 ; You can use the microsoft "guidgen" or "uuidgen" tools, or go on
f35d1b
diff -up ./esc/src/app/xul/esc/chrome/content/esc/password.xul.fix14 ./esc/src/app/xul/esc/chrome/content/esc/password.xul
f35d1b
--- ./esc/src/app/xul/esc/chrome/content/esc/password.xul.fix14	2012-05-10 15:09:37.251144429 -0700
f35d1b
+++ ./esc/src/app/xul/esc/chrome/content/esc/password.xul	2012-05-10 15:09:37.301143805 -0700
f35d1b
@@ -27,7 +27,6 @@
f35d1b
 
f35d1b
 <stringbundle id="esc_strings" src="chrome://esc/locale/esc.properties"/>
f35d1b
 <script src="password.js"/>
f35d1b
-<script src="TRAY.js"/>
f35d1b
 
f35d1b
 <spacer class = "horSpacerVeryShort"/>
f35d1b
  <grid>
f35d1b
diff -up ./esc/src/lib/coolkey/CoolKeyHandler.cpp.fix14 ./esc/src/lib/coolkey/CoolKeyHandler.cpp
f35d1b
--- ./esc/src/lib/coolkey/CoolKeyHandler.cpp.fix14	2009-02-03 17:43:47.000000000 -0800
f35d1b
+++ ./esc/src/lib/coolkey/CoolKeyHandler.cpp	2012-05-10 15:09:37.302143792 -0700
f35d1b
@@ -451,7 +451,6 @@ HRESULT CoolKeyHandler::Init(const CoolK
f35d1b
     PR_LOG( coolKeyLogHN, PR_LOG_DEBUG, ("%s CoolKeyHandler::Init:\n",GetTStamp(tBuff,56)));
f35d1b
 
f35d1b
     bool connected = false;
f35d1b
-    PRThread*  cThread = NULL;
f35d1b
     const char *readerName =  NULL;
f35d1b
 
f35d1b
     if (!aKey || aKey->mKeyType != eCKType_CoolKey ||  !aKey->mKeyID) {
f35d1b
@@ -461,9 +460,6 @@ HRESULT CoolKeyHandler::Init(const CoolK
f35d1b
   
f35d1b
     readerName = GetReaderNameForKeyID(aKey);
f35d1b
 
f35d1b
-    cThread = PR_GetCurrentThread();
f35d1b
-
f35d1b
-
f35d1b
     mKey = *aKey;
f35d1b
 
f35d1b
   
f35d1b
diff -up ./esc/src/lib/coolkey/SmartCardMonitoringThread.cpp.fix14 ./esc/src/lib/coolkey/SmartCardMonitoringThread.cpp
f35d1b
--- ./esc/src/lib/coolkey/SmartCardMonitoringThread.cpp.fix14	2012-05-10 15:09:37.250144442 -0700
f35d1b
+++ ./esc/src/lib/coolkey/SmartCardMonitoringThread.cpp	2012-05-10 15:09:37.302143792 -0700
f35d1b
@@ -29,6 +29,9 @@
f35d1b
 
f35d1b
 #include <assert.h>
f35d1b
 #include <time.h>
f35d1b
+#ifdef LINUX
f35d1b
+#include <unistd.h>
f35d1b
+#endif
f35d1b
 
f35d1b
 static PRLogModuleInfo *coolKeyLogSC = PR_NewLogModule("coolKeySmart");
f35d1b