Merge pull request #59512 from averelld/rstudio-upgrade
Rstudio upgrade
This commit is contained in:
commit
408f62bf67
@ -1,43 +1,49 @@
|
|||||||
{ stdenv, fetchurl, fetchFromGitHub, makeDesktopItem, cmake, boost
|
{ stdenv, fetchurl, fetchFromGitHub, makeDesktopItem, cmake, boost, zlib
|
||||||
, zlib, openssl, R, qtbase, qtwebkit, qtwebchannel, qtxmlpatterns, libuuid
|
, openssl, R, qtbase, qtxmlpatterns, qtsensors, qtwebengine, qtwebchannel
|
||||||
, hunspellDicts, unzip, ant, jdk, gnumake, makeWrapper, pandoc
|
, libuuid, hunspellDicts, unzip, ant, jdk, gnumake, makeWrapper, pandoc
|
||||||
|
, llvmPackages
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
verMajor = "1";
|
verMajor = "1";
|
||||||
verMinor = "1";
|
verMinor = "2";
|
||||||
verPatch = "463";
|
verPatch = "1335";
|
||||||
version = "${verMajor}.${verMinor}.${verPatch}";
|
version = "${verMajor}.${verMinor}.${verPatch}";
|
||||||
ginVer = "1.5";
|
ginVer = "2.1.2";
|
||||||
gwtVer = "2.7.0";
|
gwtVer = "2.8.1";
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "RStudio-${version}";
|
name = "RStudio-${version}";
|
||||||
|
|
||||||
nativeBuildInputs = [ cmake unzip ant jdk makeWrapper pandoc ];
|
nativeBuildInputs = [ cmake unzip ant jdk makeWrapper pandoc ];
|
||||||
|
|
||||||
buildInputs = [ boost zlib openssl R qtbase qtwebkit qtwebchannel
|
buildInputs = [ boost zlib openssl R qtbase qtxmlpatterns qtsensors
|
||||||
qtxmlpatterns libuuid ];
|
qtwebengine qtwebchannel libuuid ];
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "rstudio";
|
owner = "rstudio";
|
||||||
repo = "rstudio";
|
repo = "rstudio";
|
||||||
rev = "v${version}";
|
rev = "v${version}";
|
||||||
sha256 = "014g984znsczzy1fyn9y1ly3rbsngryfs674lfgciz60mqnl8im6";
|
sha256 = "0jv1d4yznv2lzwp0fdf377vqpg0k2q4z9qvji4sj86fabj835lqd";
|
||||||
};
|
};
|
||||||
|
|
||||||
# Hack RStudio to only use the input R.
|
# Hack RStudio to only use the input R and provided libclang.
|
||||||
patches = [ ./r-location.patch ];
|
patches = [ ./r-location.patch ./clang-location.patch ];
|
||||||
postPatch = "substituteInPlace src/cpp/core/r_util/REnvironmentPosix.cpp --replace '@R@' ${R}";
|
postPatch = ''
|
||||||
|
substituteInPlace src/cpp/core/r_util/REnvironmentPosix.cpp --replace '@R@' ${R}
|
||||||
|
substituteInPlace src/cpp/core/libclang/LibClang.cpp \
|
||||||
|
--replace '@clang@' ${llvmPackages.clang.cc} \
|
||||||
|
--replace '@libclang.so@' ${llvmPackages.clang.cc.lib}/lib/libclang.so
|
||||||
|
'';
|
||||||
|
|
||||||
ginSrc = fetchurl {
|
ginSrc = fetchurl {
|
||||||
url = "https://s3.amazonaws.com/rstudio-buildtools/gin-${ginVer}.zip";
|
url = "https://s3.amazonaws.com/rstudio-buildtools/gin-${ginVer}.zip";
|
||||||
sha256 = "155bjrgkf046b8ln6a55x06ryvm8agnnl7l8bkwwzqazbpmz8qgm";
|
sha256 = "16jzmljravpz6p2rxa87k5f7ir8vs7ya75lnfybfajzmci0p13mr";
|
||||||
};
|
};
|
||||||
|
|
||||||
gwtSrc = fetchurl {
|
gwtSrc = fetchurl {
|
||||||
url = "https://s3.amazonaws.com/rstudio-buildtools/gwt-${gwtVer}.zip";
|
url = "https://s3.amazonaws.com/rstudio-buildtools/gwt-${gwtVer}.zip";
|
||||||
sha256 = "1cs78z9a1jg698j2n35wsy07cy4fxcia9gi00x0r0qc3fcdhcrda";
|
sha256 = "19x000m3jwnkqgi6ic81lkzyjvvxcfacw2j0vcfcaknvvagzhyhb";
|
||||||
};
|
};
|
||||||
|
|
||||||
hunspellDictionaries = with stdenv.lib; filter isDerivation (attrValues hunspellDicts);
|
hunspellDictionaries = with stdenv.lib; filter isDerivation (attrValues hunspellDicts);
|
||||||
@ -47,14 +53,11 @@ stdenv.mkDerivation rec {
|
|||||||
sha256 = "0wbcqb9rbfqqvvhqr1pbqax75wp8ydqdyhp91fbqfqp26xzjv6lk";
|
sha256 = "0wbcqb9rbfqqvvhqr1pbqax75wp8ydqdyhp91fbqfqp26xzjv6lk";
|
||||||
};
|
};
|
||||||
|
|
||||||
rstudiolibclang = fetchurl {
|
rsconnectSrc = fetchFromGitHub {
|
||||||
url = https://s3.amazonaws.com/rstudio-buildtools/libclang-3.5.zip;
|
owner = "rstudio";
|
||||||
sha256 = "1sl5vb8misipwbbbykdymw172w9qrh8xv3p29g0bf3nzbnv6zc7c";
|
repo = "rsconnect";
|
||||||
};
|
rev = "984745d8";
|
||||||
|
sha256 = "037z0y32k1gdda192y5qn5hi7wp8wyap44mkjlklrgcqkmlcylb9";
|
||||||
rstudiolibclangheaders = fetchurl {
|
|
||||||
url = https://s3.amazonaws.com/rstudio-buildtools/libclang-builtin-headers.zip;
|
|
||||||
sha256 = "0x4ax186bm3kf098izwmsplckgx1kqzg9iiyzg95rpbqsb4593qb";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
preConfigure =
|
preConfigure =
|
||||||
@ -80,13 +83,14 @@ stdenv.mkDerivation rec {
|
|||||||
done
|
done
|
||||||
|
|
||||||
unzip ${mathJaxSrc} -d dependencies/common/mathjax-26
|
unzip ${mathJaxSrc} -d dependencies/common/mathjax-26
|
||||||
mkdir -p dependencies/common/libclang/3.5
|
|
||||||
unzip ${rstudiolibclang} -d dependencies/common/libclang/3.5
|
|
||||||
mkdir -p dependencies/common/libclang/builtin-headers
|
|
||||||
unzip ${rstudiolibclangheaders} -d dependencies/common/libclang/builtin-headers
|
|
||||||
|
|
||||||
mkdir -p dependencies/common/pandoc
|
mkdir -p dependencies/common/pandoc
|
||||||
cp ${pandoc}/bin/pandoc dependencies/common/pandoc/
|
cp ${pandoc}/bin/pandoc dependencies/common/pandoc/
|
||||||
|
|
||||||
|
cp -r ${rsconnectSrc} dependencies/common/rsconnect
|
||||||
|
pushd dependencies/common
|
||||||
|
${R}/bin/R CMD build -d --no-build-vignettes rsconnect
|
||||||
|
popd
|
||||||
'';
|
'';
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
@ -1,119 +0,0 @@
|
|||||||
{ stdenv, fetchurl, fetchFromGitHub, makeDesktopItem, cmake, boost, zlib
|
|
||||||
, openssl, R, qtbase, qtxmlpatterns, qtsensors, qtwebengine, qtwebchannel
|
|
||||||
, libuuid, hunspellDicts, unzip, ant, jdk, gnumake, makeWrapper, pandoc
|
|
||||||
, llvmPackages
|
|
||||||
}:
|
|
||||||
|
|
||||||
let
|
|
||||||
rev = "f79330d4";
|
|
||||||
ginVer = "2.1.2";
|
|
||||||
gwtVer = "2.8.1";
|
|
||||||
in
|
|
||||||
stdenv.mkDerivation rec {
|
|
||||||
name = "RStudio-preview-${rev}";
|
|
||||||
|
|
||||||
nativeBuildInputs = [ cmake unzip ant jdk makeWrapper pandoc ];
|
|
||||||
|
|
||||||
buildInputs = [ boost zlib openssl R qtbase qtxmlpatterns qtsensors
|
|
||||||
qtwebengine qtwebchannel libuuid ];
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "rstudio";
|
|
||||||
repo = "rstudio";
|
|
||||||
inherit rev;
|
|
||||||
sha256 = "0v3vzqjp74c3m4h9l6w2lrdnjqaimdjzbf7vhnlxj2qa0lwsnykb";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Hack RStudio to only use the input R and provided libclang.
|
|
||||||
patches = [ ./r-location.patch ./clang-location.patch ];
|
|
||||||
postPatch = ''
|
|
||||||
substituteInPlace src/cpp/core/r_util/REnvironmentPosix.cpp --replace '@R@' ${R}
|
|
||||||
substituteInPlace src/cpp/core/libclang/LibClang.cpp \
|
|
||||||
--replace '@clang@' ${llvmPackages.clang.cc} \
|
|
||||||
--replace '@libclang.so@' ${llvmPackages.clang.cc.lib}/lib/libclang.so
|
|
||||||
'';
|
|
||||||
|
|
||||||
ginSrc = fetchurl {
|
|
||||||
url = "https://s3.amazonaws.com/rstudio-buildtools/gin-${ginVer}.zip";
|
|
||||||
sha256 = "16jzmljravpz6p2rxa87k5f7ir8vs7ya75lnfybfajzmci0p13mr";
|
|
||||||
};
|
|
||||||
|
|
||||||
gwtSrc = fetchurl {
|
|
||||||
url = "https://s3.amazonaws.com/rstudio-buildtools/gwt-${gwtVer}.zip";
|
|
||||||
sha256 = "19x000m3jwnkqgi6ic81lkzyjvvxcfacw2j0vcfcaknvvagzhyhb";
|
|
||||||
};
|
|
||||||
|
|
||||||
hunspellDictionaries = with stdenv.lib; filter isDerivation (attrValues hunspellDicts);
|
|
||||||
|
|
||||||
mathJaxSrc = fetchurl {
|
|
||||||
url = https://s3.amazonaws.com/rstudio-buildtools/mathjax-26.zip;
|
|
||||||
sha256 = "0wbcqb9rbfqqvvhqr1pbqax75wp8ydqdyhp91fbqfqp26xzjv6lk";
|
|
||||||
};
|
|
||||||
|
|
||||||
rsconnectSrc = fetchFromGitHub {
|
|
||||||
owner = "rstudio";
|
|
||||||
repo = "rsconnect";
|
|
||||||
rev = "984745d8";
|
|
||||||
sha256 = "037z0y32k1gdda192y5qn5hi7wp8wyap44mkjlklrgcqkmlcylb9";
|
|
||||||
};
|
|
||||||
|
|
||||||
preConfigure =
|
|
||||||
''
|
|
||||||
GWT_LIB_DIR=src/gwt/lib
|
|
||||||
|
|
||||||
mkdir -p $GWT_LIB_DIR/gin/${ginVer}
|
|
||||||
unzip ${ginSrc} -d $GWT_LIB_DIR/gin/${ginVer}
|
|
||||||
|
|
||||||
unzip ${gwtSrc}
|
|
||||||
mkdir -p $GWT_LIB_DIR/gwt
|
|
||||||
mv gwt-${gwtVer} $GWT_LIB_DIR/gwt/${gwtVer}
|
|
||||||
|
|
||||||
mkdir dependencies/common/dictionaries
|
|
||||||
for dict in ${builtins.concatStringsSep " " hunspellDictionaries}; do
|
|
||||||
for i in "$dict/share/hunspell/"*; do
|
|
||||||
ln -sv $i dependencies/common/dictionaries/
|
|
||||||
done
|
|
||||||
done
|
|
||||||
|
|
||||||
unzip ${mathJaxSrc} -d dependencies/common/mathjax-26
|
|
||||||
|
|
||||||
mkdir -p dependencies/common/pandoc
|
|
||||||
cp ${pandoc}/bin/pandoc dependencies/common/pandoc/
|
|
||||||
|
|
||||||
cp -r ${rsconnectSrc} dependencies/common/rsconnect
|
|
||||||
pushd dependencies/common
|
|
||||||
${R}/bin/R CMD build -d --no-build-vignettes rsconnect
|
|
||||||
popd
|
|
||||||
'';
|
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
|
||||||
|
|
||||||
cmakeFlags = [ "-DRSTUDIO_TARGET=Desktop" "-DQT_QMAKE_EXECUTABLE=$NIX_QT5_TMP/bin/qmake" ];
|
|
||||||
|
|
||||||
desktopItem = makeDesktopItem {
|
|
||||||
name = name;
|
|
||||||
exec = "rstudio %F";
|
|
||||||
icon = "rstudio";
|
|
||||||
desktopName = "RStudio Preview";
|
|
||||||
genericName = "IDE";
|
|
||||||
comment = meta.description;
|
|
||||||
categories = "Development;";
|
|
||||||
mimeType = "text/x-r-source;text/x-r;text/x-R;text/x-r-doc;text/x-r-sweave;text/x-r-markdown;text/x-r-html;text/x-r-presentation;application/x-r-data;application/x-r-project;text/x-r-history;text/x-r-profile;text/x-tex;text/x-markdown;text/html;text/css;text/javascript;text/x-chdr;text/x-csrc;text/x-c++hdr;text/x-c++src;";
|
|
||||||
};
|
|
||||||
|
|
||||||
postInstall = ''
|
|
||||||
wrapProgram $out/bin/rstudio --suffix PATH : ${gnumake}/bin
|
|
||||||
mkdir $out/share
|
|
||||||
cp -r ${desktopItem}/share/applications $out/share
|
|
||||||
mkdir $out/share/icons
|
|
||||||
ln $out/rstudio.png $out/share/icons
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = with stdenv.lib;
|
|
||||||
{ description = "Set of integrated tools for the R language";
|
|
||||||
homepage = https://www.rstudio.com/;
|
|
||||||
license = licenses.agpl3;
|
|
||||||
maintainers = with maintainers; [ averelld ];
|
|
||||||
platforms = platforms.linux;
|
|
||||||
};
|
|
||||||
}
|
|
@ -19839,9 +19839,6 @@ in
|
|||||||
|
|
||||||
rstudio = libsForQt5.callPackage ../applications/editors/rstudio {
|
rstudio = libsForQt5.callPackage ../applications/editors/rstudio {
|
||||||
boost = boost166;
|
boost = boost166;
|
||||||
};
|
|
||||||
rstudio-preview = libsForQt5.callPackage ../applications/editors/rstudio/preview.nix {
|
|
||||||
boost = boost166;
|
|
||||||
llvmPackages = llvmPackages_7;
|
llvmPackages = llvmPackages_7;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user