//var XObject = imports.XObject.XObject;
//var File = imports.File.File;
-
+/// # valac --pkg gee-0.8 --pkg gio-2.0 --pkg posix Monitor.val
using Gee; // for array list?
}
-class MonitorNamePathDir {
+public class MonitorNamePathDir {
public string name;
public string path;
this.paused = false;
}
- public ArrayList<FileMonitor> monitors;// Array of GioFileMonitors
+ public ArrayList<FileMonitor> monitors;// Array of MonitorNamePathDirileMonitors
public ArrayList<string> top; // list of top level directories..
public bool paused;
/**
if (depth > 0) {
var fm = f.monitor(FileMonitorFlags.SEND_MOVED,null); //Gio.FileMonitorFlags.SEND_MOVED
- fm.changed.connect(onEvent);
+ fm.changed.connect( ( fm, f_orig, of_orig, event_type) => {
+ this.onEvent (fm, f_orig, of_orig, event_type ) ;
+ });
this.monitors.add(fm);
// print("ADD path " + depth + ' ' + path);
}
// FIX ME - string split?/?
var bn = file.get_basename();
- var ar = file.get_path().to_string().split('/');
- ar.pop();
- var dirname = ar.join('/');
+ var ar = file.get_path().split("/");
+ ar.resize(ar.length-1);
+ var dirname = string.joinv("/",ar );
var rp = Posix.realpath(dirname);
- return File.new_for_path(rp + '/' + bn);
+ return File.new_for_path(rp + "/" + bn);
}
- MonitorNamePathDir src = new MonitorNamePathDir( f.get_basename(), f.get_path() , GLib.path_get_dirname(f.get_path()));
+ MonitorNamePathDir src = new MonitorNamePathDir( f.get_basename(), f.get_path() , Path.get_dirname(f.get_path()));
MonitorNamePathDir dest = null;
- if (of) {
- dest = new MonitorNamePathDir( of.get_basename(), of.get_path(), GLib.path_get_dirname(of.get_path()));
+ if (of != null) {
+ dest = new MonitorNamePathDir( of.get_basename(), of.get_path(), Path.get_dirname(of.get_path()));
}
string event_name = "UKNOWN";
try {
switch(event_type) {
- case Gio.FileMonitorEvent.CHANGED:
+ case FileMonitorEvent.CHANGED:
this.onChanged(src);
return; // ingore thise?? -wait for changes_done_htin?
- case Gio.FileMonitorEvent.CHANGES_DONE_HINT:
+ case FileMonitorEvent.CHANGES_DONE_HINT:
this.onChangesDoneHint(src);
return;
- case Gio.FileMonitorEvent.DELETED:
+ case FileMonitorEvent.DELETED:
this.onDeleted(src);
return;
- case Gio.FileMonitorEvent.CREATED:
+ case FileMonitorEvent.CREATED:
this.onCreated(src);
return;
- case Gio.FileMonitorEvent.ATTRIBUTE_CHANGED: // eg. chmod/chatt
+ case FileMonitorEvent.ATTRIBUTE_CHANGED: // eg. chmod/chatt
this.onAttributeChanged(src);
return;
- case Gio.FileMonitorEvent.MOVED: // eg. chmod/chatt
+ case FileMonitorEvent.MOVED: // eg. chmod/chatt
this.onMoved(src,dest);
return;
public void onDeleted(MonitorNamePathDir src) { }
public void onCreated(MonitorNamePathDir src) { }
public void onAttributeChanged(MonitorNamePathDir src) { }
- public void onMoved(MonitorNamePathDir src) { }
+ public void onMoved(MonitorNamePathDir src,MonitorNamePathDir dest) { }
}