Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F121987126
washers.py
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Tue, Jul 15, 05:15
Size
3 KB
Mime Type
text/x-python
Expires
Thu, Jul 17, 05:15 (2 d)
Engine
blob
Format
Raw Data
Handle
27414794
Attached To
R3600 invenio-infoscience
washers.py
View Options
# -*- coding: utf-8 -*-
# This file is part of Invenio.
# Copyright (C) 2012, 2013, 2014, 2015 CERN.
#
# Invenio is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation; either version 2 of the
# License, or (at your option) any later version.
#
# Invenio is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Invenio; if not, write to the Free Software Foundation, Inc.,
# 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
#
"""Washing utilities."""
import
types
def
wash_urlargd
(
form
,
content
):
"""Wash the complete form based on the specification in content.
Content is a dictionary containing the field names as a
key, and a tuple (type, default) as value.
'type' can be list, unicode, invenio.legacy.wsgi.utils.StringField, int,
tuple, or invenio.legacy.wsgi.utils.Field (for file uploads).
The specification automatically includes the 'ln' field, which is
common to all queries.
Arguments that are not defined in 'content' are discarded.
.. note::
In case `list` or `tuple` were asked for, we assume that
`list` or `tuple` of strings is to be returned. Therefore beware when
you want to use ``wash_urlargd()`` for multiple file upload forms.
:returns: argd dictionary that can be used for passing function
parameters by keywords.
"""
result
=
{}
for
k
,
(
dst_type
,
default
)
in
content
.
items
():
try
:
value
=
form
[
k
]
except
KeyError
:
result
[
k
]
=
default
continue
src_type
=
type
(
value
)
# First, handle the case where we want all the results. In
# this case, we need to ensure all the elements are strings,
# and not Field instances.
if
src_type
in
(
list
,
tuple
):
if
dst_type
is
list
:
result
[
k
]
=
[
x
for
x
in
value
]
continue
if
dst_type
is
tuple
:
result
[
k
]
=
tuple
([
x
for
x
in
value
])
continue
# in all the other cases, we are only interested in the
# first value.
value
=
value
[
0
]
# Allow passing argument modyfing function.
if
isinstance
(
dst_type
,
types
.
FunctionType
):
result
[
k
]
=
dst_type
(
value
)
continue
# Maybe we already have what is expected? Then don't change
# anything.
if
isinstance
(
value
,
dst_type
):
result
[
k
]
=
value
continue
# Since we got here, 'value' is sure to be a single symbol,
# not a list kind of structure anymore.
if
dst_type
in
(
int
,
float
,
long
,
bool
):
try
:
result
[
k
]
=
dst_type
(
value
)
except
:
result
[
k
]
=
default
elif
dst_type
is
tuple
:
result
[
k
]
=
(
value
,
)
elif
dst_type
is
list
:
result
[
k
]
=
[
value
]
else
:
raise
ValueError
(
'cannot cast form value
%s
of type
%r
into type
%r
'
%
(
value
,
src_type
,
dst_type
))
return
result
def
wash_html_id
(
dirty
):
"""Strip non-alphabetic or newline characters from a given string.
It can be used as a HTML element ID (also with jQuery and in all browsers).
:param dirty: the string to wash
:returns: the HTML ID ready string
"""
import
re
if
not
dirty
[
0
]
.
isalpha
():
# we make sure that the first character is a lowercase letter
dirty
=
'i'
+
dirty
non_word
=
re
.
compile
(
r'[^\w]+'
)
return
non_word
.
sub
(
''
,
dirty
)
Event Timeline
Log In to Comment