|
From: | Guillermo Moliní |
Subject: | Re: New package |
Date: | Wed, 16 Jul 2014 10:29:44 +0200 |
On 15 Jul 2014, at 11:19, gumlym <address@hidden> wrote:Hi again,
Ok, Ive been trying but still doesnt work. First Im going to describe what I
did before trying to do the package, so that youll be able to understand
better what im attempting.
Before, I had just programmed some functions in c, compiled in myLibrary.dll
and myLibrary.lib. Then all I did was
mkoctfile myccFile.cc myLibrary.lib
autoload("func1","myccFile.oct")
autoload("func2","myccFile.oct"),
etc.
And that works, if I then call from octave func1(), it does what its
supposed to. Im trying to accomplish the same thing, but with a package.
In the /src folder I have now the myccFile.cc (and all the .h and so on that
it needs). And the library file. The makefile just does:
all:
mkoctfile myccFile.cc myLibrary.lib
In the main directory I have a PKG_ADD file with autoloads like this:
autoload("func1",fullfile (fileparts (mfilename ("fullpath")),
"myccFile.oct”))
Several weird things happen: One is that even though pkg install mypackage
doesnt return any errors, if I write func1, it doesnt find it.That’s because you should first of all load your package:>> pkg load yourpkgAnyway, it would be probably both logically clearer and easier to maintain if you split
But if I
manually do autoload("func1", "full path to package oct installed in
octave") it does finde the function, but then it cant find the dll. So my
guess is that the first mistake im making has to do with the PKG_ADD, and
then with the library.I’ve never tried with shared libraries, but I know for sure that static libraries work ina similar context, so maybe you could try to compile forcing static linking or just removethe .dll from mkoctfile's reach.
And this brings me to another question. Should I put the myLibrary.dll and
myLibrary.lib files in the /bin directory? So that they will be
automatically copied to the exec path. Or should I keep them in the /src
directory, and then have them copied over to octave with a FILES file. I
have tried both things (and none ultimately work) and they copy the files
but to different locations.If you still have the source code I suggest you to just add it to your /src directoryand write proper lines in the Makefile to compile the library during the build process.If you have doubts about how pkg install works and what it expects to find in yourpackage, this is a quite complete reference:
On 15 Jul 2014, at 11:19, gumlym <address@hidden> wrote:
Hi again,
Ok, Ive been trying but still doesnt work. First Im going to describe what I
did before trying to do the package, so that youll be able to understand
better what im attempting.
Before, I had just programmed some functions in c, compiled in myLibrary.dll
and myLibrary.lib. Then all I did was
mkoctfile myccFile.cc myLibrary.lib
autoload("func1","myccFile.oct")
autoload("func2","myccFile.oct"),
etc.
And that works, if I then call from octave func1(), it does what its
supposed to. Im trying to accomplish the same thing, but with a package.
In the /src folder I have now the myccFile.cc (and all the .h and so on that
it needs). And the library file. The makefile just does:
all:
mkoctfile myccFile.cc myLibrary.lib
In the main directory I have a PKG_ADD file with autoloads like this:
autoload("func1",fullfile (fileparts (mfilename ("fullpath")),
"myccFile.oct”))
Several weird things happen: One is that even though pkg install mypackage
doesnt return any errors, if I write func1, it doesnt find it.
That’s because you should first of all load your package:>> pkg load yourpkg
Anyway, it would be probably both logically clearer and easier to maintain if you split
But if I
manually do autoload("func1", "full path to package oct installed in
octave") it does finde the function, but then it cant find the dll. So my
guess is that the first mistake im making has to do with the PKG_ADD, and
then with the library.
I’ve never tried with shared libraries, but I know for sure that static libraries work ina similar context, so maybe you could try to compile forcing static linking or just removethe .dll from mkoctfile's reach.
And this brings me to another question. Should I put the myLibrary.dll and
myLibrary.lib files in the /bin directory? So that they will be
automatically copied to the exec path. Or should I keep them in the /src
directory, and then have them copied over to octave with a FILES file. I
have tried both things (and none ultimately work) and they copy the files
but to different locations.
If you still have the source code I suggest you to just add it to your /src directoryand write proper lines in the Makefile to compile the library during the build process.
If you have doubts about how pkg install works and what it expects to find in yourpackage, this is a quite complete reference:
HTH,Eugenio
--
View this message in context: http://octave.1599824.n4.nabble.com/New-package-tp4665192p4665513.html
Sent from the Octave - Maintainers mailing list archive at Nabble.com.
[Prev in Thread] | Current Thread | [Next in Thread] |