Skip to content

Commit

Permalink
[Truffle] - Implements String#swapcase!
Browse files Browse the repository at this point in the history
  • Loading branch information
lucasallan committed Feb 9, 2015
1 parent a294f73 commit 944a8b7
Showing 1 changed file with 42 additions and 14 deletions.
56 changes: 42 additions & 14 deletions truffle/src/main/java/org/jruby/truffle/nodes/core/StringNodes.java
Original file line number Diff line number Diff line change
Expand Up @@ -730,7 +730,7 @@ public Object eachChar(VirtualFrame frame, RubyString string, @SuppressWarnings(
public RubyString eachChar(VirtualFrame frame, RubyString string, RubyProc block) {
notDesignedForCompilation();

// TODO (nirvdrum 04-Feb-15): This needs to support Ruby's encoding and code range semantics. For now, this hack will suffice for very simple Strings.
// TODO (nirvdrum 04-Feb-15): This needs to support Ruby' encoding and code range semantics. For now, this hack will suffice for very simple Strings.
final String javaString = string.toString();

for (int i = 0; i < javaString.length(); i++) {
Expand Down Expand Up @@ -1343,21 +1343,28 @@ public SwapcaseNode(SwapcaseNode prev) {
public RubyString swapcase(RubyString string) {
notDesignedForCompilation();

char[] charArray = string.toString().toCharArray();
StringBuilder newString = new StringBuilder();
ByteList byteList = StringNodesHelper.swapcase(string);
return getContext().makeString(byteList);
}
}

for (int i = 0; i < charArray.length; i++) {
char current = charArray[i];
@CoreMethod(names = "swapcase!")
public abstract static class SwapcaseBangNode extends CoreMethodNode {
public SwapcaseBangNode(RubyContext context, SourceSection sourceSection) {
super(context, sourceSection);
}

if (Character.isLowerCase(current)) {
newString.append(Character.toString(current).toUpperCase());
} else if (Character.isUpperCase(current)){
newString.append(Character.toString(current).toLowerCase());
} else {
newString.append(current);
}
}
return getContext().makeString(newString.toString(), string.getByteList().getEncoding());
public SwapcaseBangNode(SwapcaseBangNode prev) {
super(prev);
}

@Specialization
public RubyString swapcase(RubyString string) {
notDesignedForCompilation();

ByteList byteList = StringNodesHelper.swapcase(string);
string.set(byteList);
return string;
}
}

Expand Down Expand Up @@ -2033,6 +2040,27 @@ public static ByteList reverse(RubyString string) {

return byteListString;
}

public static ByteList swapcase(RubyString string) {
char[] charArray = string.toString().toCharArray();
StringBuilder newString = new StringBuilder();

for (int i = 0; i < charArray.length; i++) {
char current = charArray[i];

if (Character.isLowerCase(current)) {
newString.append(Character.toString(current).toUpperCase());
} else if (Character.isUpperCase(current)){
newString.append(Character.toString(current).toLowerCase());
} else {
newString.append(current);
}
}
ByteList byteListString = ByteList.create(newString);
byteListString.setEncoding(string.getBytes().getEncoding());

return byteListString;
}
}

}

0 comments on commit 944a8b7

Please sign in to comment.