<?php namespace Safe; use Safe\Exceptions\StringsException; /** * convert_uudecode decodes a uuencoded string. * * @param string $data The uuencoded data. * @return string Returns the decoded data as a string. * @throws StringsException * */ function convert_uudecode(string $data): string { error_clear_last(); $result = \convert_uudecode($data); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * convert_uuencode encodes a string using the uuencode * algorithm. * * Uuencode translates all strings (including binary data) into printable * characters, making them safe for network transmissions. Uuencoded data is * about 35% larger than the original. * * @param string $data The data to be encoded. * @return string Returns the uuencoded data. * @throws StringsException * */ function convert_uuencode(string $data): string { error_clear_last(); $result = \convert_uuencode($data); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Decodes a hexadecimally encoded binary string. * * @param string $data Hexadecimal representation of data. * @return string Returns the binary representation of the given data. * @throws StringsException * */ function hex2bin(string $data): string { error_clear_last(); $result = \hex2bin($data); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Calculates the MD5 hash of the file specified by the * filename parameter using the * RSA Data Security, Inc. * MD5 Message-Digest Algorithm, and returns that hash. * The hash is a 32-character hexadecimal number. * * @param string $filename The filename * @param bool $raw_output When TRUE, returns the digest in raw binary format with a length of * 16. * @return string Returns a string on success, FALSE otherwise. * @throws StringsException * */ function md5_file(string $filename, bool $raw_output = false): string { error_clear_last(); $result = \md5_file($filename, $raw_output); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Calculates the metaphone key of str. * * Similar to soundex metaphone creates the same key for * similar sounding words. It's more accurate than * soundex as it knows the basic rules of English * pronunciation. The metaphone generated keys are of variable length. * * Metaphone was developed by Lawrence Philips * <lphilips at verity dot com>. It is described in ["Practical * Algorithms for Programmers", Binstock & Rex, Addison Wesley, * 1995]. * * @param string $str The input string. * @param int $phonemes This parameter restricts the returned metaphone key to * phonemes characters in length. * The default value of 0 means no restriction. * @return string Returns the metaphone key as a string. * @throws StringsException * */ function metaphone(string $str, int $phonemes = 0): string { error_clear_last(); $result = \metaphone($str, $phonemes); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * * * @param string $filename The filename of the file to hash. * @param bool $raw_output When TRUE, returns the digest in raw binary format with a length of * 20. * @return string Returns a string on success, FALSE otherwise. * @throws StringsException * */ function sha1_file(string $filename, bool $raw_output = false): string { error_clear_last(); $result = \sha1_file($filename, $raw_output); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Calculates the soundex key of str. * * Soundex keys have the property that words pronounced similarly * produce the same soundex key, and can thus be used to simplify * searches in databases where you know the pronunciation but not * the spelling. This soundex function returns a string 4 characters * long, starting with a letter. * * This particular soundex function is one described by Donald Knuth * in "The Art Of Computer Programming, vol. 3: Sorting And * Searching", Addison-Wesley (1973), pp. 391-392. * * @param string $str The input string. * @return string Returns the soundex key as a string. * @throws StringsException * */ function soundex(string $str): string { error_clear_last(); $result = \soundex($str); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Returns a string produced according to the formatting string * format. * * @param string $format The format string is composed of zero or more directives: * ordinary characters (excluding %) that are * copied directly to the result and conversion * specifications, each of which results in fetching its * own parameter. * * A conversion specification follows this prototype: * %[argnum$][flags][width][.precision]specifier. * * An integer followed by a dollar sign $, * to specify which number argument to treat in the conversion. * * * Flags * * * * Flag * Description * * * * * - * * Left-justify within the given field width; * Right justification is the default * * * * + * * Prefix positive numbers with a plus sign * +; Default only negative * are prefixed with a negative sign. * * * * (space) * * Pads the result with spaces. * This is the default. * * * * 0 * * Only left-pads numbers with zeros. * With s specifiers this can * also right-pad with zeros. * * * * '(char) * * Pads the result with the character (char). * * * * * * * An integer that says how many characters (minimum) * this conversion should result in. * * A period . followed by an integer * who's meaning depends on the specifier: * * * * For e, E, * f and F * specifiers: this is the number of digits to be printed * after the decimal point (by default, this is 6). * * * * * For g and G * specifiers: this is the maximum number of significant * digits to be printed. * * * * * For s specifier: it acts as a cutoff point, * setting a maximum character limit to the string. * * * * * * If the period is specified without an explicit value for precision, * 0 is assumed. * * * * * Specifiers * * * * Specifier * Description * * * * * % * * A literal percent character. No argument is required. * * * * b * * The argument is treated as an integer and presented * as a binary number. * * * * c * * The argument is treated as an integer and presented * as the character with that ASCII. * * * * d * * The argument is treated as an integer and presented * as a (signed) decimal number. * * * * e * * The argument is treated as scientific notation (e.g. 1.2e+2). * The precision specifier stands for the number of digits after the * decimal point since PHP 5.2.1. In earlier versions, it was taken as * number of significant digits (one less). * * * * E * * Like the e specifier but uses * uppercase letter (e.g. 1.2E+2). * * * * f * * The argument is treated as a float and presented * as a floating-point number (locale aware). * * * * F * * The argument is treated as a float and presented * as a floating-point number (non-locale aware). * Available as of PHP 5.0.3. * * * * g * * * General format. * * * Let P equal the precision if nonzero, 6 if the precision is omitted, * or 1 if the precision is zero. * Then, if a conversion with style E would have an exponent of X: * * * If P > X ≥ −4, the conversion is with style f and precision P − (X + 1). * Otherwise, the conversion is with style e and precision P − 1. * * * * * G * * Like the g specifier but uses * E and f. * * * * o * * The argument is treated as an integer and presented * as an octal number. * * * * s * * The argument is treated and presented as a string. * * * * u * * The argument is treated as an integer and presented * as an unsigned decimal number. * * * * x * * The argument is treated as an integer and presented * as a hexadecimal number (with lowercase letters). * * * * X * * The argument is treated as an integer and presented * as a hexadecimal number (with uppercase letters). * * * * * * * General format. * * Let P equal the precision if nonzero, 6 if the precision is omitted, * or 1 if the precision is zero. * Then, if a conversion with style E would have an exponent of X: * * If P > X ≥ −4, the conversion is with style f and precision P − (X + 1). * Otherwise, the conversion is with style e and precision P − 1. * * The c type specifier ignores padding and width * * Attempting to use a combination of the string and width specifiers with character sets that require more than one byte per character may result in unexpected results * * Variables will be co-erced to a suitable type for the specifier: * * Type Handling * * * * Type * Specifiers * * * * * string * s * * * integer * * d, * u, * c, * o, * x, * X, * b * * * * double * * g, * G, * e, * E, * f, * F * * * * * * @param mixed $params * @return string Returns a string produced according to the formatting string * format. * @throws StringsException * */ function sprintf(string $format, ...$params): string { error_clear_last(); if ($params !== []) { $result = \sprintf($format, ...$params); } else { $result = \sprintf($format); } if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Returns the portion of string specified by the * start and length parameters. * * @param string $string The input string. * @param int $start If start is non-negative, the returned string * will start at the start'th position in * string, counting from zero. For instance, * in the string 'abcdef', the character at * position 0 is 'a', the * character at position 2 is * 'c', and so forth. * * If start is negative, the returned string * will start at the start'th character * from the end of string. * * If string is less than * start characters long, FALSE will be returned. * * * Using a negative start * * * ]]> * * * @param int $length If length is given and is positive, the string * returned will contain at most length characters * beginning from start (depending on the length of * string). * * If length is given and is negative, then that many * characters will be omitted from the end of string * (after the start position has been calculated when a * start is negative). If * start denotes the position of this truncation or * beyond, FALSE will be returned. * * If length is given and is 0, * FALSE or NULL, an empty string will be returned. * * If length is omitted, the substring starting from * start until the end of the string will be * returned. * @return string Returns the extracted part of string;, or * an empty string. * @throws StringsException * */ function substr(string $string, int $start, int $length = null): string { error_clear_last(); if ($length !== null) { $result = \substr($string, $start, $length); } else { $result = \substr($string, $start); } if ($result === false) { throw StringsException::createFromPhpError(); } return $result; } /** * Operates as sprintf but accepts an array of * arguments, rather than a variable number of arguments. * * @param string $format The format string is composed of zero or more directives: * ordinary characters (excluding %) that are * copied directly to the result and conversion * specifications, each of which results in fetching its * own parameter. * * A conversion specification follows this prototype: * %[argnum$][flags][width][.precision]specifier. * * An integer followed by a dollar sign $, * to specify which number argument to treat in the conversion. * * * Flags * * * * Flag * Description * * * * * - * * Left-justify within the given field width; * Right justification is the default * * * * + * * Prefix positive numbers with a plus sign * +; Default only negative * are prefixed with a negative sign. * * * * (space) * * Pads the result with spaces. * This is the default. * * * * 0 * * Only left-pads numbers with zeros. * With s specifiers this can * also right-pad with zeros. * * * * '(char) * * Pads the result with the character (char). * * * * * * * An integer that says how many characters (minimum) * this conversion should result in. * * A period . followed by an integer * who's meaning depends on the specifier: * * * * For e, E, * f and F * specifiers: this is the number of digits to be printed * after the decimal point (by default, this is 6). * * * * * For g and G * specifiers: this is the maximum number of significant * digits to be printed. * * * * * For s specifier: it acts as a cutoff point, * setting a maximum character limit to the string. * * * * * * If the period is specified without an explicit value for precision, * 0 is assumed. * * * * * Specifiers * * * * Specifier * Description * * * * * % * * A literal percent character. No argument is required. * * * * b * * The argument is treated as an integer and presented * as a binary number. * * * * c * * The argument is treated as an integer and presented * as the character with that ASCII. * * * * d * * The argument is treated as an integer and presented * as a (signed) decimal number. * * * * e * * The argument is treated as scientific notation (e.g. 1.2e+2). * The precision specifier stands for the number of digits after the * decimal point since PHP 5.2.1. In earlier versions, it was taken as * number of significant digits (one less). * * * * E * * Like the e specifier but uses * uppercase letter (e.g. 1.2E+2). * * * * f * * The argument is treated as a float and presented * as a floating-point number (locale aware). * * * * F * * The argument is treated as a float and presented * as a floating-point number (non-locale aware). * Available as of PHP 5.0.3. * * * * g * * * General format. * * * Let P equal the precision if nonzero, 6 if the precision is omitted, * or 1 if the precision is zero. * Then, if a conversion with style E would have an exponent of X: * * * If P > X ≥ −4, the conversion is with style f and precision P − (X + 1). * Otherwise, the conversion is with style e and precision P − 1. * * * * * G * * Like the g specifier but uses * E and f. * * * * o * * The argument is treated as an integer and presented * as an octal number. * * * * s * * The argument is treated and presented as a string. * * * * u * * The argument is treated as an integer and presented * as an unsigned decimal number. * * * * x * * The argument is treated as an integer and presented * as a hexadecimal number (with lowercase letters). * * * * X * * The argument is treated as an integer and presented * as a hexadecimal number (with uppercase letters). * * * * * * * General format. * * Let P equal the precision if nonzero, 6 if the precision is omitted, * or 1 if the precision is zero. * Then, if a conversion with style E would have an exponent of X: * * If P > X ≥ −4, the conversion is with style f and precision P − (X + 1). * Otherwise, the conversion is with style e and precision P − 1. * * The c type specifier ignores padding and width * * Attempting to use a combination of the string and width specifiers with character sets that require more than one byte per character may result in unexpected results * * Variables will be co-erced to a suitable type for the specifier: * * Type Handling * * * * Type * Specifiers * * * * * string * s * * * integer * * d, * u, * c, * o, * x, * X, * b * * * * double * * g, * G, * e, * E, * f, * F * * * * * * @param array $args * @return string Return array values as a formatted string according to * format. * @throws StringsException * */ function vsprintf(string $format, array $args): string { error_clear_last(); $result = \vsprintf($format, $args); if ($result === false) { throw StringsException::createFromPhpError(); } return $result; }