NAME
    Convert::TBX::Basic - Convert TBX-Basic data into TBX-Min

VERSION
    version 0.02

SYNOPSIS
        use Convert::TBX::Basic 'basic2min';
        # create a TBX-Min document from the TBX-Basic file, using EN
        # as the source language and DE as the target language
        print ${ basic2min('/path/to/file.tbx', 'EN', 'DE')->as_xml };

DESCRIPTION
    TBX-Basic is a subset of TBX-Default which is meant to contain a smaller
    number of data categories suitable for most needs. To some users,
    however, TBX-Basic can still be too complicated. This module allows you
    to convert TBX-Basic into TBX-Min, a minimal, DCT-style dialect that
    stresses human-readability and bare-bones simplicity.

METHODS
  "basic2min"
        # example usage
        basic2min('path/to/file.tbx', 'EN', 'DE');

    Given TBX-Basic input and the source and target languages, this method
    returns a TBX::Min object containing a rough equivalent of the specified
    data. The source and target languages are necessary because TBX-Basic
    can contain many languages, while TBX-Min must contain exactly 2
    languages. The TBX-Basic data may be either a string containing a file
    name or a scalar ref containing the actual TBX-Basic document as a
    string.

    Obviously TBX-Min allows much less structured information than
    TBX-Basic, so the conversion must be lossy. "<termNote>"s, "<descrip>",
    and "<admins>"s will be converted if there is a correspondence with
    TBX-Min, but those with "type" attribute values with no correspondence
    in TBX-Min will simply be pasted as a note, prefixed with the name of
    the category and a colon. This is only possible for elements at the term
    level (children of a "<termEntry>" element) because TBX-Min only allows
    notes inside of its "<termGrp>" elements.

    As quite a bit of data can be packed into a single "<note>" element, the
    result can be quite messy. Log::Any is used to record the following:

    1   (info) the elements which are stuffed into a note

    2   (info) the elements that are skipped altogether during the
        conversion process

    3   (warn) The entries that are skipped because they contained no
        relevant language sets, and

    4   (warn) The entries that are skipped because they did not have any
        language specified.

TODO
    It would be nice to preserve the "xml:id" attributes in order to make
    the conversion process more tranparent to the user.

SEE ALSO
    basic2min (the included script)
    TBX::Min
    Convert::TBX::Min

AUTHOR
    BYU Translation Research Group <akmtrg@byu.edu>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2014 by Alan K. Melby.

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