merged from lp:~donkult/apt/sid
[apt.git] / apt-pkg / cdrom.h
index 608cb0e2fa5fa993785f909691c1c9fdbb413ef9..e83c385829bfc965fb3279ff440118198ac371ce 100644 (file)
@@ -67,4 +67,49 @@ class pkgCdrom                                                               /*{{{*/
 };
                                                                        /*}}}*/
 
+
+// class that uses libudev to find cdrom/removable devices dynamically
+struct CdromDevice                                                     /*{{{*/
+{
+   string DeviceName;
+   bool Mounted;
+   string MountPath;
+};
+                                                                       /*}}}*/
+class pkgUdevCdromDevices                                              /*{{{*/
+{
+ protected:
+   // libudev dlopen stucture
+   void *libudev_handle;
+   struct udev* (*udev_new)(void);
+   int (*udev_enumerate_add_match_property)(struct udev_enumerate *udev_enumerate, const char *property, const char *value);
+   int (*udev_enumerate_scan_devices)(struct udev_enumerate *udev_enumerate);
+   struct udev_list_entry* (*udev_enumerate_get_list_entry)(struct udev_enumerate *udev_enumerate);
+   struct udev_device* (*udev_device_new_from_syspath)(struct udev *udev, const char *syspath);
+   struct udev* (*udev_enumerate_get_udev)(struct udev_enumerate *udev_enumerate);
+   const char* (*udev_list_entry_get_name)(struct udev_list_entry *list_entry);
+   const char* (*udev_device_get_devnode)(struct udev_device *udev_device);
+   struct udev_enumerate *(*udev_enumerate_new) (struct udev *udev);
+   struct udev_list_entry *(*udev_list_entry_get_next)(struct udev_list_entry *list_entry);
+   const char* (*udev_device_get_property_value)(struct udev_device *udev_device, const char *key);
+#if 0 // FIXME: uncomment on next ABI break
+   int (*udev_enumerate_add_match_sysattr)(struct udev_enumerate *udev_enumerate, const char *property, const char *value);
+#endif 
+   // end libudev dlopen
+   
+ public:
+   pkgUdevCdromDevices();
+   virtual ~pkgUdevCdromDevices();
+
+   // try to open 
+   bool Dlopen();
+
+   // this is the new interface
+   vector<CdromDevice> ScanForRemovable(bool CdromOnly);
+   // FIXME: compat with the old interface/API/ABI only
+   vector<CdromDevice> Scan();
+
+};
+                                                                       /*}}}*/
+
 #endif