blob: 2759d6b1f626bc2f4a710075042135aa5508a5f9 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// BEGIN android-note
// address length was changed from long to int for performance reasons.
// END android-note
package org.apache.harmony.luni.platform;
import java.io.FileDescriptor;
import java.io.FileNotFoundException;
import java.io.IOException;
/**
* This is the portable implementation of the file system interface.
*
*/
class OSFileSystem extends OSComponent implements IFileSystem {
/**
*
*/
public OSFileSystem() {
super();
}
private final void validateLockArgs(int type, long start, long length) {
if ((type != IFileSystem.SHARED_LOCK_TYPE)
&& (type != IFileSystem.EXCLUSIVE_LOCK_TYPE)) {
throw new IllegalArgumentException("Illegal lock type requested."); //$NON-NLS-1$
}
// Start position
if (start < 0) {
throw new IllegalArgumentException(
"Lock start position must be non-negative"); //$NON-NLS-1$
}
// Length of lock stretch
if (length < 0) {
throw new IllegalArgumentException(
"Lock length must be non-negative"); //$NON-NLS-1$
}
}
private native int lockImpl(int fileDescriptor, long start, long length,
int type, boolean wait);
/**
* Returns the granularity for virtual memory allocation.
* Note that this value for Windows differs from the one for the
* page size (64K and 4K respectively).
*/
public native int getAllocGranularity() throws IOException;
public boolean lock(int fileDescriptor, long start, long length, int type,
boolean waitFlag) throws IOException {
// Validate arguments
validateLockArgs(type, start, length);
int result = lockImpl(fileDescriptor, start, length, type, waitFlag);
return result != -1;
}
private native int unlockImpl(int fileDescriptor, long start, long length);
public void unlock(int fileDescriptor, long start, long length)
throws IOException {
// Validate arguments
validateLockArgs(IFileSystem.SHARED_LOCK_TYPE, start, length);
int result = unlockImpl(fileDescriptor, start, length);
if (result == -1) {
throw new IOException();
}
}
private native int fflushImpl(int fd, boolean metadata);
public void fflush(int fileDescriptor, boolean metadata)
throws IOException {
int result = fflushImpl(fileDescriptor, metadata);
if (result == -1) {
throw new IOException();
}
}
/*
* File position seeking.
*/
private native long seekImpl(int fd, long offset, int whence);
public long seek(int fileDescriptor, long offset, int whence)
throws IOException {
long pos = seekImpl(fileDescriptor, offset, whence);
if (pos == -1) {
throw new IOException();
}
return pos;
}
/*
* Direct read/write APIs work on addresses.
*/
private native long readDirectImpl(int fileDescriptor, int address,
int offset, int length);
public long readDirect(int fileDescriptor, int address, int offset,
int length) throws IOException {
long bytesRead = readDirectImpl(fileDescriptor, address, offset, length);
if (bytesRead < -1) {
throw new IOException();
}
return bytesRead;
}
private native long writeDirectImpl(int fileDescriptor, int address,
int offset, int length);
public long writeDirect(int fileDescriptor, int address, int offset,
int length) throws IOException {
long bytesWritten = writeDirectImpl(fileDescriptor, address, offset,
length);
if (bytesWritten < 0) {
throw new IOException();
}
return bytesWritten;
}
/*
* Indirect read/writes work on byte[]'s
*/
private native long readImpl(int fileDescriptor, byte[] bytes, int offset,
int length);
public long read(int fileDescriptor, byte[] bytes, int offset, int length)
throws IOException {
if (bytes == null) {
throw new NullPointerException();
}
long bytesRead = readImpl(fileDescriptor, bytes, offset, length);
if (bytesRead < -1) {
throw new IOException();
}
return bytesRead;
}
private native long writeImpl(int fileDescriptor, byte[] bytes,
int offset, int length);
public long write(int fileDescriptor, byte[] bytes, int offset, int length)
throws IOException {
long bytesWritten = writeImpl(fileDescriptor, bytes, offset, length);
if (bytesWritten < 0) {
throw new IOException();
}
return bytesWritten;
}
/*
* Scatter/gather calls.
*/
public long readv(int fileDescriptor, int[] addresses, int[] offsets,
int[] lengths, int size) throws IOException {
long bytesRead = readvImpl(fileDescriptor, addresses, offsets, lengths,
size);
if (bytesRead < -1) {
throw new IOException();
}
return bytesRead;
}
private native long readvImpl(int fileDescriptor, int[] addresses,
int[] offsets, int[] lengths, int size);
public long writev(int fileDescriptor, int[] addresses, int[] offsets,
int[] lengths, int size) throws IOException {
long bytesWritten = writevImpl(fileDescriptor, addresses, offsets,
lengths, size);
if (bytesWritten < 0) {
throw new IOException();
}
return bytesWritten;
}
private native long writevImpl(int fileDescriptor, int[] addresses,
int[] offsets, int[] lengths, int size);
private native int closeImpl(int fileDescriptor);
/*
* (non-Javadoc)
*
* @see org.apache.harmony.luni.platform.IFileSystem#close(long)
*/
public void close(int fileDescriptor) throws IOException {
int rc = closeImpl(fileDescriptor);
if (rc == -1) {
throw new IOException();
}
}
public void truncate(int fileDescriptor, long size) throws IOException {
int rc = truncateImpl(fileDescriptor, size);
if (rc < 0) {
throw new IOException();
}
}
private native int truncateImpl(int fileDescriptor, long size);
public int open(byte[] fileName, int mode) throws FileNotFoundException {
if (fileName == null) {
throw new NullPointerException();
}
int handler = openImpl(fileName, mode);
if (handler < 0) {
throw new FileNotFoundException(new String(fileName));
}
return handler;
}
private native int openImpl(byte[] fileName, int mode);
public long transfer(int fileHandler, FileDescriptor socketDescriptor,
long offset, long count) throws IOException {
long result = transferImpl(fileHandler, socketDescriptor, offset, count);
if (result < 0) throw new IOException();
return result;
}
private native long transferImpl(int fileHandler,
FileDescriptor socketDescriptor, long offset, long count);
// BEGIN android-deleted
// public long ttyAvailable() throws IOException {
// long nChar = ttyAvailableImpl();
// if (nChar < 0) {
// throw new IOException();
// }
// return nChar;
// }
//
// private native long ttyAvailableImpl();
// END android-deleted
public long ttyRead(byte[] bytes, int offset, int length) throws IOException {
long nChar = ttyReadImpl(bytes, offset, length);
// BEGIN android-changed
if (nChar < -1) {
throw new IOException();
}
// END android-changed
return nChar;
}
private native long ttyReadImpl(byte[] bytes, int offset, int length);
// BEGIN android-added
public native int ioctlAvailable(int fileDescriptor) throws IOException;
// END android-added
}