1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
/**************************************************************************
* *
* Regina - A Normal Surface Theory Calculator *
* Computational Engine *
* *
* Copyright (c) 1999-2009, Ben Burton *
* For further details contact Ben Burton (bab@debian.org). *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License as *
* published by the Free Software Foundation; either version 2 of the *
* License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, but *
* WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
* General Public License for more details. *
* *
* You should have received a copy of the GNU General Public *
* License along with this program; if not, write to the Free *
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
* MA 02110-1301, USA. *
* *
**************************************************************************/
/* end stub */
#include <cstdio>
#include <sys/stat.h>
#include "foreign/pdf.h"
#include "packet/npdf.h"
namespace regina {
NPDF* readPDF(const char* filename) {
// Use FILE* so we can call fstat().
// Open the file.
FILE* in = fopen(filename, "rb");
if (! in)
return 0;
// Get the file size.
struct stat s;
if (fstat(fileno(in), &s)) {
fclose(in);
return 0;
}
size_t size = s.st_size;
if (size == 0) {
fclose(in);
return new NPDF();
}
// Read the file contents.
char* data = new char[size];
if (fread(data, 1, size, in) != size) {
fclose(in);
delete[] data;
return 0;
}
// Is there more to the file that we weren't expecting?
char c;
if (fread(&c, 1, 1, in) > 0) {
fclose(in);
delete[] data;
return 0;
}
// All good!
fclose(in);
return new NPDF(data, size, NPDF::OWN_NEW);
}
bool writePDF(const char* filename, const NPDF& pdf) {
// Use FILE* for symmetry with readPDF().
// Open the file.
FILE* out = fopen(filename, "wb");
if (!out)
return false;
// Is there anything to write?
const char* data = pdf.data();
if (data) {
size_t size = pdf.size();
if (fwrite(data, 1, size, out) != size) {
fclose(out);
return false;
}
}
// All done.
fclose(out);
return true;
}
} // namespace regina
|