diff plugins/napster.c @ 1444:55f67ef24683

[gaim-migrate @ 1454] Downloading actually works for clients other than gnapster. I guesss that I, technically, discovered a "bug" in gnapster. Although its not REAALLY a bug. It just doesnt exactly follow the specs properly :). Anyway, progress bars when downloading, too. They're ugly but they work. Ill make them pretty once I'm finished. committer: Tailor Script <tailor@pidgin.im>
author Rob Flynn <gaim@robflynn.com>
date Mon, 29 Jan 2001 09:21:54 +0000
parents 336fc98b7f90
children 13bbf7b8f920
line wrap: on
line diff
--- a/plugins/napster.c	Mon Jan 29 02:53:40 2001 +0000
+++ b/plugins/napster.c	Mon Jan 29 09:21:54 2001 +0000
@@ -81,6 +81,10 @@
 	int status;
 	int inpa;
 	FILE *mp3;
+	GtkWidget *window;
+	GtkWidget *progress;
+	GtkWidget *ok;
+	GtkWidget *cancel;
 };
 
 struct nap_data {
@@ -118,10 +122,10 @@
 	unsigned short size;
 
 	size = strlen(message);
-
 	write(ndata->fd, &size, 2);
 	write(ndata->fd, &command, 2);
 	write(ndata->fd, message, size);
+
 }
 
 void nap_send_download_req(struct gaim_connection *gc, char *who, char *file)
@@ -338,7 +342,10 @@
 		long filesize;
 		gchar **parse_name;
 		gchar path[2048];
-
+		GtkWidget *hbox;
+		GtkWidget *vbox;
+		GtkWidget *label;
+		gchar *buf2;
 
 		recv(source, buf, 1, 0);
 
@@ -403,6 +410,36 @@
 		g_strfreev(parse_name);
 		
 		req->mp3 = fopen(path, "w");
+
+		req->window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
+
+		vbox = gtk_vbox_new(FALSE, 5);
+
+		buf2 = (gchar *)g_malloc(sizeof(gchar) * (strlen(req->file) + 33));
+		g_snprintf(buf2, strlen(req->file) + 32, "Downloading File: %s", req->file);
+		label = gtk_label_new(buf2);
+		gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 5);
+
+		req->progress = gtk_progress_bar_new();
+		gtk_progress_bar_update(GTK_PROGRESS_BAR(req->progress), 0);
+		gtk_progress_set_format_string(GTK_PROGRESS(req->progress), "%P %%");
+		gtk_progress_set_show_text(GTK_PROGRESS(req->progress), TRUE);
+		gtk_box_pack_start(GTK_BOX(vbox), req->progress, FALSE, FALSE, 5);
+
+		hbox = gtk_hbox_new(TRUE, 5);
+	
+		req->ok = gtk_button_new_with_label("Ok");
+		req->cancel = gtk_button_new_with_label("Cancel");
+
+		gtk_box_pack_end(GTK_BOX(hbox), req->cancel, FALSE, FALSE, 5);
+		gtk_box_pack_end(GTK_BOX(hbox), req->ok, FALSE, FALSE, 5);
+		
+		gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 5);
+
+		gtk_container_add(GTK_CONTAINER(req->window), vbox);
+		
+		gtk_widget_show_all(req->window);
+		
 		free(buf);
 		return;
 	}
@@ -412,7 +449,12 @@
 
 	req->size += i; /* Lets add up the total */
 
-	printf("Downloaded %ld of %ld\n", req->size, req->total);
+//	printf("Downloaded %ld of %ld (%f)\n", req->size, req->total, (float)req->size/(float)req->total);
+	
+	gtk_progress_bar_update(GTK_PROGRESS_BAR(req->progress), (float)req->size/(float)req->total);
+
+	while (gtk_events_pending())
+		gtk_main_iteration();
 
 	fwrite(buf, i, sizeof(char), req->mp3);
 
@@ -422,9 +464,15 @@
 		printf("Download complete.\n");
 		nap_write_packet(gc, 0xdb, "\n"); /* Tell the server we're finished */
 		gdk_input_remove(req->inpa);
+
 		ndata->requests = g_slist_remove(ndata->requests, req);
-		g_free(req->name);
-		g_free(req->file);
+
+		if (req->name != NULL)
+			g_free(req->name);
+
+		if (req->file != NULL)
+			g_free(req->file);
+
 		g_free(req);
 		fclose(req->mp3);
 		close(source);
@@ -465,9 +513,12 @@
 	req->status = 0;
 	req->total = 0;
 
+	send(fd, "GET", 3, 0);
+
 	/* Send our request to the user */
-	g_snprintf(buf, sizeof(buf), "GET%s \"%s\" 0\n", user, file);
-	write(fd, buf, strlen(buf));
+	g_snprintf(buf, sizeof(buf), "%s \"%s\" 0",gc->username, file);
+
+	send(fd, buf, strlen(buf), 0);
 
 	/* Add our request */
 	ndata->requests = g_slist_append(ndata->requests, req);
@@ -845,7 +896,7 @@
 	int i;
 	int status;
 
-	host = gethostbyname("208.184.216.87");
+	host = gethostbyname("64.124.41.175");
 
 	if (!host) {
 		hide_login_progress(gc, "Unable to resolve hostname");