From fdf79703e21026666fd3adbb4f76ad47b62bf02c Mon Sep 17 00:00:00 2001
From: Aleksander Machniak <alec@alec.pl>
Date: Wed, 20 Nov 2013 07:42:47 -0500
Subject: [PATCH] Merge branch 'master' of github.com:roundcube/roundcubemail

---
 program/lib/Roundcube/rcube_browser.php |   41 ++++++++++++++---------------------------
 tests/Framework/Browser.php             |   16 +++-------------
 2 files changed, 17 insertions(+), 40 deletions(-)

diff --git a/program/lib/Roundcube/rcube_browser.php b/program/lib/Roundcube/rcube_browser.php
index 6d5decf..e53e312 100644
--- a/program/lib/Roundcube/rcube_browser.php
+++ b/program/lib/Roundcube/rcube_browser.php
@@ -28,37 +28,24 @@
     {
         $HTTP_USER_AGENT = strtolower($_SERVER['HTTP_USER_AGENT']);
 
-        $this->ver = 0;
-        $this->win = strpos($HTTP_USER_AGENT, 'win') != false;
-        $this->mac = strpos($HTTP_USER_AGENT, 'mac') != false;
+        $this->ver   = 0;
+        $this->win   = strpos($HTTP_USER_AGENT, 'win') != false;
+        $this->mac   = strpos($HTTP_USER_AGENT, 'mac') != false;
         $this->linux = strpos($HTTP_USER_AGENT, 'linux') != false;
         $this->unix  = strpos($HTTP_USER_AGENT, 'unix') != false;
 
-        $this->opera = strpos($HTTP_USER_AGENT, 'opera') !== false;
-        $this->ns4 = strpos($HTTP_USER_AGENT, 'mozilla/4') !== false && strpos($HTTP_USER_AGENT, 'msie') === false;
-        $this->ns  = ($this->ns4 || strpos($HTTP_USER_AGENT, 'netscape') !== false);
-        $this->ie  = !$this->opera && (strpos($HTTP_USER_AGENT, 'compatible; msie') !== false || strpos($HTTP_USER_AGENT, 'trident/') !== false);
-        $this->khtml = strpos($HTTP_USER_AGENT, 'khtml') !== false;
-        $this->mz  = !$this->ie && !$this->khtml && strpos($HTTP_USER_AGENT, 'mozilla/5') !== false;
+        $this->opera  = strpos($HTTP_USER_AGENT, 'opera') !== false;
+        $this->ns     = strpos($HTTP_USER_AGENT, 'netscape') !== false;
         $this->chrome = strpos($HTTP_USER_AGENT, 'chrome') !== false;
-        $this->safari = !$this->chrome && ($this->khtml || strpos($HTTP_USER_AGENT, 'safari') !== false);
+        $this->ie     = !$this->opera && (strpos($HTTP_USER_AGENT, 'compatible; msie') !== false || strpos($HTTP_USER_AGENT, 'trident/') !== false);
+        $this->safari = !$this->chrome && (strpos($HTTP_USER_AGENT, 'safari') !== false || strpos($HTTP_USER_AGENT, 'applewebkit') !== false);
+        $this->mz     = !$this->ie && !$this->safari && !$this->chrome && !$this->ns && strpos($HTTP_USER_AGENT, 'mozilla') !== false;
 
-        if ($this->ns || $this->chrome) {
-            $test = preg_match('/(mozilla|chrome)\/([0-9.]+)/', $HTTP_USER_AGENT, $regs);
-            $this->ver = $test ? (float)$regs[2] : 0;
+        if (preg_match('/(chrome|msie|opera|version|khtml)(\s*|\/)([0-9.]+)/', $HTTP_USER_AGENT, $regs)) {
+            $this->ver = (float) $regs[3];
         }
-        else if ($this->mz) {
-            $test = preg_match('/rv:([0-9.]+)/', $HTTP_USER_AGENT, $regs);
-            $this->ver = $test ? (float)$regs[1] : 0;
-        }
-        else if ($this->ie || $this->opera) {
-            $test = preg_match('/(msie|opera) ([0-9.]+)/', $HTTP_USER_AGENT, $regs);
-            $this->ver = $test ? (float)$regs[2] : 0;
-
-            // IE 11
-            if (!$this->ver && preg_match('/rv:([0-9.]+)/', $HTTP_USER_AGENT, $regs)) {
-                $this->ver = (float) $regs[1];
-            }
+        else if (preg_match('/rv:([0-9.]+)/', $HTTP_USER_AGENT, $regs)) {
+            $this->ver = (float) $regs[1];
         }
 
         if (preg_match('/ ([a-z]{2})-([a-z]{2})/', $HTTP_USER_AGENT, $regs))
@@ -66,10 +53,10 @@
         else
             $this->lang =  'en';
 
-        $this->dom = ($this->mz || $this->safari || ($this->ie && $this->ver>=5) || ($this->opera && $this->ver>=7));
+        $this->dom      = $this->mz || $this->safari || ($this->ie && $this->ver>=5) || ($this->opera && $this->ver>=7);
         $this->pngalpha = $this->mz || $this->safari || ($this->ie && $this->ver>=5.5) ||
             ($this->ie && $this->ver>=5 && $this->mac) || ($this->opera && $this->ver>=7) ? true : false;
-        $this->imgdata = !$this->ie;
+        $this->imgdata  = !$this->ie;
     }
 }
 
diff --git a/tests/Framework/Browser.php b/tests/Framework/Browser.php
index ac92e41..a042572 100644
--- a/tests/Framework/Browser.php
+++ b/tests/Framework/Browser.php
@@ -21,7 +21,7 @@
     /**
      * @dataProvider browsers
      */
-    function test_browser($useragent, $opera, $chrome, $ie, $ns, $ns4, $khtml, $safari, $mz)
+    function test_browser($useragent, $opera, $chrome, $ie, $ns, $safari, $mz)
     {
 
         $object = $this->getBrowser($useragent);
@@ -30,8 +30,6 @@
         $this->assertEquals($chrome, $object->chrome, 'Check for Chrome failed');
         $this->assertEquals($ie, $object->ie, 'Check for IE failed');
         $this->assertEquals($ns, $object->ns, 'Check for NS failed');
-        $this->assertEquals($ns4, $object->ns4, 'Check for NS4 failed');
-        $this->assertEquals($khtml, $object->khtml, 'Check for khtml failed');
         $this->assertEquals($safari, $object->safari, 'Check for Safari failed');
         $this->assertEquals($mz, $object->mz, 'Check for MZ failed');
     }
@@ -132,7 +130,7 @@
 
     function browsers()
     {
-        return $this->extractDataSet(array('isOpera','isChrome','isIE','isNS','isNS4','isKHTML','isSafari','isMZ'));
+        return $this->extractDataSet(array('isOpera','isChrome','isIE','isNS','isSafari','isMZ'));
     }
 
     function useragents()
@@ -149,8 +147,6 @@
                  'isChrome'     => false,                                                                                           //isChrome
                  'isIE'         => false,                                                                                           //isIE
                  'isNS'         => false,                                                                                           //isNS
-                 'isNS4'        => false,                                                                                           //isNS4
-                 'isKHTML'      => false,                                                                                           //isKHTML
                  'isSafari'     => false,                                                                                           //isSafari
                  'isMZ'         => true,                                                                                           //isMZ
                  'lang'         => 'en-US',                                                                               //lang
@@ -169,8 +165,6 @@
                  'isChrome'     => false,                                                                                           //isChrome
                  'isIE'         => false,                                                                                           //isIE
                  'isNS'         => false,                                                                                           //isNS
-                 'isNS4'        => false,                                                                                           //isNS4
-                 'isKHTML'      => false,                                                                                           //isKHTML
                  'isSafari'     => false,                                                                                           //isSafari
                  'isMZ'         => true,                                                                                           //isMZ
                  'lang'         => 'en-US',                                                                               //lang
@@ -181,7 +175,7 @@
 
             'Chrome Mac' => array(
                  'useragent'    => 'Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10_6_4; en-US) AppleWebKit/534.3 (KHTML, like Gecko) Chrome/6.0.461.0 Safari/534.3',
-                 'version'      => '5',                                                                                      //Version
+                 'version'      => '6',                                                                                      //Version
                  'isWin'        => false,                                                                                           //isWindows
                  'isLinux'      => false,
                  'isMac'        => true,                                                                                           //isMac
@@ -190,8 +184,6 @@
                  'isChrome'     => true,                                                                                           //isChrome
                  'isIE'         => false,                                                                                           //isIE
                  'isNS'         => false,                                                                                           //isNS
-                 'isNS4'        => false,                                                                                           //isNS4
-                 'isKHTML'      => true,                                                                                           //isKHTML
                  'isSafari'     => false,                                                                                           //isSafari
                  'isMZ'         => false,                                                                                           //isMZ
                  'lang'         => 'en-US',                                                                               //lang
@@ -211,8 +203,6 @@
                  'isChrome'     => false,                                                                                           //isChrome
                  'isIE'         => true,                                                                                           //isIE
                  'isNS'         => false,                                                                                           //isNS
-                 'isNS4'        => false,                                                                                           //isNS4
-                 'isKHTML'      => false,                                                                                           //isKHTML
                  'isSafari'     => false,                                                                                           //isSafari
                  'isMZ'         => false,                                                                                           //isMZ
                  'lang'         => '',                                                                                         //lang

--
Gitblit v1.9.1