B::Hooks::OP::Check
Section: User Contributed Perl Documentation (3pm)
Updated: 2022-10-19
Index
Return to Main Contents
NAME
B::Hooks::OP::Check - Wrap OP check callbacks
VERSION
version 0.22
SYNOPSIS
# include "hook_op_check.h"
STATIC OP *my_const_check_op (pTHX_ OP *op, void *user_data) {
/* ... */
return op;
}
STATIC hook_op_check_id my_hook_id = 0;
void
setup ()
CODE:
my_hook_id = hook_op_check (OP_CONST, my_const_check_op, NULL);
void
teardown ()
CODE:
hook_op_check_remove (OP_CONST, my_hook_id);
DESCRIPTION
This module provides a C API for XS modules to hook into the callbacks of
"PL_check".
ExtUtils::Depends is used to export all functions for other XS modules to
use. Include the following in your Makefile.PL:
my $pkg = ExtUtils::Depends->new('Your::XSModule', 'B::Hooks::OP::Check');
WriteMakefile(
... # your normal makefile flags
$pkg->get_makefile_vars,
);
Your XS module can now include "hook_op_check.h".
TYPES
typedef OP *(*hook_op_check_cb) (pTHX_ OP *, void *);
Type that callbacks need to implement.
typedef UV hook_op_check_id
Type to identify a callback.
FUNCTIONS
hook_op_check_id hook_op_check (opcode type, hook_op_check_cb cb, void *user_data)
Register the callback "cb" to be called after the "PL_check" function for
opcodes of the given "type". "user_data" will be passed to the callback as
the last argument. Returns an id that can be used to remove the callback later
on.
void *hook_op_check_remove (opcode type, hook_op_check_id id)
Remove the callback identified by "id". Returns the user_data that the callback had.
SUPPORT
Bugs may be submitted through the RT bug tracker <https://rt.cpan.org/Public/Dist/Display.html?Name=B-Hooks-OP-Check>
(or bug-B-Hooks-OP-Check@rt.cpan.org <mailto:bug-B-Hooks-OP-Check@rt.cpan.org>).
AUTHOR
Florian Ragwitz <rafl@debian.org>
CONTRIBUTORS
- •
-
Karen Etheridge <ether@cpan.org>
- •
-
Zefram <zefram@fysh.org>
- •
-
Alexandr Ciornii <alexchorny@gmail.com>
COPYRIGHT AND LICENCE
This software is copyright (c) 2008 by Florian Ragwitz.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
Index
- NAME
-
- VERSION
-
- SYNOPSIS
-
- DESCRIPTION
-
- TYPES
-
- typedef OP *(*hook_op_check_cb) (pTHX_ OP *, void *);
-
- typedef UV hook_op_check_id
-
- FUNCTIONS
-
- hook_op_check_id hook_op_check (opcode type, hook_op_check_cb cb, void *user_data)
-
- void *hook_op_check_remove (opcode type, hook_op_check_id id)
-
- SUPPORT
-
- AUTHOR
-
- CONTRIBUTORS
-
- COPYRIGHT AND LICENCE
-
This document was created by
man2html,
using the manual pages.
Time: 06:19:27 GMT, April 25, 2024