Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

module_* #5

Open
xenoterracide opened this issue Jun 13, 2013 · 3 comments
Open

module_* #5

xenoterracide opened this issue Jun 13, 2013 · 3 comments

Comments

@xenoterracide
Copy link

any chance you'll be adding support for things like module_dir? so I could write

my $config  = module_file( __PACKAGE__, 'config.yml' );
@kentfredric
Copy link
Member

The problem therein is that while its easy to resolve where the sharedir is for __PACKAGE__ in an install ENV, its not so straight forward during development, because of the property where 1 dist has 1 share dir, but 1 dist has many modules , and each module has its own sharedir, and thus, 1 dist -> many module sharedirs.

ie: When you install those sharedirs with Dist::Zilla, you often have to provide a mapping to tell File::ShareDir::Install where to find a given share dir for a given module, and an equivalent is thus mandatory for this module, which somewhat breaks the notion of "no configuration, just works" that this module mostly relies on.

If you can propose some syntax to make this mapping possible, I'm all for it, but I'm inclined to think it would be grounds for a distinct module to prevent the guts getting too messy.

@xenoterracide
Copy link
Author

outside of saying standard File::ShareDir location, or look in share (maybe some defined default substructure of share) , I don't have any good suggestions. It's likely I don't understand the problem well enough. Realistically this is about me not liking hardcoding the current dist in the module.

@kentfredric
Copy link
Member

The very best I think you'll be able to achieve automatically, is a layout such as

/
/share/
/share/Some::Module::Name::Here

But that seems problematic as I'd imagine not all filesystem types support :: in filenames.

A transliteration such as

/
/share/
/share/Some-Module-Name-Here

could work, but thats still rather wordy.

I think the best I can muster is having a default of /share/Some-Module-Name-Here, and look for a sub on __PACKAGE__ called _develop_share_subdir that simply returned the name of the development sharedir to use.

So the effective synopsis would be

    package Long::Name::Here;
    use File::ShareDir::ProjectDistDir::Module qw( module_dir module_file );
    sub _develop_share_subdir { 'longnamehere' }
    ...
    sub bar {
      my $dir = module_dir(__PACKAGE__ ); 
      my $file = module_file( __PACKAGE__, 'config.yml' );
    }

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants