Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
592c1efc
Commit
592c1efc
authored
Feb 01, 2010
by
Pierre d'Herbemont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
macosx/framework: Get rid of VLCMediaListAspect, and remove a bunch of exception.
parent
cb9e605b
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
56 additions
and
662 deletions
+56
-662
projects/macosx/framework/Headers/Internal/VLCLibVLCBridging.h
...cts/macosx/framework/Headers/Internal/VLCLibVLCBridging.h
+3
-32
projects/macosx/framework/Headers/Public/VLCKit.h
projects/macosx/framework/Headers/Public/VLCKit.h
+0
-1
projects/macosx/framework/Headers/Public/VLCMediaList.h
projects/macosx/framework/Headers/Public/VLCMediaList.h
+0
-19
projects/macosx/framework/Headers/Public/VLCMediaListAspect.h
...ects/macosx/framework/Headers/Public/VLCMediaListAspect.h
+0
-52
projects/macosx/framework/Sources/VLCAudio.m
projects/macosx/framework/Sources/VLCAudio.m
+1
-1
projects/macosx/framework/Sources/VLCLibrary.m
projects/macosx/framework/Sources/VLCLibrary.m
+13
-14
projects/macosx/framework/Sources/VLCMediaList.m
projects/macosx/framework/Sources/VLCMediaList.m
+0
-38
projects/macosx/framework/Sources/VLCMediaListAspect.m
projects/macosx/framework/Sources/VLCMediaListAspect.m
+0
-330
projects/macosx/framework/Sources/VLCMediaListPlayer.m
projects/macosx/framework/Sources/VLCMediaListPlayer.m
+1
-4
projects/macosx/framework/Sources/VLCMediaPlayer.m
projects/macosx/framework/Sources/VLCMediaPlayer.m
+38
-163
projects/macosx/framework/VLCKit.xcodeproj/project.pbxproj
projects/macosx/framework/VLCKit.xcodeproj/project.pbxproj
+0
-8
No files found.
projects/macosx/framework/Headers/Internal/VLCLibVLCBridging.h
View file @
592c1efc
...
@@ -23,14 +23,13 @@
...
@@ -23,14 +23,13 @@
*****************************************************************************/
*****************************************************************************/
#import "VLCLibrary.h"
#import "VLCLibrary.h"
#import "VLCMediaListAspect.h"
#import "VLCStreamOutput.h"
#import "VLCStreamOutput.h"
#import "VLCMediaPlayer.h"
#import "VLCMediaPlayer.h"
/* Utility functions */
/* Utility functions */
/**
/**
* \function catch_execption( ex )
* \function catch_execption( ex )
* Utility function that catches a LibVLC generated exception by throwing a Cocoa based NSException.
* Utility function that catches a LibVLC generated exception by throwing a Cocoa based NSException.
* \param ex LibVLC exception returned by LibVLC internal functions.
* \param ex LibVLC exception returned by LibVLC internal functions.
*/
*/
#define catch_exception( ex ) __catch_exception( (void *)(ex), __FUNCTION__, __FILE__, __LINE__ )
#define catch_exception( ex ) __catch_exception( (void *)(ex), __FUNCTION__, __FILE__, __LINE__ )
...
@@ -44,7 +43,7 @@ extern void __catch_exception( void * e, const char * function, const char * fil
...
@@ -44,7 +43,7 @@ extern void __catch_exception( void * e, const char * function, const char * fil
/**
/**
* Manufactures new object wrapped around specified media list.
* Manufactures new object wrapped around specified media list.
* \param p_new_mlist LibVLC media list pointer.
* \param p_new_mlist LibVLC media list pointer.
* \return Newly create media list instance using specified media list
* \return Newly create media list instance using specified media list
* pointer.
* pointer.
*/
*/
+
(
id
)
mediaListWithLibVLCMediaList
:(
void
*
)
p_new_mlist
;
+
(
id
)
mediaListWithLibVLCMediaList
:(
void
*
)
p_new_mlist
;
...
@@ -129,41 +128,13 @@ extern void __catch_exception( void * e, const char * function, const char * fil
...
@@ -129,41 +128,13 @@ extern void __catch_exception( void * e, const char * function, const char * fil
@property
(
readonly
)
void
*
instance
;
@property
(
readonly
)
void
*
instance
;
@end
@end
/**
* Bridges functionality between VLCMediaListAspect and libvlc.
*/
@interface
VLCMediaListAspect
(
VLCLibVLCBridging
)
/* Factories */
/**
* Manufactures a new media list aspect object with libvlc media list view instance.
* \return Newly created media list aspect using specified libvlc media list view.
*/
+
(
id
)
mediaListAspectWithLibVLCMediaListView
:(
libvlc_media_list_view_t
*
)
p_new_mlv
;
/**
* Manufactures a new media list aspect object with libvlc media list view instance.
* \return Newly created media list aspect using specified libvlc media list view.
*/
+
(
id
)
mediaListAspectWithLibVLCMediaListView
:(
libvlc_media_list_view_t
*
)
p_new_mlv
andMediaList
:(
VLCMediaList
*
)
mediaList
;
/* Initializers */
/**
* Initializes a new media list aspect object with libvlc media list view instance.
* \return Newly created media list aspect using specified libvlc media list view.
*/
-
(
id
)
initWithLibVLCMediaListView
:(
libvlc_media_list_view_t
*
)
p_new_mlv
andMediaList
:(
VLCMediaList
*
)
mediaList
;
/* Properties */
@property
(
readonly
)
libvlc_media_list_view_t
*
libVLCMediaListView
;
//< Libvlc pointer to media list view instance.
@end
/**
/**
* Bridges functionality between VLCLibrary and VLCAudio.
* Bridges functionality between VLCLibrary and VLCAudio.
*/
*/
@interface
VLCLibrary
(
VLCAudioBridging
)
@interface
VLCLibrary
(
VLCAudioBridging
)
/**
/**
* Called by VLCAudio, each library has a singleton VLCaudio instance. VLCAudio
* Called by VLCAudio, each library has a singleton VLCaudio instance. VLCAudio
* calls this function to let the VLCLibrary instance know how to get in touch
* calls this function to let the VLCLibrary instance know how to get in touch
* with the VLCAudio instance. TODO: Each media player instance should have it's
* with the VLCAudio instance. TODO: Each media player instance should have it's
* own audio instance...not each library instance.
* own audio instance...not each library instance.
*/
*/
...
...
projects/macosx/framework/Headers/Public/VLCKit.h
View file @
592c1efc
...
@@ -31,7 +31,6 @@
...
@@ -31,7 +31,6 @@
#import <VLCKit/VLCMediaLibrary.h>
#import <VLCKit/VLCMediaLibrary.h>
#import <VLCKit/VLCMediaList.h>
#import <VLCKit/VLCMediaList.h>
#import <VLCKit/VLCMediaListPlayer.h>
#import <VLCKit/VLCMediaListPlayer.h>
#import <VLCKit/VLCMediaListAspect.h>
#import <VLCKit/VLCMediaDiscoverer.h>
#import <VLCKit/VLCMediaDiscoverer.h>
#import <VLCKit/VLCMediaPlayer.h>
#import <VLCKit/VLCMediaPlayer.h>
#import <VLCKit/VLCTime.h>
#import <VLCKit/VLCTime.h>
...
...
projects/macosx/framework/Headers/Public/VLCMediaList.h
View file @
592c1efc
...
@@ -30,7 +30,6 @@ extern NSString * VLCMediaListItemDeleted;
...
@@ -30,7 +30,6 @@ extern NSString * VLCMediaListItemDeleted;
@class
VLCMedia
;
@class
VLCMedia
;
@class
VLCMediaList
;
@class
VLCMediaList
;
@class
VLCMediaListAspect
;
/**
/**
* TODO: Documentation VLCMediaListDelegate
* TODO: Documentation VLCMediaListDelegate
...
@@ -56,9 +55,6 @@ extern NSString * VLCMediaListItemDeleted;
...
@@ -56,9 +55,6 @@ extern NSString * VLCMediaListItemDeleted;
id
<
VLCMediaListDelegate
,
NSObject
>
delegate
;
//< Delegate object
id
<
VLCMediaListDelegate
,
NSObject
>
delegate
;
//< Delegate object
/* We need that private copy because of Cocoa Bindings, that need to be working on first thread */
/* We need that private copy because of Cocoa Bindings, that need to be working on first thread */
NSMutableArray
*
cachedMedia
;
//< Private copy of media objects.
NSMutableArray
*
cachedMedia
;
//< Private copy of media objects.
VLCMediaListAspect
*
flatAspect
;
//< TODO: Documentation VLCMediaList.flatAspect
VLCMediaListAspect
*
hierarchicalAspect
;
//< TODO: Documentation VLCMediaList.hierarchicalAspect
VLCMediaListAspect
*
hierarchicalNodeAspect
;
//< TODO: Documentation VLCMediaList.hierarchicalNodeAspect
}
}
/* Operations */
/* Operations */
...
@@ -113,19 +109,4 @@ extern NSString * VLCMediaListItemDeleted;
...
@@ -113,19 +109,4 @@ extern NSString * VLCMediaListItemDeleted;
*/
*/
@property
(
readonly
)
BOOL
isReadOnly
;
@property
(
readonly
)
BOOL
isReadOnly
;
/* Media list aspect */
/**
* TODO: Documentation VLCMediaList.hierarchicalAspect
*/
@property
(
readonly
)
VLCMediaListAspect
*
hierarchicalAspect
;
/**
* TODO: Documentation VLCMediaList.hierarchicalNodeAspect
*/
@property
(
readonly
)
VLCMediaListAspect
*
hierarchicalNodeAspect
;
/**
* TODO: Documentation VLCMediaList.flatAspect
*/
@property
(
readonly
)
VLCMediaListAspect
*
flatAspect
;
@end
@end
projects/macosx/framework/Headers/Public/VLCMediaListAspect.h
deleted
100644 → 0
View file @
cb9e605b
/*****************************************************************************
* VLCMediaLisAspect.h: VLCKit.framework VLCMediaLisAspect header
*****************************************************************************
* Copyright (C) 2007 Pierre d'Herbemont
* Copyright (C) 2007 the VideoLAN team
* $Id$
*
* Authors: Pierre d'Herbemont <pdherbemont # videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#import "VLCMediaList.h"
@class
VLCMedia
;
@class
VLCMediaList
;
@interface
VLCMediaListAspectNode
:
NSObject
{
VLCMedia
*
media
;
VLCMediaListAspect
*
children
;
}
@property
(
retain
)
VLCMedia
*
media
;
@property
(
retain
)
VLCMediaListAspect
*
children
;
-
(
BOOL
)
isLeaf
;
@end
@interface
VLCMediaListAspect
:
NSObject
{
void
*
p_mlv
;
//< Internal instance of media list view
NSMutableArray
*
cachedNode
;
VLCMediaList
*
parentMediaList
;
BOOL
ownHisMediaList
;
}
-
(
VLCMedia
*
)
mediaAtIndex
:(
NSInteger
)
index
;
-
(
VLCMediaListAspectNode
*
)
nodeAtIndex
:(
NSInteger
)
index
;
-
(
NSInteger
)
count
;
-
(
VLCMediaList
*
)
parentMediaList
;
@end
projects/macosx/framework/Sources/VLCAudio.m
View file @
592c1efc
...
@@ -68,7 +68,7 @@ NSString * VLCMediaPlayerVolumeChanged = @"VLCMediaPlayerVolumeChanged";
...
@@ -68,7 +68,7 @@ NSString * VLCMediaPlayerVolumeChanged = @"VLCMediaPlayerVolumeChanged";
value
=
VOLUME_MIN
;
value
=
VOLUME_MIN
;
else
if
(
value
>
VOLUME_MAX
)
else
if
(
value
>
VOLUME_MAX
)
value
=
VOLUME_MAX
;
value
=
VOLUME_MAX
;
libvlc_audio_set_volume
([
library
instance
],
value
,
NULL
);
libvlc_audio_set_volume
([
library
instance
],
value
);
}
}
-
(
void
)
volumeUp
-
(
void
)
volumeUp
...
...
projects/macosx/framework/Sources/VLCLibrary.m
View file @
592c1efc
...
@@ -41,7 +41,7 @@ void __catch_exception( void * e, const char * function, const char * file, int
...
@@ -41,7 +41,7 @@ void __catch_exception( void * e, const char * function, const char * file, int
{
{
NSException
*
libvlcException
=
[
NSException
NSException
*
libvlcException
=
[
NSException
exceptionWithName:
@"LibVLCException"
exceptionWithName:
@"LibVLCException"
reason:
[
NSString
stringWithFormat
:
@"libvlc has thrown us an error: %s (%s:%d %s)"
,
reason:
[
NSString
stringWithFormat
:
@"libvlc has thrown us an error: %s (%s:%d %s)"
,
libvlc_errmsg
(),
file
,
line_number
,
function
]
libvlc_errmsg
(),
file
,
line_number
,
function
]
userInfo:
nil
];
userInfo:
nil
];
libvlc_exception_clear
(
ex
);
libvlc_exception_clear
(
ex
);
...
@@ -52,7 +52,7 @@ void __catch_exception( void * e, const char * function, const char * file, int
...
@@ -52,7 +52,7 @@ void __catch_exception( void * e, const char * function, const char * file, int
@implementation
VLCLibrary
@implementation
VLCLibrary
+
(
VLCLibrary
*
)
sharedLibrary
+
(
VLCLibrary
*
)
sharedLibrary
{
{
if
(
!
sharedLibrary
)
if
(
!
sharedLibrary
)
{
{
/* Initialize a shared instance */
/* Initialize a shared instance */
sharedLibrary
=
[[
self
alloc
]
init
];
sharedLibrary
=
[[
self
alloc
]
init
];
...
@@ -60,13 +60,13 @@ void __catch_exception( void * e, const char * function, const char * file, int
...
@@ -60,13 +60,13 @@ void __catch_exception( void * e, const char * function, const char * file, int
return
sharedLibrary
;
return
sharedLibrary
;
}
}
-
(
id
)
init
-
(
id
)
init
{
{
if
(
self
=
[
super
init
])
if
(
self
=
[
super
init
])
{
{
libvlc_exception_t
ex
;
libvlc_exception_t
ex
;
libvlc_exception_init
(
&
ex
);
libvlc_exception_init
(
&
ex
);
NSArray
*
vlcParams
=
[[
NSBundle
mainBundle
]
objectForInfoDictionaryKey
:
@"VLCParams"
];
NSArray
*
vlcParams
=
[[
NSBundle
mainBundle
]
objectForInfoDictionaryKey
:
@"VLCParams"
];
if
(
!
vlcParams
)
{
if
(
!
vlcParams
)
{
NSMutableArray
*
defaultParams
=
[
NSMutableArray
array
];
NSMutableArray
*
defaultParams
=
[
NSMutableArray
array
];
...
@@ -93,8 +93,7 @@ void __catch_exception( void * e, const char * function, const char * file, int
...
@@ -93,8 +93,7 @@ void __catch_exception( void * e, const char * function, const char * file, int
lib_vlc_params
[
paramNum
]
=
[
vlcParam
cStringUsingEncoding
:
NSASCIIStringEncoding
];
lib_vlc_params
[
paramNum
]
=
[
vlcParam
cStringUsingEncoding
:
NSASCIIStringEncoding
];
paramNum
++
;
paramNum
++
;
}
}
instance
=
(
void
*
)
libvlc_new
(
sizeof
(
lib_vlc_params
)
/
sizeof
(
lib_vlc_params
[
0
]),
lib_vlc_params
,
&
ex
);
instance
=
(
void
*
)
libvlc_new
(
sizeof
(
lib_vlc_params
)
/
sizeof
(
lib_vlc_params
[
0
]),
lib_vlc_params
);
catch_exception
(
&
ex
);
NSAssert
(
instance
,
@"libvlc failed to initialize"
);
NSAssert
(
instance
,
@"libvlc failed to initialize"
);
// Assignment unneeded, as the audio unit will do it for us
// Assignment unneeded, as the audio unit will do it for us
...
@@ -103,24 +102,24 @@ void __catch_exception( void * e, const char * function, const char * file, int
...
@@ -103,24 +102,24 @@ void __catch_exception( void * e, const char * function, const char * file, int
return
self
;
return
self
;
}
}
-
(
NSString
*
)
version
-
(
NSString
*
)
version
{
{
return
[
NSString
stringWithUTF8String
:
libvlc_get_version
()];
return
[
NSString
stringWithUTF8String
:
libvlc_get_version
()];
}
}
-
(
NSString
*
)
changeset
-
(
NSString
*
)
changeset
{
{
return
[
NSString
stringWithUTF8String
:
libvlc_get_changeset
()];
return
[
NSString
stringWithUTF8String
:
libvlc_get_changeset
()];
}
}
-
(
void
)
dealloc
-
(
void
)
dealloc
{
{
if
(
instance
)
if
(
instance
)
libvlc_release
(
instance
);
libvlc_release
(
instance
);
if
(
self
==
sharedLibrary
)
if
(
self
==
sharedLibrary
)
sharedLibrary
=
nil
;
sharedLibrary
=
nil
;
instance
=
nil
;
instance
=
nil
;
[
audio
release
];
[
audio
release
];
[
super
dealloc
];
[
super
dealloc
];
...
...
projects/macosx/framework/Sources/VLCMediaList.m
View file @
592c1efc
...
@@ -81,7 +81,6 @@ static void HandleMediaListItemDeleted( const libvlc_event_t * event, void * use
...
@@ -81,7 +81,6 @@ static void HandleMediaListItemDeleted( const libvlc_event_t * event, void * use
// Initialize internals to defaults
// Initialize internals to defaults
cachedMedia
=
[[
NSMutableArray
alloc
]
init
];
cachedMedia
=
[[
NSMutableArray
alloc
]
init
];
delegate
=
flatAspect
=
hierarchicalAspect
=
hierarchicalNodeAspect
=
nil
;
[
self
initInternalMediaList
];
[
self
initInternalMediaList
];
}
}
return
self
;
return
self
;
...
@@ -111,9 +110,6 @@ static void HandleMediaListItemDeleted( const libvlc_event_t * event, void * use
...
@@ -111,9 +110,6 @@ static void HandleMediaListItemDeleted( const libvlc_event_t * event, void * use
libvlc_media_list_release
(
p_mlist
);
libvlc_media_list_release
(
p_mlist
);
[
cachedMedia
release
];
[
cachedMedia
release
];
[
flatAspect
release
];
[
hierarchicalAspect
release
];
[
hierarchicalNodeAspect
release
];
[
super
dealloc
];
[
super
dealloc
];
}
}
...
@@ -211,40 +207,6 @@ static void HandleMediaListItemDeleted( const libvlc_event_t * event, void * use
...
@@ -211,40 +207,6 @@ static void HandleMediaListItemDeleted( const libvlc_event_t * event, void * use
return
libvlc_media_list_is_readonly
(
p_mlist
);
return
libvlc_media_list_is_readonly
(
p_mlist
);
}
}
/* Media list aspect */
-
(
VLCMediaListAspect
*
)
hierarchicalAspect
{
if
(
hierarchicalAspect
)
return
hierarchicalAspect
;
libvlc_media_list_view_t
*
p_mlv
=
libvlc_media_list_hierarchical_view
(
p_mlist
);
hierarchicalAspect
=
[[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_mlv
andMediaList
:
self
]
retain
];
libvlc_media_list_view_release
(
p_mlv
);
return
hierarchicalAspect
;
}
-
(
VLCMediaListAspect
*
)
hierarchicalNodeAspect
{
if
(
hierarchicalNodeAspect
)
return
hierarchicalNodeAspect
;
libvlc_media_list_view_t
*
p_mlv
=
libvlc_media_list_hierarchical_node_view
(
p_mlist
);
hierarchicalNodeAspect
=
[[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_mlv
andMediaList
:
self
]
retain
];
libvlc_media_list_view_release
(
p_mlv
);
return
hierarchicalNodeAspect
;
}
-
(
VLCMediaListAspect
*
)
flatAspect
{
if
(
flatAspect
)
return
flatAspect
;
libvlc_media_list_view_t
*
p_mlv
=
libvlc_media_list_flat_view
(
p_mlist
,
NULL
);
flatAspect
=
[[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_mlv
andMediaList
:
self
]
retain
];
libvlc_media_list_view_release
(
p_mlv
);
return
flatAspect
;
}
@end
@end
@implementation
VLCMediaList
(
LibVLCBridging
)
@implementation
VLCMediaList
(
LibVLCBridging
)
...
...
projects/macosx/framework/Sources/VLCMediaListAspect.m
deleted
100644 → 0
View file @
cb9e605b
/*****************************************************************************
* VLCMediaListAspect.m: VLCKit.framework VLCMediaListAspect implementation
*****************************************************************************
* Copyright (C) 2007 Pierre d'Herbemont
* Copyright (C) 2007 the VideoLAN team
* $Id$
*
* Authors: Pierre d'Herbemont <pdherbemont # videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#import "VLCMediaListAspect.h"
#import "VLCLibrary.h"
#import "VLCEventManager.h"
#import "VLCLibVLCBridging.h"
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <vlc/vlc.h>
#include <vlc/libvlc.h>
// TODO: Documentation
@interface
VLCMediaListAspect
(
Private
)
/* Initializers */
-
(
void
)
initInternalMediaListView
;
-
(
void
)
mediaListViewItemAdded
:(
NSArray
*
)
args
;
-
(
void
)
mediaListViewItemRemoved
:(
NSNumber
*
)
index
;
@end
@implementation
VLCMediaListAspectNode
-
(
id
)
init
{
if
(
self
=
[
super
init
])
{
media
=
nil
;
children
=
nil
;
}
return
self
;
}
-
(
void
)
dealloc
{
[
media
release
];
[
children
release
];
[
super
dealloc
];
}
@synthesize
media
;
@synthesize
children
;
-
(
BOOL
)
isLeaf
{
return
self
.
children
==
nil
;
}
@end
@implementation
VLCMediaListAspect
(
KeyValueCodingCompliance
)
/* For the @"media" key */
-
(
NSInteger
)
countOfMedia
{
return
[
cachedNode
count
];
}
-
(
id
)
objectInMediaAtIndex
:(
NSInteger
)
i
{
return
[[
cachedNode
objectAtIndex
:
i
]
media
];
}
/* For the @"node" key */
-
(
NSInteger
)
countOfNode
{
return
[
cachedNode
count
];
}
-
(
id
)
objectInNodeAtIndex
:(
NSInteger
)
i
{
return
[
cachedNode
objectAtIndex
:
i
];
}
@end
/* libvlc event callback */
static
void
HandleMediaListViewItemAdded
(
const
libvlc_event_t
*
event
,
void
*
user_data
)
{
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
id
self
=
user_data
;
[[
VLCEventManager
sharedManager
]
callOnMainThreadObject
:
self
withMethod:
@selector
(
mediaListViewItemAdded
:)
withArgumentAsObject:
[
NSArray
arrayWithObject
:[
NSDictionary
dictionaryWithObjectsAndKeys
:
[
VLCMedia
mediaWithLibVLCMediaDescriptor
:
event
->
u
.
media_list_item_added
.
item
],
@"media"
,
[
NSNumber
numberWithInt
:
event
->
u
.
media_list_item_added
.
index
],
@"index"
,
nil
]]];
[
pool
release
];
}
static
void
HandleMediaListViewItemDeleted
(
const
libvlc_event_t
*
event
,
void
*
user_data
)
{
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
id
self
=
user_data
;
[[
VLCEventManager
sharedManager
]
callOnMainThreadObject
:
self
withMethod:
@selector
(
mediaListViewItemRemoved
:)
withArgumentAsObject:
[
NSNumber
numberWithInt
:
event
->
u
.
media_list_item_deleted
.
index
]];
[
pool
release
];
}
@implementation
VLCMediaListAspect
-
(
void
)
dealloc
{
// Release allocated memory
libvlc_media_list_view_release
(
p_mlv
);
[
cachedNode
release
];
if
(
ownHisMediaList
)
[
parentMediaList
release
];
[
super
dealloc
];
}
-
(
void
)
release
{
@synchronized
(
self
)
{
if
([
self
retainCount
]
<=
1
)
{
/* We must make sure we won't receive new event after an upcoming dealloc
* We also may receive a -retain in some event callback that may occcur
* Before libvlc_event_detach. So this can't happen in dealloc */
libvlc_event_manager_t
*
p_em
=
libvlc_media_list_view_event_manager
(
p_mlv
);
libvlc_event_detach
(
p_em
,
libvlc_MediaListViewItemDeleted
,
HandleMediaListViewItemDeleted
,
self
);
libvlc_event_detach
(
p_em
,
libvlc_MediaListViewItemAdded
,
HandleMediaListViewItemAdded
,
self
);
}
[
super
release
];
}
}
-
(
NSString
*
)
description
{
NSMutableString
*
content
=
[
NSMutableString
string
];
NSUInteger
i
;
for
(
i
=
0
;
i
<
[
self
count
];
i
++
)
{
[
content
appendFormat
:
@"%@
\n
"
,
[
self
mediaAtIndex
:
i
]];
}
return
[
NSString
stringWithFormat
:
@"<%@ %p> {
\n
%@}"
,
[
self
className
],
self
,
content
];
}
-
(
VLCMedia
*
)
mediaAtIndex
:(
NSInteger
)
index
{
libvlc_exception_t
p_e
;
libvlc_exception_init
(
&
p_e
);
libvlc_media_t
*
p_md
=
libvlc_media_list_view_item_at_index
(
p_mlv
,
index
,
&
p_e
);
catch_exception
(
&
p_e
);
// Returns local object for media descriptor, searchs for user data first. If not found it creates a
// new cocoa object representation of the media descriptor.
return
[
VLCMedia
mediaWithLibVLCMediaDescriptor
:
p_md
];
}
-
(
VLCMediaListAspect
*
)
childrenAtIndex
:(
NSInteger
)
index
{
libvlc_exception_t
p_e
;
libvlc_exception_init
(
&
p_e
);
libvlc_media_list_view_t
*
p_sub_mlv
=
libvlc_media_list_view_children_at_index
(
p_mlv
,
index
,
&
p_e
);
catch_exception
(
&
p_e
);
if
(
!
p_sub_mlv
)
return
nil
;
// Returns local object for media descriptor, searchs for user data first. If not found it creates a
// new cocoa object representation of the media descriptor.
return
[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_sub_mlv
];
}
-
(
VLCMediaListAspectNode
*
)
nodeAtIndex
:(
NSInteger
)
index
{
VLCMediaListAspectNode
*
node
=
[[[
VLCMediaListAspectNode
alloc
]
init
]
autorelease
];
[
node
setMedia
:[
self
mediaAtIndex
:
index
]];
libvlc_media_list_view_t
*
p_sub_mlv
=
libvlc_media_list_view_children_for_item
([
self
libVLCMediaListView
],
[
node
.
media
libVLCMediaDescriptor
],
NULL
);
if
(
p_sub_mlv
)
{
[
node
setChildren
:[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_sub_mlv
]];
libvlc_media_list_view_release
(
p_sub_mlv
);
}
return
node
;
}
-
(
NSInteger
)
count
{
libvlc_exception_t
p_e
;
libvlc_exception_init
(
&
p_e
);
NSInteger
result
=
libvlc_media_list_view_count
(
p_mlv
,
&
p_e
);
catch_exception
(
&
p_e
);
return
result
;
}
-
(
VLCMediaList
*
)
parentMediaList
{
return
parentMediaList
;
}
@end
@implementation
VLCMediaListAspect
(
LibVLCBridging
)
+
(
id
)
mediaListAspectWithLibVLCMediaListView
:(
libvlc_media_list_view_t
*
)
p_new_mlv
{
return
[[[
VLCMediaListAspect
alloc
]
initWithLibVLCMediaListView
:
p_new_mlv
andMediaList
:
nil
]
autorelease
];
}
+
(
id
)
mediaListAspectWithLibVLCMediaListView
:(
libvlc_media_list_view_t
*
)
p_new_mlv
andMediaList
:(
VLCMediaList
*
)
mediaList
;
{
return
[[[
VLCMediaListAspect
alloc
]
initWithLibVLCMediaListView
:
p_new_mlv
andMediaList
:
mediaList
]
autorelease
];
}
-
(
id
)
initWithLibVLCMediaListView
:(
libvlc_media_list_view_t
*
)
p_new_mlv
andMediaList
:(
VLCMediaList
*
)
mediaList
;
{
if
(
self
=
[
super
init
]
)
{
p_mlv
=
p_new_mlv
;
libvlc_media_list_view_retain
(
p_mlv
);
/* parentMediaList isn't retained, because we need a mediaList to exists, and not the contrary */
parentMediaList
=
mediaList
;
ownHisMediaList
=
NO
;
if
(
!
parentMediaList
)
{
/* We have to create it then */
libvlc_media_list_view_retain
(
p_mlv
);
libvlc_media_list_t
*
p_mlist
=
libvlc_media_list_view_parent_media_list
(
p_mlv
,
NULL
);
parentMediaList
=
[[
VLCMediaList
mediaListWithLibVLCMediaList
:
p_mlist
]
retain
];
libvlc_media_list_release
(
p_mlist
);
/* This is an exception, and we owns it here */
ownHisMediaList
=
YES
;
}
cachedNode
=
[[
NSMutableArray
alloc
]
initWithCapacity
:
libvlc_media_list_view_count
(
p_mlv
,
NULL
)];
libvlc_media_list_t
*
p_mlist
;
p_mlist
=
libvlc_media_list_view_parent_media_list
(
p_mlv
,
NULL
);
libvlc_media_list_lock
(
p_mlist
);
NSUInteger
i
,
count
=
libvlc_media_list_view_count
(
p_mlv
,
NULL
);
for
(
i
=
0
;
i
<
count
;
i
++
)
{
libvlc_media_t
*
p_md
=
libvlc_media_list_view_item_at_index
(
p_mlv
,
i
,
NULL
);
libvlc_media_list_view_t
*
p_sub_mlv
=
libvlc_media_list_view_children_at_index
(
p_mlv
,
i
,
NULL
);
VLCMediaListAspectNode
*
node
=
[[[
VLCMediaListAspectNode
alloc
]
init
]
autorelease
];
[
node
setMedia
:[
VLCMedia
mediaWithLibVLCMediaDescriptor
:
p_md
]];
[
node
setChildren
:
p_sub_mlv
?
[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_sub_mlv
]
:
nil
];
if
(
p_sub_mlv
)
NSAssert
(
!
[
node
isLeaf
],
@"Not leaf"
);
[
cachedNode
addObject
:
node
];
libvlc_media_release
(
p_md
);
if
(
p_sub_mlv
)
libvlc_media_list_view_release
(
p_sub_mlv
);
}
[
self
initInternalMediaListView
];
libvlc_media_list_unlock
(
p_mlist
);
libvlc_media_list_release
(
p_mlist
);
}
return
self
;
}
-
(
libvlc_media_list_view_t
*
)
libVLCMediaListView
{
return
(
libvlc_media_list_view_t
*
)
p_mlv
;
}
@end
@implementation
VLCMediaListAspect
(
Private
)
-
(
void
)
initInternalMediaListView
{
libvlc_event_manager_t
*
p_em
=
libvlc_media_list_event_manager
(
p_mlv
);
/* Add internal callback */
libvlc_event_attach
(
p_em
,
libvlc_MediaListViewItemAdded
,
HandleMediaListViewItemAdded
,
self
);
libvlc_event_attach
(
p_em
,
libvlc_MediaListViewItemDeleted
,
HandleMediaListViewItemDeleted
,
self
);
}
-
(
void
)
mediaListViewItemAdded
:(
NSArray
*
)
arrayOfArgs
{
NSAssert
([
NSThread
isMainThread
],
@"We are not on main thread"
);
/* We hope to receive index in a nide range, that could change one day */
NSInteger
start
=
[[[
arrayOfArgs
objectAtIndex
:
0
]
objectForKey
:
@"index"
]
intValue
];
NSInteger
end
=
[[[
arrayOfArgs
objectAtIndex
:
[
arrayOfArgs
count
]
-
1
]
objectForKey
:
@"index"
]
intValue
];
NSRange
range
=
NSMakeRange
(
start
,
end
-
start
);
[
self
willChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndexesInRange
:
range
]
forKey
:
@"media"
];
[
self
willChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndexesInRange
:
range
]
forKey
:
@"node"
];
for
(
NSDictionary
*
args
in
arrayOfArgs
)
{
NSInteger
index
=
[[
args
objectForKey
:
@"index"
]
intValue
];
VLCMedia
*
media
=
[
args
objectForKey
:
@"media"
];
VLCMediaListAspectNode
*
node
=
[[[
VLCMediaListAspectNode
alloc
]
init
]
autorelease
];
[
node
setMedia
:
media
];
/* Set the sub media list view we enventually have */
libvlc_media_list_view_t
*
p_sub_mlv
=
libvlc_media_list_view_children_for_item
([
self
libVLCMediaListView
],
[
media
libVLCMediaDescriptor
],
NULL
);
if
(
p_sub_mlv
)
{
[
node
setChildren
:[
VLCMediaListAspect
mediaListAspectWithLibVLCMediaListView
:
p_sub_mlv
]];
libvlc_media_list_view_release
(
p_sub_mlv
);
NSAssert
(
!
[
node
isLeaf
],
@"Not leaf"
);
}
/* Sanity check */
if
(
index
&&
index
>
[
cachedNode
count
]
)
index
=
[
cachedNode
count
];
[
cachedNode
insertObject
:
node
atIndex
:
index
];
}
[
self
didChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndexesInRange
:
range
]
forKey
:
@"node"
];
[
self
didChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndexesInRange
:
range
]
forKey
:
@"media"
];
}
-
(
void
)
mediaListViewItemRemoved
:(
NSNumber
*
)
index
{
[
self
willChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndex
:[
index
intValue
]]
forKey
:
@"media"
];
[
self
willChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndex
:[
index
intValue
]]
forKey
:
@"node"
];
[
cachedNode
removeObjectAtIndex
:[
index
intValue
]];
[
self
didChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndex
:[
index
intValue
]]
forKey
:
@"node"
];
[
self
didChange
:
NSKeyValueChangeInsertion
valuesAtIndexes
:[
NSIndexSet
indexSetWithIndex
:[
index
intValue
]]
forKey
:
@"media"
];
}
@end
projects/macosx/framework/Sources/VLCMediaListPlayer.m
View file @
592c1efc
...
@@ -37,10 +37,7 @@
...
@@ -37,10 +37,7 @@
{
{
_mediaPlayer
=
[[
VLCMediaPlayer
alloc
]
init
];
_mediaPlayer
=
[[
VLCMediaPlayer
alloc
]
init
];
libvlc_exception_t
ex
;
instance
=
libvlc_media_list_player_new
([
VLCLibrary
sharedInstance
]);
libvlc_exception_init
(
&
ex
);
instance
=
libvlc_media_list_player_new
([
VLCLibrary
sharedInstance
],
&
ex
);
catch_exception
(
&
ex
);
libvlc_media_list_player_set_media_player
(
instance
,
[
_mediaPlayer
libVLCMediaPlayer
]);
libvlc_media_list_player_set_media_player
(
instance
,
[
_mediaPlayer
libVLCMediaPlayer
]);
}
}
return
self
;
return
self
;
...
...
projects/macosx/framework/Sources/VLCMediaPlayer.m
View file @
592c1efc
...
@@ -257,11 +257,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -257,11 +257,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
id
)
drawable
-
(
id
)
drawable
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_get_nsobject
(
instance
);
libvlc_exception_init
(
&
ex
);
id
ret
=
libvlc_media_player_get_nsobject
(
instance
);
catch_exception
(
&
ex
);
return
ret
;
}
}
-
(
VLCAudio
*
)
audio
-
(
VLCAudio
*
)
audio
...
@@ -304,19 +300,12 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -304,19 +300,12 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
BOOL
)
openVideoSubTitlesFromFile
:(
NSString
*
)
path
-
(
BOOL
)
openVideoSubTitlesFromFile
:(
NSString
*
)
path
{
{
libvlc_exception_t
ex
;
return
libvlc_video_set_subtitle_file
(
instance
,
[
path
UTF8String
]);
libvlc_exception_init
(
&
ex
);
BOOL
result
=
libvlc_video_set_subtitle_file
(
instance
,
[
path
UTF8String
],
&
ex
);
catch_exception
(
&
ex
);
return
result
;
}
}
-
(
NSArray
*
)
videoSubTitles
-
(
NSArray
*
)
videoSubTitles
{
{
libvlc_exception_t
ex
;
libvlc_track_description_t
*
currentTrack
=
libvlc_video_get_spu_description
(
instance
);
libvlc_exception_init
(
&
ex
);
libvlc_track_description_t
*
currentTrack
=
libvlc_video_get_spu_description
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
while
(
currentTrack
)
{
while
(
currentTrack
)
{
...
@@ -383,23 +372,12 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -383,23 +372,12 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
void
)
setRate
:(
float
)
value
-
(
void
)
setRate
:(
float
)
value
{
{
libvlc_exception_t
ex
;
libvlc_media_player_set_rate
(
instance
,
value
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_set_rate
(
instance
,
value
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
float
)
rate
-
(
float
)
rate
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_get_rate
(
instance
);
libvlc_exception_init
(
&
ex
);
float
result
=
libvlc_media_player_get_rate
(
instance
,
&
ex
);
if
(
libvlc_exception_raised
(
&
ex
))
{
result
=
1
;
libvlc_exception_clear
(
&
ex
);
}
return
result
;
}
}
-
(
NSSize
)
videoSize
-
(
NSSize
)
videoSize
...
@@ -414,37 +392,19 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -414,37 +392,19 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
BOOL
)
hasVideoOut
-
(
BOOL
)
hasVideoOut
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_has_vout
(
instance
);
libvlc_exception_init
(
&
ex
);
BOOL
result
=
libvlc_media_player_has_vout
((
libvlc_media_player_t
*
)
instance
,
&
ex
);
if
(
libvlc_exception_raised
(
&
ex
))
{
libvlc_exception_clear
(
&
ex
);
return
NO
;
}
else
return
result
;
}
}
-
(
float
)
framesPerSecond
-
(
float
)
framesPerSecond
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_get_fps
(
instance
);
libvlc_exception_init
(
&
ex
);
float
result
=
libvlc_media_player_get_fps
(
(
libvlc_media_player_t
*
)
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
result
;
}
}
-
(
void
)
setTime
:(
VLCTime
*
)
value
-
(
void
)
setTime
:(
VLCTime
*
)
value
{
{
libvlc_exception_t
ex
;
libvlc_exception_init
(
&
ex
);
// Time is managed in seconds, while duration is managed in microseconds
// Time is managed in seconds, while duration is managed in microseconds
// TODO: Redo VLCTime to provide value numberAsMilliseconds, numberAsMicroseconds, numberAsSeconds, numberAsMinutes, numberAsHours
// TODO: Redo VLCTime to provide value numberAsMilliseconds, numberAsMicroseconds, numberAsSeconds, numberAsMinutes, numberAsHours
libvlc_media_player_set_time
(
(
libvlc_media_player_t
*
)
instance
,
libvlc_media_player_set_time
(
instance
,
value
?
[[
value
numberValue
]
longLongValue
]
:
0
);
(
value
?
[[
value
numberValue
]
longLongValue
]
:
0
),
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
VLCTime
*
)
time
-
(
VLCTime
*
)
time
...
@@ -459,70 +419,51 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -459,70 +419,51 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
NSUInteger
)
fps
-
(
NSUInteger
)
fps
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_get_fps
(
instance
);
libvlc_exception_init
(
&
ex
);
NSUInteger
result
=
libvlc_media_player_get_fps
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
result
;
}
}
#pragma mark -
#pragma mark -
#pragma mark Chapters
#pragma mark Chapters
-
(
void
)
setCurrentChapterIndex
:(
NSUInteger
)
value
;
-
(
void
)
setCurrentChapterIndex
:(
NSUInteger
)
value
;
{
{
libvlc_exception_t
ex
;
libvlc_media_player_set_chapter
(
instance
,
value
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_set_chapter
(
instance
,
value
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
NSUInteger
)
currentChapterIndex
-
(
NSUInteger
)
currentChapterIndex
{
{
libvlc_exception_t
ex
;
NSInteger
count
=
libvlc_media_player_get_chapter_count
(
instance
);
libvlc_exception_init
(
&
ex
);
NSInteger
count
=
libvlc_media_player_get_chapter_count
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
if
(
count
<=
0
)
if
(
count
<=
0
)
return
NSNotFound
;
return
NSNotFound
;
NSUInteger
result
=
libvlc_media_player_get_chapter
(
instance
,
&
ex
);
NSUInteger
result
=
libvlc_media_player_get_chapter
(
instance
);
catch_exception
(
&
ex
);
return
result
;
return
result
;
}
}
-
(
void
)
nextChapter
-
(
void
)
nextChapter
{
{
libvlc_exception_t
ex
;
libvlc_media_player_next_chapter
(
instance
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_next_chapter
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
void
)
previousChapter
-
(
void
)
previousChapter
{
{
libvlc_exception_t
ex
;
libvlc_media_player_previous_chapter
(
instance
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_previous_chapter
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
NSArray
*
)
chaptersForTitleIndex
:(
NSUInteger
)
title
-
(
NSArray
*
)
chaptersForTitleIndex
:(
NSUInteger
)
title
{
{
libvlc_exception_t
ex
;
NSInteger
count
=
libvlc_media_player_get_chapter_count
(
instance
);
libvlc_exception_init
(
&
ex
);
NSInteger
count
=
libvlc_media_player_get_chapter_count
(
instance
,
&
ex
);
if
(
count
<=
0
)
if
(
count
<=
0
)
return
[
NSArray
array
];
return
[
NSArray
array
];
libvlc_track_description_t
*
tracks
=
libvlc_video_get_chapter_description
(
instance
,
title
,
&
ex
);
libvlc_track_description_t
*
tracks
=
libvlc_video_get_chapter_description
(
instance
,
title
);
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSInteger
i
;
NSInteger
i
;
for
(
i
=
0
;
i
<
count
;
i
++
)
for
(
i
=
0
;
i
<
count
;
i
++
)
{
{
[
tempArray
addObject
:[
NSString
stringWithUTF8String
:
tracks
->
psz_name
]];
[
tempArray
addObject
:[
NSString
stringWithUTF8String
:
tracks
->
psz_name
]];
tracks
=
tracks
->
p_next
;
tracks
=
tracks
->
p_next
;
}
}
libvlc_track_description_release
(
tracks
);
libvlc_track_description_release
(
tracks
);
return
[
NSArray
arrayWithArray
:
tempArray
];
return
[
NSArray
arrayWithArray
:
tempArray
];
}
}
#pragma mark -
#pragma mark -
...
@@ -530,41 +471,27 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -530,41 +471,27 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
void
)
setCurrentTitleIndex
:(
NSUInteger
)
value
-
(
void
)
setCurrentTitleIndex
:(
NSUInteger
)
value
{
{
libvlc_exception_t
ex
;
libvlc_media_player_set_title
(
instance
,
value
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_set_title
(
instance
,
value
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
NSUInteger
)
currentTitleIndex
-
(
NSUInteger
)
currentTitleIndex
{
{
libvlc_exception_t
ex
;
NSInteger
count
=
libvlc_media_player_get_title_count
(
instance
);
libvlc_exception_init
(
&
ex
);
NSInteger
count
=
libvlc_media_player_get_title_count
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
if
(
count
<=
0
)
if
(
count
<=
0
)
return
NSNotFound
;
return
NSNotFound
;
NSUInteger
result
=
libvlc_media_player_get_title
(
instance
,
&
ex
);
return
libvlc_media_player_get_title
(
instance
);
catch_exception
(
&
ex
);
return
result
;
}
}
-
(
NSUInteger
)
countOfTitles
-
(
NSUInteger
)
countOfTitles
{
{
libvlc_exception_t
ex
;
NSUInteger
result
=
libvlc_media_player_get_title_count
(
instance
);
libvlc_exception_init
(
&
ex
);
NSUInteger
result
=
libvlc_media_player_get_title_count
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
result
;
return
result
;
}
}
-
(
NSArray
*
)
titles
-
(
NSArray
*
)
titles
{
{
libvlc_exception_t
ex
;
libvlc_track_description_t
*
tracks
=
libvlc_video_get_title_description
(
instance
);
libvlc_exception_init
(
&
ex
);
libvlc_track_description_t
*
tracks
=
libvlc_video_get_title_description
(
instance
,
&
ex
);
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSInteger
i
;
NSInteger
i
;
for
(
i
=
0
;
i
<
[
self
countOfTitles
]
;
i
++
)
for
(
i
=
0
;
i
<
[
self
countOfTitles
]
;
i
++
)
...
@@ -580,36 +507,26 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -580,36 +507,26 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
#pragma mark Audio tracks
#pragma mark Audio tracks
-
(
void
)
setCurrentAudioTrackIndex
:(
NSUInteger
)
value
-
(
void
)
setCurrentAudioTrackIndex
:(
NSUInteger
)
value
{
{
libvlc_exception_t
ex
;
libvlc_audio_set_track
(
instance
,
(
int
)
value
);
libvlc_exception_init
(
&
ex
);
libvlc_audio_set_track
(
instance
,
(
int
)
value
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
NSUInteger
)
currentAudioTrackIndex
-
(
NSUInteger
)
currentAudioTrackIndex
{
{
libvlc_exception_t
ex
;
NSInteger
count
=
libvlc_audio_get_track_count
(
instance
);
libvlc_exception_init
(
&
ex
);
NSInteger
count
=
libvlc_audio_get_track_count
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
if
(
count
<=
0
)
if
(
count
<=
0
)
return
NSNotFound
;
return
NSNotFound
;
NSUInteger
result
=
libvlc_audio_get_track
(
instance
,
&
ex
);
NSUInteger
result
=
libvlc_audio_get_track
(
instance
);
catch_exception
(
&
ex
);
return
result
;
return
result
;
}
}
-
(
NSArray
*
)
audioTracks
-
(
NSArray
*
)
audioTracks
{
{
libvlc_exception_t
ex
;
NSInteger
count
=
libvlc_audio_get_track_count
(
instance
);
libvlc_exception_init
(
&
ex
);
NSInteger
count
=
libvlc_audio_get_track_count
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
if
(
count
<=
0
)
if
(
count
<=
0
)
return
[
NSArray
array
];
return
[
NSArray
array
];
libvlc_track_description_t
*
tracks
=
libvlc_audio_get_track_description
(
instance
,
&
ex
);
libvlc_track_description_t
*
tracks
=
libvlc_audio_get_track_description
(
instance
);
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSMutableArray
*
tempArray
=
[
NSMutableArray
array
];
NSUInteger
i
;
NSUInteger
i
;
for
(
i
=
0
;
i
<
count
;
i
++
)
for
(
i
=
0
;
i
<
count
;
i
++
)
...
@@ -624,19 +541,12 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -624,19 +541,12 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
void
)
setAudioChannel
:(
NSInteger
)
value
-
(
void
)
setAudioChannel
:(
NSInteger
)
value
{
{
libvlc_exception_t
ex
;
libvlc_audio_set_channel
(
instance
,
value
);
libvlc_exception_init
(
&
ex
);
libvlc_audio_set_channel
(
instance
,
value
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
NSInteger
)
audioChannel
-
(
NSInteger
)
audioChannel
{
{
libvlc_exception_t
ex
;
return
libvlc_audio_get_channel
(
instance
);
libvlc_exception_init
(
&
ex
);
NSInteger
result
=
libvlc_audio_get_channel
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
result
;
}
}
-
(
void
)
setMedia
:(
VLCMedia
*
)
value
-
(
void
)
setMedia
:(
VLCMedia
*
)
value
...
@@ -660,10 +570,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -660,10 +570,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
BOOL
)
play
-
(
BOOL
)
play
{
{
libvlc_exception_t
ex
;
libvlc_media_player_play
(
instance
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_play
(
(
libvlc_media_player_t
*
)
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
YES
;
return
YES
;
}
}
...
@@ -680,16 +587,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -680,16 +587,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
}
}
// Pause the stream
// Pause the stream
libvlc_exception_t
ex
;
libvlc_media_player_pause
(
instance
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_pause
(
instance
,
&
ex
);
// fail gracefully
// in most cases, it's just EOF so let's stop
if
(
libvlc_exception_raised
(
&
ex
))
[
self
stop
];
libvlc_exception_clear
(
&
ex
);
}
}
-
(
void
)
stop
-
(
void
)
stop
...
@@ -699,10 +597,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -699,10 +597,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
void
)
gotoNextFrame
-
(
void
)
gotoNextFrame
{
{
libvlc_exception_t
e
;
libvlc_media_player_next_frame
(
instance
);
libvlc_exception_init
(
&
e
);
libvlc_media_player_next_frame
(
instance
,
&
e
);
catch_exception
(
&
e
);
}
}
...
@@ -798,16 +693,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
...
@@ -798,16 +693,7 @@ static void HandleMediaPlayerMediaChanged(const libvlc_event_t * event, void * s
-
(
BOOL
)
willPlay
-
(
BOOL
)
willPlay
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_will_play
(
instance
);
libvlc_exception_init
(
&
ex
);
BOOL
ret
=
libvlc_media_player_will_play
(
(
libvlc_media_player_t
*
)
instance
,
&
ex
);
if
(
libvlc_exception_raised
(
&
ex
))
{
libvlc_exception_clear
(
&
ex
);
return
NO
;
}
else
return
ret
;
}
}
static
const
VLCMediaPlayerState
libvlc_to_local_state
[]
=
static
const
VLCMediaPlayerState
libvlc_to_local_state
[]
=
...
@@ -833,28 +719,17 @@ static const VLCMediaPlayerState libvlc_to_local_state[] =
...
@@ -833,28 +719,17 @@ static const VLCMediaPlayerState libvlc_to_local_state[] =
-
(
void
)
setPosition
:(
float
)
newPosition
-
(
void
)
setPosition
:(
float
)
newPosition
{
{
libvlc_exception_t
ex
;
libvlc_media_player_set_position
(
instance
,
newPosition
);
libvlc_exception_init
(
&
ex
);
libvlc_media_player_set_position
(
instance
,
newPosition
,
&
ex
);
catch_exception
(
&
ex
);
}
}
-
(
BOOL
)
isSeekable
-
(
BOOL
)
isSeekable
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_is_seekable
(
instance
);
libvlc_exception_init
(
&
ex
);
BOOL
ret
=
libvlc_media_player_is_seekable
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
ret
;
}
}
-
(
BOOL
)
canPause
-
(
BOOL
)
canPause
{
{
libvlc_exception_t
ex
;
return
libvlc_media_player_can_pause
(
instance
);
libvlc_exception_init
(
&
ex
);
BOOL
ret
=
libvlc_media_player_can_pause
(
instance
,
&
ex
);
catch_exception
(
&
ex
);
return
ret
;
}
}
-
(
void
*
)
libVLCMediaPlayer
-
(
void
*
)
libVLCMediaPlayer
...
@@ -880,7 +755,7 @@ static const VLCMediaPlayerState libvlc_to_local_state[] =
...
@@ -880,7 +755,7 @@ static const VLCMediaPlayerState libvlc_to_local_state[] =
// instance
// instance
libvlc_exception_t
ex
;
libvlc_exception_t
ex
;
libvlc_exception_init
(
&
ex
);
libvlc_exception_init
(
&
ex
);
instance
=
(
void
*
)
libvlc_media_player_new
([
VLCLibrary
sharedInstance
],
&
ex
);
instance
=
libvlc_media_player_new
([
VLCLibrary
sharedInstance
]
);
catch_exception
(
&
ex
);
catch_exception
(
&
ex
);
[
self
registerObservers
];
[
self
registerObservers
];
...
...
projects/macosx/framework/VLCKit.xcodeproj/project.pbxproj
View file @
592c1efc
...
@@ -62,8 +62,6 @@
...
@@ -62,8 +62,6 @@
/* Begin PBXBuildFile section */
/* Begin PBXBuildFile section */
63014A7A1042ACE100534090
/* VLCMediaListPlayer.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63014A781042ACE100534090
/* VLCMediaListPlayer.m */
;
};
63014A7A1042ACE100534090
/* VLCMediaListPlayer.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63014A781042ACE100534090
/* VLCMediaListPlayer.m */
;
};
63014B7E1042E64A00534090
/* VLCMediaListPlayer.h in Headers */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63014B7D1042E64A00534090
/* VLCMediaListPlayer.h */
;
settings
=
{
ATTRIBUTES
=
(
Public
,
);
};
};
63014B7E1042E64A00534090
/* VLCMediaListPlayer.h in Headers */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63014B7D1042E64A00534090
/* VLCMediaListPlayer.h */
;
settings
=
{
ATTRIBUTES
=
(
Public
,
);
};
};
6303C43A0CF45CAE0000ECC8
/* VLCMediaListAspect.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
6303C4390CF45CAE0000ECC8
/* VLCMediaListAspect.m */
;
};
6303C43C0CF45CC30000ECC8
/* VLCMediaListAspect.h in Headers */
=
{
isa
=
PBXBuildFile
;
fileRef
=
6303C43B0CF45CC30000ECC8
/* VLCMediaListAspect.h */
;
settings
=
{
ATTRIBUTES
=
(
Public
,
);
};
};
63098FDC110E7159005F46AE
/* VLCExtensionsManager.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63098FDA110E7159005F46AE
/* VLCExtensionsManager.m */
;
};
63098FDC110E7159005F46AE
/* VLCExtensionsManager.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63098FDA110E7159005F46AE
/* VLCExtensionsManager.m */
;
};
63099116110F0EC3005F46AE
/* VLCExtension.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63099114110F0EC3005F46AE
/* VLCExtension.m */
;
};
63099116110F0EC3005F46AE
/* VLCExtension.m in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63099114110F0EC3005F46AE
/* VLCExtension.m */
;
};
6309994B110FC791005F46AE
/* VLCExtension.h in Headers */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63099949110FC791005F46AE
/* VLCExtension.h */
;
settings
=
{
ATTRIBUTES
=
(
Public
,
);
};
};
6309994B110FC791005F46AE
/* VLCExtension.h in Headers */
=
{
isa
=
PBXBuildFile
;
fileRef
=
63099949110FC791005F46AE
/* VLCExtension.h */
;
settings
=
{
ATTRIBUTES
=
(
Public
,
);
};
};
...
@@ -141,8 +139,6 @@
...
@@ -141,8 +139,6 @@
63014A781042ACE100534090
/* VLCMediaListPlayer.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCMediaListPlayer.m
;
sourceTree
=
"<group>"
;
};
63014A781042ACE100534090
/* VLCMediaListPlayer.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCMediaListPlayer.m
;
sourceTree
=
"<group>"
;
};
63014B7D1042E64A00534090
/* VLCMediaListPlayer.h */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.h
;
name
=
VLCMediaListPlayer.h
;
path
=
Public/VLCMediaListPlayer.h
;
sourceTree
=
"<group>"
;
};
63014B7D1042E64A00534090
/* VLCMediaListPlayer.h */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.h
;
name
=
VLCMediaListPlayer.h
;
path
=
Public/VLCMediaListPlayer.h
;
sourceTree
=
"<group>"
;
};
63030CC70CCA652C0088ECD1
/* Info.plist */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
30
;
lastKnownFileType
=
text.plist.xml
;
name
=
Info.plist
;
path
=
Resources/Info.plist
;
sourceTree
=
"<group>"
;
};
63030CC70CCA652C0088ECD1
/* Info.plist */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
30
;
lastKnownFileType
=
text.plist.xml
;
name
=
Info.plist
;
path
=
Resources/Info.plist
;
sourceTree
=
"<group>"
;
};
6303C4390CF45CAE0000ECC8
/* VLCMediaListAspect.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCMediaListAspect.m
;
sourceTree
=
"<group>"
;
};
6303C43B0CF45CC30000ECC8
/* VLCMediaListAspect.h */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.h
;
name
=
VLCMediaListAspect.h
;
path
=
Public/VLCMediaListAspect.h
;
sourceTree
=
"<group>"
;
};
63098FDA110E7159005F46AE
/* VLCExtensionsManager.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCExtensionsManager.m
;
sourceTree
=
"<group>"
;
};
63098FDA110E7159005F46AE
/* VLCExtensionsManager.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCExtensionsManager.m
;
sourceTree
=
"<group>"
;
};
63099114110F0EC3005F46AE
/* VLCExtension.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCExtension.m
;
sourceTree
=
"<group>"
;
};
63099114110F0EC3005F46AE
/* VLCExtension.m */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.objc
;
path
=
VLCExtension.m
;
sourceTree
=
"<group>"
;
};
63099949110FC791005F46AE
/* VLCExtension.h */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.h
;
name
=
VLCExtension.h
;
path
=
Public/VLCExtension.h
;
sourceTree
=
"<group>"
;
};
63099949110FC791005F46AE
/* VLCExtension.h */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.c.h
;
name
=
VLCExtension.h
;
path
=
Public/VLCExtension.h
;
sourceTree
=
"<group>"
;
};
...
@@ -247,7 +243,6 @@
...
@@ -247,7 +243,6 @@
637D5ADB0CF6F2720073EA45
/* VLCMediaDiscoverer.m */
,
637D5ADB0CF6F2720073EA45
/* VLCMediaDiscoverer.m */
,
EF78BD410CAEEFF600354E6E
/* VLCMediaList.m */
,
EF78BD410CAEEFF600354E6E
/* VLCMediaList.m */
,
63014A781042ACE100534090
/* VLCMediaListPlayer.m */
,
63014A781042ACE100534090
/* VLCMediaListPlayer.m */
,
6303C4390CF45CAE0000ECC8
/* VLCMediaListAspect.m */
,
EF8BB8CF0CAFA8D80038A613
/* VLCMediaPlayer.m */
,
EF8BB8CF0CAFA8D80038A613
/* VLCMediaPlayer.m */
,
EF78BD400CAEEFF600354E6E
/* VLCMediaLibrary.m */
,
EF78BD400CAEEFF600354E6E
/* VLCMediaLibrary.m */
,
A7A0CEA30D2EF13000F2C039
/* VLCVideoCommon.m */
,
A7A0CEA30D2EF13000F2C039
/* VLCVideoCommon.m */
,
...
@@ -332,7 +327,6 @@
...
@@ -332,7 +327,6 @@
EF78BD130CAEEEE700354E6E
/* VLCMedia.h */
,
EF78BD130CAEEEE700354E6E
/* VLCMedia.h */
,
637D5ABC0CF6F2650073EA45
/* VLCMediaDiscoverer.h */
,
637D5ABC0CF6F2650073EA45
/* VLCMediaDiscoverer.h */
,
EF78BD160CAEEEE700354E6E
/* VLCMediaList.h */
,
EF78BD160CAEEEE700354E6E
/* VLCMediaList.h */
,
6303C43B0CF45CC30000ECC8
/* VLCMediaListAspect.h */
,
63014B7D1042E64A00534090
/* VLCMediaListPlayer.h */
,
63014B7D1042E64A00534090
/* VLCMediaListPlayer.h */
,
EF8BB8CE0CAFA8D80038A613
/* VLCMediaPlayer.h */
,
EF8BB8CE0CAFA8D80038A613
/* VLCMediaPlayer.h */
,
EF78BD150CAEEEE700354E6E
/* VLCMediaLibrary.h */
,
EF78BD150CAEEEE700354E6E
/* VLCMediaLibrary.h */
,
...
@@ -363,7 +357,6 @@
...
@@ -363,7 +357,6 @@
isa
=
PBXHeadersBuildPhase
;
isa
=
PBXHeadersBuildPhase
;
buildActionMask
=
2147483647
;
buildActionMask
=
2147483647
;
files
=
(
files
=
(
6303C43C0CF45CC30000ECC8
/* VLCMediaListAspect.h in Headers */
,
EF78BD100CAEEEC300354E6E
/* VLCEventManager.h in Headers */
,
EF78BD100CAEEEC300354E6E
/* VLCEventManager.h in Headers */
,
EF78BD1B0CAEEEE700354E6E
/* VLCKit.h in Headers */
,
EF78BD1B0CAEEEE700354E6E
/* VLCKit.h in Headers */
,
EF78BD1C0CAEEEE700354E6E
/* VLCMedia.h in Headers */
,
EF78BD1C0CAEEEE700354E6E
/* VLCMedia.h in Headers */
,
...
@@ -574,7 +567,6 @@
...
@@ -574,7 +567,6 @@
EF78BEF40CAF07E500354E6E
/* VLCVideoView.m in Sources */
,
EF78BEF40CAF07E500354E6E
/* VLCVideoView.m in Sources */
,
EF8BB8D10CAFA8D80038A613
/* VLCMediaPlayer.m in Sources */
,
EF8BB8D10CAFA8D80038A613
/* VLCMediaPlayer.m in Sources */
,
EF7311910CB5797B009473B4
/* VLCAudio.m in Sources */
,
EF7311910CB5797B009473B4
/* VLCAudio.m in Sources */
,
6303C43A0CF45CAE0000ECC8
/* VLCMediaListAspect.m in Sources */
,
637D5ADC0CF6F2720073EA45
/* VLCMediaDiscoverer.m in Sources */
,
637D5ADC0CF6F2720073EA45
/* VLCMediaDiscoverer.m in Sources */
,
6341FCB10D2C0936002A97B7
/* VLCVideoLayer.m in Sources */
,
6341FCB10D2C0936002A97B7
/* VLCVideoLayer.m in Sources */
,
A7A0CEA50D2EF13000F2C039
/* VLCVideoCommon.m in Sources */
,
A7A0CEA50D2EF13000F2C039
/* VLCVideoCommon.m in Sources */
,
...
...
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