Commit baa61e09 by Michael Koch

[multiple changes]

2004-07-17  Mark Wielaard  <mark@klomp.org>

	* gnu/java/nio/channels/FileChannelImpl.java (truncate): Only truncate
	when size is smaller.
	* java/io/RandomAccessFile.java (setLength): Use truncate for
	shrinking the file and seek plus write for expanding the file.

2004-07-17  Michael Koch  <konqueror@gmx.de>

	* gnu/java/nio/channels/natFileChannelPosix.cc
	(implTruncate): Always save current position. Only reposition file
	pointer to where we started if not beyond new lenght. Reposition file
	pointer to file length if it points beyond the end of file.

From-SVN: r84868
parent 3e25b3a8
2004-07-17 Mark Wielaard <mark@klomp.org>
* gnu/java/nio/channels/FileChannelImpl.java (truncate): Only truncate
when size is smaller.
* java/io/RandomAccessFile.java (setLength): Use truncate for
shrinking the file and seek plus write for expanding the file.
2004-07-17 Michael Koch <konqueror@gmx.de>
* gnu/java/nio/channels/natFileChannelPosix.cc
(implTruncate): Always save current position. Only reposition file
pointer to where we started if not beyond new lenght. Reposition file
pointer to file length if it points beyond the end of file.
2004-07-17 Mark Wielaard <mark@klomp.org>
* javax/swing/Box.java: Put FIXME comment above class declaration.
* javax/swing/JButton.java: Remove illegal L&F HTML from comments.
* javax/swing/JCheckBox.java: Likewise.
......
......@@ -422,7 +422,9 @@ public final class FileChannelImpl extends FileChannel
if ((mode & WRITE) == 0)
throw new NonWritableChannelException ();
implTruncate (size);
if (size < size ())
implTruncate (size);
return this;
}
}
......@@ -274,7 +274,10 @@ FileChannelImpl::implTruncate (jlong size)
}
else
{
if (::ftruncate (fd, (off_t) pos))
if (::ftruncate (fd, (off_t) size))
throw new IOException (JvNewStringLatin1 (strerror (errno)));
if (pos > size
&& ::lseek (fd, (off_t) size, SEEK_SET) == -1)
throw new IOException (JvNewStringLatin1 (strerror (errno)));
pos = size;
}
......
......@@ -194,12 +194,14 @@ public class RandomAccessFile implements DataOutput, DataInput
}
/**
* This method sets the length of the file to the specified length. If
* the currently length of the file is longer than the specified length,
* then the file is truncated to the specified length. If the current
* length of the file is shorter than the specified length, the file
* is extended with bytes of an undefined value.
* <p>
* This method sets the length of the file to the specified length.
* If the currently length of the file is longer than the specified
* length, then the file is truncated to the specified length (the
* file position is set to the end of file in this case). If the
* current length of the file is shorter than the specified length,
* the file is extended with bytes of an undefined value (the file
* position is unchanged in this case).
* <p>
* The file must be open for write access for this operation to succeed.
*
* @param newlen The new length of the file
......@@ -208,7 +210,19 @@ public class RandomAccessFile implements DataOutput, DataInput
*/
public void setLength (long newLen) throws IOException
{
ch.truncate (newLen);
// FIXME: Extending a file should probably be done by one method call.
// FileChannel.truncate() can only shrink a file.
// To expand it we need to seek forward and write at least one byte.
if (newLen < length())
ch.truncate (newLen);
else if (newLen > length())
{
long pos = getFilePointer();
seek(newLen - 1);
write(0);
seek(pos);
}
}
/**
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment