Perl subroutine calltips - with PythonScript
-
it has
... 806 325 00023D20 Perl_parse_arithexpr 807 326 00023D90 Perl_parse_barestmt 808 327 00023D60 Perl_parse_block 809 328 00023D50 Perl_parse_fullexpr 810 329 00024130 Perl_parse_fullstmt 811 32A 00023DC0 Perl_parse_label 812 32B 00023D40 Perl_parse_listexpr 813 32C 00024160 Perl_parse_stmtseq 814 32D 00023D30 Perl_parse_termexpr 815 32E 00039A50 Perl_parse_uniprop_string 816 32F 0009B3C0 Perl_parser_dup ...
-
there is even an exported function RunPerl
EXTERN_C DllExport int RunPerl(int argc, char **argv, char **env) { int exitstatus; PerlInterpreter *my_perl, *new_perl = NULL; bool use_environ = (env == environ); #ifdef PERL_GLOBAL_STRUCT #define PERLVAR(prefix,var,type) /**/ #define PERLVARA(prefix,var,type) /**/ #define PERLVARI(prefix,var,type,init) PL_Vars.prefix##var = init; #define PERLVARIC(prefix,var,type,init) PL_Vars.prefix##var = init; #include "perlvars.h" #undef PERLVAR #undef PERLVARA #undef PERLVARI #undef PERLVARIC #endif PERL_SYS_INIT(&argc,&argv); if (!(my_perl = perl_alloc())) return (1); perl_construct(my_perl); PL_perl_destruct_level = 0; /* PERL_SYS_INIT() may update the environment, e.g. via ansify_path(). * This may reallocate the RTL environment block. Therefore we need * to make sure that `env` continues to have the same value as `environ` * if we have been called this way. If we have been called with any * other value for `env` then all environment munging by PERL_SYS_INIT() * will be lost again. */ if (use_environ) env = environ; if (!perl_parse(my_perl, xs_init, argc, argv, env)) { #if defined(TOP_CLONE) && defined(USE_ITHREADS) /* XXXXXX testing */ new_perl = perl_clone(my_perl, 1); (void) perl_run(new_perl); PERL_SET_THX(my_perl); #else (void) perl_run(my_perl); #endif } exitstatus = perl_destruct(my_perl); perl_free(my_perl); #ifdef USE_ITHREADS if (new_perl) { PERL_SET_THX(new_perl); exitstatus = perl_destruct(new_perl); perl_free(new_perl); } #endif PERL_SYS_TERM(); return (exitstatus); }
-
I don’t know the guts (I was going to say “very well”, but that would be understatement; I think the unqualified comes closest to the truth), but perldoc perlembed shows how to embed the perl interpreter into an application, and takes a bit about
perl_parse
andperl_run
.But I wouldn’t know where to begin on using those functions, or even the output of
-MO=Deparse
, and implementing a stronger version of what @Michael-Vincent has shown. And even if I did, I already have my huge project of the Win32::Mechanize::NotepadPlusPlus which isn’t quite to where I want it, and the PerlScript plugin wrapper that I haven’t even started writing yet – and I cannot take on another big project until I’ve got those to a reasonably-functional level. -
no problem … I was curious and played already a bit with it.
If I’m right, then 5 lines of pythonscript might give you an embedded perl. -
@Ekopalypse said in Perl subroutine calltips - with PythonScript:
5 lines of pythonscript might give you an embedded perl.
Oh, the irony. :-)
-
:-D
this seems to do something, not sure what but it doesn’t crash my npp … so … still crossing fingers ;-)
from ctypes import CDLL, POINTER, c_int, c_char_p perllib = CDLL(r'd:\perl\bin\perl531.dll') ["-le", "print 'something \"with\" quotes';"] perllib.RunPerl.restype = c_int perllib.RunPerl.argtypes = c_int, POINTER(c_char_p), POINTER(c_char_p) args = (c_char_p * 2)(b"-le", b"print 'something \"with\" quotes';") print(perllib.RunPerl(len(args),args, None))
-
can you give me a qiuck “Win32::Mechanize::NotepadPlusPlus for dummies äh ekopalypses” to open a new npp buffer?
-
From the command line, to just open a new file tab:
perl -le "use Win32::Mechanize::NotepadPlusPlus qw/:main/; notepad->newFile();"
If you want to call a script.pl instead,
use Win32::Mechanize::NotepadPlusPlus qw/:main/; notepad->newFile();
But that assumes that perl has the right
@INC
(include library paths) to find Win32::Mechanize::NotepadPlusPlus. -
D:\perl\bin>perl D:\temp\perl\Win32-Mechanize-NotepadPlusPlus-0.005\Makefile.PL Could not open 'lib/Win32/Mechanize/NotepadPlusPlus.pm': No such file or directory at D:/perl/lib/ExtUtils/MM_Unix.pm line 2973.
Now you know why I said “… for ekopalypses” ;-)
-
hah, it is the other way around … from within the source call perl …
-
@Ekopalypse said in Perl subroutine calltips - with PythonScript:
D:\perl\bin>perl D:\temp\perl\Win32-Mechanize-NotepadPlusPlus-0.005\Makefile.PL Could not open 'lib/Win32/Mechanize/NotepadPlusPlus.pm': No such file or directory at D:/perl/lib/ExtUtils/MM_Unix.pm line 2973.
For the installation, you need to be in the
D:\temp\perl\Win32-Mechanize-NotepadPlusPlus-0.005\
directory, and rund:\perl\bin\perl Makefile.PL
instead: you need to be in the same directory as the Makefile.PL, so that the relative paths are all correct. -
and then I used nmake to create the pm’s.
I’ve copied the resulting Win32 to …/perl/lib/
but now I getCan't locate Win32/API.pm in @INC (you may need to install the Win32::API module) (@INC contains: d:/perl/site/lib d:/perl/lib) at d:/perl/lib/Win32/Mechanize/NotepadPlusPlus/Notepad.pm line 9.
-
The other thing I realized: you probably won’t have all the prerequisite modules installed. I normally use the cpanm utility, which distributes with strawberry perl, and that automatically downloads and installs prereqs before the module you’re trying to install. Without such a tool (and if you built your own perl, which I think you did to get the DLL), I don’t know that you have that.
I think the make process will tell you what prereqs you’re missing … but it’s been a long time since I’ve done a complicated manual install of a module.
Oh, yep, there, you posted the error while I was typing. You’re going to have to install at least Win32::API first… doing that manually is a pain.
When you built your own perl, did you at least get cpan, if not cpanm? I think one or both would be in the same directory as perl.exe… if you have cpanm, just do
cpanm Win32::Mechanize::NotepadPlusPlus
, and everything should work. If you have just cpan, I forget whether it handles prereqs; trycpan Win32::Mechanize::NotepadPlusPlus
; if that’s not sufficient, do the missing prereqs one at a time with thecpan
client. If you have neither… um… That’s going to be tough. -
@PeterJones said in Perl subroutine calltips - with PythonScript:
If you have just cpan, I forget whether it handles prereqs
I believe it does - I normally just use CPAN and it fetches what I need to build.
Cheers.
-
I have cpan and it keeps installing stuff - did I choose to install the world??
-
it does this now since ~10 minutes
-
finished - but no Win32::API. started cpan Win32::API now.
-
Is there a reason you build your own Perl? I have Strawberry 5.24 installed and doing this works:
That’s @Ekopalypse script from above using my “system” Strawberry Perl 5.24 DLL (the Perl that has my Win32::Mechanize::NotepadPlusPlus and all my other stull installed on it). Not sure why it’s printing “9” in the PythonScript console - is that what it’s supposed to do? I thought I’d get that string
"print something ...
Cheers.
-
I get also 9 and from the function it seems correct to return an int.
See my previous post. RunPerl returns only an int. Not sure how to get the result (the print output), so far. -
@Ekopalypse said in Perl subroutine calltips - with PythonScript:
I get also 9
Oh, OK - great then. Seems I may be able to keep testing along without having to build a Perl and just use my Strawberry install.
Cheers.