-
Notifications
You must be signed in to change notification settings - Fork 21
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
Add map access feature for lists #36
base: master
Are you sure you want to change the base?
Conversation
This change means that all list entries have to be visited upon the first access, whereas with the current code only half of the entries (on the average) need to be visited. Perhaps it would be better to implement |
I see your point, the problem is that if you have only a partial cache, each query for a non-existing key has to iterate over all elements. Using the key-access operator only takes double the time if you populate the cache fully, but all consecutive accesses will be very fast (both hit and miss). My current problem is that the cache needs to be cleared/updated every times a node member gets added, removed or changed... and I am still trying to work out on which code paths this would happen. |
@HRogge my idea was to scan only entries that haven't been scanned yet. That would mean also keeping the index of the last-scanned entry. |
I like this idea... I will see that I modify my path and send a new pull request so that you can review it. The only thing missing then would be to clear/modify the index if something modifies the keys of a subnode. |
I have changed the caching lookup to the one you suggested and also added a "map" based lookup and some convenience functions. |
Looks good, thanks. I will add some tests and update docs, and then make a new version. BTW, do you have any bigger data to demonstrate a speedup? |
No... but I always worry that I break existing stuff by introducing some nice O(n^2) delay... it would also work without the cache... |
Any new thoughts about merging this changes? Anything I should change on the code before this happens? |
Actually, this change also has to be reflected in methods that manipulate the instance, like |
I will create a branch without the cache and send another pull request. I still think the cache could be useful, but you are right that I might have missed some parts where the instance data can be modified. |
I have removed the mapping cache for now, maybe you want to have a look again? |
Hmm, I don't see anything new, the last commit in this PR is still from 20 January. |
Sorry, I pushed the wrong branch... sigh |
Cleanup XML element generation
Cleanup XML element generation
This change allows to access children of InstanceNodes to be accessed by a tuple containing the keys defined in the yang schema:
instancenode[(1,'hello')]
for a yang structure like
to increase performance the mapping between the list and its children is calculated and stored during first use.