1 /*
2  * Copyright (C) 2007 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package android.os;
18 
19 import android.compat.annotation.UnsupportedAppUsage;
20 import android.system.ErrnoException;
21 import android.system.Os;
22 import android.system.StructStatVfs;
23 
24 /**
25  * Retrieve overall information about the space on a filesystem. This is a
26  * wrapper for Unix statvfs().
27  */
28 public class StatFs {
29     @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.R, trackingBug = 170729553)
30     private StructStatVfs mStat;
31 
32     /**
33      * Construct a new StatFs for looking at the stats of the filesystem at
34      * {@code path}. Upon construction, the stat of the file system will be
35      * performed, and the values retrieved available from the methods on this
36      * class.
37      *
38      * @param path path in the desired file system to stat.
39      *
40      * @throws IllegalArgumentException if the file system access fails
41      */
StatFs(String path)42     public StatFs(String path) {
43         mStat = doStat(path);
44     }
45 
46     /**
47      * @throws IllegalArgumentException if the file system access fails
48      */
doStat(String path)49     private static StructStatVfs doStat(String path) {
50         try {
51             return Os.statvfs(path);
52         } catch (ErrnoException e) {
53             throw new IllegalArgumentException("Invalid path: " + path, e);
54         }
55     }
56 
57     /**
58      * Perform a restat of the file system referenced by this object. This is
59      * the same as re-constructing the object with the same file system path,
60      * and the new stat values are available upon return.
61      *
62      * @throws IllegalArgumentException if the file system access fails
63      */
restat(String path)64     public void restat(String path) {
65         mStat = doStat(path);
66     }
67 
68     /**
69      * @deprecated Use {@link #getBlockSizeLong()} instead.
70      */
71     @Deprecated
getBlockSize()72     public int getBlockSize() {
73         return (int) mStat.f_frsize;
74     }
75 
76     /**
77      * The size, in bytes, of a block on the file system. This corresponds to
78      * the Unix {@code statvfs.f_frsize} field.
79      */
getBlockSizeLong()80     public long getBlockSizeLong() {
81         return mStat.f_frsize;
82     }
83 
84     /**
85      * @deprecated Use {@link #getBlockCountLong()} instead.
86      */
87     @Deprecated
getBlockCount()88     public int getBlockCount() {
89         return (int) mStat.f_blocks;
90     }
91 
92     /**
93      * The total number of blocks on the file system. This corresponds to the
94      * Unix {@code statvfs.f_blocks} field.
95      */
getBlockCountLong()96     public long getBlockCountLong() {
97         return mStat.f_blocks;
98     }
99 
100     /**
101      * @deprecated Use {@link #getFreeBlocksLong()} instead.
102      */
103     @Deprecated
getFreeBlocks()104     public int getFreeBlocks() {
105         return (int) mStat.f_bfree;
106     }
107 
108     /**
109      * The total number of blocks that are free on the file system, including
110      * reserved blocks (that are not available to normal applications). This
111      * corresponds to the Unix {@code statvfs.f_bfree} field. Most applications
112      * will want to use {@link #getAvailableBlocksLong()} instead.
113      */
getFreeBlocksLong()114     public long getFreeBlocksLong() {
115         return mStat.f_bfree;
116     }
117 
118     /**
119      * The number of bytes that are free on the file system, including reserved
120      * blocks (that are not available to normal applications). Most applications
121      * will want to use {@link #getAvailableBytes()} instead.
122      */
getFreeBytes()123     public long getFreeBytes() {
124         return mStat.f_bfree * mStat.f_frsize;
125     }
126 
127     /**
128      * @deprecated Use {@link #getAvailableBlocksLong()} instead.
129      */
130     @Deprecated
getAvailableBlocks()131     public int getAvailableBlocks() {
132         return (int) mStat.f_bavail;
133     }
134 
135     /**
136      * The number of blocks that are free on the file system and available to
137      * applications. This corresponds to the Unix {@code statvfs.f_bavail} field.
138      */
getAvailableBlocksLong()139     public long getAvailableBlocksLong() {
140         return mStat.f_bavail;
141     }
142 
143     /**
144      * The number of bytes that are free on the file system and available to
145      * applications.
146      */
getAvailableBytes()147     public long getAvailableBytes() {
148         return mStat.f_bavail * mStat.f_frsize;
149     }
150 
151     /**
152      * The total number of bytes supported by the file system.
153      */
getTotalBytes()154     public long getTotalBytes() {
155         return mStat.f_blocks * mStat.f_frsize;
156     }
157 }
158