From 1c7d214f539c82e9dd57ffeca3b173fbc37fa61a Mon Sep 17 00:00:00 2001 From: Andrew Dinn Date: Tue, 9 Apr 2019 16:21:20 +0100 Subject: [PATCH] 8221397: Support implementation-defined Map Modes Allow implementation-defined extensions to FileChannel MapMode enum Reviewed-by: alanb --- .../java/nio/channels/FileChannel.java | 35 +++++++++++++------ .../classes/sun/nio/ch/FileChannelImpl.java | 5 +-- 2 files changed, 27 insertions(+), 13 deletions(-) diff --git a/src/java.base/share/classes/java/nio/channels/FileChannel.java b/src/java.base/share/classes/java/nio/channels/FileChannel.java index 055cbfc7dad..dd2a6686fc6 100644 --- a/src/java.base/share/classes/java/nio/channels/FileChannel.java +++ b/src/java.base/share/classes/java/nio/channels/FileChannel.java @@ -791,7 +791,7 @@ public abstract class FileChannel // -- Memory-mapped buffers -- /** - * A typesafe enumeration for file-mapping modes. + * A file-mapping mode. * * @since 1.4 * @@ -819,6 +819,12 @@ public abstract class FileChannel private final String name; + /** + * Constructs an instance of this class. This constructor may be used + * by code in java.base to create file mapping modes beyond the file + * mapping modes defined here. + * @param name the name of the map mode + */ private MapMode(String name) { this.name = name; } @@ -837,8 +843,8 @@ public abstract class FileChannel /** * Maps a region of this channel's file directly into memory. * - *

A region of a file may be mapped into memory in one of three modes: - *

+ *

The {@code mode} parameter specifies how the region of the file is + * mapped and may be one of the following modes: * *

* + *

An implementation may support additional map modes. + * *

For a read-only mapping, this channel must have been opened for * reading; for a read/write or private mapping, this channel must have * been opened for both reading and writing. @@ -892,7 +900,8 @@ public abstract class FileChannel * MapMode#READ_WRITE READ_WRITE}, or {@link MapMode#PRIVATE * PRIVATE} defined in the {@link MapMode} class, according to * whether the file is to be mapped read-only, read/write, or - * privately (copy-on-write), respectively + * privately (copy-on-write), respectively, or an implementation + * specific map mode * * @param position * The position within the file at which the mapped region @@ -905,25 +914,29 @@ public abstract class FileChannel * @return The mapped byte buffer * * @throws NonReadableChannelException - * If the {@code mode} is {@link MapMode#READ_ONLY READ_ONLY} but - * this channel was not opened for reading + * If the {@code mode} is {@link MapMode#READ_ONLY READ_ONLY} or + * an implementation specific map mode requiring read access + * but this channel was not opened for reading * * @throws NonWritableChannelException - * If the {@code mode} is {@link MapMode#READ_WRITE READ_WRITE} or - * {@link MapMode#PRIVATE PRIVATE} but this channel was not opened - * for both reading and writing + * If the {@code mode} is {@link MapMode#READ_WRITE READ_WRITE}. + * {@link MapMode#PRIVATE PRIVATE} or an implementation specific + * map mode requiring write access but this channel was not + * opened for both reading and writing * * @throws IllegalArgumentException * If the preconditions on the parameters do not hold * + * @throws UnsupportedOperationException + * If an unsupported map mode is specified + * * @throws IOException * If some other I/O error occurs * * @see java.nio.channels.FileChannel.MapMode * @see java.nio.MappedByteBuffer */ - public abstract MappedByteBuffer map(MapMode mode, - long position, long size) + public abstract MappedByteBuffer map(MapMode mode, long position, long size) throws IOException; diff --git a/src/java.base/share/classes/sun/nio/ch/FileChannelImpl.java b/src/java.base/share/classes/sun/nio/ch/FileChannelImpl.java index 85f5c834712..777cab24ea8 100644 --- a/src/java.base/share/classes/sun/nio/ch/FileChannelImpl.java +++ b/src/java.base/share/classes/sun/nio/ch/FileChannelImpl.java @@ -940,14 +940,15 @@ public class FileChannelImpl if (size > Integer.MAX_VALUE) throw new IllegalArgumentException("Size exceeds Integer.MAX_VALUE"); - int imode = -1; + int imode; if (mode == MapMode.READ_ONLY) imode = MAP_RO; else if (mode == MapMode.READ_WRITE) imode = MAP_RW; else if (mode == MapMode.PRIVATE) imode = MAP_PV; - assert (imode >= 0); + else + throw new UnsupportedOperationException(); if ((mode != MapMode.READ_ONLY) && !writable) throw new NonWritableChannelException(); if (!readable)