Jim Wise [Wed, 1 May 2013 01:23:05 +0000 (21:23 -0400)]
backtrace-interrupted-condition-wait now passes on darwin.
Stas Boukarev [Tue, 30 Apr 2013 19:32:43 +0000 (23:32 +0400)]
Micro-optimize integer-length on fixnums on x86-64.
INTEGER-LENGTH is implemented by using the BSR instruction, which
returns the position of the first 1-bit from the right. And that needs
to be incremented to get the width of the integer, and BSR doesn't
work on 0, so it needs a branch to handle 0.
But fixnums are tagged by being shifted left n-fixnum-tag-bits times,
untagging by shifting right n-fixnum-tag-bits-1 times (and if
n-fixnum-tag-bits = 1, no shifting is required), will make the
resulting integer one bit wider, making the increment unnecessary.
Then, to avoid calling BSR on 0, OR the result with 1. That sets the
first bit to 1, and if all other bits are 0, BSR will return 0,
which is the correct value for INTEGER-LENGTH.
Stas Boukarev [Tue, 30 Apr 2013 09:52:57 +0000 (13:52 +0400)]
Document the new :directory argument for run-program.
Lutz Euler [Mon, 29 Apr 2013 21:18:27 +0000 (23:18 +0200)]
Convert the MOVE macro on x86-64 into a function.
This is possible as the macro is used just to simulate an inline
function. Converting MOVE into a true function shrinks the core by
448 KiB and may even make the compiler run faster due to reduced
instruction cache pressure.
Some background: Only on x86-64 MOVE is used with float SCs sometimes.
It therefore needs to select different machine instructions depending on
the SC of its destination argument. This compiles to so much code that
inlining it can't be justified, especially given that MOVE is used in
several hundred VOPs.
While at it, correct the comment at the top of the file for 64-bitness.
Lutz Euler [Mon, 29 Apr 2013 20:57:41 +0000 (22:57 +0200)]
Faster ISQRT on small (about fixnum sized) numbers.
ISQRT is implemented using a recursive algorithm for arguments above 24
which is compiled using generic arithmetic only (as it must support both
fixnums and bignums).
Improve this by compiling this recursive part twice, once using generic
and once fixnum-only arithmetic, and dispatching on function entry into
the applicable part. For maximum speed, the fixnum part recurs directly
into itself, thereby avoiding further type dispatching.
This makes ISQRT run about three times as fast on fixnum inputs while
the generated code is about 40 percent larger (both measured on x86-64).
For bignums a speedup can be seen, too, as ISQRT always recurs into
fixnum territory eventually, but the relative gain obviously becomes
smaller very fast with increasing size of the argument.
I have changed the variable names in the recursive part; they no longer
have an "n-" prefix as this in SBCL by convention means "number of" and
as the argument of the recursive part is no longer visibly "n".
Slightly augment the test case.
Lutz Euler [Mon, 29 Apr 2013 20:35:01 +0000 (22:35 +0200)]
Improve scaling of type derivation for LOG{AND,IOR,XOR}.
If the types of the arguments of LOG{AND,IOR,XOR} are known to be ranges
of non-negative integers the compiler currently derives the range of the
result using straightforward implementations of algorithms from
"Hacker's Delight". These take quadratical time in the number of bits of
the inputs in the worst case, potentially leading to unacceptably long
compilation times. (The algorithms are based on loops over the bits of
the inputs, doing calculations during each iteration that are themselves
linear in the number of bits of their operands.)
Instead implement bit-parallel algorithms I have found that take linear
time in all cases. While their runtime therefore is limited to much
smaller values for large inputs, it is comparable to that of the current
algorithms for small inputs, too; the new deriver for LOGXOR is in fact
faster than the old one by a factor of two to ten already in the latter
case.
The (existing) test for these derivers compares their results with those
from a brute-force algorithm for all O(N^4) many pairs of input ranges
with endpoints from the set of N-bit unsigned integers. The brute-force
algorithm needs to consider O(N^2) input pairs for each pair of ranges,
making the total runtime O(N^6). Therefore the test normally runs with
N = 5. I have tested all three new derivers successfully with N = 7.
Replace LOG{AND,IOR,XOR}-DERIVE-UNSIGNED-{LOW,HIGH}-BOUND with
LOG{AND,IOR,XOR}-DERIVE-UNSIGNED-BOUNDS to make it possible to evaluate
expressions only once that the calculations for the low and the high
bound have in common. The callers always need both bounds anyway.
Adapt the test to this change. (It runs twice as fast now due to the
brute force loop calculating both bounds in one go.)
Add a test for the scaling behaviour. This needs a function to measure
runtimes over potentially large ranges; add this to test-util.lisp.
Fixes lp#1096444.
Lutz Euler [Mon, 29 Apr 2013 20:35:01 +0000 (22:35 +0200)]
Split bitops-derive-type.lisp out of srctran.lisp.
The moved part contains DERIVE-TYPE methods for LOGAND, LOGIOR, and
friends. The split is motivated by srctran.lisp being too large and
by planned changes to these type derivers.
Stas Boukarev [Mon, 29 Apr 2013 19:40:41 +0000 (23:40 +0400)]
Fix init-var-ignoring-errors.
Actually set the variable to the default value in case of an error.
Caught by Nikodemus Siivola.
Stas Boukarev [Mon, 29 Apr 2013 19:28:32 +0000 (23:28 +0400)]
Add :directory argument to sb-ext:run-program.
The implementation uses chdir(2) on Unices, the lpCurrentDirectory
argument to CreateProcessW on Windows.
Slightly adapted from the patch by Matthias Benkard.
Closes lp#791800
Stas Boukarev [Mon, 29 Apr 2013 17:15:57 +0000 (21:15 +0400)]
Handle environment initialization better.
Don't fail with mysterious errors and memory faults on startup during
initialization of *default-pathname-defaults* when the current
directory contains undecodable characters or is deleted. Similarly
catch decoding errors for things like *runtime-pathname* and
*posix-argv*.
Turn the errors into warnings, and ensure that streams are initialized
and the error messages can be printed.
Christophe Rhodes [Mon, 29 Apr 2013 14:12:05 +0000 (15:12 +0100)]
1.1.7: will be tagged as "sbcl-1.1.7"
Christophe Rhodes [Mon, 29 Apr 2013 14:11:21 +0000 (15:11 +0100)]
fix formatting of most recent "changes" line in NEWS
Christophe Rhodes [Tue, 23 Apr 2013 10:33:26 +0000 (11:33 +0100)]
sort NEWS into enhancement/bug fix/optimization order
Paul Khuong [Sat, 20 Apr 2013 13:31:30 +0000 (15:31 +0200)]
Trivial code cleanups
Declare a variable as ignored, and descriptors are 64 bit on
x86-64. The latter was brought to my attention by Douglas Katzman.
Paul Khuong [Sat, 20 Apr 2013 11:50:52 +0000 (13:50 +0200)]
Substitute constants with modular equivalents more safely
* Modular arithmetic sometimes lets us narrow constants down,
especially with signed arithmetic. We now update the receiving
LVAR's type conservatively when there are multiple uses; otherwise,
conflicting type information results in spurious dead code
elimination.
* Test case by Eric Marsden.
* Reported by Eric Marsden on sbcl-devel (2013-04-18).
Paul Khuong [Sat, 20 Apr 2013 11:43:00 +0000 (13:43 +0200)]
Fix the build on OS X 10.8.0
It seems our exception handler can be called before it's fully set up.
Handle that case without potentially leaking too many ports.
Reported by Gabriel Dos Reis on sbcl-devel.
Matthias Andreas Benkard [Tue, 16 Apr 2013 14:53:00 +0000 (16:53 +0200)]
Handle multiple-valued forms in TRACE :PRINT.
Closes: lp#457053.
Stas Boukarev [Mon, 15 Apr 2013 23:47:24 +0000 (03:47 +0400)]
Remove an unused VOP %make-symbol on x86-64.
%make-symbol is handled by define-primitive-object now.
The old VOP was copied into alloc.lisp during the x86_64 port, got
removed from x86 before the merge. It wasn't even ported to x86-64,
and was never invoked during the 9 years it has been sitting there.
Also remove fast_random_state variable from the C runtime, it was used
by the VOP.
Stas Boukarev [Mon, 15 Apr 2013 19:50:12 +0000 (23:50 +0400)]
Disassemble: print the size into the right stream.
Print the newly introduced size information to the provided stream,
not to *standard-output*.
Reported by Jan Moringen.
Christophe Rhodes [Sun, 14 Apr 2013 05:49:57 +0000 (06:49 +0100)]
remove stray debugging code from condition-related patches
Jan Moringen [Fri, 5 Apr 2013 09:59:37 +0000 (11:59 +0200)]
Handle :ALLOCATION of condition slots correctly
Previously, DEFINE-CONDITION failed to pass the :ALLOCATION slot
option to MAKE-CONDITION-SLOT.
A test case has been added.
fixes lp#1049404
Jan Moringen [Fri, 5 Apr 2013 10:24:37 +0000 (12:24 +0200)]
Evaluate condition default initargs once, even after redefinition
There were two causes of this failure
* %DEFINE-CONDITION did not clear CONDITION-CLASSOID-HAIRY-SLOTS when
a condition was redefined. This led to multiple copies of slots in
CONDITION-CLASSOID-HAIRY-SLOTS and thus to initforms being evaluated
multiple times. %DEFINE-CONDITION now clears
CONDITION-CLASSOID-HAIRY-SLOTS before populating it again.
* (MAKE-INSTANCE CONDITION-CLASS) produced the call tree
MAKE-INSTANCE
+ ALLOCATE-INSTANCE SLOT-OBJECT
+ MAKE-CONDITION
+ INITIALIZE-INSTANCE SLOT-OBJECT
+ SHARED-INITIALIZE SLOT-OBJECT
MAKE-CONDITION and SHARED-INITIALIZE both called initfunctions
leading to multiple evaluations
A test case has been added.
fixes lp#1164969
Jan Moringen [Fri, 5 Apr 2013 10:31:06 +0000 (12:31 +0200)]
Use AMOP representation of canonicalized default initargs for conditions
This fixes two issues:
1. CLASS-DIRECT-DEFAULT-INITARGS did not work for condition
classes (bug 1164970)
2. Constant functions as default initargs of condition classes did not
work correctly (bug 539517)
The following things have been changed:
* CONDITION-CLASSOID-DEFAULT-INITARGS is now called
CONDITION-CLASSOID-DIRECT-DEFAULT-INITARGS to better reflect its
purpose.
* Previously, default initargs of condition classes where stored in a
plist the values of which where constant initforms or
initfunctions. Now default initargs of condition classes are always
of the form
(INITARG INITFORM THUNK)
as described in AMOP.
* The SHARED-INITIALIZED :AFTER CONDITION-CLASS T method now stores
the direct default initargs in the class plist. These are now of the
correct form as described in the previous bullet point.
* The DOPLIST macro used to be defined in src/pcl/macros.lisp. It is
now in src/code/early-extensions.lisp and exported from SB-INT. This
was necessary to use DOPLIST in src/code/condition.lisp.
* Unit test for both problems have been added.
fixes lp#539517, fixes lp#1164970
Stas Boukarev [Fri, 12 Apr 2013 15:27:50 +0000 (19:27 +0400)]
Disassemble: print the function size in bytes.
Print "; Size: 981 bytes" at the beginning of DISASSEMBLE output.
Martin Cracauer [Thu, 11 Apr 2013 15:34:03 +0000 (11:34 -0400)]
LOGBITP and LOGTEST optimizations from x86.
Copy Nathan Froyd's optimizations for LOGBITP and LOGTEST
on x86 architecture into x86-64.
Committing change submitted by Doug Katzman.
Stas Boukarev [Mon, 8 Apr 2013 10:12:55 +0000 (14:12 +0400)]
Don't signal an error on (setf (documentation nil 'function) "doc").
Signal a style-warning instead when trying to set documentation of NIL
for all other documentation types (except TYPE).
Reported by Zach Beane. Regression since
2e52fa05.
Stas Boukarev [Mon, 1 Apr 2013 13:59:28 +0000 (17:59 +0400)]
Check bounds of ELT on &more in safe code.
Disable &more optimizations for ELT if safety = 3.
Stas Boukarev [Sun, 31 Mar 2013 17:27:14 +0000 (21:27 +0400)]
type=: Compare &key parameters of function types.
Compare key parameters in type=-args, mostly so that deftransforms
with key arguments could be redefined at runtime.
Paul Khuong [Sat, 30 Mar 2013 20:06:32 +0000 (21:06 +0100)]
Stop emitting references to inexistant #n= forms in the pretty printer
* Special logic was introduced in 2003 to avoid pprinting backquote-comma
forms as ", foo" when ",foo" is unambiguous; the bug has likely been
around since then.
* Reported by Douglas Katzman on launchpad, and reduced by James M. Lawrence
(lp#1161218)
Paul Khuong [Sat, 30 Mar 2013 18:22:46 +0000 (19:22 +0100)]
Fix a compilation failure on svref of a symbol macro
Introduced in
0892423b (faster SVREF and (SETF SVREF) compilation)
Thanks to James M. Lawrence for the quick report, with a reduced
test case.
Christophe Rhodes [Fri, 29 Mar 2013 20:24:51 +0000 (20:24 +0000)]
remove sb-studio from commercial support section of the manual
(thanks to Titus Barik)
Christophe Rhodes [Fri, 29 Mar 2013 19:38:35 +0000 (19:38 +0000)]
1.1.6: will be tagged as "sbcl-1.1.6"
Christophe Rhodes [Tue, 26 Mar 2013 12:45:35 +0000 (12:45 +0000)]
test environment fix for 64-bit PowerPC/Linux
(from Eric Marsden sbcl-devel 2012-03-26)
Jan Moringen [Tue, 5 Mar 2013 18:46:01 +0000 (19:46 +0100)]
Declare types of END and TEST in N{LIST,VECTOR}-SUBSTITUTE-IF[-NOT]*
The types of END and TEST are known because the respective callers are
defined with DEFINE-SEQUENCE-TRAVERSER which checks/COERCEs
appropriately.
Jan Moringen [Tue, 5 Mar 2013 18:13:06 +0000 (19:13 +0100)]
Lazy length computation in DEFINE-SEQUENCE-TRAVERSER
DEFINE-SEQUENCE-TRAVERSER used to unconditionally establish a binding
of LENGTH{,1,2} to the length of the processed sequence(s). This was
wasteful in the case of user-defined sequences whos implementations
could not access this information.
DEFINE-SEQUENCE-TRAVERSER now uses SYMBOL-MACROLET to provide LENGTH{,1,2}
symbols which evaluate to the respective sequence lengths, but the
sequence length is only computed when needed.
Uses of DEFINE-SEQUENCE-TRAVERSER now have to avoid forcing
LENGTH{,1,2} and thus END{,1,2} handling only appears in the list- and
vector-code-paths. The affected sequence functions are REDUCE,
DELETE[-IF[-NOT]], REMOVE[-IF[-NOT]], REMOVE-DUPLICATES,
DELETE-DUPLICATES, SUBSTITUTE[-IF[-NOT]], NSUBSTITUE[-IF[-NOT]],
COUNT[-IF[-NOT]], MISMATCH and SEARCH.
Jan Moringen [Mon, 4 Mar 2013 10:26:35 +0000 (11:26 +0100)]
Remove redundant LENGTH calls in NSUBSTITUTE[-IF[-NOT]]
NSUBSTITUTE, NSUBSTITUTE-IF and NSUBSTITUTE-IF used to contain
(let ((length (length sequence))) ...
in the code path for lists. In the macroexpansion it became clear that
this recomputed and shadowed the LENGTH variables already established
by DEFINE-SEQUENCE-TRAVERSER.
A very brief test with list lengths between 5 and 500 suggests that
the speedup produced by removing the redundant computation can be
around 5 to 20 %.
Jan Moringen [Mon, 4 Mar 2013 10:25:24 +0000 (11:25 +0100)]
Fix typo in comment in src/compiler/seqtran.lisp
Christophe Rhodes [Fri, 22 Mar 2013 12:14:33 +0000 (12:14 +0000)]
minor NEWS fixups
Jan Moringen [Sun, 10 Mar 2013 15:28:55 +0000 (16:28 +0100)]
Fix SEQUENCE:SEARCH, test seq. functions with user-defined sequences
Extending the tests in tests/seq.impure.lisp to user-defined sequences
revealed that the previous implementation produced incorrect results
for some inputs.
SEQUENCE:WITH-SEQUENCE-ITERATOR now accepts NIL in the list of
variables and generates ignored bindings for these elements.
The new implementation is also slightly faster (at least for the
inputs in tests/seq.impure.lisp).
fixes lp#1153312
Christophe Rhodes [Sat, 16 Mar 2013 12:05:31 +0000 (12:05 +0000)]
micro-optimize sane-package a tiny bit more
Nikodemus Siivola [Sun, 17 Mar 2013 11:54:17 +0000 (13:54 +0200)]
faster SVREF and (SETF SVREF) compilation
Stas Boukarev [Sun, 17 Mar 2013 08:53:47 +0000 (12:53 +0400)]
make-array transform error on unknown element-type.
Check for the type to be known, otherwise give up transforming.
Based on a patch by James Kalenius.
Fixes lp#1156095.
Stas Boukarev [Sat, 16 Mar 2013 12:33:29 +0000 (16:33 +0400)]
Optimize pprinting of heavily nested lists.
Declare types of PREFIX and SUFFIX slots of PRETTY-STREAM to be
(simple-array character (*)), not just simple-string.
Stas Boukarev [Sat, 16 Mar 2013 12:09:03 +0000 (16:09 +0400)]
Reduce consing for find-package.
Don't use return-from inside restart-case, it causes consing even when
the branch with restart-case is not taken.
Stas Boukarev [Thu, 14 Mar 2013 11:29:10 +0000 (15:29 +0400)]
Optimize CAD*R for &MORE args.
Call %rest-ref when possible, and SECOND-FOURTH are optimized by
extension too.
Stas Boukarev [Thu, 14 Mar 2013 10:09:54 +0000 (14:09 +0400)]
Accessing &MORE arguments checks bounds.
(funcall (lambda (&rest args) (car args))) => garbage,
because &more accessing didn't check bounds.
Fixes lp#1154946.
Stas Boukarev [Thu, 14 Mar 2013 08:11:13 +0000 (12:11 +0400)]
Better errors for package operations.
Add some missing errors, make other errors to be of type
sb-kernel:simple-package-error.
Fixes lp#1154776.
DELETE-PACKAGE should be signalling a continuable error, but wasn't
since 1.0.37.44.
Stas Boukarev [Wed, 13 Mar 2013 08:29:26 +0000 (12:29 +0400)]
Slightly better arglist for defmethod.
(defmethod name &rest args) instead of just (defmethod &rest args).
Stas Boukarev [Sun, 10 Mar 2013 16:15:53 +0000 (20:15 +0400)]
format: Signal an error for ~<~@>
CLHS doesn't allow @ to appear in the closing directive of ~<~>.
Patch by Jan Moringen.
Fixes lp#1153148
Stas Boukarev [Sun, 10 Mar 2013 15:05:59 +0000 (19:05 +0400)]
clear-output: call stream-clear-output on gray streams.
clear-output should call sb-gray:stream-clear-output instead of
sb-gray:stream-force-output.
Fixes lp#1153257.
Paul Khuong [Mon, 4 Mar 2013 05:13:28 +0000 (00:13 -0500)]
New keyword argument for SB-C:DEFKNOWN: :overwrite-fndb-silently
While not useful in the compiler itself, some libraries (not only
contribs) define their own VOPs, transforms, etc., and the error
when clobbering pre-existing defknowns made these libraries hard
to reload.
Use with :allow-other-keys for backward compatibility.
Stas Boukarev [Sun, 3 Mar 2013 11:09:40 +0000 (15:09 +0400)]
Fix a test-case in threads.impure.lisp on -sb-thread.
A test was using make-thread without ensuring that sb-thread is enabled.
Fixes lp#1141795
Stas Boukarev [Sat, 2 Mar 2013 20:54:34 +0000 (00:54 +0400)]
Prevent a make-array transform from modifying source forms.
That causes repeated compilations of inlined functions to accumulate
changes made by the transform.
Thanks to Bart Botta.
(regression since 1.0.42.11-bis)
Lutz Euler [Sat, 2 Mar 2013 19:49:30 +0000 (20:49 +0100)]
Improve the failure output of the test :range-reduction :x87.
Namely, output the function, argument, expected and actual result.
Lutz Euler [Sat, 2 Mar 2013 18:52:19 +0000 (19:52 +0100)]
Silence a warning from the test harness for unthreaded builds.
"The variable THREADS is defined but never used.", so, in WITH-TEST only
bind THREADS under #+SB-THREAD as all places where this variable is used
are guarded by this feature expression, too.
Christophe Rhodes [Tue, 26 Feb 2013 11:42:11 +0000 (11:42 +0000)]
1.1.5: will be tagged as "sbcl-1.1.5"
Christophe Rhodes [Mon, 25 Feb 2013 10:25:32 +0000 (10:25 +0000)]
Revert "upgrade asdf to 2.29, per request by Faré (sbcl-devel 2013-02-16)"
This reverts commit
5bf941f419b6cd275feb3ee44ca264596fbd9e8e.
Nikodemus Siivola [Thu, 21 Feb 2013 11:18:34 +0000 (13:18 +0200)]
prohibit adding name of a package to itself as a local nickname
Seems useless, confusing, and probably unintentional. Make it a
continuable error, though. Thanks to Rudi Schlatte for thinking
about this.
So, NO MORE:
(in-package :foo)
(add-package-local-nickname :foo :bar)
'foo::x ; => BAR::X
Nikodemus Siivola [Thu, 21 Feb 2013 10:46:07 +0000 (12:46 +0200)]
suffix PACKAGE-LOCALLY-NICKNAMED-BY with -LIST
Less confusing, and more in line with PACKAGED-NICKNAMED-BY-LIST &co.
(Thanks to Rudi Schlatte for heads-up.)
Christophe Rhodes [Wed, 20 Feb 2013 11:49:48 +0000 (11:49 +0000)]
upgrade asdf to 2.29, per request by Faré (sbcl-devel 2013-02-16)
Nikodemus Siivola [Fri, 8 Feb 2013 00:45:18 +0000 (19:45 -0500)]
update LIST-QUEUE-CONTENTS docstring, add note
James M. Lawrence [Wed, 14 Nov 2012 00:18:43 +0000 (19:18 -0500)]
Replace sb-concurrency:queue implementation.
Singly-linked queue is faster and conses less.
Nikodemus Siivola [Thu, 7 Feb 2013 20:16:47 +0000 (22:16 +0200)]
it's print-read consistency, not read/print consistency
Doesn't really matter, I guess, but let's not confuse terminology if
we can avoid it. (Kudos to Zach Beane for pointing this out.)
Nikodemus Siivola [Mon, 4 Feb 2013 16:49:36 +0000 (18:49 +0200)]
fix manual build
Stas Boukarev [Tue, 5 Feb 2013 15:25:46 +0000 (19:25 +0400)]
Fix (setf documentation) regression.
When built with sb-doc enabled (the default), it crashes the build
because it uses a not yet defined function, sb-impl::fun-name.
Reported by Janis Dzerins.
Stas Boukarev [Tue, 5 Feb 2013 10:53:06 +0000 (14:53 +0400)]
Test-suite results colorization.
Failures in red, unexpected success in green. Works on Windows and on
terminals with ANSI escape code support.
Can be disabled with --no-color.
Stas Boukarev [Mon, 4 Feb 2013 12:08:07 +0000 (16:08 +0400)]
Fix (documentation closure) test.
Take into account the idea that
(setf (documentation #'function t) "doc")
(setf (documentation 'function 'function) "doc")
should do the same.
Stas Boukarev [Mon, 4 Feb 2013 12:06:22 +0000 (16:06 +0400)]
Build on newer glibc.
Newer glibc don't like the usage of #define __USE_GNU, use _GNU_SOURCE
instead.
Fixes lp#1095036
Stas Boukarev [Mon, 4 Feb 2013 11:21:22 +0000 (15:21 +0400)]
Fix (documentation #'function t)
(defun test () "xx" nil)
(setf (documentation 'test 'function) "test")
(list (documentation #'test t) (documentation 'test 'function)))
returned ("xx" "test").
Francois-Rene Rideau [Tue, 1 Jan 2013 21:35:05 +0000 (16:35 -0500)]
Remove a style-warning from sb-bsd-sockets.asd when #-sb-testing-contrib.
Nikodemus Siivola [Thu, 24 Nov 2011 12:36:15 +0000 (14:36 +0200)]
add SB-POSIX:MAP-ANON
Christophe Rhodes [Sun, 3 Feb 2013 14:14:55 +0000 (14:14 +0000)]
typo fix in sb-sprof.
Also update NEWS for fix of #1113859
Nikodemus Siivola [Sun, 3 Feb 2013 10:28:32 +0000 (12:28 +0200)]
grab-bag of SB-SPROF improvements.
(1) Thread distribution handler must not check *SAMPLING*, as it
is thread-local.
(2) Return the values from the final round when looping.
(3) Better warning on no sampling process: list the reasons users can
do something about.
(4) Update WITH-PROFILING docstring to reflect reality.
(5) When printing *SAMPLES*, don't print the array.
Attila Lendvai [Tue, 6 Apr 2010 15:24:54 +0000 (17:24 +0200)]
make SB-SPROF:WITH-PROFILING not loop by default
...and in non-loop mode it properly returns the result values of the
macro body.
Nikodemus Siivola [Sun, 3 Feb 2013 09:03:12 +0000 (11:03 +0200)]
mention :TIME in *SAMPLING-MODE* docstring
Stas Boukarev [Sun, 3 Feb 2013 09:38:29 +0000 (13:38 +0400)]
restart-case: Spurious unused variable warnings.
restart-case without any restart clauses used to signal an unused
variable warning, add ignorable declaration.
Fixes lp#1113859
Nikodemus Siivola [Fri, 1 Feb 2013 22:17:36 +0000 (00:17 +0200)]
remove bogus IGNORE declaration from XC version of WITH-FAST-READ-BYTE
Nikodemus Siivola [Wed, 23 May 2012 06:53:34 +0000 (09:53 +0300)]
make %COERCE-TO-CALLABLE compilers notes make sense
Get the cause and the problem right.
Nikodemus Siivola [Fri, 1 Feb 2013 20:35:21 +0000 (22:35 +0200)]
export MAP-DIRECTORY from SB-EXT
It's proven itself a capable and stable interface.
Nikodemus Siivola [Mon, 15 Nov 2010 15:21:25 +0000 (17:21 +0200)]
prettier backtraces
Introduce PRINT-BACKTRACE and LIST-BACKTRACE as forward compatible
replacements for BACKTRACE and BACKTRACE-AS-LIST. (Not yet deprecated.)
*SHOW-ENTRY-POINT-DETAILS* is also deprecated. Function names and
lambda-lists are now always cleaned, but the details that were
previously available via the debug name are now provided as part of
the auxilliary frame info.
*METHOD-FRAME-STYLE* can be :MINIMAL, :NORMAL, or :FULL, defaulting to
:NORMAL.
Nikodemus Siivola [Thu, 18 Nov 2010 15:19:50 +0000 (17:19 +0200)]
support for deprecating special variables
Use DEFINE-DEPRECATED-VARIABLE to deprecate them.
Nikodemus Siivola [Tue, 12 Jun 2012 20:49:09 +0000 (23:49 +0300)]
cross-compiler OAOOM ugliness
Couple of conditions for easier debugging of
the build.
Nikodemus Siivola [Sat, 26 Jan 2013 21:14:02 +0000 (23:14 +0200)]
better debug name for secondary GF dispatch functions
Fixes lp#503081
Stas Boukarev [Fri, 1 Feb 2013 11:57:41 +0000 (19:57 +0800)]
Use CryptGenRandom as a random seed on Windows.
Patch by Anton Kovalenko.
Fixes lp#1102748
Nikodemus Siivola [Fri, 1 Feb 2013 19:54:09 +0000 (21:54 +0200)]
fix NEWS: oops, one item was wrong, one item not in place yet
Stas Boukarev [Fri, 1 Feb 2013 11:51:58 +0000 (19:51 +0800)]
Fix win32-foreign-stack-unwind.impure test.
Don't pass -mno-cygwin to gcc, it doesn't work with MinGW.
Nikodemus Siivola [Fri, 1 Feb 2013 18:13:31 +0000 (20:13 +0200)]
restore old behaviour as the default for package variance
Use *on-package-variance* to adjust.
Hint:
(setf *on-package-variance* '(:warn (:swank :swank-backend) :error t))
Nikodemus Siivola [Fri, 1 Feb 2013 16:40:23 +0000 (18:40 +0200)]
oops, it's :package-local-nicknams, not :local-nicknames
Also mention it in the manual.
...just couldn't get it right the first time.
Nikodemus Siivola [Tue, 22 Jan 2013 02:04:49 +0000 (04:04 +0200)]
package local nicknames
Example terminal session using Linedit:
* (defpackage :foo (:use :cl) (:local-nicknames (:sb :sb-ext)))
#<PACKAGE "FOO">
* (in-package :foo)
#<PACKAGE "FOO">
* (sb:posix-
sb:posix-environ sb:posix-getenv
* (sb:posix-getenv "USER")
"nikodemus"
API:
function PACKAGE-LOCAL-NICKNAMES package
function PACKAGE-LOCALLY-NICKNAMED-BY package
function ADD-PACKAGE-LOCAL-NICKNAME nick global &optional package
function REMOVE-PACKAGE-LOCAL-NICKNAME old-nick &optional package
DEFPACKAGE option: (:local-nicknames {(local-nick global-name)}*)
:PACKAGE-LOCAL-NICKNAMES in *FEATURES*
Design issues and considerations:
* "CL", "COMMON-LISP", and "KEYWORD" signal a continuable error
when used as local nicknames. I think this is good for sanity,
but not strictly required. Because of the way (find-package
:keyword) is idiomatically used to guarantee print/read
consistency across packages, I think it at least should be
protected.
* To preserve read/print consistency, we use package local nicknames
as prefixes when printing.
* The hook into FIND-PACKAGE is invisible, but built on top of
FIND-PACKAGE-USING-PACKAGE -- undocumented and unexported, but
waiting to be turned into something interesting by Christophe.
* Local nicknames are protected by package locks.
* If you want to bypass nicknames, you need to first get into
a known package without nicknames. There could be an explicit
way as well, but not sure if that's needed or a good idea.
Random crap mixed in:
Re-order DEFPACKAGE option docs in rough order of usefulness.
Nikodemus Siivola [Fri, 1 Feb 2013 13:01:30 +0000 (15:01 +0200)]
update NEWS
Nikodemus Siivola [Fri, 1 Feb 2013 13:01:11 +0000 (15:01 +0200)]
remove deleted packages from implementation-packages list of other packages
Nikodemus Siivola [Fri, 1 Feb 2013 12:49:41 +0000 (14:49 +0200)]
DEFPACKAGE at variance restarts
Signal a full error on variances, in each case offering the user the
choice of keeping the old stuff or dropping it.
Fixes lp#891351.
Nikodemus Siivola [Tue, 29 Jan 2013 09:27:34 +0000 (11:27 +0200)]
nicer name-conflict restarts for common cases
For IMPORT: offer option to SHADOWING-IMPORT the new symbol or skip
importing.
For EXPORT: offer option to KEEP-OLD or TAKE-NEW. (Shadowing or
uninterning the other one.)
For USE-PACKAGE: offer option to KEEP-OLD or TAKE-NEW. (Shadowing or
uninterning the other ones.)
Christophe Rhodes [Wed, 30 Jan 2013 19:28:03 +0000 (19:28 +0000)]
1.1.4: will be tagged as "sbcl-1.1.4"
Nikodemus Siivola [Sat, 26 Jan 2013 15:34:35 +0000 (17:34 +0200)]
disable the other sb-sprof test on darwin as well *sigh*
Stas Boukarev [Wed, 23 Jan 2013 10:33:08 +0000 (14:33 +0400)]
Slightly improve random seed on Windows.
Use unix-getpid on Windows too.
Christoph Egger [Wed, 23 Jan 2013 05:02:59 +0000 (06:02 +0100)]
Adapt cheneygc.c to type changes in gc-internal.h
Cyrus Harmon [Mon, 21 Jan 2013 01:24:24 +0000 (17:24 -0800)]
disable sb-sprof test on darwin
restore buildability by disabling failing test for the moment.
Nikodemus Siivola [Sun, 20 Jan 2013 11:28:43 +0000 (13:28 +0200)]
better initial value for LOOP variables of-type CHARACTER
Nikodemus Siivola [Sun, 20 Jan 2013 11:16:31 +0000 (13:16 +0200)]
note FIRST fix in NEWS, fix stupid typo in tests