Page 1 of 1

File Truncation

Posted: Mon Apr 02, 2007 11:49 am
by ~
Does anybody know how to truncate files, at least under Windows, and other OS'es, just like HIEW (hex editor application) does?

Posted: Mon Apr 02, 2007 12:14 pm
by Solar
Possibly, if you would care to tell us what HIEW does?

Posted: Mon Apr 02, 2007 12:54 pm
by Combuster
I noticed how many questions you asked that can be answered with a forum search or google. While I don't know the answer to this one, or where to find the answer, may i kindly suggest you to have a good look and give us some indication of what you have tried.

By the appearance of the question, you might want to reverse-engineer the algorithm involved. Which, probably, is the most educational way to understanding it.

Posted: Mon Apr 02, 2007 1:08 pm
by ~
I noticed how many questions you asked that can be answered with a forum search or google.
I try to ask for small details that even when finding information in Google, are hard to figure out and need to be extensively reworked. After that, I try to build up something to finish the issue at once. For example the CHS to LBA to CHS question, I didn't know that actually the HIW document about it could completely answer my question, yet I already knew its existence long ago.

-------------------


Basically one of the things HIEW can do is to shred a file, for example from the half of it and leave only the first 50%, and it does it immediately.

The things I have tried are horribly inefficient, like recopying the file into a new one up to the offset it should be preserved and then deleting the original and finally rename the new one.

What I would do, if I could, were to truncate the file by indicating the EOF in the "file allocation table" to make it smaller and thus effectively cause a truncation effect. Maybe there's some API to do so, I have looked for it for like 2 years, but maybe I should look again...

Posted: Mon Apr 02, 2007 2:28 pm
by ehird
char *blah = malloc((lengthoffile/2) * sizeof(char));
fgets(myfile, lengthoffile/2, blah);
fwrite(newfile, blah);

?

Posted: Mon Apr 02, 2007 4:56 pm
by mystran
In Unix if you just wanna truncate, you can do:

Code: Select all

  int fd = open("filename-to-truncate", O_WRONLY | O_TRUNC);
  if(fd < 0) { /* error: */ exit(1); }
  close(fd);
Either O_WRONLY or O_RDWR will do. For details, see open(2). On Windows the same can be done with a flag for CreateFile.

If your system doesn't support this, you can delete the file, and recreate it without writing anything into it.

As for actually saving the beginning (and just dumping out the rest) you need to look into system specific stuff. Technically it's done by simply setting the file-length in the filesystem to a smaller value, and freeing whatever blocks aren't part of the file anymore. It took me full 2 minutes to browse Win32 API reference to find out that there's an API function called SetEndOfFile... see said API documentation to figure out how it works.

Posted: Mon Apr 02, 2007 9:11 pm
by B.E
For a Unix OS try truncate/ftruncate, for windose try what mystran segested.

Posted: Mon Apr 02, 2007 9:54 pm
by mystran
Oh ok, I didn't actually know of truncate(2) :)

Posted: Tue Apr 03, 2007 4:38 pm
by B.E
I knew it existed on unix, I just did what ~ should of done in the first place, googled for "set file size".

But I didn' know about SetEndOfFile though.