1 /*****************************************************************************
2 * vlccontrol.cpp: ActiveX control for VLC
3 *****************************************************************************
4 * Copyright (C) 2005 the VideoLAN team
6 * Authors: Damien Fouilleul <Damien.Fouilleul@laposte.net>
7 * Jean-Paul Saman <jpsaman@videolan.org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22 *****************************************************************************/
25 #include "vlccontrol.h"
31 VLCControl::~VLCControl()
34 _p_typeinfo->Release();
37 HRESULT VLCControl::getTypeInfo(void)
40 if( NULL == _p_typeinfo )
44 hr = _p_instance->getTypeLib(LOCALE_USER_DEFAULT, &p_typelib);
47 hr = p_typelib->GetTypeInfoOfGuid(IID_IVLCControl, &_p_typeinfo);
58 STDMETHODIMP VLCControl::GetTypeInfoCount(UINT* pctInfo)
63 if( SUCCEEDED(getTypeInfo()) )
71 STDMETHODIMP VLCControl::GetTypeInfo(UINT iTInfo, LCID lcid, LPTYPEINFO* ppTInfo)
76 if( SUCCEEDED(getTypeInfo()) )
78 _p_typeinfo->AddRef();
79 *ppTInfo = _p_typeinfo;
86 STDMETHODIMP VLCControl::GetIDsOfNames(REFIID riid, LPOLESTR* rgszNames,
87 UINT cNames, LCID lcid, DISPID* rgDispID)
89 if( SUCCEEDED(getTypeInfo()) )
91 return DispGetIDsOfNames(_p_typeinfo, rgszNames, cNames, rgDispID);
96 STDMETHODIMP VLCControl::Invoke(DISPID dispIdMember, REFIID riid,
97 LCID lcid, WORD wFlags, DISPPARAMS* pDispParams,
98 VARIANT* pVarResult, EXCEPINFO* pExcepInfo, UINT* puArgErr)
100 if( SUCCEEDED(getTypeInfo()) )
102 return DispInvoke(this, _p_typeinfo, dispIdMember, wFlags, pDispParams,
103 pVarResult, pExcepInfo, puArgErr);
108 STDMETHODIMP VLCControl::get_Visible(VARIANT_BOOL *isVisible)
110 if( NULL == isVisible )
113 *isVisible = _p_instance->getVisible() ? VARIANT_TRUE : VARIANT_FALSE;
118 STDMETHODIMP VLCControl::put_Visible(VARIANT_BOOL isVisible)
120 _p_instance->setVisible(isVisible != VARIANT_FALSE);
125 STDMETHODIMP VLCControl::play(void)
127 libvlc_instance_t* p_libvlc;
128 HRESULT result = _p_instance->getVLC(&p_libvlc);
129 if( SUCCEEDED(result) )
131 libvlc_exception_t ex;
132 libvlc_exception_init(&ex);
134 libvlc_playlist_play(p_libvlc, -1, 0, NULL, &ex);
135 if( libvlc_exception_raised(&ex) )
137 _p_instance->setErrorInfo(IID_IVLCControl,
138 libvlc_exception_get_message(&ex));
139 libvlc_exception_clear(&ex);
142 _p_instance->fireOnPlayEvent();
148 STDMETHODIMP VLCControl::pause(void)
150 libvlc_instance_t* p_libvlc;
151 HRESULT result = _p_instance->getVLC(&p_libvlc);
152 if( SUCCEEDED(result) )
154 libvlc_exception_t ex;
155 libvlc_exception_init(&ex);
157 libvlc_playlist_pause(p_libvlc, &ex);
158 if( libvlc_exception_raised(&ex) )
160 _p_instance->setErrorInfo(IID_IVLCControl,
161 libvlc_exception_get_message(&ex));
162 libvlc_exception_clear(&ex);
165 _p_instance->fireOnPauseEvent();
171 STDMETHODIMP VLCControl::stop(void)
173 libvlc_instance_t* p_libvlc;
174 HRESULT result = _p_instance->getVLC(&p_libvlc);
175 if( SUCCEEDED(result) )
177 libvlc_exception_t ex;
178 libvlc_exception_init(&ex);
180 libvlc_playlist_stop(p_libvlc, &ex);
181 if( libvlc_exception_raised(&ex) )
183 _p_instance->setErrorInfo(IID_IVLCControl,
184 libvlc_exception_get_message(&ex));
185 libvlc_exception_clear(&ex);
190 _p_instance->fireOnStopEvent();
194 STDMETHODIMP VLCControl::get_Playing(VARIANT_BOOL *isPlaying)
196 if( NULL == isPlaying )
199 HRESULT result = NOERROR;
200 if( _p_instance->isRunning() )
202 libvlc_instance_t *p_libvlc;
203 result = _p_instance->getVLC(&p_libvlc);
204 if( SUCCEEDED(result) )
206 if( libvlc_playlist_isplaying(p_libvlc, NULL) )
207 *isPlaying = VARIANT_TRUE;
209 *isPlaying = VARIANT_FALSE;
213 *isPlaying = VARIANT_FALSE;
217 STDMETHODIMP VLCControl::get_Position(float *position)
219 if( NULL == position )
223 libvlc_instance_t* p_libvlc;
224 HRESULT result = E_UNEXPECTED;
225 result = _p_instance->getVLC(&p_libvlc);
226 if( SUCCEEDED(result) )
228 libvlc_exception_t ex;
229 libvlc_exception_init(&ex);
231 libvlc_media_player_t *p_md;
232 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
233 if( !libvlc_exception_raised(&ex) )
235 *position = libvlc_media_player_get_position(p_md, &ex);
236 libvlc_media_player_release(p_md);
237 if( ! libvlc_exception_raised(&ex) )
242 _p_instance->setErrorInfo(IID_IVLCControl,
243 libvlc_exception_get_message(&ex));
244 libvlc_exception_clear(&ex);
250 STDMETHODIMP VLCControl::put_Position(float position)
252 HRESULT result = E_UNEXPECTED;
253 libvlc_instance_t* p_libvlc;
254 result = _p_instance->getVLC(&p_libvlc);
255 if( SUCCEEDED(result) )
257 libvlc_exception_t ex;
258 libvlc_exception_init(&ex);
260 libvlc_media_player_t *p_md;
261 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
262 if( ! libvlc_exception_raised(&ex) )
264 libvlc_media_player_set_position(p_md, position, &ex);
265 libvlc_media_player_release(p_md);
266 if( ! libvlc_exception_raised(&ex) )
271 _p_instance->setErrorInfo(IID_IVLCControl,
272 libvlc_exception_get_message(&ex));
273 libvlc_exception_clear(&ex);
279 STDMETHODIMP VLCControl::get_Time(int *seconds)
281 if( NULL == seconds )
285 libvlc_instance_t* p_libvlc;
286 HRESULT result = _p_instance->getVLC(&p_libvlc);
287 if( SUCCEEDED(result) )
289 libvlc_exception_t ex;
290 libvlc_exception_init(&ex);
292 libvlc_media_player_t *p_md;
293 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
294 if( ! libvlc_exception_raised(&ex) )
296 *seconds = libvlc_media_player_get_time(p_md, &ex);
297 libvlc_media_player_release(p_md);
298 if( ! libvlc_exception_raised(&ex) )
303 _p_instance->setErrorInfo(IID_IVLCControl,
304 libvlc_exception_get_message(&ex));
305 libvlc_exception_clear(&ex);
311 STDMETHODIMP VLCControl::put_Time(int seconds)
313 /* setTime function of the plugin sets the time. */
314 _p_instance->setTime(seconds);
318 STDMETHODIMP VLCControl::shuttle(int seconds)
320 libvlc_instance_t* p_libvlc;
321 HRESULT result = _p_instance->getVLC(&p_libvlc);
322 if( SUCCEEDED(result) )
324 libvlc_exception_t ex;
325 libvlc_exception_init(&ex);
327 libvlc_media_player_t *p_md;
328 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
329 if( ! libvlc_exception_raised(&ex) )
331 if( seconds < 0 ) seconds = 0;
332 libvlc_media_player_set_time(p_md, (int64_t)seconds, &ex);
333 libvlc_media_player_release(p_md);
334 if( ! libvlc_exception_raised(&ex) )
339 _p_instance->setErrorInfo(IID_IVLCControl,
340 libvlc_exception_get_message(&ex));
341 libvlc_exception_clear(&ex);
348 STDMETHODIMP VLCControl::fullscreen(void)
350 HRESULT result = E_UNEXPECTED;
351 if( _p_instance->isRunning() )
353 libvlc_instance_t *p_libvlc;
354 result = _p_instance->getVLC(&p_libvlc);
355 if( SUCCEEDED(result) )
357 if( libvlc_playlist_isplaying(p_libvlc, NULL) )
359 libvlc_media_player_t *p_md =
360 libvlc_playlist_get_media_player(p_libvlc, NULL);
363 libvlc_toggle_fullscreen(p_md, NULL);
364 libvlc_media_player_release(p_md);
372 STDMETHODIMP VLCControl::get_Length(int *seconds)
374 if( NULL == seconds )
378 libvlc_instance_t* p_libvlc;
379 HRESULT result = _p_instance->getVLC(&p_libvlc);
380 if( SUCCEEDED(result) )
382 libvlc_exception_t ex;
383 libvlc_exception_init(&ex);
385 libvlc_media_player_t *p_md;
386 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
387 if( ! libvlc_exception_raised(&ex) )
389 *seconds = (double)libvlc_media_player_get_length(p_md, &ex);
390 libvlc_media_player_release(p_md);
391 if( ! libvlc_exception_raised(&ex) )
396 _p_instance->setErrorInfo(IID_IVLCControl,
397 libvlc_exception_get_message(&ex));
398 libvlc_exception_clear(&ex);
405 STDMETHODIMP VLCControl::playFaster(void)
409 HRESULT result = E_UNEXPECTED;
410 if( !_p_instance->isRunning() )
413 libvlc_instance_t* p_libvlc;
414 result = _p_instance->getVLC(&p_libvlc);
415 if( SUCCEEDED(result) )
417 libvlc_exception_t ex;
418 libvlc_exception_init(&ex);
420 libvlc_media_player_t *p_md;
421 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
422 if( ! libvlc_exception_raised(&ex) )
424 libvlc_media_player_set_rate(p_md, rate, &ex);
425 libvlc_media_player_release(p_md);
426 if( ! libvlc_exception_raised(&ex) )
431 _p_instance->setErrorInfo(IID_IVLCControl,
432 libvlc_exception_get_message(&ex));
433 libvlc_exception_clear(&ex);
439 STDMETHODIMP VLCControl::playSlower(void)
443 HRESULT result = E_UNEXPECTED;
444 if( !_p_instance->isRunning() )
447 libvlc_instance_t* p_libvlc;
448 result = _p_instance->getVLC(&p_libvlc);
449 if( SUCCEEDED(result) )
451 libvlc_exception_t ex;
452 libvlc_exception_init(&ex);
454 libvlc_media_player_t *p_md;
455 p_md = libvlc_playlist_get_media_player(p_libvlc, &ex);
456 if( ! libvlc_exception_raised(&ex) )
458 libvlc_media_player_set_rate(p_md, rate, &ex);
459 libvlc_media_player_release(p_md);
460 if( ! libvlc_exception_raised(&ex) )
465 _p_instance->setErrorInfo(IID_IVLCControl,
466 libvlc_exception_get_message(&ex));
467 libvlc_exception_clear(&ex);
473 STDMETHODIMP VLCControl::get_Volume(int *volume)
478 *volume = _p_instance->getVolume();
482 STDMETHODIMP VLCControl::put_Volume(int volume)
484 _p_instance->setVolume(volume);
488 STDMETHODIMP VLCControl::toggleMute(void)
490 libvlc_instance_t* p_libvlc;
491 HRESULT result = _p_instance->getVLC(&p_libvlc);
492 if( SUCCEEDED(result) )
494 libvlc_exception_t ex;
495 libvlc_exception_init(&ex);
497 libvlc_audio_toggle_mute(p_libvlc, &ex);
498 if( libvlc_exception_raised(&ex) )
500 _p_instance->setErrorInfo(IID_IVLCControl,
501 libvlc_exception_get_message(&ex));
502 libvlc_exception_clear(&ex);
510 STDMETHODIMP VLCControl::setVariable(BSTR name, VARIANT value)
514 if( 0 == SysStringLen(name) )
517 libvlc_instance_t *p_libvlc;
518 HRESULT hr = _p_instance->getVLC(&p_libvlc);
521 int codePage = _p_instance->getCodePage();
522 char *psz_varname = CStrFromBSTR(codePage, name);
523 if( NULL == psz_varname )
524 return E_OUTOFMEMORY;
529 if( VLC_SUCCESS == VLC_VariableType(i_vlc, psz_varname, &i_type) )
537 hr = VariantChangeType(&arg, &value, 0, VT_BOOL);
539 val.b_bool = (VARIANT_TRUE == V_BOOL(&arg)) ? true : false;
542 case VLC_VAR_INTEGER:
544 hr = VariantChangeType(&arg, &value, 0, VT_I4);
546 val.i_int = V_I4(&arg);
550 hr = VariantChangeType(&arg, &value, 0, VT_R4);
552 val.f_float = V_R4(&arg);
558 case VLC_VAR_DIRECTORY:
559 case VLC_VAR_VARIABLE:
560 hr = VariantChangeType(&arg, &value, 0, VT_BSTR);
563 i_type = VLC_VAR_STRING;
564 val.psz_string = CStrFromBSTR(codePage, V_BSTR(&arg));
570 // use a double value to represent time (base is expressed in seconds)
571 hr = VariantChangeType(&arg, &value, 0, VT_R8);
573 val.i_time = (signed __int64)(V_R8(&arg)*1000000.0);
577 hr = DISP_E_TYPEMISMATCH;
581 // no defined type, use type in VARIANT
583 switch( V_VT(&value) )
586 val.b_bool = (VARIANT_TRUE == V_BOOL(&value)) ? true : false;
587 i_type = VLC_VAR_BOOL;
590 val.i_int = V_I4(&value);
591 i_type = VLC_VAR_INTEGER;
594 val.f_float = V_R4(&value);
595 i_type = VLC_VAR_FLOAT;
598 val.psz_string = CStrFromBSTR(codePage, V_BSTR(&value));
599 i_type = VLC_VAR_STRING;
602 // use a double value to represent time (base is expressed in seconds)
603 val.i_time = (signed __int64)(V_R8(&value)*1000000.0);
604 i_type = VLC_VAR_TIME;
607 hr = DISP_E_TYPEMISMATCH;
612 hr = (VLC_SUCCESS == VLC_VariableSet(i_vlc, psz_varname, val)) ? NOERROR : E_FAIL;
614 if( (VLC_VAR_STRING == i_type) && (NULL != val.psz_string) )
615 CoTaskMemFree(val.psz_string);
617 CoTaskMemFree(psz_varname);
623 STDMETHODIMP VLCControl::getVariable( BSTR name, VARIANT *value)
632 if( 0 == SysStringLen(name) )
635 libvlc_instance_t *p_libvlc;
636 HRESULT hr = _p_instance->getVLC(&p_libvlc);
639 UINT codePage = _p_instance->getCodePage();
640 char *psz_varname = CStrFromBSTR(codePage, name);
641 if( NULL == psz_varname )
642 return E_OUTOFMEMORY;
649 if( (VLC_SUCCESS == VLC_VariableGet(i_vlc, psz_varname, &val))
650 && (VLC_SUCCESS == VLC_VariableType(i_vlc, psz_varname, &i_type)) )
656 V_VT(value) = VT_BOOL;
657 V_BOOL(value) = val.b_bool ? VARIANT_TRUE : VARIANT_FALSE;
660 case VLC_VAR_INTEGER:
663 V_I4(value) = val.i_int;
668 V_R4(value) = val.f_float;
674 case VLC_VAR_DIRECTORY:
675 case VLC_VAR_VARIABLE:
676 V_VT(value) = VT_BSTR;
677 V_BSTR(value) = BSTRFromCStr(codePage, val.psz_string);
678 if( NULL != val.psz_string)
679 free(val.psz_string);
683 // use a double value to represent time (base is expressed in seconds)
685 V_R8(value) = ((double)val.i_time)/1000000.0;
689 hr = DISP_E_TYPEMISMATCH;
692 CoTaskMemFree(psz_varname);
699 void VLCControl::FreeTargetOptions(char **cOptions, int cOptionCount)
702 if( NULL != cOptions )
704 for( int pos=0; pos<cOptionCount; ++pos )
706 char *cOption = cOptions[pos];
707 if( NULL != cOption )
708 CoTaskMemFree(cOption);
712 CoTaskMemFree(cOptions);
716 static HRESULT parseStringOptions(int codePage, BSTR bstr, char*** cOptions, int *cOptionCount)
718 HRESULT hr = E_INVALIDARG;
719 if( SysStringLen(bstr) > 0 )
722 char *s = CStrFromBSTR(codePage, bstr);
727 char **options = (char **)CoTaskMemAlloc(capacity*sizeof(char *));
732 char *end = val + strlen(val);
735 // skip leading blanks
737 && ((*val == ' ' ) || (*val == '\t')) )
741 // skip till we get a blank character
747 if( ('\'' == c) || ('"' == c) )
749 // skip till end of string
750 while( (val < end) && (*(val++) != c ) );
756 if( nOptions == capacity )
759 char **moreOptions = (char **)CoTaskMemRealloc(options, capacity*sizeof(char*));
762 /* failed to allocate more memory */
764 /* return what we got so far */
765 *cOptionCount = nOptions;
769 options = moreOptions;
772 options[nOptions] = (char *)CoTaskMemAlloc(val-start);
773 if( options[nOptions] )
775 memcpy(options[nOptions], start, val-start);
780 /* failed to allocate memory */
782 /* return what we got so far */
783 *cOptionCount = nOptions;
789 // must be end of string
792 *cOptionCount = nOptions;
802 HRESULT VLCControl::CreateTargetOptions(int codePage, VARIANT *options, char ***cOptions, int *cOptionCount)
804 HRESULT hr = E_INVALIDARG;
805 if( VT_ERROR == V_VT(options) )
807 if( DISP_E_PARAMNOTFOUND == V_ERROR(options) )
809 // optional parameter not set
815 else if( (VT_EMPTY == V_VT(options)) || (VT_NULL == V_VT(options)) )
822 else if( VT_DISPATCH == V_VT(options) )
824 // if object is a collection, retrieve enumerator
826 V_VT(&colEnum) = VT_UNKNOWN;
827 hr = GetObjectProperty(V_DISPATCH(options), DISPID_NEWENUM, colEnum);
830 IEnumVARIANT *enumVar;
831 hr = V_UNKNOWN(&colEnum)->QueryInterface(IID_IEnumVARIANT, (LPVOID *)&enumVar);
838 *cOptions = (char **)CoTaskMemAlloc(capacity*sizeof(char *));
839 if( NULL != *cOptions )
841 ZeroMemory(*cOptions, sizeof(char *)*capacity);
842 while( SUCCEEDED(hr) && (S_OK == enumVar->Next(1, &option, NULL)) )
844 if( VT_BSTR == V_VT(&option) )
846 char *cOption = CStrFromBSTR(codePage, V_BSTR(&option));
847 (*cOptions)[pos] = cOption;
848 if( NULL != cOption )
851 if( pos == capacity )
853 char **moreOptions = (char **)CoTaskMemRealloc(*cOptions, (capacity+16)*sizeof(char *));
854 if( NULL != moreOptions )
856 ZeroMemory(moreOptions+capacity, sizeof(char *)*16);
858 *cOptions = moreOptions;
865 hr = ( SysStringLen(V_BSTR(&option)) > 0 ) ?
866 E_OUTOFMEMORY : E_INVALIDARG;
871 VariantClear(&option);
876 // free already processed elements
877 FreeTargetOptions(*cOptions, *cOptionCount);
888 // coerce object into a string and parse it
890 VariantInit(&v_name);
891 hr = VariantChangeType(&v_name, options, 0, VT_BSTR);
894 hr = parseStringOptions(codePage, V_BSTR(&v_name), cOptions, cOptionCount);
895 VariantClear(&v_name);
899 else if( V_ISARRAY(options) )
902 SAFEARRAY *array = V_ISBYREF(options) ? *V_ARRAYREF(options) : V_ARRAY(options);
904 if( SafeArrayGetDim(array) != 1 )
909 SafeArrayGetLBound(array, 1, &lBound);
910 SafeArrayGetUBound(array, 1, &uBound);
912 // have we got any options
913 if( uBound >= lBound )
916 hr = SafeArrayGetVartype(array, &vType);
922 // marshall options into an array of C strings
923 if( VT_VARIANT == vType )
925 *cOptions = (char **)CoTaskMemAlloc(sizeof(char *)*(uBound-lBound+1));
926 if( NULL == *cOptions )
927 return E_OUTOFMEMORY;
929 ZeroMemory(*cOptions, sizeof(char *)*(uBound-lBound+1));
930 for(pos=lBound; (pos<=uBound) && SUCCEEDED(hr); ++pos )
933 hr = SafeArrayGetElement(array, &pos, &option);
936 if( VT_BSTR == V_VT(&option) )
938 char *cOption = CStrFromBSTR(codePage, V_BSTR(&option));
939 (*cOptions)[pos-lBound] = cOption;
940 if( NULL == cOption )
941 hr = ( SysStringLen(V_BSTR(&option)) > 0 ) ?
942 E_OUTOFMEMORY : E_INVALIDARG;
946 VariantClear(&option);
950 else if( VT_BSTR == vType )
952 *cOptions = (char **)CoTaskMemAlloc(sizeof(char *)*(uBound-lBound+1));
953 if( NULL == *cOptions )
954 return E_OUTOFMEMORY;
956 ZeroMemory(*cOptions, sizeof(char *)*(uBound-lBound+1));
957 for(pos=lBound; (pos<=uBound) && SUCCEEDED(hr); ++pos )
960 hr = SafeArrayGetElement(array, &pos, &option);
963 char *cOption = CStrFromBSTR(codePage, option);
965 (*cOptions)[pos-lBound] = cOption;
966 if( NULL == cOption )
967 hr = ( SysStringLen(option) > 0 ) ?
968 E_OUTOFMEMORY : E_INVALIDARG;
969 SysFreeString(option);
979 *cOptionCount = pos-lBound;
982 // free already processed elements
983 FreeTargetOptions(*cOptions, *cOptionCount);
994 else if( VT_UNKNOWN == V_VT(options) )
996 // coerce object into a string and parse it
998 VariantInit(&v_name);
999 hr = VariantChangeType(&v_name, options, 0, VT_BSTR);
1002 hr = parseStringOptions(codePage, V_BSTR(&v_name), cOptions, cOptionCount);
1003 VariantClear(&v_name);
1006 else if( VT_BSTR == V_VT(options) )
1008 hr = parseStringOptions(codePage, V_BSTR(options), cOptions, cOptionCount);
1014 ** use VARIANT rather than a SAFEARRAY as argument type
1015 ** for compatibility with some scripting language (JScript)
1018 STDMETHODIMP VLCControl::addTarget(BSTR uri, VARIANT options, enum VLCPlaylistMode mode, int position)
1020 if( 0 == SysStringLen(uri) )
1021 return E_INVALIDARG;
1023 libvlc_instance_t *p_libvlc;
1024 HRESULT hr = _p_instance->getVLC(&p_libvlc);
1027 char *cUri = CStrFromBSTR(CP_UTF8, uri);
1029 return E_OUTOFMEMORY;
1034 if( FAILED(CreateTargetOptions(CP_UTF8, &options, &cOptions, &cOptionsCount)) )
1035 return E_INVALIDARG;
1037 libvlc_exception_t ex;
1038 libvlc_exception_init(&ex);
1040 position = libvlc_playlist_add_extended(p_libvlc, cUri, cUri,
1042 const_cast<const char**>(cOptions),
1045 FreeTargetOptions(cOptions, cOptionsCount);
1046 CoTaskMemFree(cUri);
1048 if( libvlc_exception_raised(&ex) )
1050 _p_instance->setErrorInfo(IID_IVLCPlaylist,
1051 libvlc_exception_get_message(&ex));
1052 libvlc_exception_clear(&ex);
1054 if( mode & VLCPlayListAppendAndGo )
1055 _p_instance->fireOnStopEvent();
1059 if( mode & VLCPlayListAppendAndGo )
1060 _p_instance->fireOnPlayEvent();
1066 STDMETHODIMP VLCControl::get_PlaylistIndex(int *index)
1068 return E_INVALIDARG;
1073 libvlc_instance_t *p_libvlc;
1074 HRESULT result = _p_instance->getVLC(&p_libvlc);
1075 if( SUCCEEDED(result) )
1077 *index = VLC_PlaylistIndex(i_vlc);
1085 STDMETHODIMP VLCControl::get_PlaylistCount(int *count)
1091 libvlc_instance_t* p_libvlc;
1092 HRESULT result = _p_instance->getVLC(&p_libvlc);
1093 if( SUCCEEDED(result) )
1095 libvlc_exception_t ex;
1096 libvlc_exception_init(&ex);
1098 *count = libvlc_playlist_items_count(p_libvlc, &ex);
1099 if( libvlc_exception_raised(&ex) )
1101 _p_instance->setErrorInfo(IID_IVLCControl,
1102 libvlc_exception_get_message(&ex));
1103 libvlc_exception_clear(&ex);
1111 STDMETHODIMP VLCControl::playlistNext(void)
1113 libvlc_instance_t* p_libvlc;
1114 HRESULT result = _p_instance->getVLC(&p_libvlc);
1115 if( SUCCEEDED(result) )
1117 libvlc_exception_t ex;
1118 libvlc_exception_init(&ex);
1120 libvlc_playlist_next(p_libvlc, &ex);
1121 if( libvlc_exception_raised(&ex) )
1123 _p_instance->setErrorInfo(IID_IVLCControl,
1124 libvlc_exception_get_message(&ex));
1125 libvlc_exception_clear(&ex);
1133 STDMETHODIMP VLCControl::playlistPrev(void)
1135 libvlc_instance_t* p_libvlc;
1136 HRESULT result = _p_instance->getVLC(&p_libvlc);
1137 if( SUCCEEDED(result) )
1139 libvlc_exception_t ex;
1140 libvlc_exception_init(&ex);
1142 libvlc_playlist_prev(p_libvlc, &ex);
1143 if( libvlc_exception_raised(&ex) )
1145 _p_instance->setErrorInfo(IID_IVLCControl,
1146 libvlc_exception_get_message(&ex));
1147 libvlc_exception_clear(&ex);
1155 STDMETHODIMP VLCControl::playlistClear(void)
1157 libvlc_instance_t* p_libvlc;
1158 HRESULT result = _p_instance->getVLC(&p_libvlc);
1159 if( SUCCEEDED(result) )
1161 libvlc_exception_t ex;
1162 libvlc_exception_init(&ex);
1164 libvlc_playlist_clear(p_libvlc, &ex);
1165 if( libvlc_exception_raised(&ex) )
1167 _p_instance->setErrorInfo(IID_IVLCControl,
1168 libvlc_exception_get_message(&ex));
1169 libvlc_exception_clear(&ex);
1177 STDMETHODIMP VLCControl::get_VersionInfo(BSTR *version)
1179 if( NULL == version )
1182 const char *versionStr = libvlc_get_version();
1183 if( NULL != versionStr )
1185 *version = BSTRFromCStr(CP_UTF8, versionStr);
1186 return (NULL == *version) ? E_OUTOFMEMORY : NOERROR;
1192 STDMETHODIMP VLCControl::get_MRL(BSTR *mrl)
1197 *mrl = SysAllocStringLen(_p_instance->getMRL(),
1198 SysStringLen(_p_instance->getMRL()));
1202 STDMETHODIMP VLCControl::put_MRL(BSTR mrl)
1204 _p_instance->setMRL(mrl);
1209 STDMETHODIMP VLCControl::get_AutoPlay(VARIANT_BOOL *autoplay)
1211 if( NULL == autoplay )
1214 *autoplay = _p_instance->getAutoPlay() ? VARIANT_TRUE: VARIANT_FALSE;
1218 STDMETHODIMP VLCControl::put_AutoPlay(VARIANT_BOOL autoplay)
1220 _p_instance->setAutoPlay((VARIANT_FALSE != autoplay) ? TRUE: FALSE);
1224 STDMETHODIMP VLCControl::get_AutoLoop(VARIANT_BOOL *autoloop)
1226 if( NULL == autoloop )
1229 *autoloop = _p_instance->getAutoLoop() ? VARIANT_TRUE: VARIANT_FALSE;
1233 STDMETHODIMP VLCControl::put_AutoLoop(VARIANT_BOOL autoloop)
1235 _p_instance->setAutoLoop((VARIANT_FALSE != autoloop) ? TRUE: FALSE);