in reply to Re: Unabled to use exported routine
in thread Unable to use exported routine

I know that will make it work, but in the way I had it, why was it even able to 'use' the module? There must be something different about how functions are exported than how modules are accessed that I don't understand. It's that understanding that I'm looking for :)

Replies are listed 'Best First'.
Re^3: Unabled to use exported routine
by Fletch (Bishop) on Apr 02, 2009 at 21:28 UTC

    There's nothing strictly speaking which directly ties the package namespace the contents of a module defines with the filename containing it. You could have a file Fred/Ethyl/Mertzomatic.pm which contained a line package Ricky::Lucy::Recardotron; and use Fred::Ethyl::Mertzomatic; would succeed fine so long as it parsed and returned a true value. You can also have code in several different namespaces in the same file if you like (often used to declare subclasses or subsidiary packages which are pulled in by using the top level module).

    However use will look and see if the package corresponding to the name it was given has an import method and will call that method if it exists; since your example doesn't define a method dir::mod->import (directly or through inheritance; you do declare, implicitly through inheritance, mod->import though) Exporter's import is never called and so the assignment of \&mod::hello into *main::hello never occurs and you get the undefined sub error at runtime.

    That clear things up?

    The cake is a lie.
    The cake is a lie.
    The cake is a lie.

      That makes sense. Thanks!
Re^3: Unabled to use exported routine
by linuxer (Curate) on Apr 02, 2009 at 21:23 UTC

    Well, I am not so familiar with the internal Perl actions, but I assume the problem is something like this:

    use dir::mod; is internally a combination of require dir::mod; and import dir::mod;.

    require dir::mod works, as it is translated into a file path dir/mod.pm and that file is found and read. Then it tries to import the exported stuff from the dir::mod namespace. But this is not defined as your package name is mod, and not dir::mod.

    If you'd call mod::hello() your script should work.