Skip to content
Permalink

Comparing changes

Choose two branches to see what’s changed or to start a new pull request. If you need to, you can also or learn more about diff comparisons.

Open a pull request

Create a new pull request by comparing changes across two branches. If you need to, you can also . Learn more about diff comparisons here.
base repository: jruby/jruby
Failed to load repositories. Confirm that selected base ref is valid, then try again.
Loading
base: b2f4f39ed761
Choose a base ref
...
head repository: jruby/jruby
Failed to load repositories. Confirm that selected head ref is valid, then try again.
Loading
compare: f140b23fda44
Choose a head ref
  • 4 commits
  • 5 files changed
  • 1 contributor

Commits on Feb 4, 2015

  1. RubySpec: Add a comment.

    eregon committed Feb 4, 2015
    Copy the full SHA
    ce066de View commit details
  2. 1
    Copy the full SHA
    e91e650 View commit details
  3. Copy the full SHA
    5685994 View commit details
  4. 2
    Copy the full SHA
    f140b23 View commit details
1 change: 1 addition & 0 deletions spec/ruby/shared/mutex/locked.rb
Original file line number Diff line number Diff line change
@@ -28,6 +28,7 @@
m1.locked?.should be_true
m2.unlock # release th
th.join
# A Thread releases its locks upon termination
m1.locked?.should be_false
end
end
2 changes: 0 additions & 2 deletions spec/truffle/tags/core/kernel/sleep_tags.txt
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
fails:Kernel#sleep pauses execution for approximately the duration requested
fails:Kernel#sleep returns the rounded number of seconds asleep
fails:Kernel#sleep raises a TypeError when passed a non-numeric duration
fails:Kernel#sleep accepts a Rational
fails:Kernel#sleep pauses execution indefinitely if not given a duration
slow:Kernel#sleep accepts a Float
slow:Kernel#sleep accepts a Rational
2 changes: 1 addition & 1 deletion tool/jt.rb
Original file line number Diff line number Diff line change
@@ -149,7 +149,7 @@ def tag(path, *args)

def untag(path, *args)
puts
puts "WARNING: untag is currently not very reliable - run `jt test #{path}` after and manually annotate any new failures"
puts "WARNING: untag is currently not very reliable - run `jt test #{path} #{args * ' '}` after and manually annotate any new failures"
puts
mspec 'tag', '--del', 'fails', '--pass', path, *args
end
Original file line number Diff line number Diff line change
@@ -16,8 +16,8 @@
import com.oracle.truffle.api.frame.*;
import com.oracle.truffle.api.nodes.UnexpectedResultException;
import com.oracle.truffle.api.source.SourceSection;

import com.oracle.truffle.api.utilities.ConditionProfile;

import org.jruby.common.IRubyWarnings;
import org.jruby.runtime.Visibility;
import org.jruby.truffle.nodes.RubyNode;
@@ -1924,6 +1924,8 @@ public Object string(VirtualFrame frame, Object value) {
@CoreMethod(names = "sleep", isModuleFunction = true, optional = 1)
public abstract static class SleepNode extends CoreMethodNode {

@Child CallDispatchHeadNode floatNode;

public SleepNode(RubyContext context, SourceSection sourceSection) {
super(context, sourceSection);
}
@@ -1958,6 +1960,24 @@ public long sleep(double duration) {
return doSleepMillis((long) (duration * 1000));
}

@Specialization(guards = "isRational")
public long sleep(VirtualFrame frame, RubyBasicObject duration) {
if (floatNode == null) {
CompilerDirectives.transferToInterpreterAndInvalidate();
floatNode = insert(DispatchHeadNodeFactory.createMethodCall(getContext()));
}

try {
return sleep(floatNode.callFloat(frame, duration, "to_f", null));
} catch (UseMethodMissingException e) {
throw new RaiseException(getContext().getCoreLibrary().typeErrorCantConvertInto(
getContext().getCoreLibrary().getLogicalClass(duration).getName(),
getContext().getCoreLibrary().getFloatClass().getName(),
this));
}

}

@TruffleBoundary
private long doSleepMillis(final long durationInMillis) {
if (durationInMillis < 0) {
Original file line number Diff line number Diff line change
@@ -349,4 +349,27 @@ public Object value(RubyThread self) {

}

@CoreMethod(names = "wakeup")
public abstract static class WakeupNode extends CoreMethodNode {

public WakeupNode(RubyContext context, SourceSection sourceSection) {
super(context, sourceSection);
}

public WakeupNode(WakeupNode prev) {
super(prev);
}

@Specialization
public RubyThread wakeup(final RubyThread thread) {
notDesignedForCompilation();

// TODO: should only interrupt sleep
thread.interrupt();

return thread;
}

}

}