-
Notifications
You must be signed in to change notification settings - Fork 54
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Revamp manga list syncing method #75
Comments
Pros and cons as far as I see it: ==chrome.storage:== ==chrome.syncFileSystem== ==Bookmark method== It seems to me that in all cases we need to store a serialized json object, so that won't be a deciding factor. |
You're absolutely correct about that... (just tested it to make sure) Teaches me to read more carefully... Good breakdown though, certainly storage.sync would be the simplest to implement since it really is just syncable localstorage with more severe storage limitations. |
I feel the best to do for now is to find out why bookmark sync isn't working and wait to implement a new sync until the new storage solution has been finalized. Replacing manga names with unique ids would shrink the json string, so starting to implement storage.sync now might lead to us making doing a lot of unnececcary work. I'll look at the bookmark sync this weekend if I got time. Also, do you know if a lot of people use this feature? I've never been able to, but I'd love it if I were. Another thing to consider, even if the syncfilesystem api requires a google account, so does the bookmark sync (if you aren't using other bookmark syncing software) so it wouldn't really be an issue. |
That's true, and come to think of it chrome.storage must require a google account too, otherwise how would the data know where to sync to. I guess that means that one pro for the bookmark sync is that it doesn't necessarily require a google account.
Some people must have it working since you don't hear too many complaints about it. Could just be that not many people have the need to sync. I used to have it working, but some AMR version came along and broke it for me. Might be some encoding error like you mentioned earlier. |
In reality was chrome that broke it first, and we didn't touch it when we ported the extension to manifest version 2. So, is to be expected that something doesn't work, but funny enough the export function that use almost the same method works like charm. Also, after 1.5.0 a guy came to forums asking for a method to recover his list because he activated the bookmark syncing backwards (first were he didn't had the list, then in his main) so his list got wiped, so I assumed it does work... About the storage.sync limitations, I've calculate how much data I need to store my stuff, the way I'm thinking about the implementation. My current export json string has about 63k characters, but some of that is easily cut down (like the name of the chapter or the chapter list url), so I was estimating about 156 bytes for the value (the last read chapter link + metadata like categories and stuff) and 13 for the key (unique chapter + mirror numerical value cut till the 13th value, or whatever), way down of the 4,096 bytes per item limit and multiplied for 512... (156+13)_512=169_512=86,528 so we still have space left for more stuff! Bookmarks and preferences... or so I would like it to be. Also, we need to think about the max writes/hour and operations/minute. We might think about a limiter so users don't abuse of this (like deactivating/activating a function several times). We could compress the data using some shady library I saw like 2 month ago whenever we exceed the max value. The compression wasn't binary, if memory serves me right, so we might store it like any other string. Found the library as I was writing my response (thanks again SO) http://stackoverflow.com/a/294421/792066 |
I have a javascript zip implementation that works like a charm. I almost But for a JSON string it would work perfectly. Also if the binary encoding 2013/4/25 Braiam Peguero [email protected]
Fábio de Godoy |
@mexicano21 I'd be curious to see the implementation, I was actually taking a look at the link that @braiam just posted, I found the same function a few days ago. Just made a little test page for it. I manage to reduce my manga list json to about 48% of its size using it 9ms to encode 1ms to decode 24KB file. Although I'm not sure if I was calculating the savings correctly... |
Made an issue about the bug in BSync: |
@fuzetsu I've just tried it but seems that it don't like the ampersand character cuz it became gibberish when I tried. |
@braiam what kind of gibberish? The way it compresses it is by converting it to those unicode characters. Is that what you're seeing? |
Ah, ok, yeah, was a little sleepy and saw like your code shall return the same value. But in any case let's consentrate in the issue at hand. |
Haha, yeah I guess I should have probably put another field to decode the encoded data to prove that it worked. |
The current method of syncing through a bookmark is less than ideal and many people have had trouble getting it to work well for them. There is also the issue of storage space to keep in mind.
Possible Solutions
The text was updated successfully, but these errors were encountered: