Age | Commit message (Collapse) | Author | |
---|---|---|---|
2019-03-11 | Json parsing fix + new API for copying. | Mike Buland | |
2018-12-17 | Bu::Json handles encoding control chars. | Mike Buland | |
It still needs to handle the rest of unicode properly. It'll require a minor change but shouldn't be too bad overall. | |||
2018-12-11 | Fixed MyriadFS path exists error. | Mike Buland | |
Also started some FS related thread safety. | |||
2018-11-07 | Added convinience Key/Value typedefs to ptrs. | Mike Buland | |
2018-07-16 | Removed a little cache debugging. | Mike Buland | |
2018-07-02 | Added a threadsafe speedometer class. | Mike Buland | |
2018-02-20 | Json parse fixes. | Mike Buland | |
It didn't handle empty arrays or objects correctly. | |||
2018-02-05 | Removed some debugging. | Mike Buland | |
2018-01-29 | Changes related to debugging an issue. | Mike Buland | |
It may not have had as much to do with low-level protocol details, and a lot of this can be reverted, but I can't revert it right now. I'll look it over later in the week. | |||
2018-01-24 | Json stuff | Mike Buland | |
2018-01-22 | Fixed escaped character encoding in Json decoding. | Mike Buland | |
2018-01-18 | Made json much more helpful. Fixed array iterators. | Mike Buland | |
2017-10-18 | I think this version works. | Mike Buland | |
It would be really cool to add more features, like pre-websocket negotiation and callbacks for serving web content, etc. | |||
2017-08-30 | Json now can take a UtfString as a text component. | Mike Buland | |
It immedaitely converts it to UTF-8 and stores it for now, but later on we may keep it longer, do some better validation, and have encoding options. | |||
2017-08-23 | Json has a "has" function now. | Mike Buland | |
2017-08-23 | Added append to the json interface. | Mike Buland | |
It needs a lot more help. | |||
2017-08-23 | Fixed string constructor. | Mike Buland | |
2017-08-22 | Updated json. | Mike Buland | |
It needs a lot more work before it can be used to programattically build complex objects, but it's a great start. | |||
2017-06-07 | Changed interface slightly, it's easier to create json programmatically. | Mike Buland | |
2017-06-06 | Reading, writing, and accessing loaded data all work. | Mike Buland | |
2017-06-06 | Hey! This is a much better structure for the Json class. | Mike Buland | |
This new setup is one class for everything, the values are kept in a union, and the instance knows what type it is. The tree of objects is a tree of instantiations of the same class. It's much simpler, it's much easier to write, and maybe even easier to use. | |||
2017-06-05 | Json? | Mike Buland | |
I'm honestly not sure what kind of interface I want here, or how to organize it. It may just be better to expand the whole thing, spread it out some. | |||
2016-09-22 | Included the experimental TeeStream. | Mike Buland | |
This allows you to write data to multiple streams simultaneously and easily. It's pretty much complete, but it feels like it could use more...features somehow. | |||
2015-09-13 | The cache wasn't accessible from CacheObject decendants that were const. | Mike Buland | |
2015-08-25 | Added more lock/unlock features to the cache Lockers. That...was a weird | Mike Buland | |
sentence, but it's true. Also, oddly enough, Lockers aren't thread-safe, but they shouldn't ever have to be. Figure that one out! | |||
2015-08-24 | Added some refcount debugging. | Mike Buland | |
2015-08-16 | Thread safety update for the previous commit. I left one structure access | Mike Buland | |
unprotected, but fortunately this time I was able to use a read lock which is much lest nasty and persistant. | |||
2015-08-16 | Fixed a highly essoteric issue. The ReadWriteMutex was locked in write while | Mike Buland | |
syncing changes. That was important so that more changes wouldn't be added while we're writing, but it also meant that in a very particular circumstance where one thread was syncing changes, another was marking changes as having happened, and another locked an object that was being written because it had changes they would all deadlock. This should be fixed now. | |||
2015-07-14 | constant cache pointers can now be bound and unbound. It may seem odd, but it's | Mike Buland | |
important, they are references to constant data, weather they should be able to become bound still. | |||
2015-06-16 | Const chnaged functions. I think this makes sense. | Mike Buland | |
2014-10-03 | Tweaked Bu::Uuid loading to pad it's data more cleanly. This will help ensure | Mike Buland | |
that we don't get valgrind errors, and is probably safer in general. Added Bu::ArchiveStream. It could use some tweaks, but as a quick hack it's handy to allow systems that can only read/write from/to streams to work with archives. | |||
2014-08-08 | The cache didn't handle syncing objects that were marked changed and then | Mike Buland | |
deleted before the sync could occur properly. They are now ignored during sync. | |||
2014-07-22 | Deferred erase now works on cache entries. You can erase a cache entry while | Mike Buland | |
it still has active references, and it will be safely cleaned up when the last reference is released. | |||
2014-03-05 | Added a method to null/clear a cache pointer, and one to see if it's set at all. | Mike Buland | |
2014-02-03 | Changed copyright to 2007-2014. | Mike Buland | |
2014-02-03 | Compiles with LLVM 3.4 as well now. | Mike Buland | |
2014-01-30 | Attempting to fix OSX compatibility, it's not 100%, but it builds and most ↵ | Mike Buland | |
things seem to work. We've also tested against LLVM. | |||
2014-01-22 | Updated the cache system. It now ensures that objects are initialized with | Mike Buland | |
cache information before they are deserialized from storage. This changed the signature of the cache loading template function, but the new function isn't harder to use, and provides the key information as well. | |||
2013-07-20 | Added a Locker class to the Bu::CacheObject base class. This is a super simple | Mike Buland | |
wrapper that lets you take advantage of nifty Locker based mutex locking when in a CacheObject subclass. | |||
2013-07-18 | Fixed caching changed issue. The cache now marks objects as unchanged for you | Mike Buland | |
after they are saved. It needs some more testing, but the theory is sound. | |||
2013-07-03 | Modified the Bu::CacheBase API, what was erase is eraseNow, and erase is about | Mike Buland | |
to be re-engineered to actually do a lazy erase like removing an iNode in a posix filesystem. While the file remains open it exists, but the references visible to the user on disk are gone. | |||
2013-04-08 | Minor tweaks to the cache object base class. The per-object mutex is actually | Mike Buland | |
in the CacheEntry class, not the CacheObject, so you can't lock it until you have an entry. This isn't a big deal unless your objects aren't actually part of a cache yet. I changed it so that lock/unlock have no effect if you haven't joined to a cache yet, probably not ideal, I'll think about moving that mutex. I also fixed it so you can lock/unlock even when const. | |||
2013-03-25 | Corrected a pure virtual call issue while destroying caches. | Mike Buland | |
2013-03-21 | The Bu::MyriadCache now ensures that it saves the myriad structure after | Mike Buland | |
saving an entry or syncing. | |||
2013-03-18 | Cache object handles changed() events when no cache has been set cleanly now. | Mike Buland | |
2013-03-18 | Added the has function to the new cache system. If the object identified by | Mike Buland | |
key is loaded then the query doesn't even get to the superclass. | |||
2013-03-18 | Corrected compliation issue in the new cache with older GCC versions. | Mike Buland | |
2013-03-17 | The new cache system has been broken out into it's individual headers, and is | Mike Buland | |
now ready for actual use. | |||
2013-03-12 | Bu::Uuid now supports being formatted, it uses the standard toString() method. | Mike Buland | |
The new cache is really coming along now. | |||
2013-03-03 | Adding the Bu::DualFilter which could work out really well, it's going in for | Mike Buland | |
testing now. The idea is that it makes it easy to use a bi-directional stream like a tcpstream that requires a seperate filter instance for each read and write side. |