gopher.c
Go to the documentation of this file.
1 /*
2  * Gopher protocol
3  *
4  * Copyright (c) 2009 Toshimitsu Kimura
5  *
6  * based on libavformat/http.c, Copyright (c) 2000, 2001 Fabrice Bellard
7  *
8  * This file is part of FFmpeg.
9  *
10  * FFmpeg is free software; you can redistribute it and/or
11  * modify it under the terms of the GNU Lesser General Public
12  * License as published by the Free Software Foundation; either
13  * version 2.1 of the License, or (at your option) any later version.
14  *
15  * FFmpeg is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18  * Lesser General Public License for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public
21  * License along with FFmpeg; if not, write to the Free Software
22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
23  */
24 
25 #include "libavutil/avstring.h"
26 #include "avformat.h"
27 #include "internal.h"
28 #include "network.h"
29 #include "url.h"
30 
31 typedef struct {
34 
35 static int gopher_write(URLContext *h, const uint8_t *buf, int size)
36 {
38  return ffurl_write(s->hd, buf, size);
39 }
40 
41 static int gopher_connect(URLContext *h, const char *path)
42 {
43  char buffer[1024];
44 
45  if (!*path) return AVERROR(EINVAL);
46  switch (*++path) {
47  case '5':
48  case '9':
49  path = strchr(path, '/');
50  if (!path) return AVERROR(EINVAL);
51  break;
52  default:
54  "Gopher protocol type '%c' not supported yet!\n",
55  *path);
56  return AVERROR(EINVAL);
57  }
58 
59  /* send gopher sector */
60  snprintf(buffer, sizeof(buffer), "%s\r\n", path);
61 
62  if (gopher_write(h, buffer, strlen(buffer)) < 0)
63  return AVERROR(EIO);
64 
65  return 0;
66 }
67 
68 static int gopher_close(URLContext *h)
69 {
71  if (s->hd) {
72  ffurl_close(s->hd);
73  s->hd = NULL;
74  }
75  return 0;
76 }
77 
78 static int gopher_open(URLContext *h, const char *uri, int flags)
79 {
81  char hostname[1024], auth[1024], path[1024], buf[1024];
82  int port, err;
83 
84  h->is_streamed = 1;
85 
86  /* needed in any case to build the host string */
87  av_url_split(NULL, 0, auth, sizeof(auth), hostname, sizeof(hostname), &port,
88  path, sizeof(path), uri);
89 
90  if (port < 0)
91  port = 70;
92 
93  ff_url_join(buf, sizeof(buf), "tcp", NULL, hostname, port, NULL);
94 
95  s->hd = NULL;
96  err = ffurl_open(&s->hd, buf, AVIO_FLAG_READ_WRITE,
98  if (err < 0)
99  goto fail;
100 
101  if ((err = gopher_connect(h, path)) < 0)
102  goto fail;
103  return 0;
104  fail:
105  gopher_close(h);
106  return err;
107 }
108 
109 static int gopher_read(URLContext *h, uint8_t *buf, int size)
110 {
111  GopherContext *s = h->priv_data;
112  int len = ffurl_read(s->hd, buf, size);
113  return len;
114 }
115 
116 
118  .name = "gopher",
119  .url_open = gopher_open,
120  .url_read = gopher_read,
121  .url_write = gopher_write,
122  .url_close = gopher_close,
123  .priv_data_size = sizeof(GopherContext),
125 };
static int gopher_open(URLContext *h, const char *uri, int flags)
Definition: gopher.c:78
void av_url_split(char *proto, int proto_size, char *authorization, int authorization_size, char *hostname, int hostname_size, int *port_ptr, char *path, int path_size, const char *url)
Split a URL string into components.
const char * s
Definition: avisynth_c.h:668
#define URL_PROTOCOL_FLAG_NETWORK
Definition: url.h:35
URLContext * hd
Definition: gopher.c:32
int ffurl_write(URLContext *h, const unsigned char *buf, int size)
Write size bytes from buf to the resource accessed by h.
Definition: avio.c:317
int is_streamed
true if streamed (no seek possible), default = false
Definition: url.h:48
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:154
AVIOInterruptCB interrupt_callback
Definition: url.h:50
static int gopher_read(URLContext *h, uint8_t *buf, int size)
Definition: gopher.c:109
int ff_url_join(char *str, int size, const char *proto, const char *authorization, const char *hostname, int port, const char *fmt,...) av_printf_format(7
Assemble a URL string from components.
uint8_t
static int gopher_connect(URLContext *h, const char *path)
Definition: gopher.c:41
void av_log(void *avcl, int level, const char *fmt,...)
Definition: log.c:246
int size
NULL
Definition: eval.c:55
void * buf
Definition: avisynth_c.h:594
Definition: url.h:41
#define AVIO_FLAG_READ_WRITE
read-write pseudo flag
Definition: avio.h:334
static int gopher_close(URLContext *h)
Definition: gopher.c:68
void * priv_data
Definition: url.h:44
URLProtocol ff_gopher_protocol
Definition: gopher.c:117
#define snprintf
Definition: snprintf.h:34
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFilterBuffer structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later.That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another.Buffer references ownership and permissions
const char * name
Definition: url.h:55
static int flags
Definition: cpu.c:23
int ffurl_close(URLContext *h)
Definition: avio.c:359
Main libavformat public API header.
int ffurl_open(URLContext **puc, const char *filename, int flags, const AVIOInterruptCB *int_cb, AVDictionary **options)
Create an URLContext for accessing to the resource indicated by url, and open it. ...
Definition: avio.c:247
the buffer and buffer reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFilterBuffer structures They must not be accessed but through references stored in AVFilterBufferRef structures Several references can point to the same buffer
int len
static int gopher_write(URLContext *h, const uint8_t *buf, int size)
Definition: gopher.c:35
unbuffered private I/O API
int ffurl_read(URLContext *h, unsigned char *buf, int size)
Read up to size bytes from the resource accessed by h, and store the read bytes in buf...
Definition: avio.c:303