X-Git-Url: https://gitweb.michael.orlitzky.com/?a=blobdiff_plain;f=src%2Fsvgtiny_css.c;h=b80d0578b7bd219d8397a2532b23f1b4491e608d;hb=f310f5518bee392ccb6c55649dc0a3eccda1403a;hp=a5a75214a57239d3bbfb150768dc1611531007ae;hpb=aa4b2d7b7b628407f6361c6b5c5a4ad2b0176877;p=libsvgtiny.git diff --git a/src/svgtiny_css.c b/src/svgtiny_css.c index a5a7521..b80d057 100644 --- a/src/svgtiny_css.c +++ b/src/svgtiny_css.c @@ -73,6 +73,47 @@ static css_error get_libcss_node_data(void *pw, void *node, static struct css_select_handler svgtiny_select_handler; +/** + * Convenient wrapper around css_select_style() + * + * \param state The current state of the libsvgtiny parser + * \param node The node that we're getting styles for + * \param inline_sheet The inline stylesheet for the given node + * \param result Address at which to store the results array + */ +css_error svgtiny_select_style(struct svgtiny_parse_state *state, + dom_element *node, + const css_stylesheet *inline_sheet, + css_select_results **result) +{ + const css_media media_all = { + .type = CSS_MEDIA_ALL, + }; + + /* These magic numbers below were taken from the libcss + * example program without much thought, because at the moment + * we don't support any properties with units. */ + const css_unit_ctx unitctx = { + .viewport_width = FLTTOFIX(state->viewport_width), + .viewport_height = FLTTOFIX(state->viewport_height), + .font_size_default = FLTTOFIX(16.0), + .font_size_minimum = FLTTOFIX(6.0), + .device_dpi = FLTTOFIX(96.0), + .root_style = NULL, + .pw = NULL, + .measure = NULL, + }; + + return css_select_style(state->select_ctx, + node, + &unitctx, + &media_all, + inline_sheet, + &svgtiny_select_handler, + state, + result); +} + /** * Resolve a relative URL to an absolute one by doing nothing. This is * the simplest possible implementation of a URL resolver, needed for @@ -1931,15 +1972,12 @@ css_error set_libcss_node_data(void *pw, void *node, void *old_data; /* A unique "userdata key" (a string) is used to identify this - * data. The fourth parameter (NULL) is a "user handler - * function." We will eventually have one, but for now we set - * it to NULL to avoid a circular reference mess that would - * break the build temporarily. */ + * data. */ state = (struct svgtiny_parse_state *)pw; dom_node_set_user_data((dom_node *)node, state->interned_userdata_key, libcss_node_data, - NULL, + svgtiny_dom_user_data_handler, &old_data); /* dom_node_set_user_data() always returns DOM_NO_ERR */ @@ -2020,3 +2058,5 @@ static css_select_handler svgtiny_select_handler = { set_libcss_node_data, get_libcss_node_data, }; + +