]> git.sesse.net Git - vlc/blobdiff - include/vlc_update.h
Use var_Inherit* instead of var_CreateGet*.
[vlc] / include / vlc_update.h
index d4ecbdcd15b2c9e990315663faeb454f1afe6d7a..1fd5a8593aca6d0f06b34debf5564c207abd8727 100644 (file)
@@ -1,10 +1,11 @@
 /*****************************************************************************
- * vlc_update.h: VLC update and plugins download
+ * vlc_update.h: VLC update download
  *****************************************************************************
- * Copyright (C) 2005 the VideoLAN team
- * $Id$
+ * Copyright © 2005-2007 the VideoLAN team
+ * $Id$
  *
  * Authors: Antoine Cellerier <dionoea -at- videolan -dot- org>
+ *          Rafaël Carré <funman@videolanorg>
  *
  * 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
  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
  *****************************************************************************/
 
-#ifndef _VLC_UPDATE_H
-#define _VLC_UPDATE_H
-
-#include <vlc/vlc.h>
-
-#define UPDATE_FILE_TYPE_ALL    (~0)
-#define UPDATE_FILE_TYPE_NONE   0
-
-#define UPDATE_FILE_TYPE_UNDEF      1
-#define UPDATE_FILE_TYPE_INFO       2
-#define UPDATE_FILE_TYPE_SOURCE     4
-#define UPDATE_FILE_TYPE_BINARY     8
-#define UPDATE_FILE_TYPE_PLUGIN     16
-
-#define UPDATE_RELEASE_STATUS_ALL       (~0)
-#define UPDATE_RELEASE_STATUS_NONE      0
-
-#define UPDATE_RELEASE_STATUS_OLDER     1
-#define UPDATE_RELEASE_STATUS_EQUAL     2
-#define UPDATE_RELEASE_STATUS_NEWER     4
-
-#define UPDATE_RELEASE_TYPE_STABLE      1
-#define UPDATE_RELEASE_TYPE_TESTING     2
-#define UPDATE_RELEASE_TYPE_UNSTABLE    4
-
-#define UPDATE_FAIL     0
-#define UPDATE_SUCCESS  1
-#define UPDATE_NEXT     0
-#define UPDATE_PREV     2
-#define UPDATE_MIRROR   4
-#define UPDATE_RELEASE  8
-#define UPDATE_FILE     16
-#define UPDATE_RESET    32
+#ifndef VLC_UPDATE_H
+#define VLC_UPDATE_H
 
 /**
- * Describes an update file
+ * \file
+ * This file defines update API in vlc
  */
-struct update_file_t
-{
-    int i_type;             //< File type
-    char* psz_md5;          //< MD5 hash
-    long int l_size;        //< File size in bytes
-    char* psz_url;          //< Relative (to a mirror) or absolute url
-    char* psz_description;  //< Plain text description
-};
 
 /**
- * Describes an update VLC release number
+ * \defgroup update Update
+ *
+ * @{
  */
-struct update_release_t
-{
-    char* psz_major;        //< Version major string
-    char* psz_minor;        //< Version minor string
-    char* psz_revision;     //< Version revision string
-    char* psz_extra;        //< Version extra string
 
-    char* psz_svn_revision; //< SVN revision
-
-    int i_type;             //< Release type
-
-    int i_status;           //< Release status compared to current VLC version
-
-    struct update_file_t* p_files; //< Files list
-    int i_files;            //< Number of files in the files list
-};
+#ifdef UPDATE_CHECK
 
 /**
- * Describes a mirror
+ * Describes an update VLC release number
  */
-struct update_mirror_t
+struct update_release_t
 {
-    char *psz_name;         //< Mirror name
-    char *psz_location;     //< Mirror geographical location
-    char *psz_type;         //< Mirror type (FTP, HTTP, ...)
-
-    char *psz_base_url;     //< Mirror base url
-
+    int i_major;        ///< Version major
+    int i_minor;        ///< Version minor
+    int i_revision;     ///< Version revision
+    unsigned char extra;///< Version extra
+    char* psz_url;      ///< Download URL
+    char* psz_desc;     ///< Release description
 };
 
-/**
- * The update object. Stores (and caches) all information relative to updates
- */
-struct update_t
-{
-    vlc_t *p_vlc;
+#endif /* UPDATE_CHECK */
 
-    vlc_mutex_t lock;
+typedef struct update_release_t update_release_t;
 
-    struct update_release_t *p_releases;    //< Releases (version) list
-    int i_releases;                         //< Number of releases
-    vlc_bool_t b_releases;                  //< True if we have a releases list
-
-    struct update_mirror_t *p_mirrors;      //< Mirrors list
-    int i_mirrors;                          //< Number of mirrors
-    vlc_bool_t b_mirrors;                   //< True if we have a mirrors list
-};
+VLC_EXPORT( update_t *, update_New, ( vlc_object_t * ) );
+#define update_New( a ) update_New( VLC_OBJECT( a ) )
+VLC_EXPORT( void, update_Delete, ( update_t * ) );
+VLC_EXPORT( void, update_Check, ( update_t *, void (*callback)( void*, bool ), void * ) );
+VLC_EXPORT( bool, update_NeedUpgrade, ( update_t * ) );
+VLC_EXPORT( void, update_Download, ( update_t *, const char* ) );
+VLC_EXPORT( update_release_t*, update_GetRelease, ( update_t * ) );
 
 /**
- * The update iterator structure. Usefull to browse the update object seamlessly
+ * @}
  */
-struct update_iterator_t
-{
-    update_t *p_u;  //< Pointer to VLC update object
-
-    int i_r;        //< Position in the releases list
-    int i_f;        //< Position in the release's files list
-    int i_m;        //< Position in the mirrors list
-
-    int i_t;        //< File type bitmask
-    int i_rs;       //< Release status bitmask
-    int i_rt;       //< Release type bitmask
-
-    struct
-    {
-        int i_type;             //< Type
-        char* psz_md5;          //< MD5 hash
-        long int l_size;        //< Size in bytes
-        char* psz_url;          //< Absolute URL
-        char* psz_description;  //< Description
-    } file;         //< Local 'copy' of the current file's information
-    struct
-    {
-        char *psz_version;      //< Version string
-        char *psz_svn_revision; //< SVN revision
-        int i_status;           //< Status
-        int i_type;             //< Type
-    } release;      //< Local 'copy' of the current release's information
-    struct
-    {
-        char *psz_name;         //< Name
-        char *psz_location;     //< Geographical location
-        char *psz_type;         //< Type (HTTP, FTP, ...)
-    } mirror;       //< Local 'copy' of the current mirror's information
-};
-
-#define update_New( a ) __update_New( VLC_OBJECT( a ) )
-
-VLC_EXPORT( update_t *, __update_New, ( vlc_object_t * ) );
-VLC_EXPORT( void, update_Delete, (update_t * ) );
-VLC_EXPORT( void, update_Check, ( update_t *, vlc_bool_t ) );
-
-VLC_EXPORT( update_iterator_t *, update_iterator_New, ( update_t * ) );
-VLC_EXPORT( void, update_iterator_Delete, ( update_iterator_t * ) );
-VLC_EXPORT( unsigned int, update_iterator_Action, ( update_iterator_t *, int ) );
-VLC_EXPORT( unsigned int, update_iterator_ChooseMirrorAndFile, ( update_iterator_t *, int, int, int ) );
-VLC_EXPORT( void, update_download, ( update_iterator_t *, char * ) );
 
-#endif
+#endif /* _VLC_UPDATE_H */