NAME
    isa - isn't the isa operator

SYNOPSIS
      use isa 'HTTP::Tiny';
  
      my $obj = MyApp->get_user_agent;
  
      if ( isa_HTTP_Tiny $obj ) {
        my $response = $obj->get( 'https://www.example.com/' );
        MyApp->do_something( $response );
      }

DESCRIPTION
    The new `isa` operator in Perl 5.32 is pretty great, but if you need to
    support legacy versions of Perl, you can't use it yet. This module gives
    you isa-like functions you can use in Perl 5.6 and above.

    If you've got Type::Tiny::XS installed, you will probably find that this
    module is *faster* than the native `isa` operator!

    The functions exported respect inheritance and allow classes to override
    their `isa` method as you'd expect.

IMPORT
    You need to list the classes you'll be using on the `use` line.

      use isa 'HTTP::Tiny', 'MyApp::Person';

    This module will replace the "::" bits with underscores, and prefix "isa_"
    to each name to create functions like `isa_HTTP_Tiny` and
    `isa_MyApp_Person`.

  Alternative Style
    If you'd prefer to pick your own names for the imported functions, you can
    use a hashref in the import:

      use isa {
        isa_Browser => 'HTTP::Tiny',
        isa_Person  => 'MyApp::Person',
      };

BUGS
    Please report any bugs to
    <http://rt.cpan.org/Dist/Display.html?Queue=isa>.

SEE ALSO
    perlop, Scalar::Util.

    <https://github.com/tobyink/p5-isa/wiki>.

AUTHOR
    Toby Inkster <tobyink@cpan.org>.

COPYRIGHT AND LICENCE
    This software is copyright (c) 2020 by Toby Inkster.

    This is free software; you can redistribute it and/or modify it under the
    same terms as the Perl 5 programming language system itself.

DISCLAIMER OF WARRANTIES
    THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
    WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
    MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.