NAME
    Lingua::Identify::Any - Detect language of text using one of several
    available backends

VERSION
    This document describes version 0.002 of Lingua::Identify::Any (from
    Perl distribution Lingua-Identify-Any), released on 2019-07-12.

SYNOPSIS
     use Lingua::Identify::Any qw(
         detect_text_language
     );

     my $res = detect_text_language(text => 'Blah blah blah');

    Sample result:

     [200, "OK", {
         backend     => 'Lingua::Identify',
         lang_code   => "en",
         confidence  => 0.78, # 1 would mean certainty
         is_reliable => 1,
     }]

DESCRIPTION
    This module offers a common interface to several language detection
    backends.

FUNCTIONS
  detect_text_language
    Usage:

     detect_text_language(%args) -> [status, msg, payload, meta]

    Detect language of text using one of several available backends.

    Backends will be tried in order. When a backend is not available, or
    when it fails to detect the language, the next backend will be tried.
    Currently supported backends:

    *   Lingua::Identify::CLD

    *   Lingua::Identify

    *   WebService::DetectLanguage (only when "try_remote_backends" is set
        to true)

    This function is not exported by default, but exportable.

    Arguments ('*' denotes required arguments):

    *   backends => *array[str]*

    *   dlcom_api_key => *str*

        API key for detectlanguage.com.

        Only required if you use WebService::DetectLanguage backend.

    *   text* => *str*

    *   try_remote_backends => *bool*

    Returns an enveloped result (an array).

    First element (status) is an integer containing HTTP status code (200
    means OK, 4xx caller error, 5xx function error). Second element (msg) is
    a string containing error message, or 'OK' if status is 200. Third
    element (payload) is optional, the actual result. Fourth element (meta)
    is called result metadata and is optional, a hash that contains extra
    information.

    Return value: (hash)

    Status: will return 200 status if detection is successful. Otherwise,
    will return 400 if a specified backend is unknown/unsupported, or 500 if
    detection has failed.

    Payload: a hash with the following keys: "backend" (the backend name
    used to produce the result), "lang_code" (str, 2-letter ISO language
    code), "confidence" (float), "is_reliable" (bool).

ENVIRONMENT
  PERL_LINGUA_IDENTIFY_ANY_BACKENDS
    String. Comma-separated list of backends.

  PERL_LINGUA_IDENTIFY_ANY_TRY_REMOTE_BACKENDS
    Boolean. Set the default for "detect_text_language"'s
    "try_remote_backends" argument.

    If set to 1, will also include backends that query remotely, e.g.
    WebService::DetectLanguage.

  PERL_LINGUA_IDENTIFY_ANY_DLCOM_API_KEY
    String. Set the default for "detect_text_language"'s "dlcom_api_key".

HOMEPAGE
    Please visit the project's homepage at
    <https://metacpan.org/release/Lingua-Identify-Any>.

SOURCE
    Source repository is at
    <https://github.com/perlancar/perl-Lingua-Identify-Any>.

BUGS
    Please report any bugs or feature requests on the bugtracker website
    <https://rt.cpan.org/Public/Dist/Display.html?Name=Lingua-Identify-Any>

    When submitting a bug or request, please include a test-file or a patch
    to an existing test-file that illustrates the bug or desired feature.

AUTHOR
    perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2019 by perlancar@cpan.org.

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