private dynamic DBus.Object server;
List<MovieSource> sources;
private weak Osso.Context osso_context;
- private Gtk.Window _window;
public override void hello (Gtk.Window window, Osso.Context context) {
string filename = Path.build_filename (Environment.get_user_cache_dir(),
sources.append (source);
osso_context = context;
- _window = window;
// FIXME - this forces the inclusion of config.h
(void) Config.GETTEXT_PACKAGE;
return sources;
}
- public override List<MovieAction> get_actions (Movie movie) {
+ public override List<MovieAction> get_actions (Movie movie, Gtk.Window window) {
List<MovieAction> list = null;
if (movie.year > 0)
- list.append (new MovieAction (_("IMDb page"), on_visit_imdb, movie));
+ list.append (new MovieAction (_("IMDb page"), on_visit_imdb, movie, window));
else
- list.append (new MovieAction (_("Lookup on IMDb"), on_visit_imdb, movie));
+ list.append (new MovieAction (_("Lookup on IMDb"), on_visit_imdb, movie, window));
return list;
}
- private void on_visit_imdb (Movie movie) {
+ private void on_visit_imdb (Movie movie, Gtk.Window window) {
var url = "http://www.imdb.com/find?s=tt&q=" + movie.title.replace(" ", "+");
if (movie.year > 0)
url += "+(%d)".printf (movie.year);
var status = osso_context.rpc_run_with_defaults ("osso_browser", "open_new_window", null, 's', url, 'b', false);
if (status != Osso.Status.OK) {
- var banner = (Banner) Hildon.Banner.show_information_with_markup (_window, null, "Failed to open browser.");
+ var banner = (Banner) Hildon.Banner.show_information_with_markup (window, null, "Failed to open browser.");
banner.set_timeout (1500);
}
}
}
class IMDBSource : MovieSource {
+ public override bool active { get; set construct; }
+
+ public IMDBSource () {
+ GLib.Object (active: true);
+ }
+
MovieSource.ReceiveMovieFunction _get_callback;
public override async void get_movies (MovieFilter filter, MovieSource.ReceiveMovieFunction callback, int limit, Cancellable? cancellable) {
// IMDb has too many movies
- if (filter.title == "")
+ if (filter.title == "" && filter.year_min == 0 && filter.year_max == 0 && filter.genres.field == 0 && filter.rating_min == 0)
return;
var sqlite = new IMDbSqlite (Path.build_filename (Environment.get_user_cache_dir (),
"cinaest", "imdb.db", null));
_get_callback = callback;
- yield sqlite.query (filter, receive_movie, cancellable);
+ yield sqlite.query (filter, receive_movie, limit, cancellable);
}
- private void receive_movie (string title, int year, int rating, int genres) {
+ private void receive_movie (string title, string? aka, int year, int rating, int genres) {
Movie movie = new Movie ();
movie.title = title;
movie.year = year;
movie.rating = rating;
movie.genres.field = genres;
// TODO - depending on settings, this could be something else, like director info or runtime
- movie.secondary = movie.genres.to_string ();
+ if (aka != null) {
+ movie.secondary = "aka \"%s\" - %s".printf (aka, movie.genres.to_string ());
+ } else {
+ movie.secondary = movie.genres.to_string ();
+ }
_get_callback (movie);
}
public override void add_movie (Movie movie) {
}
+ public override void delete_movie (Movie movie) {
+ }
+
public override unowned string get_name () {
return "IMDb";
}
public override unowned string get_description () {
return "Movies on IMDb";
}
+
+ public override bool get_editable () {
+ return false;
+ }
}
[ModuleInit]