Revamped documentation comments about argument arrays in the C and Rust-no-heap ports.

pull/143/head
Project Nayuki 3 years ago
parent 5990e6a99c
commit d4085a443a

@ -154,9 +154,17 @@ struct qrcodegen_Segment {
* - The input text must be encoded in UTF-8 and contain no NULs. * - The input text must be encoded in UTF-8 and contain no NULs.
* - The variables ecl and mask must correspond to enum constant values. * - The variables ecl and mask must correspond to enum constant values.
* - Requires 1 <= minVersion <= maxVersion <= 40. * - Requires 1 <= minVersion <= maxVersion <= 40.
* - The arrays tempBuffer and qrcode must each have a length of at least * - About the arrays, letting len = qrcodegen_BUFFER_LEN_FOR_VERSION(maxVersion):
* qrcodegen_BUFFER_LEN_FOR_VERSION(maxVersion), and cannot overlap. * - Before calling the function:
* - After the function returns, tempBuffer contains no useful data. * - The array ranges tempBuffer[0 : len] and qrcode[0 : len] must allow
* reading and writing; hence each array must have a length of at least len.
* - The two ranges must not overlap (aliasing).
* - The initial state of both ranges can be uninitialized
* because the function always writes before reading.
* - After the function returns:
* - Both ranges have no guarantee on which elements are initialized and what values are stored.
* - tempBuffer contains no useful data and should be treated as entirely uninitialzed.
* - If successful, qrcode can be passed into qrcodegen_getSize() and qrcodegen_getModule().
* - If successful, the resulting QR Code may use numeric, * - If successful, the resulting QR Code may use numeric,
* alphanumeric, or byte mode to encode the text. * alphanumeric, or byte mode to encode the text.
* - In the most optimistic case, a QR Code at version 40 with low ECC * - In the most optimistic case, a QR Code at version 40 with low ECC
@ -174,14 +182,21 @@ bool qrcodegen_encodeText(const char *text, uint8_t tempBuffer[], uint8_t qrcode
* Encodes the given binary data to a QR Code, returning true if encoding succeeded. * Encodes the given binary data to a QR Code, returning true if encoding succeeded.
* If the data is too long to fit in any version in the given range * If the data is too long to fit in any version in the given range
* at the given ECC level, then false is returned. * at the given ECC level, then false is returned.
* - The input array range dataAndTemp[0 : dataLen] should normally be
* valid UTF-8 text, but is not required by the QR Code standard.
* - The variables ecl and mask must correspond to enum constant values. * - The variables ecl and mask must correspond to enum constant values.
* - Requires 1 <= minVersion <= maxVersion <= 40. * - Requires 1 <= minVersion <= maxVersion <= 40.
* - The arrays dataAndTemp and qrcode must each have a length of at least * - About the arrays, letting len = qrcodegen_BUFFER_LEN_FOR_VERSION(maxVersion):
* qrcodegen_BUFFER_LEN_FOR_VERSION(maxVersion), and cannot overlap. * - Before calling the function:
* - After the function returns, the contents of dataAndTemp may have changed, * - The array ranges dataAndTemp[0 : len] and qrcode[0 : len] must allow
* and does not represent useful data anymore. * reading and writing; hence each array must have a length of at least len.
* - The two ranges must not overlap (aliasing).
* - The input array range dataAndTemp[0 : dataLen] should normally be
* valid UTF-8 text, but is not required by the QR Code standard.
* - The initial state of dataAndTemp[dataLen : len] and qrcode[0 : len]
* can be uninitialized because the function always writes before reading.
* - After the function returns:
* - Both ranges have no guarantee on which elements are initialized and what values are stored.
* - dataAndTemp contains no useful data and should be treated as entirely uninitialzed.
* - If successful, qrcode can be passed into qrcodegen_getSize() and qrcodegen_getModule().
* - If successful, the resulting QR Code will use byte mode to encode the data. * - If successful, the resulting QR Code will use byte mode to encode the data.
* - In the most optimistic case, a QR Code at version 40 with low ECC can hold any byte * - In the most optimistic case, a QR Code at version 40 with low ECC can hold any byte
* sequence up to length 2953. This is the hard upper limit of the QR Code standard. * sequence up to length 2953. This is the hard upper limit of the QR Code standard.

@ -139,7 +139,14 @@ impl<'a> QrCode<'a> {
/// version. The mask number is either between 0 to 7 (inclusive) to force that /// version. The mask number is either between 0 to 7 (inclusive) to force that
/// mask, or `None` to automatically choose an appropriate mask (which may be slow). /// mask, or `None` to automatically choose an appropriate mask (which may be slow).
/// ///
/// The arrays tempbuffer and outbuffer must each have a length of at least maxversion.buffer_len(). /// About the slices, letting len = maxversion.buffer_len():
/// - Before calling the function:
/// - The slices tempbuffer and outbuffer each must have a length of at least len.
/// - If a slice is longer than len, then the function will not
/// read from or write to the suffix array[len .. array.len()].
/// - The initial values of both slices can be arbitrary
/// because the function always writes before reading.
/// - After the function returns, both slices have no guarantee on what values are stored.
/// ///
/// In the most optimistic case, a QR Code at version 40 with low ECC /// In the most optimistic case, a QR Code at version 40 with low ECC
/// can hold any UTF-8 string up to 2953 bytes, or any alphanumeric string /// can hold any UTF-8 string up to 2953 bytes, or any alphanumeric string
@ -149,8 +156,6 @@ impl<'a> QrCode<'a> {
/// Please consult the QR Code specification for information on /// Please consult the QR Code specification for information on
/// data capacities per version, ECC level, and text encoding mode. /// data capacities per version, ECC level, and text encoding mode.
/// ///
/// After the function returns, tempbuffer contains no useful data.
///
/// If successful, the resulting QR Code may use numeric, alphanumeric, or byte mode to encode the text. /// If successful, the resulting QR Code may use numeric, alphanumeric, or byte mode to encode the text.
/// ///
/// Returns a wrapped `QrCode` if successful, or `Err` if the /// Returns a wrapped `QrCode` if successful, or `Err` if the
@ -185,7 +190,16 @@ impl<'a> QrCode<'a> {
/// Returns a QR Code representing the given binary data with the given encoding parameters. /// Returns a QR Code representing the given binary data with the given encoding parameters.
/// ///
/// The arrays dataandtemp and outbuffer must each have a length of at least maxversion.buffer_len(). /// About the slices, letting len = maxversion.buffer_len():
/// - Before calling the function:
/// - The slices dataandtempbuffer and outbuffer each must have a length of at least len.
/// - If a slice is longer than len, then the function will not
/// read from or write to the suffix array[len .. array.len()].
/// - The input slice range dataandtempbuffer[0 .. datalen] should normally be
/// valid UTF-8 text, but is not required by the QR Code standard.
/// - The initial values of dataandtempbuffer[datalen .. len] and outbuffer[0 .. len]
/// can be arbitrary because the function always writes before reading.
/// - After the function returns, both slices have no guarantee on what values are stored.
/// ///
/// In the most optimistic case, a QR Code at version 40 with low ECC can hold any byte /// In the most optimistic case, a QR Code at version 40 with low ECC can hold any byte
/// sequence up to length 2953. This is the hard upper limit of the QR Code standard. /// sequence up to length 2953. This is the hard upper limit of the QR Code standard.
@ -193,9 +207,6 @@ impl<'a> QrCode<'a> {
/// Please consult the QR Code specification for information on /// Please consult the QR Code specification for information on
/// data capacities per version, ECC level, and text encoding mode. /// data capacities per version, ECC level, and text encoding mode.
/// ///
/// After the function returns, the contents of dataandtemp may have changed,
/// and does not represent useful data anymore.
///
/// If successful, the resulting QR Code will use byte mode to encode the data. /// If successful, the resulting QR Code will use byte mode to encode the data.
/// ///
/// Returns a wrapped `QrCode` if successful, or `Err` if the /// Returns a wrapped `QrCode` if successful, or `Err` if the

Loading…
Cancel
Save