1 /*****************************************************************************
2 * history.c: vlc_history_t (web-browser-like back/forward history) handling
3 *****************************************************************************
4 * Copyright (C) 2004 Commonwealth Scientific and Industrial Research
5 * Organisation (CSIRO) Australia
6 * Copyright (C) 2004 the VideoLAN team
10 * Authors: Andre Pang <Andre.Pang@csiro.au>
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation; either version 2 of the License, or
15 * (at your option) any later version.
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, write to the Free Software
24 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
25 *****************************************************************************/
28 #include <vlc_input.h>
35 # include <stdlib.h> /* realloc() */
40 /*****************************************************************************
42 *****************************************************************************/
43 static void history_Dump( history_t *p_history );
45 /*****************************************************************************
46 * Local structure lock
47 *****************************************************************************/
49 /*****************************************************************************
51 *****************************************************************************/
53 history_t *history_New( void )
55 history_t *p_new_history;
57 p_new_history = calloc( 1, sizeof( struct history_t ) );
58 if( p_new_history == NULL ) return NULL;
60 p_new_history->p_xarray = xarray_New( 0 );
61 if( p_new_history->p_xarray == NULL )
63 free( p_new_history );
68 /* make dummy reference to history_Dump to avoid compiler warnings */
80 vlc_bool_t history_GoBackSavingCurrentItem ( history_t *p_history,
81 history_item_t *p_item )
83 history_PruneAndInsert( p_history, p_item );
85 /* PruneAndInsert will increment the index, so we need to go
86 * back one position to reset the index to the place we were at
87 * before saving the current state, and then go back one more to
89 p_history->i_index -= 2;
92 history_Dump( p_history );
97 static void history_Dump( history_t *p_history )
102 if( xarray_Count( p_history->p_xarray, &i_count ) != XARRAY_SUCCESS )
105 for (i = 0; i < (int) i_count; i++)
107 history_item_t *p_item;
110 xarray_ObjectAtIndex( p_history->p_xarray, i, &pv_item );
112 p_item = (history_item_t *) pv_item;
115 fprintf( stderr, "HISTORY: [%d] NULL\n", i );
118 char *psz_uri = input_item_GetURI( p_item );
119 fprintf( stderr, "HISTORY: [%d] %p (%p->%s)\n", i, p_item,
126 vlc_bool_t history_GoForwardSavingCurrentItem ( history_t *p_history,
127 history_item_t *p_item )
130 history_Dump( p_history );
133 if( xarray_ReplaceObject( p_history->p_xarray, p_history->i_index, p_item )
136 p_history->i_index++;
145 vlc_bool_t history_CanGoBack( history_t *p_history )
147 if( p_history->i_index > 0 )
153 vlc_bool_t history_CanGoForward( history_t *p_history )
155 unsigned int i_count;
157 if( xarray_Count( p_history->p_xarray, &i_count ) != XARRAY_SUCCESS )
160 if( p_history->i_index < i_count )
166 history_item_t *history_Item( history_t *p_history )
168 history_item_t *p_item;
171 if( xarray_ObjectAtIndex( p_history->p_xarray, p_history->i_index,
175 p_item = (history_item_t *) pv_item;
184 void history_Prune( history_t *p_history )
186 xarray_RemoveObjectsAfter( p_history->p_xarray, p_history->i_index );
187 xarray_RemoveObject( p_history->p_xarray, p_history->i_index );
190 void history_PruneAndInsert( history_t *p_history, history_item_t *p_item )
192 unsigned int i_count;
194 xarray_Count( p_history->p_xarray, &i_count );
198 xarray_InsertObject( p_history->p_xarray, p_item, 0 );
199 p_history->i_index = 1;
203 history_Prune( p_history );
204 xarray_InsertObject( p_history->p_xarray, p_item, p_history->i_index );
205 p_history->i_index++;
209 unsigned int history_Count( history_t *p_history )
211 unsigned int i_count;
212 xarray_Count( p_history->p_xarray, &i_count );
216 unsigned int history_Index( history_t *p_history )
218 return p_history->i_index;
221 history_item_t * historyItem_New( char *psz_name, char *psz_uri )
223 history_item_t *p_history_item = NULL;
225 p_history_item = (history_item_t *) malloc( sizeof(history_item_t) );
226 if( !p_history_item ) return NULL;
228 p_history_item->psz_uri = strdup( psz_uri );
229 p_history_item->psz_name = strdup( psz_name );
231 return p_history_item;