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
cbed6628
Commit
cbed6628
authored
Mar 20, 2013
by
Calen Pennington
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix pep8 and pylint errors
parent
36443163
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
31 additions
and
4 deletions
+31
-4
.pylintrc
+2
-1
lms/djangoapps/courseware/model_data.py
+29
-3
No files found.
.pylintrc
View file @
cbed6628
...
@@ -41,7 +41,8 @@ disable=
...
@@ -41,7 +41,8 @@ disable=
# R0902: Too many instance attributes
# R0902: Too many instance attributes
# R0903: Too few public methods (1/2)
# R0903: Too few public methods (1/2)
# R0904: Too many public methods
# R0904: Too many public methods
W0141,W0142,R0201,R0901,R0902,R0903,R0904
# R0913: Too many arguments
W0141,W0142,R0201,R0901,R0902,R0903,R0904,R0913
[REPORTS]
[REPORTS]
...
...
lms/djangoapps/courseware/model_data.py
View file @
cbed6628
"""
Classes to provide the LMS runtime data storage to XBlocks
"""
import
json
import
json
from
collections
import
namedtuple
,
defaultdict
from
collections
import
namedtuple
,
defaultdict
from
itertools
import
chain
from
itertools
import
chain
...
@@ -14,10 +18,16 @@ from xblock.core import Scope
...
@@ -14,10 +18,16 @@ from xblock.core import Scope
class
InvalidWriteError
(
Exception
):
class
InvalidWriteError
(
Exception
):
pass
"""
Raised to indicate that writing to a particular key
in the KeyValueStore is disabled
"""
def
chunks
(
items
,
chunk_size
):
def
chunks
(
items
,
chunk_size
):
"""
Yields the values from items in chunks of size chunk_size
"""
items
=
list
(
items
)
items
=
list
(
items
)
return
(
items
[
i
:
i
+
chunk_size
]
for
i
in
xrange
(
0
,
len
(
items
),
chunk_size
))
return
(
items
[
i
:
i
+
chunk_size
]
for
i
in
xrange
(
0
,
len
(
items
),
chunk_size
))
...
@@ -67,6 +77,15 @@ class ModelDataCache(object):
...
@@ -67,6 +77,15 @@ class ModelDataCache(object):
"""
"""
def
get_child_descriptors
(
descriptor
,
depth
,
descriptor_filter
):
def
get_child_descriptors
(
descriptor
,
depth
,
descriptor_filter
):
"""
Return a list of all child descriptors down to the specified depth
that match the descriptor filter. Includes `descriptor`
descriptor: The parent to search inside
depth: The number of levels to descend, or None for infinite depth
descriptor_filter(descriptor): A function that returns True
if descriptor should be included in the results
"""
if
descriptor_filter
(
descriptor
):
if
descriptor_filter
(
descriptor
):
descriptors
=
[
descriptor
]
descriptors
=
[
descriptor
]
else
:
else
:
...
@@ -168,6 +187,9 @@ class ModelDataCache(object):
...
@@ -168,6 +187,9 @@ class ModelDataCache(object):
return
scope_map
return
scope_map
def
_cache_key_from_kvs_key
(
self
,
key
):
def
_cache_key_from_kvs_key
(
self
,
key
):
"""
Return the key used in the ModelDataCache for the specified KeyValueStore key
"""
if
key
.
scope
==
Scope
.
student_state
:
if
key
.
scope
==
Scope
.
student_state
:
return
(
key
.
scope
,
key
.
block_scope_id
.
url
())
return
(
key
.
scope
,
key
.
block_scope_id
.
url
())
elif
key
.
scope
==
Scope
.
content
:
elif
key
.
scope
==
Scope
.
content
:
...
@@ -180,6 +202,10 @@ class ModelDataCache(object):
...
@@ -180,6 +202,10 @@ class ModelDataCache(object):
return
(
key
.
scope
,
key
.
field_name
)
return
(
key
.
scope
,
key
.
field_name
)
def
_cache_key_from_field_object
(
self
,
scope
,
field_object
):
def
_cache_key_from_field_object
(
self
,
scope
,
field_object
):
"""
Return the key used in the ModelDataCache for the specified scope and
field
"""
if
scope
==
Scope
.
student_state
:
if
scope
==
Scope
.
student_state
:
return
(
scope
,
field_object
.
module_state_key
)
return
(
scope
,
field_object
.
module_state_key
)
elif
scope
==
Scope
.
content
:
elif
scope
==
Scope
.
content
:
...
@@ -230,7 +256,7 @@ class ModelDataCache(object):
...
@@ -230,7 +256,7 @@ class ModelDataCache(object):
usage_id
=
'
%
s-
%
s'
%
(
self
.
course_id
,
key
.
block_scope_id
.
url
()),
usage_id
=
'
%
s-
%
s'
%
(
self
.
course_id
,
key
.
block_scope_id
.
url
()),
)
)
elif
key
.
scope
==
Scope
.
student_preferences
:
elif
key
.
scope
==
Scope
.
student_preferences
:
field_object
,
_
=
XModuleStudentPrefsField
.
objects
.
get_or_create
(
field_object
,
_
=
XModuleStudentPrefsField
.
objects
.
get_or_create
(
field_name
=
key
.
field_name
,
field_name
=
key
.
field_name
,
module_type
=
key
.
block_scope_id
,
module_type
=
key
.
block_scope_id
,
student
=
self
.
user
.
pk
,
student
=
self
.
user
.
pk
,
...
@@ -276,6 +302,7 @@ class LmsKeyValueStore(KeyValueStore):
...
@@ -276,6 +302,7 @@ class LmsKeyValueStore(KeyValueStore):
Scope
.
student_info
,
Scope
.
student_info
,
Scope
.
children
,
Scope
.
children
,
)
)
def
__init__
(
self
,
descriptor_model_data
,
model_data_cache
):
def
__init__
(
self
,
descriptor_model_data
,
model_data_cache
):
self
.
_descriptor_model_data
=
descriptor_model_data
self
.
_descriptor_model_data
=
descriptor_model_data
self
.
_model_data_cache
=
model_data_cache
self
.
_model_data_cache
=
model_data_cache
...
@@ -357,4 +384,3 @@ class LmsKeyValueStore(KeyValueStore):
...
@@ -357,4 +384,3 @@ class LmsKeyValueStore(KeyValueStore):
LmsUsage
=
namedtuple
(
'LmsUsage'
,
'id, def_id'
)
LmsUsage
=
namedtuple
(
'LmsUsage'
,
'id, def_id'
)
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