|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T a
Length: 1760 (0x6e0)
Types: TextFile
Names: »ascii2var.c++«
└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
└─⟦this⟧ »EUUGD11/euug-87hel/sec1/image/vartools/ascii2var.c++«
/*
This contains the work routine that converts an image to
a ascii file
*/
#include <stream.h>
#include <stdio.h>
#include <string.h>
#include <double_image.h++>
#include "vartools.h++"
// input is a file pointer to the input file
// output is a file pointer open for output
void
ascii2var(FILE *input , FILE *output)
{
int number_rows = -1;
int number_cols = -1;
// read the length and the width
fscanf(input,"%d%d",&number_rows,&number_cols);
// initialize the image
double_image output_image(CREATE,number_rows,number_cols,output);
// iterate through the output image reading in numbers
while(output_image++)
{
fscanf(input,"%lf",&(output_image()));
}
// scan through the image until an end of file or a new line
char c;
for(;;)
{
c = getc(input);
if ( c == EOF ) return ;
if ( c == '\n') break;
}
// read in the comments
int comments_size = 128;
char * comments = new char[comments_size];
for ( int i = 0 ; EOF != (c = getc(input)) ; i++ )
{
// if you ran out of room double the size of the comments
if ( i == comments_size )
{
char *new_comments = new char[comments_size + comments_size];
for( int j = 0 ; j < comments_size ; j++ )
{
new_comments[j] = comments[j];
}
comments_size += comments_size;
comments = new_comments;
}
comments[i] = c;
}
comments[i] = 0;
output_image.set_comments(comments,i);
// write the output to disk
output_image.write();
}
/*
Copyright (C) 1986, David Sher in the University of Rochester
Permission is granted to any individual or institution to use, copy, or
redistribute this software so long as it is not sold for profit, provided
this copyright notice is retained.
*/