Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
aa222d7d
Commit
aa222d7d
authored
Jun 02, 2020
by
Nikolay Sivov
Committed by
Alexandre Julliard
Jun 02, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dwrite: Use lookup fitering for context matching.
Signed-off-by:
Nikolay Sivov
<
nsivov@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
f2db3b58
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
8 deletions
+8
-8
opentype.c
dlls/dwrite/opentype.c
+8
-8
No files found.
dlls/dwrite/opentype.c
View file @
aa222d7d
...
@@ -3496,7 +3496,7 @@ struct match_context
...
@@ -3496,7 +3496,7 @@ struct match_context
unsigned
int
input_offset
;
unsigned
int
input_offset
;
unsigned
int
lookahead_offset
;
unsigned
int
lookahead_offset
;
p_match_func
match_func
;
p_match_func
match_func
;
unsigned
int
mask
;
const
struct
lookup
*
lookup
;
};
};
struct
glyph_iterator
struct
glyph_iterator
...
@@ -5015,8 +5015,8 @@ static BOOL opentype_layout_context_match_input(const struct match_context *mc,
...
@@ -5015,8 +5015,8 @@ static BOOL opentype_layout_context_match_input(const struct match_context *mc,
match_positions
[
0
]
=
context
->
cur
;
match_positions
[
0
]
=
context
->
cur
;
glyph_iterator_init
(
context
,
0
,
context
->
cur
,
count
-
1
,
&
iter
);
glyph_iterator_init
(
context
,
mc
->
lookup
->
flags
,
context
->
cur
,
count
-
1
,
&
iter
);
iter
.
mask
=
mc
->
mask
;
iter
.
mask
=
mc
->
lookup
->
mask
;
iter
.
match_func
=
mc
->
match_func
;
iter
.
match_func
=
mc
->
match_func
;
iter
.
match_data
=
&
match_data
;
iter
.
match_data
=
&
match_data
;
iter
.
glyph_data
=
input
;
iter
.
glyph_data
=
input
;
...
@@ -5042,7 +5042,7 @@ static BOOL opentype_layout_context_match_backtrack(const struct match_context *
...
@@ -5042,7 +5042,7 @@ static BOOL opentype_layout_context_match_backtrack(const struct match_context *
struct
glyph_iterator
iter
;
struct
glyph_iterator
iter
;
unsigned
int
i
;
unsigned
int
i
;
glyph_iterator_init
(
context
,
0
,
context
->
cur
,
count
,
&
iter
);
glyph_iterator_init
(
context
,
mc
->
lookup
->
flags
,
context
->
cur
,
count
,
&
iter
);
iter
.
match_func
=
mc
->
match_func
;
iter
.
match_func
=
mc
->
match_func
;
iter
.
match_data
=
&
match_data
;
iter
.
match_data
=
&
match_data
;
iter
.
glyph_data
=
backtrack
;
iter
.
glyph_data
=
backtrack
;
...
@@ -5066,7 +5066,7 @@ static BOOL opentype_layout_context_match_lookahead(const struct match_context *
...
@@ -5066,7 +5066,7 @@ static BOOL opentype_layout_context_match_lookahead(const struct match_context *
struct
glyph_iterator
iter
;
struct
glyph_iterator
iter
;
unsigned
int
i
;
unsigned
int
i
;
glyph_iterator_init
(
context
,
0
,
context
->
cur
+
offset
-
1
,
count
,
&
iter
);
glyph_iterator_init
(
context
,
mc
->
lookup
->
flags
,
context
->
cur
+
offset
-
1
,
count
,
&
iter
);
iter
.
match_func
=
mc
->
match_func
;
iter
.
match_func
=
mc
->
match_func
;
iter
.
match_data
=
&
match_data
;
iter
.
match_data
=
&
match_data
;
iter
.
glyph_data
=
lookahead
;
iter
.
glyph_data
=
lookahead
;
...
@@ -5262,7 +5262,7 @@ static BOOL opentype_layout_apply_rule_set(const struct match_context *mc, unsig
...
@@ -5262,7 +5262,7 @@ static BOOL opentype_layout_apply_rule_set(const struct match_context *mc, unsig
static
BOOL
opentype_layout_apply_gsub_context_substitution
(
struct
scriptshaping_context
*
context
,
const
struct
lookup
*
lookup
,
static
BOOL
opentype_layout_apply_gsub_context_substitution
(
struct
scriptshaping_context
*
context
,
const
struct
lookup
*
lookup
,
unsigned
int
subtable_offset
)
unsigned
int
subtable_offset
)
{
{
struct
match_context
mc
=
{
.
context
=
context
,
.
mask
=
lookup
->
mask
};
struct
match_context
mc
=
{
.
context
=
context
,
.
lookup
=
lookup
};
const
struct
dwrite_fonttable
*
table
=
&
context
->
table
->
table
;
const
struct
dwrite_fonttable
*
table
=
&
context
->
table
->
table
;
unsigned
int
coverage_index
=
GLYPH_NOT_COVERED
,
count
,
offset
;
unsigned
int
coverage_index
=
GLYPH_NOT_COVERED
,
count
,
offset
;
UINT16
glyph
,
format
,
coverage
;
UINT16
glyph
,
format
,
coverage
;
...
@@ -5364,7 +5364,7 @@ static BOOL opentype_layout_apply_gsub_context_substitution(struct scriptshaping
...
@@ -5364,7 +5364,7 @@ static BOOL opentype_layout_apply_gsub_context_substitution(struct scriptshaping
static
BOOL
opentype_layout_apply_gsub_chain_context_substitution
(
struct
scriptshaping_context
*
context
,
static
BOOL
opentype_layout_apply_gsub_chain_context_substitution
(
struct
scriptshaping_context
*
context
,
const
struct
lookup
*
lookup
,
unsigned
int
subtable_offset
)
const
struct
lookup
*
lookup
,
unsigned
int
subtable_offset
)
{
{
struct
match_context
mc
=
{
.
context
=
context
,
.
mask
=
lookup
->
mask
};
struct
match_context
mc
=
{
.
context
=
context
,
.
lookup
=
lookup
};
const
struct
dwrite_fonttable
*
table
=
&
context
->
table
->
table
;
const
struct
dwrite_fonttable
*
table
=
&
context
->
table
->
table
;
unsigned
int
coverage_index
=
GLYPH_NOT_COVERED
,
count
,
offset
;
unsigned
int
coverage_index
=
GLYPH_NOT_COVERED
,
count
,
offset
;
UINT16
glyph
,
format
,
coverage
;
UINT16
glyph
,
format
,
coverage
;
...
@@ -5493,7 +5493,7 @@ static BOOL opentype_layout_apply_gsub_reverse_chain_context_substitution(struct
...
@@ -5493,7 +5493,7 @@ static BOOL opentype_layout_apply_gsub_reverse_chain_context_substitution(struct
if
(
format
==
1
)
if
(
format
==
1
)
{
{
struct
match_context
mc
=
{
.
context
=
context
,
.
mask
=
lookup
->
mask
};
struct
match_context
mc
=
{
.
context
=
context
,
.
lookup
=
lookup
};
unsigned
int
start_index
=
0
,
end_index
=
0
,
backtrack_count
,
lookahead_count
;
unsigned
int
start_index
=
0
,
end_index
=
0
,
backtrack_count
,
lookahead_count
;
unsigned
int
coverage
,
coverage_index
;
unsigned
int
coverage
,
coverage_index
;
const
UINT16
*
backtrack
,
*
lookahead
;
const
UINT16
*
backtrack
,
*
lookahead
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment