@ -281,7 +281,7 @@ public class ResultFetcher {
// check if we already retrieved this item
// check if we already retrieved this item
// (happens if a search pages is accessed a second time)
// (happens if a search pages is accessed a second time)
EventTracker . update ( "SEARCH" , new ProfilingGraph . searchEvent ( query . id ( true ) , "obtain one result entry - start" , 0 , 0 ) , false , 30000 , ProfilingGraph . maxTime ) ;
EventTracker . update ( "SEARCH" , new ProfilingGraph . searchEvent ( query . id ( true ) , "obtain one result entry - start" , 0 , 0 ) , false , 30000 , ProfilingGraph . maxTime ) ;
if ( this . result . size Store ( ) > item ) {
if ( this . result . size ( ) > item ) {
// we have the wanted result already in the result array .. return that
// we have the wanted result already in the result array .. return that
return this . result . element ( item ) . element ;
return this . result . element ( item ) . element ;
}
}
@ -319,30 +319,36 @@ public class ResultFetcher {
}
}
public MediaSnippet oneImage ( final int item ) {
public MediaSnippet oneImage ( final int item ) {
// check if we already retrieved this item (happens if a search pages is accessed a second time)
// always look for a next object if there are way too less
if ( this . images . sizeStore ( ) > item ) {
if ( this . images . size ( ) < = item + 10 ) fillImagesCache ( ) ;
// we have the wanted result already in the result array .. return that
// check if we already retrieved the item
if ( this . images . size ( ) > item ) return this . images . element ( item ) . element ;
// look again if there are not enough for presentation
while ( this . images . size ( ) < = item ) {
if ( fillImagesCache ( ) = = 0 ) break ;
}
if ( this . images . size ( ) < = item ) return null ;
// now take the specific item from the image stack
return this . images . element ( item ) . element ;
return this . images . element ( item ) . element ;
}
}
// generate result object
private int fillImagesCache ( ) {
final ResultEntry result = nextResult ( ) ;
ResultEntry result = nextResult ( ) ;
MediaSnippet ms ;
int c = 0 ;
if ( result ! = null ) {
if ( result == null ) return c ;
// iterate over all images in the result
// iterate over all images in the result
final ArrayList < MediaSnippet > imagemedia = result . mediaSnippets ( ) ;
final ArrayList < MediaSnippet > imagemedia = result . mediaSnippets ( ) ;
if ( imagemedia ! = null ) {
if ( imagemedia ! = null ) {
for ( int j = 0 ; j < imagemedia . size ( ) ; j + + ) {
for ( MediaSnippet ms : imagemedia ) {
ms = imagemedia . get ( j ) ;
images . push ( ms , Long . valueOf ( ms . ranking ) ) ;
images . push ( ms , Long . valueOf ( ms . ranking ) ) ;
//System.out.println("*** image " + ms.href.hash() + " images.size = " + images.size() + "/" + images.size());
c + + ;
}
System . out . println ( "*** image " + new String ( ms . href . hash ( ) ) + " images.size = " + images . size ( ) + "/" + images . size ( ) ) ;
}
}
}
}
return c ;
// now take the specific item from the image stack
if ( this . images . size ( ) < = item ) return null ;
return this . images . element ( item ) . element ;
}
}
public ArrayList < SortStack < ResultEntry > . stackElement > completeResults ( final long waitingtime ) {
public ArrayList < SortStack < ResultEntry > . stackElement > completeResults ( final long waitingtime ) {