Skip to content

Commit e2b5abf

Browse files
authored
Merge pull request #3459 from TeamTamoad/maketrans
Fix maketrans not thrown ValueError when length of the arguments are …
2 parents 3f2bab6 + cf7c815 commit e2b5abf

File tree

4 files changed

+14
-7
lines changed

4 files changed

+14
-7
lines changed

Lib/test/test_bytes.py

-2
Original file line numberDiff line numberDiff line change
@@ -859,8 +859,6 @@ def test_ord(self):
859859
self.assertEqual([ord(b[i:i+1]) for i in range(len(b))],
860860
[0, 65, 127, 128, 255])
861861

862-
# TODO: RUSTPYTHON
863-
@unittest.expectedFailure
864862
def test_maketrans(self):
865863
transtable = b'\000\001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037 !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`xyzdefghijklmnopqrstuvwxyz{|}~\177\200\201\202\203\204\205\206\207\210\211\212\213\214\215\216\217\220\221\222\223\224\225\226\227\230\231\232\233\234\235\236\237\240\241\242\243\244\245\246\247\250\251\252\253\254\255\256\257\260\261\262\263\264\265\266\267\270\271\272\273\274\275\276\277\300\301\302\303\304\305\306\307\310\311\312\313\314\315\316\317\320\321\322\323\324\325\326\327\330\331\332\333\334\335\336\337\340\341\342\343\344\345\346\347\350\351\352\353\354\355\356\357\360\361\362\363\364\365\366\367\370\371\372\373\374\375\376\377'
866864
self.assertEqual(self.type2test.maketrans(b'abc', b'xyz'), transtable)

vm/src/builtins/bytearray.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -228,8 +228,8 @@ impl PyByteArray {
228228
}
229229

230230
#[pymethod]
231-
fn maketrans(from: PyBytesInner, to: PyBytesInner) -> PyResult<Vec<u8>> {
232-
PyBytesInner::maketrans(from, to)
231+
fn maketrans(from: PyBytesInner, to: PyBytesInner, vm: &VirtualMachine) -> PyResult<Vec<u8>> {
232+
PyBytesInner::maketrans(from, to, vm)
233233
}
234234

235235
#[pymethod]

vm/src/builtins/bytes.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -150,8 +150,8 @@ impl PyBytes {
150150
}
151151

152152
#[pymethod]
153-
fn maketrans(from: PyBytesInner, to: PyBytesInner) -> PyResult<Vec<u8>> {
154-
PyBytesInner::maketrans(from, to)
153+
fn maketrans(from: PyBytesInner, to: PyBytesInner, vm: &VirtualMachine) -> PyResult<Vec<u8>> {
154+
PyBytesInner::maketrans(from, to, vm)
155155
}
156156

157157
#[pymethod(magic)]

vm/src/bytesinner.rs

+10-1
Original file line numberDiff line numberDiff line change
@@ -525,7 +525,16 @@ impl PyBytesInner {
525525
Ok(self.elements.py_find(&needle, range, find))
526526
}
527527

528-
pub fn maketrans(from: PyBytesInner, to: PyBytesInner) -> PyResult<Vec<u8>> {
528+
pub fn maketrans(
529+
from: PyBytesInner,
530+
to: PyBytesInner,
531+
vm: &VirtualMachine,
532+
) -> PyResult<Vec<u8>> {
533+
if from.len() != to.len() {
534+
return Err(
535+
vm.new_value_error("the two maketrans arguments must have equal length".to_owned())
536+
);
537+
}
529538
let mut res = vec![];
530539

531540
for i in 0..=255 {

0 commit comments

Comments
 (0)