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
e203d3be
Commit
e203d3be
authored
Jun 07, 2022
by
Bernhard Kölbl
Committed by
Alexandre Julliard
Jan 24, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
windows.media.speech: Move constraints vector to the recognition session.
Signed-off-by:
Bernhard Kölbl
<
besentv@gmail.com
>
parent
08643dc4
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
5 deletions
+14
-5
recognizer.c
dlls/windows.media.speech/recognizer.c
+14
-5
No files found.
dlls/windows.media.speech/recognizer.c
View file @
e203d3be
...
@@ -156,6 +156,8 @@ struct session
...
@@ -156,6 +156,8 @@ struct session
ISpeechContinuousRecognitionSession
ISpeechContinuousRecognitionSession_iface
;
ISpeechContinuousRecognitionSession
ISpeechContinuousRecognitionSession_iface
;
LONG
ref
;
LONG
ref
;
IVector_ISpeechRecognitionConstraint
*
constraints
;
struct
list
completed_handlers
;
struct
list
completed_handlers
;
struct
list
result_handlers
;
struct
list
result_handlers
;
};
};
...
@@ -208,6 +210,7 @@ static ULONG WINAPI session_Release( ISpeechContinuousRecognitionSession *iface
...
@@ -208,6 +210,7 @@ static ULONG WINAPI session_Release( ISpeechContinuousRecognitionSession *iface
{
{
typed_event_handlers_clear
(
&
impl
->
completed_handlers
);
typed_event_handlers_clear
(
&
impl
->
completed_handlers
);
typed_event_handlers_clear
(
&
impl
->
result_handlers
);
typed_event_handlers_clear
(
&
impl
->
result_handlers
);
IVector_ISpeechRecognitionConstraint_Release
(
impl
->
constraints
);
free
(
impl
);
free
(
impl
);
}
}
...
@@ -360,7 +363,6 @@ struct recognizer
...
@@ -360,7 +363,6 @@ struct recognizer
LONG
ref
;
LONG
ref
;
ISpeechContinuousRecognitionSession
*
session
;
ISpeechContinuousRecognitionSession
*
session
;
IVector_ISpeechRecognitionConstraint
*
constraints
;
};
};
/*
/*
...
@@ -424,7 +426,6 @@ static ULONG WINAPI recognizer_Release( ISpeechRecognizer *iface )
...
@@ -424,7 +426,6 @@ static ULONG WINAPI recognizer_Release( ISpeechRecognizer *iface )
if
(
!
ref
)
if
(
!
ref
)
{
{
ISpeechContinuousRecognitionSession_Release
(
impl
->
session
);
ISpeechContinuousRecognitionSession_Release
(
impl
->
session
);
IVector_ISpeechRecognitionConstraint_Release
(
impl
->
constraints
);
free
(
impl
);
free
(
impl
);
}
}
...
@@ -452,8 +453,11 @@ static HRESULT WINAPI recognizer_GetTrustLevel( ISpeechRecognizer *iface, TrustL
...
@@ -452,8 +453,11 @@ static HRESULT WINAPI recognizer_GetTrustLevel( ISpeechRecognizer *iface, TrustL
static
HRESULT
WINAPI
recognizer_get_Constraints
(
ISpeechRecognizer
*
iface
,
IVector_ISpeechRecognitionConstraint
**
vector
)
static
HRESULT
WINAPI
recognizer_get_Constraints
(
ISpeechRecognizer
*
iface
,
IVector_ISpeechRecognitionConstraint
**
vector
)
{
{
struct
recognizer
*
impl
=
impl_from_ISpeechRecognizer
(
iface
);
struct
recognizer
*
impl
=
impl_from_ISpeechRecognizer
(
iface
);
struct
session
*
session
=
impl_from_ISpeechContinuousRecognitionSession
(
impl
->
session
);
TRACE
(
"iface %p, operation %p.
\n
"
,
iface
,
vector
);
TRACE
(
"iface %p, operation %p.
\n
"
,
iface
,
vector
);
IVector_ISpeechRecognitionConstraint_AddRef
((
*
vector
=
impl
->
constraints
));
IVector_ISpeechRecognitionConstraint_AddRef
((
*
vector
=
session
->
constraints
));
return
S_OK
;
return
S_OK
;
}
}
...
@@ -797,18 +801,22 @@ static HRESULT WINAPI recognizer_factory_Create( ISpeechRecognizerFactory *iface
...
@@ -797,18 +801,22 @@ static HRESULT WINAPI recognizer_factory_Create( ISpeechRecognizerFactory *iface
if
(
language
)
if
(
language
)
FIXME
(
"language parameter unused. Stub!
\n
"
);
FIXME
(
"language parameter unused. Stub!
\n
"
);
/* Init ISpeechContinuousRecognitionSession */
session
->
ISpeechContinuousRecognitionSession_iface
.
lpVtbl
=
&
session_vtbl
;
session
->
ISpeechContinuousRecognitionSession_iface
.
lpVtbl
=
&
session_vtbl
;
session
->
ref
=
1
;
session
->
ref
=
1
;
list_init
(
&
session
->
completed_handlers
);
list_init
(
&
session
->
completed_handlers
);
list_init
(
&
session
->
result_handlers
);
list_init
(
&
session
->
result_handlers
);
if
(
FAILED
(
hr
=
vector_inspectable_create
(
&
constraints_iids
,
(
IVector_IInspectable
**
)
&
session
->
constraints
)))
goto
error
;
/* Init ISpeechRecognizer */
impl
->
ISpeechRecognizer_iface
.
lpVtbl
=
&
speech_recognizer_vtbl
;
impl
->
ISpeechRecognizer_iface
.
lpVtbl
=
&
speech_recognizer_vtbl
;
impl
->
IClosable_iface
.
lpVtbl
=
&
closable_vtbl
;
impl
->
IClosable_iface
.
lpVtbl
=
&
closable_vtbl
;
impl
->
ISpeechRecognizer2_iface
.
lpVtbl
=
&
speech_recognizer2_vtbl
;
impl
->
ISpeechRecognizer2_iface
.
lpVtbl
=
&
speech_recognizer2_vtbl
;
impl
->
session
=
&
session
->
ISpeechContinuousRecognitionSession_iface
;
impl
->
session
=
&
session
->
ISpeechContinuousRecognitionSession_iface
;
impl
->
ref
=
1
;
impl
->
ref
=
1
;
if
(
FAILED
(
hr
=
vector_inspectable_create
(
&
constraints_iids
,
(
IVector_IInspectable
**
)
&
impl
->
constraints
)))
goto
error
;
TRACE
(
"created SpeechRecognizer %p.
\n
"
,
impl
);
TRACE
(
"created SpeechRecognizer %p.
\n
"
,
impl
);
...
@@ -816,6 +824,7 @@ static HRESULT WINAPI recognizer_factory_Create( ISpeechRecognizerFactory *iface
...
@@ -816,6 +824,7 @@ static HRESULT WINAPI recognizer_factory_Create( ISpeechRecognizerFactory *iface
return
S_OK
;
return
S_OK
;
error
:
error
:
if
(
session
->
constraints
)
IVector_ISpeechRecognitionConstraint_Release
(
session
->
constraints
);
free
(
session
);
free
(
session
);
free
(
impl
);
free
(
impl
);
...
...
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