1a5d2f2bea179a0b7becb33faae9c0ff4cab5d80
[harmattan/cameraplus] / src / fsmonitor.cpp
1 /*!
2  * This file is part of CameraPlus.
3  *
4  * Copyright (C) 2012 Mohammed Sameer <msameer@foolab.org>
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
19  */
20
21 #include "fsmonitor.h"
22 #include <qmusbmode.h>
23 #include <sys/statvfs.h>
24 #include <cstdio>
25
26 #define MIN_SPACE 100 * 1024 * 1024 // 100 MB
27
28 FSMonitor::FSMonitor(QObject *parent) :
29   QObject(parent), m_mode(new MeeGo::QmUSBMode(this)) {
30
31   QObject::connect(m_mode, SIGNAL(modeChanged(MeeGo::QmUSBMode::Mode)),
32                    this, SLOT(modeChanged()));
33
34   m_available =
35     m_mode->mountStatus(MeeGo::QmUSBMode::DocumentDirectoryMount)
36     .testFlag(MeeGo::QmUSBMode::ReadWriteMount);
37 }
38
39 FSMonitor::~FSMonitor() {
40
41 }
42
43 bool FSMonitor::isAvailable() const {
44   return m_available;
45 }
46
47 void FSMonitor::setAvailable(bool available) {
48   if (m_available != available) {
49     m_available = available;
50     emit availabilityChanged();
51   }
52 }
53
54 void FSMonitor::modeChanged() {
55   setAvailable(m_mode->mountStatus(MeeGo::QmUSBMode::DocumentDirectoryMount)
56                .testFlag(MeeGo::QmUSBMode::ReadWriteMount));
57 }
58
59 bool FSMonitor::hasFreeSpace(const QString& path) {
60   struct statvfs buf;
61
62   if (statvfs(path.toLocal8Bit().data(), &buf) == -1) {
63     std::perror("statvfs");
64     return false;
65   }
66
67   // If the user has a lot of free space (8 GB for example)
68   // then we will overflow the unsigned long int thus we use a 64 bits "int"
69   quint64 freeSpace = (quint64)buf.f_bsize * (quint64)buf.f_bavail;
70   return (freeSpace >= MIN_SPACE);
71 }