Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-gpu
Commits
25763b6a
Commit
25763b6a
authored
Aug 26, 2003
by
Gildas Bazin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* modules/access/dshow/*: bug fixes.
parent
fe574e12
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
27 additions
and
23 deletions
+27
-23
modules/access/dshow/dshow.cpp
modules/access/dshow/dshow.cpp
+6
-7
modules/access/dshow/filter.cpp
modules/access/dshow/filter.cpp
+21
-16
No files found.
modules/access/dshow/dshow.cpp
View file @
25763b6a
...
...
@@ -2,7 +2,7 @@
* dshow.c : DirectShow access module for vlc
*****************************************************************************
* Copyright (C) 2002 VideoLAN
* $Id: dshow.cpp,v 1.
3 2003/08/25 22:57:40
gbazin Exp $
* $Id: dshow.cpp,v 1.
4 2003/08/26 19:14:09
gbazin Exp $
*
* Author: Gildas Bazin <gbazin@netcourrier.com>
*
...
...
@@ -303,12 +303,13 @@ static int AccessOpen( vlc_object_t *p_this )
if
(
!
p_sys
->
i_streams
)
{
/* Uninitialize OLE/COM */
CoUninitialize
();
/* Release directshow objects */
p_sys
->
p_control
->
Release
();
p_sys
->
p_graph
->
Release
();
/* Uninitialize OLE/COM */
CoUninitialize
();
free
(
p_sys
->
p_header
);
free
(
p_sys
);
return
VLC_EGENERIC
;
...
...
@@ -336,7 +337,6 @@ static void AccessClose( vlc_object_t *p_this )
p_sys
->
p_control
->
Stop
();
p_sys
->
p_control
->
Release
();
#if 0
/* Remove filters from graph */
for
(
int
i
=
0
;
i
<
p_sys
->
i_streams
;
i
++
)
{
...
...
@@ -346,7 +346,6 @@ static void AccessClose( vlc_object_t *p_this )
p_sys
->
pp_streams
[
i
]
->
p_capture_filter
->
Release
();
}
p_sys
->
p_graph
->
Release
();
#endif
/* Uninitialize OLE/COM */
CoUninitialize
();
...
...
@@ -705,7 +704,7 @@ static int Read( input_thread_t * p_input, byte_t * p_buffer, size_t i_len )
}
/* Get new sample/frame from next stream */
//if( p_sream->sample.p_sample ) p_stream->sample.p_sample->Release();
//if( p_s
t
ream->sample.p_sample ) p_stream->sample.p_sample->Release();
p_sys
->
i_current_stream
=
(
p_sys
->
i_current_stream
+
1
)
%
p_sys
->
i_streams
;
p_stream
=
p_sys
->
pp_streams
[
p_sys
->
i_current_stream
];
...
...
modules/access/dshow/filter.cpp
View file @
25763b6a
...
...
@@ -2,7 +2,7 @@
* filter.c : DirectShow access module for vlc
*****************************************************************************
* Copyright (C) 2002 VideoLAN
* $Id: filter.cpp,v 1.
2 2003/08/25 21:45:04
gbazin Exp $
* $Id: filter.cpp,v 1.
3 2003/08/26 19:14:10
gbazin Exp $
*
* Author: Gildas Bazin <gbazin@netcourrier.com>
*
...
...
@@ -180,11 +180,13 @@ STDMETHODIMP CapturePin::QueryInterface(REFIID riid, void **ppv)
if
(
riid
==
IID_IUnknown
||
riid
==
IID_IPin
)
{
AddRef
();
*
ppv
=
(
IPin
*
)
this
;
return
NOERROR
;
}
if
(
riid
==
IID_IMemInputPin
)
{
AddRef
();
*
ppv
=
(
IMemInputPin
*
)
this
;
return
NOERROR
;
}
...
...
@@ -200,8 +202,7 @@ STDMETHODIMP_(ULONG) CapturePin::AddRef()
msg_Dbg
(
p_input
,
"CapturePin::AddRef"
);
#endif
i_ref
++
;
return
NOERROR
;
return
i_ref
++
;
};
STDMETHODIMP_
(
ULONG
)
CapturePin
::
Release
()
{
...
...
@@ -212,7 +213,7 @@ STDMETHODIMP_(ULONG) CapturePin::Release()
i_ref
--
;
if
(
!
i_ref
)
delete
this
;
return
NOERROR
;
return
i_ref
;
};
/* IPin methods */
...
...
@@ -252,6 +253,8 @@ STDMETHODIMP CapturePin::ConnectedTo( IPin **pPin )
msg_Dbg
(
p_input
,
"CapturePin::ConnectedTo"
);
#endif
if
(
!
p_connected_pin
)
return
VFW_E_NOT_CONNECTED
;
p_connected_pin
->
AddRef
();
*
pPin
=
p_connected_pin
;
...
...
@@ -452,21 +455,25 @@ STDMETHODIMP CaptureFilter::QueryInterface( REFIID riid, void **ppv )
if
(
riid
==
IID_IUnknown
)
{
AddRef
();
*
ppv
=
(
IUnknown
*
)
this
;
return
NOERROR
;
}
if
(
riid
==
IID_IPersist
)
{
AddRef
();
*
ppv
=
(
IPersist
*
)
this
;
return
NOERROR
;
}
if
(
riid
==
IID_IMediaFilter
)
{
AddRef
();
*
ppv
=
(
IMediaFilter
*
)
this
;
return
NOERROR
;
}
if
(
riid
==
IID_IBaseFilter
)
{
AddRef
();
*
ppv
=
(
IBaseFilter
*
)
this
;
return
NOERROR
;
}
...
...
@@ -482,8 +489,7 @@ STDMETHODIMP_(ULONG) CaptureFilter::AddRef()
msg_Dbg
(
p_input
,
"CaptureFilter::AddRef"
);
#endif
i_ref
++
;
return
NOERROR
;
return
i_ref
++
;
};
STDMETHODIMP_
(
ULONG
)
CaptureFilter
::
Release
()
{
...
...
@@ -494,7 +500,7 @@ STDMETHODIMP_(ULONG) CaptureFilter::Release()
i_ref
--
;
if
(
!
i_ref
)
delete
this
;
return
NOERROR
;
return
i_ref
;
};
/* IPersist method */
...
...
@@ -646,6 +652,7 @@ STDMETHODIMP CaptureEnumPins::QueryInterface( REFIID riid, void **ppv )
if
(
riid
==
IID_IUnknown
||
riid
==
IID_IEnumPins
)
{
AddRef
();
*
ppv
=
(
IEnumPins
*
)
this
;
return
NOERROR
;
}
...
...
@@ -661,8 +668,7 @@ STDMETHODIMP_(ULONG) CaptureEnumPins::AddRef()
msg_Dbg
(
p_input
,
"CaptureEnumPins::AddRef"
);
#endif
i_ref
++
;
return
NOERROR
;
return
i_ref
++
;
};
STDMETHODIMP_
(
ULONG
)
CaptureEnumPins
::
Release
()
{
...
...
@@ -673,7 +679,7 @@ STDMETHODIMP_(ULONG) CaptureEnumPins::Release()
i_ref
--
;
if
(
!
i_ref
)
delete
this
;
return
NOERROR
;
return
i_ref
;
};
/* IEnumPins */
...
...
@@ -693,10 +699,9 @@ STDMETHODIMP CaptureEnumPins::Next( ULONG cPins, IPin ** ppPins,
pPin
->
AddRef
();
*
pcFetched
=
1
;
i_position
++
;
return
NOERROR
;
}
return
S_FALSE
;
return
*
pcFetched
==
cPins
?
NOERROR
:
S_FALSE
;
};
STDMETHODIMP
CaptureEnumPins
::
Skip
(
ULONG
cPins
)
{
...
...
@@ -772,6 +777,7 @@ STDMETHODIMP CaptureEnumMediaTypes::QueryInterface( REFIID riid, void **ppv )
if
(
riid
==
IID_IUnknown
||
riid
==
IID_IEnumMediaTypes
)
{
AddRef
();
*
ppv
=
(
IEnumMediaTypes
*
)
this
;
return
NOERROR
;
}
...
...
@@ -787,8 +793,7 @@ STDMETHODIMP_(ULONG) CaptureEnumMediaTypes::AddRef()
msg_Dbg
(
p_input
,
"CaptureEnumMediaTypes::AddRef"
);
#endif
i_ref
++
;
return
NOERROR
;
return
i_ref
++
;
};
STDMETHODIMP_
(
ULONG
)
CaptureEnumMediaTypes
::
Release
()
{
...
...
@@ -799,7 +804,7 @@ STDMETHODIMP_(ULONG) CaptureEnumMediaTypes::Release()
i_ref
--
;
if
(
!
i_ref
)
delete
this
;
return
NOERROR
;
return
i_ref
;
};
/* IEnumMediaTypes */
...
...
@@ -833,7 +838,7 @@ STDMETHODIMP CaptureEnumMediaTypes::Skip( ULONG cMediaTypes )
msg_Dbg
(
p_input
,
"CaptureEnumMediaTypes::Skip"
);
#endif
if
(
cMediaTypes
>
1
)
if
(
cMediaTypes
>
0
)
{
return
S_FALSE
;
}
...
...
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