Make URI structures reference-counted.

This commit is contained in:
Michael Brown
2007-05-28 17:35:15 +00:00
parent bc694ec768
commit 656485c1f1
5 changed files with 28 additions and 15 deletions

View File

@@ -121,7 +121,7 @@ int start_download ( const char *uri_string, struct async *parent,
err:
async_uninit ( &download->async );
ufree ( download->buffer.addr );
free_uri ( download->uri );
uri_put ( download->uri );
free ( download );
return rc;
}
@@ -150,7 +150,7 @@ static void download_sigchld ( struct async *async,
/* Discard the buffer */
ufree ( download->buffer.addr );
}
free_uri ( download->uri );
uri_put ( download->uri );
download->uri = NULL;
/* Terminate ourselves */

View File

@@ -52,6 +52,7 @@ static struct socket_opener socket_openers_end[0]
int xfer_open_uri ( struct xfer_interface *xfer, const char *uri_string ) {
struct uri *uri;
struct uri_opener *opener;
int rc = -ENOTSUP;
DBGC ( xfer, "XFER %p opening URI %s\n", xfer, uri_string );
@@ -61,14 +62,16 @@ int xfer_open_uri ( struct xfer_interface *xfer, const char *uri_string ) {
for ( opener = uri_openers ; opener < uri_openers_end ; opener++ ) {
if ( strcmp ( uri->scheme, opener->scheme ) == 0 ) {
return opener->open ( xfer, uri );
rc = opener->open ( xfer, uri );
goto done;
}
}
DBGC ( xfer, "XFER %p attempted to open unsupported URI scheme "
"\"%s\"\n", xfer, uri->scheme );
free_uri ( uri );
return -ENOTSUP;
done:
uri_put ( uri );
return rc;
}
/**

View File

@@ -35,7 +35,7 @@
*
* Splits a URI into its component parts. The return URI structure is
* dynamically allocated and must eventually be freed by calling
* free_uri().
* uri_put().
*/
struct uri * parse_uri ( const char *uri_string ) {
struct uri *uri;