After an excruciatingly long development period the Pike developers
are proud to present the first beta of Pike 7.8. Users and developers
alike are encouraged to test this beta and report problems so we can
have a final release as soon as possible.
The source and windows installer can be downloaded here:
https://pike.ida.liu.se/download/pub/pike/beta/7.8.98/
Known issues:
* The new Windows installer does not install all the explorer
bindings the old one did, neither does it set up start menu
entries.
* The new Windows installer does not precompile the installed modules.
Changes since Pike 7.6:
----------------------------------------------------------------------
This is a high level list of changes between Pike 7.6 and Pike 7.8.
General bug fixes, build fixes and optimizations are not mentioned
here. For a complete list of changes, please consult the CVS changelog
either directly or through Code Librarian.
This high level changelog is also available here:
https://pike.ida.liu.se/download/notes/7.8.xml
New / improved language functionality
-------------------------------------
o New syntax to index from the end in range operations.
A "<" can be added before an index in the [..] operator to count
from the end instead, beginning with 0 for the last element. This is
convenient to e.g. chop off the last element in an array: a[..<1].
o New `[..] operator function.
Range operations have been separated from the `[] operator function
and are now handled by the new `[..] which provides greater control
for how the range bounds are specified. For compatibility, if there
is no `[..] then `[] is still called for range operations.
The `[..] callback will get four arguments, start value, start type,
end value and end type. The type arguments is any of
Pike.INDEX_FROM_BEG, Pike.INDEX_FROM_END or Pike.OPEN_BOUND. Here
are a few examples of what input arguments different calls would
generate.
[..] 0 OPEN_BOUND 0 OPEN_BOUND
[1..] 1 INDEX_FROM_BEG 0 OPEN_BOUND
[..2] 0 OPEN_BOUND 2 INDEX_FROM_BEG
[3..4] 3 INDEX_FROM_BEG 4 INDEX_FROM_BEG
[<5..] 5 INDEX_FROM_END 0 OPEN_BOUND
[6..<7] 6 INDEX_FROM_BEG 7 INDEX_FROM_END
o Generalized this and this_program.
It is now possible to refer to inherits in objects. Example:
class A {
int a;
void foo() { werror("A\n"); }
}
class B {
inherit A;
int b;
void foo() { werror("B\n"); }
A::this_program get_a() { return A::this; }
}
In the above B()->get_a() will return an object with two symbols,
'a' and 'foo', but B()->get_a()->foo() will still write "B\n".
o Added support for getters and setters.
It is now possible to simulate variables with functions. Example:
class A {
private int a;
int `b() { return a; } // Getter for the symbol b.
void `b=(int c) { a = c; } // Setter for the symbol b.
int c()
{
return b; // Calls `b().
}
}
object a = A();
a->b = 17; // Calls `b=(17).
werror("%d\n", a->b); // Calls `b().
o Casting to derived types.
It is now possible to call a value of type type to perform the
corresponding value cast. eg:
typedef string MyString;
return MyString(17); // Casts 17 to "17".
o Unicode escapes.
Pike now understands the common way to escape unicode chars, using
\uxxxx and \Uxxxxxxxx escapes. These escapes works both in string
and character literals and in the preprocessor. The latter means
that unicode escapes can be used in identifiers, which is useful if
they contain characters that can't be represented raw in the source
code charset.
o Stricter type checker for function calls.
The type checker for function calls is now based on the concept of
currification. This should provide for error messages that are more
easily understood. It also is much better att typechecking function
calls utilizing the splice (@) operator. The mechanisms used by the
typechecker are also made available as Pike.get_first_arg_type(),
Pike.low_check_call() and Pike.get_return_type().
o Stricter typing of strings.
The string type may now have an optional value range.
string(0..255) bytes;
o Support for having multiple different active backend implementations.
In Pike 7.6 and earlier, there could only be one active backend
implementation at a time, which was the one selected for best
performance with lots of files (cf Pike.Backend below). This led
to problems when Pike attempted to run poll-device based backends
on older versions of operating systems where poll devices aren't
available, and with extra overhead when the backend was only used
with a very small set of files.
Basic backend implementations:
- Pike.PollDeviceBackend
This is a backend that is implemented based on keeping the state in
the operating system kernel and thus eliminating the need to send the
state in every system call. This is however not available on all
operating systems. Currently supported are /dev/poll (Solaris, etc),
epoll(2) (Linux) and kqueue(2) (FreeBSD, MacOS X).
- Pike.PollBackend
This is a backend that is implemented based on the poll(2) system call.
This is typically available on all System V or Linux based systems.
- Pike.SelectBackend
This is a backend that is implmented based on the BSD select(2) system
call. This backend is available on all operating systems supported by
Pike.
Derived backend implementations:
- Pike.Backend
This is the backend selected among the basic backend implementations,
which is likely to have the best performance when there are lots of
files in the backend.
- Pike.SmallBackend
This is the backend selected among the basic backend implementations,
which is likely to have the best performance when there are very few
files in the backend.
Note that there is also a default backend object:
- Pike.DefaultBackend
This is the Pike.Backend object that is used for file callbacks and
call outs if no other backend object has been specified.
o cpp
The preprocessor now supports macro expansion in the #include and #string
directives.
#include USER_SETTINGS
o Destruct reason passed to lfun::destroy.
lfun::destroy now receives an integer flag that tells why the object
is being destructed, e.g. if it was an explicit call to destroy(),
running out of references, or reaped by the garbage collector.
These integers are defined in the new Object module as
DESTRUCT_EXPLICIT, DESTRUCT_NO_REFS, DESTRUCT_GC and
DESTRUCT_CLEANUP.
o Improved support for mixin.
The Pike compiler now supports mixin for symbols that have been
declared protected. Mixin is the concept of overloading symbols
via multiple inheritance. In previous versions of Pike the mixin
paradigm was only supported for public symbols. For more information
about mixin see eg http://en.wikipedia.org/wiki/Mixin .
o Implicit and explicit create().
The compiler now supports defining classes with both an implicit
and an explicit create().
o Warnings for unused private symbols.
The compiler now checks that all symbols that have been declared
private actually are used.
class A (int i)
{
protected string j;
protected void create(string j)
{
A::j = reverse(j);
}
}
o Warnings for unused local variables.
The compiler now checks that all local variables are used.
o Unicode
Case information and the Unicode module are updated to Unicode
5.1.0.
o The keyword protected
The modifier protected is now an alias for the modifier static.
NOTE: In the next release static will be deprecated.
o extern declared variables
Variables can now be declared as 'extern'. This means that
inheriting classes must have them. They can be used like normal
variables in the base class.
Example:
class A
{
extern int a;
int dummy() { return ++a; }
}
o __attribute__ and __deprecated__
It's now possible to set custom attributes on types, so that
it is possible to make custom type checking. This is currently
used to improve the argument checking for sprintf() and related
functions, and for marking symbols as deprecated.
eg:
__deprecated__ mixed obsolete_function();
__deprecated__(mixed) obsolete_return_value();
mixed fun(__deprecated__(mixed) obsolete_arg);
__deprecated__(mixed) obsolete_variable;
The deprecated type flag using __deprecated__ is a convenience
syntax to use instead of e.g.
void f(void|__attribute__("deprecated",int) timeout)
Other uses of __attribute__ in type declarations can be seen in e.g.
the type for werror():
> typeof(werror);
(1) Result: scope(0,function(string : int) |
function(__attribute__("sprintf_format", string),
__attribute__("sprintf_args", mixed) ... : int) |
function(array(string), mixed ... : int))
o __func__
The symbol __func__ now evaluates to the name of the current
function. Note that this name currently can differ from the
declared name in case of local functions (i.e. lambdas). Note
also that __func__ behaves like a literal string, so implicit
string concatenation is supported. eg:
error("Error in " __func__ ".\n");
o __DIR__
__DIR__ is a new preprocessor symbol that resolves to the directory
that the current file is placed in. Similar to how __FILE__ points
out the file the code is placed in.
o #pragma deprecation_warnings
Warnings for use of deprecated symbols can be turned off for a
segment of code with
#pragma no_deprecation_warnings
and turned on again with
#pragma deprecation_warnings
o Compatibility name spaces
Older versions of a function can be reached through its version name
space. For example the 7.4 version of the hash function can be
called through 7.4::hash().
o Iterator API
The iterator API method Iterator->next() is no longer optional.
Extensions and New Functions
----------------------------
o exit()
Exit now takes optional arguments to act as a werror in addition to
exiting the process.
exit(1, "Error while opening file %s: %s\n", path, strerror(errno()));
o getenv()/putenv()
getenv() and putenv() are now accessing and modifying the real
environment.
o get_dir()
Calling get_dir() with no arguments will now return the directory
listing for the current directory.
o undefinedp()/destructedp()
undefinedp() and destructedp() have been added as more readable
alternatives to zero_type().
o limit()
The new toplevel function limit(a, x, b) is a convenience function
that works like min(max(a,x),b).
o listxattr(), getxattr(), setxattr(), removexattr()
The new xattr functions listxattr(), getxattr(), setxattr and
removexattr() allows extended file attributes to be modified from
within Pike.
o sprintf() and sscanf()
- sprintf() now attempts to lookup the name of the program when
formatting types of objects and programs.
- The new formatting directive %H can be used to format a string as
a binary hollerith string.
> sprintf("%2H", "Hello");
(1) Result: "Hello"
- The new formatting directive %q can be used to format a atring as
a quoted string, quoting all control character and non-8-bit
characters as well as quote characters. Like %O but always on one
line.
> sprintf("%q", "abc \x00 \" \' 345");
(1) Result: "\"abc \" ' \u14e5\""
- Ranges in sscanf sets can now start with ^, even at the beginning
of the set specifier. Example: %[^-^] matches a set with only ^ in
it. To negate a set with - in it, the - character must now be the
last character in the set specifier.
o encode/decode value and programs
--with-portable-bytecode is now the default. Pike programs that have
been dumped on one architecture now can be decoded on another.
o gethrtime, gethrvtime, gauge
Added support for POSIX style timers using clock_gettime(3). Notably
this fixes nice high resolution thread local cpu time and monotonic
real time on reasonably modern Linux systems.
There are new constants CPU_TIME_* and REAL_TIME_* in the System
module to allow pike code to query various properties of the CPU and
real time clocks in use.
o ADT.BitBuffer
Added read() method that reads whole bytes from the buffer and
returns as a string.
o ADT.Queue
It is now possible to use sizeof() and values() on a Queue object to
get the size of the queue and all elements in the queue as an array.
o ADT.Stack
Stack objects can now be cast to arrays to get all elements on the
stack.
o ADT.Struct
- New Item class SByte, SWord and SLong represents a signed byte,
word and longword respectively.
- The Item classes int8, uint8, int16, uint16, int32, uint32, int64
and uint64 are aliases for already existing Item classes.
- sizeof() now works for empty Struct objects.
- sizeof() can be used on individual Item objects.
- Struct objects can now be used as Items in other Structs.
class Pair
{
inherit ADT.Struct;
Item id = uint8();
Item val = uint64();
}
class File
{
inherit ADT.Struct;
Item magic = Chars(4);
Item one = Pair();
Item two = Pair();
}
o Array
- New function combinations() returns all combinations of a
specified length with elements from a given array.
- Added push(), pop(), shift() and unshift() functions for Perl
weirdos.
o Calendar
- Added new calendar Badi, used in the Baha'i religion.
- Fixed bugs in discordian, where the year() was off by 1166 and
now() was off 5 month per year.
- Time objects now handle * and / with floats. A split() method has
been added for more advanced splitting where the preferred time
quanta can be given as an argument.
- A new formatting method format_ext_time_short() has been added to
Time objects.
- Timezones are now read from /etc/localtime, if available.
- Cleaned up year-day (yd) handling so that it never goes below 1.
Instead be careful to use either year (y) or week-year (wy)
depending on context.
- Fixed inconsistent range handling in year() and years() that made
them almost but not quite zero-based. Now they are one-based just
like day()/days(), month()/months() etc.
- Cleaned up conversion between weeks and years: E.g. if a week has
days in two years then converting it to years will produce a range
of both years. The attempt to always map a week to a single year
is gone since it's inconsistent with how other overlapping time
ranges are handled. If the user wants to convert a week to the
year it "unambiguously" belongs to, (s)he can do
Calendar.ISO.Year(week->year_no()).
- Did away with the attempt to map leap days between February 24th
and 29th before and after year 2000, since doing so breaks date
arithmetic.
- The last four changes above are not entirely compatible.
Compatibility with 7.6 and older is retained with #pike 7.6.
o CompilerEnvironment & CompilerEnvironment()->PikeCompiler
The Pike compiler has been refactored to be more object-oriented and
more transparent. It is now possible to customize the compiler by
overloading functions in the above two classes. The compiler object
used by Pike internally is available through the global constant
DefaultCompilerEnvironment.
o Debug
The new function count_objects() will return the different kinds of
objects existing within the Pike process. Useful when trying to
pinpoint a leak of Pike objects.
o Error
The new function mkerror() will normalize any thrown value into a
proper error object (or 0).
o Filesystem
Traversion has been extended with two new create arguments. The
first one is a flag to supress errors and the other is a sorting
function which will be applied to the entries in every directory.
This callback can also be used to filter the directory entries.
o Float
The function isnan() can be used to check if a float is Not a
Number.
> Float.isnan(Math.inf/Math.inf);
(1) Result: 1
o Gdbm
Gdbm databases can be opened in synchronous mode or locking mode by
adding "s" or "l" respectively in the mode parameter to the create
method.
o Geography.Position
It is now possible to encode Position objects with encode_value().
o GLUE
- The default event callback will now exit both on Exit and Escape
events.
- The texture, list and light id generators will now be created
after we are sure that GL has been initialized, to prevent crashes
on several systems.
- BaseTexture and BaseDWIM now supports clamped textures.
o Gmp
Many small changes to fix Gmp build issues on different platforms.
The most visible being that the Gmp module now is statically linked
to work around Mac OS X 10.5 linker issues.
o Gz
- Added compress() and uncompress() functions as an simpler and more
efficient but non-streaming interface.
- Support for RLE And FIXED compression method, if supported by
zlib. Give Gz.RLE or Gz.FIXED to the strategy argument of
compress() or the deflate constructor.
- Added support for configurable compression window size. This is
the last argument to compress() and the constructor for
inflate/deflate.
o Image.Colortable
- The new method greyp() can be used to query if the color in the
color object is grey.
- Partial support for serializing color objects. Dithering type and
lookup mode is not currently saved.
o Image.Dims
Support for parsing out the dimensions of TIFF files has been added.
o Image.FreeType
- Added support for handling monochrome (bitmap) fonts.
o Image.Image
- Image object can now be serialized and deserialized with
encode_value() and decode_value().
- It is possible to convert the colors in an image object to and
from YUV (YCrCb) with the new rgb_to_yuv() and yuv_to_rgb()
methods.
o Image.Layer
- It is now possible to get the raw bitmap data of a layer by
casting the layer object to a string.
o Image.PNG
- Properly decode cHRM (chrome), sBIT (sbit), gAMA (gamma), pHYs
(physical), oFFs (offset), tIME (time) chunks.
- The compression level and strategy when compressing PNG images can
be controlled by passing "zlevel" and "zstrategy" options to the
encode() method. Available strategies are filtered, huffman, rle
and fixed.
Image.PNG.encode( img, ([ "zlevel":9, "zstrategy":Gz.RLE ]) );
o Image.TIFF
Added support for little endian TIFF files.
o Int
Int.inf is an object that can be used as an infinitly large integer.
o Java
- If possible, Pike now uses libffi instead of creating our own
trampolines. Adding libffi as a bundle is supported.
- Added built-in support for SPARC64 trampolines.
- The method signature fuzzy-matcher now only considers Pike strings
to match formal parameters of type String, Object, Comparable,
CharSequence or java.io.Serializable.
- When the fuzzy-matcher can not decide on a single method
signature, all candidates are now listed in the error message.
o Locale.Charset
- The character name normalizer now recognizes Unicode prefixes,
e.g. "unicode-1-1-utf-7", though the Unicode version itself is
ignored.
- Added support for the following character sets
GB18030/GBK (CP936)
UTF-EBCDIC
DIN-31624 (ISO-IR-38)
ISO-5426:1980 (ISO-IR-53)
ISO-6438:1996 (ISO-IR-39, ISO-IR-216)
ISO-6937:2001 (ISO-IR-156)
GSM 03.38
Mysql Latin 1
- Added typed encode and decode error objects,
Locale.Charset.EncodeError and Locale.Charset.DecodeError, to make
it possible to catch such errors in a better way.
- ISO-IR non-spacers are now converted into combiners.
o Math
- Matrix multiplication was bugged and gave B*A instead of A*B,
which is now fixed.
- Matrix objects now have xsize() and ysize() methods to query their
dimensions.
- To ease your logarithmic needs log2() and logn() have been added.
o MIME
- Added remapping variants of the encode words functions with
encode_word_text_remapped(), encode_word_quoted(),
encode_words_quoted_remapped() and
encode_words_quoted_labled_remapped().
- Added workaround for a bug in Microsoft Internet Explorer where it
forgets to properly quote backslashes in the Content-Disposition
field.
- Fixed a bug that could occur when casting MIME.Message objects to
strings.
o Mysql
- Two functions set_charset() and get_charset() have been added to
set and query the connection charset. The create() function also
takes a "charset" setting in the options mapping.
- Improved Unicode support. The MySQL driver now supports
(possibly wide) Unicode queries and text return values, handling
the connection charset and all encoding/decoding internally. This
is enabled by setting the charset to "unicode", or through the new
functions set_unicode_encode_mode() and set_unicode_decode_mode().
See their documentation for further details.
o Odbc
The Odbc module has been updated to support the UnixODBC library, and
several issues with Unicode and FreeTDS handling have been fixed.
o Oracle
- The module has been updated to work with Oracle 10.
- An approximation of the number of rows in a result object can be
queried from the new function num_rows().
o Parser.HTML
- Allow string and array as argument to _set_*_callback(). Those
variants work just like a function only returning the string or
array.
o Parser.Pike and Parser.C
- Parser.Pike and Parser.C have been rewritten in C for increased
performance.
- The #string directives should be handled correctly now.
o Parser.RCS
- The RCS parser has been rewritten to be more robust with regards
to broken RCS data.
o Parser.XML.NSTree
- Added add_child_before() and add_child_after() methods to the
NSNode object.
o Parser.XML.Simple
- The autoconvert() function, used to autodetect the character
encoding of an XML file and decode it, has been moved from being a
method of the Parser.XML.Simple object to being a function in the
Parser.XML module.
o Parser.XML.SloppyDOM
Yet another DOM-like module aimed at quickly and conveniently parse
an xml snippet (or whole document) to access its parts. Nodes can be
selected using a subset of XPath.
Footnote: This module was previously part of Roxen WebServer.
o Parser.XML.Tree
The module code has been refactored and a second "simple" interface
has been added. The (new) SimpleNode interface implements a node tree
interface similar to the (old) Node interface, with two major
differences:
- The SimpleNodes do not have parent pointers, this means that they
do not generate cyclic data structures (and thus less garbage, and
no need for zap_tree()), but also that it is no longer possible to
find the root of a tree from any node in the tree.
- Some methods in SimpleNode return different values than the
corresponding method in Node; notably SimpleNode()->add_child(),
which returns the current node rather than the argument.
The refactoring also added individual classes for all of the XML node
types (both for Nodes and for SimpleNodes). This allows for stricter
typing of code involving XML tree manipulation.
Several new functions added to manipulate and insert nodes in the
XML tree.
The module now also has a much better knowledge of DTDs and DOCTYPEs.
o Postgres
- Extended the SQL query interface to include affected_rows() and
streaming_query() as well as variable bindings.
- Automatic binary or text transfer for queryarguments and resultrows.
o Pike
- A new function count_memory() has been added which can calculate
the memory consumed by arbitrary data structures. Useful when
implementing memory caches.
- A new function get_runtime_info() has been added which returns
information about current ABI, if automatic bignums are enabled,
what bytecode method is used, the size of native floats and
integers and the native byte order.
- The constants INDEX_FROM_BEG, INDEX_FROM_END and OPEN_BOUND has
been added for use with the `[..] operator API.
- The functions low_check_call(), get_return_type() and
get_first_arg_type() allows for inspection of attributes and
return values of functions.
o Pike.Backend
Besides the new multiple backend implementations described earlier,
backends now support two new callbacks: before_callback and
after_callback are two new variables in the backend objects. They
can be set to functions that gets called just before and after a
backend is waiting for events.
o Process
- The new function spawn_pike() will spawn a Pike process similar to
the current one, using the same binary file, master and module
paths.
- The new function run() is an easy interface that will run a
process and return a mapping with all the outputs and exit code.
- Process.popen is now able to run in nonblocking mode. If a second
argument is provided a file object will be opened with that mode
and return, enabling two way communication with the new process.
- The system() function has been extended to be able to pass stdin,
stdout and stderr arguments to the spawn() call it performs.
o Protocols.DNS
- Added support for NAPTR (RFC 3403) and SPF (RFC 4408) records.
- The gethostbyname() function now returns IPv6 addresses too, if
available.
- Fixed bugs in IPv6 record parsing.
o Protocols.Bittorrent
- Support for gzipped and compact tracker responses.
- Many performance and bug fixes, such as 30% faster hashing of
files.
o Protocols.HTTP
- Added support for httpu and httpmu requests.
- Queries will now throw an exception in case of an errno condition.
- A new function, do_async_method(), has been added to allow access
to low level asynchronous HTTP calls.
- The http_encode_string() function now knows how to encode UCS-2
characters.
o Protocols.HTTP.Server
- If accept() fails on the open port, the Port object will continue
trying, to support servers with high load.
o Protocols.HTTP.Query
- Added unicode_data() method that will return the payload decoded
according to the charset described in the Content-Type header.
- Many fixes for bugs in asynchronous mode.
- A query will not silently downgrade to http from https anymore if
there is no crypto support.
- Fixes for keep alive.
o Protocols.LDAP
- Enabled support for paged queries.
- Added more resilience to UTF-8 encode errors.
Locale.Charset.DecodeError is thrown for UTF-8 decode exceptions.
- Added a connection pool for connection reuse. It is used through
get_connection() and return_connection().
- Added some schema handling and use it to fix the UTF-8 conversion
to only affect attributes that actually are UTF-8 encoded.
- Added client.read(), client.read_attr(),
client.get_root_dse_attr(), client.get_basedn(),
client.get_scope(), client.get_attr_type_descr(),
get_constant_name(), and a bunch of constants for various object
oids, attributes, well-known object guids and other things.
- Rewrote the search filter parser to handle LDAPv3 extensible
matches. It now also throw errors on all syntactic errors (using a
new FilterError object), instead of sending a partial filter to
the server. It is also possible to compile filters separately
through make_filter(), and there is a very simple cache for
compiled filters through get_cached_filter().
- Added ldap_encode_string(), ldap_decode_string(),
encode_dn_value(), canonicalize_dn(), parse_ldap_url(),
client.get_parsed_url(), and client.get_bound_dn().
- Added client.result.fetch_all().
- Added new flag field to client.search() to control various aspects
of how results are returned: SEARCH_LOWER_ATTRS lowercases all
attribute names. SEARCH_MULTIVAL_ARRAYS_ONLY uses arrays for
attribute values only for attributes that might return more than
one value. SEARCH_RETURN_DECODE_ERRORS may be used to avoid
throwing exceptions on decode errors.
- Added client.get_protocol_version(),
client.get_supported_controls(), and the possibility to specify
controls in client.search().
- Made the result iterator somewhat more convenient: next() now
advances one step past the end so the next fetch() returns zero.
- Added client.error_number(), client.error_string(), and
client.server_error_string() to make it possible to query errors
when no result object is returned.
o Protocols.SNMP
The readmsg() method in the protocol object now takes an optional
timout argument.
o Protocols.XMLRPC
The new AsyncClient class implements an asynchronous XMLRPC client.
o Regexp.PCRE.Widestring
- Replace matches in a string, with support for backreferences, now
possible from replace_positional().
> Regexp.PCRE.Plain("my name is ([a-zA-Z]+)")->
>> replace_positional("hello, my name is john.",
>> "%[0]s is my name");
(1) Result: "hello, john is my name."
- Regexp.PCRE.Widestring is now reported in the basic feature list
(pike --features).
o Sql
- Bugfixes in listing Postgres fields.
- If ENABLE_SPAWN_RSQLD is defined, rsqld will be spawned when
needed to complete rsql queries.
- Added streaming_query() method to Sql objects which enables larger
result sets than available memory.
- It is possible to iterate over the result object from big_query()
queries directly in foreach.
- Support UNDEFINED to designate NULL in emulated bindings.
- Support for ODBC DSN files.
Sql.Sql db = Sql.Sql("dsn://user:<pass[at]host>/database");
- Some native support for the TDS protocol, used by Sybase and
Microsoft SQL server.
Sql.Sql db = Sql.Sql("tds://user:<pass[at]host>/database");
- Support for the SQLite database added. A raw interface is
available through the SQLite module.
Sql.Sql db = Sql.Sql("sqlite://relative/path/to/file");
Sql.Sql db = Sql.Sql("sqlite:///absolute/path/to/file");
- Sql.pgsql. New driver for native PostgreSQL network protocol support.
It implements a superset of the existing Postgres driver.
Current features: no library dependencies (no libpq), native binding
support, streaming support, NOTIFY/LISTEN support (fully eventdriven,
no polling), binary support for integer, float and string datatypes
through big_typed_query(), native support for 64-bit ints and doubles,
COPY FROM/TO STDIN/STDOUT support, multiple simultaneous streaming
queries on the same connection (i.e. multiple PostgreSQL-portal-
support), automatic precompilation and caching of often-used
long-compile-time-needing queries, extended columndescriptions,
accurate error messages under all circumstances, SSL-support,
SQL-injection protection since it will ignore everything after the
first semicolon delimiting the first command in the query, integrated
statistics, _reconnect callback for sessions that use temptables.
Performance tuned, with the helperclass _PGsql.PGsql it currently
is around 21% faster than the old libpq based Postgres driver
for smaller queries; for large bytea blobs and large texts, it
speeds up even more.
Support for this driver is indicated by PostgresNative appearing
in the featurelist, and since it has no library or OS dependencies,
it will always be available.
This driver serves URLs of the form:
pgsql:// (plain) and pgsqls:// (SSL).
In case the old Postgres driver is disabled, this driver takes
over postgres:// transparently as well.
o SSL
It is now possible to set certificates to SSL connections. Example:
SSL.sslfile ssl_connection(Stdio.File conn, string my_key,
string my_certificate)
{
ctx->client_rsa = Standards.PKCS.RSA.parse_private_key(my_key);
// client_certificates is an array holding arrays of certificate
// chains. since we've got a self-signed cert, our cert array has
// only 1 element.
ctx->client_certificates += ({ ({ my_certificate }) });
return SSL.sslfile(conn, ctx, 1, 1);
}
o Standards.IIM
Some bugfixes in parsing Photoshop headers and DOS EPS Binary
Headers.
o Standards.ISO639_2
Updated with the latest ISO639-2 languages.
o Standards.URI
- Updated to conform to RFC 3986.
- Added methods get_query_variables(), set_query_variables(),
add_query_variable() and add_query_variables() to give a better
API to to handle query variables.
- The new method get_http_query() returns the query part and
get_http_path_query() returns both the path and the query, both
coded according to RFC 1738.
o Standards.UUID
- Added support for UUID version 5; name based with SHA hash, which
can be generated from the make_version5 function.
- An UUID object can now be used as namespace in the second argument
to make_version3 as well as the new make_version5.
o Standards.XML.Wix
- Updated to support a more recent version of the Wix tool chain.
- Improved generation of 8.3-style filenames.
- Added support for Shortcut and IniFile-nodes.
- Added support for overriding the language and installer version.
- Improved support for TTF-files.
o Stdio
- Stdio.cp can now work recursively in a directory tree. It will
also keep the permissions of files it copies.
- Added Stdio.recursive_mv which works on every OS and also when the
destination isn't on the same filesystem as the source.
- Added more symbolc default termcap/terminfo bindings to
Stdio.Readline.
- Improved support for Terminfo on NetBSD.
- read_file(), read_bytes(), write_file() and append_file() will may
now throw exceptions on uncommon errors such as when write_file is
unable to write all its data.
- Stdio.File->openat(), statat() and unlinkat() opens, stats and
removes a file or directory relative to an open directory.
- Stdio.FILE->unread() allows pushing back binary strings into the
input stream, as opposed to ungets() which pushes back lines.
- Stdio.UDP has had enable_multicast(), set_multicast_ttl(),
add_membership() and drop_membership() added to make real
multicast use possible.
o String
- The function int2size has been rewritten to fixpoint as well as
using the more common abbreviation of "B" for byte.
- String.secure marks a string as "secure" which currently only
means that the memory is cleared before it is freed.
o System
- resolvepath() is now enabled on more OSes and falls back to
realpath(3C) if resolvepath(2) doesn't exists.
- On systems that support it, setproctitle() can be used to set the
title of the running application.
- Added support for POSIX style timers using clock_gettime(3) to
allow for high resolution thread local cpu time and monotonic real
time on reasonable modern Linux systems for gethrvtime() and
gauge(). Added CPU_TIME_RESOLUTION, CPU_TIME_IMPLEMENTATION,
REAL_TIME_IS_MONOTONIC, REAL_TIME_RESOLUTION and
REAL_TIME_IMPLEMENTATION constants to tell the system
capabilities.
o Tools.Hilfe
- Added support for tab-completion on modules, global and local
symbols and operators.
- Added support for file/directory completion within strings
- Added doc command and F1 key to print documentation on an item if
available (currently only works for modules and classes written in
pike).
o Tools.Standalone
- "pike -x cgrep" now tries to parse Java code.
- "pike -x features" now tests for several more features.
o Web.Crawler
- Bugfix to support robots.txt created on windows.
- User Agent change to "Mozilla 4.0 (PikeCrawler)"
o Web.RDF
- Added add_statement() method which allows new relations to be
added to an RDF set.
New modules / classes / methods added
-------------------------------------
o Fuse
FUSE (Filesystem in USErspace) provides a simple interface for
userspace programs to export a virtual filesystem to the Linux
kernel (and some other OS:es). FUSE also aims to provide a secure
method for non privileged users to create and mount their own
filesystem implementations.
This module implements the needed interfaces to make it possible to
write a FUSE filesystem in Pike.
o ADT.List
A simple doubly linked list of values.
ADT.List l = ADT.List(1, 2, 3);
l->insert(-1, 0);
l->append(4, 5);
foreach(l; int index; int value) {
werror(" %d: value: %d\n", index, value);
}
o ADT.Set
ADT.Set implements a datatype for sets. These sets behave much
like multisets, except that they are restricted to containing only
one instance of each member value.
From a performance viewpoint, it is probably more efficient for a
Pike program to use mappings to serve as sets, rather than using an
ADT.Set, so ADT.Set is mainly provided for the sake of completeness
and code readability.
o Arg
The new argument parser module allows for Getopt style argument
parsing, but with a much simpler and object oriented API.
class Parser
{
inherit Arg.Options;
Opt verbose = NoOpt("-v")|NoOpt("--verbose")|Env("VERBOSE");
Opt name = HasOpt("-f")|HasOpt("--file")|Default("out");
Opt debug = MaybeOpt("-d")|MaybeOpt("--debug");
}
void main(int argc, array(string) argv)
{
Parser p = Parser(argv);
werror("name: %O, verbose: %O, debug: %O\n",
p->name, p->verbose, p->debug);
}
A more simplistic interface is also available for smaller hacks and
programs.
void main(int argc, array(string) argv)
{
mapping opts = Arg.parse(argv);
argv = opts[Arg.REST];
}
o GSSAPI
Implements Pike access to GSS-API v2 as specified in RFC 2743. This
API is used to authenticate users and servers, and optionally also
to encrypt communication between them. The API is generic and can be
used without any knowledge of the actual implementation of these
security services, which is typically provided by the operating
system.
The most common implementation is Kerberos, which means that the
main benefit of this API is to allow clients and servers to
authenticate each other using Kerberos, thereby making single
sign-on possible in a Kerberized environment.
o GTK2
Wrapper for the GTK2 library. Not yet 100% completed, but usable.
o Protocols.DNS_SD
This module provides an interface to DNS Service Discovery. The
functionality of DNS-SD is described at <http://www.dns-sd.org/>.
Using the Proctocols.DNS_SD.Service class a Pike program can
announce services, for example a web site or a database server, to
computers on the local network.
When registering a service you need to provide the service name.
service type, domain and port number. You can also optionally
specify a TXT record. The contents of the TXT record varies between
different services; for example, a web server can announce a path
to a web page, and a printer spooler is able to list printer
features such as color support or two-sided printing.
The service is registered on the network for as long as the instance
of the Service class is valid.
o Bittorrent.Tracker
Bittorrent tracker with support for scraping and UDP extension.
o Protocols.HTTP.Server.Proxy
A simple HTTP proxy.
o Standards.TLD
Country domains and other TLDs according to IANA. Useful when
parsing log information or providing live information about clients
connecting to your server.
o Tools.Shoot
Several new tests have been added to benchmark and improve on
various aspects of Pike. ReplaceParallel and ReplaceSerial measure
the times it takes to replace multiple substrings of a string in a
single call to replace and with subsequent calls.
TagRemoveArraySscanf, TagRemoveDivide, TagRemoveLoop,
TagRemoveParserHTML, TagRemovePCRE, TagRemoveSearch and
TagRemoveSscanf measure different methods of completing the same
task; to remove XML tags from a string.
o Web.CGI
Provides a CGI interface on the callee side. Retrieves information
from environment variables and populates the variables in the
Request object.
Deprecations
------------
o The keyword nomask has been deprecated. It was functionally
equivivalent with the keyword final.
o Stdio.File->set_peek_file_before_read_callback() is deprecated.
Incompatible changes
--------------------
These incompatible changes can be solved by adding #pike 7.6 to your
source file or starting Pike with -V7.6 unless otherwise noted.
o main() environment
The main() method will no longer be given the environment as a
mapping as third argument. Use an explicit call to getenv() instead.
o Array.transpose_old
This function has been removed.
o Calendar
Changes made to fix inconsistensies has created som unavoidable
incompatibilities. See the entry for Calendar in the functional
changes section for details.
o _Charset
The parts of this internal module that were written in Pike
have moved to Locale.Charset.
o Crypto
The old crypto functions from Pike 7.4 have been removed. These
functions produced a warning when used in Pike 7.6.
o Debug.describe_program
The API for this debug function has changed.
o Image.Image
The functions select_colors(), map_closest(), map_fast() and
map_fs() has been removed. Use Image.Colortable operations instead.
o Parser.XML
The XML parsers are now stricter in verifying the correctness
of the XML. The function compat_allow_errors can be called in the
create method of the Parser.XML.Simple and Parser.XML.Validating
(with "7.6" as argument for 7.6 compatibility). Parser.XML.Tree can
be created with PARSE_COMPAT_ALLOW_ERRORS_7_6 as flag.
o Protocols.LDAP.client
The "dn" field wasn't properly utf-8 decoded in 7.6 and earlier. If
your application does it yourself, you need to use the compatibility
version of this class.
o spider.XML
The spider module no longer contains the XML parser. The functions
isbasechar(), iscombiningchar(), isdigit(), isextender(),
isfirstnamechar(), ishexchar(), isidiographic(), isletter(),
isnamechar() and isspace() have also been moved to the Parser module.
o Sql.Sql
Pike will no longer create a .column entry in SQL query responses if
there is no table name.
o Standards.UUID
Functions new() and new_string() have been removed. Use
make_version1(-1)->encode() and make_version1(-1)->str() instead.
o Stdio
The functions read_file(), read_bytes(), write_file() and
append_file() now always throw errors on error conditions,
to allow easier use as errno doesn't have to be checked.
read_file() and read_bytes() still return 0 if the file
does not exist.
o The modules Mird, Perl and Ssleay have been removed.
Note that these modules are not available via the backwards
compatibility layer.
C level module API
------------------
o Improved support for embedding.
Several declarations and definitions (most notably the debug and
runtime flags) have moved from main.h to pike_embed.h, in an attempt
to add support for embedding.
o Major compiler API cleanups.
The Pike compiler is now executing in a pike function context
(rather than in an efun context), and it is possible to customize
some of its behaviour via inherit (rather than via handler objects).
As a consequence the compiler is now much closer to being thread-safe.
o The global variable next_timeout is no more. It has been replaced by
a backend-specific variable. Added backend_lower_timeout() for accessing
the new variable. This fixes issues GTK, GTK2 and sendfile had with the
new backend implementation.
NOTE! C-API incompatibility!
NOTE! Changed the argument for backend callbacks!
The argument is now a struct Backend_struct * when called
at entry (was NULL).
The argument is now NULL when called at exit (was 1).
o Pike_fp->context
Pike_fp->context is now a pointer to the current struct inherit
rather than a copy of it. This allows for easier access to
inherited symbols in C-code.
o Inherit level argument added to several object handling functions.
In order to implement subtyping of objects, an extra argument
"inherit_level" has been added to many object indexing related
functions.
o .cmod:
Voidable pointer types are no longer promoted to mixed.
o Support for class symbols with storage in parent scope.
Also added support for aliased symbols.
o Machine code backend for PPC64
- Machine code generation is now supported for PowerPC in
64-bit ABI mode.
o Objectiv-C embedding framwork
- Experimental support for interfacing with Objective-C code
has been added.
NOTE! This API is experimental and is subject to change
NOTE! without notice.
o Added %c and %C to get_all_args to get char * without
NUL characters (no 0 valued characters inside the string).
%c: char * Only narrow (8 bit) strings without NUL.
This is identical to %s.
%C: char * or NULL Only narrow (8 bit) strings without NUL, or 0
Building and installing
-----------------------
o Dynamic modules now become DLLs on Windows.
This means the homegrown module loader is no longer used, but it
also means some DLL limitations:
- PMOD_EXPORT is now required to allow access to an identifier in
the pike core.
- DLLs have to be recompiled too if pike.exe is recompiled.
The primary motivation for this change is to work with the new
library tracking (so-called "side-by-side assemblies") in Visual C++
2005 and later.
o Added ABI selection.
It's now possible to select whether to compile in 32bit or 64bit
mode at configure time by using the --with-abi option.
o MinGW builds.
It's now possible to build Pike in MinGW on windows computers from
source distributions.
o Cmod precompiler.
- The cmod precompiler (pike -x precompile) now supports declaring
all autogenerated identifiers as static.
NOTE! C-API incompatibility!
NOTE! As a side effect of this change, the DECLARATIONS statement
NOTE! now required in cmod files.
New simplified method to write external C/C++ modules
-----------------------------------------------------
It's now suggested that you do not use the fairly complex 'pike
internal' style of external modules (configure.in with
AC_MODULE_INIT etc).
It's also no longer required that you have a configure script to use
pike -x module.
Instead simply locate the includefiles using 'pike -x cflags', and
convert .cmod to .c files using 'pike -x precompile'.
An example rather minimal 'pike -x module' compatible Makefile,
without a configure script, using .cmod format files for a simple
local module:
| CC=gcc
| CFLAGS := -O9 -fweb -shared -Wall $(CFLAGS) $(shell $(PIKE) -x cflags) -g
| LD=$(CC) -shared -lGL
|
| all: Spike.so
|
| install: Spike.so
| cp $< $(MODULE_INSTALL_DIR)
|
| Spike.so: Spike.o
| $(LD) -o Spike.so Spike.o $(LDFLAGS)
|
| Spike.o: Spike.c
|
| Spike.c: Spike.cmod
| $(PIKE) -x precompile $< > $@
It's usually OK not to use pike -x module at all, but it will pass
on a few extra variables to your make (and configure script):
PIKE: How to start the pike interpreter used running pike -x module
MODULE_INSTALL_DIR: Where modules goes
LOCAL_MODULE_PATH: Alternative (user local) module location
/ Peter Bortas
Previous text:
>17128836 2008-12-12 05:28 /1489 lines/ Brevbäraren
>Recipients: Pike (-) developers forum
>Subject: Pike 7.8 beta
>--------------------------------------------------------------------
>After an excruciatingly long development period the Pike developers
>are proud to present the first beta of Pike 7.8. Users and developers
>alike are encouraged to test this beta and report problems so we can
>have a final release as soon as possible.
>
>The source and windows installer can be downloaded here:
>
> https://pike.ida.liu.se/download/pub/pike/beta/7.8.98/
>
>Known issues:
>
> * The new Windows installer does not install all the explorer
> bindings the old one did, neither does it set up start menu
> entries.
>
> * The new Windows installer does not precompile the installed modules.
>
>
>Changes since Pike 7.6:
>----------------------------------------------------------------------
>
>This is a high level list of changes between Pike 7.6 and Pike 7.8.
>General bug fixes, build fixes and optimizations are not mentioned
>here. For a complete list of changes, please consult the CVS changelog
>either directly or through Code Librarian.
>
>This high level changelog is also available here:
>
> https://pike.ida.liu.se/download/notes/7.8.xml
>
>
>New / improved language functionality
>-------------------------------------
>
>o New syntax to index from the end in range operations.
>
> A "<" can be added before an index in the [..] operator to count
> from the end instead, beginning with 0 for the last element. This is
> convenient to e.g. chop off the last element in an array: a[..<1].
>
>o New `[..] operator function.
>
> Range operations have been separated from the `[] operator function
> and are now handled by the new `[..] which provides greater control
> for how the range bounds are specified. For compatibility, if there
> is no `[..] then `[] is still called for range operations.
>
> The `[..] callback will get four arguments, start value, start type,
> end value and end type. The type arguments is any of
> Pike.INDEX_FROM_BEG, Pike.INDEX_FROM_END or Pike.OPEN_BOUND. Here
> are a few examples of what input arguments different calls would
> generate.
>
> [..] 0 OPEN_BOUND 0 OPEN_BOUND
> [1..] 1 INDEX_FROM_BEG 0 OPEN_BOUND
> [..2] 0 OPEN_BOUND 2 INDEX_FROM_BEG
> [3..4] 3 INDEX_FROM_BEG 4 INDEX_FROM_BEG
> [<5..] 5 INDEX_FROM_END 0 OPEN_BOUND
> [6..<7] 6 INDEX_FROM_BEG 7 INDEX_FROM_END
>
>o Generalized this and this_program.
>
> It is now possible to refer to inherits in objects. Example:
>
> class A {
> int a;
> void foo() { werror("A\n"); }
> }
> class B {
> inherit A;
> int b;
> void foo() { werror("B\n"); }
> A::this_program get_a() { return A::this; }
> }
>
> In the above B()->get_a() will return an object with two symbols,
> 'a' and 'foo', but B()->get_a()->foo() will still write "B\n".
>
>o Added support for getters and setters.
>
> It is now possible to simulate variables with functions. Example:
>
> class A {
> private int a;
> int `b() { return a; } // Getter for the symbol b.
> void `b=(int c) { a = c; } // Setter for the symbol b.
> int c()
> {
> return b; // Calls `b().
> }
> }
>
> object a = A();
> a->b = 17; // Calls `b=(17).
> werror("%d\n", a->b); // Calls `b().
>
>o Casting to derived types.
>
> It is now possible to call a value of type type to perform the
> corresponding value cast. eg:
>
> typedef string MyString;
>
> return MyString(17); // Casts 17 to "17".
>
>o Unicode escapes.
>
> Pike now understands the common way to escape unicode chars, using
> \uxxxx and \Uxxxxxxxx escapes. These escapes works both in string
> and character literals and in the preprocessor. The latter means
> that unicode escapes can be used in identifiers, which is useful if
> they contain characters that can't be represented raw in the source
> code charset.
>
>o Stricter type checker for function calls.
>
> The type checker for function calls is now based on the concept of
> currification. This should provide for error messages that are more
> easily understood. It also is much better att typechecking function
> calls utilizing the splice (@) operator. The mechanisms used by the
> typechecker are also made available as Pike.get_first_arg_type(),
> Pike.low_check_call() and Pike.get_return_type().
>
>o Stricter typing of strings.
>
> The string type may now have an optional value range.
>
> string(0..255) bytes;
>
>o Support for having multiple different active backend implementations.
>
> In Pike 7.6 and earlier, there could only be one active backend
> implementation at a time, which was the one selected for best
> performance with lots of files (cf Pike.Backend below). This led
> to problems when Pike attempted to run poll-device based backends
> on older versions of operating systems where poll devices aren't
> available, and with extra overhead when the backend was only used
> with a very small set of files.
>
> Basic backend implementations:
>
> - Pike.PollDeviceBackend
> This is a backend that is implemented based on keeping the state in
> the operating system kernel and thus eliminating the need to send the
> state in every system call. This is however not available on all
> operating systems. Currently supported are /dev/poll (Solaris, etc),
> epoll(2) (Linux) and kqueue(2) (FreeBSD, MacOS X).
>
> - Pike.PollBackend
> This is a backend that is implemented based on the poll(2) system call.
> This is typically available on all System V or Linux based systems.
>
> - Pike.SelectBackend
> This is a backend that is implmented based on the BSD select(2) system
> call. This backend is available on all operating systems supported by
> Pike.
>
> Derived backend implementations:
>
> - Pike.Backend
> This is the backend selected among the basic backend implementations,
> which is likely to have the best performance when there are lots of
> files in the backend.
>
> - Pike.SmallBackend
> This is the backend selected among the basic backend implementations,
> which is likely to have the best performance when there are very few
> files in the backend.
>
> Note that there is also a default backend object:
>
> - Pike.DefaultBackend
> This is the Pike.Backend object that is used for file callbacks and
> call outs if no other backend object has been specified.
>
>o cpp
>
> The preprocessor now supports macro expansion in the #include and #string
> directives.
>
> #include USER_SETTINGS
>
>o Destruct reason passed to lfun::destroy.
>
> lfun::destroy now receives an integer flag that tells why the object
> is being destructed, e.g. if it was an explicit call to destroy(),
> running out of references, or reaped by the garbage collector.
>
> These integers are defined in the new Object module as
> DESTRUCT_EXPLICIT, DESTRUCT_NO_REFS, DESTRUCT_GC and
> DESTRUCT_CLEANUP.
>
>o Improved support for mixin.
>
> The Pike compiler now supports mixin for symbols that have been
> declared protected. Mixin is the concept of overloading symbols
> via multiple inheritance. In previous versions of Pike the mixin
> paradigm was only supported for public symbols. For more information
> about mixin see eg http://en.wikipedia.org/wiki/Mixin .
>
>o Implicit and explicit create().
>
> The compiler now supports defining classes with both an implicit
> and an explicit create().
>
>o Warnings for unused private symbols.
>
> The compiler now checks that all symbols that have been declared
> private actually are used.
>
> class A (int i)
> {
> protected string j;
> protected void create(string j)
> {
> A::j = reverse(j);
> }
> }
>
>o Warnings for unused local variables.
>
> The compiler now checks that all local variables are used.
>
>o Unicode
>
> Case information and the Unicode module are updated to Unicode
> 5.1.0.
>
>o The keyword protected
>
> The modifier protected is now an alias for the modifier static.
> NOTE: In the next release static will be deprecated.
>
>o extern declared variables
>
> Variables can now be declared as 'extern'. This means that
> inheriting classes must have them. They can be used like normal
> variables in the base class.
>
> Example:
> class A
> {
> extern int a;
> int dummy() { return ++a; }
> }
>
>o __attribute__ and __deprecated__
>
> It's now possible to set custom attributes on types, so that
> it is possible to make custom type checking. This is currently
> used to improve the argument checking for sprintf() and related
> functions, and for marking symbols as deprecated.
> eg:
>
> __deprecated__ mixed obsolete_function();
> __deprecated__(mixed) obsolete_return_value();
> mixed fun(__deprecated__(mixed) obsolete_arg);
> __deprecated__(mixed) obsolete_variable;
>
> The deprecated type flag using __deprecated__ is a convenience
> syntax to use instead of e.g.
>
> void f(void|__attribute__("deprecated",int) timeout)
>
> Other uses of __attribute__ in type declarations can be seen in e.g.
> the type for werror():
>
> > typeof(werror);
> (1) Result: scope(0,function(string : int) |
> function(__attribute__("sprintf_format", string),
> __attribute__("sprintf_args", mixed) ... : int) |
> function(array(string), mixed ... : int))
>
>o __func__
>
> The symbol __func__ now evaluates to the name of the current
> function. Note that this name currently can differ from the
> declared name in case of local functions (i.e. lambdas). Note
> also that __func__ behaves like a literal string, so implicit
> string concatenation is supported. eg:
>
> error("Error in " __func__ ".\n");
>
>o __DIR__
>
> __DIR__ is a new preprocessor symbol that resolves to the directory
> that the current file is placed in. Similar to how __FILE__ points
> out the file the code is placed in.
>
>o #pragma deprecation_warnings
>
> Warnings for use of deprecated symbols can be turned off for a
> segment of code with
>
> #pragma no_deprecation_warnings
>
> and turned on again with
>
> #pragma deprecation_warnings
>
>o Compatibility name spaces
>
> Older versions of a function can be reached through its version name
> space. For example the 7.4 version of the hash function can be
> called through 7.4::hash().
>
>o Iterator API
>
> The iterator API method Iterator->next() is no longer optional.
>
>
>Extensions and New Functions
>----------------------------
>
>o exit()
>
> Exit now takes optional arguments to act as a werror in addition to
> exiting the process.
>
> exit(1, "Error while opening file %s: %s\n", path, strerror(errno()));
>
>o getenv()/putenv()
>
> getenv() and putenv() are now accessing and modifying the real
> environment.
>
>o get_dir()
>
> Calling get_dir() with no arguments will now return the directory
> listing for the current directory.
>
>o undefinedp()/destructedp()
>
> undefinedp() and destructedp() have been added as more readable
> alternatives to zero_type().
>
>o limit()
>
> The new toplevel function limit(a, x, b) is a convenience function
> that works like min(max(a,x),b).
>
>o listxattr(), getxattr(), setxattr(), removexattr()
>
> The new xattr functions listxattr(), getxattr(), setxattr and
> removexattr() allows extended file attributes to be modified from
> within Pike.
>
>o sprintf() and sscanf()
>
> - sprintf() now attempts to lookup the name of the program when
> formatting types of objects and programs.
>
> - The new formatting directive %H can be used to format a string as
> a binary hollerith string.
>
> > sprintf("%2H", "Hello");
> (1) Result: "Hello"
>
> - The new formatting directive %q can be used to format a atring as
> a quoted string, quoting all control character and non-8-bit
> characters as well as quote characters. Like %O but always on one
> line.
>
> > sprintf("%q", "abc \x00 \" \' 345");
> (1) Result: "\"abc \" ' \u14e5\""
>
> - Ranges in sscanf sets can now start with ^, even at the beginning
> of the set specifier. Example: %[^-^] matches a set with only ^ in
> it. To negate a set with - in it, the - character must now be the
> last character in the set specifier.
>
>o encode/decode value and programs
>
|