X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fvariable.c;h=64e4b3f0cd9cbeb46e1315a6ee122de4834b9b51;hb=2e5ba1599578af2f13aa483db3ee49d591aed42f;hp=56993e461c5d43998105123767037bba1a9be16d;hpb=393668423c1c9456fd82db6b30f25de078915da5;p=pspp-builds.git diff --git a/src/data/variable.c b/src/data/variable.c index 56993e46..64e4b3f0 100644 --- a/src/data/variable.c +++ b/src/data/variable.c @@ -351,87 +351,13 @@ dict_class_to_name (enum dict_class dict_class) } } - -/* Copies buffer SRC, of SRC_SIZE bytes, to DST, of DST_SIZE bytes. - Each 256th byte, which is expected to be a ' ', is deleted. - DST is then truncated to DST_SIZE bytes or padded on the right with - spaces as needed. */ -void -copy_demangle (char *dst, size_t dst_size, - const char *src, size_t src_size) -{ - int src_bytes_left = src_size; - int dst_bytes_left = dst_size; - const char *s = src; - char *d = dst; - - - while( src_bytes_left > 0 ) - { - const size_t s_chunk = min(MAX_LONG_STRING, src_bytes_left); - const size_t d_chunk = min(MAX_LONG_STRING, dst_bytes_left); - - assert ( d < dst + dst_size); - - buf_copy_rpad (d, d_chunk, - s, s_chunk); - - d += d_chunk; - s += s_chunk; - src_bytes_left -= s_chunk; - dst_bytes_left -= d_chunk; - - if ( src_bytes_left > 0 && ! (++s - src) % (MAX_LONG_STRING+1) ) - { - if ( *s != ' ') - msg(MW, _("Expected a space in very long string")); - src_bytes_left--; - } - } -} - -/* Copies buffer SRC, of SRC_SIZE bytes, to DST, of DST_SIZE bytes. - DST is rounded up to the nearest 8 byte boundary. - A space is inserted at each 256th byte. - DST is then truncated to DST_SIZE bytes or padded on the right with - spaces as needed. */ -void -copy_mangle (char *dst, size_t dst_size, - const char *src, size_t src_size) -{ - int src_bytes_left = src_size; - int dst_bytes_left = dst_size; - const char *s = src; - char *d = dst; - - memset(dst, ' ', dst_size); - - while( src_bytes_left > 0 ) - { - const size_t s_chunk = min(MAX_LONG_STRING, src_bytes_left); - const size_t d_chunk = min(MAX_LONG_STRING, dst_bytes_left); - - buf_copy_rpad (d, d_chunk, s, s_chunk); - - d += d_chunk; - s += s_chunk; - src_bytes_left -= s_chunk; - dst_bytes_left -= d_chunk; - - if ( dst_bytes_left > 0 && 0 == ( d + 1 - dst ) % (MAX_LONG_STRING + 1) ) - { - memset(d, ' ', 1); - d++; - dst_bytes_left--; - } - } -} - /* Return the number of bytes used when writing case_data for a variable of WIDTH */ int width_to_bytes(int width) { + const int chunks = width / EFFECTIVE_LONG_STRING_LENGTH ; + const int remainder = width - (chunks * EFFECTIVE_LONG_STRING_LENGTH) ; int bytes, mod8; assert (width >= 0); @@ -442,9 +368,6 @@ width_to_bytes(int width) if ( width <= MAX_LONG_STRING) return MAX_SHORT_STRING * DIV_RND_UP(width, MAX_SHORT_STRING); - const int chunks = width / EFFECTIVE_LONG_STRING_LENGTH ; - - const int remainder = width - (chunks * EFFECTIVE_LONG_STRING_LENGTH) ; bytes = remainder + (chunks * (MAX_LONG_STRING + 1) ); @@ -459,3 +382,4 @@ width_to_bytes(int width) return bytes; } +