Load thumbnails from cache
This commit is contained in:
		
							parent
							
								
									c21a3e3f28
								
							
						
					
					
						commit
						1d0f51f95a
					
				
							
								
								
									
										37
									
								
								thumbs.c
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								thumbs.c
									
									
									
									
									
								
							| @ -31,6 +31,7 @@ extern Imlib_Image *im_invalid; | ||||
| const int thumb_dim = THUMB_SIZE + 10; | ||||
| 
 | ||||
| int tns_cache_enabled(); | ||||
| Imlib_Image* tns_cache_load(const char*); | ||||
| void tns_cache_write(thumb_t*, Bool); | ||||
| 
 | ||||
| void tns_init(tns_t *tns, int cnt) { | ||||
| @ -87,7 +88,8 @@ void tns_load(tns_t *tns, win_t *win, int n, const char *filename) { | ||||
| 		imlib_free_image(); | ||||
| 	} | ||||
| 
 | ||||
| 	if ((im = imlib_load_image(filename))) | ||||
| 	if ((tns_cache_enabled() && (im = tns_cache_load(filename))) || | ||||
| 	    (im = imlib_load_image(filename))) | ||||
| 		imlib_context_set_image(im); | ||||
| 	else | ||||
| 		imlib_context_set_image(im_invalid); | ||||
| @ -346,6 +348,29 @@ char* tns_cache_filename(const char *filename) { | ||||
| 	return cfile; | ||||
| } | ||||
| 
 | ||||
| Imlib_Image* tns_cache_load(const char *filename) { | ||||
| 	char *cfile; | ||||
| 	struct stat cstats, fstats; | ||||
| 	Imlib_Image *im = NULL; | ||||
| 
 | ||||
| 	if (!filename || stat(filename, &fstats)) | ||||
| 		return NULL; | ||||
| 
 | ||||
| 	if ((cfile = tns_cache_filename(filename))) { | ||||
| 		if (!stat(cfile, &cstats) && | ||||
| 		    cstats.st_mtim.tv_sec == fstats.st_mtim.tv_sec && | ||||
| 				cstats.st_mtim.tv_nsec == fstats.st_mtim.tv_nsec) | ||||
| 		{ | ||||
| 			printf("cache hit:  %s\n", filename); | ||||
| 			im = imlib_load_image(cfile); | ||||
| 		} else | ||||
| 			printf("cache MISS: %s\n", filename); | ||||
| 		free(cfile); | ||||
| 	} | ||||
| 
 | ||||
| 	return im; | ||||
| } | ||||
| 
 | ||||
| void tns_cache_write(thumb_t *t, Bool force) { | ||||
| 	char *cfile; | ||||
| 	struct stat cstats, fstats; | ||||
| @ -354,11 +379,10 @@ void tns_cache_write(thumb_t *t, Bool force) { | ||||
| 
 | ||||
| 	if (!t || !t->im || !t->filename) | ||||
| 		return; | ||||
| 	if (stat(t->filename, &fstats)) | ||||
| 		return; | ||||
| 
 | ||||
| 	if ((cfile = tns_cache_filename(t->filename))) { | ||||
| 		if (stat(t->filename, &fstats)) | ||||
| 			goto end; | ||||
| 
 | ||||
| 		if (force || stat(cfile, &cstats) || | ||||
| 		    cstats.st_mtim.tv_sec != fstats.st_mtim.tv_sec || | ||||
| 		    cstats.st_mtim.tv_nsec != fstats.st_mtim.tv_nsec) | ||||
| @ -373,10 +397,9 @@ void tns_cache_write(thumb_t *t, Bool force) { | ||||
| 				TIMESPEC_TO_TIMEVAL(×[0], &fstats.st_atim); | ||||
| 				TIMESPEC_TO_TIMEVAL(×[1], &fstats.st_mtim); | ||||
| 				utimes(cfile, times); | ||||
| 				printf("thumbnail cache file written: %s\n", t->filename); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| end: | ||||
| 		free(cfile); | ||||
| 	} | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Bert
						Bert