X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2Fmain.cpp;h=46946f9e9bcd1279f94e6fad26f986365aa0e3a8;hp=273d82a5bd0901ca32c4c044bf55b0c86b7a9764;hb=dfd021b1505fb3924ae103d8aa27c6200d6ec3fd;hpb=245ccc8576d4bd29ab04d506ddb0c44b04a67e39 diff --git a/src/main.cpp b/src/main.cpp index 273d82a..46946f9 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -1,26 +1,97 @@ -#include "common.h" +#include "main.h" +#include // Because we can. -#include "document.h" -#include "view.h" -#include "screen.h" +int main(int argc, char ** argv) +{ + #ifndef __STDC_IEC_559__ + Warn("__STDC_IEC_559__ not defined. IEEE 754 floating point not fully supported.\n"); + #endif -using namespace std; -using namespace IPDF; -int main(int argc, char ** argv) -{ + Debug("Compiled with REAL = %d => \"%s\" sizeof(Real) == %d bytes", REAL, g_real_name[REAL], sizeof(Real)); + Document doc; - doc.Add(0.5, 0.5, 0.5, 0.5); + srand(time(NULL)); + + enum {OUTPUT_TO_BMP, LOOP} mode = LOOP; + + + Colour c(0,0,0,1); + const char * input_bmp = NULL; + const char * output_bmp = NULL; + const char * input_filename = NULL; + float b[4] = {0,0,1,1}; - View view(doc); + int i = 0; + while (++i < argc) + { + if (argv[i][0] != '-') + { + input_filename = argv[i]; + continue; + } + switch (argv[i][1]) + { + case 'o': + mode = OUTPUT_TO_BMP; + if (++i >= argc) + Fatal("No input argument following -o switch"); + input_bmp = argv[i]; + if (++i >= argc) + Fatal("No output argument following -o switch"); + output_bmp = argv[i]; - Screen scr; + break; + case 'c': + { + Debug("Reading paint colour"); + for (int j = 1; j <= 4; ++j) + { + if (i+j >= argc) + Fatal("No %d colour component following -c switch", j); + char * e; + float * comp = (j == 1) ? (&c.r) : ((j == 2) ? (&c.g) : ((j == 3) ? (&c.b) : &(c.a))); + *comp = strtof(argv[i+j], &e); + if (*e != '\0') + Fatal("Colour component %d not a valid float", j); + } + i += 4; + break; + } + case 'b': + { + Debug("Reading view bounds"); + for (int j = 1; j <= 4; ++j) + { + if (i+j >= argc) + Fatal("No %d bounds component following -b switch", j); + char * e; + b[j-1] = strtof(argv[i+j], &e); + if (*e != '\0') + Fatal("Bounds component %d not a valid float", j); + } + i += 4; + break; + } + } + } - while (scr.PumpEvents()) + if (input_filename != NULL) + { + doc.LoadSVG(input_filename, Rect(0,0,Real(1)/Real(800),Real(1)/Real(600))); + } + else { - view.Render(); - scr.Present(); + //doc.AddBezier(Bezier(0,0, 1,0.5, 0.5,1, 1,1)); + doc.AddText("The quick brown\nfox jumps over\nthe lazy dog",0.1,0,0.5); + //doc.AddBezier(Bezier(0,0,0,0.1,0,0.1,0,0.1)); } + Debug("Start!"); + Rect bounds(b[0],b[1],b[2],b[3]); + if (mode == LOOP) + MainLoop(doc, bounds, c); + else if (mode == OUTPUT_TO_BMP) + OverlayBMP(doc, input_bmp, output_bmp, bounds, c); return 0; }