Yep, works on my machine as well. Seems like it would be a pain to have to do it manually every time csaw (or deepSNV, or diffHic) gets re-installed, though.

I should stress that I didn't do anything special to my R installation to get it to install packages in a different place. As far as I know, that's just what R decided to do by itself. (I never run R with sudo permissions, so it wouldn't be able to put packages in the central R installation folder anyway.)

So I think it's worth seriously thinking about whether this scenario should be supported; a user (i.e., me) would reasonably expect that BioC packages would work off the bat on this "standard" setting. Perhaps the csaw.so library can be built with static linkage to the libhts.a?

Or maybe I'm just spouting rubbish here. I don't know, I never do any serious work on a Mac.

Cheers,

Aaron


On 24/05/16 18:42, Dan Tenenbaum wrote:


----- Original Message -----
From: "Dan Tenenbaum" <dtene...@fredhutch.org>
To: "Aaron Lun" <a...@wehi.edu.au>
Cc: "bioc-devel" <bioc-devel@r-project.org>
Sent: Tuesday, May 24, 2016 9:38:01 AM
Subject: Re: [Bioc-devel] problems linking to Rhtslib on Mac OSX

----- Original Message -----
From: "Dan Tenenbaum" <dtene...@fredhutch.org>
To: "Aaron Lun" <a...@wehi.edu.au>
Cc: "bioc-devel" <bioc-devel@r-project.org>
Sent: Tuesday, May 24, 2016 8:51:30 AM
Subject: Re: [Bioc-devel] problems linking to Rhtslib on Mac OSX

----- Original Message -----
From: "Aaron Lun" <a...@wehi.edu.au>
To: "bioc-devel" <bioc-devel@r-project.org>
Sent: Tuesday, May 24, 2016 8:06:13 AM
Subject: Re: [Bioc-devel] problems linking to Rhtslib on Mac OSX

Dear Martin and List,

I have a problem with linking to Rhtslib on Mac OSX when my R installation
directory differs from the package installation directory. Trying to load csaw
(Bioc release version) gives me:

require(csaw)
# ... whole lot of dependencies...
Loading required package: csaw
Error in dyn.load(file, DLLpath = DLLpath, ...) :
  unable to load shared object
  '/Users/lun01/Library/R/3.3/library/csaw/libs/csaw.so':
  dlopen(/Users/lun01/Library/R/3.3/library/csaw/libs/csaw.so, 6): Library not
  loaded:
  
/Library/Frameworks/R.framework/Versions/3.3/Resources/library/Rhtslib/lib/libhts.0.dylib
  Referenced from: /Users/lun01/Library/R/3.3/library/csaw/libs/csaw.so
  Reason: image not found

... which is because my Rhtslib shared library is sitting instead at
/Users/lun01/Library/R/3.3/library/Rhtslib/lib/libhts.0.dylib (along with all
my other non-recommended, non-base packages). I presume this linking failure
occurs because the Makevars file (which would normally indicate where the
shared library is living) doesn't get run when installing a prebuilt binary?
The same issue occurs with deepSNV, which is the other package that links to
Rhtslib.


I can't reproduce this issue after installing the binaries of csaw and Rhtslib.
I believe that htslib is statically linked inside of Rhtslib so you don't need
your own installation of htslib on your machine in order to use it.If you look
at the Mac tarball
(https://bioconductor.org/packages/release/bioc/bin/macosx/mavericks/contrib/3.3/Rhtslib_1.4.2.tgz)
untar it and go to the Rhtslib/lib directory you see the following files:

libhts.0.dylib
libhts.a
libhts.dylib

...in addition to Rhtslib.so which is in Rhtslib/libs.


Actually I can induce issues if I install Rhtslib in a different library
directory, which is what you were saying. Will look into this a little.


The following seems to fix it:

cd ~/Library/R/3.3/csaw/libs
# change dtenenba to your username in the below
sudo install_name_tool -change 
"/Library/Frameworks/R.framework/Versions/3.3/Resources/library/Rhtslib/lib/libhts.0.dylib"
 "/Users/dtenenba/Library/R/3.3/Rhtslib/lib/libhts.0.dylib" csaw.so

(the sudo may not be necessary)

Then I can
require(csaw)

and it works.

I'm not sure if there is something that the bioc group should be doing about 
this....we'll discuss it when we meet soon.

Dan



Dan



Dan




Any thoughts? I don't usually use Macs, so I don't know exactly what goes on
during package installation, or whether my setup (i.e., with different
package/R locations) is atypical or not.

Aaron

sessionInfo()
R version 3.3.0 (2016-05-03)
Platform: x86_64-apple-darwin13.4.0 (64-bit)
Running under: OS X 10.10.5 (Yosemite)

locale:
[1] en_GB.UTF-8/en_GB.UTF-8/en_GB.UTF-8/C/en_GB.UTF-8/en_GB.UTF-8

attached base packages:
[1] stats4    parallel  stats     graphics  grDevices utils     datasets
[8] methods   base

other attached packages:
[1] SummarizedExperiment_1.2.2 Biobase_2.32.0
[3] GenomicRanges_1.24.0       GenomeInfoDb_1.8.1
[5] IRanges_2.6.0              S4Vectors_0.10.1
[7] BiocGenerics_0.18.0        BiocInstaller_1.22.2

loaded via a namespace (and not attached):
[1] AnnotationDbi_1.34.3    XVector_0.12.0          edgeR_3.14.0
[4] GenomicAlignments_1.8.0 zlibbioc_1.18.0         BiocParallel_1.6.2
[7] tools_3.3.0             DBI_0.4-1               Rhtslib_1.4.2
[10] rtracklayer_1.32.0      bitops_1.0-6            RCurl_1.95-4.8
[13] biomaRt_2.28.0          RSQLite_1.0.0           limma_3.28.5
[16] GenomicFeatures_1.24.2  Biostrings_2.40.1       Rsamtools_1.24.0
[19] XML_3.98-1.4
______________________________________________________________________

The information in this email is confidential and inte...{{dropped:6}}

_______________________________________________
Bioc-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/bioc-devel

_______________________________________________
Bioc-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/bioc-devel

_______________________________________________
Bioc-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/bioc-devel

Reply via email to