mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-28 17:04:41 +00:00
minor tweaks; updated todo.txt
This commit is contained in:
@@ -380,6 +380,7 @@ proc evalOp(m: TMagic, n, a, b, c: PNode): PNode =
|
||||
of mInSet: result = newIntNodeT(ord(inSet(a, b)), n)
|
||||
of mRepr:
|
||||
# BUGFIX: we cannot eval mRepr here for reasons that I forgot.
|
||||
discard
|
||||
of mIntToStr, mInt64ToStr: result = newStrNodeT($(getOrdValue(a)), n)
|
||||
of mBoolToStr:
|
||||
if getOrdValue(a) == 0: result = newStrNodeT("false", n)
|
||||
|
||||
@@ -192,7 +192,7 @@ when false:
|
||||
if path[path.len-1] == '/' or existsDir(path):
|
||||
path = path / "index.html"
|
||||
|
||||
if not ExistsFile(path):
|
||||
if not existsFile(path):
|
||||
discardHeaders(client)
|
||||
notFound(client)
|
||||
else:
|
||||
|
||||
@@ -243,7 +243,7 @@ when not defined(useNimRtl):
|
||||
|
||||
# on UNIX, the GC uses ``SIGFREEZE`` to tell every thread to stop so that
|
||||
# the GC can examine the stacks?
|
||||
proc stopTheWord() = nil
|
||||
proc stopTheWord() = discard
|
||||
|
||||
# We jump through some hops here to ensure that Nimrod thread procs can have
|
||||
# the Nimrod calling convention. This is needed because thread procs are
|
||||
|
||||
26
todo.txt
26
todo.txt
@@ -1,6 +1,17 @@
|
||||
version 0.9.4
|
||||
version 0.9.6
|
||||
=============
|
||||
|
||||
- fix the bug that keeps 'defer' template from working
|
||||
- make '--implicitStatic:on' the default
|
||||
- fix the tuple unpacking in lambda bug
|
||||
- make tuple unpacking work in a non-var/let context
|
||||
- special rule for ``[]=``
|
||||
- ``=`` should be overloadable; requires specialization for ``=``; general
|
||||
lift mechanism in the compiler is already implemented for 'fields'
|
||||
- built-in 'getImpl'
|
||||
- type API for macros; make 'spawn' a macro
|
||||
- markAndSweepGC should expose an API for fibers
|
||||
|
||||
|
||||
Bugs
|
||||
====
|
||||
@@ -16,7 +27,6 @@ Bugs
|
||||
version 0.9.x
|
||||
=============
|
||||
|
||||
- fix the bug that keeps 'defer' template from working
|
||||
- pragmas need 'bindSym' support
|
||||
- pragmas need re-work: 'push' is dangerous, 'hasPragma' does not work
|
||||
reliably with user-defined pragmas
|
||||
@@ -28,18 +38,10 @@ version 0.9.x
|
||||
- ensure (ref T)(a, b) works as a type conversion and type constructor
|
||||
- optimize 'genericReset'; 'newException' leads to code bloat
|
||||
- stack-less GC
|
||||
- make '--implicitStatic:on' the default
|
||||
- implicit deref for parameter matching
|
||||
|
||||
- special rule for ``[]=``
|
||||
- ``=`` should be overloadable; requires specialization for ``=``; general
|
||||
lift mechanism in the compiler is already implemented for 'fields'
|
||||
- built-in 'getImpl'
|
||||
- VM: optimize opcAsgnStr
|
||||
|
||||
- change comment handling in the AST; that's lots of work as c2nim and pas2nim
|
||||
make use of the fact every node can have a comment!
|
||||
|
||||
|
||||
version 0.9.X
|
||||
=============
|
||||
@@ -111,10 +113,6 @@ GC
|
||||
- precise stack marking; embrace C++ code generation for that
|
||||
- marker procs for Boehm GC
|
||||
- hybrid GC
|
||||
- GC: implement simple generational GC
|
||||
* first version: mark black in write barrier
|
||||
* second version: introduce fake roots instead of marking black
|
||||
* third version: find some clever heuristic which is preferable
|
||||
- acyclic vs prunable; introduce GC hints
|
||||
- use big blocks in the allocator
|
||||
- object pooling support for *hard* realtime systems
|
||||
|
||||
@@ -21,7 +21,7 @@ proc walker(dir: string) =
|
||||
moveFile(dest=path, sourc=newName(path))
|
||||
of pcDir:
|
||||
walker(path)
|
||||
else: nil
|
||||
else: discard
|
||||
|
||||
if paramCount() == 1:
|
||||
walker(paramStr(1))
|
||||
|
||||
Reference in New Issue
Block a user