.\" Automatically generated by Pod::Man 4.14 (Pod::Simple 3.40) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .nr rF 0 .if \n(.g .if rF .nr rF 1 .if (\n(rF:(\n(.g==0)) \{\ . if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} . \} .\} .rr rF .\" ======================================================================== .\" .IX Title "CheckDigits::M10_004 3pm" .TH CheckDigits::M10_004 3pm "2021-01-03" "perl v5.32.0" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" CheckDigits::M10_004 \- compute check digits for 2aus5, EAN, ILN, ISBN13, NVE .SH "SYNOPSIS" .IX Header "SYNOPSIS" .Vb 1 \& use Algorithm::CheckDigits; \& \& $ean = CheckDigits(\*(Aqean\*(Aq); \& \& if ($ean\->is_valid(\*(Aq7622200004607\*(Aq)) { \& # do something \& } \& \& $cn = $ean\->complete(\*(Aq762220000460\*(Aq); \& # $cn = \*(Aq7622200004607\*(Aq \& \& $cd = $ean\->checkdigit(\*(Aq7622200004607\*(Aq); \& # $cd = \*(Aq7\*(Aq \& \& $bn = $ean\->basenumber(\*(Aq7622200004607\*(Aq); \& # $bn = \*(Aq762220000460\*(Aq .Ve .SH "DESCRIPTION" .IX Header "DESCRIPTION" .SS "\s-1ALGORITHM\s0" .IX Subsection "ALGORITHM" .IP "1." 4 Beginning right all numbers are weighted alternatively 1 and 3 (that is the check digit is weighted 1). .IP "2." 4 The sum of all products is computed. .IP "3." 4 The sum of step 3 ist taken modulo 10. .IP "4." 4 The check digit is the difference between 10 and the number from step 3. .PP To validate the total of the digits of all numbers inclusive check digit taken modulo 10 must be 0. .SS "\s-1METHODS\s0" .IX Subsection "METHODS" .IP "is_valid($number)" 4 .IX Item "is_valid($number)" Returns true only if \f(CW$number\fR consists solely of digits, spaces and hyphen and the last digit is a valid check digit according to the algorithm given above. .Sp Returns false otherwise, .IP "complete($number)" 4 .IX Item "complete($number)" The check digit for \f(CW$number\fR is computed and concatenated to the end of \f(CW$number\fR. .Sp Returns the complete number with check digit or '' if \f(CW$number\fR does not consist solely of digits, spaces and hyphen. .IP "basenumber($number)" 4 .IX Item "basenumber($number)" Returns the basenumber of \f(CW$number\fR if \f(CW$number\fR has a valid check digit. .Sp Return '' otherwise. .IP "checkdigit($number)" 4 .IX Item "checkdigit($number)" Returns the checkdigit of \f(CW$number\fR if \f(CW$number\fR has a valid check digit. .Sp Return '' otherwise. .SS "\s-1EXPORT\s0" .IX Subsection "EXPORT" None by default. .SH "BUGS AND LIMITATIONS" .IX Header "BUGS AND LIMITATIONS" When invoked as \f(CW\*(C`CheckDigits(\*(Aqisbn13\*(Aq)\*(C'\fR the module checks whether the first three digits (the country code) are 978 or 979, the current (as of 2006) \s-1EAN\s0 country codes for books. If at any time other \s-1EAN\s0 country codes for \s-1ISBN\-13\s0 will be specified and the then responsible maintainer ignores this in the code, please send a friendly email. .SH "AUTHOR" .IX Header "AUTHOR" Mathias Weidner, .SH "SEE ALSO" .IX Header "SEE ALSO" perl, CheckDigits, \&\fIwww.pruefziffernberechnung.de\fR.