summary refs log tree commit diff
path: root/pkgs/applications/networking
diff options
context:
space:
mode:
authorYury G. Kudryashov <urkud.urkud@gmail.com>2011-09-28 15:23:28 +0000
committerYury G. Kudryashov <urkud.urkud@gmail.com>2011-09-28 15:23:28 +0000
commite2c4af0946a31d830ce7bd88952e8d845b16b540 (patch)
treeab27d294bd41d4ec821da98477926552373ca752 /pkgs/applications/networking
parent9457c15f418d0892a49a7842c069a7274ee65c44 (diff)
downloadnixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.tar
nixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.tar.gz
nixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.tar.bz2
nixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.tar.lz
nixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.tar.xz
nixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.tar.zst
nixpkgs-e2c4af0946a31d830ce7bd88952e8d845b16b540.zip
Update opera to the latest version
Also add missing dependencies (KDE, cups, gstreamer)

svn path=/nixpkgs/trunk/; revision=29527
Diffstat (limited to 'pkgs/applications/networking')
-rw-r--r--pkgs/applications/networking/browsers/opera/builder.sh39
-rw-r--r--pkgs/applications/networking/browsers/opera/default.nix89
2 files changed, 62 insertions, 66 deletions
diff --git a/pkgs/applications/networking/browsers/opera/builder.sh b/pkgs/applications/networking/browsers/opera/builder.sh
deleted file mode 100644
index de4a413e4ac..00000000000
--- a/pkgs/applications/networking/browsers/opera/builder.sh
+++ /dev/null
@@ -1,39 +0,0 @@
-source $stdenv/setup
-
-buildPhase() {
-    true
-}
-
-installPhase() {
-    substituteInPlace install --replace /bin/pwd pwd
-    substituteInPlace install --replace /usr/local "$out"
-    
-    # Note: the "no" is because the install scripts asks whether we
-    # want to install icons in some system-wide directories.
-    
-    ensureDir "$out"
-
-    ./install --text --system
-
-    [ -z ${system##*64*} ] && suf=64
-
-    find $out -type f | while read f; do
-      echo testing "$f"
-      # patch all executables
-      if readelf -h "$f" | grep 'EXEC (Executable file)' &> /dev/null; then
-        echo "patching $f <<"
-        patchelf \
-            --set-interpreter "$(cat $NIX_GCC/nix-support/dynamic-linker)" \
-            --set-rpath "$libPath" \
-            "$f"
-      fi
-    done
-    
-    # Substitute pwd as late as possible so that the md5 checksum check of opera passes.
-    substituteInPlace $out/bin/opera --replace /bin/pwd pwd
-
-    ensureDir $out/share/applications
-    cp $desktopItem/share/applications/* $out/share/applications
-}
-
-genericBuild
diff --git a/pkgs/applications/networking/browsers/opera/default.nix b/pkgs/applications/networking/browsers/opera/default.nix
index 8b7ef628044..3dddc856963 100644
--- a/pkgs/applications/networking/browsers/opera/default.nix
+++ b/pkgs/applications/networking/browsers/opera/default.nix
@@ -1,46 +1,81 @@
-{ stdenv, fetchurl, qt, zlib, libX11, libXext, libSM, libICE, libXt, glibc
-, makeDesktopItem, freetype, fontconfig, libXft, libXrender
+{ stdenv, fetchurl, zlib, libX11, libXext, libSM, libICE, libXt
+, freetype, fontconfig, libXft, libXrender, libxcb, expat, libXau, libXdmcp
+, libuuid, cups, xz
+, gstreamer, gstPluginsBase, libxml2
+, gtkSupport ? true, glib, gtk, pango, gdk_pixbuf, cairo, atk
+, kdeSupport ? false, qt4, kdelibs
 }:
 
-assert stdenv.isLinux && stdenv.gcc.gcc != null;
+assert stdenv.isLinux && stdenv.gcc.gcc != null && stdenv.gcc.libc != null;
+
+let
+  mirror = ftp://ftp.ussg.iu.edu/pub/opera;
+in
 
 stdenv.mkDerivation rec {
-  name = "opera-10.63";
+  name = "opera-11.51-1087";
 
-  builder = ./builder.sh;
+  buildNativeInputs = [ xz ];
   
   src =
     if stdenv.system == "i686-linux" then
       fetchurl {
-        url = "http://mirror.liteserver.nl/pub/opera/linux/1063/opera-10.63-6450.i386.linux.tar.bz2";
-        sha256 = "dd105d602a4b8897749a4cb9610f8bfe2d07d4f4cc9bf3905930c65592737259";
+        url = "${mirror}/linux/1151/${name}.i386.linux.tar.bz2";
+        sha256 = "1baaim404g8nwd7knbl1p1ardpx36ib5159nkvqfnnavfyhkinp2";
       }
     else if stdenv.system == "x86_64-linux" then
       fetchurl {
-        url = "http://mirror.liteserver.nl/pub/opera/linux/1063/opera-10.63-6450.x86_64.linux.tar.bz2";
-        sha256 = "da8ae14cf317364ab0295102220246b205bf30c59c00cadb571395c90dda7c74";
+        url = "${mirror}/linux/1151/${name}.x86_64.linux.tar.xz";
+        sha256 = "1bciqyfhhdywaasj717by1a975ywf672r3pv9cw9bn0b90pgp933";
       }
     else throw "Opera is not supported on ${stdenv.system} (only i686-linux and x86_64 linux are supported)";
 
   dontStrip = 1;
-  
-  # `operapluginwrapper' requires libXt. Adding it makes startup faster
-  # and omits error messages (on x86).
-  libPath =
-    let list = [ stdenv.gcc.gcc glibc qt zlib libX11 libXt libXext libSM libICE libXft freetype fontconfig
-       libXrender];
-    in stdenv.lib.makeLibraryPath list
-        + ":" + (if stdenv.system == "x86_64-linux" then stdenv.lib.makeSearchPath "lib64" list else "");
-
-  desktopItem = makeDesktopItem {
-    name = "Opera";
-    exec = "opera";
-    icon = "opera";
-    comment = "Opera Web Browser";
-    desktopName = "Opera";
-    genericName = "Web Browser";
-    categories = "Application;Network;";
-  };
+
+  phases = "unpackPhase installPhase fixupPhase";
+
+  installPhase = ''
+    ./install --unattended --prefix $out
+    '';
+
+  buildInputs =
+    [ stdenv.gcc.gcc stdenv.gcc.libc zlib libX11 libXt libXext libSM libICE
+      libXft freetype fontconfig libXrender libuuid expat
+      gstreamer libxml2 gstPluginsBase
+    ]
+    ++ stdenv.lib.optionals gtkSupport [ glib gtk pango gdk_pixbuf cairo atk ]
+    ++ stdenv.lib.optionals kdeSupport [ kdelibs qt4 ];
+
+  libPath = stdenv.lib.makeLibraryPath buildInputs
+    + stdenv.lib.optionalString (stdenv.system == "x86_64-linux")
+      (":" + stdenv.lib.makeSearchPath "lib64" buildInputs);
+
+  preFixup =
+    ''
+    find $out/lib/opera -type f | while read f; do
+      type=$(readelf -h "$f" 2>/dev/null | grep 'Type:' | sed -e 's/ *Type: *\([A-Z]*\) (.*/\1/')
+      if [ -z "$type" ]; then
+        :
+      elif [ $type == "EXEC" ]; then
+        echo "patching $f executable <<"
+        patchelf \
+            --set-interpreter "$(cat $NIX_GCC/nix-support/dynamic-linker)" \
+            --set-rpath "${libPath}" \
+            "$f"
+      elif [ $type == "DYN" ]; then
+        echo "patching $f library <<"
+        patchelf --set-rpath "${libPath}" "$f"
+      else
+        echo "Unknown type $type"
+        exit 1
+      fi
+    done
+    '';
+
+  postFixup = ''
+    oldRPATH=`patchelf --print-rpath $out/lib/opera/opera`
+    patchelf --set-rpath $oldRPATH:${cups}/lib $out/lib/opera/opera
+    '';
 
   meta = {
     homepage = http://www.opera.com;