1 /* 2 * This file is part of gtkD. 3 * 4 * gtkD is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU Lesser General Public License 6 * as published by the Free Software Foundation; either version 3 7 * of the License, or (at your option) any later version, with 8 * some exceptions, please read the COPYING file. 9 * 10 * gtkD is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU Lesser General Public License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with gtkD; if not, write to the Free Software 17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA 18 */ 19 20 // generated automatically - do not change 21 // find conversion definition on APILookup.txt 22 // implement new conversion functionalities on the wrap.utils pakage 23 24 25 module gio.UnixMountPoint; 26 27 private import gio.IconIF; 28 private import gio.c.functions; 29 public import gio.c.types; 30 private import glib.Str; 31 private import glib.c.functions; 32 private import gobject.ObjectG; 33 private import gtkd.Loader; 34 35 36 /** 37 * Defines a Unix mount point (e.g. <filename>/dev</filename>). 38 * This corresponds roughly to a fstab entry. 39 */ 40 public class UnixMountPoint 41 { 42 /** the main Gtk struct */ 43 protected GUnixMountPoint* gUnixMountPoint; 44 protected bool ownedRef; 45 46 /** Get the main Gtk struct */ 47 public GUnixMountPoint* getUnixMountPointStruct(bool transferOwnership = false) 48 { 49 if (transferOwnership) 50 ownedRef = false; 51 return gUnixMountPoint; 52 } 53 54 /** the main Gtk struct as a void* */ 55 protected void* getStruct() 56 { 57 return cast(void*)gUnixMountPoint; 58 } 59 60 /** 61 * Sets our main struct and passes it to the parent class. 62 */ 63 public this (GUnixMountPoint* gUnixMountPoint, bool ownedRef = false) 64 { 65 this.gUnixMountPoint = gUnixMountPoint; 66 this.ownedRef = ownedRef; 67 } 68 69 ~this () 70 { 71 if ( Linker.isLoaded(LIBRARY_GIO) && ownedRef ) 72 g_unix_mount_point_free(gUnixMountPoint); 73 } 74 75 76 /** */ 77 public static GType getType() 78 { 79 return g_unix_mount_point_get_type(); 80 } 81 82 /** 83 * Compares two unix mount points. 84 * 85 * Params: 86 * mount2 = a #GUnixMount. 87 * 88 * Returns: 1, 0 or -1 if @mount1 is greater than, equal to, 89 * or less than @mount2, respectively. 90 */ 91 public int compare(UnixMountPoint mount2) 92 { 93 return g_unix_mount_point_compare(gUnixMountPoint, (mount2 is null) ? null : mount2.getUnixMountPointStruct()); 94 } 95 96 /** 97 * Makes a copy of @mount_point. 98 * 99 * Returns: a new #GUnixMountPoint 100 * 101 * Since: 2.54 102 */ 103 public UnixMountPoint copy() 104 { 105 auto __p = g_unix_mount_point_copy(gUnixMountPoint); 106 107 if(__p is null) 108 { 109 return null; 110 } 111 112 return ObjectG.getDObject!(UnixMountPoint)(cast(GUnixMountPoint*) __p, true); 113 } 114 115 /** 116 * Frees a unix mount point. 117 */ 118 public void free() 119 { 120 g_unix_mount_point_free(gUnixMountPoint); 121 ownedRef = false; 122 } 123 124 /** 125 * Gets the device path for a unix mount point. 126 * 127 * Returns: a string containing the device path. 128 */ 129 public string getDevicePath() 130 { 131 return Str.toString(g_unix_mount_point_get_device_path(gUnixMountPoint)); 132 } 133 134 /** 135 * Gets the file system type for the mount point. 136 * 137 * Returns: a string containing the file system type. 138 */ 139 public string getFsType() 140 { 141 return Str.toString(g_unix_mount_point_get_fs_type(gUnixMountPoint)); 142 } 143 144 /** 145 * Gets the mount path for a unix mount point. 146 * 147 * Returns: a string containing the mount path. 148 */ 149 public string getMountPath() 150 { 151 return Str.toString(g_unix_mount_point_get_mount_path(gUnixMountPoint)); 152 } 153 154 /** 155 * Gets the options for the mount point. 156 * 157 * Returns: a string containing the options. 158 * 159 * Since: 2.32 160 */ 161 public string getOptions() 162 { 163 return Str.toString(g_unix_mount_point_get_options(gUnixMountPoint)); 164 } 165 166 /** 167 * Guesses whether a Unix mount point can be ejected. 168 * 169 * Returns: %TRUE if @mount_point is deemed to be ejectable. 170 */ 171 public bool guessCanEject() 172 { 173 return g_unix_mount_point_guess_can_eject(gUnixMountPoint) != 0; 174 } 175 176 /** 177 * Guesses the icon of a Unix mount point. 178 * 179 * Returns: a #GIcon 180 */ 181 public IconIF guessIcon() 182 { 183 auto __p = g_unix_mount_point_guess_icon(gUnixMountPoint); 184 185 if(__p is null) 186 { 187 return null; 188 } 189 190 return ObjectG.getDObject!(IconIF)(cast(GIcon*) __p, true); 191 } 192 193 /** 194 * Guesses the name of a Unix mount point. 195 * The result is a translated string. 196 * 197 * Returns: A newly allocated string that must 198 * be freed with g_free() 199 */ 200 public string guessName() 201 { 202 auto retStr = g_unix_mount_point_guess_name(gUnixMountPoint); 203 204 scope(exit) Str.freeString(retStr); 205 return Str.toString(retStr); 206 } 207 208 /** 209 * Guesses the symbolic icon of a Unix mount point. 210 * 211 * Returns: a #GIcon 212 * 213 * Since: 2.34 214 */ 215 public IconIF guessSymbolicIcon() 216 { 217 auto __p = g_unix_mount_point_guess_symbolic_icon(gUnixMountPoint); 218 219 if(__p is null) 220 { 221 return null; 222 } 223 224 return ObjectG.getDObject!(IconIF)(cast(GIcon*) __p, true); 225 } 226 227 /** 228 * Checks if a unix mount point is a loopback device. 229 * 230 * Returns: %TRUE if the mount point is a loopback. %FALSE otherwise. 231 */ 232 public bool isLoopback() 233 { 234 return g_unix_mount_point_is_loopback(gUnixMountPoint) != 0; 235 } 236 237 /** 238 * Checks if a unix mount point is read only. 239 * 240 * Returns: %TRUE if a mount point is read only. 241 */ 242 public bool isReadonly() 243 { 244 return g_unix_mount_point_is_readonly(gUnixMountPoint) != 0; 245 } 246 247 /** 248 * Checks if a unix mount point is mountable by the user. 249 * 250 * Returns: %TRUE if the mount point is user mountable. 251 */ 252 public bool isUserMountable() 253 { 254 return g_unix_mount_point_is_user_mountable(gUnixMountPoint) != 0; 255 } 256 257 /** 258 * Gets a #GUnixMountPoint for a given mount path. If @time_read is set, it 259 * will be filled with a unix timestamp for checking if the mount points have 260 * changed since with g_unix_mount_points_changed_since(). 261 * 262 * If more mount points have the same mount path, the last matching mount point 263 * is returned. 264 * 265 * Params: 266 * mountPath = path for a possible unix mount point. 267 * timeRead = guint64 to contain a timestamp. 268 * 269 * Returns: a #GUnixMountPoint, or %NULL if no match 270 * is found. 271 * 272 * Since: 2.66 273 */ 274 public static UnixMountPoint at(string mountPath, out ulong timeRead) 275 { 276 auto __p = g_unix_mount_point_at(Str.toStringz(mountPath), &timeRead); 277 278 if(__p is null) 279 { 280 return null; 281 } 282 283 return ObjectG.getDObject!(UnixMountPoint)(cast(GUnixMountPoint*) __p, true); 284 } 285 }