Blame contrib/addtiffo/addtiffo.c

Packit 7838c8
/******************************************************************************
Packit 7838c8
 * $Id: addtiffo.c,v 1.8 2015-05-30 20:30:27 bfriesen Exp $
Packit 7838c8
 *
Packit 7838c8
 * Project:  GeoTIFF Overview Builder
Packit 7838c8
 * Purpose:  Mainline for building overviews in a TIFF file.
Packit 7838c8
 * Author:   Frank Warmerdam, warmerdam@pobox.com
Packit 7838c8
 *
Packit 7838c8
 ******************************************************************************
Packit 7838c8
 * Copyright (c) 1999, Frank Warmerdam
Packit 7838c8
 *
Packit 7838c8
 * Permission is hereby granted, free of charge, to any person obtaining a
Packit 7838c8
 * copy of this software and associated documentation files (the "Software"),
Packit 7838c8
 * to deal in the Software without restriction, including without limitation
Packit 7838c8
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
Packit 7838c8
 * and/or sell copies of the Software, and to permit persons to whom the
Packit 7838c8
 * Software is furnished to do so, subject to the following conditions:
Packit 7838c8
 *
Packit 7838c8
 * The above copyright notice and this permission notice shall be included
Packit 7838c8
 * in all copies or substantial portions of the Software.
Packit 7838c8
 *
Packit 7838c8
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
Packit 7838c8
 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Packit 7838c8
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
Packit 7838c8
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Packit 7838c8
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
Packit 7838c8
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
Packit 7838c8
 * DEALINGS IN THE SOFTWARE.
Packit 7838c8
 ******************************************************************************
Packit 7838c8
 *
Packit 7838c8
 * $Log: addtiffo.c,v $
Packit 7838c8
 * Revision 1.8  2015-05-30 20:30:27  bfriesen
Packit 7838c8
 * * contrib/addtiffo/addtiffo.c (main): Possibly address Coverity
Packit 7838c8
 * 1024226 "Untrusted value as argument".
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.7  2010-06-08 18:55:15  bfriesen
Packit 7838c8
 * * contrib: Add an emacs formatting mode footer to all source files
Packit 7838c8
 * so that emacs can be effectively used.
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.6  2005/12/16 05:59:55  fwarmerdam
Packit 7838c8
 * Major upgrade to support YCbCr subsampled jpeg images
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.4  2004/09/21 13:31:23  dron
Packit 7838c8
 * Add missed include string.h.
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.3  2000/04/18 22:48:31  warmerda
Packit 7838c8
 * Added support for averaging resampling
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.2  2000/01/28 15:36:38  warmerda
Packit 7838c8
 * pass TIFF handle instead of filename to overview builder
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.1  1999/08/17 01:47:59  warmerda
Packit 7838c8
 * New
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.1  1999/03/12 17:46:32  warmerda
Packit 7838c8
 * New
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.2  1999/02/11 22:27:12  warmerda
Packit 7838c8
 * Added multi-sample support
Packit 7838c8
 *
Packit 7838c8
 * Revision 1.1  1999/02/11 18:12:30  warmerda
Packit 7838c8
 * New
Packit 7838c8
 */
Packit 7838c8
Packit 7838c8
#include <stdio.h>
Packit 7838c8
#include <stdlib.h>
Packit 7838c8
#include <string.h>
Packit 7838c8
#include "tiffio.h"
Packit 7838c8
Packit 7838c8
void TIFFBuildOverviews( TIFF *, int, int *, int, const char *,
Packit 7838c8
                         int (*)(double,void*), void * );
Packit 7838c8
Packit 7838c8
/************************************************************************/
Packit 7838c8
/*                                main()                                */
Packit 7838c8
/************************************************************************/
Packit 7838c8
Packit 7838c8
int main( int argc, char ** argv )
Packit 7838c8
Packit 7838c8
{
Packit 7838c8
    int		anOverviews[100];   /* TODO: un-hardwire array length, flexible allocate */
Packit 7838c8
    int		nOverviewCount = 0;
Packit 7838c8
    int		bUseSubIFD = 0;
Packit 7838c8
    TIFF	*hTIFF;
Packit 7838c8
    const char  *pszResampling = "nearest";
Packit 7838c8
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
/*      Usage:                                                          */
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
    if( argc < 2 )
Packit 7838c8
    {
Packit 7838c8
        printf( "Usage: addtiffo [-r {nearest,average,mode}]\n"
Packit 7838c8
                "                tiff_filename [resolution_reductions]\n"
Packit 7838c8
                "\n"
Packit 7838c8
                "Example:\n"
Packit 7838c8
                " %% addtiffo abc.tif 2 4 8 16\n" );
Packit 7838c8
        return( 1 );
Packit 7838c8
    }
Packit 7838c8
Packit 7838c8
    while( argv[1][0] == '-' )
Packit 7838c8
    {
Packit 7838c8
        if( strcmp(argv[1],"-subifd") == 0 )
Packit 7838c8
        {
Packit 7838c8
            bUseSubIFD = 1;
Packit 7838c8
            argv++;
Packit 7838c8
            argc--;
Packit 7838c8
        }
Packit 7838c8
        else if( strcmp(argv[1],"-r") == 0 )
Packit 7838c8
        {
Packit 7838c8
            argv += 2;
Packit 7838c8
            argc -= 2;
Packit 7838c8
            pszResampling = *argv;
Packit 7838c8
        }
Packit 7838c8
        else
Packit 7838c8
        {
Packit 7838c8
            fprintf( stderr, "Incorrect parameters\n" );
Packit 7838c8
            return( 1 );
Packit 7838c8
        }
Packit 7838c8
    }
Packit 7838c8
Packit 7838c8
    /* TODO: resampling mode parameter needs to be encoded in an integer from this point on */
Packit 7838c8
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
/*      Collect the user requested reduction factors.                   */
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
    while( nOverviewCount < argc - 2 && nOverviewCount < 100 )
Packit 7838c8
    {
Packit 7838c8
        anOverviews[nOverviewCount] = atoi(argv[nOverviewCount+2]);
Packit 7838c8
        if( (anOverviews[nOverviewCount] <= 0) ||
Packit 7838c8
            ((anOverviews[nOverviewCount] > 1024)))
Packit 7838c8
        {
Packit 7838c8
            fprintf( stderr, "Incorrect parameters\n" );
Packit 7838c8
            return(1);
Packit 7838c8
        }
Packit 7838c8
        nOverviewCount++;
Packit 7838c8
    }
Packit 7838c8
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
/*      Default to four overview levels.  It would be nicer if it       */
Packit 7838c8
/*      defaulted based on the size of the source image.                */
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
    /* TODO: make it default based on the size of the source image */
Packit 7838c8
    if( nOverviewCount == 0 )
Packit 7838c8
    {
Packit 7838c8
        nOverviewCount = 4;
Packit 7838c8
Packit 7838c8
        anOverviews[0] = 2;
Packit 7838c8
        anOverviews[1] = 4;
Packit 7838c8
        anOverviews[2] = 8;
Packit 7838c8
        anOverviews[3] = 16;
Packit 7838c8
    }
Packit 7838c8
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
/*      Build the overview.                                             */
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
    hTIFF = TIFFOpen( argv[1], "r+" );
Packit 7838c8
    if( hTIFF == NULL )
Packit 7838c8
    {
Packit 7838c8
        fprintf( stderr, "TIFFOpen(%s) failed.\n", argv[1] );
Packit 7838c8
        return( 1 );
Packit 7838c8
    }
Packit 7838c8
Packit 7838c8
    TIFFBuildOverviews( hTIFF, nOverviewCount, anOverviews, bUseSubIFD,
Packit 7838c8
                        pszResampling, NULL, NULL );
Packit 7838c8
Packit 7838c8
    TIFFClose( hTIFF );
Packit 7838c8
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
/*      Optionally test for memory leaks.                               */
Packit 7838c8
/* -------------------------------------------------------------------- */
Packit 7838c8
#ifdef DBMALLOC
Packit 7838c8
    malloc_dump(1);
Packit 7838c8
#endif
Packit 7838c8
Packit 7838c8
    return( 0 );
Packit 7838c8
}
Packit 7838c8
/*
Packit 7838c8
 * Local Variables:
Packit 7838c8
 * mode: c
Packit 7838c8
 * c-basic-offset: 4
Packit 7838c8
 * fill-column: 78
Packit 7838c8
 * End:
Packit 7838c8
 */