--- /dev/null
+import urllib2
+import sys
+
+DATA = 'http://www.unicode.org/Public/6.0.0/ucd/UnicodeData.txt'
+OUTPUT = 'src/iso6937_tables'
+
+data = urllib2.urlopen(DATA).read()
+# data = open('UnicodeData.txt').read()
+output_c = open(OUTPUT + '.cc', 'w')
+output_h = open(OUTPUT + '.h', 'w')
+
+def find_unicode(n):
+ for line in iter(data.splitlines()):
+ s = line.split(';')
+ if s[1] == n:
+ return s[0]
+
+ print 'Could not find %s' % n
+ sys.exit(1)
+
+def setup(output_diacritical_name):
+ print>>output_c,'map<char, wchar_t> sub::iso6937::%s;' % output_diacritical_name
+
+def fill(unicode_diacritical_name, output_diacritical_name, letters):
+
+ print>>output_h,'extern std::map<char, wchar_t> %s;' % output_diacritical_name
+
+ for letter in letters:
+ if letter.isupper():
+ case = 'CAPITAL'
+ else:
+ case = 'SMALL'
+
+ unicode_name = 'LATIN %s LETTER %s WITH %s' % (case, letter.upper(), unicode_diacritical_name)
+ print>>output_c,"\t%s['%s'] = 0x%s;" % (output_diacritical_name, letter, find_unicode(unicode_name))
+
+ print>>output_c,""
+
+print>>output_c,"""/*
+ Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+/* THIS FILE WAS AUTO-GENERATED BY iso6937.py */
+
+#include <map>
+#include "iso6937_tables.h"
+
+using std::map;
+"""
+
+print>>output_h,"""/*
+ Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+/* THIS FILE WAS AUTO-GENERATED BY iso6937.py */
+
+#include <map>
+
+namespace sub {
+
+extern void make_iso6937_tables ();
+
+namespace iso6937 {
+"""
+
+groups = [
+ ('GRAVE', 'grave', 'AEIOUaeiou'),
+ ('ACUTE', 'acute', 'ACEILNORSUYZacegilnorsuyz'),
+ ('CIRCUMFLEX', 'circumflex', 'ACEGHIJOSUWYaceghijosuwy'),
+ ('TILDE', 'tilde', 'AINOUainou'),
+ ('MACRON', 'macron', 'AEIOUaeiou'),
+ ('BREVE', 'breve', 'AGUagu'),
+ ('DOT ABOVE', 'dot', 'CEGIZcegz'),
+ ('DIAERESIS', 'diaeresis', 'AEIOUYaeiouy'),
+ ('RING ABOVE', 'ring', 'AUau'),
+ ('CEDILLA', 'cedilla', 'CGKLNRSTcklnrst'),
+ ('DOUBLE ACUTE', 'double_acute', 'OUou'),
+ ('OGONEK', 'ogonek', 'AEIUaeui'),
+ ('CARON', 'caron', 'CDELNRSTZcdelnrstz')
+]
+
+for g in groups:
+ setup(g[1])
+
+print>>output_c,"map<char, wchar_t> sub::iso6937::main;"
+print>>output_h,"extern std::map<char, wchar_t> main;"
+
+print>>output_c,"""
+void
+sub::make_iso6937_tables ()
+{
+\tusing namespace sub::iso6937;
+"""
+
+for g in groups:
+ fill(g[0], g[1], g[2])
+
+print>>output_c,"\tmain[10] = 0x000A;"
+
+for i in range(32, 127):
+ if chr(i) == "'" or chr(i) == "\\":
+ print>>output_c,"\tmain['\\%s'] = 0x00%x;" % (chr(i), i)
+ else:
+ print>>output_c,"\tmain['%s'] = 0x00%x;" % (chr(i), i)
+
+# From Wikipedia
+# http://en.wikipedia.org/wiki/ISO/IEC_6937
+print>>output_c,"\tmain[161] = 0x00A1;"
+print>>output_c,"\tmain[162] = 0x00A2;"
+print>>output_c,"\tmain[163] = 0x00A3;"
+print>>output_c,"\tmain[165] = 0x00A5;"
+print>>output_c,"\tmain[167] = 0x00A7;"
+print>>output_c,"\tmain[168] = 0x00A4;"
+print>>output_c,"\tmain[169] = 0x2018;"
+print>>output_c,"\tmain[170] = 0x201C;"
+print>>output_c,"\tmain[171] = 0x00AB;"
+print>>output_c,"\tmain[172] = 0x2190;"
+print>>output_c,"\tmain[173] = 0x2191;"
+print>>output_c,"\tmain[174] = 0x2192;"
+print>>output_c,"\tmain[175] = 0x2193;"
+print>>output_c,"\tmain[176] = 0x00B0;"
+print>>output_c,"\tmain[177] = 0x00B1;"
+print>>output_c,"\tmain[178] = 0x00B2;"
+print>>output_c,"\tmain[179] = 0x00B3;"
+print>>output_c,"\tmain[180] = 0x00D7;"
+print>>output_c,"\tmain[181] = 0x00B5;"
+print>>output_c,"\tmain[182] = 0x00B6;"
+print>>output_c,"\tmain[183] = 0x00B7;"
+print>>output_c,"\tmain[184] = 0x00F7;"
+print>>output_c,"\tmain[185] = 0x2019;"
+print>>output_c,"\tmain[186] = 0x201D;"
+print>>output_c,"\tmain[187] = 0x00BB;"
+print>>output_c,"\tmain[188] = 0x00BC;"
+print>>output_c,"\tmain[189] = 0x00BD;"
+print>>output_c,"\tmain[190] = 0x00BE;"
+print>>output_c,"\tmain[191] = 0x00BF;"
+print>>output_c,"\tmain[193] = 0x0300;"
+print>>output_c,"\tmain[194] = 0x0301;"
+print>>output_c,"\tmain[195] = 0x0302;"
+print>>output_c,"\tmain[196] = 0x0303;"
+print>>output_c,"\tmain[197] = 0x0304;"
+print>>output_c,"\tmain[198] = 0x0306;"
+print>>output_c,"\tmain[199] = 0x0307;"
+print>>output_c,"\tmain[200] = 0x0308;"
+print>>output_c,"\tmain[202] = 0x030A;"
+print>>output_c,"\tmain[203] = 0x0327;"
+print>>output_c,"\tmain[205] = 0x030B;"
+print>>output_c,"\tmain[206] = 0x032B;"
+print>>output_c,"\tmain[207] = 0x030C;"
+print>>output_c,"\tmain[208] = 0x2015;"
+print>>output_c,"\tmain[209] = 0x00B9;"
+print>>output_c,"\tmain[210] = 0x00AE;"
+print>>output_c,"\tmain[211] = 0x00A9;"
+print>>output_c,"\tmain[212] = 0x2122;"
+print>>output_c,"\tmain[213] = 0x266A;"
+print>>output_c,"\tmain[214] = 0x00AC;"
+print>>output_c,"\tmain[215] = 0x00A6;"
+print>>output_c,"\tmain[220] = 0x215B;"
+print>>output_c,"\tmain[221] = 0x215C;"
+print>>output_c,"\tmain[222] = 0x215D;"
+print>>output_c,"\tmain[223] = 0x215E;"
+print>>output_c,"\tmain[224] = 0x2126;"
+print>>output_c,"\tmain[225] = 0x00C6;"
+print>>output_c,"\tmain[226] = 0x0110;"
+print>>output_c,"\tmain[227] = 0x00AA;"
+print>>output_c,"\tmain[228] = 0x0126;"
+print>>output_c,"\tmain[230] = 0x0132;"
+print>>output_c,"\tmain[231] = 0x013F;"
+print>>output_c,"\tmain[232] = 0x0141;"
+print>>output_c,"\tmain[233] = 0x00D8;"
+print>>output_c,"\tmain[234] = 0x0152;"
+print>>output_c,"\tmain[235] = 0x00BA;"
+print>>output_c,"\tmain[236] = 0x00DE;"
+print>>output_c,"\tmain[237] = 0x0166;"
+print>>output_c,"\tmain[238] = 0x014A;"
+print>>output_c,"\tmain[239] = 0x0149;"
+print>>output_c,"\tmain[240] = 0x0138;"
+print>>output_c,"\tmain[241] = 0x00E6;"
+print>>output_c,"\tmain[242] = 0x0111;"
+print>>output_c,"\tmain[243] = 0x00F0;"
+print>>output_c,"\tmain[244] = 0x0127;"
+print>>output_c,"\tmain[245] = 0x0131;"
+print>>output_c,"\tmain[246] = 0x0133;"
+print>>output_c,"\tmain[247] = 0x0140;"
+print>>output_c,"\tmain[248] = 0x0142;"
+print>>output_c,"\tmain[249] = 0x00F8;"
+print>>output_c,"\tmain[250] = 0x0153;"
+print>>output_c,"\tmain[251] = 0x00DF;"
+print>>output_c,"\tmain[252] = 0x00FE;"
+print>>output_c,"\tmain[253] = 0x0167;"
+print>>output_c,"\tmain[254] = 0x014B;"
+print>>output_c,"\tmain[255] = 0x00AD;"
+
+print>>output_c,"}"
+print>>output_h,""
+print>>output_h,"}"
+print>>output_h,"}"
*/
#include <boost/lexical_cast.hpp>
+#include <boost/algorithm/string.hpp>
+#include <boost/locale.hpp>
#include "stl_binary_reader.h"
#include "exceptions.h"
+#include "iso6937.h"
#include "compose.hpp"
using std::map;
using std::string;
using std::istream;
using boost::lexical_cast;
+using boost::algorithm::replace_all;
+using boost::locale::conv::utf_to_utf;
using namespace sub;
-template <class T>
-T
-string_to_value (string k, map<string, STLCode<T> > m, string name)
+template <class E, class F>
+E
+file_to_enum (F k, map<F, STLCode<E> > m, string name)
{
- typename map<string, STLCode<T> >::const_iterator i = m.find (k);
+ typename map<F, STLCode<E> >::const_iterator i = m.find (k);
if (i == m.end ()) {
throw STLError (String::compose ("Unknown %1 %2 in binary STL file", name, k));
}
return i->second.value;
}
-template <class T>
+template <class E, class F>
string
-value_to_description (T v, map<string, STLCode<T> > const & m)
+enum_to_description (E v, map<F, STLCode<E> > const & m)
{
- for (typename map<string, STLCode<T> >::const_iterator i = m.begin(); i != m.end(); ++i) {
+ for (typename map<F, STLCode<E> >::const_iterator i = m.begin(); i != m.end(); ++i) {
if (i->second.value == v) {
return i->second.description;
}
return "";
}
-template <class T>
+template <class E, class F>
void
-code (map<string, STLCode<T> >& m, string k, T v, string d)
+code (map<F, STLCode<E> >& m, F k, E v, string d)
{
- m[k] = STLCode<T> (v, d);
+ m[k] = STLCode<E> (v, d);
}
STLBinaryReader::STLBinaryReader (istream& in)
: _buffer (new unsigned char[1024])
{
- create_maps ();
+ create_tables ();
in.read ((char *) _buffer, 1024);
if (in.gcount() != 1024) {
throw STLError ("Could not read GSI block from binary STL file");
}
- code_page_number = atoi (fixed_string (0, 3).c_str ());
+ code_page_number = atoi (get_string (0, 3).c_str ());
- string const dfc = fixed_string (3, 8);
+ string const dfc = get_string (3, 8);
if (dfc == "STL24.01") {
frame_rate = 24;
} else if (dfc == "STL25.01") {
throw STLError (String::compose ("Unknown disk format code %1 in binary STL file", dfc));
}
- display_standard = string_to_value (fixed_string (11, 1), _display_standard_map, "display standard code");
- language_group = string_to_value (fixed_string (12, 2), _language_group_map, "character code");
- language = string_to_value (fixed_string (14, 2), _language_map, "language code");
- original_programme_title = fixed_string (16, 32);
- original_episode_title = fixed_string (48, 32);
- translated_programme_title = fixed_string (80, 32);
- translated_episode_title = fixed_string (112, 32);
- translator_name = fixed_string (144, 32);
- translator_contact_details = fixed_string (176, 32);
- subtitle_list_reference_code = fixed_string (208, 32);
- creation_date = fixed_string (224, 6);
- revision_date = fixed_string (230, 6);
- revision_number = fixed_string (236, 2);
-
- tti_blocks = atoi (fixed_string (238, 6).c_str ());
- number_of_subtitles = atoi (fixed_string (243, 5).c_str ());
- subtitle_groups = atoi (fixed_string (248, 3).c_str ());
- maximum_characters = atoi (fixed_string (251, 2).c_str ());
- maximum_rows = atoi (fixed_string (253, 2).c_str ());
- timecode_status = string_to_value (fixed_string (255, 1), _timecode_status_map, "timecode status code");
- start_of_programme = fixed_string (256, 8);
- first_in_cue = fixed_string (256, 8);
- disks = atoi (fixed_string (272, 1).c_str ());
- disk_sequence_number = atoi (fixed_string (273, 1).c_str ());
- country_of_origin = fixed_string (274, 3);
- publisher = fixed_string (277, 32);
- editor_name = fixed_string (309, 32);
- editor_contact_details = fixed_string (341, 32);
+ display_standard = file_to_enum (get_string (11, 1), _display_standard_map, "display standard code");
+ language_group = file_to_enum (get_string (12, 2), _language_group_map, "character code");
+ language = file_to_enum (get_string (14, 2), _language_map, "language code");
+ original_programme_title = get_string (16, 32);
+ original_episode_title = get_string (48, 32);
+ translated_programme_title = get_string (80, 32);
+ translated_episode_title = get_string (112, 32);
+ translator_name = get_string (144, 32);
+ translator_contact_details = get_string (176, 32);
+ subtitle_list_reference_code = get_string (208, 32);
+ creation_date = get_string (224, 6);
+ revision_date = get_string (230, 6);
+ revision_number = get_string (236, 2);
+
+ tti_blocks = atoi (get_string (238, 5).c_str ());
+ number_of_subtitles = atoi (get_string (243, 5).c_str ());
+ subtitle_groups = atoi (get_string (248, 3).c_str ());
+ maximum_characters = atoi (get_string (251, 2).c_str ());
+ maximum_rows = atoi (get_string (253, 2).c_str ());
+ timecode_status = file_to_enum (get_string (255, 1), _timecode_status_map, "timecode status code");
+ start_of_programme = get_string (256, 8);
+ first_in_cue = get_string (256, 8);
+ disks = atoi (get_string (272, 1).c_str ());
+ disk_sequence_number = atoi (get_string (273, 1).c_str ());
+ country_of_origin = get_string (274, 3);
+ publisher = get_string (277, 32);
+ editor_name = get_string (309, 32);
+ editor_contact_details = get_string (341, 32);
+
+ for (int i = 0; i < tti_blocks; ++i) {
+ Subtitle sub;
+
+ in.read ((char *) _buffer, 128);
+ if (in.gcount() != 128) {
+ throw STLError ("Could not read TTI block from binary STL file");
+ }
+
+ if (file_to_enum (get_int (15, 1), _comment_map, "comment flag") == COMMENT_YES) {
+ continue;
+ }
+
+ sub.from.frame = get_timecode (5);
+ sub.to.frame = get_timecode (9);
+ sub.line = get_int (13, 1);
+
+ /* XXX: justification, effects */
+
+ string s = get_string (16, 112);
+
+ /* 8Ah is a new line */
+ replace_all (s, "\x8a", "\n");
+
+ /* 8Fh is unused space, so trim the string to the first instance of that */
+ size_t unused = s.find_first_of ('\x8f');
+ if (unused != string::npos) {
+ s = s.substr (0, unused);
+ }
+
+ sub.text = utf_to_utf<char> (iso6937_to_utf16 (s.c_str()));
+
+ _subs.push_back (sub);
+ }
}
STLBinaryReader::~STLBinaryReader ()
}
string
-STLBinaryReader::fixed_string (int offset, int length) const
+STLBinaryReader::get_string (int offset, int length) const
{
string s;
for (int i = 0; i < length; ++i) {
return s;
}
+int
+STLBinaryReader::get_int (int offset, int length) const
+{
+ int v = 0;
+ for (int i = 0; i < length; ++i) {
+ v |= _buffer[offset + i] << (8 * i);
+ }
+
+ return v;
+}
+
+FrameTime
+STLBinaryReader::get_timecode (int offset) const
+{
+ return FrameTime (_buffer[offset], _buffer[offset + 1], _buffer[offset + 2], _buffer[offset + 3]);
+}
+
map<string, string>
STLBinaryReader::metadata () const
{
m["Code page number"] = lexical_cast<string> (code_page_number);
m["Frame rate"] = lexical_cast<string> (frame_rate);
- m["Display standard"] = value_to_description (display_standard, _display_standard_map);
- m["Language group"] = value_to_description (language_group, _language_group_map);
- m["Language"] = value_to_description (language, _language_map);
+ m["Display standard"] = enum_to_description (display_standard, _display_standard_map);
+ m["Language group"] = enum_to_description (language_group, _language_group_map);
+ m["Language"] = enum_to_description (language, _language_map);
m["Original programme title"] = original_programme_title;
m["Original episode title"] = original_episode_title;
m["Translated programme title"] = translated_programme_title;
m["Subtitle groups"] = lexical_cast<string> (subtitle_groups);
m["Maximum characters"] = lexical_cast<string> (maximum_characters);
m["Maximum rows"] = lexical_cast<string> (maximum_rows);
- m["Timecode status"] = value_to_description (timecode_status, _timecode_status_map);
+ m["Timecode status"] = enum_to_description (timecode_status, _timecode_status_map);
m["Start of programme"] = start_of_programme;
m["First in cue"] = first_in_cue;
m["Disks"] = lexical_cast<string> (disks);
}
void
-STLBinaryReader::create_maps ()
+STLBinaryReader::create_tables ()
{
- code (_display_standard_map, " ", DISPLAY_STANDARD_UNDEFINED, "Undefined");
- code (_display_standard_map, "0", DISPLAY_STANDARD_OPEN_SUBTITLING, "Open subtitling");
- code (_display_standard_map, "1", DISPLAY_STANDARD_LEVEL_1_TELETEXT, "Level 1 teletext");
- code (_display_standard_map, "2", DISPLAY_STANDARD_LEVEL_2_TELETEXT, "Level 2 teletext");
+ code<DisplayStandard, string> (_display_standard_map, " ", DISPLAY_STANDARD_UNDEFINED, "Undefined");
+ code<DisplayStandard, string> (_display_standard_map, "0", DISPLAY_STANDARD_OPEN_SUBTITLING, "Open subtitling");
+ code<DisplayStandard, string> (_display_standard_map, "1", DISPLAY_STANDARD_LEVEL_1_TELETEXT, "Level 1 teletext");
+ code<DisplayStandard, string> (_display_standard_map, "2", DISPLAY_STANDARD_LEVEL_2_TELETEXT, "Level 2 teletext");
- code (_language_group_map, "00", LANGUAGE_GROUP_LATIN, "Latin");
- code (_language_group_map, "01", LANGUAGE_GROUP_LATIN_CYRILLIC, "Latin/Cyrillic");
- code (_language_group_map, "02", LANGUAGE_GROUP_LATIN_ARABIC, "Latin/Arabic");
- code (_language_group_map, "03", LANGUAGE_GROUP_LATIN_GREEK, "Latin/Greek");
- code (_language_group_map, "04", LANGUAGE_GROUP_LATIN_HEBREW, "Latin/Hebrew");
+ code<LanguageGroup, string> (_language_group_map, "00", LANGUAGE_GROUP_LATIN, "Latin");
+ code<LanguageGroup, string> (_language_group_map, "01", LANGUAGE_GROUP_LATIN_CYRILLIC, "Latin/Cyrillic");
+ code<LanguageGroup, string> (_language_group_map, "02", LANGUAGE_GROUP_LATIN_ARABIC, "Latin/Arabic");
+ code<LanguageGroup, string> (_language_group_map, "03", LANGUAGE_GROUP_LATIN_GREEK, "Latin/Greek");
+ code<LanguageGroup, string> (_language_group_map, "04", LANGUAGE_GROUP_LATIN_HEBREW, "Latin/Hebrew");
- code (_language_map, "00", LANGUAGE_UNKNOWN, "Unknown");
- code (_language_map, "01", LANGUAGE_ALBANIAN, "Albanian");
- code (_language_map, "02", LANGUAGE_BRETON, "Breton");
- code (_language_map, "03", LANGUAGE_CATALAN, "Catalan");
- code (_language_map, "04", LANGUAGE_CROATIAN, "Croatian");
- code (_language_map, "05", LANGUAGE_WELSH, "Welsh");
- code (_language_map, "06", LANGUAGE_CZECH, "Czech");
- code (_language_map, "07", LANGUAGE_DANISH, "Danish");
- code (_language_map, "08", LANGUAGE_GERMAN, "German");
- code (_language_map, "09", LANGUAGE_ENGLISH, "English");
- code (_language_map, "0A", LANGUAGE_SPANISH, "Spanish");
- code (_language_map, "0B", LANGUAGE_ESPERANTO, "Esperanto");
- code (_language_map, "0C", LANGUAGE_ESTONIAN, "Estonian");
- code (_language_map, "0D", LANGUAGE_BASQUE, "Basque");
- code (_language_map, "0E", LANGUAGE_FAROESE, "Faroese");
- code (_language_map, "0F", LANGUAGE_FRENCH, "French");
- code (_language_map, "10", LANGUAGE_FRISIAN, "Frisian");
- code (_language_map, "11", LANGUAGE_IRISH, "Irish");
- code (_language_map, "12", LANGUAGE_GAELIC, "Gaelic");
- code (_language_map, "13", LANGUAGE_GALACIAN, "Galacian");
- code (_language_map, "14", LANGUAGE_ICELANDIC, "Icelandic");
- code (_language_map, "15", LANGUAGE_ITALIAN, "Italian");
- code (_language_map, "16", LANGUAGE_LAPPISH, "Lappish");
- code (_language_map, "17", LANGUAGE_LATIN, "Latin");
- code (_language_map, "18", LANGUAGE_LATVIAN, "Latvian");
- code (_language_map, "19", LANGUAGE_LUXEMBORGIAN, "Luxemborgian");
- code (_language_map, "1A", LANGUAGE_LITHUANIAN, "Lithuanian");
- code (_language_map, "1B", LANGUAGE_HUNGARIAN, "Hungarian");
- code (_language_map, "1C", LANGUAGE_MALTESE, "Maltese");
- code (_language_map, "1D", LANGUAGE_DUTCH, "Dutch");
- code (_language_map, "1E", LANGUAGE_NORWEGIAN, "Norwegian");
- code (_language_map, "1F", LANGUAGE_OCCITAN, "Occitan");
- code (_language_map, "20", LANGUAGE_POLISH, "Polish");
- code (_language_map, "21", LANGUAGE_PORTUGESE, "Portugese");
- code (_language_map, "22", LANGUAGE_ROMANIAN, "Romanian");
- code (_language_map, "23", LANGUAGE_ROMANSH, "Romansh");
- code (_language_map, "24", LANGUAGE_SERBIAN, "Serbian");
- code (_language_map, "25", LANGUAGE_SLOVAK, "Slovak");
- code (_language_map, "26", LANGUAGE_SLOVENIAN, "Slovenian");
- code (_language_map, "27", LANGUAGE_FINNISH, "Finnish");
- code (_language_map, "28", LANGUAGE_SWEDISH, "Swedish");
- code (_language_map, "29", LANGUAGE_TURKISH, "Turkish");
- code (_language_map, "2A", LANGUAGE_FLEMISH, "Flemish");
- code (_language_map, "2B", LANGUAGE_WALLON, "Wallon");
- code (_language_map, "7F", LANGUAGE_AMHARIC, "Amharic");
- code (_language_map, "7E", LANGUAGE_ARABIC, "Arabic");
- code (_language_map, "7D", LANGUAGE_ARMENIAN, "Armenian");
- code (_language_map, "7C", LANGUAGE_ASSAMESE, "Assamese");
- code (_language_map, "7B", LANGUAGE_AZERBAIJANI, "Azerbaijani");
- code (_language_map, "7A", LANGUAGE_BAMBORA, "Bambora");
- code (_language_map, "79", LANGUAGE_BIELORUSSIAN, "Bielorussian");
- code (_language_map, "78", LANGUAGE_BENGALI, "Bengali");
- code (_language_map, "77", LANGUAGE_BULGARIAN, "Bulgarian");
- code (_language_map, "76", LANGUAGE_BURMESE, "Burmese");
- code (_language_map, "75", LANGUAGE_CHINESE, "Chinese");
- code (_language_map, "74", LANGUAGE_CHURASH, "Churash");
- code (_language_map, "73", LANGUAGE_DARI, "Dari");
- code (_language_map, "72", LANGUAGE_FULANI, "Fulani");
- code (_language_map, "71", LANGUAGE_GEORGIAN, "Georgian");
- code (_language_map, "70", LANGUAGE_GREEK, "Greek");
- code (_language_map, "6F", LANGUAGE_GUJURATI, "Gujarati");
- code (_language_map, "6E", LANGUAGE_GURANI, "Gurani");
- code (_language_map, "6D", LANGUAGE_HAUSA, "Hausa");
- code (_language_map, "6C", LANGUAGE_HEBREW, "Hebrew");
- code (_language_map, "6B", LANGUAGE_HINDI, "Hindi");
- code (_language_map, "6A", LANGUAGE_INDONESIAN, "Indonesian");
- code (_language_map, "69", LANGUAGE_JAPANESE, "Japanese");
- code (_language_map, "68", LANGUAGE_KANNADA, "Kannada");
- code (_language_map, "67", LANGUAGE_KAZAKH, "Kazakh");
- code (_language_map, "66", LANGUAGE_KHMER, "Khmer");
- code (_language_map, "65", LANGUAGE_KOREAN, "Korean");
- code (_language_map, "64", LANGUAGE_LAOTIAN, "Laotian");
- code (_language_map, "63", LANGUAGE_MACEDONIAN, "Macedonian");
- code (_language_map, "62", LANGUAGE_MALAGASAY, "Malagasay");
- code (_language_map, "61", LANGUAGE_MALAYSIAN, "Malaysian");
- code (_language_map, "60", LANGUAGE_MOLDAVIAN, "Moldavian");
- code (_language_map, "5F", LANGUAGE_MARATHI, "Marathi");
- code (_language_map, "5E", LANGUAGE_NDEBELE, "Ndebele");
- code (_language_map, "5D", LANGUAGE_NEPALI, "Nepali");
- code (_language_map, "5C", LANGUAGE_ORIYA, "Oriya");
- code (_language_map, "5B", LANGUAGE_PAPAMIENTO, "Papamiento");
- code (_language_map, "5A", LANGUAGE_PERSIAN, "Persian");
- code (_language_map, "59", LANGUAGE_PUNJABI, "Punjabi");
- code (_language_map, "58", LANGUAGE_PUSHTU, "Pushtu");
- code (_language_map, "57", LANGUAGE_QUECHUA, "Quechua");
- code (_language_map, "56", LANGUAGE_RUSSIAN, "Russian");
- code (_language_map, "55", LANGUAGE_RUTHENIAN, "Ruthenian");
- code (_language_map, "54", LANGUAGE_SERBO_CROAT, "Serbo Croat");
- code (_language_map, "53", LANGUAGE_SHONA, "Shona");
- code (_language_map, "52", LANGUAGE_SINHALESE, "Sinhalese");
- code (_language_map, "51", LANGUAGE_SOMALI, "Somali");
- code (_language_map, "50", LANGUAGE_SRANAN_TONGO, "Sranan Tongo");
- code (_language_map, "4F", LANGUAGE_SWAHILI, "Swahili");
- code (_language_map, "4E", LANGUAGE_TADZHIK, "Tadzhik");
- code (_language_map, "4D", LANGUAGE_TAMIL, "Tamil");
- code (_language_map, "4C", LANGUAGE_TATAR, "Tatar");
- code (_language_map, "4B", LANGUAGE_TELUGU, "Telugu");
- code (_language_map, "4A", LANGUAGE_THAI, "Thai");
- code (_language_map, "49", LANGUAGE_UKRANIAN, "Ukranian");
- code (_language_map, "48", LANGUAGE_URDU, "Urdu");
- code (_language_map, "47", LANGUAGE_UZBEK, "Uzbek");
- code (_language_map, "46", LANGUAGE_VIETNAMESE, "Vietnamese");
- code (_language_map, "45", LANGUAGE_ZULU, "Zulu");
-
- code (_timecode_status_map, "0", TIMECODE_STATUS_NOT_INTENDED_FOR_USE, "Not intended for use");
- code (_timecode_status_map, "1", TIMECODE_STATUS_INTENDED_FOR_USE, "Intended for use");
+ code<Language, string> (_language_map, "00", LANGUAGE_UNKNOWN, "Unknown");
+ code<Language, string> (_language_map, "01", LANGUAGE_ALBANIAN, "Albanian");
+ code<Language, string> (_language_map, "02", LANGUAGE_BRETON, "Breton");
+ code<Language, string> (_language_map, "03", LANGUAGE_CATALAN, "Catalan");
+ code<Language, string> (_language_map, "04", LANGUAGE_CROATIAN, "Croatian");
+ code<Language, string> (_language_map, "05", LANGUAGE_WELSH, "Welsh");
+ code<Language, string> (_language_map, "06", LANGUAGE_CZECH, "Czech");
+ code<Language, string> (_language_map, "07", LANGUAGE_DANISH, "Danish");
+ code<Language, string> (_language_map, "08", LANGUAGE_GERMAN, "German");
+ code<Language, string> (_language_map, "09", LANGUAGE_ENGLISH, "English");
+ code<Language, string> (_language_map, "0A", LANGUAGE_SPANISH, "Spanish");
+ code<Language, string> (_language_map, "0B", LANGUAGE_ESPERANTO, "Esperanto");
+ code<Language, string> (_language_map, "0C", LANGUAGE_ESTONIAN, "Estonian");
+ code<Language, string> (_language_map, "0D", LANGUAGE_BASQUE, "Basque");
+ code<Language, string> (_language_map, "0E", LANGUAGE_FAROESE, "Faroese");
+ code<Language, string> (_language_map, "0F", LANGUAGE_FRENCH, "French");
+ code<Language, string> (_language_map, "10", LANGUAGE_FRISIAN, "Frisian");
+ code<Language, string> (_language_map, "11", LANGUAGE_IRISH, "Irish");
+ code<Language, string> (_language_map, "12", LANGUAGE_GAELIC, "Gaelic");
+ code<Language, string> (_language_map, "13", LANGUAGE_GALACIAN, "Galacian");
+ code<Language, string> (_language_map, "14", LANGUAGE_ICELANDIC, "Icelandic");
+ code<Language, string> (_language_map, "15", LANGUAGE_ITALIAN, "Italian");
+ code<Language, string> (_language_map, "16", LANGUAGE_LAPPISH, "Lappish");
+ code<Language, string> (_language_map, "17", LANGUAGE_LATIN, "Latin");
+ code<Language, string> (_language_map, "18", LANGUAGE_LATVIAN, "Latvian");
+ code<Language, string> (_language_map, "19", LANGUAGE_LUXEMBORGIAN, "Luxemborgian");
+ code<Language, string> (_language_map, "1A", LANGUAGE_LITHUANIAN, "Lithuanian");
+ code<Language, string> (_language_map, "1B", LANGUAGE_HUNGARIAN, "Hungarian");
+ code<Language, string> (_language_map, "1C", LANGUAGE_MALTESE, "Maltese");
+ code<Language, string> (_language_map, "1D", LANGUAGE_DUTCH, "Dutch");
+ code<Language, string> (_language_map, "1E", LANGUAGE_NORWEGIAN, "Norwegian");
+ code<Language, string> (_language_map, "1F", LANGUAGE_OCCITAN, "Occitan");
+ code<Language, string> (_language_map, "20", LANGUAGE_POLISH, "Polish");
+ code<Language, string> (_language_map, "21", LANGUAGE_PORTUGESE, "Portugese");
+ code<Language, string> (_language_map, "22", LANGUAGE_ROMANIAN, "Romanian");
+ code<Language, string> (_language_map, "23", LANGUAGE_ROMANSH, "Romansh");
+ code<Language, string> (_language_map, "24", LANGUAGE_SERBIAN, "Serbian");
+ code<Language, string> (_language_map, "25", LANGUAGE_SLOVAK, "Slovak");
+ code<Language, string> (_language_map, "26", LANGUAGE_SLOVENIAN, "Slovenian");
+ code<Language, string> (_language_map, "27", LANGUAGE_FINNISH, "Finnish");
+ code<Language, string> (_language_map, "28", LANGUAGE_SWEDISH, "Swedish");
+ code<Language, string> (_language_map, "29", LANGUAGE_TURKISH, "Turkish");
+ code<Language, string> (_language_map, "2A", LANGUAGE_FLEMISH, "Flemish");
+ code<Language, string> (_language_map, "2B", LANGUAGE_WALLON, "Wallon");
+ code<Language, string> (_language_map, "7F", LANGUAGE_AMHARIC, "Amharic");
+ code<Language, string> (_language_map, "7E", LANGUAGE_ARABIC, "Arabic");
+ code<Language, string> (_language_map, "7D", LANGUAGE_ARMENIAN, "Armenian");
+ code<Language, string> (_language_map, "7C", LANGUAGE_ASSAMESE, "Assamese");
+ code<Language, string> (_language_map, "7B", LANGUAGE_AZERBAIJANI, "Azerbaijani");
+ code<Language, string> (_language_map, "7A", LANGUAGE_BAMBORA, "Bambora");
+ code<Language, string> (_language_map, "79", LANGUAGE_BIELORUSSIAN, "Bielorussian");
+ code<Language, string> (_language_map, "78", LANGUAGE_BENGALI, "Bengali");
+ code<Language, string> (_language_map, "77", LANGUAGE_BULGARIAN, "Bulgarian");
+ code<Language, string> (_language_map, "76", LANGUAGE_BURMESE, "Burmese");
+ code<Language, string> (_language_map, "75", LANGUAGE_CHINESE, "Chinese");
+ code<Language, string> (_language_map, "74", LANGUAGE_CHURASH, "Churash");
+ code<Language, string> (_language_map, "73", LANGUAGE_DARI, "Dari");
+ code<Language, string> (_language_map, "72", LANGUAGE_FULANI, "Fulani");
+ code<Language, string> (_language_map, "71", LANGUAGE_GEORGIAN, "Georgian");
+ code<Language, string> (_language_map, "70", LANGUAGE_GREEK, "Greek");
+ code<Language, string> (_language_map, "6F", LANGUAGE_GUJURATI, "Gujarati");
+ code<Language, string> (_language_map, "6E", LANGUAGE_GURANI, "Gurani");
+ code<Language, string> (_language_map, "6D", LANGUAGE_HAUSA, "Hausa");
+ code<Language, string> (_language_map, "6C", LANGUAGE_HEBREW, "Hebrew");
+ code<Language, string> (_language_map, "6B", LANGUAGE_HINDI, "Hindi");
+ code<Language, string> (_language_map, "6A", LANGUAGE_INDONESIAN, "Indonesian");
+ code<Language, string> (_language_map, "69", LANGUAGE_JAPANESE, "Japanese");
+ code<Language, string> (_language_map, "68", LANGUAGE_KANNADA, "Kannada");
+ code<Language, string> (_language_map, "67", LANGUAGE_KAZAKH, "Kazakh");
+ code<Language, string> (_language_map, "66", LANGUAGE_KHMER, "Khmer");
+ code<Language, string> (_language_map, "65", LANGUAGE_KOREAN, "Korean");
+ code<Language, string> (_language_map, "64", LANGUAGE_LAOTIAN, "Laotian");
+ code<Language, string> (_language_map, "63", LANGUAGE_MACEDONIAN, "Macedonian");
+ code<Language, string> (_language_map, "62", LANGUAGE_MALAGASAY, "Malagasay");
+ code<Language, string> (_language_map, "61", LANGUAGE_MALAYSIAN, "Malaysian");
+ code<Language, string> (_language_map, "60", LANGUAGE_MOLDAVIAN, "Moldavian");
+ code<Language, string> (_language_map, "5F", LANGUAGE_MARATHI, "Marathi");
+ code<Language, string> (_language_map, "5E", LANGUAGE_NDEBELE, "Ndebele");
+ code<Language, string> (_language_map, "5D", LANGUAGE_NEPALI, "Nepali");
+ code<Language, string> (_language_map, "5C", LANGUAGE_ORIYA, "Oriya");
+ code<Language, string> (_language_map, "5B", LANGUAGE_PAPAMIENTO, "Papamiento");
+ code<Language, string> (_language_map, "5A", LANGUAGE_PERSIAN, "Persian");
+ code<Language, string> (_language_map, "59", LANGUAGE_PUNJABI, "Punjabi");
+ code<Language, string> (_language_map, "58", LANGUAGE_PUSHTU, "Pushtu");
+ code<Language, string> (_language_map, "57", LANGUAGE_QUECHUA, "Quechua");
+ code<Language, string> (_language_map, "56", LANGUAGE_RUSSIAN, "Russian");
+ code<Language, string> (_language_map, "55", LANGUAGE_RUTHENIAN, "Ruthenian");
+ code<Language, string> (_language_map, "54", LANGUAGE_SERBO_CROAT, "Serbo Croat");
+ code<Language, string> (_language_map, "53", LANGUAGE_SHONA, "Shona");
+ code<Language, string> (_language_map, "52", LANGUAGE_SINHALESE, "Sinhalese");
+ code<Language, string> (_language_map, "51", LANGUAGE_SOMALI, "Somali");
+ code<Language, string> (_language_map, "50", LANGUAGE_SRANAN_TONGO, "Sranan Tongo");
+ code<Language, string> (_language_map, "4F", LANGUAGE_SWAHILI, "Swahili");
+ code<Language, string> (_language_map, "4E", LANGUAGE_TADZHIK, "Tadzhik");
+ code<Language, string> (_language_map, "4D", LANGUAGE_TAMIL, "Tamil");
+ code<Language, string> (_language_map, "4C", LANGUAGE_TATAR, "Tatar");
+ code<Language, string> (_language_map, "4B", LANGUAGE_TELUGU, "Telugu");
+ code<Language, string> (_language_map, "4A", LANGUAGE_THAI, "Thai");
+ code<Language, string> (_language_map, "49", LANGUAGE_UKRANIAN, "Ukranian");
+ code<Language, string> (_language_map, "48", LANGUAGE_URDU, "Urdu");
+ code<Language, string> (_language_map, "47", LANGUAGE_UZBEK, "Uzbek");
+ code<Language, string> (_language_map, "46", LANGUAGE_VIETNAMESE, "Vietnamese");
+ code<Language, string> (_language_map, "45", LANGUAGE_ZULU, "Zulu");
+
+ code<TimecodeStatus, string> (_timecode_status_map, "0", TIMECODE_STATUS_NOT_INTENDED_FOR_USE, "Not intended for use");
+ code<TimecodeStatus, string> (_timecode_status_map, "1", TIMECODE_STATUS_INTENDED_FOR_USE, "Intended for use");
+
+ code<CumulativeStatus, int> (_cumulative_status_map, 0, CUMULATIVE_STATUS_NOT_CUMULATIVE, "Not part of a cumulative set");
+ code<CumulativeStatus, int> (_cumulative_status_map, 1, CUMULATIVE_STATUS_FIRST, "First subtitle of a cumulative set");
+ code<CumulativeStatus, int> (_cumulative_status_map, 2, CUMULATIVE_STATUS_INTERMEDIATE, "Intermediate subtitle of a cumulative set");
+ code<CumulativeStatus, int> (_cumulative_status_map, 3, CUMULATIVE_STATUS_LAST, "Last subtitle of a cumulative set");
+
+ code<Justification, int> (_justification_map, 0, JUSTIFICATION_NONE, "No justification");
+ code<Justification, int> (_justification_map, 1, JUSTIFICATION_LEFT, "Left justification");
+ code<Justification, int> (_justification_map, 2, JUSTIFICATION_CENTRE, "Centre justification");
+ code<Justification, int> (_justification_map, 3, JUSTIFICATION_CENTRE, "Right justification");
+
+ code<Comment, int> (_comment_map, 0, COMMENT_NO, "Not a comment");
+ code<Comment, int> (_comment_map, 1, COMMENT_YES, "Is a comment");
}