NAME

ReturnValue - A structured return value for failure or success

SYNOPSIS

use ReturnValue;

sub do_something {
	...;

	return ReturnValue->error(
		value       => $your_usual_error_value,
		description => 'Some longer description',
		tag         => 'short_value'
		) if $failed;

	return ReturnValue->success(
		value       => $your_usual_return_value,
		description => 'Some longer description',
		tag         => 'short_value'
		) unless $failed;
	}


my $result = do_something();
if( $result->is_error ) {
	...; # do error stuff
	}

my $result = do_something_else();
for( $result->tag ) {
	when( 'tag1' ) { ... }
	when( 'tag2' ) { ... }

	}

DESCRIPTION

The ReturnValue class provides a very simple wrapper around a value so you can tell if it's a success or failure without taking pains to examine the particular value. Instead of using exceptions, you inspect the class of the object you get back. Errors and successes flow through the same path.

This isn't particularly interesting for success values, but can be helpful with multiple ways to describe an error.

success

Create a success object

error

Create an error object

value

The value that you'd normally return. This class doesn't care what it is. It can be a number, string, or reference. It's up to your application to figure out how you want to do that.

description

A long description of the return values,

tag

A short tag suitable for switching on in a given, or something similar.

success_type

Returns the class for success objects

error_type

Returns the class for error objects

is_success

Returns true is the result represents a success

is_error

Returns true is the result represents an error

TO DO

SEE ALSO

SOURCE AVAILABILITY

This source is in Github:

http://github.com/briandfoy/returnvalue/

AUTHOR

brian d foy, <briandfoy@pobox.com>

COPYRIGHT AND LICENSE

Copyright © 2013-2025, brian d foy <briandfoy@pobox.com>. All rights reserved.

You may redistribute this under the terms of the Artistic License 2.0.