mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-11-14 23:50:37 +02:00
81f76c5079
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@15901 3c298f89-4303-0410-b956-a3cf2f4a3e73
106 lines
3.2 KiB
Plaintext
106 lines
3.2 KiB
Plaintext
diff -urN opkg-4993/configure.ac opkg-4993.new/configure.ac
|
|
--- opkg-4993/configure.ac 2009-05-17 18:15:52.000000000 +0200
|
|
+++ opkg-4993.new/configure.ac 2009-05-17 18:17:09.000000000 +0200
|
|
@@ -26,9 +26,16 @@
|
|
|
|
# Checks for libraries
|
|
|
|
-# check for libcurl
|
|
-PKG_CHECK_MODULES(CURL, libcurl)
|
|
+AC_ARG_ENABLE(curl,
|
|
+ AC_HELP_STRING([--enable-curl], [Enable use of libcurl instead of wget
|
|
+ [[default=yes]] ]),
|
|
+ [want_curl="$enableval"], [want_curl="yes"])
|
|
|
|
+if test "x$want_curl" = "xyes"; then
|
|
+ # check for libcurl
|
|
+ PKG_CHECK_MODULES(CURL, libcurl)
|
|
+ AC_DEFINE(HAVE_CURL, 1, [Define if you want to use libcurl instead of wget])
|
|
+fi
|
|
|
|
|
|
dnl **********
|
|
diff -urN opkg-4993/libopkg/opkg.c opkg-4993.new/libopkg/opkg.c
|
|
--- opkg-4993/libopkg/opkg.c 2009-05-17 18:15:50.000000000 +0200
|
|
+++ opkg-4993.new/libopkg/opkg.c 2009-05-17 18:17:09.000000000 +0200
|
|
@@ -1019,8 +1019,9 @@
|
|
|
|
return package;
|
|
}
|
|
-
|
|
+#ifdef HAVE_CURL
|
|
#include <curl/curl.h>
|
|
+#endif
|
|
/**
|
|
* @brief Check the accessibility of repositories. It will try to access the repository to check if the respository is accessible throught current network status.
|
|
* @param opkg The opkg_t
|
|
@@ -1070,6 +1071,7 @@
|
|
repositories--;
|
|
|
|
err = opkg_download(opkg->conf, iter1->data, "/dev/null", NULL, NULL);
|
|
+ #ifdef HAVE_CURL
|
|
if (!(err == CURLE_OK ||
|
|
err == CURLE_HTTP_RETURNED_ERROR ||
|
|
err == CURLE_FILE_COULDNT_READ_FILE ||
|
|
@@ -1078,6 +1080,7 @@
|
|
)) {
|
|
ret++;
|
|
}
|
|
+ #endif
|
|
str_list_elt_deinit(iter1);
|
|
free(iter1);
|
|
}
|
|
diff -urN opkg-4993/libopkg/opkg_download.c opkg-4993.new/libopkg/opkg_download.c
|
|
--- opkg-4993/libopkg/opkg_download.c 2009-05-17 18:15:50.000000000 +0200
|
|
+++ opkg-4993.new/libopkg/opkg_download.c 2009-05-17 18:17:09.000000000 +0200
|
|
@@ -17,7 +17,9 @@
|
|
General Public License for more details.
|
|
*/
|
|
#include "config.h"
|
|
+#ifdef HAVE_CURL
|
|
#include <curl/curl.h>
|
|
+#endif
|
|
#ifdef HAVE_GPGME
|
|
#include <gpgme.h>
|
|
#endif
|
|
@@ -77,6 +79,7 @@
|
|
setenv("no_proxy", conf->no_proxy, 1);
|
|
}
|
|
|
|
+#ifdef HAVE_CURL
|
|
CURL *curl;
|
|
CURLcode res;
|
|
FILE * file = fopen (tmp_file_location, "w");
|
|
@@ -123,6 +126,31 @@
|
|
free(src_basec);
|
|
return -1;
|
|
}
|
|
+#else /* if wget is selected */
|
|
+ char *cmd;
|
|
+ /* XXX: BUG rewrite to use execvp or else busybox's internal wget -Jamey 7/23/2002 */
|
|
+ sprintf_alloc(&cmd, "wget --passive-ftp %s %s%s %s%s -P %s %s",
|
|
+ (conf->http_proxy || conf->ftp_proxy) ? "--proxy=on" : "",
|
|
+ conf->proxy_user ? "--proxy-user=" : "",
|
|
+ conf->proxy_user ? conf->proxy_user : "",
|
|
+ conf->proxy_passwd ? "--proxy-passwd=" : "",
|
|
+ conf->proxy_passwd ? conf->proxy_passwd : "",
|
|
+ conf->tmp_dir,
|
|
+ src);
|
|
+ err = xsystem(cmd);
|
|
+ if (err) {
|
|
+ if (err != -1) {
|
|
+ opkg_message(conf,OPKG_ERROR, "%s: ERROR: Command failed with return value %d: `%s'\n",
|
|
+ __FUNCTION__, err, cmd);
|
|
+ }
|
|
+ unlink(tmp_file_location);
|
|
+ free(tmp_file_location);
|
|
+ free(src_basec);
|
|
+ free(cmd);
|
|
+ return EINVAL;
|
|
+ }
|
|
+ free(cmd);
|
|
+#endif
|
|
|
|
err = file_move(tmp_file_location, dest_file_name);
|
|
|