home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / misc / volume2 / pbm / Part4 / pbmtrnspos.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-08-07  |  1.3 KB  |  57 lines

  1. /* pbmtrnspos.c - read a portable bitmap and transpose it x for y
  2. **
  3. ** Copyright (C) 1988 by Jef Poskanzer.
  4. **
  5. ** Permission to use, copy, modify, and distribute this software and its
  6. ** documentation for any purpose and without fee is hereby granted, provided
  7. ** that the above copyright notice appear in all copies and that both that
  8. ** copyright notice and this permission notice appear in supporting
  9. ** documentation.  This software is provided "as is" without express or
  10. ** implied warranty.
  11. */
  12.  
  13. #include <stdio.h>
  14. #include "pbm.h"
  15.  
  16. main( argc, argv )
  17. int argc;
  18. char *argv[];
  19.     {
  20.     FILE *ifd;
  21.     bit **bits, **newbits;
  22.     int rows, cols, row, col;
  23.  
  24.     if ( argc > 2 )
  25.     {
  26.     fprintf( stderr, "usage:  %s [pbmfile]\n", argv[0] );
  27.     exit( 1 );
  28.     }
  29.  
  30.     if ( argc == 2 )
  31.     {
  32.         ifd = fopen( argv[1], "r" );
  33.         if ( ifd == NULL )
  34.         {
  35.         fprintf( stderr, "%s: can't open.\n", argv[1] );
  36.         exit( 1 );
  37.         }
  38.     }
  39.     else
  40.     ifd = stdin;
  41.  
  42.     bits = pbm_readpbm( ifd, &cols, &rows );
  43.  
  44.     if ( ifd != stdin )
  45.     fclose( ifd );
  46.  
  47.     newbits = pbm_allocarray( rows, cols );    /* note parameter reversal */
  48.  
  49.     for ( row = 0; row < rows; row++ )
  50.         for ( col = 0; col < cols; col++ )
  51.         newbits[col][row] = bits[row][col];
  52.  
  53.     pbm_writepbm( stdout, newbits, rows, cols );    /* reversed again */
  54.  
  55.     exit( 0 );
  56.     }
  57.