dvb-apps: charset support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

I added some patches to dvb-apps/util/scan.c in order to properly support EN 300 468 charsets.
Before the patch, scan were producing invalid UTF-8 codes here, for ISO-8859-15 charsets, as
scan were simply filling service/provider name with whatever non-control characters that were
there. So, if your computer uses the same character as your service provider, you're lucky.
Otherwise, invalid characters will appear at the scan tables.

After the changes, scan gets the locale environment charset, and use it as the output charset
on the output files. 

The TS info may provide the used charset on the first character of the provider name and service name,
if the first character is < 0x20. If not provided, the spec says that the character table 00 should be
assumed (a modified version of ISO 6937 charset). However, on my tests, local carriers here
don't fill it, but they use ISO-8859-15 charset, instead of ISO-6937. So, a new optional parameter 
allows to change the default charset.

Also, the spec provides 2 tables with control character codes, one for 1-byte character tables,
and another for 2-byte character tables. Before the patch, the 1-byte control character table
were applied for all character sets. Now, the table is applied only for ISO-8859* and ISO-6937,
as they don't seem to make sense for the other character sets. However, the 2-byte control
character table were not implemented yet, due to a few reasons:
	1) I'm not familiar with 2-byte charsets;
	2) I don't have any environment here that would allow me to test it;
	3) The spec is not very clear about what character tables use 2-byte control codes.

The EN 300 428 Annex A says, just before the 2-byte control code table:
	"For two-byte character tables, the codes in the range 0xE080 to 0xE09F 
	 are assigned to control functions as shown in table A.2."

So, it seems that the 2-byte control character table refers to character tables 0x11 to 0x14 
(iso-10646 + Korean Character Set + GB2312 + BIG5).

However, the table A.2 is described as just:
	"Table A.2: DVB codes within private use area of ISO/IEC 10646"

So, one may assume that it refers only to ISO-10646 (character table 0x11), or to this one
plus BIG5 (table 0x14), as BIG5 is a subset of ISO-10646.

The spec is even less clear about what should be done with character table 0x15 (ISO-10646/UTF-8),
as UTF-8 codes have a variable length from 1-byte to 4-bytes.

I _suspect_ that all character tables that are not ISO-8859 or ISO-6937 should be using table
A.2 (that means, character tables 0x11 to 0x15).

The code change to implement 2-byte control codes should be trivial trough. A placeholder for such
code is there at the scancode with a short comment.

It would be great to have some feedback about it. So, comments are welcome.

Thanks,
Mauro.
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux