Linux iad1-shared-b7-18 6.6.49-grsec-jammy+ #10 SMP Thu Sep 12 23:23:08 UTC 2024 x86_64
Apache
: 67.205.6.31 | : 216.73.216.47
Cant Read [ /etc/named.conf ]
8.2.29
fernandoquevedo
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
usr /
share /
perl5 /
Image /
ExifTool /
[ HOME SHELL ]
Name
Size
Permission
Action
Charset
[ DIR ]
drwxr-xr-x
Lang
[ DIR ]
drwxr-xr-x
AES.pm
18.66
KB
-rw-r--r--
AFCP.pm
10.38
KB
-rw-r--r--
AIFF.pm
9.59
KB
-rw-r--r--
APE.pm
9.06
KB
-rw-r--r--
APP12.pm
10.44
KB
-rw-r--r--
ASF.pm
30.21
KB
-rw-r--r--
Apple.pm
5.43
KB
-rw-r--r--
Audible.pm
11.52
KB
-rw-r--r--
BMP.pm
10.45
KB
-rw-r--r--
BPG.pm
7.53
KB
-rw-r--r--
BZZ.pm
17.46
KB
-rw-r--r--
BigTIFF.pm
11.27
KB
-rw-r--r--
BuildTagLookup.pm
121.94
KB
-rw-r--r--
CBOR.pm
11.51
KB
-rw-r--r--
Canon.pm
375.39
KB
-rw-r--r--
CanonCustom.pm
84.32
KB
-rw-r--r--
CanonRaw.pm
29.68
KB
-rw-r--r--
CanonVRD.pm
75.2
KB
-rw-r--r--
CaptureOne.pm
7.85
KB
-rw-r--r--
Casio.pm
62.21
KB
-rw-r--r--
Charset.pm
16.01
KB
-rw-r--r--
DICOM.pm
245.09
KB
-rw-r--r--
DJI.pm
6.31
KB
-rw-r--r--
DNG.pm
31.59
KB
-rw-r--r--
DPX.pm
9.51
KB
-rw-r--r--
DV.pm
9.75
KB
-rw-r--r--
DarwinCore.pm
15.43
KB
-rw-r--r--
DjVu.pm
12.46
KB
-rw-r--r--
EXE.pm
50.3
KB
-rw-r--r--
Exif.pm
246.64
KB
-rw-r--r--
FITS.pm
5.73
KB
-rw-r--r--
FLAC.pm
9.89
KB
-rw-r--r--
FLIF.pm
11.65
KB
-rw-r--r--
FLIR.pm
59.45
KB
-rw-r--r--
Fixup.pm
12.43
KB
-rw-r--r--
Flash.pm
27.5
KB
-rw-r--r--
FlashPix.pm
87.44
KB
-rw-r--r--
Font.pm
27.34
KB
-rw-r--r--
FotoStation.pm
7.97
KB
-rw-r--r--
FujiFilm.pm
54.47
KB
-rw-r--r--
GE.pm
2
KB
-rw-r--r--
GIF.pm
21.85
KB
-rw-r--r--
GIMP.pm
8.35
KB
-rw-r--r--
GPS.pm
19.53
KB
-rw-r--r--
GeoTiff.pm
87.51
KB
-rw-r--r--
Geotag.pm
62.87
KB
-rw-r--r--
GoPro.pm
28
KB
-rw-r--r--
H264.pm
39.29
KB
-rw-r--r--
HP.pm
8
KB
-rw-r--r--
HTML.pm
22.1
KB
-rw-r--r--
HtmlDump.pm
32.8
KB
-rw-r--r--
ICC_Profile.pm
45.63
KB
-rw-r--r--
ID3.pm
56.91
KB
-rw-r--r--
IPTC.pm
39.54
KB
-rw-r--r--
ISO.pm
6.81
KB
-rw-r--r--
ITC.pm
6.63
KB
-rw-r--r--
Import.pm
12.83
KB
-rw-r--r--
InDesign.pm
10.4
KB
-rw-r--r--
JPEG.pm
24.3
KB
-rw-r--r--
JPEGDigest.pm
212.38
KB
-rw-r--r--
JSON.pm
6.15
KB
-rw-r--r--
JVC.pm
3.57
KB
-rw-r--r--
Jpeg2000.pm
49.65
KB
-rw-r--r--
Kodak.pm
120.47
KB
-rw-r--r--
KyoceraRaw.pm
4.31
KB
-rw-r--r--
LIF.pm
4.66
KB
-rw-r--r--
LNK.pm
22.02
KB
-rw-r--r--
Leaf.pm
16.34
KB
-rw-r--r--
Lytro.pm
7.56
KB
-rw-r--r--
M2TS.pm
37.11
KB
-rw-r--r--
MIE.pm
102.09
KB
-rw-r--r--
MIEUnits.pod
13.68
KB
-rw-r--r--
MIFF.pm
9.05
KB
-rw-r--r--
MNG.pm
16.22
KB
-rw-r--r--
MOI.pm
4.14
KB
-rw-r--r--
MPC.pm
4.05
KB
-rw-r--r--
MPEG.pm
22.32
KB
-rw-r--r--
MPF.pm
8.94
KB
-rw-r--r--
MRC.pm
18.39
KB
-rw-r--r--
MWG.pm
30.64
KB
-rw-r--r--
MXF.pm
252.65
KB
-rw-r--r--
MacOS.pm
30.7
KB
-rw-r--r--
MakerNotes.pm
68.93
KB
-rw-r--r--
Matroska.pm
34.44
KB
-rw-r--r--
Microsoft.pm
52.13
KB
-rw-r--r--
Minolta.pm
99.93
KB
-rw-r--r--
MinoltaRaw.pm
16.49
KB
-rw-r--r--
Motorola.pm
5.31
KB
-rw-r--r--
Nikon.pm
431.96
KB
-rw-r--r--
NikonCapture.pm
28.13
KB
-rw-r--r--
NikonCustom.pm
290.78
KB
-rw-r--r--
NikonSettings.pm
71.88
KB
-rw-r--r--
Nintendo.pm
3.24
KB
-rw-r--r--
OOXML.pm
13.61
KB
-rw-r--r--
Ogg.pm
8.81
KB
-rw-r--r--
Olympus.pm
139.89
KB
-rw-r--r--
OpenEXR.pm
10.26
KB
-rw-r--r--
Opus.pm
2.22
KB
-rw-r--r--
Other.pm
2.63
KB
-rw-r--r--
PCX.pm
3.72
KB
-rw-r--r--
PDF.pm
90.77
KB
-rw-r--r--
PGF.pm
4.04
KB
-rw-r--r--
PICT.pm
33.2
KB
-rw-r--r--
PLIST.pm
17.07
KB
-rw-r--r--
PLUS.pm
147.71
KB
-rw-r--r--
PNG.pm
60.72
KB
-rw-r--r--
PPM.pm
4.97
KB
-rw-r--r--
PSP.pm
9.02
KB
-rw-r--r--
Palm.pm
11.9
KB
-rw-r--r--
Panasonic.pm
96.62
KB
-rw-r--r--
PanasonicRaw.pm
31.77
KB
-rw-r--r--
Parrot.pm
20.95
KB
-rw-r--r--
Pentax.pm
220.46
KB
-rw-r--r--
PhaseOne.pm
26.24
KB
-rw-r--r--
PhotoCD.pm
18.25
KB
-rw-r--r--
PhotoMechanic.pm
8.09
KB
-rw-r--r--
Photoshop.pm
43.36
KB
-rw-r--r--
PostScript.pm
29.11
KB
-rw-r--r--
PrintIM.pm
3.44
KB
-rw-r--r--
Qualcomm.pm
43.43
KB
-rw-r--r--
QuickTime.pm
409.72
KB
-rw-r--r--
QuickTimeStream.pl
126.03
KB
-rw-r--r--
RIFF.pm
70.97
KB
-rw-r--r--
RSRC.pm
9.58
KB
-rw-r--r--
RTF.pm
13.46
KB
-rw-r--r--
Radiance.pm
4.56
KB
-rw-r--r--
Rawzor.pm
6.17
KB
-rw-r--r--
Real.pm
26.89
KB
-rw-r--r--
Reconyx.pm
14.2
KB
-rw-r--r--
Red.pm
10.82
KB
-rw-r--r--
Ricoh.pm
37.18
KB
-rw-r--r--
Samsung.pm
54.64
KB
-rw-r--r--
Sanyo.pm
11.83
KB
-rw-r--r--
Scalado.pm
3.91
KB
-rw-r--r--
Shift.pl
23.28
KB
-rw-r--r--
Shortcuts.pm
9.81
KB
-rw-r--r--
Sigma.pm
33.16
KB
-rw-r--r--
SigmaRaw.pm
23.45
KB
-rw-r--r--
Sony.pm
439.69
KB
-rw-r--r--
SonyIDC.pm
11.95
KB
-rw-r--r--
Stim.pm
4.53
KB
-rw-r--r--
TagInfoXML.pm
33.14
KB
-rw-r--r--
TagLookup.pm
647.18
KB
-rw-r--r--
TagNames.pod
1.76
MB
-rw-r--r--
Text.pm
8.12
KB
-rw-r--r--
Theora.pm
3.41
KB
-rw-r--r--
Torrent.pm
11.58
KB
-rw-r--r--
Unknown.pm
1.69
KB
-rw-r--r--
VCard.pm
17.31
KB
-rw-r--r--
Validate.pm
29.75
KB
-rw-r--r--
Vorbis.pm
8.13
KB
-rw-r--r--
WTV.pm
12.97
KB
-rw-r--r--
WriteCanonRaw.pl
24.29
KB
-rw-r--r--
WriteExif.pl
130.6
KB
-rw-r--r--
WriteIPTC.pl
29.6
KB
-rw-r--r--
WritePDF.pl
29.02
KB
-rw-r--r--
WritePNG.pl
16.07
KB
-rw-r--r--
WritePhotoshop.pl
10.85
KB
-rw-r--r--
WritePostScript.pl
26.71
KB
-rw-r--r--
WriteQuickTime.pl
89.63
KB
-rw-r--r--
WriteXMP.pl
70.49
KB
-rw-r--r--
Writer.pl
301.76
KB
-rw-r--r--
XMP.pm
176.89
KB
-rw-r--r--
XMP2.pl
81.66
KB
-rw-r--r--
XMPStruct.pl
36.66
KB
-rw-r--r--
ZIP.pm
27.61
KB
-rw-r--r--
ZISRAW.pm
7.85
KB
-rw-r--r--
iWork.pm
7.79
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : Charset.pm
#------------------------------------------------------------------------------ # File: Charset.pm # # Description: ExifTool character encoding routines # # Revisions: 2009/08/28 - P. Harvey created # 2010/01/20 - P. Harvey complete re-write # 2010/07/16 - P. Harvey added UTF-16 support # # Notes: Charset lookups are generated using my convertCharset script #------------------------------------------------------------------------------ package Image::ExifTool::Charset; use strict; use vars qw($VERSION %csType); use Image::ExifTool qw(:DataAccess :Utils); $VERSION = '1.11'; my %charsetTable; # character set tables we've loaded # lookup for converting Unicode to 1-byte character sets my %unicode2byte = ( Latin => { # pre-load Latin (cp1252) for speed 0x20ac => 0x80, 0x0160 => 0x8a, 0x2013 => 0x96, 0x201a => 0x82, 0x2039 => 0x8b, 0x2014 => 0x97, 0x0192 => 0x83, 0x0152 => 0x8c, 0x02dc => 0x98, 0x201e => 0x84, 0x017d => 0x8e, 0x2122 => 0x99, 0x2026 => 0x85, 0x2018 => 0x91, 0x0161 => 0x9a, 0x2020 => 0x86, 0x2019 => 0x92, 0x203a => 0x9b, 0x2021 => 0x87, 0x201c => 0x93, 0x0153 => 0x9c, 0x02c6 => 0x88, 0x201d => 0x94, 0x017e => 0x9e, 0x2030 => 0x89, 0x2022 => 0x95, 0x0178 => 0x9f, }, ); # bit flags for all supported character sets # (this number must be correct because it dictates the decoding algorithm!) # 0x001 = character set requires a translation module # 0x002 = inverse conversion not yet supported by Recompose() # 0x080 = some characters with codepoints in the range 0x00-0x7f are remapped # 0x100 = 1-byte fixed-width characters # 0x200 = 2-byte fixed-width characters # 0x400 = 4-byte fixed-width characters # 0x800 = 1- and 2-byte variable-width characters, or 1-byte # fixed-width characters that map into multiple codepoints # Note: In its public interface, ExifTool can currently only support type 0x101 # and lower character sets because strings are only converted if they # contain characters above 0x7f and there is no provision for specifying # the byte order for input/output values %csType = ( UTF8 => 0x100, ASCII => 0x100, # (treated like UTF8) Arabic => 0x101, Baltic => 0x101, Cyrillic => 0x101, Greek => 0x101, Hebrew => 0x101, Latin => 0x101, Latin2 => 0x101, DOSLatinUS => 0x101, DOSLatin1 => 0x101, DOSCyrillic => 0x101, MacCroatian => 0x101, MacCyrillic => 0x101, MacGreek => 0x101, MacIceland => 0x101, MacLatin2 => 0x101, MacRoman => 0x101, MacRomanian => 0x101, MacTurkish => 0x101, Thai => 0x101, Turkish => 0x101, Vietnam => 0x101, MacArabic => 0x103, # (directional characters not supported) PDFDoc => 0x181, Unicode => 0x200, # (UCS2) UCS2 => 0x200, UTF16 => 0x200, Symbol => 0x201, JIS => 0x201, UCS4 => 0x400, MacChineseCN => 0x803, MacChineseTW => 0x803, MacHebrew => 0x803, # (directional characters not supported) MacKorean => 0x803, MacRSymbol => 0x803, MacThai => 0x803, MacJapanese => 0x883, ShiftJIS => 0x883, ); #------------------------------------------------------------------------------ # Load character set module # Inputs: 0) Module name # Returns: Reference to lookup hash, or undef on error sub LoadCharset($) { my $charset = shift; my $conv = $charsetTable{$charset}; unless ($conv) { # load translation module my $module = "Image::ExifTool::Charset::$charset"; no strict 'refs'; if (%$module or eval "require $module") { $conv = $charsetTable{$charset} = \%$module; } } return $conv; } #------------------------------------------------------------------------------ # Does an array contain valid UTF-16 characters? # Inputs: 0) array reference to list of UCS-2 values # Returns: 0=invalid UTF-16, 1=valid UTF-16 with no surrogates, 2=valid UTF-16 with surrogates sub IsUTF16($) { local $_; my $uni = shift; my $surrogate; foreach (@$uni) { my $hiBits = ($_ & 0xfc00); if ($hiBits == 0xfc00) { # check for invalid values in UTF-16 return 0 if $_ == 0xffff or $_ == 0xfffe or ($_ >= 0xfdd0 and $_ <= 0xfdef); } elsif ($surrogate) { return 0 if $hiBits != 0xdc00; $surrogate = 0; } else { return 0 if $hiBits == 0xdc00; $surrogate = 1 if $hiBits == 0xd800; } } return 1 if not defined $surrogate; return 2 unless $surrogate; return 0; } #------------------------------------------------------------------------------ # Decompose string with specified encoding into an array of integer code points # Inputs: 0) ExifTool object ref (or undef), 1) string, 2) character set name, # 3) optional byte order ('II','MM','Unknown' or undef to use ExifTool ordering) # Returns: Reference to array of Unicode values # Notes: Accepts any type of character set # - byte order only used for fixed-width 2-byte and 4-byte character sets # - byte order mark observed and then removed with UCS2 and UCS4 # - no warnings are issued if ExifTool object is not provided # - sets ExifTool WrongByteOrder flag if byte order is Unknown and current order is wrong sub Decompose($$$;$) { local $_; my ($et, $val, $charset) = @_; # ($byteOrder assigned later if required) my $type = $csType{$charset}; my (@uni, $conv); if ($type & 0x001) { $conv = LoadCharset($charset); unless ($conv) { # (shouldn't happen) $et->Warn("Invalid character set $charset") if $et; return \@uni; # error! } } elsif ($type == 0x100) { # convert ASCII and UTF8 (treat ASCII as UTF8) if ($] < 5.006001) { # do it ourself @uni = Image::ExifTool::UnpackUTF8($val); } else { # handle warnings from malformed UTF-8 undef $Image::ExifTool::evalWarning; local $SIG{'__WARN__'} = \&Image::ExifTool::SetWarning; # (somehow the meaning of "U0" was reversed in Perl 5.10.0!) @uni = unpack($] < 5.010000 ? 'U0U*' : 'C0U*', $val); # issue warning if we had errors if ($Image::ExifTool::evalWarning and $et and not $$et{WarnBadUTF8}) { $et->Warn('Malformed UTF-8 character(s)'); $$et{WarnBadUTF8} = 1; } } return \@uni; # all done! } if ($type & 0x100) { # 1-byte fixed-width characters @uni = unpack('C*', $val); foreach (@uni) { $_ = $$conv{$_} if defined $$conv{$_}; } } elsif ($type & 0x600) { # 2-byte or 4-byte fixed-width characters my $unknown; my $byteOrder = $_[3]; if (not $byteOrder) { $byteOrder = GetByteOrder(); } elsif ($byteOrder eq 'Unknown') { $byteOrder = GetByteOrder(); $unknown = 1; } my $fmt = $byteOrder eq 'MM' ? 'n*' : 'v*'; if ($type & 0x400) { # 4-byte $fmt = uc $fmt; # unpack as 'N*' or 'V*' # honour BOM if it exists $val =~ s/^(\0\0\xfe\xff|\xff\xfe\0\0)// and $fmt = $1 eq "\0\0\xfe\xff" ? 'N*' : 'V*'; undef $unknown; # (byte order logic applies to 2-byte only) } elsif ($val =~ s/^(\xfe\xff|\xff\xfe)//) { $fmt = $1 eq "\xfe\xff" ? 'n*' : 'v*'; undef $unknown; } # convert from UCS2 or UCS4 @uni = unpack($fmt, $val); if (not $conv) { # no translation necessary if ($unknown) { # check the byte order my (%bh, %bl); my ($zh, $zl) = (0, 0); foreach (@uni) { $bh{$_ >> 8} = 1; $bl{$_ & 0xff} = 1; ++$zh unless $_ & 0xff00; ++$zl unless $_ & 0x00ff; } # count the number of unique values in the hi and lo bytes my ($bh, $bl) = (scalar(keys %bh), scalar(keys %bl)); # the byte with the greater number of unique values should be # the low-order byte, otherwise the byte which is zero more # often is likely the high-order byte if ($bh > $bl or ($bh == $bl and $zl > $zh)) { # we guessed wrong, so decode using the other byte order $fmt =~ tr/nvNV/vnVN/; @uni = unpack($fmt, $val); $$et{WrongByteOrder} = 1; } } # handle surrogate pairs of UTF-16 if ($charset eq 'UTF16') { my $i; for ($i=0; $i<$#uni; ++$i) { next unless ($uni[$i] & 0xfc00) == 0xd800 and ($uni[$i+1] & 0xfc00) == 0xdc00; my $cp = 0x10000 + (($uni[$i] & 0x3ff) << 10) + ($uni[$i+1] & 0x3ff); splice(@uni, $i, 2, $cp); } } } elsif ($unknown) { # count encoding errors as we do the translation my $e1 = 0; foreach (@uni) { defined $$conv{$_} and $_ = $$conv{$_}, next; ++$e1; } # try the other byte order if we had any errors if ($e1) { $fmt = $byteOrder eq 'MM' ? 'v*' : 'n*'; #(reversed) my @try = unpack($fmt, $val); my $e2 = 0; foreach (@try) { defined $$conv{$_} and $_ = $$conv{$_}, next; ++$e2; } # use this byte order if there are fewer errors if ($e2 < $e1) { $$et{WrongByteOrder} = 1; return \@try; } } } else { # translate any characters found in the lookup foreach (@uni) { $_ = $$conv{$_} if defined $$conv{$_}; } } } else { # variable-width characters # unpack into bytes my @bytes = unpack('C*', $val); while (@bytes) { my $ch = shift @bytes; my $cv = $$conv{$ch}; # pass straight through if no translation $cv or push(@uni, $ch), next; # byte translates into single Unicode character ref $cv or push(@uni, $cv), next; # byte maps into multiple Unicode characters ref $cv eq 'ARRAY' and push(@uni, @$cv), next; # handle 2-byte character codes $ch = shift @bytes; if (defined $ch) { if ($$cv{$ch}) { $cv = $$cv{$ch}; ref $cv or push(@uni, $cv), next; push @uni, @$cv; # multiple Unicode characters } else { push @uni, ord('?'); # encoding error unshift @bytes, $ch; } } else { push @uni, ord('?'); # encoding error } } } return \@uni; } #------------------------------------------------------------------------------ # Convert array of code point integers into a string with specified encoding # Inputs: 0) ExifTool ref (or undef), 1) unicode character array ref, # 2) character set (note: not all types are supported) # 3) byte order ('MM' or 'II', multi-byte sets only, defaults to current byte order) # Returns: converted string (truncated at null character if it exists), empty on error # Notes: converts elements of input character array to new code points # - ExifTool ref may be undef provided $charset is defined sub Recompose($$;$$) { local $_; my ($et, $uni, $charset) = @_; # ($byteOrder assigned later if required) my ($outVal, $conv, $inv); $charset or $charset = $$et{OPTIONS}{Charset}; my $csType = $csType{$charset}; if ($csType == 0x100) { # UTF8 (also treat ASCII as UTF8) if ($] >= 5.006001) { # let Perl do it $outVal = pack('C0U*', @$uni); } else { # do it ourself $outVal = Image::ExifTool::PackUTF8(@$uni); } $outVal =~ s/\0.*//s; # truncate at null terminator return $outVal; } # get references to forward and inverse lookup tables if ($csType & 0x801) { $conv = LoadCharset($charset); unless ($conv) { $et->Warn("Missing charset $charset") if $et; return ''; } $inv = $unicode2byte{$charset}; # generate inverse lookup if necessary unless ($inv) { if (not $csType or $csType & 0x802) { $et->Warn("Invalid destination charset $charset") if $et; return ''; } # prepare table to convert from Unicode to 1-byte characters my ($char, %inv); foreach $char (keys %$conv) { $inv{$$conv{$char}} = $char; } $inv = $unicode2byte{$charset} = \%inv; } } if ($csType & 0x100) { # 1-byte fixed-width # convert to specified character set foreach (@$uni) { next if $_ < 0x80; $$inv{$_} and $_ = $$inv{$_}, next; # our tables omit 1-byte characters with the same values as Unicode, # so pass them straight through after making sure there isn't a # different character with this byte value next if $_ < 0x100 and not $$conv{$_}; $_ = ord('?'); # set invalid characters to '?' if ($et and not $$et{EncodingError}) { $et->Warn("Some character(s) could not be encoded in $charset"); $$et{EncodingError} = 1; } } # repack as an 8-bit string and truncate at null $outVal = pack('C*', @$uni); $outVal =~ s/\0.*//s; } else { # 2-byte and 4-byte fixed-width # convert if required if ($inv) { $$inv{$_} and $_ = $$inv{$_} foreach @$uni; } # generate surrogate pairs of UTF-16 if ($charset eq 'UTF16') { my $i; for ($i=0; $i<@$uni; ++$i) { next unless $$uni[$i] >= 0x10000 and $$uni[$i] < 0x10ffff; my $t = $$uni[$i] - 0x10000; my $w1 = 0xd800 + (($t >> 10) & 0x3ff); my $w2 = 0xdc00 + ($t & 0x3ff); splice(@$uni, $i, 1, $w1, $w2); ++$i; # skip surrogate pair } } # pack as 2- or 4-byte integer in specified byte order my $byteOrder = $_[3] || GetByteOrder(); my $fmt = $byteOrder eq 'MM' ? 'n*' : 'v*'; $fmt = uc($fmt) if $csType & 0x400; $outVal = pack($fmt, @$uni); } return $outVal; } 1; # end __END__ =head1 NAME Image::ExifTool::Charset - ExifTool character encoding routines =head1 SYNOPSIS This module is required by Image::ExifTool. =head1 DESCRIPTION This module contains routines used by ExifTool to translate special character sets. Currently, the following character sets are supported: UTF8, UTF16, UCS2, UCS4, Arabic, Baltic, Cyrillic, Greek, Hebrew, JIS, Latin, Latin2, DOSLatinUS, DOSLatin1, DOSCyrillic, MacArabic, MacChineseCN, MacChineseTW, MacCroatian, MacCyrillic, MacGreek, MacHebrew, MacIceland, MacJapanese, MacKorean, MacLatin2, MacRSymbol, MacRoman, MacRomanian, MacThai, MacTurkish, PDFDoc, RSymbol, ShiftJIS, Symbol, Thai, Turkish, Vietnam However, only some of these character sets are available to the user via ExifTool options -- the multi-byte character sets are used only internally when decoding certain types of information. =head1 AUTHOR Copyright 2003-2022, Phil Harvey (philharvey66 at gmail.com) This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =head1 SEE ALSO L<Image::ExifTool(3pm)|Image::ExifTool> =cut
Close