3.25 Performance Hints: begin-encourage-inline (original) (raw)
3.25 Performance Hints: begin-encourage-inline🔗ℹ
(begin-encourage-inline form ...)
Attaches a 'compiler-hint:cross-module-inline syntax property to each form, which is useful when aform is a function definition. See define-values.
The begin-encourage-inline form is also provided by the(submod racket/performance-hint begin-encourage-inline) module, which has fewer dependencies than racket/performance-hint.
Changed in version 6.2 of package base: Added the (submod racket/performance-hint begin-encourage-inline) submodule.
(define-inline id expr) (define-inline (head args) body ...+) head = id | (head args) args = arg ... arg ... . rest-id arg = arg-id [arg-id default-expr] keyword arg-id keyword [arg-id default-expr]
Like define, but ensures that the definition will be inlined at its call sites. Recursive calls are not inlined, to avoid infinite inlining. Higher-order uses are supported, but also not inlined. Misapplication (by supplying the wrong number of arguments or incorrect keyword arguments) is also not inlined and left as a run-time error.
The define-inline form may interfere with the Racket compiler’s own inlining heuristics, and should only be used when other inlining attempts (such asbegin-encourage-inline) fail.
Changed in version 8.1.0.5 of package base: Changed to treat misapplication as a run-time error.