| Age | Commit message (Collapse) | Author | 
|---|
|  | * bg/deprecations:
  test suites: Remove incidental use of deprecated concat_binary/1
  Postpone removal of concat_binary/1
  Remove deprecated lists:flat_length/1
OTP-8584 bg/deprecations | 
|  | The function erl_scan:reserved_word/1 no longer returns true when given the
word spec. This bug was introduced in STDLIB-1.15.3 (R12B-3). | 
|  |  | 
|  | * ks/stdlib:
  erl_parse.yrl: Add missing operator in type declaration
  stdlib: Add types and specs
  stdlib: Use fun object instead of {M,F} tuple
  ets: Cleanup as suggested by tidier
OTP-8576 ks/stdlib | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | When defining macros the closing right parenthesis before the dot is now
mandatory. | 
|  | concat_binary/1 has long been documented as not recommended,
but was formally deprecated as late as in R13B04. Since that
gives very little time to notice and act on the deprecation,
postpone the removal to R15. | 
|  | Remove lists:flat_length/1 which has never been documented or
supported. It has been deprecated since R13A. | 
|  | Unfortunately, commit 1e2ecf8c492b6d499880b8676e3c1fe0c5793103
removed all cond support except for two lines. | 
|  | The Erlang parser no longer duplicates the singleton type undefined in the
type of record fields without initial value. | 
|  | It is possible to obtain the same effect with the
functions escript:extract/2 and zip:fold/3. See
escript_SUITE:escript_foldl/3 for a complete
emulation of the old escript:foldl/3 function. | 
|  | Both reltool and rebar needs to parse escripts. They are currently
using an undocumented function called escript:foldl/3. It folds a
function over all files in the body of an escript. If the body
contains source code the function compiles it and the gives debug
compiled beam code to the fold fun. If the body is an archive the fun
is applied for all files in the archive.
Instead of making the undocumented function public, the new functions
escript:create/2 and escript:extract/2 has been introduced. Together
with the new zip:foldl/3 function they have the same functionality as
escript:foldl/3 in a more flexible and generic way.
escript:foldl/3 should be removed as soon as reltool and rebar has
been adopted to use the new functions. The simplest way for reltool
and rebar to do this is to just copy the code from
escript_SUITE:escript_foldl/3, which happens to provide a future
compatible implementation of an emulated escript:foldl/3 function.
I was quite hesitant when I introduced the compile_source option.  It
feels that it does not belong there but the alternative felt worse.
The rationale for the compile_source option is that it is a bit
cumbersome to compile the source code, as the source in most cases is
partial. In order to do compile the source you need to know about some
internals in escript. Without compile_source I think that these
internals should be documented. Further you need to duplicate parts of
the code.
Without the compile_source option you need to first parse the source
to forms, using an undocumented function in epp with an extended
format of predefined macros which also is undocumented. Then you need
to investigate the forms to see if you need to add an export form for
main. When that is done you can run the rest of the compiler passes as
usual. It is not so much code (60 lines or so) to write, but I do not
want to urge people to write it. I actually wrote the code (see
escript_SUITE:escript_foldl/3) before I decided to introduce the
compile_source option. | 
|  | This is the public interface of prim_zip:open/3,
which has been used in earlier releases by both
erl_prim_loader and escript. The new function
can be used as a replacement for the undocumented
function escript:foldl/3 that is likely to be
removed without further notice.
The error handling of prim_zip:open/3 (and
prim_zip:foldl/3) has been improved in order to
better suite a public interface. For example it
could happen that a file or a zlib port could be
left open in some errors cases.
The documentation of the FileSpec parameter to
zip:create/3 has been updated to show that
file info can be explicitly specified. A FileSpec
may contain {Filename, binary(), #file_info{}}
elements. The function zip:create/3 was already
prepared to partly support this, but now after
a few minor fixes it is fully supported. | 
|  | 'cond' is an experimental feature that was never completed. | 
|  | The guard test constant/1 was removed in R13B. | 
|  |  | 
|  |  | 
|  | The empty record (no fields) is now considered typed.
It is more consistent than before; the base case is
the logical one.
A record is typed iff all its fields are typed.
A record is tagged 'typed' iff it is typed. | 
|  | The erlang pretty printer (erl_pp) no longer quotes atoms in types. | 
|  | Change the shell's line buffer mechanism to more
closely match readline-based shells. New behavior:
  1. Blank lines are not added to the line buffer.
  2. Pressing the down arrow on the last line causes no change.
     The previous behavior erased the line.
  3. The new line is temporarily added to the line buffer
     so the user can move to previous lines with up arrows
     and then back to the new line with down arrows.
     The previous behavior discarded the partially written
     new line.
  4. Changes made to previous lines while exploring the line
     buffer history are preserved.
     The previous behavior discarded changes made to older lines. | 
|  | * ks/types:
  file.hrl: Move out type declarations
  kernel: Add types and specs
OTP-8494 ks/types | 
|  | Having various type declarations in the file.hrl file was once upon a time
necessary since the system could not really handle remote types. Now it can
and these declarations should not be there but appear in file.erl instead.
This means that files that need to use these types can refer to them using
a remote type reference, and not having to include file.hrl - at least not
for this reason. | 
|  | The abstract type 'fun' could not be printed. This bug has been fixed. | 
|  | The Erlang code preprocessor (epp) sent extra messages on the form
{eof,Location} to the client when parsing the file attribute. This bug,
introduced in R11B, has been fixed. | 
|  | escript:foldl/3 was not completely adapted to the changes introduced
in 6af2ac91005276add18b1c9bbf4c8fe4f8c6e040.
A partial fix has already been applied by Hakan Mattson in
4ec4a06edb5baaa0af2840943230c4a0be3a93cf.
Signed-off-by: Tuncer Ayaz <[email protected]> | 
|  |  | 
|  | * jn/supervisor_child_count_only:
  Add count_children/1 to supervisor.erl to determine the number of
OTP-8436  Added supervisor:count_children/1 to count the number of children
          being managed without the memory impact of which_children/1.
          (Thanks to Jay Nelson.) | 
|  | * ks/stdlib-cleanups:
  stdlib: clean up as suggested by tidier
OTP-8435: ks/stdlib-cleanups | 
|  |  | 
|  | children being managed without the memory impact of which_children/1
The function which_children/1 returns a list of the child processes
currently being supervised, but it has the penalty of creating a new
list thereby consuming more memory.  In low memory situations it is
often desirable to know which supervisor may have generated many
processes, but the act of discovering the culprit should not cause the
node to crash (or worse a different node if the kernel kills one
randomly).  The new function count_children/1 can give an indication
of which supervisor is taxing resources the most without adding to the
burden.  Rather than creating a new list, it walks the supervisor's
internal children structure using an accumulator function so that any
used memory can be incrementally collected yet the resulting count can
still be obtained.
The return result of count_children/1 is a property list of counts
containing:
  - {specs, Total_Num_Child_Specs}
  - {active, Num_Active_Child_Processes_Of_Supervisor_Or_Worker_Type}
  - {supervisors, Num_Supervisor_Type_Children_Including_Dead_Processes}
  - {workers, Num_Worker_Type_Children_Including_Dead_Processes}
This patch was made in response to mailing list discussions of the
problem diagnosing heavily taxed production systems.  I cannot find
the original request, but http://www.erlang.org/cgi-bin/ezmlm-cgi/4/35060
is my original post of the patch. | 
|  | prompt strings (io:get_line/{1,2}). io_lib is also updated to
          format prompts with the 't' modifier (i.e. ~ts instead of ~s). | 
|  | * ks/erl_lint:
  erl_lint_SUITE: adjust failing test case
  Allow recursive types and check for undefined types
OTP-8421: ks/erl_lint | 
|  |  | 
|  | Hans Bolinder (the author/maintainer of qlc) prefers
for readability reasons to use length/1 in a guard
when it is known that the list is guaranteed to be
short, so the change suggested by tidier for line 875
of qlc_pt has not been included. | 
|  | Contains four kinds of changes:
 * Allows recursive types and type definitions to be in any order.
 * Because the checking is not performed from top to bottom, there
   is a separate pass which checks for undefined module-local types.
 * Behaviour callbacks which allow specs in them.
 * Clean up the code as suggested by tidier. | 
|  | configuration parameter shell_prompt_func can be used for
          customizing the Erlang shell prompt. | 
|  |  | 
|  | Now, when we have only the constant definition of a macro (without
arguments), we always use it. In all other cases, we try to find the
exact matching definition. We throw an error if we don't find it. | 
|  | This feature simplifies the definition of macros by avoiding to have a
different name for each version (with different arities) of the same
macros. New rules:
- can have multiple definitions of the same macro with different arities
- cannot overload macro with the same arity
- the overloading of predefined macros (?MODULE, ?LINE, ...) is forbidden
- the directive '-undef' removes all definitions of a macro | 
|  | The dict St#epp.uses that helps to find circular macros was not correctly
updated. | 
|  | * ta/ensure_dir_eexist:
  filelib_SUITE: strenghten tests of filelib:ensure_dir/1
  Don't return a false {error,eexist} in filelib:ensure_dir/1
OTP-8389  Because of a race condition, using filelib:ensure_dir/1 from
          multiple processes to create the same path or parts of the same
          directory structure, filelib:ensure_dir/1 could return a
          meaningless {error,eexist}. That race condition has been
          eliminated, and {error,eexist} will now be returned only if there
          exists a regular file, device file, or some other non-directory
          file with the same name. (Thanks to Tuncer Ayaz.) | 
|  | * rb/stdlib_re_unicode_fixes:
  Fix lost unicode option in re:compile()
  Refactor out repeated block in re module
  Fix re:replace/4 to handle unicode charlist Replacement argument
  Fix re:replace/4 to handle unicode charlist RE argument
  Fix re:replace/4 to handle binary unicode output when nothing replaced
OTP-8394  A number of bugs concerning re and unicode are corrected:
          - re:compile no longer loses unicode option, which also fixes bug
            in re:split.
          - re:replace now handles unicode charlist replacement argument
          - re:replace now handles unicode RE charlist argument correctly
          - re:replace now handles binary unicode output correctly when
          nothing is replaced.
          Most code, testcases and error isolation done by Rory Byrne. | 
|  | Noticed-by: Rory Byrne | 
|  |  | 
|  | A bug in re:replace/4 causes a badarg exception to be thrown when the
Replacement argument is a charlist containing non-ascii codepoints.
The problem is that the code incorrectly assumes that the Replacement
text is iodata() and calls iolist_to_binary/1 on it. This patch fixes
it to obey the 'unicode' option and handle charlist() Replacement
arguments correctly. | 
|  | A bug with re:replace/4 causes an exception when: (a) it's given a
unicode charlist as input; (b) it's set to {return,binary}; and
(c) it finds nothing to replace.
The problem is: when re:replace/4 does not find anything to replace
in its Subject input, it calls iolist_to_binary on this data. This
fails if the original input is a charlist with non-ascii codepoints. | 
|  | For example, if an archive (app-vsn.ez) just contains an
          app-vsn/ebin/mod.beam file, the file info for the app-vsn and
          app-vsn/ebin directories are faked using the file info from the
          archive file as origin. The virtual direcories can also be
          listed. For short, the top directories are virtual if they does
          not exist. |