⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testcomp.c

📁 短小精悍的C语言标准函数库。提供450个以上的可移植的算法和工具代码。
💻 C
字号:
/*  ----------------------------------------------------------------<Prolog>-
    Name:       testcomp.c
    Title:      Test program for compression functions
    Package:    Standard Function Library (SFL)

    Written:    1996/05/19  iMatix SFL project team <sfl@imatix.com>
    Revised:    1997/09/08

    Synopsis:   Runs tests on the compression functions.  Takes a file and
                compresses it if is not compressed, or expands it if it was
                compressed.  The output file is always called testcomp.out.

    Copyright:  Copyright (c) 1996-2000 iMatix Corporation
    License:    This is free software; you can redistribute it and/or modify
                it under the terms of the SFL License Agreement as provided
                in the file LICENSE.TXT.  This software is distributed in
                the hope that it will be useful, but without any warranty.
 ------------------------------------------------------------------</Prolog>-*/

#include "sfl.h"

#define BLOCK_SIZE      8192
#define RLE_BLOCK_SIZE  512
#define OUT_FILE        "testcomp.out"
#define LZ_SIGNATURE    0x12345670L
#define RLE_SIGNATURE   0x12345671L

local compress_file_lz  (FILE *input, FILE *output);
local expand_file_lz    (FILE *input, FILE *output);
local compress_file_rle (FILE *input, FILE *output);
local expand_file_rle   (FILE *input, FILE *output);

static byte
    in_block  [BLOCK_SIZE + 1],
    out_block [BLOCK_SIZE + 1];

int main (int argc, char *argv [])
{
    FILE
        *input,
        *output;
    qbyte
        signature;

    if (argc != 2 && argc != 3)
      {
        puts ("Usage: testcomp filename [rle]");
        return (EXIT_FAILURE);
      }
    input = fopen (argv [1], FOPEN_READ_BINARY);
    if (input == NULL)
      {
        printf ("Cannot open %s for input: %s\n", argv [1], strerror (errno));
        return (EXIT_FAILURE);
      }
    output = fopen (OUT_FILE, FOPEN_WRITE_BINARY);
    if (output == NULL)
      {
        printf ("Cannot open %s for output: %s\n", OUT_FILE, strerror (errno));
        return (EXIT_FAILURE);
      }
    /*  Look at signature to see if already compressed                       */
    fread (&signature, sizeof (signature), 1, input);
    if (signature == LZ_SIGNATURE)
        expand_file_lz (input, output);
    else
    if (signature == RLE_SIGNATURE)
        expand_file_rle (input, output);
    else
    if (argc == 3 && streq (argv [2], "rle"))
        compress_file_rle (input, output);
    else
        compress_file_lz (input, output);

    fclose (input);
    fclose (output);
    return (EXIT_SUCCESS);
}

local
compress_file_lz (FILE *input, FILE *output)
{
    word
        in_size,
        out_size;
    qbyte
        signature = LZ_SIGNATURE;

    fseek (input, 0, SEEK_SET);         /*  Start from beginning of file     */
    fwrite (&signature, sizeof (signature), 1, output);
    while ((in_size = fread (in_block, 1, BLOCK_SIZE, input)) > 0)
      {
        out_size = compress_block (in_block, out_block, in_size);
        fwrite (&out_size, 1, sizeof (out_size), output);
        fwrite (out_block, 1, out_size, output);
        printf ("lz compress: in=%d out=%d\n", in_size, out_size);
      }
}

local
expand_file_lz (FILE *input, FILE *output)
{
    word
        in_size,
        out_size;

    while ((fread (&in_size, 1, sizeof (in_size), input)) > 0)
      {
        fread (in_block, 1, in_size, input);
        out_size = expand_block (in_block, out_block, in_size);
        fwrite (out_block, 1, out_size, output);
        printf ("lz expand: in=%d out=%d\n", in_size, out_size);
      }
}

local
compress_file_rle (FILE *input, FILE *output)
{
    word
        in_size,
        out_size;
    qbyte
        signature = RLE_SIGNATURE;

    fseek (input, 0, SEEK_SET);         /*  Start from beginning of file     */
    fwrite (&signature, sizeof (signature), 1, output);
    while ((in_size = fread (in_block, 1, BLOCK_SIZE, input)) > 0)
      {
        out_size = compress_bits (in_block, out_block, in_size);
        fwrite (&out_size, 1, sizeof (out_size), output);
        fwrite (out_block, 1, out_size, output);
        printf ("rle compress: in=%d out=%d\n", in_size, out_size);
      }
}

local
expand_file_rle (FILE *input, FILE *output)
{
    word
        in_size,
        out_size;

    while ((fread (&in_size, 1, sizeof (in_size), input)) > 0)
      {
        fread (in_block, 1, in_size, input);
        out_size = expand_bits (in_block, out_block, in_size);
        fwrite (out_block, 1, out_size, output);
        printf ("rle expand: in=%d out=%d\n", in_size, out_size);
      }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -