1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
/*
* This file is part of LibCSS
* Licensed under the MIT License,
* http://www.opensource.org/licenses/mit-license.php
*/
#include "bytecode/bytecode.h"
#include "bytecode/opcodes.h"
#include "select/propset.h"
#include "select/propget.h"
#include "utils/utils.h"
#include "select/properties/properties.h"
#include "select/properties/helpers.h"
css_error css__cascade_stroke_opacity(uint32_t opv, css_style *style,
css_select_state *state)
{
uint16_t value = CSS_STROKE_OPACITY_INHERIT;
css_fixed stroke_opacity = 0;
if (hasFlagValue(opv) == false) {
value = CSS_STROKE_OPACITY_SET;
stroke_opacity = *((css_fixed *) style->bytecode);
advance_bytecode(style, sizeof(stroke_opacity));
}
if (css__outranks_existing(getOpcode(opv), isImportant(opv), state,
getFlagValue(opv))) {
return set_stroke_opacity(state->computed, value, stroke_opacity);
}
return CSS_OK;
}
css_error css__set_stroke_opacity_from_hint(const css_hint *hint,
css_computed_style *style)
{
return set_stroke_opacity(style, hint->status, hint->data.fixed);
}
css_error css__initial_stroke_opacity(css_select_state *state)
{
return set_stroke_opacity(state->computed, CSS_STROKE_OPACITY_SET, INTTOFIX(1));
}
css_error css__copy_stroke_opacity(
const css_computed_style *from,
css_computed_style *to)
{
css_fixed stroke_opacity = 0;
uint8_t type = get_stroke_opacity(from, &stroke_opacity);
if (from == to) {
return CSS_OK;
}
return set_stroke_opacity(to, type, stroke_opacity);
}
css_error css__compose_stroke_opacity(const css_computed_style *parent,
const css_computed_style *child,
css_computed_style *result)
{
css_fixed stroke_opacity = 0;
uint8_t type = get_stroke_opacity(child, &stroke_opacity);
return css__copy_stroke_opacity(
type == CSS_STROKE_OPACITY_INHERIT ? parent : child,
result);
}
|