Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
edx-platform
Commits
6ce7cc77
Commit
6ce7cc77
authored
Apr 15, 2015
by
Calen Pennington
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move `has` logic down into per-scope caches
parent
43d41d66
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
8 deletions
+28
-8
lms/djangoapps/courseware/model_data.py
+28
-8
No files found.
lms/djangoapps/courseware/model_data.py
View file @
6ce7cc77
...
...
@@ -222,6 +222,18 @@ class DjangoOrmFieldCache(object):
field_object
.
delete
()
del
self
.
_cache
[
cache_key
]
@contract
(
kvs_key
=
DjangoKeyValueStore
.
Key
,
returns
=
bool
)
def
has
(
self
,
kvs_key
):
"""
Return whether the specified `kvs_key` is set.
Arguments:
kvs_key (`DjangoKeyValueStore.Key`): The field value to delete
Returns: bool
"""
return
self
.
_cache_key_for_kvs_key
(
kvs_key
)
in
self
.
_cache
def
__len__
(
self
):
return
len
(
self
.
_cache
)
...
...
@@ -337,6 +349,21 @@ class UserStateCache(DjangoOrmFieldCache):
field_object
.
state
=
json
.
dumps
(
state
)
field_object
.
save
()
@contract
(
kvs_key
=
DjangoKeyValueStore
.
Key
,
returns
=
bool
)
def
has
(
self
,
kvs_key
):
"""
Return whether the specified `kvs_key` is set.
Arguments:
kvs_key (`DjangoKeyValueStore.Key`): The field value to delete
Returns: bool
"""
field_object
=
self
.
_cache
.
get
(
self
.
_cache_key_for_kvs_key
(
kvs_key
))
if
field_object
is
None
:
return
False
return
kvs_key
.
field_name
in
json
.
loads
(
field_object
.
state
)
class
UserStateSummaryCache
(
DjangoOrmFieldCache
):
"""
...
...
@@ -724,14 +751,7 @@ class FieldDataCache(object):
if
key
.
scope
not
in
self
.
cache
:
return
False
field_object
=
self
.
cache
[
key
.
scope
]
.
get
(
key
)
if
field_object
is
None
:
return
False
if
key
.
scope
==
Scope
.
user_state
:
return
key
.
field_name
in
json
.
loads
(
field_object
.
state
)
else
:
return
True
return
self
.
cache
[
key
.
scope
]
.
has
(
key
)
def
find_or_create
(
self
,
key
):
'''
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment