forked from len0rd/rockbox
plugin: search,sort: Handle UTF-8 BOM at the start of file.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@24081 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
275d960b04
commit
0cbf210d76
4 changed files with 46 additions and 32 deletions
|
@ -65,6 +65,7 @@ static int num_entries;
|
|||
static char **pointers;
|
||||
static char *stringbuffer;
|
||||
static char crlf[2] = "\r\n";
|
||||
static int bomsize;
|
||||
|
||||
/* Compare function for sorting backwards */
|
||||
static int compare(const void* p1, const void* p2)
|
||||
|
@ -86,11 +87,14 @@ int read_buffer(int offset)
|
|||
char *buf_ptr;
|
||||
char *tmp_ptr;
|
||||
int readsize;
|
||||
|
||||
fd = rb->open(filename, O_RDONLY);
|
||||
|
||||
fd = rb->open_utf8(filename, O_RDONLY);
|
||||
if(fd < 0)
|
||||
return 10 * fd - 1;
|
||||
|
||||
bomsize = rb->lseek(fd, 0, SEEK_CUR);
|
||||
offset += bomsize;
|
||||
|
||||
/* Fill the buffer from the file */
|
||||
rb->lseek(fd, offset, SEEK_SET);
|
||||
readsize = rb->read(fd, stringbuffer, buf_size);
|
||||
|
@ -127,7 +131,7 @@ int read_buffer(int offset)
|
|||
num_entries++;
|
||||
buf_ptr++;
|
||||
} while(buf_ptr < stringbuffer + readsize);
|
||||
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -140,7 +144,11 @@ static int write_file(void)
|
|||
|
||||
/* Create a temporary file */
|
||||
rb->snprintf(tmpfilename, MAX_PATH+1, "%s.tmp", filename);
|
||||
fd = rb->creat(tmpfilename);
|
||||
if (bomsize)
|
||||
fd = rb->open_utf8(tmpfilename, O_WRONLY|O_CREAT|O_TRUNC);
|
||||
else
|
||||
fd = rb->open(tmpfilename, O_WRONLY|O_CREAT|O_TRUNC);
|
||||
|
||||
if(fd < 0)
|
||||
return 10 * fd - 1;
|
||||
|
||||
|
@ -191,16 +199,16 @@ enum plugin_status plugin_start(const void* parameter)
|
|||
|
||||
rb->lcd_clear_display();
|
||||
rb->splash(0, "Loading...");
|
||||
|
||||
|
||||
rc = read_buffer(0);
|
||||
if(rc == 0) {
|
||||
rb->lcd_clear_display();
|
||||
rb->splash(0, "Sorting...");
|
||||
sort_buffer();
|
||||
|
||||
|
||||
rb->lcd_clear_display();
|
||||
rb->splash(0, "Writing...");
|
||||
|
||||
|
||||
rc = write_file();
|
||||
if(rc < 0) {
|
||||
rb->lcd_clear_display();
|
||||
|
@ -218,6 +226,6 @@ enum plugin_status plugin_start(const void* parameter)
|
|||
rb->splash(HZ, "The file is too big");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return PLUGIN_OK;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue