This file is indexed.

/usr/include/libfm-qt/job.h is in libfm-qt-dev 0.11.2-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
/*
 * Copyright (C) 2016 Hong Jen Yee (PCMan) <pcman.tw@gmail.com>
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 *
 */

#ifndef __LIBFM_QT_FM_JOB_H__
#define __LIBFM_QT_FM_JOB_H__

#include <libfm/fm.h>
#include <QObject>
#include <QtGlobal>
#include "libfmqtglobals.h"


namespace Fm {


class LIBFM_QT_API Job {
public:


  // default constructor
  Job() {
    dataPtr_ = nullptr;
  }


  Job(FmJob* dataPtr){
    dataPtr_ = dataPtr != nullptr ? reinterpret_cast<GObject*>(g_object_ref(dataPtr)) : nullptr;
  }


  // copy constructor
  Job(const Job& other) {
    dataPtr_ = other.dataPtr_ != nullptr ? reinterpret_cast<GObject*>(g_object_ref(other.dataPtr_)) : nullptr;
  }


  // move constructor
  Job(Job&& other) {
    dataPtr_ = reinterpret_cast<GObject*>(other.takeDataPtr());
  }


  // destructor
  virtual ~Job() {
    if(dataPtr_ != nullptr) {
      g_object_unref(dataPtr_);
    }
  }


  // create a wrapper for the data pointer without increasing the reference count
  static Job wrapPtr(FmJob* dataPtr) {
    Job obj;
    obj.dataPtr_ = reinterpret_cast<GObject*>(dataPtr);
    return obj;
  }

  // disown the managed data pointer
  FmJob* takeDataPtr() {
    FmJob* data = reinterpret_cast<FmJob*>(dataPtr_);
    dataPtr_ = nullptr;
    return data;
  }

  // get the raw pointer wrapped
  FmJob* dataPtr() {
    return reinterpret_cast<FmJob*>(dataPtr_);
  }

  // automatic type casting
  operator FmJob*() {
    return dataPtr();
  }

  // automatic type casting
  operator void*() {
    return dataPtr();
  }


  // copy assignment
  Job& operator=(const Job& other) {
    if(dataPtr_ != nullptr) {
      g_object_unref(dataPtr_);
    }
    dataPtr_ = other.dataPtr_ != nullptr ? reinterpret_cast<GObject*>(g_object_ref(other.dataPtr_)) : nullptr;
    return *this;
  }


  // move assignment
  Job& operator=(Job&& other) {
    dataPtr_ = reinterpret_cast<GObject*>(other.takeDataPtr());
    return *this;
  }

  bool isNull() {
    return (dataPtr_ == nullptr);
  }

  // methods

  void resume(void) {
    fm_job_resume(dataPtr());
  }


  bool pause(void) {
    return fm_job_pause(dataPtr());
  }


  int askValist(const char* question, va_list options) {
    return fm_job_ask_valist(dataPtr(), question, options);
  }


  int askv(const char* question, gchar* const* options) {
    return fm_job_askv(dataPtr(), question, options);
  }


  int ask(const char* question, ... ) {
    
    int ret;
    va_list args;
    va_start (args, question);
    ret = fm_job_ask_valist(dataPtr(), question, args);
    va_end (args);
    return ret;

  }


  FmJobErrorAction emitError(GError* err, FmJobErrorSeverity severity) {
    return fm_job_emit_error(dataPtr(), err, severity);
  }


  void finish(void) {
    fm_job_finish(dataPtr());
  }


  void setCancellable(GCancellable* cancellable) {
    fm_job_set_cancellable(dataPtr(), cancellable);
  }


  GCancellable* getCancellable(void) {
    return fm_job_get_cancellable(dataPtr());
  }


  void initCancellable(void) {
    fm_job_init_cancellable(dataPtr());
  }


  gpointer callMainThread(FmJobCallMainThreadFunc func, gpointer user_data) {
    return fm_job_call_main_thread(dataPtr(), func, user_data);
  }


  void cancel(void) {
    fm_job_cancel(dataPtr());
  }


  bool runSyncWithMainloop(void) {
    return fm_job_run_sync_with_mainloop(dataPtr());
  }


  bool runSync(void) {
    return fm_job_run_sync(dataPtr());
  }


  bool runAsync(void) {
    return fm_job_run_async(dataPtr());
  }


  bool isRunning(void) {
    return fm_job_is_running(dataPtr());
  }


  bool isCancelled(void) {
    return fm_job_is_cancelled(dataPtr());
  }


  // automatic type casting for GObject
  operator GObject*() {
    return reinterpret_cast<GObject*>(dataPtr_);
  }


protected:
  GObject* dataPtr_; // data pointer for the underlying C struct

};


}

#endif // __LIBFM_QT_FM_JOB_H__