Do not use deprecated or obsolescent functions when more secure equivalent functions are available.
Here is a list of deprecated functions, along with their recommended alternatives if available:
| Deprecated | Preferred | 
|---|---|
|   |  object  | 
|   |  object  | 
|   |   | 
|   |   | 
|   |   | 
|   |   | 
die())This noncompliant code example tries to open a file and invokes the obsolete die() method if it fails.
| my $file; open(FILE, "<", $file) or die "error opening $file: stopped"; # work with FILE | 
The die() method is considered deprecated because it prints the file name and line number in which it was invoked. This might be sensitive information.
croak())This compliant solution uses the croak() function instead of die().
| use Carp; my $file; open(FILE, "<", $file) or croak "error opening $file: stopped"; # work with FILE | 
Unlike die(), croak() provides the file name and line number of the function that invoked the function that invoked croak(). This is more useful for application code that invokes library code; in this case, croak() and carp() also will reveal the file name and line number of the application code rather than the library code.
Failure to handle error codes or other values returned by functions can lead to incorrect program flow and violations of data integrity.
| Recommendation | Severity | Likelihood | Remediation Cost | Priority | Level | 
|---|---|---|---|---|---|
| EXP30-PL | info | probable | low | P12 | L1 | 
| Tool | Diagnostic | 
|---|---|
| Perl::Critic | BuiltinFunctions::ProhibitUniversalCan | 
| 
 | BuiltinFunctions::ProhibitUniversalIsa | 
| 
 | ErrorHandling::RequireCarping | 
| 
 | InputOutput::ProhibitInteractiveTest | 
| 
 | Miscellanea::ProhibitFormats | 
CERT C Secure Coding Standard: MSC34-C. Do not use deprecated or obsolescent functions
The CERT Oracle Secure Coding Standard for Java: MET02-J. Do not use deprecated or obsolete classes or methods
| \[[CPAN|AA. Bibliography#CPAN]\]. [Elliot Shank, Perl-Critic-1.116|http://search.cpan.org/~elliotjs/Perl-Critic-1.116/]. [ProhibitUniversalCan|http://search.cpan.org/~elliotjs/Perl-Critic-1.116/lib/Perl/Critic/Policy/BuiltinFunctions/ProhibitUniversalCan.pm], [ProhibitUniversalIsa|http://search.cpan.org/~elliotjs/Perl-Critic-1.116/lib/Perl/Critic/Policy/BuiltinFunctions/ProhibitUniversalIsa.pm], [RequireCarping|http://search.cpan.org/~elliotjs/Perl-Critic-1.116/lib/Perl/Critic/Policy/ErrorHandling/RequireCarping.pm], [InteractiveTest|http://search.cpan.org/~elliotjs/Perl-Critic-1.116/lib/Perl/Critic/Policy/InputOutput/ProhibitInteractiveTest.pm], [ProhibitFormats|http://search.cpan.org/~elliotjs/Perl-Critic-1.116/lib/Perl/Critic/Policy/Miscellanea/ProhibitFormats.pm]. \[[Conway 2005|AA. Bibliography#Conway 2005]\] | 
      02. Expressions      EXP31-PL. Do not use the two-argument form of open()