Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl Monk, Perl Meditation
 
PerlMonks  

Re: Prototype mismatch error - ChangeNotify

by John M. Dlugosz (Monsignor)
on May 20, 2011 at 13:20 UTC ( #905916=note: print w/ replies, xml ) Need Help??


in reply to Prototype mismatch error - ChangeNotify

The "prototype" is a declaration that a function will take arguments of a certain form. I think the error is saying that there are two conflicting declarations for INFINITE, normal and prototyped to take no arguments.

I suspect that INFINITE is a constant created via use constant, and might be declared differently in different modules. (I see it is an "XS constant" in Win32::ChangeNotify) That is, Win32::ChangeNotify might declare it one way and some other module declare it another way.

Move the Win32::ChangeNotify line higher up, so it happens first. Then the error will tell you the other place.

That will tell you exactly what the problem is. If that guess is right, you can find exports of INFINITE in two different .pm files.

Then you can post the details and module names and ask again for suggestions on remedying it. Perhaps one of the modules has it wrong and needs to be fixed. The modules in question might have a way to prevent the export. Or there may be general-purpose tricks to get around it but I don't know them off hand.

I notice from the source that ChangeNotify is exporting constants by default, without mentioning that in the documentation nor providing a way to prevent it. Using () after the use line will prevent the import function from being called, but I don't know if that will prevent it from doing other things that are necessary, too!

If the other place that imports it doesn't have a way to prevent it too, then a work-around would be to use it inside a dummy package. It is only used in one line, so delegate that line to a function in that inner package, which you call from the main code.

You should complain to the module author for having default exports.

—John


Comment on Re: Prototype mismatch error - ChangeNotify
Select or Download Code
Re^2: Prototype mismatch error - ChangeNotify
by merrymonk (Friar) on May 23, 2011 at 07:30 UTC
    By carrying out your suggested test, I identified the two modules as process.pm and changenotify.pm.
    I looked in both modules and could see both had INFINITE in the EXPORT. However, I could not recognize where either defined what INFINITE meant.
    Therefore I suspect that there is some incompatibility between these two.
    You also said “If the other place that imports it doesn't have a way to prevent it too, then a work-around
    would be to use it inside a dummy package. It is only used in one line, so delegate that line to a function in that inner package, which you call from the main code.”
    Although I have just Perl for some years it would help if you could give some more details.
    I guess I should know(!) but I simply do not understand what you mean particularly with the ‘so delegate’ part of it.
      I have had a very helpful reply from Christopher J. Madsen via RT bug-Win32-IPC@rt.cpan.org who suggested that in my case I can remove the problem by using
      use Win32::ChangeNotify qw(FILE_NOTIFY_CHANGE_SIZE);
      As this will just export _NOTIFY_CHANGE_SIZE from the module. Therefore there will not be any conflict with INFINITE. This worked so I no longer have a problem!
      Thanks for your help in pointing me in the right direction
        Ah yes, I should have thought of that. Listing the one thing you do want (or can tolerate) is different from using an empty () which will not call import at all (which is what I worried about).
      # this is the main file $x= Helper::foo(); # ... package Helper; use PoisonModule qw/ bar INFINITE/; sub foo { return bar (blah, blah, INFINITE); }

Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://905916]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others avoiding work at the Monastery: (13)
As of 2014-07-23 18:14 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    My favorite superfluous repetitious redundant duplicative phrase is:









    Results (149 votes), past polls