/*! Writes the data from \a pattern to a file with the given \a fileName. * Returns \c true if successful, otherwise returns \c false. */ int writePec(EmbPattern* pattern, const char* fileName) { EmbFile* file = 0; if(!embStitchList_count(pattern->stitchList)) { embLog_error("format-pec.c writePec(), pattern contains no stitches\n"); return 0; } /* Check for an END stitch and add one if it is not present */ if(pattern->lastStitch->stitch.flags != END) embPattern_addStitchRel(pattern, 0, 0, END, 1); file = embFile_open(fileName, "wb"); if(!file) { embLog_error("format-pec.c writePec(), cannot open %s for writing\n", fileName); return 0; } embPattern_flipVertical(pattern); /* TODO: There needs to be a matching flipVertical() call after the write to ensure multiple writes from the same pattern work properly */ embPattern_fixColorCount(pattern); embPattern_correctForMaxStitchLength(pattern,12.7, 204.7); embPattern_scale(pattern, 10.0); binaryWriteBytes(file, "#PEC0001", 8); writePecStitches(pattern, file, fileName); embFile_close(file); return 1; }
/*! Writes the data from \a pattern to a file with the given \a fileName. * Returns \c true if successful, otherwise returns \c false. */ int writePes(EmbPattern* pattern, const char* fileName) { int pecLocation; FILE* file = 0; if(!pattern) { embLog_error("format-pes.c writePes(), pattern argument is null\n"); return 0; } if(!fileName) { embLog_error("format-pes.c writePes(), fileName argument is null\n"); return 0; } file = fopen(fileName, "wb"); if(!file) { embLog_error("format-pes.c writePes(), cannot open %s for writing\n", fileName); return 0; } if(!pattern->stitchList || embStitchList_count(pattern->stitchList) == 0) /* TODO: review this. seems like only embStitchList_count should be needed. */ { embLog_error("format-pes.c writePes(), pattern contains no stitches\n"); return 0; } embPattern_flipVertical(pattern); embPattern_scale(pattern, 10.0); binaryWriteBytes(file, "#PES0001", 8); /* WRITE PECPointer 32 bit int */ binaryWriteInt(file, 0x00); binaryWriteShort(file, 0x01); binaryWriteShort(file, 0x01); /* Write object count */ binaryWriteShort(file, 0x01); binaryWriteShort(file, 0xFFFF); /* command */ binaryWriteShort(file, 0x00); /* unknown */ pesWriteEmbOneSection(pattern, file); pesWriteSewSegSection(pattern, file); pecLocation = ftell(file); fseek(file, 0x08, SEEK_SET); binaryWriteByte(file, (unsigned char)(pecLocation & 0xFF)); binaryWriteByte(file, (unsigned char)(pecLocation >> 8) & 0xFF); binaryWriteByte(file, (unsigned char)(pecLocation >> 16) & 0xFF); fseek(file, 0x00, SEEK_END); writePecStitches(pattern, file, fileName); fclose(file); return 1; }