summaryrefslogtreecommitdiff
path: root/content/content.c
Commit message (Collapse)AuthorAgeFilesLines
* Introduce content_set_ready.John Mark Bell2010-04-091-7/+14
| | | | | | | Make content_convert emit events only if content is in appropriate state. Remove no-longer-relevant assertion from content_convert. svn path=/trunk/netsurf/; revision=10330
* Abort and release llcache handle on failure to process data.John Mark Bell2010-04-081-0/+3
| | | | | | Make hlcache retrieval ignore erroneous contents. svn path=/trunk/netsurf/; revision=10296
* Add function to test whether hlcache_handle's content is locked.Michael Drake2010-04-071-0/+17
| | | | svn path=/trunk/netsurf/; revision=10287
* Add mime-type getter.Michael Drake2010-04-071-0/+19
| | | | svn path=/trunk/netsurf/; revision=10259
* Make downloads work again.John Mark Bell2010-04-051-25/+0
| | | | svn path=/trunk/netsurf/; revision=10243
* Most of a stop implementation.John Mark Bell2010-04-041-54/+154
| | | | | | | | | Remaining work: 1) Clone content_html_data 2) Cloning content_css_data requires the charset of the old content 3) Calling hlcache_handle_abort() before a content has been created must clean up the retrieval context. svn path=/trunk/netsurf/; revision=10236
* Constify data parameter to *_process_dataJohn Mark Bell2010-04-031-2/+3
| | | | svn path=/trunk/netsurf/; revision=10234
* Use mutator to modify content's title field.John Mark Bell2010-04-031-0/+14
| | | | svn path=/trunk/netsurf/; revision=10231
* Fix compilation when building WITH_NS_SVGChris Young2010-03-301-1/+1
| | | | svn path=/trunk/netsurf/; revision=10213
* The convert stage of a content's state progression no longer reflows the ↵John Mark Bell2010-03-291-7/+6
| | | | | | | | | | | | | content to the provided dimensions. It is now defined as converting the content into a state in which it is ready for use. The user of the content is now responsible for performing an initial reformat (sic) of the content before it can be redrawn. Purge width/height parameters from hlcache_handle_retrieve/content_convert/*_convert APIs. Fix up content handlers affected by the above change in semantics. Ensure that browser_window_callback performs an initial reformat of its content. svn path=/trunk/netsurf/; revision=10207
* Replace fetch_poll with llcache_poll throughout. Allow CONTENT_OTHER to ↵Daniel Silverstone2010-03-281-24/+22
| | | | | | complete properly. svn path=/trunk/netsurf/; revision=10187
* Remove fetchcache.[ch]Daniel Silverstone2010-03-281-1/+0
| | | | svn path=/trunk/netsurf/; revision=10183
* Merge jmb/new-cache; r=dsilvers,rs=vinceDaniel Silverstone2010-03-281-511/+488
| | | | svn path=/trunk/netsurf/; revision=10180
* Merge branches/MarkieB/gtkmain to trunk.John Mark Bell2009-12-171-0/+3
| | | | svn path=/trunk/netsurf/; revision=9729
* This optimisation was so simple that it was broken.John Mark Bell2009-11-221-1/+1
| | | | svn path=/trunk/netsurf/; revision=9696
* svgtiny requires separate contentsJohn Mark Bell2009-10-081-1/+1
| | | | svn path=/trunk/netsurf/; revision=9615
* Hack around cache issue. The entire cache layer needs a redesign asap.John Mark Bell2009-08-261-0/+27
| | | | svn path=/trunk/netsurf/; revision=9460
* - content/urldb.c(auth_data): Removed;John Tytgat2009-08-041-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (prot_space_data): Added, it lives linked in the leaf host_part struct and together with its scheme and port (which defins canonical root url) and realm this defines a protection space. (path_data): Removed auth_data field and replaced by a prot_space_data pointer. (host_part::prot_space): Added linked list of protection space data structs. (urldb_get_auth_details): Given an URL fetch fetches its auth. (urldb_set_auth_details): Creates or updates the contents of a protection space to which given URL belongs. (urldb_destroy_host_tree): Delete protection data space structures using urldb_destroy_prot_space. (urldb_destroy_prot_space): Added. - content/urldb.h(urldb_get_auth_details): Added realm parameter. - content/fetchers/fetch_curl.c(fetch_curl_set_options): Update urldb_get_auth_details call (we don't know realm at this point). - content/fetchcache.c(fetchcache_callback, fetchcache_auth): At FETCH_AUTH, use realm to determine if we really don't know auth data and if so, refetch content. - content/content.h(struct content): Add content::tried_with_auth. - content/content.c(content_create): Initialize content::tried_with_auth. - riscos/401login.c(ro_gui_401login_open): Show known authentication data in dialogue so user can see what was wrong with it and correct it. Solves bug #2830829. svn path=/trunk/netsurf/; revision=9045
* Merge LibCSS port to trunk.John Mark Bell2009-07-231-4/+7
| | | | svn path=/trunk/netsurf/; revision=8752
* Replace parent_url with a pointer to the parent content.John Mark Bell2009-07-101-2/+3
| | | | svn path=/trunk/netsurf/; revision=8428
* Comment content_redraw.Michael Drake2009-02-021-0/+19
| | | | svn path=/trunk/netsurf/; revision=6355
* Revert r5478, I didn't notice content struct had a mime_type field.François Revel2008-10-031-17/+0
| | | | svn path=/trunk/netsurf/; revision=5480
* Add a function to tell the mime type for a content type.François Revel2008-10-031-0/+17
| | | | svn path=/trunk/netsurf/; revision=5478
* 'unsigned long' -> 'colour' where it made sense.John Tytgat2008-09-281-4/+4
| | | | svn path=/trunk/netsurf/; revision=5459
* Treat image/jpg as JPEG content for Royal Mail captcha.Michael Drake2008-09-161-0/+1
| | | | svn path=/trunk/netsurf/; revision=5343
* Add libpng support. Default to off.Daniel Silverstone2008-09-151-3/+17
| | | | svn path=/trunk/netsurf/; revision=5330
* Constify content_type_name & content_status_nameJohn Tytgat2008-07-301-2/+2
| | | | svn path=/trunk/netsurf/; revision=4815
* Performance improvements: rather than calling content_clean() every poll, we ↵Rob Kendrick2008-07-071-2/+3
| | | | | | now call it no more frequently than once every 5 seconds. Additionally, we cache the result of talloc_total_size() in content_clean() rather than calculating it twice. On large documents, this function took 25% of CPU time. This makes the fetching/rendering/scrolling/redrawing of large documents over twice as fast. svn path=/trunk/netsurf/; revision=4527
* Move struct cache_data from fetch to content as it is no longer needed by ↵James Bursa2008-06-031-14/+9
| | | | | | fetch. Make it a member instead of pointer in struct content. svn path=/trunk/netsurf/; revision=4246
* Implement sprite support for GTK using librospriteJames Shaw2008-03-291-2/+9
| | | | svn path=/trunk/netsurf/; revision=4051
* Make content_reset actually do what it's meant to (i.e. reset the ↵John Mark Bell2008-02-271-0/+7
| | | | | | | | appropriate members) Fix up CONTENT_MSG_REFRESH scheduled events to gracefully the refresh URL disappearing from under them. svn path=/trunk/netsurf/; revision=3870
* Add url_fragment to extract fragment from URLJohn Mark Bell2008-02-031-0/+1
| | | | | | | | Optionally allow url_compare to ignore fragments in comparison Fix handling of url_compare result in a few places Fix redirects which contain fragments in the Location header svn path=/trunk/netsurf/; revision=3826
* Rework handling of HTTP redirects -- we now count the number of redirects ↵John Mark Bell2008-01-281-0/+1
| | | | | | | | | | | | | | | | | | | | followed for a given item and abort if a fixed limit is reached. This fixes sites which have pages that redirect to themselves. Redirect handling is now transparent to clients of fetchcache. The new scheme works as follows: 1) Request content for URL (fetchcache() 2) Start fetch of content (fetchcache_go() 3) If no redirect, continue through LOADING, READY, DONE etc. states as before If redirect, receive NEWPTR for each redirect that occurs, then continue through LOADING, READY, DONE etc. states as before. The upshot of this is that redirects result in extra contents being created. It also means that, until LOADING has been received, the content (and thus the URL being fetched) may change. Therefore, fetchcache clients should expect to have to deal with transient data prior to LOADING occurring. As a necessary side-effect of this, the HTML object URLs and CSS @import URLs are no longer stored alongside the relevant contents. These URLs can be accessed by interrogating the url member of struct content anyway, so it was a rather redundant scheme before. svn path=/trunk/netsurf/; revision=3787
* Update all source code file headers to reflect GPL version 2 only and ↵Vincent Sanders2007-08-081-3/+14
| | | | | | contain appropriate licence text svn path=/trunk/netsurf/; revision=3486
* Move window scaling from platform-specific code to desktop/browser.c. Modify ↵James Bursa2007-08-071-1/+2
| | | | | | gtk gui to handle scaling in the same way as RO. svn path=/trunk/netsurf/; revision=3478
* Fix crash when building error page -- fetch will be NULL, so ↵John Mark Bell2007-08-061-1/+2
| | | | | | fetch_get_referer will fail. svn path=/trunk/netsurf/; revision=3476
* Change ArtWorks file MIME type to "image/x-artworks".Michael Drake2007-07-211-6/+3
| | | | svn path=/trunk/netsurf/; revision=3449
* Add SVG content name to content_type_name array.John Mark Bell2007-07-211-0/+3
| | | | svn path=/trunk/netsurf/; revision=3448
* Add incremental parsing of SVG data to librsvg content handler.Rob Kendrick2007-07-191-1/+1
| | | | svn path=/trunk/netsurf/; revision=3441
* Initial work on RSVG image handler. Still a lot to do.Rob Kendrick2007-07-181-1/+8
| | | | svn path=/trunk/netsurf/; revision=3433
* Wrap internal SVG renderer with appropriate #ifdef WITH_NS_SVGRob Kendrick2007-07-181-0/+6
| | | | svn path=/trunk/netsurf/; revision=3432
* Add CONTENT_SVG to content handling.James Bursa2007-07-131-0/+5
| | | | svn path=/trunk/netsurf/; revision=3406
* Remove the netsurf/ from the include paths and rationalise use of <> vs "" ↵Daniel Silverstone2007-05-301-23/+23
| | | | | | | | | | | | | | in includes NetSurf includes are now done with ""s and other system includes with <>s as C intended. The scandeps tool has been updated to only look for ""ed includes, and to verify that the files exist in the tree before adding them to the dependency lines. The depend rule has therefore been augmented to make sure the autogenerated files are built before it is run. This is untested under self-hosted RISC OS builds. All else tested and works. svn path=/trunk/netsurf/; revision=3307
* Fix abort on attempted destruction of CONTENT_DIRECTORY (1690222)John Mark Bell2007-03-281-3/+1
| | | | svn path=/trunk/netsurf/; revision=3228
* Lose noisy loggingJohn Mark Bell2007-03-181-3/+3
| | | | svn path=/trunk/netsurf/; revision=3213
* Ensure content structures are zero initialised.John Mark Bell2007-03-181-1/+1
| | | | | | | | | Make css_destroy check that the stylesheet pointer exists (content destructors may be called whilst the content is still loading - e.g. if the content type isn't permissable in the context it was loaded from). Fixes 1627413, 1580980. svn path=/trunk/netsurf/; revision=3212
* Improve debug output so that content usage may be tracedJohn Mark Bell2007-03-181-9/+17
| | | | svn path=/trunk/netsurf/; revision=3210
* Content handlers should not call warn_user - they should broadcast the John Mark Bell2007-03-111-4/+0
| | | | | | | | | | error using content_broadcast and leave it to the content owner(s) to decide what to do about it. Only use warn_user for top-level contents. svn path=/trunk/netsurf/; revision=3204
* Dynamically update scale view (implement 1556975) and prevent double redraws.Richard Wilson2007-03-031-0/+11
| | | | svn path=/trunk/netsurf/; revision=3191
* Fix handling of cookies in unverifiable transactions caused by a redirect ↵John Mark Bell2007-02-021-2/+5
| | | | | | from a fetch into a browser window which was varifiable. svn path=/trunk/netsurf/; revision=3165