LinuxFileSystem.java 4.2 KB
Newer Older
1
/*
2
 * Copyright (c) 2008, 2019, Oracle and/or its affiliates. All rights reserved.
3 4 5 6
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
7
 * published by the Free Software Foundation.  Oracle designates this
8
 * particular file as subject to the "Classpath" exception as provided
9
 * by Oracle in the LICENSE file that accompanied this code.
10 11 12 13 14 15 16 17 18 19 20
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
21 22 23
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
 */

package sun.nio.fs;

import java.nio.file.*;
import java.io.IOException;
import java.util.*;
import static sun.nio.fs.LinuxNativeDispatcher.*;

/**
 * Linux implementation of FileSystem
 */

class LinuxFileSystem extends UnixFileSystem {
    LinuxFileSystem(UnixFileSystemProvider provider, String dir) {
        super(provider, dir);
    }

    @Override
    public WatchService newWatchService()
        throws IOException
    {
46 47
        // assume 2.6.13 or newer
        return new LinuxWatchService(this);
48 49 50 51 52 53 54 55
    }


    // lazy initialization of the list of supported attribute views
    private static class SupportedFileFileAttributeViewsHolder {
        static final Set<String> supportedFileAttributeViews =
            supportedFileAttributeViews();
        private static Set<String> supportedFileAttributeViews() {
56 57
            Set<String> result = new HashSet<>();
            result.addAll(standardFileAttributeViews());
58 59
            // additional Linux-specific views
            result.add("dos");
60
            result.add("user");
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
            return Collections.unmodifiableSet(result);
        }
    }

    @Override
    public Set<String> supportedFileAttributeViews() {
        return SupportedFileFileAttributeViewsHolder.supportedFileAttributeViews;
    }

    @Override
    void copyNonPosixAttributes(int ofd, int nfd) {
        LinuxUserDefinedFileAttributeView.copyExtendedAttributes(ofd, nfd);
    }

    /**
76
     * Returns object to iterate over the mount entries in the given fstab file.
77
     */
78
    List<UnixMountEntry> getMountEntries(String fstab) {
79
        ArrayList<UnixMountEntry> entries = new ArrayList<>();
80
        try {
81
            long fp = setmntent(Util.toBytes(fstab), Util.toBytes("r"));
82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
            int maxLineSize = 1024;
            try {
                for (;;) {
                    int lineSize = getlinelen(fp);
                    if (lineSize == -1)
                        break;
                    if (lineSize > maxLineSize)
                        maxLineSize = lineSize;
                }
            } catch (UnixException x) {
                // nothing we need to do
            } finally {
                rewind(fp);
            }

97 98 99
            try {
                for (;;) {
                    UnixMountEntry entry = new UnixMountEntry();
100 101
                    // count in NUL character at the end
                    int res = getmntent(fp, entry, maxLineSize + 1);
102 103 104 105 106 107 108 109 110 111 112 113 114 115
                    if (res < 0)
                        break;
                    entries.add(entry);
                }
            } finally {
                endmntent(fp);
            }

        } catch (UnixException x) {
            // nothing we can do
        }
        return entries;
    }

116 117 118 119
    /**
     * Returns object to iterate over the mount entries in /etc/mtab
     */
    @Override
120
    List<UnixMountEntry> getMountEntries() {
121 122 123
        return getMountEntries("/etc/mtab");
    }

124

125 126 127 128 129 130

    @Override
    FileStore getFileStore(UnixMountEntry entry) throws IOException {
        return new LinuxFileStore(this, entry);
    }
}