Skip to content

Commit

Permalink
Some small refactoring while looking for example snippet code of new API
Browse files Browse the repository at this point in the history
  • Loading branch information
enebo committed Nov 10, 2024
1 parent 97e39d6 commit ce114bc
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 48 deletions.
80 changes: 32 additions & 48 deletions core/src/main/java/org/jruby/RubyRange.java
Original file line number Diff line number Diff line change
Expand Up @@ -373,11 +373,9 @@ private static RubyString inspectValue(final ThreadContext context, IRubyObject
}

private static IRubyObject inspectValueRecursive(ThreadContext context, IRubyObject state, IRubyObject obj, boolean recur) {
if (recur) {
return RubyString.newString(context.runtime, ((RubyRange) obj).isExclusive ? "(... ... ...)" : "(... .. ...)");
} else {
return inspect(context, obj);
}
return recur ?
RubyString.newString(context.runtime, ((RubyRange) obj).isExclusive ? "(... ... ...)" : "(... .. ...)") :
inspect(context, obj);
}

private static final byte[] DOTDOTDOT = new byte[]{'.', '.', '.'};
Expand Down Expand Up @@ -468,10 +466,10 @@ public IRubyObject call(ThreadContext context, IRubyObject[] args, Block origina

@Override
public void doCall(ThreadContext context, IRubyObject arg) {
if (iter instanceof RubyFixnum) {
iter = RubyFixnum.newFixnum(context.runtime, ((RubyFixnum) iter).getLongValue() - 1);
} else if (iter instanceof RubyInteger) {
iter = ((RubyInteger) iter).op_minus(context, 1);
if (iter instanceof RubyFixnum iterFixnum) {
iter = RubyFixnum.newFixnum(context.runtime, iterFixnum.getLongValue() - 1);
} else if (iter instanceof RubyInteger iterInteger) {
iter = iterInteger.op_minus(context, 1);
} else {
iter = iter.callMethod(context, "-", one(context));
}
Expand Down Expand Up @@ -616,8 +614,8 @@ public IRubyObject each(final ThreadContext context, final Block block) {
if (!block.isGiven()) {
return enumeratorizeWithSize(context, this, "each", RubyRange::size);
}
if (begin instanceof RubyFixnum && isEndless) {
((RubyFixnum) begin).step(context, IRubyObject.NULL_ARRAY, block);
if (begin instanceof RubyFixnum begFixnum && isEndless) {
begFixnum.step(context, IRubyObject.NULL_ARRAY, block);
} else if (begin instanceof RubyFixnum && end instanceof RubyFixnum) {
fixnumEach(context, block);
} else if (begin instanceof RubySymbol && end instanceof RubySymbol) {
Expand Down Expand Up @@ -670,17 +668,15 @@ public IRubyObject reverse_each(ThreadContext context, Block block) {

if (end.isNil()) throw typeError(context, "can't iterate from ", end, "");

if (beg instanceof RubyFixnum && end instanceof RubyFixnum) {
if (beg instanceof RubyFixnum && end instanceof RubyFixnum endFixnum) {
if (excl) {
RubyFixnum endFixnum = (RubyFixnum) end;
if (endFixnum.getLongValue() == RubyFixnum.MIN) return this;

end = endFixnum.op_minus(context, 1);
}

reverseEachFixnum(context, beg, (RubyInteger) end, block);
} else if ((beg.isNil() || beg instanceof RubyInteger) && end instanceof RubyInteger) {
RubyInteger endInteger = (RubyInteger) end;
} else if ((beg.isNil() || beg instanceof RubyInteger) && end instanceof RubyInteger endInteger) {
if (excl) {
endInteger = (RubyInteger) endInteger.op_minus(context, 1);
}
Expand Down Expand Up @@ -1010,8 +1006,8 @@ private IRubyObject includeCommon(ThreadContext context, final IRubyObject val,
|| !TypeConverter.convertToTypeWithCheck(context, begin, runtime.getInteger(), to_int_checked).isNil()
|| !TypeConverter.convertToTypeWithCheck(context, end, runtime.getInteger(), to_int_checked).isNil()) {
return asBoolean(context, rangeIncludes(context, val));
} else if ((begin instanceof RubyString) || (end instanceof RubyString)) {
if ((begin instanceof RubyString) && (end instanceof RubyString)) {
} else if (begin instanceof RubyString || end instanceof RubyString) {
if (begin instanceof RubyString && end instanceof RubyString) {
if (useStringCover) {
return cover_p(context, val);
} else {
Expand Down Expand Up @@ -1055,11 +1051,8 @@ public IRubyObject eqq_p(ThreadContext context, IRubyObject obj) {

@JRubyMethod(name = "cover?")
public RubyBoolean cover_p(ThreadContext context, IRubyObject obj) {
if (obj instanceof RubyRange) {
return asBoolean(context, coverRange(context, (RubyRange) obj));
}

return asBoolean(context, rangeIncludes(context, obj));
return asBoolean(context,
obj instanceof RubyRange range ? coverRange(context, range) : rangeIncludes(context, obj));
}

// MRI: r_cover_p
Expand Down Expand Up @@ -1118,9 +1111,8 @@ public IRubyObject max(ThreadContext context, Block block) {
}

int cmp = isBeginless ? -1 : RubyComparable.cmpint(context, invokedynamic(context, begin, MethodNames.OP_CMP, end), begin, end);
if (cmp > 0) {
return context.nil;
}
if (cmp > 0) return context.nil;

if (isExclusive) {
if (!(end instanceof RubyInteger)) throw typeError(context, "cannot exclude non Integer end value");

Expand Down Expand Up @@ -1189,13 +1181,11 @@ public IRubyObject call(ThreadContext ctx, IRubyObject larg, Block blk) {

@JRubyMethod
public IRubyObject count(ThreadContext context, Block block) {
if (isBeginless || isEndless) return RubyFloat.newFloat(context.runtime, RubyFloat.INFINITY);
if (isBeginless || isEndless) return asFloat(context, RubyFloat.INFINITY);

if (begin instanceof RubyInteger) {
IRubyObject size = size(context);
if (!size.isNil()) {
return size;
}
if (!size.isNil()) return size;
}

return RubyEnumerable.count(context, this, block);
Expand Down Expand Up @@ -1223,8 +1213,8 @@ public IRubyObject end(ThreadContext context) {
public IRubyObject last(ThreadContext context, IRubyObject arg) {
if (isEndless) throw context.runtime.newRangeError("cannot get the last element of endless range");

if ((begin instanceof RubyInteger) && (end instanceof RubyInteger)
&& this.getMetaClass().checkMethodBasicDefinition("each")) {
if (begin instanceof RubyInteger && end instanceof RubyInteger
&& getMetaClass().checkMethodBasicDefinition("each")) {
return intRangeLast(context, arg);
}

Expand Down Expand Up @@ -1304,9 +1294,9 @@ public void marshalTo(Ruby runtime, Object obj, RubyClass type,
marshalStream.registerLinkTarget(range);
List<Variable<Object>> attrs = range.getMarshalVariableList();

attrs.add(new VariableEntry<Object>("excl", range.isExclusive ? runtime.getTrue() : runtime.getFalse()));
attrs.add(new VariableEntry<Object>("begin", range.begin));
attrs.add(new VariableEntry<Object>("end", range.end));
attrs.add(new VariableEntry<>("excl", range.isExclusive ? runtime.getTrue() : runtime.getFalse()));
attrs.add(new VariableEntry<>("begin", range.begin));
attrs.add(new VariableEntry<>("end", range.end));

marshalStream.dumpVariables(attrs);
}
Expand Down Expand Up @@ -1461,13 +1451,13 @@ IRubyObject getRange(ThreadContext context) {

// MRI: rb_range_values
public static RangeLike rangeValues(ThreadContext context, IRubyObject range) {
if (range instanceof RubyRange) {
RubyRange vrange = (RubyRange) range;
if (range instanceof RubyRange vrange) {
return new RangeLike(vrange.begin(context), vrange.end(context), vrange.isExcludeEnd());
} else if (range instanceof RubyArithmeticSequence) {
return null;
} else if (range.respondsTo("begin") && range.respondsTo("end") && range.respondsTo("exclude_end?")) {
return new RangeLike(Helpers.invoke(context, range, "begin"), Helpers.invoke(context, range, "end"), Helpers.invoke(context, range, "exclude_end?").isTrue());
return new RangeLike(Helpers.invoke(context, range, "begin"), Helpers.invoke(context, range, "end"),
Helpers.invoke(context, range, "exclude_end?").isTrue());
}

return null;
Expand All @@ -1476,25 +1466,19 @@ public static RangeLike rangeValues(ThreadContext context, IRubyObject range) {
public static class BSearch {
@JRubyMethod(meta = true)
public static IRubyObject double_to_long_bits(ThreadContext context, IRubyObject bsearch, IRubyObject flote) {
long longBits;

if (flote instanceof RubyFixnum) {
longBits = Double.doubleToLongBits(((RubyFixnum) flote).getDoubleValue());
} else {
longBits = Double.doubleToLongBits(((RubyFloat) flote).getDoubleValue());
}

return asFixnum(context, longBits);
return flote instanceof RubyFixnum value ?
asFixnum(context, Double.doubleToLongBits(value.getDoubleValue())) :
asFixnum(context, Double.doubleToLongBits(((RubyFloat) flote).getDoubleValue()));
}

@JRubyMethod(meta = true)
public static IRubyObject long_bits_to_double(ThreadContext context, IRubyObject bsearch, IRubyObject fixnum) {
return context.runtime.newFloat(Double.longBitsToDouble(((RubyFixnum) fixnum).getLongValue()));
return asFloat(context, Double.longBitsToDouble(((RubyFixnum) fixnum).getLongValue()));
}

@JRubyMethod(meta = true)
public static IRubyObject abs(ThreadContext context, IRubyObject bsearch, IRubyObject flote) {
return context.runtime.newFloat(Math.abs(((RubyFloat) flote).getDoubleValue()));
return asFloat(context, Math.abs(((RubyFloat) flote).getDoubleValue()));
}
}

Expand Down
21 changes: 21 additions & 0 deletions core/src/main/java/org/jruby/api/Convert.java
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import org.jruby.RubyClass;
import org.jruby.RubyFile;
import org.jruby.RubyFixnum;
import org.jruby.RubyFloat;
import org.jruby.RubyHash;
import org.jruby.RubyInteger;
import org.jruby.RubyModule;
Expand Down Expand Up @@ -364,6 +365,26 @@ public static RubyFixnum asFixnum(ThreadContext context, int value) {
return RubyFixnum.newFixnum(context.runtime, value);
}

/**
* Create a Ruby Float from a java double.
* @param context the current thread context
* @param value the double value
* @return the Ruby Float
*/
public static RubyFloat asFloat(ThreadContext context, double value) {
return RubyFloat.newFloat(context.runtime, value);
}

/**
* Create a Ruby Float from a java long.
* @param context the current thread context
* @param value the long value
* @return the Ruby Float
*/
public static RubyFloat asFloat(ThreadContext context, long value) {
return RubyFloat.newFloat(context.runtime, value);
}

/**
* Create a Ruby String from a java String.
* @param context the current thread context
Expand Down

0 comments on commit ce114bc

Please sign in to comment.