 3cbbf82073
			
		
	
	3cbbf82073
	
	
	
		
			
			With some recent changes, a dictionary argument could be provided as: key1,key2,key3 But list arguments had to be space separated: "x1 x2 x3" This patch makes this consistent, to always be comma separated. At the same time backward compatibility is being preserved. Some other bugs are also getting fixed on account of this clean up: Closes-bug: 1505452 Closes-bug: 1452155 Closes-bug: 1482310 Closes-bug: 1505343 Closes-bug: 1501659 Closes-bug: 1452156 Closes-bug: 1486725 Closes-bug: 1403192 Change-Id: Ie9128e35fb75af71249dfdcfeef2c1f4f812f118
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #    Licensed under the Apache License, Version 2.0 (the "License"); you may
 | |
| #    not use this file except in compliance with the License. You may obtain
 | |
| #    a copy of the License at
 | |
| #
 | |
| #         http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| #    Unless required by applicable law or agreed to in writing, software
 | |
| #    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | |
| #    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | |
| #    License for the specific language governing permissions and limitations
 | |
| #    under the License.
 | |
| #
 | |
| 
 | |
| 
 | |
| import re
 | |
| 
 | |
| 
 | |
| def str2dict(strdict):
 | |
|     """Convert key1=value1,key2=value2,... string into dictionary.
 | |
| 
 | |
|     :param strdict: key1=value1,key2=value2
 | |
|     Note: This implementation overrides the original implementation
 | |
|     in the neutronclient such that it is no longer required to append
 | |
|     the key with a = to specify a corresponding empty value. For example,
 | |
|     key1=value1,key2,key3=value3
 | |
|     key1
 | |
|     key1,key2
 | |
|     will also be supported and converted to a dictionary with empty
 | |
|     values for the relevant keys.
 | |
|     """
 | |
|     if not strdict:
 | |
|         return {}
 | |
|     return dict([kv.split('=', 1) if '=' in kv else [kv, ""]
 | |
|                  for kv in strdict.split(',')])
 | |
| 
 | |
| 
 | |
| def str2list(strlist):
 | |
|     """Convert key1,key2,... string into list.
 | |
| 
 | |
|     :param strlist: key1,key2
 | |
|     strlist can be comma or space separated.
 | |
|     """
 | |
|     if strlist is not None:
 | |
|         strlist = strlist.strip(', ')
 | |
|     if not strlist:
 | |
|         return []
 | |
|     return re.split("[, ]+", strlist)
 |