Class MoFileParser
Parses file in PO format
Constants
-
float
MO_BIG_ENDIAN_MAGIC ¶0xde120495
Magic used for validating the format of a MO file as well as detecting if the machine used to create that file was big endian.
-
int
MO_HEADER_SIZE ¶28
The size of the header of a MO file in bytes.
-
float
MO_LITTLE_ENDIAN_MAGIC ¶0x950412de
Magic used for validating the format of a MO file as well as detecting if the machine used to create that file was little endian.
Method Summary
-
_readLong() protected
Reads an unsigned long from stream respecting endianess.
-
parse() public
Parses machine object (MO) format, independent of the machine's endian it was created on. Both 32bit and 64bit systems are supported.
Method Detail
_readLong() ¶ protected
_readLong(resource $stream, bool $isBigEndian): int
Reads an unsigned long from stream respecting endianess.
Parameters
-
resource
$stream The File being read.
-
bool
$isBigEndian Whether or not the current platform is Big Endian
Returns
int
parse() ¶ public
parse(resource $resource): array
Parses machine object (MO) format, independent of the machine's endian it was created on. Both 32bit and 64bit systems are supported.
Parameters
-
resource
$resource The file to be parsed.
Returns
array
Throws
RuntimeException
If stream content has an invalid format.