jdk/src/solaris/classes/sun/nio/fs/SolarisWatchService.java
author malenkov
Tue, 29 Oct 2013 17:01:06 +0400
changeset 21278 ef8a3a2a72f2
parent 13579 e5a8ca9244e1
child 23010 6dadb192ad81
permissions -rw-r--r--
8022746: List of spelling errors in API doc Reviewed-by: alexsch, smarks
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
     1
/*
13246
a54c4f70775c 7179305: (fs) Method name sun.nio.fs.UnixPath.getPathForExecptionMessage is misspelled
robm
parents: 12556
diff changeset
     2
 * Copyright (c) 2008, 2012, Oracle and/or its affiliates. All rights reserved.
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
     4
 *
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2057
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2057
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    10
 *
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    15
 * accompanied this code).
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    16
 *
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    20
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2057
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2057
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2057
diff changeset
    23
 * questions.
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    24
 */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    25
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    26
package sun.nio.fs;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    27
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    28
import java.nio.file.*;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    29
import java.security.AccessController;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    30
import java.security.PrivilegedAction;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    31
import java.util.*;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    32
import java.io.IOException;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    33
import sun.misc.Unsafe;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    34
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    35
import static sun.nio.fs.UnixConstants.*;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    36
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    37
/**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    38
 * Solaris implementation of WatchService based on file events notification
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    39
 * facility.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    40
 */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    41
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    42
class SolarisWatchService
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    43
    extends AbstractWatchService
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    44
{
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    45
    private static final Unsafe unsafe = Unsafe.getUnsafe();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    46
    private static int addressSize = unsafe.addressSize();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    47
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    48
    private static int dependsArch(int value32, int value64) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    49
        return (addressSize == 4) ? value32 : value64;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    50
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    51
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    52
    /*
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    53
     * typedef struct port_event {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    54
     *     int             portev_events;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    55
     *     ushort_t        portev_source;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    56
     *     ushort_t        portev_pad;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    57
     *     uintptr_t       portev_object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    58
     *     void            *portev_user;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    59
     * } port_event_t;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    60
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    61
    private static final int SIZEOF_PORT_EVENT  = dependsArch(16, 24);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    62
    private static final int OFFSETOF_EVENTS    = 0;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    63
    private static final int OFFSETOF_SOURCE    = 4;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    64
    private static final int OFFSETOF_OBJECT    = 8;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    65
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    66
    /*
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    67
     * typedef struct file_obj {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    68
     *     timestruc_t     fo_atime;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    69
     *     timestruc_t     fo_mtime;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    70
     *     timestruc_t     fo_ctime;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    71
     *     uintptr_t       fo_pad[3];
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    72
     *     char            *fo_name;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    73
     * } file_obj_t;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    74
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    75
    private static final int SIZEOF_FILEOBJ    = dependsArch(40, 80);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    76
    private static final int OFFSET_FO_NAME    = dependsArch(36, 72);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    77
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    78
    // port sources
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    79
    private static final short PORT_SOURCE_USER     = 3;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    80
    private static final short PORT_SOURCE_FILE     = 7;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    81
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    82
    // user-watchable events
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    83
    private static final int FILE_MODIFIED      = 0x00000002;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    84
    private static final int FILE_ATTRIB        = 0x00000004;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    85
    private static final int FILE_NOFOLLOW      = 0x10000000;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    86
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    87
    // exception events
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    88
    private static final int FILE_DELETE        = 0x00000010;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    89
    private static final int FILE_RENAME_TO     = 0x00000020;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    90
    private static final int FILE_RENAME_FROM   = 0x00000040;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    91
    private static final int UNMOUNTED          = 0x20000000;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    92
    private static final int MOUNTEDOVER        = 0x40000000;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    93
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    94
    // background thread to read change events
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    95
    private final Poller poller;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    96
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    97
    SolarisWatchService(UnixFileSystem fs) throws IOException {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    98
        int port = -1;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
    99
        try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   100
            port = portCreate();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   101
        } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   102
            throw new IOException(x.errorString());
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   103
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   104
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   105
        this.poller = new Poller(fs, this, port);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   106
        this.poller.start();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   107
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   108
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   109
    @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   110
    WatchKey register(Path dir,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   111
                      WatchEvent.Kind<?>[] events,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   112
                      WatchEvent.Modifier... modifiers)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   113
         throws IOException
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   114
    {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   115
        // delegate to poller
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   116
        return poller.register(dir, events, modifiers);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   117
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   118
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   119
    @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   120
    void implClose() throws IOException {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   121
        // delegate to poller
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   122
        poller.close();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   123
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   124
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   125
    /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   126
     * WatchKey implementation
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   127
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   128
    private class SolarisWatchKey extends AbstractWatchKey
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   129
        implements DirectoryNode
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   130
    {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   131
        private final UnixFileKey fileKey;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   132
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   133
        // pointer to native file_obj object
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   134
        private final long object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   135
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   136
        // events (may be changed). set to null when watch key is invalid
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   137
        private volatile Set<? extends WatchEvent.Kind<?>> events;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   138
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   139
        // map of entries in directory; created lazily; accessed only by
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   140
        // poller thread.
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   141
        private Map<Path,EntryNode> children = new HashMap<>();
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   142
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   143
        SolarisWatchKey(SolarisWatchService watcher,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   144
                        UnixPath dir,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   145
                        UnixFileKey fileKey,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   146
                        long object,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   147
                        Set<? extends WatchEvent.Kind<?>> events)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   148
        {
8158
77d9c0f1c19f 7006126: (fs) Updates to file system API (1/2011)
alanb
parents: 5506
diff changeset
   149
            super(dir, watcher);
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   150
            this.fileKey = fileKey;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   151
            this.object = object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   152
            this.events = events;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   153
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   154
8158
77d9c0f1c19f 7006126: (fs) Updates to file system API (1/2011)
alanb
parents: 5506
diff changeset
   155
        UnixPath getDirectory() {
77d9c0f1c19f 7006126: (fs) Updates to file system API (1/2011)
alanb
parents: 5506
diff changeset
   156
            return (UnixPath)watchable();
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   157
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   158
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   159
        UnixFileKey getFileKey() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   160
            return fileKey;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   161
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   162
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   163
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   164
        public long object() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   165
            return object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   166
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   167
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   168
        void invalidate() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   169
            events = null;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   170
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   171
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   172
        Set<? extends WatchEvent.Kind<?>> events() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   173
            return events;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   174
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   175
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   176
        void setEvents(Set<? extends WatchEvent.Kind<?>> events) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   177
            this.events = events;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   178
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   179
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   180
        Map<Path,EntryNode> children() {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   181
            return children;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   182
        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   183
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   184
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   185
        public boolean isValid() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   186
            return events != null;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   187
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   188
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   189
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   190
        public void cancel() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   191
            if (isValid()) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   192
                // delegate to poller
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   193
                poller.cancel(this);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   194
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   195
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   196
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   197
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   198
        public void addChild(Path name, EntryNode node) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   199
            children.put(name, node);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   200
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   201
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   202
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   203
        public void removeChild(Path name) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   204
            children.remove(name);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   205
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   206
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   207
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   208
        public EntryNode getChild(Path name) {
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   209
            return children.get(name);
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   210
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   211
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   212
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   213
    /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   214
     * Background thread to read from port
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   215
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   216
    private class Poller extends AbstractPoller {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   217
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   218
        // maximum number of events to read per call to port_getn
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   219
        private static final int MAX_EVENT_COUNT            = 128;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   220
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   221
        // events that map to ENTRY_DELETE
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   222
        private static final int FILE_REMOVED =
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   223
            (FILE_DELETE|FILE_RENAME_TO|FILE_RENAME_FROM);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   224
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   225
        // events that tell us not to re-associate the object
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   226
        private static final int FILE_EXCEPTION =
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   227
            (FILE_REMOVED|UNMOUNTED|MOUNTEDOVER);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   228
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   229
        // address of event buffers (used to receive events with port_getn)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   230
        private final long bufferAddress;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   231
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   232
        private final SolarisWatchService watcher;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   233
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   234
        // the I/O port
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   235
        private final int port;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   236
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   237
        // maps file key (dev/inode) to WatchKey
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   238
        private final Map<UnixFileKey,SolarisWatchKey> fileKey2WatchKey;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   239
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   240
        // maps file_obj object to Node
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   241
        private final Map<Long,Node> object2Node;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   242
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   243
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   244
         * Create a new instance
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   245
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   246
        Poller(UnixFileSystem fs, SolarisWatchService watcher, int port) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   247
            this.watcher = watcher;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   248
            this.port = port;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   249
            this.bufferAddress =
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   250
                unsafe.allocateMemory(SIZEOF_PORT_EVENT * MAX_EVENT_COUNT);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   251
            this.fileKey2WatchKey = new HashMap<UnixFileKey,SolarisWatchKey>();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   252
            this.object2Node = new HashMap<Long,Node>();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   253
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   254
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   255
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   256
        void wakeup() throws IOException {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   257
            // write to port to wakeup polling thread
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   258
            try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   259
                portSend(port, 0);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   260
            } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   261
                throw new IOException(x.errorString());
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   262
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   263
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   264
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   265
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   266
        Object implRegister(Path obj,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   267
                            Set<? extends WatchEvent.Kind<?>> events,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   268
                            WatchEvent.Modifier... modifiers)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   269
        {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   270
            // no modifiers supported at this time
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   271
            if (modifiers.length > 0) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   272
                for (WatchEvent.Modifier modifier: modifiers) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   273
                    if (modifier == null)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   274
                        return new NullPointerException();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   275
                    if (modifier instanceof com.sun.nio.file.SensitivityWatchEventModifier)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   276
                        continue; // ignore
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   277
                    return new UnsupportedOperationException("Modifier not supported");
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   278
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   279
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   280
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   281
            UnixPath dir = (UnixPath)obj;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   282
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   283
            // check file is directory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   284
            UnixFileAttributes attrs = null;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   285
            try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   286
                attrs = UnixFileAttributes.get(dir, true);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   287
            } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   288
                return x.asIOException(dir);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   289
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   290
            if (!attrs.isDirectory()) {
13246
a54c4f70775c 7179305: (fs) Method name sun.nio.fs.UnixPath.getPathForExecptionMessage is misspelled
robm
parents: 12556
diff changeset
   291
                return new NotDirectoryException(dir.getPathForExceptionMessage());
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   292
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   293
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   294
            // if already registered then update the events and return existing key
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   295
            UnixFileKey fileKey = attrs.fileKey();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   296
            SolarisWatchKey watchKey = fileKey2WatchKey.get(fileKey);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   297
            if (watchKey != null) {
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   298
                try {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   299
                    updateEvents(watchKey, events);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   300
                } catch (UnixException x) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   301
                    return x.asIOException(dir);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   302
                }
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   303
                return watchKey;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   304
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   305
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   306
            // register directory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   307
            long object = 0L;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   308
            try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   309
                object = registerImpl(dir, (FILE_MODIFIED | FILE_ATTRIB));
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   310
            } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   311
                return x.asIOException(dir);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   312
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   313
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   314
            // create watch key and insert it into maps
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   315
            watchKey = new SolarisWatchKey(watcher, dir, fileKey, object, events);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   316
            object2Node.put(object, watchKey);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   317
            fileKey2WatchKey.put(fileKey, watchKey);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   318
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   319
            // register all entries in directory
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   320
            registerChildren(dir, watchKey, false, false);
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   321
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   322
            return watchKey;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   323
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   324
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   325
        // release resources for single entry
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   326
        void releaseChild(EntryNode node) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   327
            long object = node.object();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   328
            if (object != 0L) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   329
               object2Node.remove(object);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   330
               releaseObject(object, true);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   331
               node.setObject(0L);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   332
           }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   333
        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   334
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   335
        // release resources for entries in directory
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   336
        void releaseChildren(SolarisWatchKey key) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   337
           for (EntryNode node: key.children().values()) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   338
               releaseChild(node);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   339
           }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   340
        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   341
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   342
        // cancel single key
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   343
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   344
        void implCancelKey(WatchKey obj) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   345
           SolarisWatchKey key = (SolarisWatchKey)obj;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   346
           if (key.isValid()) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   347
               fileKey2WatchKey.remove(key.getFileKey());
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   348
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   349
               // release resources for entries
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   350
               releaseChildren(key);
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   351
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   352
               // release resources for directory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   353
               long object = key.object();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   354
               object2Node.remove(object);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   355
               releaseObject(object, true);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   356
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   357
               // and finally invalidate the key
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   358
               key.invalidate();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   359
           }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   360
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   361
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   362
        // close watch service
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   363
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   364
        void implCloseAll() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   365
            // release all native resources
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   366
            for (Long object: object2Node.keySet()) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   367
                releaseObject(object, true);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   368
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   369
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   370
            // invalidate all keys
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   371
            for (Map.Entry<UnixFileKey,SolarisWatchKey> entry: fileKey2WatchKey.entrySet()) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   372
                entry.getValue().invalidate();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   373
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   374
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   375
            // clean-up
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   376
            object2Node.clear();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   377
            fileKey2WatchKey.clear();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   378
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   379
            // free global resources
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   380
            unsafe.freeMemory(bufferAddress);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   381
            UnixNativeDispatcher.close(port);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   382
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   383
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   384
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   385
         * Poller main loop. Blocks on port_getn waiting for events and then
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   386
         * processes them.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   387
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   388
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   389
        public void run() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   390
            try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   391
                for (;;) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   392
                    int n = portGetn(port, bufferAddress, MAX_EVENT_COUNT);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   393
                    assert n > 0;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   394
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   395
                    long address = bufferAddress;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   396
                    for (int i=0; i<n; i++) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   397
                        boolean shutdown = processEvent(address);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   398
                        if (shutdown)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   399
                            return;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   400
                        address += SIZEOF_PORT_EVENT;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   401
                    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   402
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   403
            } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   404
                x.printStackTrace();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   405
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   406
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   407
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   408
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   409
         * Process a single port_event
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   410
         *
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   411
         * Returns true if poller thread is requested to shutdown.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   412
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   413
        boolean processEvent(long address) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   414
            // pe->portev_source
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   415
            short source = unsafe.getShort(address + OFFSETOF_SOURCE);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   416
            // pe->portev_object
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   417
            long object = unsafe.getAddress(address + OFFSETOF_OBJECT);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   418
            // pe->portev_events
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   419
            int events = unsafe.getInt(address + OFFSETOF_EVENTS);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   420
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   421
            // user event is trigger to process pending requests
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   422
            if (source != PORT_SOURCE_FILE) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   423
                if (source == PORT_SOURCE_USER) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   424
                    // process any pending requests
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   425
                    boolean shutdown = processRequests();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   426
                    if (shutdown)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   427
                        return true;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   428
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   429
                return false;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   430
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   431
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   432
            // lookup object to get Node
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   433
            Node node = object2Node.get(object);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   434
            if (node == null) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   435
                // should not happen
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   436
                return false;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   437
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   438
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   439
            // As a workaround for 6642290 and 6636438/6636412 we don't use
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   440
            // FILE_EXCEPTION events to tell use not to register the file.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   441
            // boolean reregister = (events & FILE_EXCEPTION) == 0;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   442
            boolean reregister = true;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   443
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   444
            // If node is EntryNode then event relates to entry in directory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   445
            // If node is a SolarisWatchKey (DirectoryNode) then event relates
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   446
            // to a watched directory.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   447
            boolean isDirectory = (node instanceof SolarisWatchKey);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   448
            if (isDirectory) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   449
                processDirectoryEvents((SolarisWatchKey)node, events);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   450
            } else {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   451
                boolean ignore = processEntryEvents((EntryNode)node, events);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   452
                if (ignore)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   453
                    reregister = false;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   454
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   455
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   456
            // need to re-associate to get further events
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   457
            if (reregister) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   458
                try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   459
                    events = FILE_MODIFIED | FILE_ATTRIB;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   460
                    if (!isDirectory) events |= FILE_NOFOLLOW;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   461
                    portAssociate(port,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   462
                                  PORT_SOURCE_FILE,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   463
                                  object,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   464
                                  events);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   465
                } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   466
                    // unable to re-register
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   467
                    reregister = false;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   468
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   469
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   470
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   471
            // object is not re-registered so release resources. If
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   472
            // object is a watched directory then signal key
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   473
            if (!reregister) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   474
                // release resources
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   475
                object2Node.remove(object);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   476
                releaseObject(object, false);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   477
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   478
                // if watch key then signal it
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   479
                if (isDirectory) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   480
                    SolarisWatchKey key = (SolarisWatchKey)node;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   481
                    fileKey2WatchKey.remove( key.getFileKey() );
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   482
                    key.invalidate();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   483
                    key.signal();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   484
                } else {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   485
                    // if entry then remove it from parent
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   486
                    EntryNode entry = (EntryNode)node;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   487
                    SolarisWatchKey key = (SolarisWatchKey)entry.parent();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   488
                    key.removeChild(entry.name());
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   489
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   490
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   491
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   492
            return false;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   493
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   494
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   495
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   496
         * Process directory events. If directory is modified then re-scan
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   497
         * directory to register any new entries
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   498
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   499
        void processDirectoryEvents(SolarisWatchKey key, int mask) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   500
            if ((mask & (FILE_MODIFIED | FILE_ATTRIB)) != 0) {
8158
77d9c0f1c19f 7006126: (fs) Updates to file system API (1/2011)
alanb
parents: 5506
diff changeset
   501
                registerChildren(key.getDirectory(), key,
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   502
                    key.events().contains(StandardWatchEventKinds.ENTRY_CREATE),
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   503
                    key.events().contains(StandardWatchEventKinds.ENTRY_DELETE));
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   504
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   505
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   506
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   507
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   508
         * Process events for entries in registered directories. Returns {@code
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   509
         * true} if events are ignored because the watch key has been cancelled.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   510
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   511
        boolean processEntryEvents(EntryNode node, int mask) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   512
            SolarisWatchKey key = (SolarisWatchKey)node.parent();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   513
            Set<? extends WatchEvent.Kind<?>> events = key.events();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   514
            if (events == null) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   515
                // key has been cancelled so ignore event
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   516
                return true;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   517
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   518
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   519
            // entry modified
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   520
            if (((mask & (FILE_MODIFIED | FILE_ATTRIB)) != 0) &&
9679
d98ae8bc45fc 7042979: Rename StandardSocketOption and StandardWatchEventKind
alanb
parents: 9035
diff changeset
   521
                events.contains(StandardWatchEventKinds.ENTRY_MODIFY))
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   522
            {
9679
d98ae8bc45fc 7042979: Rename StandardSocketOption and StandardWatchEventKind
alanb
parents: 9035
diff changeset
   523
                key.signalEvent(StandardWatchEventKinds.ENTRY_MODIFY, node.name());
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   524
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   525
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   526
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   527
            return false;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   528
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   529
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   530
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   531
         * Registers all entries in the given directory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   532
         *
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   533
         * The {@code sendCreateEvents} and {@code sendDeleteEvents} parameters
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   534
         * indicates if ENTRY_CREATE and ENTRY_DELETE events should be queued
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   535
         * when new entries are found. When initially registering a directory
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   536
         * they will always be false. When re-scanning a directory then it
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   537
         * depends on if the events are enabled or not.
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   538
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   539
        void registerChildren(UnixPath dir,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   540
                              SolarisWatchKey parent,
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   541
                              boolean sendCreateEvents,
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   542
                              boolean sendDeleteEvents)
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   543
        {
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   544
            boolean isModifyEnabled =
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   545
                parent.events().contains(StandardWatchEventKinds.ENTRY_MODIFY) ;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   546
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   547
            // reset visited flag on entries so that we can detect file deletes
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   548
            for (EntryNode node: parent.children().values()) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   549
                node.setVisited(false);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   550
            }
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   551
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   552
            try (DirectoryStream<Path> stream = Files.newDirectoryStream(dir)) {
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   553
                for (Path entry: stream) {
8158
77d9c0f1c19f 7006126: (fs) Updates to file system API (1/2011)
alanb
parents: 5506
diff changeset
   554
                    Path name = entry.getFileName();
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   555
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   556
                    // skip entry if already registered
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   557
                    EntryNode node = parent.getChild(name);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   558
                    if (node != null) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   559
                        node.setVisited(true);
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   560
                        continue;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   561
                    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   562
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   563
                    // new entry found
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   564
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   565
                    long object = 0L;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   566
                    int errno = 0;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   567
                    boolean addNode = false;
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   568
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   569
                    // if ENTRY_MODIFY enabled then we register the entry for events
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   570
                    if (isModifyEnabled) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   571
                        try {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   572
                            UnixPath path = (UnixPath)entry;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   573
                            int events = (FILE_NOFOLLOW | FILE_MODIFIED | FILE_ATTRIB);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   574
                            object = registerImpl(path, events);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   575
                            addNode = true;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   576
                        } catch (UnixException x) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   577
                            errno = x.errno();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   578
                        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   579
                    } else {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   580
                        addNode = true;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   581
                    }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   582
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   583
                    if (addNode) {
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   584
                        // create node
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   585
                        node = new EntryNode(object, (UnixPath)entry.getFileName(), parent);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   586
                        node.setVisited(true);
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   587
                        // tell the parent about it
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   588
                        parent.addChild(entry.getFileName(), node);
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   589
                        if (object != 0L)
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   590
                            object2Node.put(object, node);
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   591
                    }
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   592
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   593
                    // send ENTRY_CREATE event for the new file
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   594
                    // send ENTRY_DELETE event for files that were deleted immediately
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   595
                    boolean deleted = (errno == ENOENT);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   596
                    if (sendCreateEvents && (addNode || deleted))
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   597
                        parent.signalEvent(StandardWatchEventKinds.ENTRY_CREATE, name);
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   598
                    if (sendDeleteEvents && deleted)
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   599
                        parent.signalEvent(StandardWatchEventKinds.ENTRY_DELETE, name);
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   600
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   601
                }
12556
2e06461600d9 7164570: (fs) WatchService queues CREATE event but not DELETE event for very short lived files [sol11]
alanb
parents: 9679
diff changeset
   602
            } catch (DirectoryIteratorException | IOException x) {
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   603
                // queue OVERFLOW event so that user knows to re-scan directory
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   604
                parent.signalEvent(StandardWatchEventKinds.OVERFLOW, null);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   605
                return;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   606
            }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   607
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   608
            // clean-up and send ENTRY_DELETE events for any entries that were
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   609
            // not found
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   610
            Iterator<Map.Entry<Path,EntryNode>> iterator =
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   611
                parent.children().entrySet().iterator();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   612
            while (iterator.hasNext()) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   613
                Map.Entry<Path,EntryNode> entry = iterator.next();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   614
                EntryNode node = entry.getValue();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   615
                if (!node.isVisited()) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   616
                    long object = node.object();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   617
                    if (object != 0L) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   618
                        object2Node.remove(object);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   619
                        releaseObject(object, true);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   620
                    }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   621
                    if (sendDeleteEvents)
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   622
                        parent.signalEvent(StandardWatchEventKinds.ENTRY_DELETE, node.name());
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   623
                    iterator.remove();
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   624
                }
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   625
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   626
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   627
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   628
        /**
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   629
         * Update watch key's events. If ENTRY_MODIFY changes to be enabled
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   630
         * then register each file in the direcory; If ENTRY_MODIFY changed to
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   631
         * be disabled then unregister each file.
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   632
         */
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   633
        void updateEvents(SolarisWatchKey key, Set<? extends WatchEvent.Kind<?>> events)
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   634
            throws UnixException
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   635
        {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   636
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   637
            // update events, rembering if ENTRY_MODIFY was previously
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   638
            // enabled or disabled.
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   639
            boolean oldModifyEnabled = key.events()
9679
d98ae8bc45fc 7042979: Rename StandardSocketOption and StandardWatchEventKind
alanb
parents: 9035
diff changeset
   640
                .contains(StandardWatchEventKinds.ENTRY_MODIFY);
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   641
            key.setEvents(events);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   642
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   643
            // check if ENTRY_MODIFY has changed
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   644
            boolean newModifyEnabled = events
9679
d98ae8bc45fc 7042979: Rename StandardSocketOption and StandardWatchEventKind
alanb
parents: 9035
diff changeset
   645
                .contains(StandardWatchEventKinds.ENTRY_MODIFY);
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   646
            if (newModifyEnabled != oldModifyEnabled) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   647
                UnixException ex = null;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   648
                for (EntryNode node: key.children().values()) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   649
                    if (newModifyEnabled) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   650
                        // register
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   651
                        UnixPath path = key.getDirectory().resolve(node.name());
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   652
                        int ev = (FILE_NOFOLLOW | FILE_MODIFIED | FILE_ATTRIB);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   653
                        try {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   654
                            long object = registerImpl(path, ev);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   655
                            object2Node.put(object, node);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   656
                            node.setObject(object);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   657
                        } catch (UnixException x) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   658
                            // if file has been deleted then it will be detected
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   659
                            // as a FILE_MODIFIED event on the directory
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   660
                            if (x.errno() != ENOENT) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   661
                                ex = x;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   662
                                break;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   663
                            }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   664
                        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   665
                    } else {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   666
                        // unregister
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   667
                        releaseChild(node);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   668
                    }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   669
                }
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   670
21278
ef8a3a2a72f2 8022746: List of spelling errors in API doc
malenkov
parents: 13579
diff changeset
   671
                // an error occurred
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   672
                if (ex != null) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   673
                    releaseChildren(key);
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   674
                    throw ex;
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   675
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   676
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   677
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   678
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   679
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   680
         * Calls port_associate to register the given path.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   681
         * Returns pointer to fileobj structure that is allocated for
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   682
         * the registration.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   683
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   684
        long registerImpl(UnixPath dir, int events)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   685
            throws UnixException
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   686
        {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   687
            // allocate memory for the path (file_obj->fo_name field)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   688
            byte[] path = dir.getByteArrayForSysCalls();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   689
            int len = path.length;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   690
            long name = unsafe.allocateMemory(len+1);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   691
            unsafe.copyMemory(path, Unsafe.ARRAY_BYTE_BASE_OFFSET, null,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   692
                name, (long)len);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   693
            unsafe.putByte(name + len, (byte)0);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   694
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   695
            // allocate memory for filedatanode structure - this is the object
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   696
            // to port_associate
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   697
            long object = unsafe.allocateMemory(SIZEOF_FILEOBJ);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   698
            unsafe.setMemory(null, object, SIZEOF_FILEOBJ, (byte)0);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   699
            unsafe.putAddress(object + OFFSET_FO_NAME, name);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   700
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   701
            // associate the object with the port
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   702
            try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   703
                portAssociate(port,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   704
                              PORT_SOURCE_FILE,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   705
                              object,
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   706
                              events);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   707
            } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   708
                // debugging
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   709
                if (x.errno() == EAGAIN) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   710
                    System.err.println("The maximum number of objects associated "+
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   711
                        "with the port has been reached");
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   712
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   713
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   714
                unsafe.freeMemory(name);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   715
                unsafe.freeMemory(object);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   716
                throw x;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   717
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   718
            return object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   719
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   720
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   721
        /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   722
         * Frees all resources for an file_obj object; optionally remove
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   723
         * association from port
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   724
         */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   725
        void releaseObject(long object, boolean dissociate) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   726
            // remove association
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   727
            if (dissociate) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   728
                try {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   729
                    portDissociate(port, PORT_SOURCE_FILE, object);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   730
                } catch (UnixException x) {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   731
                    // ignore
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   732
                }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   733
            }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   734
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   735
            // free native memory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   736
            long name = unsafe.getAddress(object + OFFSET_FO_NAME);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   737
            unsafe.freeMemory(name);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   738
            unsafe.freeMemory(object);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   739
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   740
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   741
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   742
    /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   743
     * A node with native (file_obj) resources
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   744
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   745
    private static interface Node {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   746
        long object();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   747
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   748
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   749
    /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   750
     * A directory node with a map of the entries in the directory
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   751
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   752
    private static interface DirectoryNode extends Node {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   753
        void addChild(Path name, EntryNode node);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   754
        void removeChild(Path name);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   755
        EntryNode getChild(Path name);
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   756
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   757
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   758
    /**
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   759
     * An implementation of a node that is an entry in a directory.
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   760
     */
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   761
    private static class EntryNode implements Node {
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   762
        private long object;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   763
        private final UnixPath name;
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   764
        private final DirectoryNode parent;
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   765
        private boolean visited;
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   766
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   767
        EntryNode(long object, UnixPath name, DirectoryNode parent) {
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   768
            this.object = object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   769
            this.name = name;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   770
            this.parent = parent;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   771
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   772
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   773
        @Override
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   774
        public long object() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   775
            return object;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   776
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   777
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   778
        void setObject(long ptr) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   779
            this.object = ptr;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   780
        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   781
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   782
        UnixPath name() {
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   783
            return name;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   784
        }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   785
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   786
        DirectoryNode parent() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   787
            return parent;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   788
        }
13579
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   789
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   790
        boolean isVisited() {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   791
            return visited;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   792
        }
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   793
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   794
        void setVisited(boolean v) {
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   795
            this.visited = v;
e5a8ca9244e1 7191467: (fs) WatchService periodically fails to queue ENTRY_DELETE event for short lived file [sol11]
alanb
parents: 13246
diff changeset
   796
        }
2057
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   797
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   798
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   799
    // -- native methods --
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   800
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   801
    private static native void init();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   802
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   803
    private static native int portCreate() throws UnixException;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   804
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   805
    private static native void portAssociate(int port, int source, long object, int events)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   806
        throws UnixException;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   807
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   808
    private static native void portDissociate(int port, int source, long object)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   809
        throws UnixException;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   810
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   811
    private static native void portSend(int port, int events)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   812
        throws UnixException;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   813
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   814
    private static native int portGetn(int port, long address, int max)
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   815
        throws UnixException;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   816
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   817
    static {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   818
        AccessController.doPrivileged(new PrivilegedAction<Void>() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   819
            public Void run() {
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   820
                System.loadLibrary("nio");
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   821
                return null;
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   822
        }});
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   823
        init();
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   824
    }
3acf8e5e2ca0 6781363: New I/O: Update socket-channel API to jsr203/nio2-b99
alanb
parents:
diff changeset
   825
}