Skip to content

Commit a040999

Browse files
committed
[GR-12819] bytes and bytearray don't have implemented upper and lower fucntions.
1 parent 8e1a81f commit a040999

File tree

2 files changed

+106
-0
lines changed

2 files changed

+106
-0
lines changed

graalpython/com.oracle.graal.python/src/com/oracle/graal/python/builtins/Python3Core.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -88,6 +88,7 @@
8888
import com.oracle.graal.python.builtins.modules.ZLibModuleBuiltins;
8989
import com.oracle.graal.python.builtins.objects.array.ArrayBuiltins;
9090
import com.oracle.graal.python.builtins.objects.bool.BoolBuiltins;
91+
import com.oracle.graal.python.builtins.objects.bytes.AbstractBytesBuiltins;
9192
import com.oracle.graal.python.builtins.objects.bytes.ByteArrayBuiltins;
9293
import com.oracle.graal.python.builtins.objects.bytes.BytesBuiltins;
9394
import com.oracle.graal.python.builtins.objects.cell.CellBuiltins;
@@ -239,6 +240,7 @@ private static final PythonBuiltins[] initializeBuiltins() {
239240
new BytesBuiltins(),
240241
new ComplexBuiltins(),
241242
new ByteArrayBuiltins(),
243+
new AbstractBytesBuiltins(),
242244
new TypeBuiltins(),
243245
new IntBuiltins(),
244246
new TruffleObjectBuiltins(),
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,104 @@
1+
/*
2+
* Copyright (c) 2017, 2018, Oracle and/or its affiliates.
3+
* Copyright (c) 2014, Regents of the University of California
4+
*
5+
* All rights reserved.
6+
*
7+
* Redistribution and use in source and binary forms, with or without modification, are
8+
* permitted provided that the following conditions are met:
9+
*
10+
* 1. Redistributions of source code must retain the above copyright notice, this list of
11+
* conditions and the following disclaimer.
12+
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of
13+
* conditions and the following disclaimer in the documentation and/or other materials provided
14+
* with the distribution.
15+
*
16+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS
17+
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18+
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19+
* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20+
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
21+
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
22+
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
23+
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
24+
* OF THE POSSIBILITY OF SUCH DAMAGE.
25+
*/
26+
27+
package com.oracle.graal.python.builtins.objects.bytes;
28+
29+
import com.oracle.graal.python.builtins.Builtin;
30+
import com.oracle.graal.python.builtins.CoreFunctions;
31+
import com.oracle.graal.python.builtins.PythonBuiltinClassType;
32+
import com.oracle.graal.python.builtins.PythonBuiltins;
33+
import com.oracle.graal.python.nodes.function.PythonBuiltinBaseNode;
34+
import com.oracle.graal.python.nodes.function.builtins.PythonUnaryBuiltinNode;
35+
import com.oracle.truffle.api.CompilerDirectives;
36+
import com.oracle.truffle.api.dsl.GenerateNodeFactory;
37+
import com.oracle.truffle.api.dsl.NodeFactory;
38+
import com.oracle.truffle.api.dsl.Specialization;
39+
import com.oracle.truffle.api.nodes.Node;
40+
import java.io.UnsupportedEncodingException;
41+
import java.util.List;
42+
43+
@CoreFunctions(extendClasses = {PythonBuiltinClassType.PByteArray, PythonBuiltinClassType.PBytes})
44+
public class AbstractBytesBuiltins extends PythonBuiltins {
45+
46+
@Override
47+
protected List<? extends NodeFactory<? extends PythonBuiltinBaseNode>> getNodeFactories() {
48+
return AbstractBytesBuiltinsFactory.getFactories();
49+
}
50+
51+
@Builtin(name = "lower", fixedNumOfPositionalArgs = 1)
52+
@GenerateNodeFactory
53+
abstract static class LowerNode extends PythonUnaryBuiltinNode {
54+
@Node.Child private BytesNodes.ToBytesNode toBytes = BytesNodes.ToBytesNode.create();
55+
56+
@CompilerDirectives.TruffleBoundary
57+
private static byte[] lower(byte[] bytes) {
58+
try {
59+
String string = new String(bytes, "ASCII");
60+
return string.toLowerCase().getBytes("ASCII");
61+
} catch (UnsupportedEncodingException e) {
62+
CompilerDirectives.transferToInterpreter();
63+
throw new IllegalStateException();
64+
}
65+
}
66+
67+
@Specialization
68+
PByteArray replace(PByteArray self) {
69+
return factory().createByteArray(lower(toBytes.execute(self)));
70+
}
71+
72+
@Specialization
73+
PBytes replace(PBytes self) {
74+
return factory().createBytes(lower(toBytes.execute(self)));
75+
}
76+
}
77+
78+
@Builtin(name = "upper", fixedNumOfPositionalArgs = 1)
79+
@GenerateNodeFactory
80+
abstract static class UpperNode extends PythonUnaryBuiltinNode {
81+
@Node.Child private BytesNodes.ToBytesNode toBytes = BytesNodes.ToBytesNode.create();
82+
83+
@CompilerDirectives.TruffleBoundary
84+
private static byte[] upper(byte[] bytes) {
85+
try {
86+
String string = new String(bytes, "ASCII");
87+
return string.toUpperCase().getBytes("ASCII");
88+
} catch (UnsupportedEncodingException e) {
89+
CompilerDirectives.transferToInterpreter();
90+
throw new IllegalStateException();
91+
}
92+
}
93+
94+
@Specialization
95+
PByteArray replace(PByteArray self) {
96+
return factory().createByteArray(upper(toBytes.execute(self)));
97+
}
98+
99+
@Specialization
100+
PBytes replace(PBytes self) {
101+
return factory().createBytes(upper(toBytes.execute(self)));
102+
}
103+
}
104+
}

0 commit comments

Comments
 (0)