📄 verifyargs.pm
字号:
package KinoSearch::Util::VerifyArgs;use strict;use warnings;use Scalar::Util qw( blessed );use Carp;use base qw( Exporter );our @EXPORT_OK = qw( verify_args kerror a_isa_b );my $kerror;sub kerror {$kerror}# Verify that named parameters exist in a defaults hash.sub verify_args { my $defaults = shift; # leave the rest of @_ intact # verify that args came in pairs if ( @_ % 2 ) { my ( $package, $filename, $line ) = caller(1); $kerror = "Parameter error: odd number of args at $filename line $line\n"; return 0; } # verify keys, ignore values while (@_) { my ( $var, undef ) = ( shift, shift ); next if exists $defaults->{$var}; my ( $package, $filename, $line ) = caller(1); $kerror = "Invalid parameter: '$var' at $filename line $line\n"; return 0; } return 1;}=begin commenta_isa_b serves the same purpose as the isa method from UNIVERSAL, only it iscalled as a function rather than a method. # safer than $foo->isa($class), which crashes if $foo isn't blessed my $confirm = a_isa_b( $foo, $class );=end comment=cutsub a_isa_b { my ( $item, $class_name ) = @_; return 0 unless blessed($item); return $item->isa($class_name);}1;__END____H__#ifndef H_KINO_VERIFY_ARGS#define H_KINO_VERIFY_ARGS 1#include "EXTERN.h"#include "perl.h"#include "XSUB.h"#include "KinoSearchUtilCarp.h"/* Return a mortalized hash, built using a defaults hash and @_. */#define Kino_Verify_build_args_hash(args_hash, defaults_hash_name, stack_st)\ /* dXSARGS in the next function pops a stack marker, so we push one */ \ PUSHMARK(SP); \ args_hash = Kino_Verify_do_build_args_hash(defaults_hash_name, stack_st);HV* Kino_Verify_do_build_args_hash(char*, I32);SV* Kino_Verify_extract_arg(HV*, char*, I32);#endif /* include guard */__C__#include "KinoSearchUtilVerifyArgs.h"HV*Kino_Verify_do_build_args_hash(char* defaults_hash_name, I32 stack_st) { HV *defaults_hash, *args_hash; char *key; I32 key_len; STRLEN len; SV *key_sv, *val_sv, *val_copy_sv; I32 stack_pos; dXSARGS; /* create the args hash and mortalize it */ args_hash = newHV(); args_hash = (HV*)sv_2mortal( (SV*)args_hash ); /* NOTE: the defaults hash must be declared using "our" */ defaults_hash = get_hv(defaults_hash_name, 0); if (defaults_hash == NULL) Kino_confess("Can't find hash named %s", defaults_hash_name); /* make the args hash a copy of the defaults hash */ (void)hv_iterinit(defaults_hash); while ((val_sv = hv_iternextsv(defaults_hash, &key, &key_len))) { val_copy_sv = newSVsv(val_sv); hv_store(args_hash, key, key_len, val_copy_sv, 0); } /* verify and copy hash-style params into args hash from stack */ if ((items - stack_st) % 2 != 0) Kino_confess("Expecting hash-style params, " "got odd number of args"); stack_pos = stack_st; while (stack_pos < items) { key_sv = ST(stack_pos++); key = SvPV(key_sv, len); key_len = len; if (!hv_exists(args_hash, key, key_len)) { Kino_confess("Invalid parameter: '%s'", key); } val_sv = ST(stack_pos++); val_copy_sv = newSVsv(val_sv); hv_store(args_hash, key, key_len, val_copy_sv, 0); } return args_hash;}SV* Kino_Verify_extract_arg(HV* hash, char* key, I32 key_len) { SV** sv_ptr; sv_ptr = hv_fetch(hash, key, key_len, 0); if (sv_ptr == NULL) Kino_confess("Failed to retrieve hash entry '%s'", key); return *sv_ptr;}__POD__=begin devdocs=head1 NAMEKinoSearch::Util::VerifyArgs - some validation functions=head1 DESCRIPTIONProvide some utility functions under the general heading of "verification".=head1 COPYRIGHTCopyright 2005-2007 Marvin Humphrey=head1 LICENSE, DISCLAIMER, BUGS etc.See L<KinoSearch|KinoSearch> version 0.163.=end devdocs=cut
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -