[SCM] Lisaac compiler branch, master, updated. lisaac-0.12-562-g80c8930
Mildred Ki'Lya
silkensedai at online.fr
Wed Feb 10 20:09:27 UTC 2010
The following commit has been merged in the master branch:
commit 80c8930ff594d2f17a7afb1defd010236a5b9f1e
Author: Mildred Ki'Lya <silkensedai at online.fr>
Date: Wed Feb 10 14:15:46 2010 +0100
Remove trailing spaces
diff --git a/install_lisaac.li b/install_lisaac.li
index f0d1fbe..f90a820 100644
--- a/install_lisaac.li
+++ b/install_lisaac.li
@@ -20,58 +20,58 @@
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := INSTALL_LISAAC;
- comment := "Configure the system file and the PATH";
-
+
- external := `#include <unistd.h>`;
-
+
Section Inherit
-
+
- parent_object:OBJECT <- OBJECT;
-
-Section Private
-
+
+Section Private
+
- is_release:BOOLEAN := FALSE;
-
+
//
- // Independance File System
+ // Independance File System
//
-
- - open_read n:ABSTRACT_STRING :POINTER <-
+
+ - open_read n:ABSTRACT_STRING :POINTER <-
( + buf:NATIVE_ARRAY(CHARACTER);
string_tmp.copy n;
buf := string_tmp.to_external;
- `fopen((char*)@buf,"rb")`:(POINTER)
+ `fopen((char*)@buf,"rb")`:(POINTER)
);
- - open_write n:ABSTRACT_STRING :POINTER <-
+ - open_write n:ABSTRACT_STRING :POINTER <-
( + buf:NATIVE_ARRAY(CHARACTER);
string_tmp.copy n;
buf := string_tmp.to_external;
`fopen((char*)@buf,"wb")`:(POINTER)
);
-
- - read f:POINTER in buf:STRING size sz:INTEGER :INTEGER <-
+
+ - read f:POINTER in buf:STRING size sz:INTEGER :INTEGER <-
( + ptr:NATIVE_ARRAY(CHARACTER);
+ result:INTEGER;
- ptr := buf.to_external;
+ ptr := buf.to_external;
result := `fread((void *)(@ptr),(size_t)(1), (size_t)(@sz),(FILE*)(@f))`:(INTEGER);
buf.from_external ptr;
result
);
- - write f:POINTER with buf:STRING size sz:INTEGER :INTEGER <-
+ - write f:POINTER with buf:STRING size sz:INTEGER :INTEGER <-
( + ptr:NATIVE_ARRAY(CHARACTER);
+ result:INTEGER;
- ptr := buf.to_external;
+ ptr := buf.to_external;
result := `fwrite((void *)(@ptr),(size_t)(1), (size_t)(@sz),(FILE*)(@f))`:(INTEGER);
result
);
-
+
- close p:POINTER <- `fclose((FILE*)(@p))`;
-
+
- file_size p:POINTER :INTEGER <-
( + result:INTEGER;
`fseek((FILE*)(@p),0,SEEK_END)`;
@@ -84,31 +84,31 @@ Section Private
( + p:NATIVE_ARRAY(CHARACTER);
+ stream:POINTER;
+ result:BOOLEAN;
-
+
p := new_path.to_external;
stream := `fopen((char*)@p,"w+b")`:POINTER;
(result := (stream != NULL)).if {
- close stream;
+ close stream;
};
result
);
-
+
//
// Tools management.
//
-
+
- string_tmp:STRING := STRING.create 256;
- string_tmp2:STRING := STRING.create 256;
-
+
- error st:ABSTRACT_STRING <-
(
"Error: ".print;
st.print;
die_with_code exit_failure_code;
);
-
- - step_count:INTEGER;
-
+
+ - step_count:INTEGER;
+
- title str:ABSTRACT_STRING count mx:INTEGER <-
(
step_count := step_count + 1;
@@ -129,11 +129,11 @@ Section Private
'='.print;
};
'\n'.print;
- );
-
+ );
+
- question str:ABSTRACT_STRING :CHARACTER <-
( + result:CHARACTER;
-
+
str.print;
" (y/n) ".print;
{(result != 'y') && {result != 'n'}}.while_do {
@@ -142,7 +142,7 @@ Section Private
IO.read_character;
result
);
-
+
- menu t:ABSTRACT_STRING text txt:ABSTRACT_STRING count n:INTEGER :INTEGER <-
( + result,tmp:INTEGER;
'\n'.print;
@@ -156,7 +156,7 @@ Section Private
tmp := IO.last_string.to_integer;
(tmp.in_range 0 to n).if {
result := tmp;
- } else {
+ } else {
"Incorrect range [0-".print;
n.print;
"]\n".print;
@@ -167,26 +167,26 @@ Section Private
}.do_while {result = -1};
result
);
-
- - update file:ABSTRACT_STRING idf id:STRING_CONSTANT
+
+ - update file:ABSTRACT_STRING idf id:STRING_CONSTANT
with new_text:ABSTRACT_STRING confirmation conf:BOOLEAN <-
( + index:INTEGER;
+ old_buffer,input:STRING;
+ std_file:POINTER;
+ size_file:INTEGER;
-
+
" A `".print;
file.print;
-
+
std_file := open_read file;
- (std_file != NULL).if {
+ (std_file != NULL).if {
// Update file.
size_file := file_size std_file;
input := STRING.create (size_file + new_text.count);
read std_file in input size size_file;
- close std_file;
- //
- index := input.first_substring_index id;
+ close std_file;
+ //
+ index := input.first_substring_index id;
(index != 0).if {
// Update configuration.
old_buffer := STRING.create 200;
@@ -208,25 +208,25 @@ Section Private
" New value is:\n".print;
};
} else {
- "' file has been updated with:\n".print;
+ "' file has been updated with:\n".print;
index := input.upper + 1;
};
new_text.print;
- // Append configuration.
- input.insert_string new_text to index;
+ // Append configuration.
+ input.insert_string new_text to index;
} else {
// Creation file.
- "' file has been created with:\n".print;
- new_text.print;
+ "' file has been created with:\n".print;
+ new_text.print;
input := new_text;
(! make_file file).if {
error "Not create file!";
};
- };
-
- ((! conf) || {question " Confirmation ?" = 'y'}).if {
- (conf).if {
- '\n'.print;
+ };
+
+ ((! conf) || {question " Confirmation ?" = 'y'}).if {
+ (conf).if {
+ '\n'.print;
};
std_file := open_write file;
(std_file = NULL).if {
@@ -236,8 +236,8 @@ Section Private
close std_file;
};
);
-
- - execute str:ABSTRACT_STRING :BOOLEAN <-
+
+ - execute str:ABSTRACT_STRING :BOOLEAN <-
( + result:BOOLEAN;
(ENVIRONMENT.execute_command str != 0).if {
"Error: execute `".print;
@@ -247,60 +247,60 @@ Section Private
result := TRUE;
};
result
- );
-
+ );
+
//
// Global variable.
//
-
+
- path_current:STRING;
- path_home :STRING;
- shell :STRING;
- system :STRING_CONSTANT;
- - file :STRING;
+ - file :STRING;
- comment :STRING_CONSTANT;
- path :STRING_CONSTANT;
- path_next :STRING_CONSTANT;
-
+
//
// Constant for environment variable & path.
//
-
+
- system_unix_bash:STRING_CONSTANT := "Unix - bash";
- system_unix_tcsh:STRING_CONSTANT := "Unix - tcsh";
- system_unix_zsh :STRING_CONSTANT := "Unix - zsh";
- system_unix_bsd :STRING_CONSTANT := "Unix - BSD or Mac";
- system_windows :STRING_CONSTANT := "Windows - DOS";
- system_unknown :STRING_CONSTANT := "Unknown";
-
+
- file_bashrc :STRING_CONSTANT := "/.bashrc";
- file_cshrc :STRING_CONSTANT := "/.cshrc";
- file_zshenv :STRING_CONSTANT := "/.zshenv";
- file_profile :STRING_CONSTANT := "/.profile";
- file_autoexec :STRING_CONSTANT := "C:\\autoexec.bat";
- file_msdos_sys:STRING_CONSTANT := "C:\\msdos.sys";
-
+
- comment_windows :STRING_CONSTANT := "\r\nREM **** LISAAC COMPILER ****\r\n";
- comment_unix :STRING_CONSTANT := "\n# **** LISAAC COMPILER ****\n";
-
+
- path_bash :STRING_CONSTANT := "export PATH=";
- path_tcsh :STRING_CONSTANT := "set path=(";
- path_windows:STRING_CONSTANT := "set path=";
-
+
- path_bash_next :STRING_CONSTANT := "/bin:$PATH\n\n";
- path_tcsh_next :STRING_CONSTANT := "/bin $path)\n\n";
- path_windows_next:STRING_CONSTANT := "\\bin;%path%\r\n\r\n";
-
+
//
// Detect system and install environment variables.
//
-
+
- detect_system <-
- ( + std_file :POINTER;
-
+ ( + std_file :POINTER;
+
//
// Detect system
- //
+ //
(shell != NULL).if {
file := STRING.create_from_string path_home;
(shell.is_empty).if {
@@ -310,14 +310,14 @@ Section Private
// Unix - bash
file.append file_bashrc;
system := system_unix_bash;
- comment := comment_unix;
+ comment := comment_unix;
path := path_bash;
path_next := path_bash_next;
}.elseif {shell.has_substring "tcsh"} then {
// Unix - tcsh
file.append file_cshrc;
system := system_unix_tcsh;
- comment := comment_unix;
+ comment := comment_unix;
path := path_tcsh;
path_next := path_tcsh_next;
}.elseif {shell.has_substring "zsh"} then {
@@ -331,7 +331,7 @@ Section Private
// Unknown
" Shell not recognized: ".print;
shell.print;
- '\n'.print;
+ '\n'.print;
system := system_unknown;
};
} else {
@@ -342,36 +342,36 @@ Section Private
close std_file;
file := STRING.create_from_string file_autoexec;
system := system_windows;
- comment := comment_windows;
+ comment := comment_windows;
path := path_windows;
path_next := path_windows_next;
} else {
// Unknown
system := system_unknown;
- };
- };
-
+ };
+ };
+
" System detect: ".print;
system.print;
);
-
+
- install_make_lip <-
(
- (system != system_unknown).if {
+ (system != system_unknown).if {
(system = system_windows).if {
- ENVIRONMENT.execute_command "copy make.lip.sample make.lip";
- update "make.lip" idf " + target" with
- " + target:STRING := \"windows\";\n" confirmation FALSE;
+ ENVIRONMENT.execute_command "copy make.lip.sample make.lip";
+ update "make.lip" idf " + target" with
+ " + target:STRING := \"windows\";\n" confirmation FALSE;
//
- "\n Note: Use `mingw' for Windows.\n".print;
+ "\n Note: Use `mingw' for Windows.\n".print;
} else {
- ENVIRONMENT.execute_command "cp make.lip.sample make.lip";
- update "make.lip" idf " + target" with
- " + target:STRING := \"unix\";\n" confirmation FALSE;
- };
+ ENVIRONMENT.execute_command "cp make.lip.sample make.lip";
+ update "make.lip" idf " + target" with
+ " + target:STRING := \"unix\";\n" confirmation FALSE;
+ };
(is_release).if_false {
"\n Directory for library repository: ".print;
- IO.read_line;
+ IO.read_line;
'\n'.print;
string_tmp2.copy " + lib_extra:STRING := \"";
string_tmp2.append (IO.last_string);
@@ -381,26 +381,26 @@ Section Private
string_tmp2.append "/*";
};
string_tmp2.append "\";\n";
- update "make.lip" idf " + lib_extra" with
+ update "make.lip" idf " + lib_extra" with
string_tmp2 confirmation TRUE;
- update "make.lip" idf " + lib_unstable" with
+ update "make.lip" idf " + lib_unstable" with
" + lib_unstable:STRING := \"\";\n" confirmation FALSE;
};
};
- '\n'.print;
+ '\n'.print;
);
-
- - install_variable <-
+
+ - install_variable <-
( + new_text :STRING;
-
+
title "Fix target variable in `make.lip'." count 5;
install_make_lip;
//
// Installation environment variable
//
-
+
title "Installation of environment variables." count 5;
-
+
(system = system_unknown).if {
// Fail.
" Auto-install fail !\n\
@@ -410,20 +410,20 @@ Section Private
"\\bin;%path%\n\n".print;
} else {
// Creation environment variables.
- new_text := STRING.create_from_string comment;
+ new_text := STRING.create_from_string comment;
new_text.append path;
new_text.append path_current;
new_text.append path_next;
update file idf comment with new_text confirmation TRUE;
};
-
+
//
// Installation Library path
//
-
+
title "Installation of Lisaac library path." count 5;
new_text := STRING.create_from_string path_current;
- (system = system_windows).if {
+ (system = system_windows).if {
new_text.replace_all '\\' with '/';
};
new_text.prepend "#define LISAAC_DIRECTORY \"";
@@ -433,28 +433,28 @@ Section Private
update "src/path.h" idf "#define LISAAC_DIRECTORY" with new_text confirmation FALSE;
'\n'.print;
);
-
+
//
// Install Editor.
//
-
+
- lisaac_mode_comment :STRING_CONSTANT := ";; **** LISAAC MODE ****";
- lisaac_mode_path :STRING_CONSTANT := "\n(setq load-path (cons \"";
- - lisaac_mode_path_end:STRING_CONSTANT := "/editor/emacs/\" load-path))\n";
- - lisaac_mode :STRING_CONSTANT :=
+ - lisaac_mode_path_end:STRING_CONSTANT := "/editor/emacs/\" load-path))\n";
+ - lisaac_mode :STRING_CONSTANT :=
"(add-to-list 'auto-mode-alist '(\"\\\\.li\\\\'\" . lisaac-mode))\n\
\(add-to-list 'auto-mode-alist '(\"\\\\.lip\\\\'\" . lisaac-mode))\n\
\(autoload 'lisaac-mode \"lisaac-mode\" \"Major mode for Lisaac Programs\" t)\n\n";
-
+
- lisaac_vim:STRING_CONSTANT :=
"\nsyntax on \n\
\filetype plugin on \n\
\filetype indent on \n\
\au BufNewFile,BufRead *.li setf lisaac\n";
-
+
- install_emacs <-
( + file_name, new_text:STRING;
-
+
file_name := STRING.create 100;
(path_home = NULL).if {
file_name.copy "C:";
@@ -474,21 +474,21 @@ Section Private
);
- install_kate <-
- (
+ (
(system = system_windows).if {
" Sorry, not Kate editor for windows.".print;
} else {
- ENVIRONMENT.execute_command "mkdir -p ~/.kde/share/apps/katepart/syntax";
+ ENVIRONMENT.execute_command "mkdir -p ~/.kde/share/apps/katepart/syntax";
string_tmp.copy "cp -f editor/kate/lisaac_v2.xml ~/.kde/share/apps/katepart/syntax/.";
" `".print;
string_tmp.print;
"'\t".print;
- (ENVIRONMENT.execute_command string_tmp != 0).if {
+ (ENVIRONMENT.execute_command string_tmp != 0).if {
"\n Sorry, auto-install fail !\n\
\ You can to read the `editor/kate/README' file.".print;
} else {
- "OK.".print;
- };
+ "OK.".print;
+ };
};
);
@@ -499,22 +499,22 @@ Section Private
// TODO: Fix this since gvim exists on windows system
(system = system_windows).if {
" Sorry, not Vim editor for windows.\n\n".print;
- } else {
+ } else {
ENVIRONMENT.execute_command "mkdir -p ~/.vim/syntax";
ENVIRONMENT.execute_command "mkdir -p ~/.vim/indent";
- ENVIRONMENT.execute_command "mkdir -p ~/.vim/backup";
- ENVIRONMENT.execute_command "mkdir -p ~/.vim/temp";
-
+ ENVIRONMENT.execute_command "mkdir -p ~/.vim/backup";
+ ENVIRONMENT.execute_command "mkdir -p ~/.vim/temp";
+
// Syntax hilightning support
string_tmp.copy "cp -f editor/vim/syntax/lisaac.vim ~/.vim/syntax/";
" `".print;
string_tmp.print;
"'\t".print;
- (ENVIRONMENT.execute_command string_tmp != 0).if {
+ (ENVIRONMENT.execute_command string_tmp != 0).if {
"\n Sorry, auto-install fail !\n\
\ You can read the `editor/vim/install_vim_plugin.sh' file.\n".print;
} else {
- "OK.\n".print;
+ "OK.\n".print;
};
// Syntax indentation support
@@ -522,11 +522,11 @@ Section Private
" `".print;
string_tmp.print;
"'\t".print;
- (ENVIRONMENT.execute_command string_tmp != 0).if {
+ (ENVIRONMENT.execute_command string_tmp != 0).if {
"\n Sorry, auto-install fail !\n\
\ You can read the `editor/vim/install_vim_plugin.sh' file.\n".print;
} else {
- "OK.\n".print;
+ "OK.\n".print;
};
// Install ~/.vimrc file
@@ -534,7 +534,7 @@ Section Private
"\n It is recommanded to install the default vimrc file provided by the \n\
\ lisaac installer. \n\n\
\ If you choose not doing this action, your vimrc will only be updated \n\
- \ Do you want to install the default config provided by lisaac installer ?";
+ \ Do you want to install the default config provided by lisaac installer ?";
(char = 'n').if {
file_name := STRING.create 100;
(path_home = NULL).if {
@@ -542,57 +542,57 @@ Section Private
} else {
file_name.copy path_home;
};
- file_name.append "/.vimrc";
+ file_name.append "/.vimrc";
update file_name idf lisaac_vim with lisaac_vim confirmation TRUE;
} else {
string_tmp.copy "cp -f editor/vim/vimrc ~/.vimrc";
" `".print;
string_tmp.print;
"'\t".print;
- (ENVIRONMENT.execute_command string_tmp != 0).if {
+ (ENVIRONMENT.execute_command string_tmp != 0).if {
"\n Sorry, auto-install fail !\n\
\ You can read the `editor/vim/install_vim_plugin.sh' file.\n".print;
} else {
- "OK.\n".print;
+ "OK.\n".print;
};
};
};
);
-
+
- install_hippoedit <-
(
(system = system_windows).if {
- string_tmp.copy
+ string_tmp.copy
"copy editor/hippoedit/lisaac_spec.xml \"C:\\Program Files\\HippoEDIT\\data\\syntax\"";
//
" Execute: `".print;
string_tmp.print;
- "'\t".print;
- (ENVIRONMENT.execute_command string_tmp != 0).if {
+ "'\t".print;
+ (ENVIRONMENT.execute_command string_tmp != 0).if {
"Fail!".print;
} else {
- "Ok.".print;
+ "Ok.".print;
};
} else {
" Sorry, Hippoedit editor is only for Windows.".print;
};
);
-
+
- install_eclipse <-
- (
+ (
" Prerequisite: you need the Eclipse package installed.\n\
\ Use the Eclipse Update Manager to install the Lisaac Mode with the URL:\n\
\ http://isaacproject.u-strasbg.fr/eclipse/update/\n\n\
- \ Please, read `editor/eclipse/README' file for further information.\n".print;
+ \ Please, read `editor/eclipse/README' file for further information.\n".print;
);
-
-
+
+
//
// Install Compiler
//
-
+
- compile_file n:STRING_CONSTANT <-
- (
+ (
string_tmp.copy "gcc -U_FORTIFY_SOURCE -O2 bin/";
string_tmp.append n;
string_tmp.append ".c -o bin/";
@@ -607,13 +607,13 @@ Section Private
".c' file.\n".print;
};
'\n'.print;
- );
-
+ );
+
- compile_shorter is_root:BOOLEAN <-
( + rm,compile:STRING_CONSTANT;
-
+
" Compile `shorter' tools for your system (please wait ...)\n".print;
- (is_root).if {
+ (is_root).if {
compile := "lisaac src/make.lip -shorter -q -boost -o bin/shorter -gcc -Ibin/.";
} else {
(system = system_windows).if {
@@ -624,69 +624,69 @@ Section Private
compile := "bin/lisaac src/make.lip -shorter -q -boost -o bin/shorter -gcc -Isrc/.";
};
};
- (ENVIRONMENT.execute_command compile = 0).if {
- " Shorter ok!\n".print;
+ (ENVIRONMENT.execute_command compile = 0).if {
+ " Shorter ok!\n".print;
(rm != NULL).if {
- ENVIRONMENT.execute_command rm;
+ ENVIRONMENT.execute_command rm;
};
} else {
" Sorry, `shorter' not ready...\n".print;
};
'\n'.print;
);
-
+
//
// Build lib doc.
//
-
+
- build_lib <-
- (
- string_tmp.clear;
+ (
+ string_tmp.clear;
(system = system_windows).if {
- ENVIRONMENT.execute_command "mkdir doc\\html";
+ ENVIRONMENT.execute_command "mkdir doc\\html";
string_tmp.copy "bin\\shorter -d -f belinda -o doc\\html";
// BSBS: A ajouter internal mais sur le meme run shorter
} else {
- ENVIRONMENT.execute_command "mkdir -p doc/html";
+ ENVIRONMENT.execute_command "mkdir -p doc/html";
string_tmp.copy "bin/shorter -d -f belinda -o doc/html";
- };
+ };
" Execute: `".print;
string_tmp.print;
"'\t".print;
(ENVIRONMENT.execute_command string_tmp = 0).if {
" OK\n\n\
- \ Note: you'll find this documentation in `doc/html/index.html'\n".print;
+ \ Note: you'll find this documentation in `doc/html/index.html'\n".print;
} else {
" Fail!\n".print;
};
);
-
+
- user_install <-
( + choice,choice2:INTEGER;
-
+
{
- choice := menu "Menu." text
+ choice := menu "Menu." text
"1- Compiler & Shorter Installation.\n\
- \2- Editor Installation.\n\
+ \2- Editor Installation.\n\
\3- Build the librarie documentation (HTML).\n\
\0- Exit." count 3;
-
- choice
- .when 1 then {
+
+ choice
+ .when 1 then {
step_count := 0;
-
- install_variable;
-
- title "Compilation of Lisaac compiler." count 5;
+
+ install_variable;
+
+ title "Compilation of Lisaac compiler." count 5;
"*---------------------------------------------------------*\n\
\| Note: You need at least 768MB of memory. |\n\
\*---------------------------------------------------------*\n".print;
compile_file "lisaac";
-
- title "Compilation of Shorter tool." count 5;
-
+
+ title "Compilation of Shorter tool." count 5;
+
compile_shorter FALSE;
-
+
"Welcome to the Lisaac World ! \n\
\============================= \n\
\ Installation successfull. \n\
@@ -709,23 +709,23 @@ Section Private
\5- eFTE.\n\
\6- Eclipse.\n\
\0- Exit menu." count 6;
- choice2
+ choice2
.when 1 then {
title "Installation of `lisaac-mode' for Emacs." count 0;
- install_emacs;
+ install_emacs;
}
.when 2 then {
title "Installation of `lisaac.vim' for Vim." count 0;
- install_vim;
+ install_vim;
}
.when 3 then {
title "Installation of `lisaac_v2.xml' for Kate." count 0;
- install_kate;
+ install_kate;
}
.when 4 then {
title "Installation of `lisaac_spec.xml' for Hippoedit." count 0;
install_hippoedit;
- }
+ }
.when 5 then {
title "Installation of eFTE mode." count 0;
" Note: eFTE Lisaac mode is native.\n\
@@ -738,17 +738,17 @@ Section Private
}.do_while {choice2 != 0};
}
.when 3 then {
- title "Build the librarie documentation with Shorter (HTML format)." count 0;
+ title "Build the librarie documentation with Shorter (HTML format)." count 0;
build_lib;
};
}.do_while {choice != 0};
);
-
+
- path_bin:ABSTRACT_STRING := "/usr/bin";
- path_lib:ABSTRACT_STRING := "/usr/lib/lisaac";
- path_doc:ABSTRACT_STRING := "/usr/share/lisaac";
- path_man:ABSTRACT_STRING := "/usr/share/man/man1";
-
+
- ask_path msg:ABSTRACT_STRING default val:ABSTRACT_STRING :ABSTRACT_STRING <-
( + result:STRING;
+ car:CHARACTER;
@@ -758,31 +758,31 @@ Section Private
"] ? (y/n) ".print;
car := IO.read_character;
IO.read_character;
- (car.to_lower = 'y').if {
- result := val;
- } else {
+ (car.to_lower = 'y').if {
+ result := val;
+ } else {
"\n new path : ".print;
- IO.read_word;
+ IO.read_word;
result := IO.last_string;
result.remove_first 1;
};
result
- );
-
+ );
+
- system_install <-
( + path:ABSTRACT_STRING;
+ create:{ (ABSTRACT_STRING,ABSTRACT_STRING,ABSTRACT_STRING,BOOLEAN); };
-
+
// path.h
string_tmp2.copy "#define LISAAC_DIRECTORY \"";
string_tmp2.append path_lib;
string_tmp2.append "\"\n";
- update "bin/path.h" idf "#define LISAAC_DIRECTORY"
+ update "bin/path.h" idf "#define LISAAC_DIRECTORY"
with string_tmp2 confirmation FALSE;
// compile
compile_file "lisaac";
//
- create := { (msg,cpy,dft:ABSTRACT_STRING,ask:BOOLEAN);
+ create := { (msg,cpy,dft:ABSTRACT_STRING,ask:BOOLEAN);
(ask).if {
path := ask_path msg default dft;
} else {
@@ -792,9 +792,9 @@ Section Private
string_tmp.append path;
execute string_tmp;
string_tmp.copy cpy;
- string_tmp.append path;
- execute string_tmp;
- };
+ string_tmp.append path;
+ execute string_tmp;
+ };
//
create.value (" binary path","cp bin/lisaac ",path_bin,TRUE);
//
@@ -819,35 +819,35 @@ Section Private
\| `install_lisaac' in user mode. |\n\
\*---------------------------------------------------------*\n".print;
);
-
+
Section Public
-
+
- main <-
( + cwd:NATIVE_ARRAY(CHARACTER);
- + choice:INTEGER;
+ + choice:INTEGER;
"\t\t================================\n\
- \\t\t= Auto-Install Lisaac Compiler =\n\
+ \\t\t= Auto-Install Lisaac Compiler =\n\
\\t\t================================\n\n".print;
string_tmp.clear;
cwd := string_tmp.to_external;
`getcwd(@cwd,255)`;
string_tmp.from_external cwd;
-
+
path_current := STRING.create (string_tmp.count);
- path_current.copy string_tmp;
+ path_current.copy string_tmp;
path_home := ENVIRONMENT.get_environment_variable "HOME";
shell := ENVIRONMENT.get_environment_variable "SHELL";
-
+
title "Detection system." count 0;
detect_system;
-
+
(system != system_windows).if {
- choice := menu "Menu." text
+ choice := menu "Menu." text
"1- User installation.\n\
\2- System installation (root).\n\
\0- Exit." count 2;
choice
- .when 1 then {
+ .when 1 then {
user_install;
}
.when 2 then {
@@ -855,6 +855,6 @@ Section Public
};
} else {
user_install;
- };
+ };
"\nBye.\n\n".print;
);
diff --git a/lib/internal/os_support/dos/file_system/entry.li b/lib/internal/os_support/dos/file_system/entry.li
index dd87406..7728c3f 100644
--- a/lib/internal/os_support/dos/file_system/entry.li
+++ b/lib/internal/os_support/dos/file_system/entry.li
@@ -19,23 +19,23 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ENTRY;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:= "http://IsaacOS.com";
- - author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
+ - author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
- comment := "Entry ANSI";
-
+
Section Inherit
-
+
+ parent_abstract_entry:Expanded ABSTRACT_ENTRY;
-
-Section Public
-
+
+Section Public
+
//
// Physical implementation.
//
@@ -61,35 +61,35 @@ Section Public
`}`;
result
);
-
+
- physical_remove_directory:BOOLEAN <-
( + p:NATIVE_ARRAY(CHARACTER);
p := path.to_external;
`rmdir(@p)`:(INTEGER) = 0
);
-
+
- physical_remove_file:BOOLEAN <-
( + p:NATIVE_ARRAY(CHARACTER);
p := path.to_external;
`remove(@p)`:(INTEGER) = 0
);
-
+
- physical_rename old_path:ABSTRACT_STRING with new_path:ABSTRACT_STRING :BOOLEAN <-
( + old_p,new_p:NATIVE_ARRAY(CHARACTER);
old_p := old_path.to_external;
new_p := new_path.to_external;
`rename(@old_p, at new_p)`:(INTEGER) = 0
);
-
+
//
// Time / Date: Unix -> Lisaac
//
-
+
- to_date t:POINTER :DATE <-
( + result:DATE;
+ wd,md,m:UINTEGER_8;
+ y:UINTEGER_16;
-
+
y := `((struct tm *)@t)->tm_year`:UINTEGER_16 + 1900;
m := `((struct tm *)@t)->tm_mon` :UINTEGER_8 + 1;
md := `((struct tm *)@t)->tm_mday`:UINTEGER_8;
@@ -97,15 +97,15 @@ Section Public
(! wd.in_range 1 to 7).if { // Bug in UNIX ?
wd := 1;
};
- result := DATE.create (y,m,md,wd)
+ result := DATE.create (y,m,md,wd)
);
- to_time t:POINTER :TIME <-
(
- TIME.create
+ TIME.create
((`((struct tm *)@t)->tm_hour`:UINTEGER_8),
(`((struct tm *)@t)->tm_min` :UINTEGER_8),
(`((struct tm *)@t)->tm_sec` :UINTEGER_8),
0)
);
-
+
diff --git a/lib/internal/os_support/dos/video/bitmap_8.li b/lib/internal/os_support/dos/video/bitmap_8.li
index fd51051..58bb746 100644
--- a/lib/internal/os_support/dos/video/bitmap_8.li
+++ b/lib/internal/os_support/dos/video/bitmap_8.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := BITMAP_8;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Bitmap 8 bits";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
-
+
Section Inherit
-
+
+ parent_bitmap:Expanded BITMAP;
-
+
Section Public
-
+
- pixel_geometry:PIXEL := PIXEL_8;
-
-Section Private
-
+
+Section Private
+
//
// Data.
//
-
+
// Mapping memory bitmap.
+ image:FAST_ARRAY(BMP_LINE_8);
-
+
- get_line y:INTEGER :BMP_LINE <-
(
image.item y
);
-
+
//
- // Creation.
+ // Creation.
//
- make (w,h:INTEGER) <-
@@ -65,13 +65,13 @@ Section Private
image.put (BMP_LINE_8.create w) to y;
};
clipping_off;
- );
-
+ );
+
- make (w,h:INTEGER) at offset_begin:UINTEGER_32 bytes_per_line lx:INTEGER <-
( + offset:UINTEGER_32;
-
+
width := w;
- height := h;
+ height := h;
image := FAST_ARRAY(BMP_LINE_8).create h;
offset:=offset_begin;
0.to (image.upper) do { y:INTEGER;
@@ -80,8 +80,8 @@ Section Private
};
clipping_off;
);
-
-
+
+
diff --git a/lib/internal/os_support/dos/video/bmp_line_8.li b/lib/internal/os_support/dos/video/bmp_line_8.li
index c941f5a..4e87d37 100644
--- a/lib/internal/os_support/dos/video/bmp_line_8.li
+++ b/lib/internal/os_support/dos/video/bmp_line_8.li
@@ -19,68 +19,68 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := BMP_LINE_8;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Bitmap line 8 bits";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
Section Inherit
-
+
+ parent_bmp_line:Expanded BMP_LINE;
-
+
Section Private
-
+
+ storage:MAP_NATIVE_ARRAY(PIXEL_8);
-
+
- get_storage:NATIVE_ARRAY(UINTEGER_8) <- NATIVE_ARRAY(UINTEGER_8).force_conversion storage;
-
+
- make n:INTEGER <-
- (
+ (
capacity := n;
- upper := n - 1;
- storage := MAP_NATIVE_ARRAY(PIXEL_8).calloc n;
+ upper := n - 1;
+ storage := MAP_NATIVE_ARRAY(PIXEL_8).calloc n;
);
-
+
- make_with_capacity n:INTEGER <-
(
capacity := n;
upper := -1;
- storage := MAP_NATIVE_ARRAY(PIXEL_8).calloc n;
+ storage := MAP_NATIVE_ARRAY(PIXEL_8).calloc n;
);
-
+
- make n:INTEGER at offset:UINTEGER_32 <-
- (
+ (
capacity := n;
- upper := n - 1;
- storage := MAP_NATIVE_ARRAY(PIXEL_8).force_conversion offset;
+ upper := n - 1;
+ storage := MAP_NATIVE_ARRAY(PIXEL_8).force_conversion offset;
);
Section Public
-
+
- pixel_geometry:PIXEL := PIXEL_8;
-
+
//
// Put.
//
-
- - put (r,g,b:UINTEGER_8) from idx_begin:INTEGER to idx_end:INTEGER <-
- ( + pixel:PIXEL_8;
+
+ - put (r,g,b:UINTEGER_8) from idx_begin:INTEGER to idx_end:INTEGER <-
+ ( + pixel:PIXEL_8;
? {idx_begin<=idx_end};
? {idx_begin>=0};
? {idx_end.in_range 0 to upper};
-
+
PIXEL_24.color (r,g,b);
pixel := PIXEL_24.to_pixel_8;
idx_begin.to idx_end do { n:INTEGER;
storage.item n.copy pixel;
};
);
-
+
- put bmp:BMP_LINE offset ofs:INTEGER from idx_begin:INTEGER to idx_end:INTEGER <-
( + offset:INTEGER;
+ pixel:PIXEL_8;
@@ -88,8 +88,8 @@ Section Public
? {idx_begin >= 0};
? {idx_end.in_range 0 to upper};
? {ofs >= 0};
- ? {(ofs + (idx_end - idx_begin)) <= bmp.upper};
-
+ ? {(ofs + (idx_end - idx_begin)) <= bmp.upper};
+
offset := ofs;
idx_begin.to idx_end do { n:INTEGER;
pixel := bmp.item_8 offset;
@@ -97,15 +97,15 @@ Section Public
offset := offset + 1;
};
);
-
+
//
// Get.
//
-
+
- item n:INTEGER :PIXEL <-
( ? {n.in_range 0 to upper};
storage.item n
);
-
+
diff --git a/lib/internal/os_support/dos/video/event_system.li b/lib/internal/os_support/dos/video/event_system.li
index 60c1b8b..325d290 100644
--- a/lib/internal/os_support/dos/video/event_system.li
+++ b/lib/internal/os_support/dos/video/event_system.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EVENT_SYSTEM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "X11 - Event System";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
-Section Public
- - make <-
+Section Public
+
+ - make <-
(
// Nothing.
);
-
+
- get_event <-
- (
+ (
KEYBOARD.get_scan;
MOUSE.get_new_event;
);
-
-
+
+
diff --git a/lib/internal/os_support/dos/video/keyboard.li b/lib/internal/os_support/dos/video/keyboard.li
index 166a033..a0d6353 100644
--- a/lib/internal/os_support/dos/video/keyboard.li
+++ b/lib/internal/os_support/dos/video/keyboard.li
@@ -23,22 +23,22 @@ Section Header
+ name := KEYBOARD;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:="http://IsaacOS.com";
- author :="Boutet Jerome (boutet at loria.fr),Sonntag Benoit (bsonntag at loria.fr)";
- comment :="Keyboard for DOS - AZERTY";
- - version := 1;
+ - version := 1;
- date :="2003/04";
-
+
Section Inherit
-
+
+ parent_input_keyboard:Expanded INPUT_KEYBOARD;
Section Private
-
- + e_code:BOOLEAN; // TRUE If extended mode
-
+
+ + e_code:BOOLEAN; // TRUE If extended mode
+
// Lower case.
- cmin:STRING_CONSTANT := "\0d\&\"\39d\(-_
)=\1d\\2d\azertyuiop^$\3d\^qsdfghjklmý^*wxcvbn,;:!^*^ ";
// Upper case.
@@ -46,27 +46,27 @@ Section Private
- cmm:STRING_CONSTANT := "\27d\\8d\\9d\\13d\"; // 0:Echap 1:Del 2:Tab 3:Enter
- caltgr:STRING_CONSTANT := "'~#{[|`\\^@]}";
-
+
// Num keyb.
- keynum0:STRING_CONSTANT := "789-456+1230."; // from 70-82
- keynum1:STRING_CONSTANT := "BUA\0d\LMR\0d\ELZIS"; // Without NumLock
-
+
// Extended keyboard from 88 to 102
- - ext_key:STRING_CONSTANT := "\55d\\28d\\52d\\27d\\70d\\78d\\81d\\82d\\76d\\74d\\71d\\79d\\80d\\72d\\54d\";
+ - ext_key:STRING_CONSTANT := "\55d\\28d\\52d\\27d\\70d\\78d\\81d\\82d\\76d\\74d\\71d\\79d\\80d\\72d\\54d\";
- buf_extk:STRING_CONSTANT := "\13d\BEISRLUDZAH";
-Section Public
-
+Section Public
+
- old_scan:UINTEGER_8;
-
+
//
// Get Character (Interrupt #21)
//
- get_scan <-
( + cu,scancode,tmp:UINTEGER_8;
-
- scancode:=SYSTEM.itemb 60h;
+
+ scancode:=SYSTEM.itemb 60h;
(scancode != old_scan).if {
old_scan := scancode;
cu:=getcode (scancode-1);
@@ -76,7 +76,7 @@ Section Public
"Reboot ...\n".print;
die_with_code exit_failure_code;
};
-
+
tmp:=(p_end+1)&003h;
buffer_event.item p_end.make ((cmd.to_uinteger_16<<8)|cu);
(((tmp+2)&3)!=p_beg).if {
@@ -86,30 +86,30 @@ Section Public
};
};
);
-
+
Section Private
-
+
- send_cmd (comm,dta:UINTEGER_8) <-
- // Send a command to keyboard
+ // Send a command to keyboard
(
// Empty buffer
{ ((SYSTEM.itemb 64h) & 2) != 0}.while_do {
- SYSTEM.itemb 60h;
- };
+ SYSTEM.itemb 60h;
+ };
// Send command
- SYSTEM.putb comm to 60h;
+ SYSTEM.putb comm to 60h;
// Waiting for answer
- { ((SYSTEM.itemb 64h) & 1) == 0}.while_do {};
+ { ((SYSTEM.itemb 64h) & 1) == 0}.while_do {};
// Read answer
- SYSTEM.itemb 60h;
+ SYSTEM.itemb 60h;
// Send data
- SYSTEM.putb dta to 60h;
+ SYSTEM.putb dta to 60h;
// Waiting for answer
- { ((SYSTEM.itemb 64h) & 1) == 0}.while_do {};
+ { ((SYSTEM.itemb 64h) & 1) == 0}.while_do {};
// Read answer
- SYSTEM.itemb 60h;
+ SYSTEM.itemb 60h;
);
-
+
- light <-
(
send_cmd (0EDh,(((cmd & 80h)>>7)|((cmd & 40h)>>5)|((cmd & 20h)>>3)));
@@ -117,7 +117,7 @@ Section Private
- keyup cu:UINTEGER_8 :UINTEGER_8 <-
( + result:UINTEGER_8;
- cmd := cmd & 0F7h; // Deactivate the cmd bit
+ cmd := cmd & 0F7h; // Deactivate the cmd bit
bin_code.put ((bin_code.item (cu>>3)) & ~(1<<(cu&7))) to (cu>>3);
// Analyze: for deactivate the cmd
((cu == 28) || {cu == 89}).if {
@@ -128,9 +128,9 @@ Section Private
cmd := cmd & (~02h);
}.elseif { cu == 55 } then {
// Alt
- cmd := cmd & (~04h);
+ cmd := cmd & (~04h);
result := ascii_code;
- ascii_code := 0;
+ ascii_code := 0;
}.elseif { (cu == 41) || { cu == 53} } then {
// Shift 1 or Shift 2
cmd := cmd & (~10h);
@@ -150,7 +150,7 @@ Section Private
cmd := cmd | 02h;
}.elseif { cu == 55 } then {
// Alt
- cmd := cmd | 04h;
+ cmd := cmd | 04h;
}.elseif { (cu == 41) || { cu == 53} } then {
// Shift 1 or Shift 2
cmd := cmd | 10h;
@@ -189,7 +189,7 @@ Section Private
} else {
cmd := cmd | 08h;
result := cmm.item (cu2+1).to_uinteger_8;
- };
+ };
};
}.elseif {cu <= 67} then {
cmd := cmd | 08h; // F1 to F10 = cmd
@@ -221,11 +221,11 @@ Section Private
result := '/'.to_uinteger_8;
} else {
cmd := cmd | 08h;
- result := buf_extk.item (cu-90).to_uinteger_8;
+ result := buf_extk.item (cu-90).to_uinteger_8;
};
result
);
-
+
- getcode cu:UINTEGER_8 :UINTEGER_8 <-
// Translate Scan Code -> cmd.ASCII
( + j:INTEGER;
@@ -264,8 +264,8 @@ Section Private
};
result
);
-
-
+
+
diff --git a/lib/internal/os_support/dos/video/mouse.li b/lib/internal/os_support/dos/video/mouse.li
index a333ee3..10c6d01 100644
--- a/lib/internal/os_support/dos/video/mouse.li
+++ b/lib/internal/os_support/dos/video/mouse.li
@@ -23,77 +23,77 @@ Section Header
+ name := MOUSE;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:="http://IsaacOS.com";
- author :="Sonntag Benoit (bsonntag at loria.fr)";
- comment :="Mouse for DOS.";
-
+
- external := `union REGS __in_mouse;`;
-
+
Section Inherit
+ parent_input:Expanded INPUT;
-
+
+ parent_window:Expanded AREA;
-
+
Section Public
- set (x,y:INTEGER) with (left_new,right_new:BOOLEAN) <-
( + tmp:UINTEGER_8;
+ x_new, y_new:INTEGER;
-
+
y_new := y.max y_minimum.min y_maximum;
x_new := x.max x_minimum.min x_maximum;
-
+
tmp:=(p_end+1)&003h;
buffer_event.item p_end.make (x_new,y_new) button (left_new,right_new);
(((tmp+2)&3)!=p_beg).if {
p_end:=tmp;
};
-
+
get_event;
-
+
// Update status.
x_current:=x_new;
y_current:=y_new;
right:=right_new;
- left :=left_new;
+ left :=left_new;
);
-
+
Section Public
-
+
+ x_minimum:INTEGER;
+ x_maximum:INTEGER;
-
+
+ y_minimum:INTEGER;
+ y_maximum:INTEGER;
-
+
+ x_current:INTEGER;
- + y_current:INTEGER;
-
+ + y_current:INTEGER;
+
+ right:BOOLEAN;
+ left:BOOLEAN;
-
+
Section Private
-
+
+ buffer_event:MAP_FAST_ARRAY(EVENT_MOUSE);
- p_beg:UINTEGER_8; // Pointer on the buffer (beginning)
- p_end:UINTEGER_8; // Pointer on the buffer (end)
-
+
Section Public
-
+
//
// Creation / Initialisation.
//
-
+
- make <-
(
//
// Mouse hardware configuration.
//
//display_on;
-
+
x_maximum := VIDEO.x_max;
y_maximum := VIDEO.y_max;
@@ -104,38 +104,38 @@ Section Public
0.to 3 do { j:INTEGER;
buffer_event.item j.set_prev (buffer_event.item ((j-1)&3));
};
-
+
mask := FAST_ARRAY(UINTEGER_16).create 16;
make (INTERFACE.screen) from (x_current,y_current) size (16,16);
);
-
+
- get_event <-
( + p:INTEGER;
+ evt:EVENT_MOUSE;
-
+
p := p_beg;
{ p != p_end }.while_do {
evt := buffer_event.item p;
(list_client.lower).to (list_client.upper) do { j:INTEGER;
list_client.item j.receive (buffer_event.item p);
- };
+ };
p := (p + 1) & 03h;
- };
+ };
);
-
+
- acknowledge <-
(
p_beg := (p_beg+1) & 03h;
);
-
+
- display_on <- `__in_mouse.w.ax=0x01; int386(0x33,&__in_mouse,&__in_mouse)`;
- display_off <- `__in_mouse.w.ax=0x02; int386(0x33,&__in_mouse,&__in_mouse)`;
-
+
- get_new_event <-
( + b,x,y:INTEGER;
+ new_r,new_l,is_move:BOOLEAN;
-
+
`__in_mouse.w.ax=0x03; int386(0x33,&__in_mouse,&__in_mouse)`;
b:=`__in_mouse.w.bx`:INTEGER;
x:=`__in_mouse.w.cx`:INTEGER / 2;
@@ -151,14 +151,14 @@ Section Public
set (x,y) with (new_l,new_r);
};
);
-
+
//
// Display.
//
-
+
// BSBS: A refaire avec une bitmap en dehors contenant le dessin avec une couleur de mask!!
- // Plus simple, plus puissant, plus rapide !
-
+ // Plus simple, plus puissant, plus rapide !
+
+ mask:FAST_ARRAY(UINTEGER_16);
- pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
@@ -172,42 +172,42 @@ Section Public
parent_window.pixel_hard (x,y) color col;
);
-
+
- line_h_hard (x0,y0:INTEGER) until x1:INTEGER color col:UINTEGER_32 <-
( + m:UINTEGER_16;
? {x0<16};
? {y0<16};
? {x1<16};
-
+
m:=mask.item y0;
x0.to x1 do { xx:INTEGER;
m:=m | (1<<xx);
};
-
+
mask.put m to y0;
parent_window.line_h_hard (x0,y0) until x1 color col;
);
- - slave_pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
+ - slave_pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
( + m:UINTEGER_16;
-
+
m:=mask.item y;
((m & (1<<x))=0).if {
parent_window.pixel_hard (x,y) color col;
};
);
-
- - slave_line_h_hard (x1,y:INTEGER) until x2:INTEGER color col:UINTEGER_32 <-
+
+ - slave_line_h_hard (x1,y:INTEGER) until x2:INTEGER color col:UINTEGER_32 <-
( + m:UINTEGER_16;
-
+
m:=mask.item y;
x1.to x2 do { xx:INTEGER;
((m & (1<<xx))=0).if {
parent_window.pixel_hard (xx,y) color col;
};
};
- );
-
+ );
+
- slave_line_h_hard (x1,y:INTEGER) until x2:INTEGER image line:BMP_LINE offset ofs:INTEGER <-
( + m:UINTEGER_16;
+ col:UINTEGER_32;
@@ -216,17 +216,17 @@ Section Public
m:=mask.item y;
x1.to x2 do { xx:INTEGER;
((m & (1<<xx))=0).if {
- col := line.get_color ofs_img;
+ col := line.get_color ofs_img;
parent_window.pixel_hard (xx,y) color col;
- };
+ };
ofs_img := ofs_img + 1;
};
);
-
+
- draw (x0,y0:INTEGER) to (x1,y1:INTEGER) <-
(
clipping (x0,y0) to (x1,y1);
-
+
color white;
poly_move_to (1,1);
poly_line_to (9,9);
@@ -234,10 +234,10 @@ Section Public
poly_line_to (8,14);
poly_line_to (5,14);
poly_line_to (5,9);
- poly_line_to (1,9);
- poly_move_to (1,1);
+ poly_line_to (1,9);
+ poly_move_to (1,1);
poly_trace;
-
+
color red;
line_v (0,0) until 10;
line_h (1,10) until 4;
@@ -247,12 +247,11 @@ Section Public
line_h (7,10) until 10;
line (1,0) to (10,9);
);
-
+
- get_object (x,y:INTEGER) :AREA <-
(
NULL
);
-
-
-
-
\ No newline at end of file
+
+
+
diff --git a/lib/internal/os_support/dos/video/pixel_8.li b/lib/internal/os_support/dos/video/pixel_8.li
index 4082c09..a671974 100644
--- a/lib/internal/os_support/dos/video/pixel_8.li
+++ b/lib/internal/os_support/dos/video/pixel_8.li
@@ -19,44 +19,44 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PIXEL_8;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Pixel 8 bits (RR-VVV-BBB)";
-
+
- bibliography:= "http://IsaacOS.com";
-
+
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
-
+
Section Inherit
-
+
- parent_pixel:PIXEL := PIXEL;
-
+
Section Mapping
-
+
+ real_color:UINTEGER_8;
-
+
Section Public
-
+
- red:UINTEGER_8 <- real_color & 11000000b;
-
+
- green:UINTEGER_8 <- (real_color & 00111000b) << 2;
-
+
- blue:UINTEGER_8 <- real_color << 5;
-
+
- color col:UINTEGER_32 <-
(
real_color := (((col >> 16).to_uinteger_8) &11000000b) | ((((col & 00FF00h) >> 10).to_uinteger_8)&00111000b) | (((col & 0000FFh).to_uinteger_8) >>5);
);
-
+
- color_rgb (r,g,b:UINTEGER_8) <-
(
real_color := (r &11000000b) | (g&00111000b) | (b >>5);
);
-
- - size:UINTEGER_8 := 8;
+
+ - size:UINTEGER_8 := 8;
- red_size:UINTEGER_8 := 2;
- red_pos:UINTEGER_8 := 6;
- green_size:UINTEGER_8 := 3;
@@ -65,14 +65,14 @@ Section Public
- blue_pos:UINTEGER_8 := 0;
- reserved_size:UINTEGER_8 :=0;
- reserved_pos:UINTEGER_8 :=0;
-
- - copy other:SELF <-
+
+ - copy other:SELF <-
(
real_color := other.real_color;
);
-
+
- to_pixel_8:PIXEL_8 <- Self;
-
+
diff --git a/lib/internal/os_support/dos/video/video.li b/lib/internal/os_support/dos/video/video.li
index a6d344c..13ad3e8 100644
--- a/lib/internal/os_support/dos/video/video.li
+++ b/lib/internal/os_support/dos/video/video.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := VIDEO;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Driver video - For DOS -";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
-
- - external :=
+
+ - external :=
`
-#include <stdio.h>
+#include <stdio.h>
#include <dos.h>
#include <dpmi.h>
#include <pc.h>
@@ -40,7 +40,7 @@ Section Header
unsigned short __desc_video;
void __init_video_320x200()
{ union REGS in;
-
+
__desc_video=__dpmi_allocate_ldt_descriptors(1);
__djgpp_map_physical_memory((void *)0xA0000, 64000,0xA0000);
__dpmi_set_segment_base_address(__desc_video,0xA0000);
@@ -51,47 +51,47 @@ void __init_video_320x200()
};
void __init_video_text()
{ union REGS in;
-
+
in.w.ax=0x03;
int86(0x10,&in,&in);
};
`;
-
-
+
+
Section Inherit
-
+
+ parent_bitmap:Expanded BITMAP;
-
+
Section Public
-
+
- message str:ABSTRACT_STRING <-
(
str.print;
);
-
+
- is_active:BOOLEAN;
- make (w,h:INTEGER) <-
- (
+ (
? {w = 320};
? {h = 200};
-
+
// Init BITMAP:
width := w;
height := h;
-
+
//
// Init mode 320x200.
//
`__init_video_320x200()`;
-
+
//
// Init palette.
//
SYSTEM.putb 0 to 3C8h;
0.to 255 do { j:INTEGER;
+ r,g,b,c:UINTEGER_8;
-
+
c:=j.to_uinteger_8;
r:=(c&11000000b)>>2;
g:=(c&00111000b);
@@ -106,7 +106,7 @@ Section Public
- pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
( + col8:UINTEGER_8;
+ ofs:INTEGER;
- col8 :=
+ col8 :=
(((col >> 16).to_uinteger_8) & 11000000b) | // Red
(((col >> 10).to_uinteger_8) & 00111000b) | // Green
(((col >> 5).to_uinteger_8) & 00000111b); // Blue
@@ -115,7 +115,7 @@ Section Public
`_farpokeb(__desc_video, at ofs, at col8)`;
//MOUSE.display_on;
);
-
+
- line_h_hard (x,y:INTEGER) until x1:INTEGER color col:UINTEGER_32 <-
( + col8:UINTEGER_8;
+ ofs:INTEGER;
@@ -140,7 +140,7 @@ Section Public
col8 := (((col >> 16).to_uinteger_8) &11000000b) | ((((col & 00FF00h) >> 10).to_uinteger_8)&00111000b) | (((col & 0000FFh).to_uinteger_8) >>5);
`_farpokeb(__desc_video, at j, at col8)`;
ofs_img2:=ofs_img2+1;
- };
+ };
//MOUSE.display_on;
);
diff --git a/lib/internal/os_support/unix/file_system/directory_unix.li b/lib/internal/os_support/unix/file_system/directory_unix.li
index 7ef87ae..c30be62 100644
--- a/lib/internal/os_support/unix/file_system/directory_unix.li
+++ b/lib/internal/os_support/unix/file_system/directory_unix.li
@@ -19,72 +19,72 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=DIRECTORY_UNIX;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:="http://IsaacOS.com";
-
+
- author :="Benoit Sonntag (bsonntag at loria.fr)";
-
+
- comment :="Directory management";
-
- - external :=
+
+ - external :=
`
#include <dirent.h>
#include <sys/stat.h>
#include <sys/types.h>
`;
-
+
Section Inherit
-
+
+ parent_entry_unix:Expanded ENTRY_UNIX;
-
+
+ parent_directory:Expanded DIRECTORY;
-
+
Section Public
-
+
- is_open:BOOLEAN <- ( list != NULL);
-
+
//
// Scanning
//
-
+
- open:BOOLEAN <-
( + p,n:NATIVE_ARRAY(CHARACTER);
+ dir,dirent:POINTER;
+ new_entry:ENTRY;
+ result:BOOLEAN;
+ i:INTEGER;
-
+
(list = NULL).if {
list := LINKED_LIST(ENTRY).create;
} else {
list.clear;
};
-
+
p := path.to_external;
- dir := `opendir(@p)`:POINTER;
+ dir := `opendir(@p)`:POINTER;
(dir != NULL).if {
- result := TRUE;
+ result := TRUE;
{
dirent := `readdir(@dir)`:POINTER;
(dirent != NULL).if {
- n := `((struct dirent *)@dirent)->d_name`:NATIVE_ARRAY(CHARACTER);
+ n := `((struct dirent *)@dirent)->d_name`:NATIVE_ARRAY(CHARACTER);
string_tmp.clear;
i := 0;
- {n.item i = '\0'}.until_do {
+ {n.item i = '\0'}.until_do {
string_tmp.add_last (n.item i);
i := i + 1;
};
(string_tmp !== ".".to_string).if {
string_tmp.add_first '/';
- string_tmp.prepend path;
- reduce_path string_tmp;
- new_entry := get_entry string_tmp;
- (new_entry = NULL).if {
- "WARNING: ".print; string_tmp.print; " no readable!\n".print;
+ string_tmp.prepend path;
+ reduce_path string_tmp;
+ new_entry := get_entry string_tmp;
+ (new_entry = NULL).if {
+ "WARNING: ".print; string_tmp.print; " no readable!\n".print;
//result := FALSE;
} else {
(new_entry.path.count >= path.count).if {
@@ -98,41 +98,41 @@ Section Public
};
result
);
-
+
Section DIRECTORY
-
+
- physical_get_entry new_path:ABSTRACT_STRING :ENTRY <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ result:ENTRY;
-
+
pe := new_path.to_external;
// #ifdef __MINGW_H ( voir sous winmerde )
`#ifndef __USE_LARGEFILE64
`;
- `{ struct stat t`;
- (`stat(@pe,&t)`:INTEGER = 0).if {
+ `{ struct stat t`;
+ (`stat(@pe,&t)`:INTEGER = 0).if {
(`S_ISDIR(t.st_mode)`:INTEGER = 0).if {
// File.
result := FILE_UNIX.clone;
} else {
// Directory.
result := DIRECTORY_UNIX.clone;
- };
+ };
result.set_path new_path;
alias.put result to (result.path); // with { (e1,e2:ABSTRACT_STRING); e1 ~=e2 };
};
`}`;
`#else
`;
- `{ struct stat64 t`;
- (`stat64(@pe,&t)`:INTEGER = 0).if {
+ `{ struct stat64 t`;
+ (`stat64(@pe,&t)`:INTEGER = 0).if {
(`S_ISDIR(t.st_mode)`:INTEGER = 0).if {
// File.
result := FILE_UNIX.clone;
} else {
// Directory.
result := DIRECTORY_UNIX.clone;
- };
+ };
result.set_path new_path;
alias.put result to (result.path); //with { (e1,e2:ABSTRACT_STRING); e1 ~=e2 };
};
@@ -141,7 +141,7 @@ Section DIRECTORY
`;
result
);
-
+
- physical_make_directory new_path:ABSTRACT_STRING :BOOLEAN <-
( + pa:NATIVE_ARRAY(CHARACTER);
pa := new_path.to_external;
@@ -152,7 +152,7 @@ Section DIRECTORY
( + pa:NATIVE_ARRAY(CHARACTER);
+ stream:POINTER;
+ result:BOOLEAN;
-
+
pa := new_path.to_external;
stream := `fopen((char*)@pa,"w+b")`:POINTER;
(stream != NULL).if {
@@ -166,7 +166,7 @@ Section DIRECTORY
pa := p.to_external;
`remove(@pa)`:(INTEGER) = 0
);
-
+
- physical_move old_path:ABSTRACT_STRING to new_path:ABSTRACT_STRING :BOOLEAN <-
( + old_p,new_p:NATIVE_ARRAY(CHARACTER);
old_p := old_path.to_external;
diff --git a/lib/internal/os_support/unix/file_system/entry_unix.li b/lib/internal/os_support/unix/file_system/entry_unix.li
index f89d4b3..55c8a10 100644
--- a/lib/internal/os_support/unix/file_system/entry_unix.li
+++ b/lib/internal/os_support/unix/file_system/entry_unix.li
@@ -19,116 +19,116 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ENTRY_UNIX;
- copyright := "2003-2008 Benoit Sonntag";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
- comment := "Entry ANSI C";
-
+
Section Inherit
-
+
+ parent_entry:Expanded ENTRY;
-
-Section Public
-
- - access:UINTEGER_16 <-
+
+Section Public
+
+ - access:UINTEGER_16 <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ result:UINTEGER_16;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
+ `{ struct stat t; stat(@pe,&t)`;
result := `t.st_mode`:UINTEGER_16 & 111_111_111b;
`}`;
result
);
-
- - access_time:TIME <-
+
+ - access_time:TIME <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:TIME;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_atime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_atime))`:POINTER;
result := to_time tt;
`}`;
result
);
-
- - access_date:DATE <-
+
+ - access_date:DATE <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:DATE;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_atime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_atime))`:POINTER;
result := to_date tt;
`}`;
result
);
-
- - update_time:TIME <-
+
+ - update_time:TIME <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:TIME;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_mtime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_mtime))`:POINTER;
result := to_time tt;
`}`;
result
);
-
- - update_date:DATE <-
+
+ - update_date:DATE <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:DATE;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_mtime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_mtime))`:POINTER;
result := to_date tt;
`}`;
result
);
-
+
- create_time:TIME <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:TIME;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_ctime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_ctime))`:POINTER;
result := to_time tt;
`}`;
result
);
-
+
- create_date:DATE <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:DATE;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_ctime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_ctime))`:POINTER;
result := to_date tt;
`}`;
result
);
-
-Section Private
-
+
+Section Private
+
//
// Time / Date: Unix -> Lisaac
//
-
+
- to_date t:POINTER :DATE <-
( + result:DATE;
+ wd,md,m:UINTEGER_8;
+ y:UINTEGER_16;
-
+
y := `((struct tm *)@t)->tm_year`:UINTEGER_16 + 1900;
m := `((struct tm *)@t)->tm_mon` :UINTEGER_8 + 1;
md := `((struct tm *)@t)->tm_mday`:UINTEGER_8;
@@ -136,15 +136,15 @@ Section Private
(! wd.in_range 1 to 7).if { // Bug in UNIX ?
wd := 1;
};
- result := DATE.create (y,m,md,wd)
+ result := DATE.create (y,m,md,wd)
);
- to_time t:POINTER :TIME <-
(
- TIME.create
+ TIME.create
((`((struct tm *)@t)->tm_hour`:UINTEGER_8),
(`((struct tm *)@t)->tm_min` :UINTEGER_8),
(`((struct tm *)@t)->tm_sec` :UINTEGER_8),
0)
);
-
+
diff --git a/lib/internal/os_support/unix/file_system/file_system.li b/lib/internal/os_support/unix/file_system/file_system.li
index b92fd70..7a41d96 100644
--- a/lib/internal/os_support/unix/file_system/file_system.li
+++ b/lib/internal/os_support/unix/file_system/file_system.li
@@ -19,32 +19,32 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=FILE_SYSTEM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment :="File System manager for Unix.";
-
+
- external := `#include <unistd.h>`; // For `getcwd'
-
-Section Inherit
-
+
+Section Inherit
+
+ parent_directory:DIRECTORY <-
- ( + cwd:NATIVE_ARRAY(CHARACTER);
+ ( + cwd:NATIVE_ARRAY(CHARACTER);
+ result:DIRECTORY;
-
+
DIRECTORY.string_tmp.clear;
cwd := DIRECTORY.string_tmp.to_external;
`getcwd(@cwd,255)`;
DIRECTORY.string_tmp.from_external cwd;
-
+
result ?= DIRECTORY_UNIX.physical_get_entry (DIRECTORY.string_tmp);
DIRECTORY.alias.put result to (result.path);
? {result != NULL};
parent_directory := result
);
-
-
+
+
diff --git a/lib/internal/os_support/unix/file_system/file_unix.li b/lib/internal/os_support/unix/file_system/file_unix.li
index 6ebe4d8..d6968f6 100644
--- a/lib/internal/os_support/unix/file_system/file_unix.li
+++ b/lib/internal/os_support/unix/file_system/file_unix.li
@@ -19,102 +19,102 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FILE_UNIX;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "File management";
-
+
Section Inherit
-
+
+ parent_entry_unix:Expanded ENTRY_UNIX;
-
+
+ parent_file:Expanded FILE;
-
-Section Private
-
+
+Section Private
+
+ stream:POINTER; // Unix file pointer (FILE *).
Section Public
-
+
//
// Physical implementation.
//
-
+
- is_open:BOOLEAN <- stream != NULL;
-
+
- size:UINTEGER_32 <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ result:UINTEGER_32;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
+ `{ struct stat t; stat(@pe,&t)`;
result := `t.st_size`:UINTEGER_32;
`}`;
result
);
-
+
- cursor:UINTEGER_32 <-
- ( + str:POINTER;
- str := stream;
+ ( + str:POINTER;
+ str := stream;
`ftell((FILE *)@str)`:UINTEGER_32
);
-
+
- set_cursor n:UINTEGER_32 <-
[
...
-? {stream != NULL};
-? {n <= size};
]
- ( + str:POINTER;
- str := stream;
+ ( + str:POINTER;
+ str := stream;
`fseek((FILE*)(@str), at n,SEEK_SET)`;
- );
-
+ );
+
- open:BOOLEAN <-
[
-? {stream = NULL};
]
- ( + pa:NATIVE_ARRAY(CHARACTER);
-
+ ( + pa:NATIVE_ARRAY(CHARACTER);
+
pa := path.to_external;
- stream := `fopen((char*)@pa,"r+b")`:(POINTER);
+ stream := `fopen((char*)@pa,"r+b")`:(POINTER);
stream != NULL
- );
+ );
- open_read_only:BOOLEAN <-
- ( + pa:NATIVE_ARRAY(CHARACTER);
+ ( + pa:NATIVE_ARRAY(CHARACTER);
pa := path.to_external;
- stream := `fopen((char*)@path_pointer,"rb")`:(POINTER);
+ stream := `fopen((char*)@path_pointer,"rb")`:(POINTER);
stream != NULL
- );
-
+ );
+
- close <-
[
-? {stream != NULL};
]
( + str:POINTER;
-
- str := stream;
- `fclose((FILE*)(@str))`;
+
+ str := stream;
+ `fclose((FILE*)(@str))`;
stream := NULL;
);
-
-Section FILE
-
+
+Section FILE
+
- physical_read buf:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :INTEGER <-
// return size read or 0 if end of input (-1 on error => exception ?)
- ( + str:POINTER;
- str := stream;
+ ( + str:POINTER;
+ str := stream;
`fread((void *)(@buf),(size_t)(1), (size_t)(@s),(FILE*)(@str))`:(INTEGER)
);
-
+
- physical_write buf:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :INTEGER <-
// return size read or 0 if end of input (-1 on error => exception ?)
( + str:POINTER;
- str := stream;
+ str := stream;
`fwrite((void *)(@buf),(size_t)(1), (size_t)(@s),(FILE*)(@str))`:(INTEGER)
);
-
-
+
+
diff --git a/lib/internal/os_support/unix/system/clock.li b/lib/internal/os_support/unix/system/clock.li
index da3cb05..4407bce 100644
--- a/lib/internal/os_support/unix/system/clock.li
+++ b/lib/internal/os_support/unix/system/clock.li
@@ -23,7 +23,7 @@ Section Header
+ name := CLOCK;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:="http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
@@ -31,45 +31,45 @@ Section Header
- comment :="X11 - Clock management.";
- date :="2003/04";
-
+
- external := `#include <time.h>`;
-
-Section Inherit
-
+
+Section Inherit
+
- parent_input:INPUT := INPUT;
-
-Section Public
-
+
+Section Public
+
- date:DATE <-
- ( + wd,d,mo:UINTEGER_8;
+ ( + wd,d,mo:UINTEGER_8;
+ y:UINTEGER_16;
-
- `{
+
+ `{
struct tm *t; time_t tt;
tt = time(NULL);
- t = localtime(&tt)`;
+ t = localtime(&tt)`;
wd := `t->tm_wday`:UINTEGER_8 + 1;
d := `t->tm_mday`:UINTEGER_8;
mo := `t->tm_mon` :UINTEGER_8 + 1;
- y := `t->tm_year`:UINTEGER_16 + 1900;
+ y := `t->tm_year`:UINTEGER_16 + 1900;
`}`;
DATE.create (y,mo,d,wd)
);
-
+
- time:TIME <-
( + s,m,h:UINTEGER_8;
-
- `{
+
+ `{
struct tm *t; time_t tt;
tt = time(NULL);
- t = localtime(&tt)`;
+ t = localtime(&tt)`;
h := `t->tm_hour`:UINTEGER_8;
m := `t->tm_min` :UINTEGER_8;
- s := `t->tm_sec` :UINTEGER_8;
- `}`;
+ s := `t->tm_sec` :UINTEGER_8;
+ `}`;
TIME.create (h,m,s,0)
);
-
+
- make <-
(
// Nothing.
diff --git a/lib/internal/os_support/unix/system/environment.li b/lib/internal/os_support/unix/system/environment.li
index 4e25a04..a2c955e 100644
--- a/lib/internal/os_support/unix/system/environment.li
+++ b/lib/internal/os_support/unix/system/environment.li
@@ -19,11 +19,11 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ENVIRONMENT;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Execute system command and to get/set environment variables.";
Section Public
@@ -38,7 +38,7 @@ Section Public
+ result:STRING;
+ p:NATIVE_ARRAY(CHARACTER);
? { variable != NULL };
-
+
p := basic_getenv(variable.to_external);
(p != NULL).if {
result := STRING.clone;
@@ -54,7 +54,7 @@ Section Public
? { value != NULL };
basic_putenv (variable,value);
);
-
+
- execute_command system_command_line:ABSTRACT_STRING :INTEGER <-
// To execute a `system_command_line' as for example, "ls -l" on UNIX.
// The `Result' depends of the actual operating system. As an exemple,
@@ -69,7 +69,7 @@ Section Public
(
execute_command (system_command_line);
);
-
+
Section Private
- basic_getenv environment_variable:NATIVE_ARRAY(CHARACTER) :NATIVE_ARRAY(CHARACTER) <-
@@ -77,12 +77,12 @@ Section Private
(
`getenv((char*)@environment_variable)`:NATIVE_ARRAY(CHARACTER)
);
-
+
- basic_putenv (variable,value:ABSTRACT_STRING) <-
// To implement `set_environment_variable'.
(
+ v:NATIVE_ARRAY(CHARACTER);
-
+
v := NATIVE_ARRAY(CHARACTER).calloc (variable.count + value.count + 2);
v.copy_from (variable.to_external) until (variable.upper);
v.put '=' to (variable.count);
@@ -90,7 +90,7 @@ Section Private
v.put '\0' to (variable.count + 1 + value.count);
`putenv((char*)@v)`;
);
-
+
- basic_system_execute_command system_command_line:NATIVE_ARRAY(CHARACTER) :INTEGER <-
(
`system(((char*)(@system_command_line)))`:(INTEGER)
diff --git a/lib/internal/os_support/unix/system/float_processor.li b/lib/internal/os_support/unix/system/float_processor.li
index 1a5a13f..afa16fd 100644
--- a/lib/internal/os_support/unix/system/float_processor.li
+++ b/lib/internal/os_support/unix/system/float_processor.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FLOAT_PROCESSOR;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,14 +32,14 @@ Section Inherit
- parent_object:OBJECT := OBJECT;
Section Public
-
+
- init; // Compatibility IsaacOS.
-
- - atan n:REAL :REAL <- `atanf(@n)`:REAL;
- - atan_32 n:REAL_32 :REAL_32 <- `atanf(@n)`:REAL_32;
+
+ - atan n:REAL :REAL <- `atanf(@n)`:REAL;
+ - atan_32 n:REAL_32 :REAL_32 <- `atanf(@n)`:REAL_32;
- atan_64 n:REAL_64 :REAL_64 <- `atan(@n)`:REAL_64;
- atan_80 n:REAL_80 :REAL_80 <- `atanl(@n)`:REAL_80;
-
+
- sqrt n:REAL :REAL <- `sqrtf(@n)`:REAL;
- sqrt_32 n:REAL_32 :REAL_32 <- `sqrtf(@n)`:REAL_32;
- sqrt_64 n:REAL_64 :REAL_64 <- `sqrt(@n)`:REAL_64;
@@ -65,4 +65,3 @@ Section Public
- pow_64 (n,exp:REAL_64) :REAL_64 <- `pow(@n, at exp)`:REAL_64;
- pow_80 (n,exp:REAL_80) :REAL_80 <- `powl(@n, at exp)`:REAL_80;
-
\ No newline at end of file
diff --git a/lib/internal/os_support/unix/system/processor.li b/lib/internal/os_support/unix/system/processor.li
index dea8594..57ceff1 100644
--- a/lib/internal/os_support/unix/system/processor.li
+++ b/lib/internal/os_support/unix/system/processor.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PROCESSOR;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Processor object.";
Section Public
-
+
- to_intel_ulong v:UINTEGER_64 :UINTEGER_64 <- deferred;
-
+
- to_intel_uint v:UINTEGER_32 :UINTEGER_32 <- deferred;
-
+
- to_intel_ushort v:UINTEGER_16 :UINTEGER_16 <- deferred;
-
+
- to_motorola_ulong v:UINTEGER_64 :UINTEGER_64 <-
- (
+ (
(v << 56) | ((v & 0FF00h) << 40) | ((v & 0FF0000h) << 24) | ((v & 0FF000000h) << 8) |
(v >> 56) | ((v >> 40) & 0FF00h) | ((v >> 24) & 0FF0000h) | ((v >> 8) & 0FF000000h)
);
-
+
- to_motorola_uint v:UINTEGER_32 :UINTEGER_32 <-
(
- (v << 24) | ((v & 0FF00h) << 8) | ((v >> 8) & 0FF00h) | (v >> 24)
+ (v << 24) | ((v & 0FF00h) << 8) | ((v >> 8) & 0FF00h) | (v >> 24)
);
-
+
- to_motorola_int v:INTEGER :INTEGER <-
(
// Conversion in uxxx to cut the sign
- (v << 24) | (((v & 0FF00h) << 8).to_uinteger_16) | (((v >> 8) & 0FF00h).to_uinteger_16) | ((v >> 24).to_uinteger_8)
+ (v << 24) | (((v & 0FF00h) << 8).to_uinteger_16) | (((v >> 8) & 0FF00h).to_uinteger_16) | ((v >> 24).to_uinteger_8)
);
-
+
- to_motorola_ushort v:UINTEGER_16 :UINTEGER_16 <-
(
(v << 8) | (v >> 8)
diff --git a/lib/internal/os_support/unix/system/system.li b/lib/internal/os_support/unix/system/system.li
index 0af6ad4..4515e7c 100644
--- a/lib/internal/os_support/unix/system/system.li
+++ b/lib/internal/os_support/unix/system/system.li
@@ -19,58 +19,58 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SYSTEM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Generic System Object (methods).";
- external := `#include <time.h>`;
Section Public
-
+
- get_current_date:DATE <-
- ( + wd,d,mo:UINTEGER_8;
+ ( + wd,d,mo:UINTEGER_8;
+ y:UINTEGER_16;
-
- `{
+
+ `{
struct tm *t; time_t tt;
tt = time(NULL);
- t = localtime(&tt)`;
+ t = localtime(&tt)`;
wd := `t->tm_wday`:UINTEGER_8 + 1;
d := `t->tm_mday`:UINTEGER_8;
mo := `t->tm_mon` :UINTEGER_8 + 1;
- y := `t->tm_year`:UINTEGER_16 + 1900;
+ y := `t->tm_year`:UINTEGER_16 + 1900;
`}`;
DATE.create (y,mo,d,wd)
);
-
+
- get_current_time:TIME <-
( + s,m,h:UINTEGER_8;
-
- `{
+
+ `{
struct tm *t; time_t tt;
tt = time(NULL);
- t = localtime(&tt)`;
+ t = localtime(&tt)`;
h := `t->tm_hour`:UINTEGER_8;
m := `t->tm_min` :UINTEGER_8;
- s := `t->tm_sec` :UINTEGER_8;
- `}`;
+ s := `t->tm_sec` :UINTEGER_8;
+ `}`;
TIME.create (h,m,s,0)
);
//
//
//
-
+
- is_ansi:BOOLEAN := TRUE;
-
+
- exit code:INTEGER <- `exit(@code)`;
-
+
- putb value:UINTEGER_8 to port:UINTEGER_16 <-
// Write in port
- (
+ (
`{ unsigned short val;
val = @value;
asm
@@ -78,7 +78,7 @@ Section Public
"movw %0,%%dx \n\
movw %1,%%ax \n\
outb %%al,%%dx "
- : /* No output */
+ : /* No output */
:"r"(@port), "r"(val)
:"%ax","%dx"
);
@@ -102,26 +102,26 @@ Section Public
`}`;
result
);
-
+
- get_universal_time:UINTEGER_64 <-
(
`(unsigned long long)time(NULL)`:UINTEGER_64
);
// Memory Management
-
+
- memory:MEMORY := MEMORY;
-
+
- get_begin_memory:POINTER;
-
- - get_memory_capacity:UINTEGER_CPU <-
+
+ - get_memory_capacity:UINTEGER_CPU <-
( + cap:UINTEGER_CPU;
+ mem,new_mem:POINTER;
cap := 32.mb;
{
cap := cap * 2;
mem := new_mem;
- new_mem := `realloc(@mem, at cap)`:POINTER;
+ new_mem := `realloc(@mem, at cap)`:POINTER;
}.do_until {(new_mem = NULL) || {(cap >> 20) = 2048}}; // BSBS: BUG COMPILO 0.13
(new_mem = NULL).if {
cap := cap / 2;
@@ -131,10 +131,10 @@ Section Public
get_begin_memory := mem;
//
cap
- );
-
+ );
+
Section SYSTEM,MEMORY
-
+
- realloc_c (beg:UINTEGER_32,nb:INTEGER) :UINTEGER_32 <-
( + result:UINTEGER_32;
result := `(unsigned long)realloc((void *)@beg, at nb+15)`:UINTEGER_32;
@@ -149,9 +149,9 @@ Section SYSTEM,MEMORY
? {result != 0};
result
);
-
-Section ISAAC
-
+
+Section ISAAC
+
- make <-
// Isaac compatibility.
(
diff --git a/lib/internal/os_support/unix/system/system_io.li b/lib/internal/os_support/unix/system/system_io.li
index 153aa23..3ee4020 100644
--- a/lib/internal/os_support/unix/system/system_io.li
+++ b/lib/internal/os_support/unix/system/system_io.li
@@ -19,17 +19,17 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SYSTEM_IO;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment := "Lower level for Input / Output";
-
+
- external := `
#include <stdio.h>
#include <stdlib.h>
-
+
/* Hardware 'print_char' */
void print_char(char car)
{
@@ -45,7 +45,7 @@ int die_with_code(int code)
`;
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
Section Public
@@ -55,14 +55,13 @@ Section Public
(
`fputc((int)@byte,stdout)`;
);
-
+
- print_error_char byte:CHARACTER <-
// Low level buffered error output.
(
`fputc((int)@byte,stderr)`;
- );
-
+ );
+
- get_char :CHARACTER <- `fgetc(stdin)`:(CHARACTER);
-
+
- eof:CHARACTER <- `EOF`:CHARACTER;
-
\ No newline at end of file
diff --git a/lib/internal/os_support/unix/video/event_system.li b/lib/internal/os_support/unix/video/event_system.li
index 3d3d7a1..5cc1298 100644
--- a/lib/internal/os_support/unix/video/event_system.li
+++ b/lib/internal/os_support/unix/video/event_system.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EVENT_SYSTEM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "X11 - Event System";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
-Section Public
-
+
+Section Public
+
- x_root:INTEGER;
- y_root:INTEGER;
-
+
- sleep n:INTEGER <-
// Milisecond
(
`usleep(@n * 1000)`;
);
-
- - make <-
+
+ - make <-
( + mask:UINTEGER_32;
-
+
mask := `ExposureMask`:UINTEGER_32;
mask := mask | `KeyPressMask|KeyReleaseMask`:UINTEGER_32;
mask := mask | `ButtonPressMask|ButtonReleaseMask|PointerMotionMask`:UINTEGER_32;
mask := mask | `ClientMessage`:UINTEGER_32;
//mask := mask | `ResizeRedirectMask`:UINTEGER_32;
mask := mask | `StructureNotifyMask`:UINTEGER_32;
- `XSelectInput(display,window, at mask)`;
+ `XSelectInput(display,window, at mask)`;
);
-
+
- get_event <-
( //+ nb_ev:INTEGER;
+ type:INTEGER;
+ x0,y0,x1,y1:INTEGER;
-
- TIMER.get_event;
- `{ XEvent ev`;
- (`XPending(display)`:INTEGER != 0).if {
+
+ TIMER.get_event;
+ `{ XEvent ev`;
+ (`XPending(display)`:INTEGER != 0).if {
`XNextEvent(display,&ev)`;
type := `ev.type`:INTEGER;
-
+
type
//
// Event Window
@@ -73,7 +73,7 @@ Section Public
x0 := `ev.xexpose.x`:INTEGER;
y0 := `ev.xexpose.y`:INTEGER;
x1 := x0 + `ev.xexpose.width` :INTEGER - 1;
- y1 := y0 + `ev.xexpose.height`:INTEGER - 1;
+ y1 := y0 + `ev.xexpose.height`:INTEGER - 1;
DESK.physical_screen.redraw (x0,y0) to (x1,y1);
}
.when `ResizeRequest`:INTEGER then {
@@ -81,32 +81,32 @@ Section Public
x1 := `ev.xresizerequest.width`:INTEGER;
y1 := `ev.xresizerequest.height`:INTEGER;
`XResizeWindow(display,window, at x1, at y1)`;
-
+
VIDEO.pixel_hard (x1,10) color 0FF0000h;
-
+
DESK.resize_window (x1,y1);
}
-
+
.when `ConfigureNotify`:INTEGER then {
// Resize X Window
x1 := `ev.xconfigure.width`:INTEGER;
- y1 := `ev.xconfigure.height`:INTEGER;
+ y1 := `ev.xconfigure.height`:INTEGER;
DESK.resize_window (x1,y1);
}
-
+
//
// Event Keyboard
//
- .when `KeyPress`:INTEGER then {
+ .when `KeyPress`:INTEGER then {
KEYBOARD.key `ev.xkey.keycode`:UINTEGER_8 press TRUE;
}
.when `KeyRelease`:INTEGER then {
KEYBOARD.key `ev.xkey.keycode`:UINTEGER_8 press FALSE;
- }
+ }
//
// Event Mouse
//
- .when `ButtonPress`:INTEGER then {
+ .when `ButtonPress`:INTEGER then {
x_root := `ev.xmotion.x_root`:INTEGER;
y_root := `ev.xmotion.y_root`:INTEGER;
(`ev.xbutton.button`:INTEGER = 1).if {
@@ -132,9 +132,9 @@ Section Public
};
`}`;
);
-
-
-
+
+
+
diff --git a/lib/internal/os_support/unix/video/keyboard.li b/lib/internal/os_support/unix/video/keyboard.li
index 6466ff5..7a0adcc 100644
--- a/lib/internal/os_support/unix/video/keyboard.li
+++ b/lib/internal/os_support/unix/video/keyboard.li
@@ -23,36 +23,36 @@ Section Header
+ name := KEYBOARD;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="X11 - Keyboard Driver";
- - version := 1;
+ - version := 1;
- date :="2003/04";
-
+
Section Inherit
+ parent_input_keyboard:Expanded INPUT_KEYBOARD;
Section Private
-
+
// Lower case.
- lower_case:STRING_CONSTANT := "&é\"'(-è_çà)=\8\\9\azertyuiop^$\13\ qsdfghjklmù *wxcvbn,;:!";
// Upper case.
- upper_case:STRING_CONSTANT := "1234567890°+\8\\9\AZERTYUIOP\"£\13\ QSDFGHJKLM% µWXCVBN?./§";
-
+
// Num lock.
- num_on :STRING_CONSTANT := "789-456+1230.";
- num_off:STRING_CONSTANT := "BUA-L\0R+EDZIS";
-
+
// AltGr.
- alt_gr:STRING_CONSTANT := "¹~#{[|`\\^@]}";
-
+
// Extension key.
- ext_key:STRING_CONSTANT := "BUAL REDZIS HP";
-
+
- keyup cu:UINTEGER_8 :UINTEGER_8 <-
- ( + result,pcu:UINTEGER_8;
-
+ ( + result,pcu:UINTEGER_8;
+
// Patch 64bits
((UINTEGER_CPU.object_size = 8) && {
(cu = 111) || {cu = 113} || {cu = 114} || {cu = 116}
@@ -62,12 +62,12 @@ Section Private
} else {
pcu := cu - 12;
};
- } else {
+ } else {
pcu := cu;
- };
+ };
// End patch
-
- cmd := cmd & 0F7h; // Deactivate the cmd bit
+
+ cmd := cmd & 0F7h; // Deactivate the cmd bit
//bin_code.put ((bin_code.item (pcu>>3)) & ~(1<<(pcu&7))) to (pcu>>3);
// Analyze: for deactivate the cmd
((pcu = 37) || {pcu = 109}).if {
@@ -78,9 +78,9 @@ Section Private
cmd := cmd & (~02h);
}.elseif { pcu = 64 } then {
// Alt
- cmd := cmd & (~04h);
+ cmd := cmd & (~04h);
result := ascii_code;
- ascii_code := 0;
+ ascii_code := 0;
}.elseif { (pcu = 50) || { pcu = 62} } then {
// Shift 1 or Shift 2
cmd := cmd & (~10h);
@@ -90,7 +90,7 @@ Section Private
- keydown cu:UINTEGER_8 :UINTEGER_8 <-
( + result,pcu:UINTEGER_8;
-
+
// Patch 64bits
((UINTEGER_CPU.object_size = 8) && {
(cu = 111) || {cu = 113} || {cu = 114} || {cu = 116}
@@ -100,11 +100,11 @@ Section Private
} else {
pcu := cu - 12;
};
- } else {
+ } else {
pcu := cu;
- };
+ };
// End patch
-
+
//bin_code.put ((bin_code.item (pcu>>3)) | (~(1<<(pcu&7)))) to (pcu>>3); // Activate key
// Analyze: for activate the cmd
((pcu = 37) || {pcu = 109}).if {
@@ -115,10 +115,10 @@ Section Private
cmd := cmd | 02h;
}.elseif { pcu = 64 } then {
// Alt
- cmd := cmd | 04h;
+ cmd := cmd | 04h;
}.elseif { pcu = 65 } then {
// Space
- result := ' '.to_uinteger_8;
+ result := ' '.to_uinteger_8;
}.elseif { (pcu = 50) || { pcu = 62} } then {
// Shift 1 or Shift 2
cmd := cmd | 10h;
@@ -151,13 +151,13 @@ Section Private
};
(result <= 13).if {
cmd := cmd | 08h;
- };
+ };
}.elseif {pcu = 63} then {
result := '*'.to_uinteger_8;
}.elseif {pcu.in_range 67 to 76} then {
cmd := cmd | 08h; // F1 to F10 = cmd
result := pcu - 67 + 'a'.to_uinteger_8; // 'a' to 'j'
- }.elseif {pcu.in_range 79 to 91} then {
+ }.elseif {pcu.in_range 79 to 91} then {
((cmd & 40h) = 0).if {
// Ver num off
result := num_off.item (pcu-78).to_uinteger_8;
@@ -172,7 +172,7 @@ Section Private
result := 0;
};
};
- }.elseif {(pcu = 95) || {pcu = 96}} then {
+ }.elseif {(pcu = 95) || {pcu = 96}} then {
cmd := cmd | 08h; // F11 to F12 = cmd
result := pcu - 95 + 'k'.to_uinteger_8; // 'k' to 'l'
}.elseif {pcu = 94} then {
@@ -183,13 +183,13 @@ Section Private
};
}.elseif {pcu.in_range 97 to 111} then {
cmd := cmd | 08h;
- result := ext_key.item (pcu-96).to_uinteger_8;
+ result := ext_key.item (pcu-96).to_uinteger_8;
}.elseif {pcu = 112} then {
result := '/'.to_uinteger_8;
};
result
);
-
+
diff --git a/lib/internal/os_support/unix/video/mouse.li b/lib/internal/os_support/unix/video/mouse.li
index 9832532..40ece71 100644
--- a/lib/internal/os_support/unix/video/mouse.li
+++ b/lib/internal/os_support/unix/video/mouse.li
@@ -19,75 +19,75 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := MOUSE;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "X11 - Mouse driver";
-
+
Section Inherit
-
+
+ parent_input:Expanded INPUT;
-
+
+ parent_window:Expanded AREA; // MASK
-
+
Section Public
-
+
- set (x,y:INTEGER) with (left_new,right_new:BOOLEAN) <-
( + tmp:UINTEGER_8;
+ x_new, y_new:INTEGER;
-
+
y_new := y.max y_minimum.min y_maximum;
x_new := x.max x_minimum.min x_maximum;
-
+
tmp:=(p_end+1)&003h;
buffer_event.item p_end.make (x_new,y_new) button (left_new,right_new);
(((tmp+2)&3)!=p_beg).if {
p_end:=tmp;
};
-
+
get_event;
-
+
// Update status.
x_current:=x_new;
y_current:=y_new;
right :=right_new;
- left :=left_new;
+ left :=left_new;
);
-
+
Section Public
-
+
+ x_minimum:INTEGER;
- x_maximum:INTEGER <- VIDEO.x_max;
-
+
+ y_minimum:INTEGER;
- - y_maximum:INTEGER <- VIDEO.y_max;
-
+ - y_maximum:INTEGER <- VIDEO.y_max;
+
+ x_current:INTEGER;
- + y_current:INTEGER;
-
+ + y_current:INTEGER;
+
+ right:BOOLEAN;
+ left :BOOLEAN;
-
+
Section Private
-
+
+ buffer_event:FAST_ARRAY(EVENT_MOUSE);
- p_beg:UINTEGER_8; // Pointer on the buffer (beginning)
- p_end:UINTEGER_8; // Pointer on the buffer (end)
-
+
Section Public
-
+
//
// Creation / Initialisation.
//
-
+
- make <-
( + new_event:EVENT_MOUSE;
-
+
is_actif := TRUE;
-
+
//
// Software configuration.
//
@@ -100,43 +100,43 @@ Section Public
};
};
buffer_event.first.set_prev new_event;
-
+
// MASK
mask := FAST_ARRAY(UINTEGER_16).create 16;
make (DESK.physical_screen) from (x_current,y_current) size (16,16);
);
-
+
- get_event <-
( + p:INTEGER;
+ evt:EVENT_MOUSE;
-
+
p := p_beg;
(p != p_end).if {
((x_current != x_window) || {y_current != y_window}).if {
set_position (x_current,y_current);
};
{ p != p_end }.while_do {
- evt := buffer_event.item p;
+ evt := buffer_event.item p;
(list_client.lower).to (list_client.upper) do { j:INTEGER;
list_client.item j.receive (buffer_event.item p);
- };
+ };
p := (p + 1) & 03h;
- };
+ };
};
);
-
+
- acknowledge <-
(
p_beg := (p_beg+1) & 03h;
);
-
+
//
// Display.
//
-
+
// BSBS: A refaire avec une bitmap en dehors contenant le dessin avec une couleur de mask!!
// Plus simple, plus puissant, plus rapide !
-
+
+ mask:FAST_ARRAY(UINTEGER_16);
- pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
@@ -149,42 +149,42 @@ Section Public
mask.put m to y;
parent_window.pixel_hard (x,y) color col;
);
-
+
- line_h_hard (x0,y0:INTEGER) until x1:INTEGER color col:UINTEGER_32 <-
( + m:UINTEGER_16;
? {x0<16};
? {y0<16};
? {x1<16};
-
+
m:=mask.item y0;
x0.to x1 do { xx:INTEGER;
m:=m | (1<<xx);
};
-
+
mask.put m to y0;
parent_window.line_h_hard (x0,y0) until x1 color col;
);
- - slave_pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
+ - slave_pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
( + m:UINTEGER_16;
-
+
m:=mask.item y;
((m & (1<<x))=0).if {
parent_window.pixel_hard (x,y) color col;
};
);
-
- - slave_line_h_hard (x1,y:INTEGER) until x2:INTEGER color col:UINTEGER_32 <-
+
+ - slave_line_h_hard (x1,y:INTEGER) until x2:INTEGER color col:UINTEGER_32 <-
( + m:UINTEGER_16;
-
+
m:=mask.item y;
x1.to x2 do { xx:INTEGER;
((m & (1<<xx))=0).if {
parent_window.pixel_hard (xx,y) color col;
};
};
- );
-
+ );
+
- slave_line_h_hard (x1,y:INTEGER) until x2:INTEGER image line:ABSTRACT_BMP_LINE offset ofs:INTEGER <-
( + m:UINTEGER_16;
+ col:UINTEGER_32;
@@ -193,17 +193,17 @@ Section Public
m:=mask.item y;
x1.to x2 do { xx:INTEGER;
((m & (1<<xx))=0).if {
- col := line.get_color ofs_img;
+ col := line.get_color ofs_img;
parent_window.pixel_hard (xx,y) color col;
- };
+ };
ofs_img := ofs_img + 1;
};
);
-
+
- draw (x0,y0:INTEGER) to (x1,y1:INTEGER) <-
(
clipping (x0,y0) to (x1,y1);
-
+
color white;
poly_move_to (1,1);
poly_line_to (9,9);
@@ -211,10 +211,10 @@ Section Public
poly_line_to (8,14);
poly_line_to (5,14);
poly_line_to (5,9);
- poly_line_to (1,9);
- poly_move_to (1,1);
+ poly_line_to (1,9);
+ poly_move_to (1,1);
poly_trace;
-
+
color red;
line_v (0,0) until 10;
line_h (1,10) until 4;
@@ -224,16 +224,16 @@ Section Public
line_h (7,10) until 10;
line (1,0) to (10,9);
);
-
+
- get_object (x,y:INTEGER) :AREA <-
(
NULL
);
-
+
//
// Extern robot.
//
-
+
- extern_event_move (x,y:INTEGER) <-
(
`XTestFakeMotionEvent(display,-1, at x, at y,1)`;
@@ -242,28 +242,28 @@ Section Public
- extern_event_left_down <-
(
- `XTestFakeButtonEvent(display,1,True,1)`;
+ `XTestFakeButtonEvent(display,1,True,1)`;
`XFlush(display)`;
);
- extern_event_left_up <-
(
- `XTestFakeButtonEvent(display,1,False,1)`;
+ `XTestFakeButtonEvent(display,1,False,1)`;
`XFlush(display)`;
);
-
+
- extern_event_right_down <-
(
- `XTestFakeButtonEvent(display,3,True,1)`;
+ `XTestFakeButtonEvent(display,3,True,1)`;
`XFlush(display)`;
);
- extern_event_right_up <-
(
- `XTestFakeButtonEvent(display,3,False,1)`;
+ `XTestFakeButtonEvent(display,3,False,1)`;
`XFlush(display)`;
);
-
+
- extern_get_mouse:(INTEGER,INTEGER,BOOLEAN,BOOLEAN) <-
( + x,y,mask:INTEGER;
+ l,r:BOOLEAN;
@@ -273,11 +273,11 @@ Section Public
x := `winx`:INTEGER;
y := `winy`:INTEGER;
mask := `mask`:INTEGER;
- `}`;
+ `}`;
l := (mask & 100h)!=0;
r := (mask & 400h)!=0;
x,y,l,r
- );
+ );
diff --git a/lib/internal/os_support/unix/video/timer.li b/lib/internal/os_support/unix/video/timer.li
index f65a6ee..45f9162 100644
--- a/lib/internal/os_support/unix/video/timer.li
+++ b/lib/internal/os_support/unix/video/timer.li
@@ -23,44 +23,44 @@ Section Header
+ name := TIMER;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Unix - Timer management.";
- - version := 1;
+ - version := 1;
- date :="2003/04";
-
- - external :=
+
+ - external :=
`
#include <signal.h>
#define __BEGIN_INTERRUPT__
#define __END_INTERRUPT__
XEvent timer_ev;
`;
-
-Section Inherit
-
+
+Section Inherit
+
+ parent_input:Expanded INPUT;
-
+
Section Private
-
+
- timer_count:UINTEGER_32;
-
+
- buffer_event:FAST_ARRAY(EVENT_TIMER);
-
+
- p_beg:UINTEGER_8; // Pointer on the buffer (beginning)
-
+
- p_end:UINTEGER_8; // Pointer on the buffer (end)
-
-Section Interrupt
-
- - timer_interrupt <-
- ( + tmp:UINTEGER_8;
-
+
+Section Interrupt
+
+ - timer_interrupt <-
+ ( + tmp:UINTEGER_8;
+
timer_count := timer_count + 1;
-
+
tmp:=(p_end+1)&003h;
- buffer_event.item p_end.make timer_count;
+ buffer_event.item p_end.make timer_count;
(((tmp+2)&3)!=p_beg).if {
p_end:=tmp;
};
@@ -78,15 +78,15 @@ Section Interrupt
// "BREAK!!!!!\n".print;
};
*/
- `ualarm(50000,0)`;
+ `ualarm(50000,0)`;
);
-
+
Section Public
- make <-
( + hdle:POINTER;
+ new_event:EVENT_TIMER;
-
+
is_actif := TRUE;
//
// Software configuration.
@@ -100,7 +100,7 @@ Section Public
};
};
buffer_event.first.set_prev new_event;
-
+
hdle := timer_interrupt;
`signal(SIGALRM, at hdle)`;
`ualarm(500000,0)`;
@@ -114,25 +114,25 @@ Section Public
- get_event <-
( + p:INTEGER;
+ evt:EVENT_TIMER;
-
+
p := p_beg;
{ p != p_end }.while_do {
- evt := buffer_event.item p;
+ evt := buffer_event.item p;
(list_client.lower).to (list_client.upper) do { j:INTEGER;
buffer_event.item p.set_destination NULL;
list_client.item j.receive (buffer_event.item p);
- };
+ };
p := (p + 1) & 03h;
- };
+ };
);
-
+
- clear <-
(
p_beg := p_end;
);
-
-/*
+
+/*
//Other solution :
void catcher( int sig ) {
@@ -147,12 +147,12 @@ int main( int argc, char *argv[] ) {
signal(SIGALRM,catcher);
- value.it_interval.tv_sec = 1;
- value.it_interval.tv_usec = 0;
- value.it_value.tv_sec = 1;
- value.it_value.tv_usec = 0;
+ value.it_interval.tv_sec = 1;
+ value.it_interval.tv_usec = 0;
+ value.it_value.tv_sec = 1;
+ value.it_value.tv_usec = 0;
- setitimer(ITIMER_REAL, &value, NULL);
+ setitimer(ITIMER_REAL, &value, NULL);
while (1) {
if (old_time != time_count) {
diff --git a/lib/internal/os_support/unix/video/video.li b/lib/internal/os_support/unix/video/video.li
index 087efa8..92fee68 100644
--- a/lib/internal/os_support/unix/video/video.li
+++ b/lib/internal/os_support/unix/video/video.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := VIDEO;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "X11 Driver video - Xlib -";
-
+
- lip <-
(
add_lib "-lX11";
);
-
- - external :=
+
+ - external :=
`
#include <X11/Xlib.h>
// For Frame buffer.
-//#include <X11/extensions/XTest.h>
+//#include <X11/extensions/XTest.h>
#include <linux/fb.h>
#include <sys/mman.h>
#include <fcntl.h>
@@ -49,42 +49,42 @@ XImage *ximage=NULL;
`;
Section Inherit
-
+
+ parent_bitmap:Expanded BITMAP(PIXEL_24);
-
+
Section Public //VIDEO
-
+
- line_tmp:ABSTRACT_BMP_LINE;
-
+
Section Public
-
+
- screen_width:INTEGER;
- screen_height:INTEGER;
-
+
- message str:ABSTRACT_STRING <-
- (
+ (
"Message : ".print; str.print; '\n'.print;
);
-
+
- is_active:BOOLEAN;
-
+
- planes:UINTEGER_32;
-
+
- resize (w,h:INTEGER) <-
(
width := w;
height := h;
clipping_off;
);
-
+
- make_size (w,h:INTEGER) <-
( + data:NATIVE_ARRAY(UINTEGER_8);
+ w_max:INTEGER;
-
+
// Init BITMAP:
width := w;
height := h;
-
+
// Creation Server X:
`display = XOpenDisplay(NULL)`;
// Screen Default:
@@ -92,54 +92,54 @@ Section Public
// Init Graphic context:
`gc = DefaultGC(display,DefaultScreen(display))`;
// Creation Window:
- `window = XCreateSimpleWindow(display,RootWindow(display,DefaultScreen(display)), 0,0, at w, at h,2,0,0)`;
+ `window = XCreateSimpleWindow(display,RootWindow(display,DefaultScreen(display)), 0,0, at w, at h,2,0,0)`;
// Event manager:
//XSelectInput(display,window,ExposureMask);
// Title window:
- `XStoreName(display,window,"X-Isaac")`;
+ `XStoreName(display,window,"X-Isaac")`;
// Display Window:
`XMapWindow(display,window)`;
-
+
planes := `PlanesOfScreen(screen)`:UINTEGER_32;
"Video mode: ".print;
planes.print; "bits\n".print;
-
+
screen_width := w_max := `WidthOfScreen(screen)`:INTEGER;
screen_height := `HeightOfScreen(screen)`:INTEGER;
-
+
planes
.when 15 then {
line_tmp := BMP_LINE(PIXEL_15).create w_max;
data := line_tmp.get_storage;
`ximage = XCreateImage(display,None,15,ZPixmap,0,(char *)@data, at w_max,1,16,0)`;
}
- .when 16 then {
- line_tmp := BMP_LINE(PIXEL_16).create w_max;
+ .when 16 then {
+ line_tmp := BMP_LINE(PIXEL_16).create w_max;
data := line_tmp.get_storage;
`ximage = XCreateImage(display,None,16,ZPixmap,0,(char *)@data, at w_max,1,16,0)`;
}
- .when 24 then {
- line_tmp := BMP_LINE(PIXEL_32).create w_max;
+ .when 24 then {
+ line_tmp := BMP_LINE(PIXEL_32).create w_max;
data := line_tmp.get_storage;
`ximage = XCreateImage(display,None,24,ZPixmap,0,(char *)@data, at w_max,1,32,0)`;
}
- .when 32 then {
- line_tmp := BMP_LINE(PIXEL_32).create w_max;
+ .when 32 then {
+ line_tmp := BMP_LINE(PIXEL_32).create w_max;
data := line_tmp.get_storage;
`ximage = XCreateImage(display,None,32,ZPixmap,0,(char *)@data, at w_max,1,32,0)`;
};
-
+
is_active := TRUE;
);
-
+
- auto_make <-
(
make_size (800,600);
);
-
+
- close <-
(
? {is_active};
@@ -149,27 +149,27 @@ Section Public
? {! is_active};
);
- //
+ //
// Redefine Low level Bitmap.
//
-
+
Section Public
-
+
- pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
( + real_col:UINTEGER_32;
+ m:UINTEGER_8;
-
+
VIDEO.planes
- .when 15 then {
+ .when 15 then {
real_col := PIXEL_15.get_raw col;
}
- .when 16 then {
- real_col := PIXEL_16.get_raw col;
+ .when 16 then {
+ real_col := PIXEL_16.get_raw col;
}
- .when 24 then {
- real_col := PIXEL_24.get_raw col;
+ .when 24 then {
+ real_col := PIXEL_24.get_raw col;
}
- .when 32 then {
+ .when 32 then {
real_col := PIXEL_32.get_raw col;
};
m := mode;
@@ -177,22 +177,22 @@ Section Public
`XSetFunction(display,gc,(int)@m)`;
`XDrawPoint(display,window,gc, at x, at y)`;
);
-
+
- line_h_hard (x0,y0:INTEGER) until x1:INTEGER color col:UINTEGER_32 <-
( + real_col:UINTEGER_32;
+ m:UINTEGER_8;
-
+
VIDEO.planes
- .when 15 then {
+ .when 15 then {
real_col := PIXEL_15.get_raw col;
}
- .when 16 then {
- real_col := PIXEL_16.get_raw col;
+ .when 16 then {
+ real_col := PIXEL_16.get_raw col;
}
- .when 24 then {
- real_col := PIXEL_24.get_raw col;
+ .when 24 then {
+ real_col := PIXEL_24.get_raw col;
}
- .when 32 then {
+ .when 32 then {
real_col := PIXEL_32.get_raw col;
};
m := mode;
@@ -200,45 +200,45 @@ Section Public
`XSetFunction(display,gc,(int)@m)`;
`XDrawLine(display,window,gc, at x0, at y0, at x1, at y0)`;
);
-
- - line_h_hard (x0,y0:INTEGER) until x1:INTEGER
+
+ - line_h_hard (x0,y0:INTEGER) until x1:INTEGER
image line:ABSTRACT_BMP_LINE offset ofs:INTEGER <-
( + len:INTEGER;
- len := x1 - x0;
+ len := x1 - x0;
VIDEO.line_tmp.put line offset ofs from 0 to len;
`XPutImage(display,window,gc, ximage, 0, 0, @x0, @y0, @len+1, 1)`;
);
-
+
- get_pixel_hard (x,y:INTEGER) :PIXEL <-
(
not_yet_implemented;
);
-
+
//
// Frame buffer.
//
-
+
- open_frame_buffer <-
( + fb,w,h:INTEGER;
-
+
fb := `open("/dev/fb0", O_RDWR)`:INTEGER;
(fb = 0).if {
"Error: cannot open framebuffer device.\n".print;
die_with_code 0;
};
-
+
w := screen_width;
h := screen_height;
view_screen := `mmap(0, @w*@h*3, PROT_READ | PROT_WRITE,MAP_SHARED, at fb, 0)`:
NATIVE_ARRAY(UINTEGER_8);
-
+
(CONVERT(NATIVE_ARRAY(UINTEGER_8),INTEGER).on view_screen = -1).if {
"Error: failed to map framebuffer device to memory.\n".print;
die_with_code 0;
};
);
-
+
- get_pixel_screen (x,y:INTEGER) :UINTEGER_32 <-
[
-? {x.in_range 0 to (screen_width -1)};
@@ -254,48 +254,48 @@ Section Public
};
*/
ofs := (y * screen_width + x) * 4;
- (view_screen.item ofs .to_uinteger_32 ) |
+ (view_screen.item ofs .to_uinteger_32 ) |
(view_screen.item (ofs+1).to_uinteger_32 << 8) |
- (view_screen.item (ofs+2).to_uinteger_32 << 16)
+ (view_screen.item (ofs+2).to_uinteger_32 << 16)
);
-
+
- set_pixel_screen (x,y:INTEGER) color col:UINTEGER_32 <-
( + ofs:INTEGER;
-
+
ofs := (y * screen_width + x) * 4;
view_screen.put ((col >> 16).to_uinteger_8) to (ofs+2);
view_screen.put (((col >> 8) & 0FFh).to_uinteger_8) to (ofs+1);
- view_screen.put ((col & 0FFh).to_uinteger_8) to (ofs+0);
+ view_screen.put ((col & 0FFh).to_uinteger_8) to (ofs+0);
);
-
+
Section Private
-
+
- view_screen:NATIVE_ARRAY(UINTEGER_8);
/* A voir pour bloquer la size minimum
-
-// pointer to the size hints structure.
+
+// pointer to the size hints structure.
XSizeHints* win_size_hints = XAllocSizeHints();
if (!win_size_hints) {
fprintf(stderr, "XAllocSizeHints - out of memory\n");
exit(1);
}
-// initialize the structure appropriately.
-// first, specify which size hints we want to fill in.
-// in our case - setting the minimal size as well as the initial size.
+// initialize the structure appropriately.
+// first, specify which size hints we want to fill in.
+// in our case - setting the minimal size as well as the initial size.
win_size_hints->flags = PSize | PMinSize;
-// next, specify the desired limits.
-// in our case - make the window's size at least 300x200 pixels.
-// and make its initial size 400x250.
+// next, specify the desired limits.
+// in our case - make the window's size at least 300x200 pixels.
+// and make its initial size 400x250.
win_size_hints->min_width = 300;
win_size_hints->min_height = 200;
win_size_hints->base_width = 400;
win_size_hints->base_height = 250;
-// pass the size hints to the window manager.
+// pass the size hints to the window manager.
XSetWMNormalHints(display, win, win_size_hints);
-// finally, we can free the size hints structure.
+// finally, we can free the size hints structure.
XFree(win_size_hints);
*/
\ No newline at end of file
diff --git a/lib/internal/os_support/unix/video_ascii/bitmap_ascii.li b/lib/internal/os_support/unix/video_ascii/bitmap_ascii.li
index 4e018c3..41719fd 100644
--- a/lib/internal/os_support/unix/video_ascii/bitmap_ascii.li
+++ b/lib/internal/os_support/unix/video_ascii/bitmap_ascii.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := BITMAP_ASCII;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Bitmap for text mode";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
-
+
Section Inherit
-
+
+ parent_bitmap_generic:Expanded BITMAP;
-
+
Section Public
-
+
- pixel_geometry:PIXEL := PIXEL_ASCII;
-
-Section Public
-
+
+Section Public
+
//
// Data.
//
-
+
// Mapping memory bitmap.
+ image:FAST_ARRAY(BMP_LINE_ASCII);
-
+
- get_line y:INTEGER :BMP_LINE <-
( //? {y < height};
image.item y
);
-
+
//
- // Creation.
+ // Creation.
//
- make (w,h:INTEGER) <-
@@ -65,13 +65,13 @@ Section Public
image.put (BMP_LINE_ASCII.create w) to y;
};
clipping_off;
- );
-
+ );
+
- make (w,h:INTEGER) at offset_begin:UINTEGER_32 bytes_per_line lx:INTEGER <-
( + offset:UINTEGER_32;
-
+
width := w;
- height := h;
+ height := h;
image := FAST_ARRAY(BMP_LINE_ASCII).create h;
offset:=offset_begin;
0.to (image.upper) do { y:INTEGER;
@@ -80,7 +80,7 @@ Section Public
};
clipping_off;
);
-
+
- print <-
(
0.to (height - 1) do {h:INTEGER;
@@ -88,5 +88,5 @@ Section Public
'\n'.print;
};
);
-
+
diff --git a/lib/internal/os_support/unix/video_ascii/bmp_line_ascii.li b/lib/internal/os_support/unix/video_ascii/bmp_line_ascii.li
index 039d14c..2991a07 100644
--- a/lib/internal/os_support/unix/video_ascii/bmp_line_ascii.li
+++ b/lib/internal/os_support/unix/video_ascii/bmp_line_ascii.li
@@ -19,65 +19,65 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := BMP_LINE_ASCII;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Bitmap line for text mode";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
Section Inherit
-
+
+ parent_bmp_line:Expanded BMP_LINE;
-
+
Section Public
-
+
+ storage:MAP_NATIVE_ARRAY(PIXEL_ASCII);
-
+
- get_storage:NATIVE_ARRAY(UINTEGER_8) <- NATIVE_ARRAY(UINTEGER_8).force_conversion storage;
-
+
- make n:INTEGER <-
- (
+ (
capacity := n;
- upper := n - 1;
- storage := MAP_NATIVE_ARRAY(PIXEL_ASCII).calloc n;
+ upper := n - 1;
+ storage := MAP_NATIVE_ARRAY(PIXEL_ASCII).calloc n;
);
-
+
- make_with_capacity n:INTEGER <-
(
capacity := n;
upper := -1;
- storage := MAP_NATIVE_ARRAY(PIXEL_ASCII).calloc n;
+ storage := MAP_NATIVE_ARRAY(PIXEL_ASCII).calloc n;
);
-
+
- make n:INTEGER at offset:UINTEGER_32 <-
- (
+ (
capacity := n;
- upper := n - 1;
- storage := MAP_NATIVE_ARRAY(PIXEL_ASCII).force_conversion offset;
+ upper := n - 1;
+ storage := MAP_NATIVE_ARRAY(PIXEL_ASCII).force_conversion offset;
);
Section Public
-
+
- pixel_geometry:PIXEL := PIXEL_ASCII;
-
+
//
// Put.
//
-
- - put col:UINTEGER_32 from idx_begin:INTEGER to idx_end:INTEGER <-
+
+ - put col:UINTEGER_32 from idx_begin:INTEGER to idx_end:INTEGER <-
( ? {idx_begin<=idx_end};
? {idx_begin>=0};
? {idx_end.in_range 0 to upper};
-
+
idx_begin.to idx_end do { n:INTEGER;
storage.item n.color col;
};
);
-
+
- put bmp:BMP_LINE offset ofs:INTEGER from idx_begin:INTEGER to idx_end:INTEGER <-
( + offset:INTEGER;
+ pixel:PIXEL_ASCII;
@@ -85,7 +85,7 @@ Section Public
? {idx_begin >= 0};
? {idx_end.in_range 0 to upper};
? {ofs >= 0};
- ? {(ofs + (idx_end - idx_begin)) <= bmp.upper};
+ ? {(ofs + (idx_end - idx_begin)) <= bmp.upper};
offset := ofs;
idx_begin.to idx_end do { n:INTEGER;
pixel := bmp.item_ascii offset;
@@ -93,17 +93,17 @@ Section Public
offset := offset + 1;
};
);
-
+
//
// Get.
//
-
+
- item n:INTEGER :PIXEL <-
( ? {n.in_range 0 to upper};
-
+
storage.item n
);
-
+
- print <-
(
0.to upper do { i:INTEGER;
diff --git a/lib/internal/os_support/unix/video_ascii/pixel_ascii.li b/lib/internal/os_support/unix/video_ascii/pixel_ascii.li
index 8ebfd96..7e491a7 100644
--- a/lib/internal/os_support/unix/video_ascii/pixel_ascii.li
+++ b/lib/internal/os_support/unix/video_ascii/pixel_ascii.li
@@ -19,79 +19,79 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PIXEL_ASCII;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Version Generic ASCII";
-
+
- bibliography:= "http://IsaacOS.com";
-
+
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
-
+
Section Inherit
-
+
- parent_pixel:PIXEL := PIXEL;
-
+
Section Mapping
-
+
+ char:CHARACTER;
-
+
Section Public
-
- - red:UINTEGER_8 <-
+
+ - red:UINTEGER_8 <-
( + result:UINTEGER_8;
-
+
char
.when ' ' then { result := 31; }
- .when '.' then { result := 63; }
+ .when '.' then { result := 63; }
.when '-' then { result := 95; }
.when '=' then { result := 127; }
.when '+' then { result := 159; }
.when '*' then { result := 191; }
- .when '%' then { result := 223; }
+ .when '%' then { result := 223; }
.when '#' then { result := 255; };
result
);
-
+
- green:UINTEGER_8 <- red;
- blue:UINTEGER_8 <- red;
-
- - color col:UINTEGER_32 :UINTEGER_32 <-
+
+ - color col:UINTEGER_32 :UINTEGER_32 <-
( + gray:UINTEGER_32;
-
+
gray := ((col >> 16)+ ((col & 00FF00h)>>8)+ ((col & 0000FFh) >> 3))/3;
gray
.when 0 to 31 then { char := ' '; }
- .when 32 to 63 then { char := '.'; }
+ .when 32 to 63 then { char := '.'; }
.when 64 to 95 then { char := '-'; }
.when 96 to 127 then { char := '='; }
.when 128 to 159 then { char := '+'; }
.when 160 to 191 then { char := '*'; }
- .when 192 to 223 then { char := '%'; }
+ .when 192 to 223 then { char := '%'; }
.when 224 to 255 then { char := '#'; };
col
);
-
- - color_rgb (r,g,b:UINTEGER_8) <-
+
+ - color_rgb (r,g,b:UINTEGER_8) <-
( + gray:INTEGER;
-
+
gray := (r.to_integer+g+b)/3;
gray
.when 0 to 31 then { char := ' '; }
- .when 32 to 63 then { char := '.'; }
+ .when 32 to 63 then { char := '.'; }
.when 64 to 95 then { char := '-'; }
.when 96 to 127 then { char := '='; }
.when 128 to 159 then { char := '+'; }
.when 160 to 191 then { char := '*'; }
- .when 192 to 223 then { char := '%'; }
+ .when 192 to 223 then { char := '%'; }
.when 224 to 255 then { char := '#'; };
);
-
- - size:UINTEGER_8 := 8;
- - red_size:UINTEGER_8 := 3;
+
+ - size:UINTEGER_8 := 8;
+ - red_size:UINTEGER_8 := 3;
- red_pos:UINTEGER_8 := 0;
- green_size:UINTEGER_8 := 3;
- green_pos:UINTEGER_8 := 3;
@@ -99,12 +99,12 @@ Section Public
- blue_pos:UINTEGER_8 := 6;
- reserved_size:UINTEGER_8 := 0;
- reserved_pos:UINTEGER_8 := 0;
-
- - copy other:SELF <-
+
+ - copy other:SELF <-
(
color_rgb ((other.red),(other.green),(other.blue));
);
-
+
- print <-
(
(char=0).if {
@@ -112,7 +112,7 @@ Section Public
};
char.print;
);
-
+
- set_char c:CHARACTER <-
(
char := c;
diff --git a/lib/internal/os_support/unix/video_ascii/video.li b/lib/internal/os_support/unix/video_ascii/video.li
index 1350ddf..a0fe153 100644
--- a/lib/internal/os_support/unix/video_ascii/video.li
+++ b/lib/internal/os_support/unix/video_ascii/video.li
@@ -19,30 +19,30 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := VIDEO;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Generic Driver video - Text mode -";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr), Jerome Boutet (boutet at loria.fr)";
-
+
Section Inherit
-
+
+ parent_bitmap:Expanded BITMAP_ASCII;
-
+
Section Public
-
+
- is_active:BOOLEAN;
-
+
- create <-
- (
+ (
make (190,80);
is_active := TRUE;
);
-
+
- display_screen <-
(
0.to (height-1) do { y:INTEGER;
@@ -66,7 +66,7 @@ Section Public
'\n'.print;
};
);
-
+
- close <-
(
? {is_active};
diff --git a/lib/internal/os_support/windows/file_system/directory_unix.li b/lib/internal/os_support/windows/file_system/directory_unix.li
index 3bd6a15..713ebd1 100644
--- a/lib/internal/os_support/windows/file_system/directory_unix.li
+++ b/lib/internal/os_support/windows/file_system/directory_unix.li
@@ -19,18 +19,18 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=DIRECTORY_UNIX;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- bibliography:="http://IsaacOS.com";
-
+
- author :="Benoit Sonntag (bsonntag at loria.fr)";
-
+
- comment :="Directory management";
-
- - external :=
+
+ - external :=
`
#include <dirent.h>
#include <sys/stat.h>
@@ -39,40 +39,40 @@ Section Header
WIN32_FIND_DATA data;
HANDLE hfile;
`;
-
+
Section Inherit
-
+
+ parent_entry_unix:Expanded ENTRY_UNIX;
-
+
+ parent_directory:Expanded DIRECTORY;
-
+
Section Public
-
+
//
// Physical implementation.
//
-
+
//
// Scanning
//
- is_open:BOOLEAN <- ( list != NULL);
-
+
//
// Scanning
//
-
+
- open:BOOLEAN <-
( + p,n:NATIVE_ARRAY(CHARACTER);
+ new_entry:ENTRY;
+ result:BOOLEAN;
+ i:INTEGER;
-
+
(list = NULL).if {
list := LINKED_LIST(ENTRY).create;
} else {
list.clear;
};
-
+
string_tmp.copy path;
string_tmp.append "\\*.*";
p := string_tmp.to_external;
@@ -80,10 +80,10 @@ Section Public
(`hfile != INVALID_HANDLE_VALUE`:BOOLEAN{TRUE,FALSE}).if {
result := TRUE;
{
- n := `data.cFileName`:NATIVE_ARRAY(CHARACTER);
+ n := `data.cFileName`:NATIVE_ARRAY(CHARACTER);
string_tmp.clear;
i := 0;
- {n.item i = '\0'}.until_do {
+ {n.item i = '\0'}.until_do {
string_tmp.add_last (n.item i);
i := i + 1;
};
@@ -107,41 +107,41 @@ Section Public
};
result
);
-
+
Section DIRECTORY
-
+
- physical_get_entry new_path:ABSTRACT_STRING :ENTRY <-
// Same UNIX
( + pe:NATIVE_ARRAY(CHARACTER);
+ result:ENTRY;
-
+
pe := new_path.to_external;
`#ifdef __MINGW_H
`;
- `{ struct stat t`;
- (`stat(@pe,&t)`:INTEGER = 0).if {
+ `{ struct stat t`;
+ (`stat(@pe,&t)`:INTEGER = 0).if {
(`S_ISDIR(t.st_mode)`:INTEGER = 0).if {
// File.
result := FILE_UNIX.clone;
} else {
// Directory.
result := DIRECTORY_UNIX.clone;
- };
+ };
result.set_path new_path;
alias.put result to (result.path); // with { (e1,e2:ABSTRACT_STRING); e1 ~=e2 };
};
`}`;
`#else
`;
- `{ struct stat64 t`;
- (`stat64(@pe,&t)`:INTEGER = 0).if {
+ `{ struct stat64 t`;
+ (`stat64(@pe,&t)`:INTEGER = 0).if {
(`S_ISDIR(t.st_mode)`:INTEGER = 0).if {
// File.
result := FILE_UNIX.clone;
} else {
// Directory.
result := DIRECTORY_UNIX.clone;
- };
+ };
result.set_path new_path;
alias.put result to (result.path); //with { (e1,e2:ABSTRACT_STRING); e1 ~=e2 };
};
@@ -150,7 +150,7 @@ Section DIRECTORY
`;
result
);
-
+
- physical_make_directory new_path:ABSTRACT_STRING :BOOLEAN <-
( + p:NATIVE_ARRAY(CHARACTER);
p := new_path.to_external;
@@ -162,7 +162,7 @@ Section DIRECTORY
( + p:NATIVE_ARRAY(CHARACTER);
+ stream:POINTER;
+ result:BOOLEAN;
-
+
p := new_path.to_external;
stream := `fopen((char*)@p,"w+b")`:POINTER;
(stream != NULL).if {
@@ -177,7 +177,7 @@ Section DIRECTORY
pa := p.to_external;
`remove(@pa)`:(INTEGER) = 0
);
-
+
- physical_move old_path:ABSTRACT_STRING to new_path:ABSTRACT_STRING :BOOLEAN <-
// Same UNIX
( + old_p,new_p:NATIVE_ARRAY(CHARACTER);
diff --git a/lib/internal/os_support/windows/file_system/entry_unix.li b/lib/internal/os_support/windows/file_system/entry_unix.li
index f89d4b3..55c8a10 100644
--- a/lib/internal/os_support/windows/file_system/entry_unix.li
+++ b/lib/internal/os_support/windows/file_system/entry_unix.li
@@ -19,116 +19,116 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ENTRY_UNIX;
- copyright := "2003-2008 Benoit Sonntag";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
- comment := "Entry ANSI C";
-
+
Section Inherit
-
+
+ parent_entry:Expanded ENTRY;
-
-Section Public
-
- - access:UINTEGER_16 <-
+
+Section Public
+
+ - access:UINTEGER_16 <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ result:UINTEGER_16;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
+ `{ struct stat t; stat(@pe,&t)`;
result := `t.st_mode`:UINTEGER_16 & 111_111_111b;
`}`;
result
);
-
- - access_time:TIME <-
+
+ - access_time:TIME <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:TIME;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_atime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_atime))`:POINTER;
result := to_time tt;
`}`;
result
);
-
- - access_date:DATE <-
+
+ - access_date:DATE <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:DATE;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_atime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_atime))`:POINTER;
result := to_date tt;
`}`;
result
);
-
- - update_time:TIME <-
+
+ - update_time:TIME <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:TIME;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_mtime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_mtime))`:POINTER;
result := to_time tt;
`}`;
result
);
-
- - update_date:DATE <-
+
+ - update_date:DATE <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:DATE;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_mtime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_mtime))`:POINTER;
result := to_date tt;
`}`;
result
);
-
+
- create_time:TIME <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:TIME;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_ctime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_ctime))`:POINTER;
result := to_time tt;
`}`;
result
);
-
+
- create_date:DATE <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ tt:POINTER;
+ result:DATE;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
- tt := `localtime(&(t.st_ctime))`:POINTER;
+ `{ struct stat t; stat(@pe,&t)`;
+ tt := `localtime(&(t.st_ctime))`:POINTER;
result := to_date tt;
`}`;
result
);
-
-Section Private
-
+
+Section Private
+
//
// Time / Date: Unix -> Lisaac
//
-
+
- to_date t:POINTER :DATE <-
( + result:DATE;
+ wd,md,m:UINTEGER_8;
+ y:UINTEGER_16;
-
+
y := `((struct tm *)@t)->tm_year`:UINTEGER_16 + 1900;
m := `((struct tm *)@t)->tm_mon` :UINTEGER_8 + 1;
md := `((struct tm *)@t)->tm_mday`:UINTEGER_8;
@@ -136,15 +136,15 @@ Section Private
(! wd.in_range 1 to 7).if { // Bug in UNIX ?
wd := 1;
};
- result := DATE.create (y,m,md,wd)
+ result := DATE.create (y,m,md,wd)
);
- to_time t:POINTER :TIME <-
(
- TIME.create
+ TIME.create
((`((struct tm *)@t)->tm_hour`:UINTEGER_8),
(`((struct tm *)@t)->tm_min` :UINTEGER_8),
(`((struct tm *)@t)->tm_sec` :UINTEGER_8),
0)
);
-
+
diff --git a/lib/internal/os_support/windows/file_system/file_system.li b/lib/internal/os_support/windows/file_system/file_system.li
index b92fd70..7a41d96 100644
--- a/lib/internal/os_support/windows/file_system/file_system.li
+++ b/lib/internal/os_support/windows/file_system/file_system.li
@@ -19,32 +19,32 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=FILE_SYSTEM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment :="File System manager for Unix.";
-
+
- external := `#include <unistd.h>`; // For `getcwd'
-
-Section Inherit
-
+
+Section Inherit
+
+ parent_directory:DIRECTORY <-
- ( + cwd:NATIVE_ARRAY(CHARACTER);
+ ( + cwd:NATIVE_ARRAY(CHARACTER);
+ result:DIRECTORY;
-
+
DIRECTORY.string_tmp.clear;
cwd := DIRECTORY.string_tmp.to_external;
`getcwd(@cwd,255)`;
DIRECTORY.string_tmp.from_external cwd;
-
+
result ?= DIRECTORY_UNIX.physical_get_entry (DIRECTORY.string_tmp);
DIRECTORY.alias.put result to (result.path);
? {result != NULL};
parent_directory := result
);
-
-
+
+
diff --git a/lib/internal/os_support/windows/file_system/file_unix.li b/lib/internal/os_support/windows/file_system/file_unix.li
index 6ebe4d8..d6968f6 100644
--- a/lib/internal/os_support/windows/file_system/file_unix.li
+++ b/lib/internal/os_support/windows/file_system/file_unix.li
@@ -19,102 +19,102 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FILE_UNIX;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "File management";
-
+
Section Inherit
-
+
+ parent_entry_unix:Expanded ENTRY_UNIX;
-
+
+ parent_file:Expanded FILE;
-
-Section Private
-
+
+Section Private
+
+ stream:POINTER; // Unix file pointer (FILE *).
Section Public
-
+
//
// Physical implementation.
//
-
+
- is_open:BOOLEAN <- stream != NULL;
-
+
- size:UINTEGER_32 <-
( + pe:NATIVE_ARRAY(CHARACTER);
+ result:UINTEGER_32;
pe := path.to_external;
- `{ struct stat t; stat(@pe,&t)`;
+ `{ struct stat t; stat(@pe,&t)`;
result := `t.st_size`:UINTEGER_32;
`}`;
result
);
-
+
- cursor:UINTEGER_32 <-
- ( + str:POINTER;
- str := stream;
+ ( + str:POINTER;
+ str := stream;
`ftell((FILE *)@str)`:UINTEGER_32
);
-
+
- set_cursor n:UINTEGER_32 <-
[
...
-? {stream != NULL};
-? {n <= size};
]
- ( + str:POINTER;
- str := stream;
+ ( + str:POINTER;
+ str := stream;
`fseek((FILE*)(@str), at n,SEEK_SET)`;
- );
-
+ );
+
- open:BOOLEAN <-
[
-? {stream = NULL};
]
- ( + pa:NATIVE_ARRAY(CHARACTER);
-
+ ( + pa:NATIVE_ARRAY(CHARACTER);
+
pa := path.to_external;
- stream := `fopen((char*)@pa,"r+b")`:(POINTER);
+ stream := `fopen((char*)@pa,"r+b")`:(POINTER);
stream != NULL
- );
+ );
- open_read_only:BOOLEAN <-
- ( + pa:NATIVE_ARRAY(CHARACTER);
+ ( + pa:NATIVE_ARRAY(CHARACTER);
pa := path.to_external;
- stream := `fopen((char*)@path_pointer,"rb")`:(POINTER);
+ stream := `fopen((char*)@path_pointer,"rb")`:(POINTER);
stream != NULL
- );
-
+ );
+
- close <-
[
-? {stream != NULL};
]
( + str:POINTER;
-
- str := stream;
- `fclose((FILE*)(@str))`;
+
+ str := stream;
+ `fclose((FILE*)(@str))`;
stream := NULL;
);
-
-Section FILE
-
+
+Section FILE
+
- physical_read buf:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :INTEGER <-
// return size read or 0 if end of input (-1 on error => exception ?)
- ( + str:POINTER;
- str := stream;
+ ( + str:POINTER;
+ str := stream;
`fread((void *)(@buf),(size_t)(1), (size_t)(@s),(FILE*)(@str))`:(INTEGER)
);
-
+
- physical_write buf:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :INTEGER <-
// return size read or 0 if end of input (-1 on error => exception ?)
( + str:POINTER;
- str := stream;
+ str := stream;
`fwrite((void *)(@buf),(size_t)(1), (size_t)(@s),(FILE*)(@str))`:(INTEGER)
);
-
-
+
+
diff --git a/lib/internal/os_support/windows/video/event_system.li b/lib/internal/os_support/windows/video/event_system.li
index 94f8e7c..201bde2 100644
--- a/lib/internal/os_support/windows/video/event_system.li
+++ b/lib/internal/os_support/windows/video/event_system.li
@@ -19,18 +19,18 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EVENT_SYSTEM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "X11 - Event System";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
-
- - external :=
-`
+
+ - external :=
+`
void (*get_event)()=NULL;
int event_num;
int event_p1;
@@ -40,9 +40,9 @@ int event_p4;
unsigned char buf[50];
-HDC hdc_glob;
+HDC hdc_glob;
LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
-{
+{
PAINTSTRUCT ps;
HDC hdc_old;
RECT rect;
@@ -54,9 +54,9 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
get_event();
return 0;
// Create
- case WM_CREATE:
+ case WM_CREATE:
return 0;
-
+
// Repaint
case WM_PAINT:
event_num = 0;
@@ -65,18 +65,18 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
event_p1 = ps.rcPaint.left;
event_p2 = ps.rcPaint.top;
event_p3 = ps.rcPaint.right;
- event_p4 = ps.rcPaint.bottom;
- get_event();
+ event_p4 = ps.rcPaint.bottom;
+ get_event();
EndPaint(hwnd, &ps);
hdc_glob = hdc_old;
return 0;
-
+
// Destroy
case WM_DESTROY:
PostQuitMessage(0);
exit(0);
return 0;
-
+
// Mouse
case WM_MOUSEMOVE:
event_num = 1;
@@ -89,7 +89,7 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
event_num = 2;
get_event();
return 0;
- case WM_LBUTTONUP:
+ case WM_LBUTTONUP:
event_num = 3;
get_event();
return 0;
@@ -97,13 +97,13 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
event_num = 4;
get_event();
return 0;
- case WM_RBUTTONUP:
+ case WM_RBUTTONUP:
event_num = 5;
get_event();
return 0;
-
+
// Kayboard
- case WM_KEYDOWN:
+ case WM_KEYDOWN:
//sprintf(buf,"KeyDown : %c(%d) ,%lx ",wParam,wParam,lParam);
//TextOutA(hdc_glob,10,100,buf,strlen(buf));
event_num = 10;
@@ -111,7 +111,7 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
event_p2 = lParam;
get_event();
return 0;
-
+
case WM_CHAR:
//sprintf(buf,"Char : %c(%d) ,%lx ",wParam,wParam,lParam);
//TextOutA(hdc_glob,10,120,buf,strlen(buf));
@@ -120,8 +120,8 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
event_p2 = lParam;
get_event();
return 0;
-
- case WM_KEYUP:
+
+ case WM_KEYUP:
//sprintf(buf,"KeyUp : %c(%d) ,%lx ",wParam,wParam,lParam);
//TextOutA(hdc_glob,10,140,buf,strlen(buf));
event_num = 12;
@@ -137,19 +137,19 @@ LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
`;
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
-Section Interrupt
-
+
+Section Interrupt
+
- get_physical_event <-
( + p1,p2,p3,p4:INTEGER;
-
+
p1 := `event_p1`:INTEGER;
p2 := `event_p2`:INTEGER;
p3 := `event_p3`:INTEGER;
p4 := `event_p4`:INTEGER;
-
+
`event_num`:INTEGER
//
// Event Window
@@ -199,22 +199,22 @@ Section Interrupt
TIMER.get_event;
};
);
-
-Section Public
-
+
+Section Public
+
- sleep n:INTEGER <-
// Milisecond
(
`sleep(@n)`;
);
-
- - make <-
+
+ - make <-
( + ptr:POINTER;
-
+
ptr := get_physical_event;
`get_event = @ptr`;
);
-
+
- get_event <-
(
`
@@ -223,8 +223,8 @@ Section Public
DispatchMessage(&msg_glob);
`;
);
-
-
+
+
diff --git a/lib/internal/os_support/windows/video/keyboard.li b/lib/internal/os_support/windows/video/keyboard.li
index 9dc38d6..dfd2195 100644
--- a/lib/internal/os_support/windows/video/keyboard.li
+++ b/lib/internal/os_support/windows/video/keyboard.li
@@ -23,28 +23,28 @@ Section Header
+ name := KEYBOARD;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Windows (Win32) - RSXNT - Keyboard Driver";
- - version := 2;
-
+ - version := 2;
+
Section Inherit
+ parent_input_keyboard:Expanded INPUT_KEYBOARD;
Section Private
-
+
- keyup cu:UINTEGER_8 :UINTEGER_8 <-
( + result:UINTEGER_8;
-
+
result := cu;
- cmd := cmd & 0F7h; // Deactivate the cmd bit
-
+ cmd := cmd & 0F7h; // Deactivate the cmd bit
+
cu
.when 8 then { cmd := cmd | 8; }
.when 13 then { cmd := cmd | 8; };
-
-
+
+
result
);
@@ -63,10 +63,10 @@ Section Private
.when 4Bh then { result := 'L'.to_uinteger_8; }
.when 4Dh then { result := 'R'.to_uinteger_8; };
cmd := cmd | 8;
-
+
result
);
-
+
diff --git a/lib/internal/os_support/windows/video/mouse.li b/lib/internal/os_support/windows/video/mouse.li
index 1af2510..2d4a708 100644
--- a/lib/internal/os_support/windows/video/mouse.li
+++ b/lib/internal/os_support/windows/video/mouse.li
@@ -19,82 +19,82 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := MOUSE;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "X11 - Mouse driver";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Benoit Sonntag (bsonntag at loria.fr)";
-
+
Section Inherit
-
+
+ parent_input:Expanded INPUT;
-
+
Section Public
-
+
- set (x,y:INTEGER) with (left_new,right_new:BOOLEAN) <-
( + tmp:UINTEGER_8;
+ x_new, y_new:INTEGER;
-
+
y_new := y.max y_minimum.min y_maximum;
x_new := x.max x_minimum.min x_maximum;
-
+
tmp:=(p_end+1)&003h;
buffer_event.item p_end.make (x_new,y_new) button (left_new,right_new);
(((tmp+2)&3)!=p_beg).if {
p_end:=tmp;
};
-
+
get_event;
-
+
// Update status.
x_current:=x_new;
y_current:=y_new;
right:=right_new;
- left :=left_new;
+ left :=left_new;
);
-
+
Section Public
-
+
+ x_minimum:INTEGER;
+ x_maximum:INTEGER;
-
+
+ y_minimum:INTEGER;
+ y_maximum:INTEGER;
-
+
+ x_current:INTEGER;
- + y_current:INTEGER;
-
+ + y_current:INTEGER;
+
+ right:BOOLEAN;
+ left:BOOLEAN;
-
+
Section Private
-
+
+ buffer_event:FAST_ARRAY(EVENT_MOUSE);
- p_beg:UINTEGER_8; // Pointer on the buffer (beginning)
- p_end:UINTEGER_8; // Pointer on the buffer (end)
-
+
Section Public
-
+
//
// Creation / Initialisation.
//
-
+
- make <-
( + new_event:EVENT_MOUSE;
-
+
is_actif := TRUE;
//
// Mouse hardware configuration.
//
-
+
x_maximum := VIDEO.x_max;
y_maximum := VIDEO.y_max;
-
+
//
// Software configuration.
//
@@ -108,28 +108,28 @@ Section Public
};
buffer_event.first.set_prev new_event;
);
-
+
- get_event <-
( + p:INTEGER;
+ evt:EVENT_MOUSE;
-
+
p := p_beg;
{ p != p_end }.while_do {
evt := buffer_event.item p;
(list_client.lower).to (list_client.upper) do { j:INTEGER;
list_client.item j.receive (buffer_event.item p);
- };
+ };
p := (p + 1) & 03h;
- };
+ };
);
-
+
- acknowledge <-
(
p_beg := (p_beg+1) & 03h;
);
-
-
-
+
+
+
diff --git a/lib/internal/os_support/windows/video/timer.li b/lib/internal/os_support/windows/video/timer.li
index ccb93a5..d22d170 100644
--- a/lib/internal/os_support/windows/video/timer.li
+++ b/lib/internal/os_support/windows/video/timer.li
@@ -26,41 +26,41 @@ Section Header
- comment :="Windows - Timer management.";
- - version := 1;
-
-Section Inherit
-
+ - version := 1;
+
+Section Inherit
+
+ parent_input:Expanded INPUT;
-
+
Section Private
-
+
- timer_count:UINTEGER_32;
-
+
+ buffer_event:FAST_ARRAY(EVENT_TIMER);
-
+
- p_beg:UINTEGER_8; // Pointer on the buffer (beginning)
-
+
- p_end:UINTEGER_8; // Pointer on the buffer (end)
-
-Section Public
-
- - timer_interrupt <-
- ( + tmp:UINTEGER_8;
-
+
+Section Public
+
+ - timer_interrupt <-
+ ( + tmp:UINTEGER_8;
+
timer_count := timer_count + 1;
-
+
tmp:=(p_end+1)&003h;
- buffer_event.item p_end.make timer_count;
+ buffer_event.item p_end.make timer_count;
(((tmp+2)&3)!=p_beg).if {
p_end:=tmp;
- };
+ };
);
-
+
Section Public
- make <-
( + new_event:EVENT_TIMER;
-
+
is_actif := TRUE;
//
// Software configuration.
@@ -74,9 +74,9 @@ Section Public
};
};
buffer_event.first.set_prev new_event;
-
- //hdle := timer_interrupt;
-
+
+ //hdle := timer_interrupt;
+
`SetTimer(hwnd_glob, 0, 50, NULL)`;
);
@@ -88,13 +88,13 @@ Section Public
- get_event <-
( + p:INTEGER;
+ evt:EVENT_TIMER;
-
+
p := p_beg;
{ p != p_end }.while_do {
evt := buffer_event.item p;
(list_client.lower).to (list_client.upper) do { j:INTEGER;
list_client.item j.receive (buffer_event.item p);
- };
+ };
p := (p + 1) & 03h;
- };
+ };
);
diff --git a/lib/internal/os_support/windows/video/video.li b/lib/internal/os_support/windows/video/video.li
index 19ae932..ae80046 100644
--- a/lib/internal/os_support/windows/video/video.li
+++ b/lib/internal/os_support/windows/video/video.li
@@ -19,11 +19,11 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := VIDEO;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Video Driver for Windows";
- lip <-
@@ -31,12 +31,12 @@ Section Header
add_lib "-lgdi32";
);
- - external :=
+ - external :=
`
#include <windows.h>
#define main main_std
-#define __BEGIN_INTERRUPT__
+#define __BEGIN_INTERRUPT__
#define __END_INTERRUPT__
#define lstat stat
@@ -59,38 +59,38 @@ LPSTR lpCmdLine, int nCmdShow)
nCmdShow_glob = nCmdShow;
main(0,NULL);
return 0;
-};
+};
`;
Section Inherit
-
+
+ parent_bitmap:Expanded BITMAP(PIXEL_24);
-
+
Section Public
// Section VIDEO
-
- - line_tmp:ABSTRACT_BMP_LINE;
-
+
+ - line_tmp:ABSTRACT_BMP_LINE;
+
Section Public
-
+
- message str:ABSTRACT_STRING <-
( + msg:NATIVE_ARRAY(CHARACTER);
msg := str.to_external;
`MessageBox(hwnd_glob, at msg, "Message", MB_OK)`;
);
-
+
- is_active:BOOLEAN;
-
- - planes:UINTEGER_32;
-
+
+ - planes:UINTEGER_32;
+
- size_pixel:INTEGER;
-
+
- make_size (w,h:INTEGER) <-
- (
+ (
// Init BITMAP:
width := w;
height := h;
-
+
EVENT_SYSTEM.make;
`
wc_glob.style = 0;
@@ -112,14 +112,14 @@ Section Public
hdc_glob = GetDC(hwnd_glob);
ShowWindow(hwnd_glob, nCmdShow_glob);
UpdateWindow(hwnd_glob);
-
+
//pen = CreatePen(PS_SOLID,1,0x151515);
//SelectObject(hdc_glob,pen);
-
-
+
+
hdcbmp = CreateCompatibleDC(hdc_glob);
`;
-
+
planes := `GetDeviceCaps(hdc_glob, BITSPIXEL) * GetDeviceCaps(hdc_glob, PLANES)`:UINTEGER_32;
planes
@@ -128,49 +128,49 @@ Section Public
line_tmp := BMP_LINE(PIXEL_15).create w;
`Bmp = CreateBitmap(@w, 1, 1, 15, NULL)`;
}
- .when 16 then {
+ .when 16 then {
size_pixel := 2;
- line_tmp := BMP_LINE(PIXEL_16).create w;
+ line_tmp := BMP_LINE(PIXEL_16).create w;
`Bmp = CreateBitmap(@w, 1, 1, 16, NULL)`;
}
- .when 24 then {
+ .when 24 then {
size_pixel := 3;
- line_tmp := BMP_LINE(PIXEL_24).create w;
+ line_tmp := BMP_LINE(PIXEL_24).create w;
`Bmp = CreateBitmap(@w, 1, 1, 24, NULL)`;
}
- .when 32 then {
+ .when 32 then {
size_pixel := 4;
- line_tmp := BMP_LINE(PIXEL_32).create w;
+ line_tmp := BMP_LINE(PIXEL_32).create w;
`Bmp = CreateBitmap(@w, 1, 1, 32, NULL)`;
};
`SelectObject(hdcbmp, Bmp)`;
is_active := TRUE;
);
-
+
- auto_make <-
(
make_size (800,600);
);
-
+
- close <-
(
? {is_active};
is_active := FALSE;
? {! is_active};
);
-
+
Section Public
-
- //
+
+ //
// Redefine Low level Bitmap.
//
-
+
- pixel_hard (x,y:INTEGER) color col:UINTEGER_32 <-
( + real_col:UINTEGER_32;
real_col := ((col>>16) & 0000FFh) | ((col<<16) & 0FF0000h) | (col & 00FF00h);
- `SetPixel(hdc_glob, at x, at y, at real_col)`;
+ `SetPixel(hdc_glob, at x, at y, at real_col)`;
);
-
+
- line_h_hard (x0,y0:INTEGER) until x1:INTEGER color col:UINTEGER_32 <-
( + real_col:UINTEGER_32;
+ pen:UINTEGER_32;
@@ -181,21 +181,21 @@ Section Public
`LineTo(hdc_glob, at x1+1, at y0)`;
`DeleteObject((HPEN)@pen)`;
);
-
- - line_h_hard (x0,y0:INTEGER) until x1:INTEGER
+
+ - line_h_hard (x0,y0:INTEGER) until x1:INTEGER
image line:ABSTRACT_BMP_LINE offset ofs:INTEGER <-
( + len:INTEGER;
+ data:NATIVE_ARRAY(UINTEGER_8);
+ sz_pix:INTEGER;
len := x1 - x0;
VIDEO.line_tmp.put line offset ofs from 0 to len;
-
+
sz_pix := VIDEO.size_pixel;
data := VIDEO.line_tmp.get_storage;
- `SetBitmapBits(Bmp,(@len+1)*@sz_pix, at data)`;
+ `SetBitmapBits(Bmp,(@len+1)*@sz_pix, at data)`;
`BitBlt(hdc_glob, @x0, @y0, at len+1,1, hdcbmp, 0, 0, SRCCOPY)`;
);
-
+
- get_pixel_hard (x,y:INTEGER) :PIXEL <-
(
not_yet_implemented;
diff --git a/lib/internal/portable/collection/any_avl_dictionary_node.li b/lib/internal/portable/collection/any_avl_dictionary_node.li
index 19f94fd..e071b9b 100644
--- a/lib/internal/portable/collection/any_avl_dictionary_node.li
+++ b/lib/internal/portable/collection/any_avl_dictionary_node.li
@@ -19,13 +19,13 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ANY_AVL_DICTIONARY_NODE;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
+
diff --git a/lib/internal/portable/collection/any_avl_set_node.li b/lib/internal/portable/collection/any_avl_set_node.li
index 813da61..e4d996e 100644
--- a/lib/internal/portable/collection/any_avl_set_node.li
+++ b/lib/internal/portable/collection/any_avl_set_node.li
@@ -24,8 +24,7 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
\ No newline at end of file
diff --git a/lib/internal/portable/collection/any_hashed_bijective_dictionary_node.li b/lib/internal/portable/collection/any_hashed_bijective_dictionary_node.li
index af0abfc..b79665f 100644
--- a/lib/internal/portable/collection/any_hashed_bijective_dictionary_node.li
+++ b/lib/internal/portable/collection/any_hashed_bijective_dictionary_node.li
@@ -24,8 +24,7 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
\ No newline at end of file
diff --git a/lib/internal/portable/collection/any_hashed_dictionary_node.li b/lib/internal/portable/collection/any_hashed_dictionary_node.li
index 1b29794..70698ed 100644
--- a/lib/internal/portable/collection/any_hashed_dictionary_node.li
+++ b/lib/internal/portable/collection/any_hashed_dictionary_node.li
@@ -24,8 +24,7 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
\ No newline at end of file
diff --git a/lib/internal/portable/collection/any_hashed_set_node.li b/lib/internal/portable/collection/any_hashed_set_node.li
index cf89429..b3d4a4b 100644
--- a/lib/internal/portable/collection/any_hashed_set_node.li
+++ b/lib/internal/portable/collection/any_hashed_set_node.li
@@ -24,8 +24,7 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
\ No newline at end of file
diff --git a/lib/internal/portable/collection/any_linked_list_node.li b/lib/internal/portable/collection/any_linked_list_node.li
index db279c0..e839bef 100644
--- a/lib/internal/portable/collection/any_linked_list_node.li
+++ b/lib/internal/portable/collection/any_linked_list_node.li
@@ -24,8 +24,7 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
\ No newline at end of file
diff --git a/lib/internal/portable/collection/any_two_way_linked_list_node.li b/lib/internal/portable/collection/any_two_way_linked_list_node.li
index fac74bb..9f0a135 100644
--- a/lib/internal/portable/collection/any_two_way_linked_list_node.li
+++ b/lib/internal/portable/collection/any_two_way_linked_list_node.li
@@ -24,8 +24,7 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
\ No newline at end of file
diff --git a/lib/internal/portable/collection/arrayed.li b/lib/internal/portable/collection/arrayed.li
index d57b4d4..1ce030a 100644
--- a/lib/internal/portable/collection/arrayed.li
+++ b/lib/internal/portable/collection/arrayed.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ARRAYED;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Generic collection";
-
+
// BSBS: A revoir cela doit rentrer ARRAYED_COLLECTION (mais il faut voir avec STRING)
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
+
- lower:INTEGER <- deferred;
- upper:INTEGER <- deferred;
- count:INTEGER <- deferred;
- capacity:INTEGER <- deferred;
-
- - element_sizeof:INTEGER <-
+
+ - element_sizeof:INTEGER <-
// The size in number of bytes for type `E'.
- (
+ (
deferred;
0
);
-
+
- add_last_buffer buf:FAST_ARRAY(UINTEGER_8) from beg:INTEGER to end:INTEGER <-
(
deferred;
);
-
+
- item_byte idx:INTEGER offset ofs:INTEGER :UINTEGER_8 <-
(
deferred;
@@ -62,13 +62,13 @@ Section Public
(
deferred;
);
-
+
- set_count new_count:INTEGER <-
(
deferred;
);
-
- - to_native_array_uinteger_8:NATIVE_ARRAY(UINTEGER_8) <-
+
+ - to_native_array_uinteger_8:NATIVE_ARRAY(UINTEGER_8) <-
(
deferred;
NULL
diff --git a/lib/internal/portable/collection/arrayed_collection.li b/lib/internal/portable/collection/arrayed_collection.li
index f93049f..082e834 100644
--- a/lib/internal/portable/collection/arrayed_collection.li
+++ b/lib/internal/portable/collection/arrayed_collection.li
@@ -19,31 +19,31 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ARRAYED_COLLECTION(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Common root for ARRAY(V) and FAST_ARRAY(V).";
-
+
Section Inherit
-
+
- parent_arrayed:ARRAYED := ARRAYED;
-
+
- parent_collection:COLLECTION(V) := COLLECTION(V);
-
+
Section Public //ARRAYED_COLLECTION, BMP_FILE, TYPES
-
+
+ storage:NATIVE_ARRAY(V);
// Internal access to storage location.
-
+
Section Public
-
- - element_sizeof:INTEGER <-
+
+ - element_sizeof:INTEGER <-
// The size in number of bytes for type `E'.
( + result:INTEGER;
-
+
(V.is_expanded_type).if {
result := V.object_size;
} else {
@@ -51,13 +51,13 @@ Section Public
};
result
);
-
+
+ capacity:INTEGER;
// Internal storage capacity in number of item.
-
+
+ upper:INTEGER;
// Upper index bound.
-
+
- subarray min:INTEGER to max:INTEGER :SELF <-
// New collection consisting of items at indexes in [`min' .. `max'].
// Result has the same dynamic type as `Current'.
@@ -67,28 +67,28 @@ Section Public
-? { max <= upper };
-? { min <= max + 1 };
]
- (
+ (
deferred;
NULL
)
- [
+ [
+? { same_dynamic_type result };
+? { result.count = max - min + 1 };
+? { result.lower = min | (result.lower = 0) };
];
-
+
//
// Implementation of deferred:
//
-
+
- first:V <- storage.item 0;
-
+
- second:V <- storage.item 1;
-
+
- last :V <- item upper;
-
+
- add element:V to index:INTEGER <-
- (
+ (
(index = upper + 1).if {
add_last element;
} else {
@@ -97,43 +97,43 @@ Section Public
put element to index;
};
);
-
+
- remove_last <-
- (
- upper := upper - 1;
+ (
+ upper := upper - 1;
);
-
+
- remove_tail n:INTEGER <-
(
upper := upper - n;
);
-
+
- replace_all old_value:V with new_value:V <-
- (
- storage.replace_all old_value with new_value until (count - 1);
+ (
+ storage.replace_all old_value with new_value until (count - 1);
);
-
+
- fast_replace_all old_value:V with new_value:V <-
- (
- storage.fast_replace_all old_value with new_value until (count - 1);
+ (
+ storage.fast_replace_all old_value with new_value until (count - 1);
);
-
+
- reverse <-
( + i,j:INTEGER;
-
+
i := lower;
- j := upper;
+ j := upper;
{i >= j}.until_do {
swap i with j;
i := i + 1;
j := j - 1;
};
- );
-
+ );
+
//
// Interfacing with C:
//
-
+
- to_external:POINTER <-
// Gives C access into the internal `storage' of the ARRAY.
// Result is pointing the element at index `lower'.
@@ -143,11 +143,11 @@ Section Public
[
-? {! is_empty};
]
- (
+ (
storage.to_pointer
)
[
- +? {Result.is_not_null};
+ +? {Result.is_not_null};
];
- to_native_array:NATIVE_ARRAY(V) <-
@@ -159,48 +159,48 @@ Section Public
[
-? {! is_empty};
]
- (
+ (
storage
)
[
- +? {Result.is_not_null};
+ +? {Result.is_not_null};
];
-
+
Section ARRAYED_COLLECTION
-
+
- set_upper new_upper:INTEGER <-
(
upper := new_upper;
);
-
+
//
// invariant
//
-
+
// [
// -? {capacity >= (upper - lower + 1)};
// -? {(capacity > 0) ->> {storage.is_not_null}};
// ];
Section Public
-
+
- set_count new_count:INTEGER <-
(
upper := new_count + lower - 1;
);
- - to_native_array_uinteger_8:NATIVE_ARRAY(UINTEGER_8) <-
+ - to_native_array_uinteger_8:NATIVE_ARRAY(UINTEGER_8) <-
(
CONVERT(NATIVE_ARRAY(V),NATIVE_ARRAY(UINTEGER_8)).on storage
);
-
+
- add_last_buffer buf:FAST_ARRAY(UINTEGER_8) from beg:INTEGER to end:INTEGER <-
( + tab:NATIVE_ARRAY(UINTEGER_8);
+ pos_beg,size,new_capacity:INTEGER;
pos_beg := count * element_sizeof; // + ofs_buf;
size := end - beg + 1;
-
+
new_capacity := (pos_beg + end - beg + element_sizeof) / element_sizeof;
(capacity < new_capacity).if {
"cap:".print;
@@ -210,7 +210,7 @@ Section Public
"Crash !\n".print;
crash;
};
-
+
tab := CONVERT(NATIVE_ARRAY(V),NATIVE_ARRAY(UINTEGER_8)).on storage;
tab.copy (buf.storage + beg) to pos_beg until size;
//ofs_buf := (pos_beg + size) % element_sizeof;
diff --git a/lib/internal/portable/collection/avl_constants.li b/lib/internal/portable/collection/avl_constants.li
index 8e77d3d..a636d7a 100644
--- a/lib/internal/portable/collection/avl_constants.li
+++ b/lib/internal/portable/collection/avl_constants.li
@@ -24,13 +24,13 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
Section SELF
-
+
- balanced:INTEGER := 0;
- imbalanced_left:INTEGER := -1;
diff --git a/lib/internal/portable/collection/avl_dictionary_node.li b/lib/internal/portable/collection/avl_dictionary_node.li
index ab49e46..ec45c54 100644
--- a/lib/internal/portable/collection/avl_dictionary_node.li
+++ b/lib/internal/portable/collection/avl_dictionary_node.li
@@ -24,23 +24,23 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Auxiliary class to implement AVL_DICTIONARY.";
-
+
Section Inherit
-
+
+ parent_avl_tree_node:Expanded AVL_TREE_NODE(K);
-
+
- parent_any_avl_dictionary_node:ANY_AVL_DICTIONARY_NODE := ANY_AVL_DICTIONARY_NODE;
-
+
Section Public
-
+
- key:K <- item;
-
+
- set_key i:K <- set_item i;
-
+
Section AVL_DICTIONARY, AVL_DICTIONARY_NODE
-
+
+ value:V;
- set_value v:V <-
@@ -54,7 +54,7 @@ Section AVL_DICTIONARY, AVL_DICTIONARY_NODE
- fast_at k:K :AVL_DICTIONARY_NODE(V, K) <-
// Is element `e' in the tree?
( + result:AVL_DICTIONARY_NODE(V, K);
-
+
(key = k).if {
result := Self;
}.elseif {key == k /*SAFE_EQUAL(K).test key and k*/} then {
@@ -63,7 +63,7 @@ Section AVL_DICTIONARY, AVL_DICTIONARY_NODE
}.elseif {k < key} then {
(left != NULL).if {
result := left.fast_at k;
- };
+ };
} else {
(right != NULL).if {
result := right.fast_at k;
@@ -84,7 +84,7 @@ Section AVL_DICTIONARY, AVL_DICTIONARY_NODE
- key_at v:V :K <-
( + result:K;
-
+
(v == value /*SAFE_EQUAL(V).test v and value*/).if {
result := key;
}.elseif {left != NULL} then {
@@ -97,19 +97,19 @@ Section AVL_DICTIONARY, AVL_DICTIONARY_NODE
- fast_key_at v:V :K <-
( + result:K;
-
+
(v = value).if {
result := key;
}.elseif {left != NULL} then {
- result := left.fast_key_at v;
+ result := left.fast_key_at v;
}.elseif {right != NULL} then {
result := right.fast_key_at v;
};
result
);
-
+
Section AVL_DICTIONARY_NODE
-
+
- occurrences v:V start cnt:INTEGER :INTEGER <-
( + result:INTEGER;
@@ -152,15 +152,15 @@ Section AVL_DICTIONARY
//
// Creation:
//
-
+
- create (v:V,k:K) :SELF <-
( + result:SELF;
-
+
result := clone;
result.make (v,k);
result
);
-
+
- make (v:V,k:K) <-
(
set_balance balanced;
diff --git a/lib/internal/portable/collection/avl_set_node.li b/lib/internal/portable/collection/avl_set_node.li
index bcdecdc..5441356 100644
--- a/lib/internal/portable/collection/avl_set_node.li
+++ b/lib/internal/portable/collection/avl_set_node.li
@@ -19,37 +19,37 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := AVL_SET_NODE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Auxiliary class to implement AVL_SET.";
-
+
// This a classic implementation of an AVL tree (balanced tree first
// designed by Adelson-Velskii and Landis, 1960)
-
+
Section Inherit
-
+
+ parent_avl_tree_node:Expanded AVL_TREE_NODE(V);
-
+
- parent_any_avl_set_node:ANY_AVL_SET_NODE := ANY_AVL_SET_NODE;
Section AVL_SET
-
+
//
// Creation:
//
-
+
- create i:V :SELF <-
( + result:SELF;
-
+
result := clone;
result.make i;
result
);
-
+
- make i:V <-
(
set_balance balanced;
@@ -60,6 +60,6 @@ Section AVL_SET
[
+? {item = i};
];
-
+
diff --git a/lib/internal/portable/collection/avl_tree.li b/lib/internal/portable/collection/avl_tree.li
index c52cd7c..2ed1b84 100644
--- a/lib/internal/portable/collection/avl_tree.li
+++ b/lib/internal/portable/collection/avl_tree.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := AVL_TREE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
// Definition of a mathematical set of comparable objects. All common
// operations on mathematical sets are available.
Section Insert
-
+
- parent_avl_constants:AVL_CONSTANTS := AVL_CONSTANTS;
Section Public
-
+
- debug_string:STRING <-
( + result:STRING;
-
+
(root = NULL).if {
result := "NULL";
} else {
@@ -48,13 +48,13 @@ Section Public
);
+ count:INTEGER;
-
+
Section Public
-
+
//
// Adding and removing:
//
-
+
- remove e:V <-
(
root := do_remove (root, e);
@@ -66,7 +66,7 @@ Section Public
);
Section SELF
-
+
+ root:AVL_TREE_NODE(V);
+ rebalance:BOOLEAN;
@@ -85,7 +85,7 @@ Section SELF
- fast_do_insert n:AVL_TREE_NODE(V) :AVL_TREE_NODE(V) <-
( + result:AVL_TREE_NODE(V);
-
+
(n = NULL).if {
result := new_node;
set_value_and_key result;
@@ -104,7 +104,7 @@ Section SELF
result := n;
};
} else {
- ? {item_memory > n.item};
+ ? {item_memory > n.item};
n.set_right (do_insert (n.right));
(rebalance).if {
result := right_grown n;
@@ -122,7 +122,7 @@ Section SELF
- do_insert n:AVL_TREE_NODE(V) :AVL_TREE_NODE(V) <-
( + result:AVL_TREE_NODE(V);
-
+
(n = NULL).if {
result := new_node;
set_value_and_key result;
@@ -144,7 +144,7 @@ Section SELF
result := n;
};
} else {
- ? {item_memory == n.item};
+ ? {item_memory == n.item};
result := n;
set_value result;
rebalance := FALSE;
@@ -164,7 +164,7 @@ Section SELF
-? {node_height (n.right) - node_height (n.left) + 1 = n.balance};
]
( + result:AVL_TREE_NODE(V);
-
+
(n.balance)
.when imbalanced_left then {
(n.left.balance = imbalanced_left).if {
@@ -205,7 +205,7 @@ Section SELF
+? {Result != NULL};
+? {Result.balance = node_height (Result.right) - node_height (Result.left)};
+? {
- rebalance = (node_height Result > 1 +
+ rebalance = (node_height Result > 1 +
Old node_height (n.right).max (node_height (n.left) - 1))
};
];
@@ -217,7 +217,7 @@ Section SELF
-? {node_height (n.right) - 1 - node_height (n.left) = n.balance};
]
( + result:AVL_TREE_NODE(V);
-
+
(n.balance)
.when imbalanced_right then {
(n.right.balance = imbalanced_right).if {
@@ -237,7 +237,7 @@ Section SELF
n.set_balance balanced;
n.right.set_balance imbalanced_right;
};
-
+
n.right.left.set_balance balanced;
n.set_right (n.right.rotate_right);
};
@@ -259,14 +259,14 @@ Section SELF
+? {Result != NULL};
+? {Result.balance = node_height (Result.right) - node_height (Result.left)};
+? {
- rebalance = (node_height Result > 1 +
+ rebalance = (node_height Result > 1 +
Old node_height (n.left).max (node_height (n.right) - 1))
};
];
- fast_do_remove (n:AVL_TREE_NODE(V),e:V) :AVL_TREE_NODE(V) <-
( + result:AVL_TREE_NODE(V);
-
+
(n = NULL).if {
rebalance := FALSE;
}.elseif {e = n.item} then {
@@ -292,7 +292,7 @@ Section SELF
result := n;
};
} else {
- ? {e > n.item};
+ ? {e > n.item};
n.set_right (do_remove (n.right, e));
(rebalance).if {
result := right_shrunk n;
@@ -303,7 +303,7 @@ Section SELF
result
)
[
- +? {Result = NULL ||
+ +? {Result = NULL ||
{Result.balance = node_height (Result.right) - node_height (Result.left)}
};
+? {rebalance = (node_height Result < Old node_height n)};
@@ -311,7 +311,7 @@ Section SELF
- do_remove (n:AVL_TREE_NODE(V),e:V) :AVL_TREE_NODE(V) <-
( + result:AVL_TREE_NODE(V);
-
+
(n = NULL).if {
rebalance := FALSE;
}.elseif {e < n.item} then {
@@ -356,7 +356,7 @@ Section SELF
-? {n2 != NULL};
]
( + result:AVL_TREE_NODE(V);
-
+
(n2.right = NULL).if {
result := n2.left;
exchange_and_discard (n1, n2);
@@ -371,7 +371,7 @@ Section SELF
result
)
[
- +? {Result = NULL ||
+ +? {Result = NULL ||
{Result.balance = node_height (Result.right) - node_height (Result.left)}};
+? {rebalance = (node_height Result < Old node_height n2)};
];
@@ -383,7 +383,7 @@ Section SELF
-? {node_height (n.right) - node_height (n.left) - 1 = n.balance};
]
( + result:AVL_TREE_NODE(V);
-
+
(n.balance)
.when imbalanced_left then {
n.set_balance balanced;
@@ -410,7 +410,7 @@ Section SELF
n.set_balance imbalanced_left;
n.right.set_balance balanced;
};
-
+
n.right.left.set_balance balanced;
n.set_right (n.right.rotate_right);
}
@@ -427,10 +427,10 @@ Section SELF
};
result
)
- [
+ [
+? {Result != NULL};
+? {Result.balance = node_height (Result.right) - node_height (Result.left)};
- +? {rebalance = (node_height Result < 1 +
+ +? {rebalance = (node_height Result < 1 +
Old node_height (n.right).max (node_height (n.left) + 1))};
];
@@ -441,7 +441,7 @@ Section SELF
-? {node_height (n.right) + 1 - node_height (n.left) = n.balance};
]
( + result:AVL_TREE_NODE(V);
-
+
(n.balance)
.when imbalanced_right then {
n.set_balance balanced;
@@ -467,7 +467,7 @@ Section SELF
.when imbalanced_left then {
n.set_balance imbalanced_right;
n.left.set_balance balanced;
- };
+ };
n.left.right.set_balance balanced;
n.set_left (n.left.rotate_left);
}
@@ -487,7 +487,7 @@ Section SELF
[
+? {Result != NULL};
+? {Result.balance = node_height (Result.right) - node_height (Result.left)};
- +? {rebalance = (node_height Result < 1 +
+ +? {rebalance = (node_height Result < 1 +
Old node_height (n.left).max (node_height (n.right) + 1))};
];
@@ -504,7 +504,7 @@ Section SELF
+? {count = Old count - 1};
+? {rebalance};
];
-
+
- clear_nodes node:AVL_TREE_NODE(V) <-
(
(node.left != NULL).if {
@@ -518,19 +518,19 @@ Section SELF
- node_height node:AVL_TREE_NODE(V) :INTEGER <-
( + result:INTEGER;
-
+
(node != NULL).if {
result := node.height;
};
result
);
-
-Section Public
-
+
+Section Public
+
//
// Looking and searching:
//
-
+
- has e:V :BOOLEAN <-
// Is element `e' in the set?
(
@@ -544,11 +544,11 @@ Section Public
);
Section SELF
-
+
//
// Iterating internals:
//
-
+
- build_map <-
[
"build_needed" -? {map_dirty};
@@ -568,13 +568,13 @@ Section SELF
// Elements in a row for iteration. See `build_map'.
+ map_dirty:BOOLEAN;
- // True when the map needs to be built again for the iterators.
+ // True when the map needs to be built again for the iterators.
// See `build_map'.
Section SELF
-
+
- new_node:AVL_TREE_NODE(V) <-
- (
+ (
a_new_node
);
@@ -583,7 +583,7 @@ Section SELF
deferred;
NULL
);
-
+
- discard_node n:AVL_TREE_NODE(V) <-
[
-? {n != NULL};
@@ -591,11 +591,11 @@ Section SELF
(
deferred;
);
-
- //
+
+ //
// invariant
//
-
+
// [
// -? {map != NULL};
// -? {(! map_dirty) -> (map.count = count)};
diff --git a/lib/internal/portable/collection/avl_tree_node.li b/lib/internal/portable/collection/avl_tree_node.li
index ac08fc3..485e159 100644
--- a/lib/internal/portable/collection/avl_tree_node.li
+++ b/lib/internal/portable/collection/avl_tree_node.li
@@ -19,23 +19,23 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := AVL_TREE_NODE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Auxiliary class to implement AVL_SET.";
-
- // This a classic implementation of an AVL tree (balanced tree first designed
+
+ // This a classic implementation of an AVL tree (balanced tree first designed
// by Adelson-Velskii and Landis (hence A.V.L.), 1960)
Section Insert
-
+
- parent_avl_constants:AVL_CONSTANTS := AVL_CONSTANTS;
Section Public
-
+
- out_in_tagged_out_memory <-
(
item.out_in_tagged_out_memory;
@@ -54,9 +54,9 @@ Section Public
tagged_out_memory.add_last ')';
);
-Section Public
+Section Public
//AVL_TREE_NODE, AVL_TREE
-
+
+ left:AVL_TREE_NODE(V);
+ right:AVL_TREE_NODE(V);
@@ -70,7 +70,7 @@ Section Public
- count:INTEGER <-
( + result:INTEGER;
-
+
result := 1;
(left != NULL).if {
result := result + left.count;
@@ -83,7 +83,7 @@ Section Public
- height:INTEGER <-
( + result:INTEGER;
-
+
(left != NULL).if {
result := left.height;
};
@@ -101,7 +101,7 @@ Section Public
(left != NULL).if {
left.map_in map;
};
- map.add_last Self;
+ map.add_last Self;
(right != NULL).if {
right.map_in map;
};
@@ -113,7 +113,7 @@ Section Public
- has e:V :BOOLEAN <-
// Is element `e' in the tree?
( + result:BOOLEAN;
-
+
result := item == e; //SAFE_EQUAL(V).test item and e;
(! result).if {
(e < item).if {
@@ -123,12 +123,12 @@ Section Public
};
};
result
- );
+ );
- fast_has e:V :BOOLEAN <-
// Is element `e' in the tree?
( + result:BOOLEAN;
-
+
result := item = e;
((! result) && {! item == e /*SAFE_EQUAL(V).test item and e*/}).if {
(e < item).if {
@@ -146,7 +146,7 @@ Section Public
- at e:V :AVL_TREE_NODE(V) <-
// Is element `e' in the tree?
( + result:AVL_TREE_NODE(V);
-
+
(item == e /*SAFE_EQUAL(V).test item and e*/).if {
result := Self;
}.elseif {e < item} then {
@@ -206,16 +206,16 @@ Section Public
];
Section AVL_TREE, AVL_DICTIONARY, AVL_SET
-
+
//
// Rotations:
//
-
+
- rotate_right:AVL_TREE_NODE(V) <-
// Proceeds to some reorganisation and returns the upper node.
( + result:AVL_TREE_NODE(V);
+ left_right:AVL_TREE_NODE(V);
-
+
result := left;
left_right := left.right;
left.set_right Self;
@@ -230,14 +230,14 @@ Section AVL_TREE, AVL_DICTIONARY, AVL_SET
// Proceeds to some reorganisation and returns the upper node.
( + result:AVL_TREE_NODE(V);
+ right_left:AVL_TREE_NODE(V);
-
+
result := right;
right_left := right.left;
- right.set_left Self;
+ right.set_left Self;
set_right right_left;
result
- )
+ )
[
+? {Result != NULL};
];
-
+
diff --git a/lib/internal/portable/collection/collection.li b/lib/internal/portable/collection/collection.li
index abdbdc7..855257f 100644
--- a/lib/internal/portable/collection/collection.li
+++ b/lib/internal/portable/collection/collection.li
@@ -19,73 +19,73 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COLLECTION(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag, 2007 Pierre-Alexandre Voye";
- - comment := "Common abstract definition of a sequenceable collection of objects.";
+ - comment := "Common abstract definition of a sequenceable collection of objects.";
- // Such a collection is traversable using a simple INTEGER index from `lower'
- // to `upper' using `item'. All COLLECTIONs are resizable thanks to
- // `add_last' / `remove_last', `add_first' / `remove_first' as well as
- // `add' / `remove' .<br/> <br/>
+ // Such a collection is traversable using a simple INTEGER index from `lower'
+ // to `upper' using `item'. All COLLECTIONs are resizable thanks to
+ // `add_last' / `remove_last', `add_first' / `remove_first' as well as
+ // `add' / `remove' .<br/> <br/>
//
- // This abstraction provides feature to view a COLLECTION as a stack
- // (as an example by using `add_last', `last', and `remove_last').
+ // This abstraction provides feature to view a COLLECTION as a stack
+ // (as an example by using `add_last', `last', and `remove_last').
// One can also use a COLLECTION as a queue (as an example, by using
- // `add_last', `first' and `remove_first').<br/> <br/>
- //
- // The Lisaac standard library provides five implementations of COLLECTION:
- // ARRAY, FAST_ARRAY, LINKED_LIST and LINKED2_LIST. <br/> Except for creations all
- // implementations have exactly the same behavior. Switching from one
- // implementation to another only change the memory used and the execution
- // time (see header comment of ARRAY, FAST_ARRAY, LINKED_LIST and LINKED2_LIST
- // for more details).<br/> <br/>
-
+ // `add_last', `first' and `remove_first').<br/> <br/>
+ //
+ // The Lisaac standard library provides five implementations of COLLECTION:
+ // ARRAY, FAST_ARRAY, LINKED_LIST and LINKED2_LIST. <br/> Except for creations all
+ // implementations have exactly the same behavior. Switching from one
+ // implementation to another only change the memory used and the execution
+ // time (see header comment of ARRAY, FAST_ARRAY, LINKED_LIST and LINKED2_LIST
+ // for more details).<br/> <br/>
+
Section Inherit
-
+
// - parent_storage:STORAGE := STORAGE;
-
- - parent_traversable:TRAVERSABLE(V) := TRAVERSABLE(V);
-
+
+ - parent_traversable:TRAVERSABLE(V) := TRAVERSABLE(V);
+
Section Public
-
+
//
// Accessing:
//
-
- - item i:INTEGER :V <-
+
+ - item i:INTEGER :V <-
// Item at the corresponding index `i'.
// * Description en Francais : Item à l'index `i'
// * See: `lower', `upper', `valid_index', `put', `swap'
// * Require : None
- // * Ensure : None
+ // * Ensure : None
( + result:V;
-
+
deferred;
result
);
-
+
//
// Writing:
//
-
+
- put element:V to i:INTEGER <-
// Make `element' the item at index `i'.
// * See: `lower', `upper', `valid_index', `item', `swap', `force'.
[
- -? { valid_index i };
+ -? { valid_index i };
]
- (
+ (
deferred;
)
[
+? { item i = element };
+? { count = Old count};
];
-
+
- swap i1:INTEGER with i2:INTEGER <-
// Swap item at index `i1' with item at index `i2'.
// * See: `item', `put'.
@@ -94,7 +94,7 @@ Section Public
-? { valid_index i2 };
]
( + tmp:V;
-
+
tmp := item i1;
put (item i2) to i1;
put tmp to i2;
@@ -104,17 +104,17 @@ Section Public
+? { item i2 = Old item i1 };
+? { count = Old count };
];
-
+
- set_all_with v:V <-
// Set all items with value `v'.
// * See: `set_slice_with'.
- (
+ (
deferred;
)
[
+? { count = Old count };
];
-
+
- set_slice lower_index:INTEGER to upper_index:INTEGER with v:V <-
// Set all items in range [`lower_index' .. `upper_index'] with `v'.
// * See: `set_all_with'.
@@ -122,40 +122,40 @@ Section Public
-? { lower_index <= upper_index };
-? { valid_index lower_index };
-? { valid_index upper_index };
- ]
- (
+ ]
+ (
lower_index.to upper_index do { i:INTEGER;
put v to i;
- };
+ };
)
[
+? { count = Old count };
];
-
+
- clear_all <-
// Set every item to its default value.
- // The `count' is not affected
+ // The `count' is not affected
// see also `clear', `all_default'.
( + value:V;
-
+
set_all_with value;
- )
+ )
[
"Stable upper." +? { upper = Old upper };
"Stable lower." +? { lower = Old lower };
+? { all_default };
];
-
+
//
// Adding:
//
-
+
- add_first element:V <-
// Add a new item in first position : `count' is increased by
// one and all other items are shifted right.
//
// * See: `add_last', `first', `last', `add'.
- (
+ (
deferred;
)
[
@@ -164,12 +164,12 @@ Section Public
-? { lower = Old lower };
-? { upper = 1 + Old upper };
];
-
+
- add_last element:V <-
// Add a new item at the end : `count' is increased by one.
//
// * See: `add_first', `last', `first', `add'.
- (
+ (
deferred;
)
[
@@ -178,7 +178,7 @@ Section Public
+? { lower = Old lower };
+? { upper = 1 + Old upper };
];
-
+
- add element:V to index:INTEGER <-
// Add a new `element' at rank `index' : `count' is increased
// by one and range [`index' .. `upper'] is shifted right
@@ -188,7 +188,7 @@ Section Public
[
-? { index.in_range lower to (upper + 1)};
]
- (
+ (
deferred;
)
[
@@ -196,7 +196,7 @@ Section Public
+? { count = 1 + Old count };
+? { upper = 1 + Old upper };
];
-
+
- append_collection other:COLLECTION(V) <-
// Append `other' to Current.
//
@@ -204,15 +204,15 @@ Section Public
[
-? { other != NULL };
]
- (
- (other.lower).to (other.upper) do { i:INTEGER;
+ (
+ (other.lower).to (other.upper) do { i:INTEGER;
add_last (other.item i);
- };
+ };
)
[
+? { count = other.count + Old count };
];
-
+
- copy_collection other:COLLECTION(V) <-
// Copy `other' to Current.
//
@@ -220,26 +220,26 @@ Section Public
[
-? { other != NULL };
]
- ( + same:SELF;
-
+ ( + same:SELF;
+
same ?= other;
(same != NULL).if {
copy same;
- } else {
+ } else {
clear;
- (other.lower).to (other.upper) do { i:INTEGER;
+ (other.lower).to (other.upper) do { i:INTEGER;
add_last (other.item i);
- };
+ };
};
)
[
+? { count = other.count };
- ];
-
+ ];
+
//
// Modification:
//
-
+
- force element:V to index:INTEGER <-
// Make `element' the item at `index', enlarging the collection if
// necessary (new bounds except `index' are initialized with
@@ -249,37 +249,37 @@ Section Public
[
+? { index >= lower};
]
- (
+ (
deferred;
)
[
-? { upper = index.max (Old upper) };
-? { item index = element };
];
-
+
- copy other:SELF <-
// Reinitialize by copying all the items of `other'.
(
deferred;
);
-
+
- from_collection model:COLLECTION(V) <-
// Initialize the current object with the contents of `model'.
[
-? { model != NULL };
"Useful work." -? {model != Self};
]
- (
+ (
deferred;
)
[
+? { count = model.count };
];
-
+
//
// Removing:
//
-
+
- remove_first <-
// Remove the `first' element of the collection.
//
@@ -287,14 +287,14 @@ Section Public
[
-? { ! is_empty };
]
- (
- deferred;
+ (
+ deferred;
)
[
+? { count = Old count - 1};
+? {(lower = Old lower + 1) ^ (upper = Old upper - 1)};
];
-
+
- remove_head n:INTEGER <-
// Remove the `n' elements of the collection.
//
@@ -310,7 +310,7 @@ Section Public
+? { count = Old count - n };
+? {(lower = Old lower + n) ^ (upper = Old upper - n)};
];
-
+
- remove index:INTEGER <-
// Remove the item at position `index'. Followings items
// are shifted left by one position.
@@ -319,14 +319,14 @@ Section Public
[
-? { valid_index index };
]
- (
- deferred;
+ (
+ deferred;
)
[
+? { count = Old count - 1};
+? { upper = Old upper - 1};
];
-
+
- remove_last <-
// Remove the `last' item.
//
@@ -334,14 +334,14 @@ Section Public
[
-? {! is_empty};
]
- (
- deferred;
+ (
+ deferred;
)
[
+? { count = Old count - 1 };
+? { upper = Old upper - 1 };
];
-
+
- remove_tail n:INTEGER <-
// Remove the last `n' item(s).
//
@@ -357,7 +357,7 @@ Section Public
+? {count = Old count - n};
+? {upper = Old upper - n};
];
-
+
- clear <-
// Discard all items in order to make it `is_empty'.
//
@@ -368,27 +368,27 @@ Section Public
[
"Is empty." +? { count = 0 };
];
-
+
//
// Looking and Searching:
//
-
+
- has x:V :BOOLEAN <-
// Look for `x' using `equal' for comparison.
- //
+ //
// * See: `fast_has', `index_of start', `fast_index_of start'.
(
valid_index (first_index_of x)
);
-
+
- fast_has x:V :BOOLEAN <-
// Look for `x' using basic `=' for comparison.
- //
+ //
// * See: `has', `fast_index_of start', `index_of start'.
(
valid_index (fast_first_index_of x)
);
-
+
- first_index_of element:V :INTEGER <-
// Give the index of the first occurrence of `element' using
// `==' for comparison.
@@ -397,31 +397,31 @@ Section Public
// * Parameter:
// `element' : element to search.
// * Require: `element' not null.
- // * Ensure: Very good fonction
+ // * Ensure: Very good fonction
//
- // * See: `fast_first_index_of', `index_of start', `last_index_of',
+ // * See: `fast_first_index_of', `index_of start', `last_index_of',
// `reverse_index_of'.
- //
- // * Description en Francais: Donne l'index de la premiere occurence de `element'
+ //
+ // * Description en Francais: Donne l'index de la premiere occurence de `element'
// en utilisant `==' pour la comparaison.
// Renvoi `upper + 1' lorsque `element' est absent.
//
- // * Parametre:
+ // * Parametre:
// `element' : L'element que l'on veut chercher.
- // * Necessite: `element' pas null.
- // * Voir: `fast_first_index_of', `index_of', `last_index_of',
+ // * Necessite: `element' pas null.
+ // * Voir: `fast_first_index_of', `index_of', `last_index_of',
// `reverse_index_of'.
- (
+ (
deferred;
0
)
[
"Definition." +? {Result = index_of element start lower};
- ];
-
+ ];
+
- index_of element:V start start_index:INTEGER :INTEGER <-
- // Using `is_equal' for comparison, gives the index of the first occurrence
- // of `element' at or after `start_index'. Answer `upper + 1' when `element'
+ // Using `is_equal' for comparison, gives the index of the first occurrence
+ // of `element' at or after `start_index'. Answer `upper + 1' when `element'
// when the search fail.
//
// * See: `fast_index_of', `reverse_index_of', `first_index_of'.
@@ -434,11 +434,11 @@ Section Public
//+? {valid_index Result ->> { SAFE_EQUAL(V).test element with (item Result)}};
+? {valid_index Result ->> {element == item Result}};
];
-
+
- reverse_index_of element:V start start_index:INTEGER :INTEGER <-
- // Using `is_equal' for comparison, gives the index of the first occurrence of
- // `element' at or before `start_index'. Search is done in reverse direction,
- // which means from the `start_index' down to the `lower' index .
+ // Using `is_equal' for comparison, gives the index of the first occurrence of
+ // `element' at or before `start_index'. Search is done in reverse direction,
+ // which means from the `start_index' down to the `lower' index .
// Answer `lower -1' when the search fail.
//
// * See: `fast_reverse_index_of', `last_index_of', `index_of'.
@@ -455,9 +455,9 @@ Section Public
];
- last_index_of element:V :INTEGER <-
- // Using `is_equal' for comparison, gives the index of the last occurrence
- // of `element' at or before `upper'. Search is done in reverse direction,
- // which means from the `upper' down to the `lower' index . Answer `lower -1'
+ // Using `is_equal' for comparison, gives the index of the last occurrence
+ // of `element' at or before `upper'. Search is done in reverse direction,
+ // which means from the `upper' down to the `lower' index . Answer `lower -1'
// when the search fail.
//
// * See: `fast_last_index_of', `reverse_index_of', `index_of'.
@@ -469,7 +469,7 @@ Section Public
];
- fast_first_index_of element:V :INTEGER <-
- // Give the index of the first occurrence of `element' using basic `='
+ // Give the index of the first occurrence of `element' using basic `='
// for comparison. Answer `upper + 1' when `element' is not inside.
//
// * See: `first_index_of', `last_index_of', `fast_last_index_of'.
@@ -482,8 +482,8 @@ Section Public
];
- fast_index_of element:V start start_index:INTEGER :INTEGER <-
- // Using basic `=' for comparison, gives the index of the first occurrence
- // of `element' at or after `start_index'. Answer `upper + 1' when `element'
+ // Using basic `=' for comparison, gives the index of the first occurrence
+ // of `element' at or after `start_index'. Answer `upper + 1' when `element'
// when the search fail.
//
// * See: `index_of', `fast_reverse_index_of', `fast_first_index_of'.
@@ -497,9 +497,9 @@ Section Public
];
- fast_reverse_index_of element:V start start_index:INTEGER :INTEGER <-
- // Using basic `=' comparison, gives the index of the first occurrence
- // of `element' at or before `start_index'. Search is done in reverse
- // direction, which means from the `start_index' down to the `lower'
+ // Using basic `=' comparison, gives the index of the first occurrence
+ // of `element' at or before `start_index'. Search is done in reverse
+ // direction, which means from the `start_index' down to the `lower'
// index . Answer `lower -1' when the search fail.
//
// * See: `reverse_index_of', `fast_index_of', `fast_last_index_of'.
@@ -516,9 +516,9 @@ Section Public
];
- fast_last_index_of element:V :INTEGER <-
- // Using basic `=' for comparison, gives the index of the last occurrence
- // of `element' at or before `upper'. Search is done in reverse direction,
- // which means from the `upper' down to the `lower' index . Answer `lower -1'
+ // Using basic `=' for comparison, gives the index of the last occurrence
+ // of `element' at or before `upper'. Search is done in reverse direction,
+ // which means from the `upper' down to the `lower' index . Answer `lower -1'
// when the search fail.
//
// * See: `fast_reverse_index_of', `last_index_of'.
@@ -528,24 +528,24 @@ Section Public
[
"Definition." +? {Result = fast_reverse_index_of element start upper};
];
-
+
//
// Looking and comparison:
//
-
+
- Self:SELF '==' Right 60 other:E :BOOLEAN <-
// Do both collections have the same `lower', `upper', and
// items?
// The basic `=' is used for comparison of items.
//
// * See: `is_equal_map', `same_items'.
- (
+ (
deferred;
FALSE
)
[ + same:SELF;
same ?= other;
- +? {(same = NULL) || {Result ->> {(lower = same.lower) & (upper = same.upper)}} };
+ +? {(same = NULL) || {Result ->> {(lower = same.lower) & (upper = same.upper)}} };
];
- Self:SELF '~=' Right 60 other:COLLECTION(V) :BOOLEAN <-
@@ -554,38 +554,38 @@ Section Public
// The basic `=' is used for comparison of items.
//
// * See: `is_equal_map', `same_items'.
- (
+ (
deferred;
FALSE
)
- [
- +? { Result ->> {(lower = other.lower) & (upper = other.upper)} };
+ [
+ +? { Result ->> {(lower = other.lower) & (upper = other.upper)} };
];
-
+
- is_equal_map other:SELF :BOOLEAN <-
// Do both collections have the same `lower', `upper', and
// items?
// Feature `==' is used for comparison of items.
//
// * See: `==', `same_items'.
- (
+ (
deferred;
FALSE
)
[
- +? { result -> ((lower = other.lower) & (upper = other.upper)) };
+ +? { result -> ((lower = other.lower) & (upper = other.upper)) };
];
-
+
- all_default:BOOLEAN <-
// Do all items have their type's default value?
// Note: for non NULL items, the test is performed with the `is_default' predicate.
//
// * See: `clear_all'.
- (
+ (
deferred;
FALSE
);
-
+
- same_items other:COLLECTION(V) :BOOLEAN <-
// Do both collections have the same items? The basic `=' is used
// for comparison of items and indices are not considered (for
@@ -598,7 +598,7 @@ Section Public
]
( + result:BOOLEAN;
+ i,j:INTEGER;
-
+
(count = other.count).if {
result := TRUE;
i := lower;
@@ -607,52 +607,52 @@ Section Public
result := (item i = other.item j);
i := i + 1;
j := j + 1;
- };
- };
+ };
+ };
result
)
[
- +? { result -> (count = other.count)};
+ +? { result -> (count = other.count)};
];
-
+
- occurrences element:V :INTEGER <-
// Number of occurrences of `element' using `equal' for comparison.
- //
+ //
// * See: `fast_occurrences', `index_of'.
- (
+ (
deferred;
0
)
[
+? { result >= 0 };
];
-
+
- fast_occurrences element:V :INTEGER <-
// Number of occurrences of `element' using basic `=' for comparison.
- //
+ //
// * See: `occurrences', `index_of'.
- (
+ (
deferred;
0
)
- [
+ [
+? { result >= 0 };
];
-
+
//
// Printing:
//
-
+
- fill_tagged_out_memory <-
( + i:INTEGER;
+ v:V;
-
+
tagged_out_memory.append "lower: ";
lower.append_in tagged_out_memory;
tagged_out_memory.append " upper: ";
upper.append_in tagged_out_memory;
tagged_out_memory.append " [";
-
+
i := lower;
{(i > upper) || {tagged_out_memory.count > 2048}}.until_do {
v := item i;
@@ -660,24 +660,24 @@ Section Public
tagged_out_memory.append "NULL";
} else {
v.out_in_tagged_out_memory;
- };
+ };
(i < upper).if {
tagged_out_memory.add_last ' ';
- };
+ };
i := i + 1;
- };
+ };
(i <= upper).if {
tagged_out_memory.append " ...";
- };
+ };
tagged_out_memory.add_last ']';
);
-
+
//
// Agents based features:
//
-
+
- foreach action:{V; } <- do_all action;
-
+
- do_all action:{V; } <-
// Apply `action' to every item of `Self'.
//
@@ -687,12 +687,12 @@ Section Public
action.value (item i);
};
);
-
+
- foreach action:{V; } while test:{V; BOOLEAN} <-
// Apply `action' to every item of `Self' while test is true
( + i:INTEGER;
+ tst:BOOLEAN;
-
+
i := lower;
{(i <= upper) && {test.value (item i)}}.while_do {
action.value (item i);
@@ -704,7 +704,7 @@ Section Public
// Apply `action' to every item of `Self' until test is true
( + i:INTEGER;
+ tst:BOOLEAN;
-
+
i := lower;
{(i <= upper) && {! test.value (item i)}}.while_do {
action.value (item i);
@@ -718,18 +718,18 @@ Section Public
test.value (item i).if {
action.value (item i);
};
- };
+ };
);
-
+
- is_all test:{V; BOOLEAN} :BOOLEAN <- for_all test;
-
+
- for_all test:{V; BOOLEAN} :BOOLEAN <-
// Do all items satisfy `test'?
//
// * See: `do_all', `exists'.
( + i:INTEGER;
+ result:BOOLEAN;
-
+
result := TRUE;
i := lower;
{(! result) || {i > upper}}.until_do {
@@ -738,14 +738,14 @@ Section Public
};
result
);
-
+
- exists test:{V; BOOLEAN} :BOOLEAN <-
// Does at least one item satisfy `test'?
//
// * See: `do_all', `for_all'.
( + i:INTEGER;
+ result:BOOLEAN;
-
+
i := lower;
{(result) || {i > upper}}.until_do {
result := test.value (item i);
@@ -753,11 +753,11 @@ Section Public
};
result
);
-
- //
+
+ //
// Traditionals features (in functional languages)
//
-
+
- filter test:{V; BOOLEAN} in other:SELF <-
// Filter all element which `test' element is true and put the result in `other'
// * Require : `other' not null
@@ -765,7 +765,7 @@ Section Public
-? { other != NULL };
]
( + elt:V;
-
+
lower.to upper do { j:INTEGER;
elt := item j;
(test.value elt).if {
@@ -787,16 +787,16 @@ Section Public
( + result,elt:V;
+ is_end:BOOLEAN;
+ j:INTEGER;
-
- j := lower;
+
+ j := lower;
{(j <= upper) && {is_end}}.while_do {
elt := item j;
(is_end := test.value elt).if {
result := elt;
};
- j := j + 1;
- };
-
+ j := j + 1;
+ };
+
result
);
@@ -813,19 +813,19 @@ Section Public
- fold_right function:{(V,V);} with element:V :V <-
// fold left with function `function' beginning with `element'
( + result:V;
-
+
result := element;
upper.downto lower do { j:INTEGER;
result := function.value (result,item j);
};
result
);
-
+
- merge other:SELF with test:{(V,V); BOOLEAN} :SELF<-
// Return the intersection between `Self' and `other' according to `test' function
( + result:SELF;
+ elt:V;
-
+
result := SELF.create 0;
(other.lower).to (other.upper) do { i:INTEGER;
lower.to upper do { j:INTEGER;
@@ -841,12 +841,12 @@ Section Public
//
// Other features
//
-
+
- unique:SELF <-
// Remove every duplicated element in the collection
// Only the first duplicate will be kept
( + j,i:INTEGER;
-
+
j := lower;
{j <= upper}.while_do {
i := upper;
@@ -859,12 +859,12 @@ Section Public
j := j + 1;
};
);
-
+
- fast_unique:SELF <-
// Remove every duplicated element in the collection
// Only the first duplicate will be kept
( + j,i:INTEGER;
-
+
j := lower;
{j <= upper}.while_do {
i := upper;
@@ -883,27 +883,27 @@ Section Public
// using `equal' for comparison.
//
// * See: `fast_replace_all', `move'.
- (
+ (
deferred;
)
[
+? { count = Old count};
+? { (! SAFE_EQUAL(V).test old_value with new_value) ->> {occurrences old_value = 0}};
- ];
-
+ ];
+
- fast_replace_all old_value:V with new_value:V <-
// Replace all occurrences of the element `old_value' by `new_value'
// using operator `=' for comparison.
//
// * See: `replace_all', `move'.
- (
+ (
deferred;
)
[
+? { count = Old count };
+? { (old_value != new_value) ->> {occurrences old_value = 0}};
- ];
-
+ ];
+
- move lower_index:INTEGER to upper_index:INTEGER by distance:INTEGER <-
// Move range `lower_index' .. `upper_index' by `distance'
// positions. Negative distance moves towards lower indices.
@@ -917,25 +917,25 @@ Section Public
-? { valid_index (upper_index + distance) };
]
( + default_value:V;
-
+
(distance != 0).if {
- (distance < 0).if {
+ (distance < 0).if {
lower_index.to upper_index do { i:INTEGER;
put (item i) to (i + distance);
put default_value to i;
- };
+ };
} else {
upper_index.downto lower_index do { i:INTEGER;
put (item i) to (i + distance);
put default_value to i;
- };
+ };
};
- };
+ };
)
[
+? {count = Old count};
];
-
+
- slice min:INTEGER to max:INTEGER :SELF <-
// New collection consisting of items at indexes in [`min'..`max'].
// Result has the same dynamic type as `Current'.
@@ -946,13 +946,13 @@ Section Public
// * require: `min' inferior or equal to `max' + 1
// * ensure: `Self' is same dynamic type of Result
// * ensure: Result size is equal to `max' - `min' + 1
- // * ensure: Result first element index is same as `Self' first element index
+ // * ensure: Result first element index is same as `Self' first element index
[
-? { lower <= min };
-? { max <= upper };
-? { min <= max + 1 };
]
- (
+ (
deferred;
NULL
)
@@ -961,21 +961,21 @@ Section Public
+? { Result.count = max - min + 1};
+? { Result.lower = lower };
];
-
+
- reverse <-
// Reverse the order of the elements.
(
deferred;
)
- [
+ [
+? { count = Old count };
];
-
+
//
// Invariant.
//
-
+
// [
// -? { lower <= upper + 1 };
// ];
-
+
diff --git a/lib/internal/portable/collection/collection2.li b/lib/internal/portable/collection/collection2.li
index 48c2371..2b81b6e 100644
--- a/lib/internal/portable/collection/collection2.li
+++ b/lib/internal/portable/collection/collection2.li
@@ -19,92 +19,92 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COLLECTION2(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Abstract definition of a 2 dimensional collection of elements of type E.";
-
- // The Lisaac standard library provides two implementations of COLLECTION2:
+
+ // The Lisaac standard library provides two implementations of COLLECTION2:
// ARRAY2 and FAST_ARRAY2.
// All implementations have exactly the same behavior. Switching from one implementation to
// another only change the memory used and the execution time.
-
+
Section Inherit
-
+
- parent_safe_equal:SAFE_EQUAL(V) := SAFE_EQUAL(V);
-
+
Section Public
-
+
//
// Indexing:
//
-
+
- lower1:INTEGER <-
// First Lower index bounds.
(
deferred;
0
);
-
+
- lower2 :INTEGER <-
// Second Lower index bounds.
(
deferred;
0
);
-
+
- line_minimum:INTEGER <- lower1;
// Equivalent of `lower1'.
- column_minimum:INTEGER <- lower2;
// Equivalent of `lower2'.
-
+
- upper1:INTEGER <-
// First Upper index bounds.
(
deferred;
0
);
-
+
- upper2 :INTEGER <-
// Second Upper index bounds.
- (
+ (
deferred;
0
);
-
+
- line_maximum:INTEGER <- upper1;
// Equivalent of `upper1'.
- column_maximum:INTEGER <- upper2;
// Equivalent of `upper2'.
-
+
//
// Reading:
//
-
+
- item (line, column:INTEGER) :V <-
[ -? { valid_index (line,column) }; ]
( + result:V;
-
+
deferred;
result
);
-
+
//
// Writing:
//
-
+
- put element:V to (line, column:INTEGER) <-
[ -? { valid_index (line,column) }; ]
(
deferred;
)
[ +? { item (line,column) = element}; ];
-
+
- force element:V to (line, column:INTEGER) <-
// Put `element' at position (`line',`column'). Collection is
// resized first when (`line',`column') is not inside current
@@ -120,63 +120,63 @@ Section Public
+? { item (line,column) = element };
+? { count >= Old count };
];
-
+
//
// Index validity:
//
-
- - valid_line line:INTEGER :BOOLEAN <-
+
+ - valid_line line:INTEGER :BOOLEAN <-
(
(lower1 <= line) && { line <= upper1}
)
[
+? { Result = ((lower1 <= line) && { line <= upper1 }) };
];
-
+
- valid_index1 line:INTEGER :BOOLEAN <-
(
valid_line line
);
-
- - valid_column column:INTEGER :BOOLEAN <-
- (
- (lower2 <= column) && {column <= upper2}
+
+ - valid_column column:INTEGER :BOOLEAN <-
+ (
+ (lower2 <= column) && {column <= upper2}
)
- [
+ [
+? { Result = ((lower2 <= column) && {column <= upper2}) };
];
-
+
- valid_index2 column:INTEGER :BOOLEAN <-
(
valid_column column
);
-
+
- valid_index (line, column:INTEGER) :BOOLEAN <-
(
- (lower1 <= line ) && {line <= upper1 } &&
+ (lower1 <= line ) && {line <= upper1 } &&
{lower2 <= column} && {column <= upper2}
)
- [
+ [
+? { Result = ((valid_line line) && {valid_column column}) };
];
-
+
//
// Counting:
//
-
+
- count1:INTEGER <-
// Size of the first dimension.
(
deferred;
0
- )
+ )
[
+? { Result = upper1 - lower1 + 1 };
];
-
+
- line_count:INTEGER <- count1;
// Equivalent of `count1'.
-
+
- count2 :INTEGER <-
// Size of the second dimension.
(
@@ -186,10 +186,10 @@ Section Public
[
+? { Result = upper2 - lower2 + 1 };
];
-
+
- column_count :INTEGER <- count2;
// Equivalent of `count2'.
-
+
- count:INTEGER <-
// Total number of elements.
(
@@ -199,7 +199,7 @@ Section Public
[
+? { Result = line_count * column_count };
];
-
+
- swap (line1, column1:INTEGER) with (line2, column2:INTEGER) <-
// Swap the element at index (`line1',`column1') with the
// the element at index (`line2',`column2').
@@ -215,7 +215,7 @@ Section Public
+? { item (line2,column2) = Old item (line1,column1) };
+? { count = Old count };
];
-
+
- set_all_with v:V <-
// Set all item with value `v'.
(
@@ -224,22 +224,22 @@ Section Public
[
+? { count = Old count };
];
-
+
- clear_all <-
// Set all items to default values.
( + value:V;
-
+
set_all_with value;
)
[
+? { count = Old count };
+? { all_default };
];
-
+
//
// Creating or initializing:
//
-
+
- from_collection2 model:COLLECTION2(V) <-
// Uses `model' to initialize Current.
[ -? { model != NULL }; ]
@@ -250,7 +250,7 @@ Section Public
+? { count1 = model.count1 };
+? { count2 = model.count2 };
];
-
+
- from_model model:COLLECTION(COLLECTION(V)) <-
// The `model' is used to fill line by line Current.
// Assume all sub-collections of `model' have the same
@@ -266,7 +266,7 @@ Section Public
+? { count1 = model.count };
+? { count2 = model.first.count };
];
-
+
- copy_collection other:COLLECTION2(V) <-
// Copy `other' to Current.
//
@@ -274,27 +274,27 @@ Section Public
[
-? { other != NULL };
]
- ( + same:SELF;
-
+ ( + same:SELF;
+
same ?= other;
(same != NULL).if {
copy same;
- } else {
+ } else {
not_yet_implemented;
};
);
-
+
//
// Looking and comparison:
//
-
+
- all_default:BOOLEAN <-
// Do all items have their type's default value?
(
deferred
FALSE
);
-
+
- Self:SELF '==' other:COLLECTION2(V) :BOOLEAN <-
// Do both collections have the same `lower1', `lower2', `upper1' and `upper2', and items?
// The basic `=' is used for comparison of items.
@@ -302,10 +302,10 @@ Section Public
// See also `is_equal_map'.
( + line, column:INTEGER;
+ result:BOOLEAN;
-
+
(
- (lower1 = other.lower1) &&
- {upper1 = other.upper1} &&
+ (lower1 = other.lower1) &&
+ {upper1 = other.upper1} &&
{lower2 = other.lower2} &&
{upper2 = other.upper2}
).if {
@@ -329,10 +329,10 @@ Section Public
//
// See also `is_equal'.
( + line, column:INTEGER;
-
+
(
- (lower1 = other.lower1) &&
- {upper1 = other.upper1} &&
+ (lower1 = other.lower1) &&
+ {upper1 = other.upper1} &&
{lower2 = other.lower2} &&
{upper2 = other.upper2}
).if {
@@ -348,16 +348,16 @@ Section Public
};
};
result
- );
-
+ );
+
//
// Printing:
//
-
+
- fill_tagged_out_memory <-
( + line:INTEGER;
+v:V;
-
+
tagged_out_memory.append "lower1:";
lower1.append_in tagged_out_memory;
tagged_out_memory.append " upper1:";
@@ -367,34 +367,34 @@ Section Public
tagged_out_memory.append " upper2:";
upper2.append_in tagged_out_memory;
tagged_out_memory.append " [\n";
-
+
line := lower1;
{ (line > upper1) || { tagged_out_memory.count > 4096 }}.until_do {
tagged_out_memory.append(once "line ");
line.append_in(tagged_out_memory);
tagged_out_memory.append(once "\t:");
-
+
lower2.to upper2 do { column:INTEGER;
v := item (line,column);
(v = NULL).if {
tagged_out_memory.append(once "NULL");
} else {
v.out_in_tagged_out_memory;
- };
+ };
tagged_out_memory.add_last ' ';
- };
+ };
tagged_out_memory.add_last '\n';
line := line + 1;
- };
+ };
(valid_line line).if {
tagged_out_memory.append(once "......\n");
- };
+ };
);
-
+
//
// Miscellaneous features:
//
-
+
- occurrences elt:V :INTEGER <-
// Number of occurrences using `equal'.
//
@@ -404,7 +404,7 @@ Section Public
0
)
[ +? { Result >= 0 }; ];
-
+
- fast_occurrences elt:V :INTEGER <-
// Number of occurrences using `='.
//
@@ -414,7 +414,7 @@ Section Public
0
)
[ +? { Result >= 0 }; ];
-
+
- has x:V :BOOLEAN <-
// Search if a element x is in the array using `equal'.
//
@@ -423,14 +423,14 @@ Section Public
deferred;
FALSE
);
-
+
- fast_has x:V :BOOLEAN <-
// Search if a element x is in the array using `='.
(
deferred;
FALSE
);
-
+
- replace_all old_value:V with new_value:V <-
// Replace all occurences of the element `old_value' by `new_value'
// using `equal' for comparison.
@@ -439,11 +439,11 @@ Section Public
(
deferred;
)
- [
+ [
+? { count = Old count };
+? { occurrences old_value = 0 };
];
-
+
- fast_replace_all old_value:V with new_value:V <-
// Replace all occurences of the element `old_value' by `new_value'
// using operator `=' for comparison.
@@ -456,36 +456,35 @@ Section Public
+? { count = Old count };
+? { fast_occurrences old_value = 0 };
];
-
+
- sub_collection2 (line_min,column_min:INTEGER) to (line_max,column_max:INTEGER) :SELF <-
// Create a new object using selected area of `Current'.
[
-? { valid_index (line_min,column_min) };
-? { valid_index (line_max,column_max) };
]
- (
+ (
deferred;
NULL
)
- [
+ [
+? { result != NULL };
];
-
+
- set_area (line_min,column_min:INTEGER) to (line_max,column_max:INTEGER) with element:V <-
// Set all the elements of the selected area rectangle with `element'.
[
-? { valid_index (line_min,column_min) };
-? { valid_index (line_max,column_max) };
]
- (
+ (
line_min.to line_max do { line:INTEGER;
column_min.to column_max do { column:INTEGER;
put element to (line,column);
- };
- };
+ };
+ };
)
[
+? { count = Old count };
];
-
-
\ No newline at end of file
+
diff --git a/lib/internal/portable/collection/collection3.li b/lib/internal/portable/collection/collection3.li
index 561bd5f..47448db 100644
--- a/lib/internal/portable/collection/collection3.li
+++ b/lib/internal/portable/collection/collection3.li
@@ -19,108 +19,108 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COLLECTION3(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Abstract definition of a 3 dimensional collection of elements of type E.";
-
- // The Lisaac standard library provides two implementations of COLLECTION3: ARRAY3
- // and FAST_ARRAY3. All implementations have exactly the same behavior.
- // Switching from one implementation to another only change the memory
+
+ // The Lisaac standard library provides two implementations of COLLECTION3: ARRAY3
+ // and FAST_ARRAY3. All implementations have exactly the same behavior.
+ // Switching from one implementation to another only change the memory
// used and the execution time.
-
+
Section Inherit
-
+
- parent_safe_equal:SAFE_EQUAL(V) := SAFE_EQUAL(V);
-
+
Section Public
-
+
- lower1:INTEGER <-
// Lower index bound for dimension 1.
(
deferred;
0
);
-
+
- lower2:INTEGER <-
// Lower index bound for dimension 2.
(
deferred;
0
);
-
+
- lower3:INTEGER <-
// Lower index bound for dimension 3.
(
deferred;
0
);
-
+
- line_minimum:INTEGER <- lower1;
// Equivalent of `lower1'.
-
+
- column_minimum:INTEGER <- lower2;
// Equivalent of `lower2'.
-
+
- depth_minimum:INTEGER <- lower3;
// Equivalent of `lower3'.
-
+
- upper1:INTEGER <-
// Upper index bound for dimension 1.
(
deferred;
0
);
-
+
- upper2:INTEGER <-
// Upper index bound for dimension 2.
(
deferred;
0
);
-
+
- upper3:INTEGER <-
// Upper index bound for dimension 3.
(
deferred;
0
);
-
+
- line_maximum:INTEGER <- upper1;
// Equivalent of `upper1'.
-
+
- column_maximum:INTEGER <- upper2;
// Equivalent of `upper2'.
-
+
- depth_maximum:INTEGER <- upper3;
// Equivalent of `upper3'.
-
+
//
// Reading:
//
- item (line, column, depth:INTEGER) :V <-
[ -? { valid_index (line,column,depth) }; ]
- ( + result:V;
-
+ ( + result:V;
+
deferred;
result
);
-
+
//
// Writing:
//
- put element:V to (line, column, depth:INTEGER) <-
[ -? {valid_index (line,column,depth) }; ]
- (
+ (
deferred;
)
[ +? { item(line,column,depth) = element}; ];
-
+
- force element:V to (line, column, depth:INTEGER) <-
// Put `element' at position (`line',`column',`depth').
// Collection is resized first when (`line',`column',`depth')
@@ -138,46 +138,46 @@ Section Public
+? { item (line,column,depth) = element };
+? { count >= Old count };
];
-
+
//
// Index validity:
//
-
+
- valid_line line:INTEGER :BOOLEAN <-
(
(lower1 <= line) && {line <= upper1}
)
[ +? {Result = (lower1 <= line) && {line <= upper1}}; ];
-
+
- valid_index1 line:INTEGER :BOOLEAN <- valid_line line;
-
+
- valid_column column:INTEGER :BOOLEAN <-
(
(lower2 <= column) && {column <= upper2}
)
[ +? {Result = (lower2 <= column) && {column <= upper2}}; ];
-
+
- valid_index2 column:INTEGER :BOOLEAN <- valid_column column;
-
+
- valid_depth depth:INTEGER :BOOLEAN <-
(
(lower3 <= depth) && {depth <= upper3}
)
[ +? {Result = (lower3 <= depth) && {depth <= upper3}}; ];
-
+
- valid_index3 depth:INTEGER :BOOLEAN <- valid_depth depth;
-
+
- valid_index (line, column, depth:INTEGER) :BOOLEAN <-
(
- (lower1 <= line ) && {line <= upper1} && {lower2 <= column} &&
+ (lower1 <= line ) && {line <= upper1} && {lower2 <= column} &&
{column <= upper2} && {lower3 <= depth } && {depth <= upper3}
)
[ +? {Result = (valid_line line) && {valid_column column} && {valid_depth depth}}; ];
-
+
//
// Counting:
//
-
+
- count1:INTEGER <-
// Size of the first dimension.
(
@@ -185,10 +185,10 @@ Section Public
0
)
[ +? {Result = upper1 - lower1 + 1}; ];
-
+
- line_count:INTEGER <- count1;
// Equivalent of `count1'.
-
+
- count2:INTEGER <-
// Size of the second dimension.
(
@@ -196,10 +196,10 @@ Section Public
0
)
[ +? {Result = upper2 - lower2 + 1}; ];
-
+
- column_count:INTEGER <- count2;
// Equivalent of `count2'.
-
+
- count3:INTEGER <-
// Size of the third dimension.
(
@@ -207,10 +207,10 @@ Section Public
0
)
[ +? {Result = upper3 - lower3 + 1}; ];
-
+
- depth_count:INTEGER <- count3;
// Equivalent of `count3'.
-
+
- count:INTEGER <-
// Total number of elements.
(
@@ -226,7 +226,7 @@ Section Public
-? { valid_index (line1,column1,depth1)};
-? { valid_index (line2,column2,depth2)};
]
- (
+ (
deferred;
)
[
@@ -234,7 +234,7 @@ Section Public
+? {item(line2,column2,depth2) = Old item(line1,column1,depth1)};
+? {count = Old count};
];
-
+
- set_all_with v:V <-
// Set all item with value `v'.
(
@@ -244,23 +244,23 @@ Section Public
- clear_all <-
// Set all items to default values.
- ( + value:V;
-
+ ( + value:V;
+
set_all_with value;
)
- [
+ [
+? {count = Old count};
+? {all_default};
];
-
+
//
// Creating or initializing:
//
-
+
- from_collection3 model:COLLECTION3(V) <-
// Uses `model' to initialize self.
[ -? {model != NULL}; ]
- (
+ (
deferred;
)
[
@@ -268,13 +268,13 @@ Section Public
+? {count2 = model.count2};
+? {count3 = model.count3};
];
-
+
- from_model model:COLLECTION(COLLECTION(COLLECTION(V))) <-
// The `model' is used to fill line by line self.
// Assume all sub-collections have the same
// dimension.
[ -? { model != NULL }; ]
- (
+ (
deferred;
)
[
@@ -282,7 +282,7 @@ Section Public
+? {count2 > 0 ->> {count2 = model.first.count}};
+? {count3 > 0 ->> {count3 = model.first.first.count}};
];
-
+
//
// Looking and comparison:
//
@@ -292,7 +292,7 @@ Section Public
(
deferred;
);
-
+
- Self:SELF '==' other:COLLECTION3(V) :BOOLEAN <-
// Do both collections have the same `lower1', `lower2', `lower3', `upper1', `upper2' and
// `upper3', and items?
@@ -301,17 +301,17 @@ Section Public
// See also `is_equal_map'.
( + line, column, depth: INTEGER;
+ result:BOOLEAN;
-
+
(
- (lower1 = other.lower1) &&
- {upper1 = other.upper1} &&
- {lower2 = other.lower2} &&
+ (lower1 = other.lower1) &&
+ {upper1 = other.upper1} &&
+ {lower2 = other.lower2} &&
{upper2 = other.upper2} &&
- {lower3 = other.lower3} &&
+ {lower3 = other.lower3} &&
{upper3 = other.upper3}
- ).if {
+ ).if {
result := TRUE;
- line := upper1;
+ line := upper1;
{(! result) || {line < lower1}}.until_do {
column := upper2;
{(! result) || {column < lower2}}.until_do {
@@ -330,22 +330,22 @@ Section Public
- is_equal_map other: COLLECTION3(V) :BOOLEAN <-
// Do both collections have the same `lower1', `lower2', `lower3', `upper1', `upper2' and `upper3',
- // and items?
+ // and items?
//
// See also `=='.
( + line, column, depth:INTEGER;
+ result:BOOLEAN;
-
+
(
- (lower1 = other.lower1) &&
- {upper1 = other.upper1} &&
- {lower2 = other.lower2} &&
+ (lower1 = other.lower1) &&
+ {upper1 = other.upper1} &&
+ {lower2 = other.lower2} &&
{upper2 = other.upper2} &&
- {lower3 = other.lower3} &&
+ {lower3 = other.lower3} &&
{upper3 = other.upper3}
- ).if {
+ ).if {
result := TRUE;
- line := upper1;
+ line := upper1;
{(! result) || {line < lower1}}.until_do {
column := upper2;
{(! result) || {column < lower2}}.until_do {
@@ -361,7 +361,7 @@ Section Public
};
result
);
-
+
//
// Printing:
//
@@ -369,7 +369,7 @@ Section Public
- fill_tagged_out_memory <-
( + line:INTEGER;
+ v:V;
-
+
tagged_out_memory.append "lower1:";
lower1.append_in tagged_out_memory;
tagged_out_memory.append " upper1:";
@@ -383,18 +383,18 @@ Section Public
tagged_out_memory.append " upper3:";
upper3.append_in tagged_out_memory;
tagged_out_memory.append " [\n";
-
+
line := lower1;
{ (line > upper1) || { tagged_out_memory.count > 4096}}.until_do {
tagged_out_memory.append "line ";
line.append_in tagged_out_memory;
tagged_out_memory.append "\t:";
-
+
lower2.to upper2 do { column:INTEGER;
tagged_out_memory.append "column ";
column.append_in tagged_out_memory;
tagged_out_memory.append "\t:";
-
+
lower3.to upper3 do { depth:INTEGER;
tagged_out_memory.append "depth ";
depth.append_in tagged_out_memory;
@@ -407,23 +407,23 @@ Section Public
};
tagged_out_memory.extend ' ';
};
-
+
tagged_out_memory.extend '\n';
};
-
+
tagged_out_memory.extend '\n';
line := line + 1;
};
-
+
(valid_line line).if {
tagged_out_memory.append "......\n";
};
);
-
+
//
// Miscellaneous features:
//
-
+
- occurrences elt:V :INTEGER <-
// Number of occurrences using `equal'.
//
@@ -452,14 +452,14 @@ Section Public
deferred;
FALSE
);
-
+
- fast_has x:V :BOOLEAN <-
// Search if a element x is in the array using `='.
(
deferred;
FALSE
);
-
+
- replace_all old_value:V with new_value:V <-
// Replace all occurences of the element `old_value' by `new_value'
// using `equal' for comparison.
@@ -472,7 +472,7 @@ Section Public
+? {count = Old count};
+? {occurrences old_value = 0};
];
-
+
- fast_replace_all old_value:V with new_value:V <-
// Replace all occurences of the element `old_value' by `new_value'
// using operator `=' for comparison.
@@ -485,20 +485,20 @@ Section Public
+? {count = Old count};
+? {fast_occurrences old_value = 0};
];
-
- - sub_collection3 (line_min, column_min, depth_min:INTEGER)
+
+ - sub_collection3 (line_min, column_min, depth_min:INTEGER)
to (line_max, column_max, depth_max:INTEGER) :SELF <-
// Create a new object using selected area of `self'.
[
-? { valid_index (line_min,column_min,depth_min)};
-? { valid_index (line_max,column_max,depth_max)};
]
- (
+ (
deferred;
)
[ +? {Result != NULL}; ];
-
- - set_area (line_min, column_min, depth_min:INTEGER)
+
+ - set_area (line_min, column_min, depth_min:INTEGER)
to (line_max, column_max, depth_max:INTEGER) with element:V <-
// Set all the elements of the selected area rectangle with `element'.
[
@@ -515,4 +515,4 @@ Section Public
};
)
[ +? {count = Old count}; ];
-
+
diff --git a/lib/internal/portable/collection/dictionary.li b/lib/internal/portable/collection/dictionary.li
index a5ea380..ea8d097 100644
--- a/lib/internal/portable/collection/dictionary.li
+++ b/lib/internal/portable/collection/dictionary.li
@@ -23,27 +23,27 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Associative memory. Values of type `V' are stored using Keys of type `K'.";
-
- // To make a comparison with the well knowned ARRAY class, with a DICTIONARY,
- // index used are not only INTEGER, you can use for example a STRING to access
+
+ // To make a comparison with the well knowned ARRAY class, with a DICTIONARY,
+ // index used are not only INTEGER, you can use for example a STRING to access
// to your information.
//
// Well knowned implementations, see HASHED_DICTIONARY and AVL_DICTIONARY.
//
// See also BIJECTIVE_DICTIONARY class.
-
+
Section Inherit
-
+
+ parent_traversable:Expanded TRAVERSABLE(V);
-
+
Section Public
-
+
//
// Counting:
//
-
+
- count:INTEGER <-
// Actual `count' of stored elements.
(
@@ -53,17 +53,17 @@ Section Public
- is_empty:BOOLEAN <- count = 0;
// Is it empty?
-
+
//
// Basic access:
//
-
+
- has k:K :BOOLEAN <-
// Is there a value currently associated with key `k'?
//
// See also `fast_has', `at'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
]
(
deferred;
@@ -74,11 +74,11 @@ Section Public
// Return the value associated to key `k'.
//
// See also `fast_at', `reference_at', `has'.
- [ ...
- -? {has k};
+ [ ...
+ -? {has k};
]
( + result:V;
-
+
deferred;
result
);
@@ -91,16 +91,16 @@ Section Public
//
// See also `fast_reference_at', `at', `has'.
[ ...
- -? {k != NULL};
+ -? {k != NULL};
// "Values are expanded." -? {(Result != NULL) -> (! Result.is_expanded_type)};
]
( + result:V;
-
- deferred;
+
+ deferred;
result
)
[ ...
- +? {(has k) ->> {Result = at k}};
+ +? {(has k) ->> {Result = at k}};
];
- fast_has k:K :BOOLEAN <-
@@ -108,8 +108,8 @@ Section Public
// Using basic `=' for comparison.
//
// See also `has', `at', `fast_at'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
]
(
deferred;
@@ -121,10 +121,10 @@ Section Public
//
// See also `at', `reference_at', `fast_reference_at'.
[ ...
- -? {fast_has k};
+ -? {fast_has k};
]
( + result:V;
-
+
deferred;
result
);
@@ -133,55 +133,55 @@ Section Public
// Same work as `reference_at', but basic `=' is used for comparison.
//
// See also `reference_at', `at', `has'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
// BSBS: Il faut que tu init Result, sinon ca ne marche pas !!!
- //"Values are expanded." -? {(Result != NULL) ->> {! Result.is_expanded_type}};
+ //"Values are expanded." -? {(Result != NULL) ->> {! Result.is_expanded_type}};
]
- ( + result:V;
-
+ ( + result:V;
+
deferred;
result
)
[ ...
- +? {fast_has k ->> {Result = fast_at k}};
+ +? {fast_has k ->> {Result = fast_at k}};
];
-
+
//
// Modification.
//
-
+
- put v:V to k:K <-
- // Change some existing entry or `add' the new one. If there is as yet
- // no key `k' in the dictionary, enter it with item `v'. Otherwise
+ // Change some existing entry or `add' the new one. If there is as yet
+ // no key `k' in the dictionary, enter it with item `v'. Otherwise
// overwrite the item associated with key `k'.
- // As the `put' procedure actually uses `is_equal', you may consider
+ // As the `put' procedure actually uses `is_equal', you may consider
// to use `fast_put' for expanded objects as well while trying to get
// the very best performances.
//
// See also `fast_put', `add'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
]
(
deferred;
)
[ ...
- +? {v = at k};
+ +? {v = at k};
];
- fast_put v:V to k:K <-
// Same job as `put', but uses basic `=' for comparison.
//
// See also `put', `add'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
]
(
deferred
)
[ ...
- +? {v = fast_at k};
+ +? {v = fast_at k};
];
- add v:V to k:K <-
@@ -189,8 +189,8 @@ Section Public
// Actually, this is equivalent to call `put', but it may run a little bit faster.
//
// See also `put', `fast_put'.
- [ ...
- -? {! has k};
+ [ ...
+ -? {! has k};
]
(
deferred
@@ -199,18 +199,18 @@ Section Public
+? {count = 1 + Old count};
+? {v = at k};
];
-
+
//
// Looking and searching some value:
//
-
+
- occurrences v:V :INTEGER <-
// Number of occurrences using `is_equal' for comparison.
//
// See also `fast_occurrences', `fast_has', `has'.
- ( + i,result:INTEGER;
+ ( + i,result:INTEGER;
+ safe_equal:SAFE_EQUAL(V);
-
+
i := 1;
{i > count}.until_do {
(safe_equal.test v with (item i)).if {
@@ -221,15 +221,15 @@ Section Public
result
)
[ ...
- +? {Result >= 0};
+ +? {Result >= 0};
];
-
+
- fast_occurrences v:V :INTEGER <-
// Number of occurrences using basic `=' for comparison.
//
// See also `occurrences', `fast_has', `has'.
( + result,i:INTEGER;
-
+
i := 1;
{i > count}.until_do {
(v = item i).if {
@@ -240,19 +240,19 @@ Section Public
result
)
[ ...
- +? {Result >= 0};
+ +? {Result >= 0};
];
-
+
- key_at v:V :K <-
// Retrieve the key used for value `v' using `is_equal' for comparison.
//
// See also `fast_key_at', `at'.
- [ ...
+ [ ...
-? {occurrences v = 1};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ safe_equal:SAFE_EQUAL(V);
-
+
i := 1;
{safe_equal.test v with (item i)}.until_do {
i := i + 1;
@@ -271,7 +271,7 @@ Section Public
-? {fast_occurrences v = 1};
]
( + i:INTEGER;
-
+
i := 1;
{v = item i}.until_do {
i := i + 1;
@@ -280,45 +280,45 @@ Section Public
)
[ ...
+? {at Result = v};
- ];
-
+ ];
+
//
// Removing:
//
-
+
- remove k:K <-
// Remove entry `k' (which may exist or not before this call).
- // As the `remove' procedure actually uses `is_equal', you may
- // consider to use `fast_remove' for expanded objects as well
+ // As the `remove' procedure actually uses `is_equal', you may
+ // consider to use `fast_remove' for expanded objects as well
// while trying to get the very best performances.
//
// See also `fast_remove', `clear_count'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
]
(
deferred
)
[ ...
- +? {! has k};
+ +? {! has k};
];
-
+
- fast_remove k:K <-
// Same job as `remove', but uses basic `=' for comparison.
//
// See also `remove', `clear_count'.
- [ ...
- -? {k != NULL};
+ [ ...
+ -? {k != NULL};
]
(
deferred
)
[ ...
- -? {! has k};
+ -? {! has k};
];
- clear_count <-
- // Discard all items (`is_empty' is True after that call).
+ // Discard all items (`is_empty' is True after that call).
// The internal `capacity' is not changed by this call.
//
// See also `clear_count_and_capacity', `remove'.
@@ -331,7 +331,7 @@ Section Public
];
- clear_count_and_capacity <-
- // Discard all items (`is_empty' is True after that call).
+ // Discard all items (`is_empty' is True after that call).
// The internal `capacity' may also be reduced after this call.
//
// See also `clear_count', `remove'.
@@ -341,24 +341,24 @@ Section Public
[ ...
"Is empty." +? {count = 0};
+? {capacity <= Old capacity};
- ];
+ ];
- capacity:INTEGER <-
- // Approximation of the actual internal storage `capacity'.
- // The `capacity' will grow automatically when needed
- // (i.e. `capacity' is not a limit for the number of values stored).
- // Also note that the `capacity' value may not be always accurate
- // depending of the implementation (anyway, this `capacity' value
+ // Approximation of the actual internal storage `capacity'.
+ // The `capacity' will grow automatically when needed
+ // (i.e. `capacity' is not a limit for the number of values stored).
+ // Also note that the `capacity' value may not be always accurate
+ // depending of the implementation (anyway, this `capacity' value
// is at least equals to `count').
(
deferred;
0
);
-
+
//
// To provide iterating facilities:
//
-
+
- lower:INTEGER := 1;
- upper:INTEGER <-
@@ -371,7 +371,7 @@ Section Public
- item i:INTEGER :V <-
( + result:V;
-
+
deferred;
result
)
@@ -380,7 +380,7 @@ Section Public
];
- first:V <- item lower;
-
+
- last:V <- item upper;
- key index:INTEGER :K <-
@@ -388,14 +388,14 @@ Section Public
-? {valid_index index};
]
( + result:K;
-
+
deferred;
result
)
[ ...
+? {(fast_at Result) = item index};
];
-
+
- key_map_in buffer:COLLECTION(K) <-
// Append in `buffer', all available keys (this may be useful to
// speed up the traversal).
@@ -405,7 +405,7 @@ Section Public
-? {buffer != NULL};
]
( + i:INTEGER;
-
+
i := count;
{i < lower}.until_do {
buffer.add_last (key i);
@@ -425,7 +425,7 @@ Section Public
-? {buffer != NULL};
]
( + i:INTEGER;
-
+
i := count;
{i < lower}.until_do {
buffer.add_last (item i);
@@ -435,11 +435,11 @@ Section Public
[
+? {buffer.count = count + Old buffer.count};
];
-
+
//
// Comparaison.
//
-
+
- Self:SELF '==' other:SELF :BOOLEAN <-
// Do both dictionaries have the same set of associations?
// Keys are compared with `is_equal' and values are comnpared
@@ -448,7 +448,7 @@ Section Public
// See also `is_equal_map'.
( + i:INTEGER;
+ result:BOOLEAN;
-
+
(Self = other).if {
result := TRUE;
}.elseif {count = other.count} then {
@@ -477,14 +477,14 @@ Section Public
// Both keys and values are compared with `is_equal'.
//
// See also `is_equal'.
- ( + i:INTEGER;
- + k:K;
+ ( + i:INTEGER;
+ + k:K;
+ safe_equal:SAFE_EQUAL(V);
+ result:BOOLEAN;
-
+
(Self = other).if {
result := TRUE;
- }.elseif {count = other.count} then {
+ }.elseif {count = other.count} then {
result := TRUE;
i := 1;
{(! result) || {i > count}}.until_do {
@@ -497,7 +497,7 @@ Section Public
};
} else {
result := FALSE;
- };
+ };
};
};
result
@@ -506,7 +506,7 @@ Section Public
- copy other:SELF <-
// Reinitialize by copying all associations of `other'.
( + i:INTEGER;
-
+
clear_count;
i := 1;
{i > other.count}.until_do {
@@ -518,15 +518,15 @@ Section Public
//
// Agents based features:
//
-
+
- do_all action:BLOCK <-
// Apply `action' to every (V, K) associations of `Current'.
//
// See also `for_all', `exist'.
- ( + i:INTEGER;
- + v:V;
+ ( + i:INTEGER;
+ + v:V;
+ k:K;
-
+
i := lower;
{i > upper}.until_do {
v := item i;
@@ -534,7 +534,7 @@ Section Public
action.value (v, k);
i := i + 1;
};
- );
+ );
- foreach_pair action:{(K,V);} <-
(
@@ -553,8 +553,8 @@ Section Public
- foreach_key action:{K; } until test:{K; BOOLEAN} <-
( + i:INTEGER;
+ k:K;
- i := lower;
- {(i > upper) || {test.value (k := key i)}}.until_do {
+ i := lower;
+ {(i > upper) || {test.value (k := key i)}}.until_do {
action.value k;
i := i + 1;
};
@@ -563,13 +563,13 @@ Section Public
- foreach_key action:{K; } while test:{K; BOOLEAN} <-
( + i:INTEGER;
+ k:K;
- i := lower;
- {(i <= upper) && {test.value (k := key i)}}.while_do {
+ i := lower;
+ {(i <= upper) && {test.value (k := key i)}}.while_do {
action.value k;
i := i + 1;
};
);
-
+
- foreach_value action:{V; } <-
(
lower.to upper do { i:INTEGER;
@@ -580,8 +580,8 @@ Section Public
- foreach_value action:{V; } until test:{V; BOOLEAN} <-
( + i:INTEGER;
+ v:V;
- i := lower;
- {(i > upper) || {test.value (v := item i)}}.until_do {
+ i := lower;
+ {(i > upper) || {test.value (v := item i)}}.until_do {
action.value v;
i := i + 1;
};
@@ -590,8 +590,8 @@ Section Public
- foreach_value action:{V; } while test:{V; BOOLEAN} <-
( + i:INTEGER;
+ v:V;
- i := lower;
- {(i <= upper) && {test.value (v := item i)}}.while_do {
+ i := lower;
+ {(i <= upper) && {test.value (v := item i)}}.while_do {
action.value v;
i := i + 1;
};
@@ -601,14 +601,14 @@ Section Public
// Do all (V, K) associations satisfy `test'?
//
// See also `do_all', `exist'.
- ( + i:INTEGER;
- + v:V;
+ ( + i:INTEGER;
+ + v:V;
+ k:K;
+ result:BOOLEAN;
-
+
result := TRUE;
i := lower;
- {(! result) || {i > upper}}.until_do {
+ {(! result) || {i > upper}}.until_do {
v := item i;
k := key i;
result := test.value (v, k);
@@ -621,25 +621,25 @@ Section Public
// Does at least one (V, K) association satisfy `test'?
//
// See also `for_all', `do_all'.
- ( + i:INTEGER;
- + v:V;
+ ( + i:INTEGER;
+ + v:V;
+ k:K;
+ result:BOOLEAN;
-
- i := lower;
+
+ i := lower;
{result || {i > upper}}.until_do {
v := item i;
k := key i;
- result := test.value (v, k);
+ result := test.value (v, k);
i := i + 1;
};
result
);
-
+
//
// Other features:
//
-
+
- internal_key k:K :K <-
// Retrieve the internal key object which correspond to the existing
// entry `k' (the one memorized into the `Current' dictionary).
@@ -649,7 +649,7 @@ Section Public
-? {has k};
]
( + result:K;
-
+
deferred;
result
)
@@ -660,15 +660,15 @@ Section Public
//
// Creation.
//
-
+
- create:SELF <-
( + result:SELF;
-
+
result := clone;
result.make;
result
);
-
+
- make <-
// Creates an empty dictionary.
(
@@ -681,7 +681,7 @@ Section Public
//
//
//
-
+
- key_safe_equal k1:K with k2:K :BOOLEAN <-
// Because keys are never NULL, we do not rely on the SAFE_EQUAL class.
[ ...
@@ -689,7 +689,7 @@ Section Public
-? {k2 != NULL};
]
( + result:BOOLEAN;
-
+
(k1 = k2).if {
result := TRUE;
}.elseif {k1.same_dynamic_type k2} then {
@@ -701,5 +701,5 @@ Section Public
//
// invariant
//
-
+
// [ -? {capacity >= count}; ]
diff --git a/lib/internal/portable/collection/hashed_dictionary_node.li b/lib/internal/portable/collection/hashed_dictionary_node.li
index 2ff137a..340baf9 100644
--- a/lib/internal/portable/collection/hashed_dictionary_node.li
+++ b/lib/internal/portable/collection/hashed_dictionary_node.li
@@ -19,27 +19,27 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := HASHED_DICTIONARY_NODE(V,K);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Auxilliary class to implement DICTIONARY(V,K).";
-
+
Section Inherit
-
+
- parent_any_hashed_dictionary_node:ANY_HASHED_DICTIONARY_NODE := ANY_HASHED_DICTIONARY_NODE;
-
+
Section Public
-
+
+ item:V;
-
+
+ key:K;
-
+
+ next:HASHED_DICTIONARY_NODE(V,K);
// The `next' one when some clash occurs.
-
+
- set_item i:V <-
(
item := i;
@@ -47,23 +47,23 @@ Section Public
[
+? {item = i};
];
-
+
- set_next n:HASHED_DICTIONARY_NODE(V,K) <-
(
next := n;
)
[
+? {next = n};
- ];
-
+ ];
+
- create i:V to k:K next n:HASHED_DICTIONARY_NODE(V,K) :SELF<-
( + result:SELF;
-
+
result := clone;
result.make i to k next n;
result
);
-
+
- make i:V to k:K next n:HASHED_DICTIONARY_NODE(V,K) <-
(
item := i;
diff --git a/lib/internal/portable/collection/hashed_set_node.li b/lib/internal/portable/collection/hashed_set_node.li
index d1bb53f..8c2e441 100644
--- a/lib/internal/portable/collection/hashed_set_node.li
+++ b/lib/internal/portable/collection/hashed_set_node.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := HASHED_SET_NODE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Auxilliary class to implement SET(V).";
-
+
Section Inherit
-
+
- parent_any_hashed_set_node:ANY_HASHED_SET_NODE := ANY_HASHED_SET_NODE;
-
+
Section Public
-
+
+ item:V;
-
+
+ next:HASHED_SET_NODE(V);
// The `next' one when some clash occurs.
-
+
- set_next n:HASHED_SET_NODE(V) <-
(
next := n;
@@ -45,17 +45,17 @@ Section Public
[
+? {next = n};
];
-
+
Section HASHED_SET
-
+
- create i:V next n:HASHED_SET_NODE(V) :SELF <-
( + result:SELF;
-
+
result := clone;
result.make i next n;
result
);
-
+
- make i:V next n:HASHED_SET_NODE(V) <-
(
item := i;
@@ -65,5 +65,5 @@ Section HASHED_SET
+? {item = i};
+? {next = n};
];
-
-
+
+
diff --git a/lib/internal/portable/collection/linked2_list_node.li b/lib/internal/portable/collection/linked2_list_node.li
index f039854..6190a20 100644
--- a/lib/internal/portable/collection/linked2_list_node.li
+++ b/lib/internal/portable/collection/linked2_list_node.li
@@ -19,36 +19,36 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED2_LIST_NODE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment := "To implement LINKED2_LIST(V).";
-
+
Section Inherit
-
+
- parent_any_two_way_linked_list_node:ANY_TWO_WAY_LINKED_LIST_NODE := ANY_TWO_WAY_LINKED_LIST_NODE;
-
+
Section Public
-
+
+ item:V;
-
+
+ previous:LINKED2_LIST_NODE(V);
-
+
+ next:LINKED2_LIST_NODE(V);
Section LINKED2_LIST
-
+
- create i:V previous p:SELF next n:SELF :SELF<-
( + result:SELF;
-
+
result := clone;
result.make i previous p next n;
result
);
-
+
- make i:V previous p:SELF next n:SELF <-
(
item := i;
@@ -62,7 +62,7 @@ Section LINKED2_LIST
];
Section LINKED2_LIST,LINKED2_LIST_NODE
-
+
- set_item i:V <-
(
item := i;
@@ -70,7 +70,7 @@ Section LINKED2_LIST,LINKED2_LIST_NODE
[
+? {item = i};
];
-
+
- set_next n:SELF <-
(
next := n;
@@ -78,17 +78,17 @@ Section LINKED2_LIST,LINKED2_LIST_NODE
[
+? {next = n};
];
-
+
- set_all_with v:V <-
( + lnk:SELF;
-
- lnk := Self;
+
+ lnk := Self;
{lnk = NULL}.until_do {
lnk.set_item v;
lnk := lnk.next;
};
);
-
+
- set_previous p:SELF <-
(
previous := p;
diff --git a/lib/internal/portable/collection/linked_collection.li b/lib/internal/portable/collection/linked_collection.li
index f737bc1..e312262 100644
--- a/lib/internal/portable/collection/linked_collection.li
+++ b/lib/internal/portable/collection/linked_collection.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED_COLLECTION(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Common root of LINKED_LIST and TWO_WAY_LINKED_LIST..";
-
+
Section Inherit
-
+
- parent_collection:COLLECTION(V) := COLLECTION(V);
-
+
Section Public
-
+
- lower:INTEGER := 1;
// Lower index bound is frozen.
+ upper:INTEGER;
// Memorized upper index bound.
-
+
- create:SELF <-
( + result:SELF;
-
+
result := clone;
result.make;
result
);
-
+
- make <-
// Make an empty list
(
@@ -55,7 +55,7 @@ Section Public
- remove_head n:INTEGER <-
( + i:INTEGER;
-
+
i := n;
{i = 0}.until_do {
remove_first;
@@ -65,9 +65,9 @@ Section Public
- remove_tail n:INTEGER <-
( + i:INTEGER;
-
- i := n;
- {i = 0}.until_do {
+
+ i := n;
+ {i = 0}.until_do {
remove_last;
i := i - 1;
};
@@ -77,16 +77,16 @@ Section Public
(
index_of element start lower
);
-
+
- fast_first_index_of element:V :INTEGER <-
(
fast_index_of element start lower
);
-
+
//
// Implement manifest generic creation.
//
-
+
- manifest_make needed_capacity:INTEGER <-
// Manifest creation of a list of items of type E.
(
diff --git a/lib/internal/portable/collection/linked_list_node.li b/lib/internal/portable/collection/linked_list_node.li
index 2a8da56..eae68af 100644
--- a/lib/internal/portable/collection/linked_list_node.li
+++ b/lib/internal/portable/collection/linked_list_node.li
@@ -19,36 +19,36 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED_LIST_NODE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "To implement LINKED_LIST(V). .";
-
+
Section Inherit
-
+
- parent_any_linked_list_node:ANY_LINKED_LIST_NODE := ANY_LINKED_LIST_NODE;
-
+
Section Public
-
+
+ item:V;
-
+
+ next:LINKED_LIST_NODE(V);
-
+
Section LINKED_LIST
-
+
- create i:V next n:LINKED_LIST_NODE(V) :SELF <-
( + result:SELF;
-
+
result := clone;
result.make i next n;
result
);
-
+
- make i:V next n:LINKED_LIST_NODE(V) <-
- (
+ (
item := i;
next := n;
)
@@ -56,10 +56,10 @@ Section LINKED_LIST
+? {item = i};
+? {next = n};
];
-
-
+
+
Section LINKED_LIST_NODE,LINKED_LIST
-
+
- set_item i:V <-
(
item := i;
@@ -67,7 +67,7 @@ Section LINKED_LIST_NODE,LINKED_LIST
[
+? {item = i};
];
-
+
- set_next n:LINKED_LIST_NODE(V) <-
(
next := n;
@@ -75,10 +75,10 @@ Section LINKED_LIST_NODE,LINKED_LIST
[
+? {next = n};
];
-
+
- set_all_with v:V <-
( + lnk:SELF;
-
+
lnk := Self;
{lnk = NULL}.until_do {
lnk.set_item v;
diff --git a/lib/internal/portable/collection/linked_xor_node.li b/lib/internal/portable/collection/linked_xor_node.li
index a204155..42f1857 100644
--- a/lib/internal/portable/collection/linked_xor_node.li
+++ b/lib/internal/portable/collection/linked_xor_node.li
@@ -19,37 +19,37 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED_XOR_NODE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment := "To implement LINKED_XOR_LIST(V).";
-
+
Section Inherit
-
+
- parent_any_two_way_linked_list_node:ANY_TWO_WAY_LINKED_LIST_NODE := ANY_TWO_WAY_LINKED_LIST_NODE;
-
+
Section Public
-
+
+ item:V;
-
+
+ link:POINTER;
Section LINKED_XOR_LIST
-
+
- create i:V previous p:SELF next n:SELF :SELF<-
( + result:SELF;
-
+
result := clone;
result.make i previous p next n;
result
);
-
+
- make i:V previous p:SELF next n:SELF <-
(
- item := i;
+ item := i;
link := p.to_pointer ^ n.to_pointer; // BSBS: il faut admettre NULL.to_pointer (perf!)
)
[
@@ -57,7 +57,7 @@ Section LINKED_XOR_LIST
];
Section LINKED_XOR_LIST,LINKED_XOR_NODE
-
+
- set_item i:V <-
(
item := i;
@@ -65,20 +65,19 @@ Section LINKED_XOR_LIST,LINKED_XOR_NODE
[
+? {item = i};
];
-
+
- next prev:LINKED_XOR_NODE :LINKED_XOR_NODE <-
- (
+ (
CONVERT(POINTER,LINKED_XOR_NODE).on (link ^ prev.to_pointer)
);
-
+
- previous nex:LINKED_XOR_NODE :LINKED_XOR_NODE <-
(
CONVERT(POINTER,LINKED_XOR_NODE).on (link ^ nex.to_pointer)
);
-
+
- set_link p:SELF and n:SELF <-
(
link := p.to_pointer ^ n.to_pointer;
);
-
-
\ No newline at end of file
+
diff --git a/lib/internal/portable/collection/native_array.li b/lib/internal/portable/collection/native_array.li
index 13c9946..6989b1c 100644
--- a/lib/internal/portable/collection/native_array.li
+++ b/lib/internal/portable/collection/native_array.li
@@ -19,31 +19,31 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Strict NATIVE_ARRAY(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Native array of collection library.";
-
+
// This class gives access to the lowest level for arrays. As any low level array, you can
// get high performances with NATIVE_ARRAYs, but you loose most valid bounds checks (as
// you can do in plain C code for example).
-
+
Section Inherit
-
+
- parent_safe_equal:SAFE_EQUAL(V) := SAFE_EQUAL(V);
-
-Section Public
-
+
+Section Public
+
//
// Basic features:
//
-
+
- object_size:INTEGER := 0; // For detect error.
-
- - element_sizeof:INTEGER <-
+
+ - element_sizeof:INTEGER <-
// The size in number of bytes for type `E'.
( + result:INTEGER;
(V.is_expanded_type).if {
@@ -53,7 +53,7 @@ Section Public
};
result
);
-
+
- calloc_intern nb_elements:INTEGER :NATIVE_ARRAY(V) <-
// Allocate a new array of 'nb_elements' of type `E'.
// The new array is initialized with default values.
@@ -63,9 +63,9 @@ Section Public
( + capacity:INTEGER;
+ p:POINTER;
+ result :NATIVE_ARRAY(V);
-
- capacity := nb_elements * element_sizeof;
- //p := `malloc(@capacity)`:POINTER;
+
+ capacity := nb_elements * element_sizeof;
+ //p := `malloc(@capacity)`:POINTER;
p := MEMORY.alloc_dynamic capacity;
result := CONVERT(POINTER,NATIVE_ARRAY(V)).on p;
result
@@ -73,7 +73,7 @@ Section Public
[ ...
+? {Result != NULL};
];
-
+
- create nb_elements:INTEGER :NATIVE_ARRAY(V) <-
// Allocate a new array of `nb_elements' of type `E'.
// The new array is initialized with default values.
@@ -81,15 +81,15 @@ Section Public
-? {nb_elements > 0};
]
( + result:NATIVE_ARRAY(V);
-
+
result:=calloc_intern nb_elements;
- result.clear_all (nb_elements-1);
+ result.clear_all (nb_elements-1);
result
)
[ ...
// +? {Result.all_default (nb_elements-1)};
];
-
+
- realloc old_nb_elts:INTEGER with new_nb_elts:INTEGER :NATIVE_ARRAY(V) <-
// Assume Current is a valid NATIVE_ARRAY in range
// [0 .. `old_nb_elts'-1]. Allocate a bigger new array in
@@ -104,11 +104,11 @@ Section Public
( + new:NATIVE_ARRAY(V);
+ old_ptr,new_ptr:POINTER;
+ new_cap:INTEGER;
-
- old_ptr := CONVERT(NATIVE_ARRAY(V),POINTER).on Self;
+
+ old_ptr := CONVERT(NATIVE_ARRAY(V),POINTER).on Self;
new_cap := new_nb_elts * element_sizeof;
//new_ptr := `realloc(@old_ptr, at new_cap)`:POINTER;
- new_ptr := MEMORY.realloc_dynamic old_ptr
+ new_ptr := MEMORY.realloc_dynamic old_ptr
old_size (old_nb_elts * element_sizeof) new_size new_cap;
new := CONVERT(POINTER,NATIVE_ARRAY(V)).on new_ptr;
new.clear old_nb_elts to (new_nb_elts - 1);
@@ -117,20 +117,20 @@ Section Public
[ ...
+? {Result != NULL};
];
-
+
- first:V <- item 0;
-
+
- item index:INTEGER :V <-
// To read an `item'.
- // Assume that `calloc' is already done and that `index' is
+ // Assume that `calloc' is already done and that `index' is
// the range [0 .. `nb_elements'-1].
[ ...
-? {index >= 0};
]
- (
- `10`
+ (
+ `10`
);
-
+
- put element:V to index:INTEGER <-
// To write an item.
// Assume that `calloc' is already done and that `index'
@@ -138,30 +138,30 @@ Section Public
[ ...
-? {index >= 0};
]
- (
- force_put element to index;
+ (
+ force_put element to index;
)
[ ...
-// +? {element = item index};
+// +? {element = item index};
];
-
+
//
// Displacement
//
-
- - Self:SELF '+' Left 80 other:INTEGER :NATIVE_ARRAY(V) <-
+
+ - Self:SELF '+' Left 80 other:INTEGER :NATIVE_ARRAY(V) <-
// other is in element index
( + ptr:POINTER;
-
+
ptr := to_pointer;
ptr := ptr + other * element_sizeof;
CONVERT(POINTER, NATIVE_ARRAY(V)).on ptr
);
-
+
//
// Comparison:
//
-
+
- memcmp other:NATIVE_ARRAY(V) until capacity:INTEGER :BOOLEAN <-
// True if all elements in range [0..capacity-1] are
// identical using `equal'. Assume Current and `other'
@@ -171,14 +171,14 @@ Section Public
-? {(capacity > 0) ->> {other.is_not_null}};
]
( + i:INTEGER;
-
+
i := capacity - 1;
{(i >= 0) && {safe_equal (item i,other.item i)}}.while_do {
i := i - 1;
};
i < 0
);
-
+
- slice_memcmp (at:INTEGER,other:NATIVE_ARRAY(V),other_lower,other_upper:INTEGER) :BOOLEAN <-
// True if all elements in range [0 .. `other_upper' - `other_lower'] are identical
// to the elements in range [`other_lower' .. `other_upper'] of `other' using
@@ -191,28 +191,28 @@ Section Public
-? {(other_upper >= other_lower) ->> {other.is_not_null}};
]
( + i:INTEGER;
-
+
i := other_upper - other_lower;
{(i >= 0) && {safe_equal (item (at + i),other.item (other_lower + i))}}.while_do {
i := i - 1;
};
i < 0
);
-
+
- fast_memcmp other:NATIVE_ARRAY(V) until capacity:INTEGER :BOOLEAN <-
// Same jobs as `memcmp' but uses infix `=' instead `equal'.
[ ...
-? {(capacity > 0) ->> {other.is_not_null}};
]
( + i:INTEGER;
-
+
i := capacity-1;
{(i >=0 ) && {item i = other.item i}}.while_do {
i := i - 1;
};
i < 0
);
-
+
- slice_fast_memcmp (at:INTEGER, other:NATIVE_ARRAY(V), other_lower,other_upper:INTEGER) :BOOLEAN <-
// Same jobs as `slice_memcmp' but uses infix "=" instead of `is_equal'.
[ ...
@@ -221,15 +221,15 @@ Section Public
-? {other_upper >= other_lower - 1};
-? {(other_upper >= other_lower) ->> {other.is_not_null}};
]
- ( + i:INTEGER;
-
+ ( + i:INTEGER;
+
i := other_upper - other_lower;
{(i < 0) || {item (at + i) != other.item (other_lower + i)}}.until_do {
i := i - 1;
};
i < 0
);
-
+
- deep_memcmp other:NATIVE_ARRAY(V) until capacity:INTEGER :BOOLEAN <-
// Same jobs as `memcmp' but uses `is_deep_equal' instead `equal'.
[ ...
@@ -238,7 +238,7 @@ Section Public
( + result:BOOLEAN; // BEN : A REVOIR, il y a + efficace...
+ e1,e2:V;
+ i:INTEGER;
-
+
result := TRUE;
i := capacity - 1;
{(result = FALSE) || {i < 0}}.until_do {
@@ -257,7 +257,7 @@ Section Public
};
result
);
-
+
- slice_deep_memcmp (at:INTEGER,other:NATIVE_ARRAY(V),other_lower,other_upper:INTEGER) :BOOLEAN <-
// Same jobs as `slice_memcmp' but uses `is_deep_equal' instead of `is_equal'.
[ ...
@@ -266,10 +266,10 @@ Section Public
-? {other_upper >= other_lower - 1};
-? {(other_upper >= other_lower) ->> {other.is_not_null}};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ e1,e2:V;
+ result:BOOLEAN;
-
+
i := other_upper - other_lower;
result := TRUE;
{(! result) || {i < 0}}.until_do {
@@ -289,11 +289,11 @@ Section Public
};
result
);
-
+
//
// Searching:
//
-
+
- first_index_of element:V until upper:INTEGER :INTEGER <-
// Give the index of the first occurrence of `element' using
// `==' for comparison.
@@ -303,15 +303,15 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
{(idx > upper) || {safe_equal (element,item idx)}}.until_do {
idx := idx + 1;
};
idx
);
-
+
- index_of (element:V,start_index:INTEGER) until upper:INTEGER :INTEGER <-
- // Using `is_equal' for comparison, gives the index of the first occurrence of `element'
+ // Using `is_equal' for comparison, gives the index of the first occurrence of `element'
// at or after `start_index'. Answer `upper + 1' when the search fail.
// See also `fast_index_of', `reverse_index_of'.
[ ...
@@ -319,7 +319,7 @@ Section Public
-? {start_index <= upper};
]
( + result:INTEGER;
-
+
result := start_index;
{(result > upper) || {safe_equal (element,item result)}}.until_do {
result := result + 1;
@@ -330,7 +330,7 @@ Section Public
+? {Result.in_range start_index to (upper + 1)};
+? {(Result <= upper) ->> {safe_equal (element,item Result)}};
];
-
+
- reverse_index_of element:V from upper:INTEGER :INTEGER <-
// Give the index of the first occurrence of `element' using
// `==' for comparison, from upper to lower.
@@ -339,7 +339,7 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
idx := upper;
{(idx < 0) || {safe_equal (element,item idx)}}.until_do {
idx := idx - 1;
@@ -350,9 +350,9 @@ Section Public
+? {Result.in_range (-1) to upper};
+? {(Result > 0) ->> {safe_equal (element, item Result)}};
];
-
+
- fast_index_of (element:V,start_index:INTEGER) until upper:INTEGER :INTEGER <-
- // Using basic `=' for comparison, gives the index of the first occurrence of
+ // Using basic `=' for comparison, gives the index of the first occurrence of
// `element' at or after `start_index'. Answer `upper + 1' when the search fail.
// See also `index_of', `reverse_index_of'.
[ ...
@@ -360,9 +360,9 @@ Section Public
-? {start_index <= upper};
]
( + result:INTEGER;
-
+
result := start_index;
- {(result > upper) || {element = item result}}.until_do {
+ {(result > upper) || {element = item result}}.until_do {
result := result + 1;
};
result
@@ -371,7 +371,7 @@ Section Public
+? {Result.in_range start_index to (upper + 1)};
+? {(Result <= upper) ->> {element = item Result}};
];
-
+
- fast_reverse_index_of element:V from upper:INTEGER :INTEGER <-
// Same as `reverse_index_of' but use basic `=' for comparison.
// Search is done in reverse direction, which means from `upper' down to the
@@ -381,7 +381,7 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
idx := upper;
{(idx < 0) || {element = item idx}}.until_do {
idx := idx - 1;
@@ -401,7 +401,7 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
{(idx > upper) || {element = item idx}}.until_do {
idx := idx + 1;
};
@@ -410,8 +410,8 @@ Section Public
[ ...
+? {Result.in_range 0 to (upper + 1)};
+? {(Result <= upper) ->> {element = item Result}};
- ];
-
+ ];
+
- has element:V until upper:INTEGER :BOOLEAN <-
// Look for `element' using `==' for comparison.
// Also consider `has' to choose the most appropriate.
@@ -419,8 +419,8 @@ Section Public
-? {upper >= -1};
]
( + result:BOOLEAN;
- + i:INTEGER;
-
+ + i:INTEGER;
+
i := upper;
{(result) || {i < 0}}.until_do {
result := safe_equal (element,item i);
@@ -428,7 +428,7 @@ Section Public
};
result
);
-
+
- fast_has element:V until upper:INTEGER :BOOLEAN <-
// Look for `element' using basic `=' for comparison.
// Also consider `has' to choose the most appropriate.
@@ -436,18 +436,18 @@ Section Public
-? {upper >= -1};
]
( + i:INTEGER;
-
+
i := upper;
{(i < 0) || {element = item i}}.until_do {
i := i - 1;
};
i >= 0
);
-
+
//
// Removing:
//
-
+
- remove_first upper:INTEGER <-
// Assume `upper' is a valid index.
// Move range [1 .. `upper'] by 1 position left.
@@ -455,13 +455,13 @@ Section Public
-? {upper >= 0};
]
( + i:INTEGER;
-
+
{i = upper}.until_do {
put (item (i + 1)) to i;
i := i + 1;
};
);
-
+
- remove index:INTEGER until upper:INTEGER <-
// Assume `upper' is a valid index.
// Move range [`index' + 1 .. `upper'] by 1 position left.
@@ -470,18 +470,18 @@ Section Public
-? {index <= upper};
]
( + i:INTEGER;
-
+
i := index;
{i = upper}.until_do {
put (item (i + 1)) to i;
i := i + 1;
};
);
-
+
//
// Replacing:
//
-
+
- replace_all old_value:V with new_value:V until upper:INTEGER <-
// Replace all occurences of the element `old_value' by `new_value'
// using `==' for comparison.
@@ -489,14 +489,14 @@ Section Public
[ ...
-? {upper >= -1};
]
- (
+ (
upper.downto 0 do { i:INTEGER;
(safe_equal (old_value,(item i))).if {
put new_value to i;
};
};
);
-
+
- fast_replace_all old_value:V with new_value:V until upper:INTEGER <-
// Replace all occurences of the element `old_value' by `new_value'
// using basic `=' for comparison.
@@ -504,18 +504,18 @@ Section Public
[ ...
-? {upper >= -1};
]
- (
+ (
upper.downto 0 do { i:INTEGER;
(old_value = item i).if {
put new_value to i;
};
};
);
-
+
//
// Adding:
//
-
+
- copy src:NATIVE_ARRAY(V) to dest:INTEGER until src_capacity:INTEGER <-
// Copy range [0 .. `src_capacity - 1'] of `src' to range
// [`dest' .. `dest + src_capacity - 1'] of `Self'.
@@ -525,7 +525,7 @@ Section Public
-? {src_capacity >= 0};
]
( + i1, i2:INTEGER;
-
+
i1 := dest;
{i2 = src_capacity}.until_do {
put (src.item i2) to i1;
@@ -533,7 +533,7 @@ Section Public
i1 := i1 + 1;
};
);
-
+
- slice_copy src:NATIVE_ARRAY(V) to dest:INTEGER from src_min:INTEGER to src_max:INTEGER <-
// Copy range [`src_min' .. `src_max'] of `src' to range
// [`at' .. `at + src_max - src_min - 1'] of `Current'.
@@ -543,8 +543,8 @@ Section Public
-? {src_min <= src_max + 1};
-? {(src != Self) | (dest != src_min)};
]
- ( + i1, i2:INTEGER;
-
+ ( + i1, i2:INTEGER;
+
i1 := dest;
i2 := src_min;
{i2 > src_max}.until_do {
@@ -553,11 +553,11 @@ Section Public
i1 := i1 + 1;
};
);
-
+
//
// Other:
//
-
+
- set_all_with v:V until upper:INTEGER <-
// Set all elements in range [0 .. upper] with
// value `v'.
@@ -569,7 +569,7 @@ Section Public
put v to i;
};
);
-
+
- set_slice_with v:V from lower:INTEGER until upper:INTEGER <-
// Set all elements in range [`lower' .. `upper'] with value `v'.
[ ...
@@ -577,14 +577,14 @@ Section Public
-? {upper >= lower - 1};
]
( + i:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
put v to i;
i := i + 1;
};
);
-
+
- clear_all upper:INTEGER <-
// Set all elements in range [0 .. `upper'] with
// the default value.
@@ -592,12 +592,12 @@ Section Public
-? {upper >= -1};
]
( + v:V;
-
- upper.downto 0 do { i:INTEGER;
+
+ upper.downto 0 do { i:INTEGER;
put v to i;
};
);
-
+
- clear lower:INTEGER to upper:INTEGER <-
// Set all elements in range [`lower' .. `upper'] with
// the default value
@@ -606,12 +606,12 @@ Section Public
-? {upper >= lower};
]
( + v:V;
-
+
lower.to upper do { i:INTEGER;
put v to i;
};
);
-
+
- copy_from model:NATIVE_ARRAY(V) until upper:INTEGER <-
// Assume `upper' is a valid index both in Current and `model'.
[ ...
@@ -622,7 +622,7 @@ Section Public
put (model.item i) to i;
};
);
-
+
- deep_twin_from capacity:INTEGER :NATIVE_ARRAY(V) <-
// To implement `deep_twin'. Allocate a new array of
// `capacity' initialized with `deep_twin'.
@@ -632,7 +632,7 @@ Section Public
]
( + element:V;
+ result:NATIVE_ARRAY(V);
-
+
(capacity > 0).if {
result := calloc capacity;
(capacity - 1).downto 0 do { i:INTEGER;
@@ -644,7 +644,7 @@ Section Public
};
};
);
-
+
- move lower:INTEGER to upper:INTEGER by offset:INTEGER <-
// Move range [`lower' .. `upper'] by `offset' positions.
// Freed positions are not initialized to default values.
@@ -653,7 +653,7 @@ Section Public
-? {upper >= lower};
-? {lower + offset >= 0};
]
- (
+ (
(offset != 0).if {
(offset < 0).if {
lower.to upper do { i:INTEGER;
@@ -666,7 +666,7 @@ Section Public
};
};
);
-
+
- occurrences element:V until upper:INTEGER :INTEGER <-
// Number of occurrences of `element' in range [0..upper]
// using `equal' for comparison.
@@ -675,7 +675,7 @@ Section Public
-? {upper >= -1};
]
( + count:INTEGER;
-
+
upper.downto 0 do { i:INTEGER;
(safe_equal (element,item i)).if {
count := count + 1;
@@ -683,9 +683,9 @@ Section Public
};
count
);
-
+
- slice_occurrences element:V from lower:INTEGER until upper:INTEGER :INTEGER <-
- // Number of occurrences of `element' in range [`lower' .. `upper'] using
+ // Number of occurrences of `element' in range [`lower' .. `upper'] using
// `is_equal' for comparison.
// See also `slice_fast_occurrences' to chose the apropriate one.
[ ...
@@ -693,7 +693,7 @@ Section Public
-? {upper >= lower - 1};
]
( + i,result:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
(safe_equal (element,item i)).if {
@@ -712,7 +712,7 @@ Section Public
-? {upper >= -1};
]
( + count:INTEGER;
-
+
upper.downto 0 do { i:INTEGER;
(element = item i).if {
count := count + 1;
@@ -720,7 +720,7 @@ Section Public
};
count
);
-
+
- slice_fast_occurrences element:V from lower:INTEGER until upper:INTEGER :INTEGER <-
// Number of occurrences of `element' in range [`lower' .. `upper']
// using basic "=" for comparison.
@@ -730,7 +730,7 @@ Section Public
-? {upper >= lower - 1};
]
( + i,result:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
(element = item i).if {
@@ -740,7 +740,7 @@ Section Public
};
result
);
-
+
- all_default upper:INTEGER :BOOLEAN <-
// Do all items in range [0 .. `upper'] have their type's
// default value?
@@ -758,7 +758,7 @@ Section Public
};
result
);
-
+
- slice_default lower:INTEGER to upper:INTEGER :BOOLEAN <-
// Do all items in range [`lower' .. `upper'] have their type's default value?
// Note: for non Void items, the test is performed with the `is_default' predicate.
@@ -766,10 +766,10 @@ Section Public
-? {lower >= 0};
-? {upper >= lower - 1};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ v:V;
+ result:BOOLEAN;
-
+
result := TRUE;
i := lower;
{(i > upper) || {! result}}.until_do {
@@ -781,30 +781,30 @@ Section Public
};
result
);
-
+
//
// Interfacing with C:
//
-
+
- to_external:POINTER <- to_pointer;
// Gives access to the C pointer on the area of storage.
-
+
- is_null:BOOLEAN <- to_pointer.is_null;
-
+
- is_not_null:BOOLEAN <- to_pointer.is_not_null;
-
+
//
// Guru Section
//
-
+
- println <- `puts(@Self)`;
-
+
- force_put element:V to index:INTEGER <-
// Used in Memory count: not to use directly without caution !
[ ...
-? {index>=0};
]
- (
- `9`;
+ (
+ `9`;
);
diff --git a/lib/internal/portable/collection/native_array_volatile.li b/lib/internal/portable/collection/native_array_volatile.li
index ea662a6..e5589c7 100644
--- a/lib/internal/portable/collection/native_array_volatile.li
+++ b/lib/internal/portable/collection/native_array_volatile.li
@@ -19,31 +19,31 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Strict NATIVE_ARRAY_VOLATILE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Native array of collection library.";
-
+
// This class gives access to the lowest level for arrays. As any low level array, you can
// get high performances with NATIVE_ARRAYs, but you loose most valid bounds checks (as
// you can do in plain C code for example).
-
+
Section Inherit
-
+
- parent_safe_equal:SAFE_EQUAL(V) := SAFE_EQUAL(V);
-
-Section Public
-
+
+Section Public
+
//
// Basic features:
//
-
+
- object_size:INTEGER := 0; // For detect error.
-
- - element_sizeof:INTEGER <-
+
+ - element_sizeof:INTEGER <-
// The size in number of bytes for type `E'.
( + result:INTEGER;
(V.is_expanded_type).if {
@@ -53,7 +53,7 @@ Section Public
};
result
);
-
+
- calloc_intern nb_elements:INTEGER :NATIVE_ARRAY_VOLATILE(V) <-
// Allocate a new array of 'nb_elements' of type `E'.
// The new array is initialized with default values.
@@ -63,9 +63,9 @@ Section Public
( + capacity:INTEGER;
+ p:POINTER;
+ result :NATIVE_ARRAY_VOLATILE(V);
-
- capacity := nb_elements * element_sizeof;
- //p := `malloc(@capacity)`:POINTER;
+
+ capacity := nb_elements * element_sizeof;
+ //p := `malloc(@capacity)`:POINTER;
p := MEMORY.alloc_dynamic (capacity.to_uinteger_32);
result := CONVERT(POINTER,NATIVE_ARRAY_VOLATILE(V)).on p;
result
@@ -73,7 +73,7 @@ Section Public
[ ...
+? {Result != NULL};
];
-
+
- create nb_elements:INTEGER :NATIVE_ARRAY_VOLATILE(V) <-
// Allocate a new array of `nb_elements' of type `E'.
// The new array is initialized with default values.
@@ -81,15 +81,15 @@ Section Public
-? {nb_elements > 0};
]
( + result:NATIVE_ARRAY_VOLATILE(V);
-
+
result:=calloc_intern nb_elements;
- result.clear_all (nb_elements-1);
+ result.clear_all (nb_elements-1);
result
)
[ ...
+? {Result.all_default (nb_elements-1)};
];
-
+
- realloc old_nb_elts:INTEGER with new_nb_elts:INTEGER :NATIVE_ARRAY_VOLATILE(V) <-
// Assume Current is a valid NATIVE_ARRAY_VOLATILE in range
// [0 .. `old_nb_elts'-1]. Allocate a bigger new array in
@@ -104,12 +104,12 @@ Section Public
( + new:NATIVE_ARRAY_VOLATILE(V);
+ old_ptr,new_ptr:POINTER;
+ new_cap:INTEGER;
-
- old_ptr := CONVERT(NATIVE_ARRAY_VOLATILE(V),POINTER).on Self;
+
+ old_ptr := CONVERT(NATIVE_ARRAY_VOLATILE(V),POINTER).on Self;
new_cap := new_nb_elts * element_sizeof;
//new_ptr := `realloc(@old_ptr, at new_cap)`:POINTER;
- new_ptr := MEMORY.realloc_dynamic old_ptr
- old_size ((old_nb_elts * element_sizeof).to_uinteger_32)
+ new_ptr := MEMORY.realloc_dynamic old_ptr
+ old_size ((old_nb_elts * element_sizeof).to_uinteger_32)
new_size (new_cap.to_uinteger_32);
new := CONVERT(POINTER,NATIVE_ARRAY_VOLATILE(V)).on new_ptr;
new.clear old_nb_elts to (new_nb_elts - 1);
@@ -118,20 +118,20 @@ Section Public
[ ...
+? {Result != NULL};
];
-
+
- first:V <- item 0;
-
+
- item index:INTEGER :V <-
// To read an `item'.
- // Assume that `calloc' is already done and that `index' is
+ // Assume that `calloc' is already done and that `index' is
// the range [0 .. `nb_elements'-1].
[ ...
-? {index >= 0};
]
- (
- `10`
+ (
+ `10`
);
-
+
- put element:V to index:INTEGER <-
// To write an item.
// Assume that `calloc' is already done and that `index'
@@ -139,30 +139,30 @@ Section Public
[ ...
-? {index >= 0};
]
- (
- force_put element to index;
+ (
+ force_put element to index;
)
[ ...
- +? {element = item index};
+ +? {element = item index};
];
-
+
//
// Displacement
//
-
- - Self:SELF '+' Left 80 other:INTEGER :NATIVE_ARRAY_VOLATILE(V) <-
+
+ - Self:SELF '+' Left 80 other:INTEGER :NATIVE_ARRAY_VOLATILE(V) <-
// other is in element index
( + ptr:POINTER;
-
+
ptr := to_pointer;
ptr := ptr + other * element_sizeof;
CONVERT(POINTER, NATIVE_ARRAY_VOLATILE(V)).on ptr
);
-
+
//
// Comparison:
//
-
+
- memcmp other:NATIVE_ARRAY_VOLATILE(V) until capacity:INTEGER :BOOLEAN <-
// True if all elements in range [0..capacity-1] are
// identical using `equal'. Assume Current and `other'
@@ -172,14 +172,14 @@ Section Public
-? {(capacity > 0) ->> {other.is_not_null}};
]
( + i:INTEGER;
-
+
i := capacity - 1;
{(i >= 0) && {safe_equal (item i,other.item i)}}.while_do {
i := i - 1;
};
i < 0
);
-
+
- slice_memcmp (at:INTEGER,other:NATIVE_ARRAY_VOLATILE(V),other_lower,other_upper:INTEGER) :BOOLEAN <-
// True if all elements in range [0 .. `other_upper' - `other_lower'] are identical
// to the elements in range [`other_lower' .. `other_upper'] of `other' using
@@ -192,28 +192,28 @@ Section Public
-? {(other_upper >= other_lower) ->> {other.is_not_null}};
]
( + i:INTEGER;
-
+
i := other_upper - other_lower;
{(i >= 0) && {safe_equal (item (at + i),other.item (other_lower + i))}}.while_do {
i := i - 1;
};
i < 0
);
-
+
- fast_memcmp other:NATIVE_ARRAY_VOLATILE(V) until capacity:INTEGER :BOOLEAN <-
// Same jobs as `memcmp' but uses infix `=' instead `equal'.
[ ...
-? {(capacity > 0) ->> {other.is_not_null}};
]
( + i:INTEGER;
-
+
i := capacity-1;
{(i >=0 ) && {item i = other.item i}}.while_do {
i := i - 1;
};
i < 0
);
-
+
- slice_fast_memcmp (at:INTEGER, other:NATIVE_ARRAY_VOLATILE(V), other_lower,other_upper:INTEGER) :BOOLEAN <-
// Same jobs as `slice_memcmp' but uses infix "=" instead of `is_equal'.
[ ...
@@ -222,15 +222,15 @@ Section Public
-? {other_upper >= other_lower - 1};
-? {(other_upper >= other_lower) ->> {other.is_not_null}};
]
- ( + i:INTEGER;
-
+ ( + i:INTEGER;
+
i := other_upper - other_lower;
{(i < 0) || {item (at + i) != other.item (other_lower + i)}}.until_do {
i := i - 1;
};
i < 0
);
-
+
- deep_memcmp other:NATIVE_ARRAY_VOLATILE(V) until capacity:INTEGER :BOOLEAN <-
// Same jobs as `memcmp' but uses `is_deep_equal' instead `equal'.
[ ...
@@ -239,7 +239,7 @@ Section Public
( + result:BOOLEAN; // BEN : A REVOIR, il y a + efficace...
+ e1,e2:V;
+ i:INTEGER;
-
+
result := TRUE;
i := capacity - 1;
{(result = FALSE) || {i < 0}}.until_do {
@@ -258,7 +258,7 @@ Section Public
};
result
);
-
+
- slice_deep_memcmp (at:INTEGER,other:NATIVE_ARRAY_VOLATILE(V),other_lower,other_upper:INTEGER) :BOOLEAN <-
// Same jobs as `slice_memcmp' but uses `is_deep_equal' instead of `is_equal'.
[ ...
@@ -267,10 +267,10 @@ Section Public
-? {other_upper >= other_lower - 1};
-? {(other_upper >= other_lower) ->> {other.is_not_null}};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ e1,e2:V;
+ result:BOOLEAN;
-
+
i := other_upper - other_lower;
result := TRUE;
{(! result) || {i < 0}}.until_do {
@@ -290,11 +290,11 @@ Section Public
};
result
);
-
+
//
// Searching:
//
-
+
- first_index_of element:V until upper:INTEGER :INTEGER <-
// Give the index of the first occurrence of `element' using
// `==' for comparison.
@@ -304,15 +304,15 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
{(idx > upper) || {safe_equal (element,item idx)}}.until_do {
idx := idx + 1;
};
idx
);
-
+
- index_of (element:V,start_index:INTEGER) until upper:INTEGER :INTEGER <-
- // Using `is_equal' for comparison, gives the index of the first occurrence of `element'
+ // Using `is_equal' for comparison, gives the index of the first occurrence of `element'
// at or after `start_index'. Answer `upper + 1' when the search fail.
// See also `fast_index_of', `reverse_index_of'.
[ ...
@@ -320,7 +320,7 @@ Section Public
-? {start_index <= upper};
]
( + result:INTEGER;
-
+
result := start_index;
{(result > upper) || {safe_equal (element,item result)}}.until_do {
result := result + 1;
@@ -331,7 +331,7 @@ Section Public
+? {Result.in_range start_index to (upper + 1)};
+? {(Result <= upper) ->> {safe_equal (element,item Result)}};
];
-
+
- reverse_index_of element:V from upper:INTEGER :INTEGER <-
// Give the index of the first occurrence of `element' using
// `==' for comparison, from upper to lower.
@@ -340,7 +340,7 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
idx := upper;
{(idx < 0) || {safe_equal (element,item idx)}}.until_do {
idx := idx - 1;
@@ -351,9 +351,9 @@ Section Public
+? {Result.in_range (-1) to upper};
+? {(Result > 0) ->> {safe_equal (element, item Result)}};
];
-
+
- fast_index_of (element:V,start_index:INTEGER) until upper:INTEGER :INTEGER <-
- // Using basic `=' for comparison, gives the index of the first occurrence of
+ // Using basic `=' for comparison, gives the index of the first occurrence of
// `element' at or after `start_index'. Answer `upper + 1' when the search fail.
// See also `index_of', `reverse_index_of'.
[ ...
@@ -361,9 +361,9 @@ Section Public
-? {start_index <= upper};
]
( + result:INTEGER;
-
+
result := start_index;
- {(result > upper) || {element = item result}}.until_do {
+ {(result > upper) || {element = item result}}.until_do {
result := result + 1;
};
result
@@ -372,7 +372,7 @@ Section Public
+? {Result.in_range start_index to (upper + 1)};
+? {(Result <= upper) ->> {element = item Result}};
];
-
+
- fast_reverse_index_of element:V from upper:INTEGER :INTEGER <-
// Same as `reverse_index_of' but use basic `=' for comparison.
// Search is done in reverse direction, which means from `upper' down to the
@@ -382,7 +382,7 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
idx := upper;
{(idx < 0) || {element = item idx}}.until_do {
idx := idx - 1;
@@ -402,7 +402,7 @@ Section Public
-? {upper >= -1};
]
( + idx:INTEGER;
-
+
{(idx > upper) || {element = item idx}}.until_do {
idx := idx + 1;
};
@@ -411,8 +411,8 @@ Section Public
[ ...
+? {Result.in_range 0 to (upper + 1)};
+? {(Result <= upper) ->> {element = item Result}};
- ];
-
+ ];
+
- has element:V until upper:INTEGER :BOOLEAN <-
// Look for `element' using `==' for comparison.
// Also consider `has' to choose the most appropriate.
@@ -420,8 +420,8 @@ Section Public
-? {upper >= -1};
]
( + result:BOOLEAN;
- + i:INTEGER;
-
+ + i:INTEGER;
+
i := upper;
{(result) || {i < 0}}.until_do {
result := safe_equal (element,item i);
@@ -429,7 +429,7 @@ Section Public
};
result
);
-
+
- fast_has element:V until upper:INTEGER :BOOLEAN <-
// Look for `element' using basic `=' for comparison.
// Also consider `has' to choose the most appropriate.
@@ -437,18 +437,18 @@ Section Public
-? {upper >= -1};
]
( + i:INTEGER;
-
+
i := upper;
{(i < 0) || {element = item i}}.until_do {
i := i - 1;
};
i >= 0
);
-
+
//
// Removing:
//
-
+
- remove_first upper:INTEGER <-
// Assume `upper' is a valid index.
// Move range [1 .. `upper'] by 1 position left.
@@ -456,13 +456,13 @@ Section Public
-? {upper >= 0};
]
( + i:INTEGER;
-
+
{i = upper}.until_do {
put (item (i + 1)) to i;
i := i + 1;
};
);
-
+
- remove index:INTEGER until upper:INTEGER <-
// Assume `upper' is a valid index.
// Move range [`index' + 1 .. `upper'] by 1 position left.
@@ -471,18 +471,18 @@ Section Public
-? {index <= upper};
]
( + i:INTEGER;
-
+
i := index;
{i = upper}.until_do {
put (item (i + 1)) to i;
i := i + 1;
};
);
-
+
//
// Replacing:
//
-
+
- replace_all old_value:V with new_value:V until upper:INTEGER <-
// Replace all occurences of the element `old_value' by `new_value'
// using `==' for comparison.
@@ -490,14 +490,14 @@ Section Public
[ ...
-? {upper >= -1};
]
- (
+ (
upper.downto 0 do { i:INTEGER;
(safe_equal (old_value,(item i))).if {
put new_value to i;
};
};
);
-
+
- fast_replace_all old_value:V with new_value:V until upper:INTEGER <-
// Replace all occurences of the element `old_value' by `new_value'
// using basic `=' for comparison.
@@ -505,18 +505,18 @@ Section Public
[ ...
-? {upper >= -1};
]
- (
+ (
upper.downto 0 do { i:INTEGER;
(old_value = item i).if {
put new_value to i;
};
};
);
-
+
//
// Adding:
//
-
+
- copy src:NATIVE_ARRAY_VOLATILE(V) to dest:INTEGER until src_capacity:INTEGER <-
// Copy range [0 .. `src_capacity - 1'] of `src' to range
// [`dest' .. `dest + src_capacity - 1'] of `Self'.
@@ -526,7 +526,7 @@ Section Public
-? {src_capacity >= 0};
]
( + i1, i2:INTEGER;
-
+
i1 := dest;
{i2 = src_capacity}.until_do {
put (src.item i2) to i1;
@@ -534,7 +534,7 @@ Section Public
i1 := i1 + 1;
};
);
-
+
- slice_copy src:NATIVE_ARRAY_VOLATILE(V) to dest:INTEGER from src_min:INTEGER to src_max:INTEGER <-
// Copy range [`src_min' .. `src_max'] of `src' to range
// [`at' .. `at + src_max - src_min - 1'] of `Current'.
@@ -544,8 +544,8 @@ Section Public
-? {src_min <= src_max + 1};
-? {(src != Self) | (dest != src_min)};
]
- ( + i1, i2:INTEGER;
-
+ ( + i1, i2:INTEGER;
+
i1 := dest;
i2 := src_min;
{i2 > src_max}.until_do {
@@ -554,11 +554,11 @@ Section Public
i1 := i1 + 1;
};
);
-
+
//
// Other:
//
-
+
- set_all_with v:V until upper:INTEGER <-
// Set all elements in range [0 .. upper] with
// value `v'.
@@ -570,7 +570,7 @@ Section Public
put v to i;
};
);
-
+
- set_slice_with v:V from lower:INTEGER until upper:INTEGER <-
// Set all elements in range [`lower' .. `upper'] with value `v'.
[ ...
@@ -578,14 +578,14 @@ Section Public
-? {upper >= lower - 1};
]
( + i:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
put v to i;
i := i + 1;
};
);
-
+
- clear_all upper:INTEGER <-
// Set all elements in range [0 .. `upper'] with
// the default value.
@@ -593,12 +593,12 @@ Section Public
-? {upper >= -1};
]
( + v:V;
-
- upper.downto 0 do { i:INTEGER;
+
+ upper.downto 0 do { i:INTEGER;
put v to i;
};
);
-
+
- clear lower:INTEGER to upper:INTEGER <-
// Set all elements in range [`lower' .. `upper'] with
// the default value
@@ -607,12 +607,12 @@ Section Public
-? {upper >= lower};
]
( + v:V;
-
+
lower.to upper do { i:INTEGER;
put v to i;
};
);
-
+
- copy_from model:NATIVE_ARRAY_VOLATILE(V) until upper:INTEGER <-
// Assume `upper' is a valid index both in Current and `model'.
[ ...
@@ -623,7 +623,7 @@ Section Public
put (model.item i) to i;
};
);
-
+
- deep_twin_from capacity:INTEGER :NATIVE_ARRAY_VOLATILE(V) <-
// To implement `deep_twin'. Allocate a new array of
// `capacity' initialized with `deep_twin'.
@@ -633,7 +633,7 @@ Section Public
]
( + element:V;
+ result:NATIVE_ARRAY_VOLATILE(V);
-
+
(capacity > 0).if {
result := calloc capacity;
(capacity - 1).downto 0 do { i:INTEGER;
@@ -645,7 +645,7 @@ Section Public
};
};
);
-
+
- move lower:INTEGER to upper:INTEGER by offset:INTEGER <-
// Move range [`lower' .. `upper'] by `offset' positions.
// Freed positions are not initialized to default values.
@@ -654,7 +654,7 @@ Section Public
-? {upper >= lower};
-? {lower + offset >= 0};
]
- (
+ (
(offset != 0).if {
(offset < 0).if {
lower.to upper do { i:INTEGER;
@@ -667,7 +667,7 @@ Section Public
};
};
);
-
+
- occurrences element:V until upper:INTEGER :INTEGER <-
// Number of occurrences of `element' in range [0..upper]
// using `equal' for comparison.
@@ -676,7 +676,7 @@ Section Public
-? {upper >= -1};
]
( + count:INTEGER;
-
+
upper.downto 0 do { i:INTEGER;
(safe_equal (element,item i)).if {
count := count + 1;
@@ -684,9 +684,9 @@ Section Public
};
count
);
-
+
- slice_occurrences element:V from lower:INTEGER until upper:INTEGER :INTEGER <-
- // Number of occurrences of `element' in range [`lower' .. `upper'] using
+ // Number of occurrences of `element' in range [`lower' .. `upper'] using
// `is_equal' for comparison.
// See also `slice_fast_occurrences' to chose the apropriate one.
[ ...
@@ -694,7 +694,7 @@ Section Public
-? {upper >= lower - 1};
]
( + i,result:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
(safe_equal (element,item i)).if {
@@ -713,7 +713,7 @@ Section Public
-? {upper >= -1};
]
( + count:INTEGER;
-
+
upper.downto 0 do { i:INTEGER;
(element = item i).if {
count := count + 1;
@@ -721,7 +721,7 @@ Section Public
};
count
);
-
+
- slice_fast_occurrences element:V from lower:INTEGER until upper:INTEGER :INTEGER <-
// Number of occurrences of `element' in range [`lower' .. `upper']
// using basic "=" for comparison.
@@ -731,7 +731,7 @@ Section Public
-? {upper >= lower - 1};
]
( + i,result:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
(element = item i).if {
@@ -741,7 +741,7 @@ Section Public
};
result
);
-
+
- all_default upper:INTEGER :BOOLEAN <-
// Do all items in range [0 .. `upper'] have their type's
// default value?
@@ -759,7 +759,7 @@ Section Public
};
result
);
-
+
- slice_default lower:INTEGER to upper:INTEGER :BOOLEAN <-
// Do all items in range [`lower' .. `upper'] have their type's default value?
// Note: for non Void items, the test is performed with the `is_default' predicate.
@@ -767,10 +767,10 @@ Section Public
-? {lower >= 0};
-? {upper >= lower - 1};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ v:V;
+ result:BOOLEAN;
-
+
result := TRUE;
i := lower;
{(i > upper) || {! result}}.until_do {
@@ -782,28 +782,28 @@ Section Public
};
result
);
-
+
//
// Interfacing with C:
//
-
+
- to_external:POINTER <- to_pointer;
// Gives access to the C pointer on the area of storage.
-
+
- is_null:BOOLEAN <- to_pointer.is_null;
-
+
- is_not_null:BOOLEAN <- to_pointer.is_not_null;
-
+
//
// Guru Section
//
-
+
- force_put element:V to index:INTEGER <-
// Used in Memory count: not to use directly without caution !
[ ...
-? {index>=0};
]
- (
- `9`;
+ (
+ `9`;
);
diff --git a/lib/internal/portable/collection/set.li b/lib/internal/portable/collection/set.li
index aa0f84f..9c3dda7 100644
--- a/lib/internal/portable/collection/set.li
+++ b/lib/internal/portable/collection/set.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SET(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Definition of a mathematical set of objects.";
// All common operations on mathematical sets are available.
// Well knowned implementations are HASHED_SET and AVL_SET.
-
+
Section Inherit
-
+
+ parent_traversable:TRAVERSABLE(V) := TRAVERSABLE(V);
-
+
+ parent_safe_equal:SAFE_EQUAL(V) := SAFE_EQUAL(V);
-
+
Section Public
//
// Counting:
//
-
+
- count:INTEGER <-
// Cardinality of the set (i.e. actual `count' of stored elements).
(
deferred;
0
);
-
+
- is_empty:BOOLEAN <- count = 0;
// Is the set empty?
-
+
//
// Adding and removing:
//
-
+
- add e:V <-
- // Add new item `e' to the set. The mathematical definition of adding
- // in a set is followed, i.e. the element `e' is added only and only
+ // Add new item `e' to the set. The mathematical definition of adding
+ // in a set is followed, i.e. the element `e' is added only and only
// if it is not yet present in the set.
- // As this `add' feature is actually using `is_equal', you may consider
- // to use `fast_add' for expanded objects as well while trying to get
+ // As this `add' feature is actually using `is_equal', you may consider
+ // to use `fast_add' for expanded objects as well while trying to get
// the very best performances.
[ ...
- -? {e != NULL};
+ -? {e != NULL};
]
(
deferred;
@@ -77,7 +77,7 @@ Section Public
- fast_add e:V <-
// Same job as `add', but uses basic `=' for comparison.
[ ...
- -? {e != NULL};
+ -? {e != NULL};
]
(
deferred;
@@ -92,7 +92,7 @@ Section Public
// Remove item `e' from the set: the mathematical definition of
// removing from a set is followed.
[ ...
- -? {e != NULL};
+ -? {e != NULL};
]
(
deferred;
@@ -106,7 +106,7 @@ Section Public
- fast_remove e:V <-
// Same job as `remove', but uses basic `=' for comparison.
[ ...
- -? {e != NULL};
+ -? {e != NULL};
]
(
deferred;
@@ -116,13 +116,13 @@ Section Public
"Not in not removed." +? {(! Old fast_has e) -> (count = Old count)};
"In then removed." +? {(Old fast_has e) -> (count = Old count - 1)};
];
-
+
- clear <- clear_count;
-
+
- clear_count <-
- // Empty the current set (`is_empty' is True after that call).
- // If possible, the actual implementation is supposed to keep
- // its internal storage area in order to refill `Current' in
+ // Empty the current set (`is_empty' is True after that call).
+ // If possible, the actual implementation is supposed to keep
+ // its internal storage area in order to refill `Current' in
// an efficient way.
//
// See also `clear_count_and_capacity' to select the most appropriate.
@@ -130,12 +130,12 @@ Section Public
deferred;
)
[ ...
- "Is empty." +? {count = 0};
+ "Is empty." +? {count = 0};
];
- clear_count_and_capacity <-
- // Empty the current set (`is_empty' is True after that call).
- // If possible, the actual implementation is supposed to release
+ // Empty the current set (`is_empty' is True after that call).
+ // If possible, the actual implementation is supposed to release
// its internal storage area for this memory to be used by other objects.
//
// See also `clear_count' to select the most appropriate.
@@ -143,36 +143,36 @@ Section Public
deferred;
)
[ ...
- "Is empty." +? {count = 0};
+ "Is empty." +? {count = 0};
];
-
+
//
// Looking and searching:
//
-
+
- has e:V :BOOLEAN <-
// Is element `e' in the set?
- // As this query is actually using `is_equal', you may consider to use
- // `fast_has' for expanded objects as well while trying to get the very
+ // As this query is actually using `is_equal', you may consider to use
+ // `fast_has' for expanded objects as well while trying to get the very
// best performances.
[ ...
- -? {e != NULL};
+ -? {e != NULL};
]
(
deferred;
FALSE
)
[ ...
- +? {Result -> ! is_empty};
+ +? {Result -> ! is_empty};
];
-
+
- fast_has e:V :BOOLEAN <-
// Is element `e' actually stored in the set?
- // Warning: this query is using basic `=' for comparison.
+ // Warning: this query is using basic `=' for comparison.
//
// See also `has' when dealing with reference types.
[ ...
- -? {e != NULL};
+ -? {e != NULL};
]
(
deferred;
@@ -182,7 +182,7 @@ Section Public
];
- reference_at e:V :V <-
- // Non Void when `e' is in the set. In such a situation, `Result' is the
+ // Non Void when `e' is in the set. In such a situation, `Result' is the
// object which is actually stored in the `Current' set (see ensure assertion).
[ ...
-? {e != NULL};
@@ -193,19 +193,19 @@ Section Public
NULL
)
[ ...
- +? {has e ->> {Result == e}};
+ +? {has e ->> {Result == e}};
];
-
+
//
// To provide iterating facilities:
//
-
+
- lower:INTEGER := 1;
- upper:INTEGER <-
( count )
[ ...
- +? {Result = count};
+ +? {Result = count};
];
- item i:INTEGER :V <-
@@ -213,25 +213,25 @@ Section Public
//
// See also `lower', `upper', `valid_index'.
//
- // SETs are intrinsically unordered, so there is no guarantee that
- // `item'(i) after performing an `add' or `remove' operation is related
+ // SETs are intrinsically unordered, so there is no guarantee that
+ // `item'(i) after performing an `add' or `remove' operation is related
// in any way to `item'(i) before that operation.
( + result:V;
-
+
deferred;
result
)
- [ ...
- +? {fast_has Result};
- ];
+ [ ...
+ +? {fast_has Result};
+ ];
- first:V <- item lower;
// The very `first' item.
//
// See also `last', `item'.
//
- // SETs are intrinsically unordered, so there is no guarantee that
- // `first' after performing an `add' or `remove' operation is related
+ // SETs are intrinsically unordered, so there is no guarantee that
+ // `first' after performing an `add' or `remove' operation is related
// in any way to `first' before that operation.
- last:V <- item upper;
@@ -239,22 +239,22 @@ Section Public
//
// See also `first', `item'.
//
- // SETs are intrinsically unordered, so there is no guarantee that
- // `last' after performing an `add' or `remove' operation is related
+ // SETs are intrinsically unordered, so there is no guarantee that
+ // `last' after performing an `add' or `remove' operation is related
// in any way to `last' before that operation.
-
+
//
// Mathematical operations:
//
-
+
- union other:SELF <-
// Make the union of the `Current' set with `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + i:INTEGER;
+ e:V;
-
+
i := 1;
{i > other.count}.until_do {
e := other.item i;
@@ -265,17 +265,17 @@ Section Public
};
)
[ ...
- +? {count <= Old count + other.count};
+ +? {count <= Old count + other.count};
];
-
+
- fast_union other:SELF <-
// Make the union of the `Current' set with `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + i:INTEGER;
+ e:V;
-
+
i := 1;
{i > other.count}.until_do {
e := other.item i;
@@ -286,16 +286,16 @@ Section Public
};
)
[ ...
- +? {count <= Old count + other.count};
+ +? {count <= Old count + other.count};
];
-
+
- Self:SELF '+' other:SELF :SELF <-
// Return the union of the `Current' set with `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + result:SELF;
-
+
result := twin;
result.union other;
result
@@ -308,11 +308,11 @@ Section Public
- intersection other:SELF <-
// Make the intersection of the `Current' set with `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ e:V;
-
+
i := upper;
{i < lower}.until_do {
e := item i;
@@ -323,17 +323,17 @@ Section Public
};
)
[ ...
- +? {count <= other.count.min (Old count)};
+ +? {count <= other.count.min (Old count)};
];
- fast_intersection other:SELF <-
// Make the intersection of the `Current' set with `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
- ( + i:INTEGER;
+ ( + i:INTEGER;
+ e:V;
-
+
i := upper;
{i < lower}.until_do {
e := item i;
@@ -344,16 +344,16 @@ Section Public
};
)
[ ...
- +? {count <= other.count.min (Old count)};
+ +? {count <= other.count.min (Old count)};
];
-
+
- Self:SELF '^' other:SELF :SELF <-
// Return the intersection of the `Current' set with `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + result:SELF;
-
+
result := twin;
result.intersection other;
result
@@ -366,10 +366,10 @@ Section Public
- minus other:SELF <-
// Make the set `Current' - `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + i:INTEGER;
-
+
(other = Self).if {
clear_count;
} else {
@@ -381,43 +381,43 @@ Section Public
};
)
[ ...
- +? {count <= Old count};
+ +? {count <= Old count};
];
- Self:SELF '-' other:SELF :SELF <-
// Return the set `Current' - `other'.
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + result:SELF;
-
+
result := twin;
result.minus other;
result
)
[ ...
+? {Result.count <= count};
- +? {Result.is_subset_of Self};
+ +? {Result.is_subset_of Self};
];
//
// Comparison:
//
-
+
- is_subset_of other:SELF :BOOLEAN <-
// Is the `Current' set a subset of `other'?
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + i:INTEGER;
+ result:BOOLEAN;
-
+
(Self = other).if {
result := TRUE;
}.elseif {count <= other.count} then {
result := TRUE;
i := 1;
- {(! result) || {i > count}}.until_do {
+ {(! result) || {i > count}}.until_do {
result := other.has (item i);
i := i + 1;
};
@@ -425,22 +425,22 @@ Section Public
result
)
[ ...
- +? {Result -> (count <= other.count)};
+ +? {Result -> (count <= other.count)};
];
- is_disjoint_from other:SELF :BOOLEAN <-
// Is the `Current' set disjoint from `other' ?
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + i:INTEGER;
+ result:BOOLEAN;
-
+
(Self != other).if {
result := TRUE;
i := 1;
(count <= other.count).if {
- {(! result) || {i > count}}.until_do {
+ {(! result) || {i > count}}.until_do {
result := ! other.has (item i);
i := i + 1;
};
@@ -454,22 +454,22 @@ Section Public
result
)
[ ...
- +? {Result = (Self ^ other).is_empty};
+ +? {Result = (Self ^ other).is_empty};
];
-
+
- fast_is_disjoint_from other:SELF :BOOLEAN <-
// Is the `Current' set disjoint from `other' ?
[ ...
- -? {other != NULL};
+ -? {other != NULL};
]
( + i:INTEGER;
+ result:BOOLEAN;
-
+
(Self != other).if {
result := TRUE;
i := 1;
(count <= other.count).if {
- {(! result) || {i > count}}.until_do {
+ {(! result) || {i > count}}.until_do {
result := ! other.fast_has (item i);
i := i + 1;
};
@@ -483,20 +483,20 @@ Section Public
result
)
[ ...
- // +? {Result = (Self ^ other).is_empty};
+ // +? {Result = (Self ^ other).is_empty};
];
-
+
- Self:SELF '==' other:SELF :BOOLEAN <-
// Is the `Current' set equal to `other'?
( + i:INTEGER;
+ result:BOOLEAN;
-
+
(Self = other).if {
result := TRUE;
}.elseif {count = other.count} then {
result := TRUE;
i := 1;
- {(! result) || {i > count}}.until_do {
+ {(! result) || {i > count}}.until_do {
result := other.has (item i);
i := i + 1;
};
@@ -510,17 +510,17 @@ Section Public
//
// Duplication.
//
-
+
- copy other:SELF <-
// Copy 'other' into the current set
( + i:INTEGER;
-
+
// Note: this naive implementation is OK because node
// recycling is implemented.
// BSBS: A revoir.
make;
i := 1;
- {i > other.count}.until_do {
+ {i > other.count}.until_do {
add (other.item i);
i := i + 1;
};
@@ -529,10 +529,10 @@ Section Public
- from_collection model:COLLECTION(V) <-
// Add all items of `model'.
[ ...
- -? {model != NULL};
+ -? {model != NULL};
]
( + i, up:INTEGER;
-
+
make
up := model.upper;
i := model.lower;
@@ -545,13 +545,13 @@ Section Public
//
// Agents based features:
//
-
+
- do_all action:BLOCK <-
// Apply `action' to every item of `Self'.
//
// See also `for_all', `exists'.
( + i:INTEGER;
-
+
i := lower;
{i > upper}.until_do {
action.value (item i);
@@ -565,7 +565,7 @@ Section Public
// See also `do_all', `exists'.
( + i:INTEGER;
+ result:BOOLEAN;
-
+
result := TRUE;
i := lower;
{(! result) || {i > upper}}.until_do {
@@ -581,7 +581,7 @@ Section Public
// See also `do_all', `for_all'.
( + i:INTEGER;
+ result:BOOLEAN;
-
+
i := lower;
{result || {i > upper}}.until_do {
result := predicate.value (item i);
@@ -593,21 +593,21 @@ Section Public
//
// Creation.
//
-
- - create:SELF <-
+
+ - create:SELF <-
( + result:SELF;
-
+
result := clone;
result.make;
result
);
-
+
- make <-
// Creation of an empty SET.
(
deferred;
)
[ ...
- +? {is_empty};
+ +? {is_empty};
];
diff --git a/lib/internal/portable/collection/simple_dictionary.li b/lib/internal/portable/collection/simple_dictionary.li
index b1304e0..22cd995 100644
--- a/lib/internal/portable/collection/simple_dictionary.li
+++ b/lib/internal/portable/collection/simple_dictionary.li
@@ -19,15 +19,15 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SIMPLE_DICTIONARY(V, K);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
// Basic dictionaries (assymmetry value / key)
// (class akin to DOUBLE_DICTIONARY)
Section Inherit
-
+
+ parent_dictionary:Expanded DICTIONARY(V,K);
diff --git a/lib/internal/portable/file_system/fs_min.li b/lib/internal/portable/file_system/fs_min.li
index d3b145b..5ee80e0 100644
--- a/lib/internal/portable/file_system/fs_min.li
+++ b/lib/internal/portable/file_system/fs_min.li
@@ -19,64 +19,64 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FS_MIN;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment := "File system minimum";
-
+
- external := `#include <unistd.h>`;
-
+
Section Inherit
-
+
- parent_object:OBJECT <- OBJECT;
-
-Section Private
-
+
+Section Private
+
- string_tmp:STRING := STRING.create 128;
-
+
Section Public
-
+
//
- // Independance File System
+ // Independance File System
//
-
- - open_read n:ABSTRACT_STRING :POINTER <-
+
+ - open_read n:ABSTRACT_STRING :POINTER <-
( + buf:NATIVE_ARRAY(CHARACTER);
string_tmp.copy n;
buf := string_tmp.to_external;
- `fopen((char*)@buf,"rb")`:(POINTER)
+ `fopen((char*)@buf,"rb")`:(POINTER)
);
- - open_write n:ABSTRACT_STRING :POINTER <-
+ - open_write n:ABSTRACT_STRING :POINTER <-
( + buf:NATIVE_ARRAY(CHARACTER);
string_tmp.copy n;
buf := string_tmp.to_external;
`fopen((char*)@buf,"wb")`:(POINTER)
);
-
- - read f:POINTER in buf:STRING size sz:INTEGER :INTEGER <-
+
+ - read f:POINTER in buf:STRING size sz:INTEGER :INTEGER <-
( + ptr:NATIVE_ARRAY(CHARACTER);
+ result:INTEGER;
- ptr := buf.to_external;
+ ptr := buf.to_external;
result := `fread((void *)(@ptr),(size_t)(1), (size_t)(@sz),(FILE*)(@f))`:(INTEGER);
ptr.put '\0' to sz;
buf.from_external ptr;
result
);
- - write f:POINTER with buf:STRING size sz:INTEGER :INTEGER <-
+ - write f:POINTER with buf:STRING size sz:INTEGER :INTEGER <-
( + ptr:NATIVE_ARRAY(CHARACTER);
+ result:INTEGER;
- ptr := buf.to_external;
+ ptr := buf.to_external;
result := `fwrite((void *)(@ptr),(size_t)(1), (size_t)(@sz),(FILE*)(@f))`:(INTEGER);
result
);
-
+
- close p:POINTER <- `fclose((FILE*)(@p))`;
-
+
- file_size p:POINTER :INTEGER <-
( + result:INTEGER;
`fseek((FILE*)(@p),0,SEEK_END)`;
@@ -89,13 +89,13 @@ Section Public
( + p:NATIVE_ARRAY(CHARACTER);
+ stream:POINTER;
+ result:BOOLEAN;
-
+
string_tmp.copy new_path;
- p := string_tmp.to_external;
+ p := string_tmp.to_external;
stream := `fopen((char*)@p,"w+b")`:POINTER;
(result := (stream != NULL)).if {
- close stream;
+ close stream;
};
result
);
-
+
diff --git a/lib/internal/portable/io/file_input_stream.li b/lib/internal/portable/io/file_input_stream.li
index 957941f..bcd396d 100644
--- a/lib/internal/portable/io/file_input_stream.li
+++ b/lib/internal/portable/io/file_input_stream.li
@@ -73,10 +73,10 @@ Section Public
- read_character <-
// Return last character from stream
( + result:INTEGER;
-
+
push_back_flag.if {
push_back_flag := FALSE;
- } else {
+ } else {
result := file.physical_read tmp size 1;
(result = 0).if {
// nothing was read
@@ -91,8 +91,8 @@ Section Public
};
);
- - unread_character <-
- (
+ - unread_character <-
+ (
push_back_flag := TRUE;
);
diff --git a/lib/internal/portable/io/file_output_stream.li b/lib/internal/portable/io/file_output_stream.li
index 5eaa52a..42ff121 100644
--- a/lib/internal/portable/io/file_output_stream.li
+++ b/lib/internal/portable/io/file_output_stream.li
@@ -50,21 +50,21 @@ Section Public
result.make std_file;
result
);
-
+
Section Public
- put_character c:CHARACTER <-
// Put `c' on stream
- (
+ (
tmp.put c to 0;
file.physical_write tmp size 1;
);
- flush <- (); //file.basic_fush;
-
+
Section Private
-
+
- tmp:NATIVE_ARRAY(UINTEGER_8) := NATIVE_ARRAY(UINTEGER_8).create 1;
-
+
// kate: hl Lisaac v0.2; indent-width 2; space-indent on; replace-tabs off;
// kate: tab-width 8; remove-trailing-space on;
diff --git a/lib/internal/portable/io/input_stream.li b/lib/internal/portable/io/input_stream.li
index cb57e9b..bc9271b 100644
--- a/lib/internal/portable/io/input_stream.li
+++ b/lib/internal/portable/io/input_stream.li
@@ -19,27 +19,27 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := INPUT_STREAM;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "This abstract class is the superclass of all classes \
\representing an input stream of bytes.";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
+
- push_back_flag:BOOLEAN;
// True if one char is already pushed back.
-
+
- last_integer:INTEGER;
// Last integer read using `read_integer'.
-
+
- last_string:STRING :=
// Access to the unique common buffer to get for example the result
// computed by `read_line', `read_word', `newline', etc. This is a once
@@ -47,15 +47,15 @@ Section Public
(
STRING.create 1024
);
-
-
+
+
- is_connected:BOOLEAN <-
// True when the corresponding stream is connected
// to some physical input device.
(
deferred;
);
-
+
- end_of_input:BOOLEAN <-
// Has end-of-input been reached ?
// True when the last character has been read.
@@ -63,10 +63,10 @@ Section Public
? { is_connected };
deferred;
);
-
-
+
+
// To read one character at a time:
-
+
- read_character:CHARACTER <-
// Read a character and assign it to `last_character'.
( + result:CHARACTER;
@@ -75,15 +75,15 @@ Section Public
? {! push_back_flag};
result
);
-
-
+
+
- last_character:CHARACTER <-
// Last character read with `read_character'.
(
? { is_connected };
deferred;
);
-
+
- unread_character <-
// Un-read the last character read.
(
@@ -91,9 +91,9 @@ Section Public
deferred;
? { push_back_flag };
);
-
+
// Skipping separators:
-
+
- skip_separators <-
// Skip all separators (see `is_separator' of class CHARACTER) and
// make the first non-separator available in `last_character'. This
@@ -109,12 +109,12 @@ Section Public
unread_character;
};
);
-
+
- skip_separators_using separators:STRING <-
// Same job as `skip_separators' using the `separators' set.
(
? { separators != NULL };
-
+
{ end_of_input ||{!separators.has last_character}}.until_do {
read_character;
};
@@ -122,7 +122,7 @@ Section Public
unread_character;
};
);
-
+
- skip_remainder_of_line <-
// Skip all the remainder of the line including the end of
// line character itself.
@@ -142,9 +142,9 @@ Section Public
};
};
);
-
+
// To read one number at a time:
-
+
- read_integer <-
// Read an integer according to the Lisaac syntax.
// Make result available in `last_integer'.
@@ -159,9 +159,9 @@ Section Public
// state = 2 :in the number.
// state = 3 :end state.
// state = 4 :error state.
-
+
? { !end_of_input };
-
+
{ state > 2 }.until_do {
read_character;
(state = 0).if {
@@ -192,7 +192,7 @@ Section Public
state := 3;
};
};
-
+
end_of_input.if {
state.when 0 to 1 then {
state := 4;
@@ -201,7 +201,7 @@ Section Public
};
};
};
-
+
!end_of_input.if {
unread_character;
};
@@ -213,9 +213,9 @@ Section Public
last_integer := - last_integer;
};
);
-
-
- /*
+
+
+ /*
- read_real <-
// Read a REAL and make the result available in `last_real'
// and in `last_double'.
@@ -225,10 +225,10 @@ Section Public
read_double;
last_real := last_double.to_real;
);
-
+
- last_real:REAL;
// Last real read with `read_real'.
-
+
- read_double <-
// Read a DOUBLE and make the result available in `last_double'.
(
@@ -240,11 +240,11 @@ Section Public
// state = 3 :in the fractional part.
// state = 4 :end state.
// state = 5 :error state.
-
+
? { !end_of_input };
-
+
last_string.clear
-
+
{ state >= 4 }.until_do {
read_character;
( state = 0).if {
@@ -287,7 +287,7 @@ Section Public
state := 4;
};
};
-
+
end_of_input.if {
state.when 2 to 4 then {
state := 4;
@@ -296,16 +296,16 @@ Section Public
};
};
};
-
+
(! end_of_input).if {
unread_character;
};
-
+
( state = 5 ).if {
io.put_string "Error in INPUT_STREAM.read_double.\n";
crash;
};
-
+
( last_string.count > 0).if {
last_double := last_string.to_double;
} else {
@@ -315,15 +315,15 @@ Section Public
last_double := - last_double;
};
);
-
-
+
+
- last_double:DOUBLE;
// Last double read with `read_double'.
-
+
*/
-
+
// To read one line or one word at a time:
-
+
- read_line <-
// Read a complete line ended by '\n' or `end_of_input'. Make the
// result available in `last_string' common buffer. The end of line
@@ -333,8 +333,8 @@ Section Public
last_string.clear;
read_line_in last_string;
);
-
-
+
+
- read_word <-
// Read a word using `is_separator' of class CHARACTER. Result is
// available in the `last_string' common buffer. Heading separators are
@@ -343,28 +343,28 @@ Section Public
// encountered, Result can be the empty string.
(
? { !end_of_input };
-
+
skip_separators;
!end_of_input.if {
read_character;
};
-
+
last_string.clear;
{ end_of_input || { last_character.is_separator }}.until_do {
last_string.extend last_character;
read_character;
};
);
-
+
- newline <-
// Consume input until newline ('\n') is found. Corresponding
// STRING is stored in `last_string' common buffer.
(
+ stop:BOOLEAN;
-
+
last_string.clear;
stop := end_of_input;
-
+
{stop}.until_do {
read_character;
( end_of_input || { last_character = '\n' }).if {
@@ -374,7 +374,7 @@ Section Public
};
};
);
-
+
- reach_and_skip keyword:STRING <-
// Try to skip enough characters in order to reach the `keyword'
// which is skipped too. If the `keyword' is not in the remainder of
@@ -385,19 +385,19 @@ Section Public
+ stop:BOOLEAN;
+ i:INTEGER;
+ first:CHARACTER;
-
+
? { !keyword.is_empty };
-
+
last_string.clear;
first := keyword.first;
-
+
{ end_of_input || stop }.until_do {
// Reach the first character of the `keyword':
i := 2;
{ (i > last_string.count) || { last_string.item i = first }}.until_do {
i := i + 1;
};
-
+
( i <= last_string.count ).if {
last_string.remove_first (i - 1);
} else {
@@ -410,10 +410,10 @@ Section Public
};
last_string.extend last_character;
};
-
+
? { !end_of_input ->> {last_string.item 1 = first}};
? { last_string.count <= keyword.count };
-
+
// Now we need as many characters as in `keyword':
{ end_of_input || { last_string.count = keyword.count } }.until_do {
read_character;
@@ -421,17 +421,17 @@ Section Public
};
stop := last_string == keyword;
};
-
+
!end_of_input.if {
read_character;
unread_character;
};
-
+
? {!end_of_input ->> { last_string == keyword} };
);
-
+
// Other features:
-
+
- read_line_in buffer:STRING <-
// Same jobs as `read_line' but storage is directly done in `buffer'.
(
@@ -439,13 +439,13 @@ Section Public
? { buffer != NULL };
deferred;
);
-
+
- read_word_using separators:STRING <-
// Same jobs as `read_word' using `separators'.
(
? { !end_of_input };
? { separators != NULL };
-
+
skip_separators_using separators;
!end_of_input.if {
read_character;
@@ -456,24 +456,24 @@ Section Public
read_character;
};
);
-
+
- read_tail_in str:STRING <-
// Read all remaining character of the file in `str'.
(
? { str != NULL };
-
+
end_of_input.until_do {
read_character;
!end_of_input.if {
str.extend last_character;
};
};
-
+
? { end_of_input };
);
Section Private
-
+
- basic_io_getc :CHARACTER <- SYSTEM_IO.get_char;
-
+
- basic_io_eof :CHARACTER <- SYSTEM_IO.eof;
\ No newline at end of file
diff --git a/lib/internal/portable/io/std_input_output.li b/lib/internal/portable/io/std_input_output.li
index 99b10fe..c1e0766 100644
--- a/lib/internal/portable/io/std_input_output.li
+++ b/lib/internal/portable/io/std_input_output.li
@@ -19,20 +19,20 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=STD_INPUT_OUTPUT;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="To have the useful `io'";
-
+
Section Inherit
-
+
- inherit_input_stream:INPUT_STREAM := INPUT_STREAM;
- inherit_output_stream:OUTPUT_STREAM := OUTPUT_STREAM;
-
+
Section Public
- is_connected:BOOLEAN := TRUE;
@@ -70,7 +70,7 @@ Section Public
(
std_input.end_of_input
);
-
+
- read_line_in str:STRING <-
(
std_input.read_line_in str;
diff --git a/lib/internal/portable/memory/memory.li b/lib/internal/portable/memory/memory.li
index e6328a6..3f5924f 100644
--- a/lib/internal/portable/memory/memory.li
+++ b/lib/internal/portable/memory/memory.li
@@ -19,104 +19,104 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Strict MEMORY;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- comment := "Memory manager 32/64 bits.";
-
+
- external :=
`
#define MINIMUM_SIZE 256
void *table_size[MINIMUM_SIZE/sizeof(void *)];
void *last_block[64];
`;
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
//
// MACRO ALLOCATOR
//
-
+
Section Mapping
-
- + previous_linear:MEMORY;
+
+ + previous_linear:MEMORY;
+ size_and_id:UINTEGER_CPU;
-
- //---------------> Limit for Busy
-
+
+ //---------------> Limit for Busy
+
+ next_free :MEMORY;
+ previous_free:MEMORY;
-
+
//---------------> Limit for Free
-
-Section Private
-
+
+Section Private
+
//
// Product by compiler.
//
-
+
// For GC only.
/*
- get_object_size t:INTEGER :INTEGER <- `get_object_size(@t)`:INTEGER;
-
- - mark_static_object <- `mark_static_object()`;
-
+
+ - mark_static_object <- `mark_static_object()`;
+
- demark_static_object <- `demark_static_object()`;
-
+
- mark_object ptr:POINTER type t:INTEGER <- `mark_object(@ptr, at t)`;
-
+
- demark_object ptr:POINTER type t:INTEGER <- `demark_object(@ptr, at t)`;
- */
-
+ */
+
Section Public
-
- - object_size:INTEGER <- POINTER.object_size + UINTEGER_CPU.object_size;
-
-Section MEMORY
-
+
+ - object_size:INTEGER <- POINTER.object_size + UINTEGER_CPU.object_size;
+
+Section MEMORY
+
- is_debug_memory:BOOLEAN := FALSE;
-
+
- this:POINTER <- CONVERT(MEMORY,POINTER).on Self;
-
+
- begin:POINTER <- this + object_size;
-
+
- size:UINTEGER_CPU <- size_and_id & ~ 3.to_uinteger_cpu;
-
+
- next_linear:MEMORY <- CONVERT(POINTER,MEMORY).on (begin + size);
-
+
- id:UINTEGER_CPU <- size_and_id & 01b;
-
+
- id_end:UINTEGER_CPU <- 10b;
-
+
- is_end:BOOLEAN <- (size_and_id & id_end).to_boolean;
-
+
- set_previous_linear p:MEMORY <- ( previous_linear := p; );
-
+
- set_size_and_id s:UINTEGER_CPU <- ( size_and_id := s; );
-
+
- get_index p:POINTER :UINTEGER_CPU <- (p - begin_memory).to_uinteger_cpu >> 26;
-
+
- nb_page:UINTEGER_CPU;
-
- - put_last m:MEMORY to idx:UINTEGER_CPU <-
+
+ - put_last m:MEMORY to idx:UINTEGER_CPU <-
(
? {idx < nb_page};
`last_block[@idx] = @m`;
);
-
+
- get_last idx:UINTEGER_CPU :MEMORY <-
- (
+ (
? {idx < nb_page};
`last_block[@idx]`:MEMORY
);
-
+
- search_capacity <-
- (
+ (
capacity_max := SYSTEM.get_memory_capacity;
begin_memory := SYSTEM.get_begin_memory;
/*
@@ -130,7 +130,7 @@ Section MEMORY
- new_page:MEMORY <-
( + old_size,new_size:UINTEGER_CPU;
+ block:MEMORY;
-
+
(capacity_max = 0).if {
search_capacity;
};
@@ -142,32 +142,32 @@ Section MEMORY
die_with_code exit_failure_code;
};
/*
- "Begin_memory + old_size : ".print;
+ "Begin_memory + old_size : ".print;
(begin_memory + old_size).print_hex; '\n'.print;
"object_size ".print; object_size.print; '\n'.print;
*/
- block := CONVERT(POINTER,MEMORY).on (begin_memory + old_size);
- block.set_previous_linear NULL;
+ block := CONVERT(POINTER,MEMORY).on (begin_memory + old_size);
+ block.set_previous_linear NULL;
block.set_size_and_id (id_free | id_end | (64.mb - object_size));
- block.add_link_free;
+ block.add_link_free;
put_last block to (nb_page - 1);
block
);
-
+
//
// Busy / Free Block.
//
-
+
- id_free:UINTEGER_CPU <- 00b;
- id_busy:UINTEGER_CPU <- 01b;
-
+
- set_next_free n:MEMORY <- ( next_free := n; );
- set_previous_free p:MEMORY <- ( previous_free := p; );
-
+
- delete_link_free <-
( + prev,next:MEMORY;
-
+
prev := previous_free;
next := next_free;
(prev = NULL).if {
@@ -179,72 +179,72 @@ Section MEMORY
next.set_previous_free prev;
};
);
-
+
- add_link_free <-
- (
+ (
next_free := first_free;
previous_free := NULL;
- (first_free != NULL).if {
+ (first_free != NULL).if {
first_free.set_previous_free Self;
- };
- first_free := Self;
+ };
+ first_free := Self;
);
-
+
Section MEMORY
-
+
- first_free:MEMORY;
-
+
//
// Management.
//
-
+
- to_free idx:UINTEGER_CPU <-
( + new_free,next:MEMORY;
+ new_size:UINTEGER_CPU;
{id = id_busy} ? "Memory: Macro block not busy.";
- {idx.in_range 0 to 63} ? "Memory: Bound index.";
-
+ {idx.in_range 0 to 63} ? "Memory: Bound index.";
+
next := next_linear;
new_free := previous_linear;
new_size := size_and_id & ~ 1.to_uinteger_cpu;
((new_free = NULL) || {new_free.id != id_free}).if {
// `Self' => Free
- new_free := Self;
- add_link_free;
+ new_free := Self;
+ add_link_free;
} else {
// `previous_linear' => Free
- new_size := new_size + new_free.size_and_id + object_size;
+ new_size := new_size + new_free.size_and_id + object_size;
};
-
+
((! is_end) && {next.id = id_free}).if {
// Delete and concat `next_linear'
new_size := new_size + next.size_and_id + object_size;
- next.delete_link_free;
- };
+ next.delete_link_free;
+ };
new_free.set_size_and_id new_size;
-
+
(new_free.is_end).if {
- put_last new_free to idx;
+ put_last new_free to idx;
} else {
next := new_free.next_linear;
next.set_previous_linear new_free;
- };
+ };
);
-
+
- to_busy sz:POINTER index idx:UINTEGER_CPU <-
- ( + siz,new_size:UINTEGER_CPU;
+ ( + siz,new_size:UINTEGER_CPU;
+ new,next:MEMORY;
- {id = id_free} ? "Memory: Macro block not free.";
+ {id = id_free} ? "Memory: Macro block not free.";
{(sz & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
-
+
delete_link_free;
- //
+ //
siz := size_and_id;
- new_size := siz - sz;
+ new_size := siz - sz;
(new_size > (minimum_size+object_size+object_size)).if {
siz := sz;
new := CONVERT(POINTER,MEMORY).on (begin+sz);
- new.set_previous_linear Self;
+ new.set_previous_linear Self;
new.set_size_and_id (new_size - object_size);
new.add_link_free;
(new.is_end).if {
@@ -253,21 +253,21 @@ Section MEMORY
next := new.next_linear;
next.set_previous_linear new;
};
- };
+ };
size_and_id := siz | id_busy;
{id = id_busy} ? "Memory: Macro Block not busy.";
);
-
+
- resize new_size:UINTEGER_CPU index idx:UINTEGER_CPU :MEMORY <-
( + nxt,result:MEMORY;
- + old_size,sz:UINTEGER_CPU;
-
+ + old_size,sz:UINTEGER_CPU;
+
{(new_size & (POINTER.object_size -1)) = 0} ? "Memory: Alignment.";
{idx.in_range 0 to 63} ? "Memory: Bound index.";
-
+
old_size := size;
- (new_size > old_size).if {
- (! is_end).if {
+ (new_size > old_size).if {
+ (! is_end).if {
nxt := next_linear;
sz := new_size - old_size - object_size;
((nxt.id = id_free) && {nxt.size >= sz}).if {
@@ -280,33 +280,33 @@ Section MEMORY
nxt.set_previous_linear Self;
};
result := Self;
- };
+ };
};
- (result = NULL).if {
- // new allocation.
- result := search new_size;
- copy begin to (result.begin) size old_size;
- to_free idx;
+ (result = NULL).if {
+ // new allocation.
+ result := search new_size;
+ copy begin to (result.begin) size old_size;
+ to_free idx;
};
} else {
result := Self;
- };
+ };
result
);
-
+
//
// Searching.
//
-
+
- search new_size:UINTEGER_CPU :MEMORY <-
( + result:MEMORY;
+ idx:UINTEGER_CPU;
-
-
+
+
{new_size > minimum_size-POINTER.object_size} ? "Memory: Big block.";
{(new_size & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
-
- result := first_free;
+
+ result := first_free;
{(result != NULL) && {result.size < new_size}}.while_do {
result := result.next_free;
};
@@ -316,17 +316,17 @@ Section MEMORY
idx := get_index (result.this);
{idx.in_range 0 to 63} ? "Memory: Bound index.";
result.to_busy new_size index idx;
-
+
result
);
-
+
- new_lab t:UINTEGER_32 :POINTER <-
( + idx:UINTEGER_CPU;
+ blc,prev:MEMORY;
+ result:POINTER;
-
+
{
- (idx < nb_page) &&
+ (idx < nb_page) &&
{
blc := get_last idx;
(blc.size < 4096) || {blc.id = id_busy}
@@ -334,80 +334,80 @@ Section MEMORY
}.while_do {
idx := idx + 1;
};
-
- (idx >= nb_page).if {
+
+ (idx >= nb_page).if {
blc := new_page;
- };
+ };
blc.set_size_and_id (blc.size_and_id - 4096);
- result := blc.next_linear.this;
-
+ result := blc.next_linear.this;
+
(blc.size < minimum_size).if {
blc.delete_link_free;
prev := blc.previous_linear;
- (prev != NULL).if {
+ (prev != NULL).if {
prev.set_size_and_id (prev.size_and_id + blc.size_and_id + object_size);
put_last prev to idx;
};
};
- put_32 t to result;
-
+ put_32 t to result;
+
{((result - begin_memory) & 0FFFh) = 0} ? "Memory: Alignment LAB.";
result + UINTEGER_32.object_size
- );
-
+ );
+
Section Private
-
+
- minimum_size:UINTEGER_CPU <- `MINIMUM_SIZE`:UINTEGER_CPU;
-
- - table_type idx:UINTEGER_32 :POINTER <-
+
+ - table_type idx:UINTEGER_32 :POINTER <-
(
//{idx.in_range 0 to 17} ? "Memory: Bound table_type.";
`&(table_type[@idx])`:POINTER
);
-
- - table_size idx:UINTEGER_CPU :POINTER <-
+
+ - table_size idx:UINTEGER_CPU :POINTER <-
(
- {idx.in_range 1 to (minimum_size/POINTER.object_size)} ?
+ {idx.in_range 1 to (minimum_size/POINTER.object_size)} ?
"Memory: Bound table_size.";
`&(table_size[@idx-1])`:POINTER
);
-
+
- begin_memory:POINTER;
-
+
- capacity_max:UINTEGER_CPU;
-
+
- read_ptr p:POINTER :POINTER <-
( + mem:NATIVE_ARRAY(POINTER);
mem := CONVERT(POINTER, NATIVE_ARRAY(POINTER)).on p;
mem.item 0
);
-
+
- put_ptr v:POINTER to p:POINTER <-
( + mem:NATIVE_ARRAY(POINTER);
mem := CONVERT(POINTER, NATIVE_ARRAY(POINTER)).on p;
mem.put v to 0;
);
-
+
- put_32 v:UINTEGER_32 to p:POINTER <-
( + mem:NATIVE_ARRAY(UINTEGER_32);
mem := CONVERT(POINTER, NATIVE_ARRAY(UINTEGER_32)).on p;
mem.put v to 0;
);
-
+
- micro_alloc new_size:UINTEGER_CPU table ptr_table:POINTER lab lab_type:UINTEGER_32 :POINTER <-
( + result,next,next2:POINTER;
+ page:POINTER;
{(new_size & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
{new_size >= POINTER.object_size} ? "Memory: Size = 0.";
- result := read_ptr ptr_table;
- (result = NULL).if {
- // Allocation new LAB.
- result := new_lab lab_type;
- next := result + new_size;
+ result := read_ptr ptr_table;
+ (result = NULL).if {
+ // Allocation new LAB.
+ result := new_lab lab_type;
+ next := result + new_size;
put_ptr NULL to next;
- put_ptr next to ptr_table;
- } else {
+ put_ptr next to ptr_table;
+ } else {
// Next Linked list.
next := read_ptr result;
(next = NULL).if {
@@ -416,72 +416,72 @@ Section Private
((page + (new_size << 1)) <= 4096).if {
next := result + new_size;
} else {
- next := new_lab lab_type;
+ next := new_lab lab_type;
};
put_ptr NULL to next;
put_ptr next to ptr_table;
- } else {
- // Linked list allocation.
+ } else {
+ // Linked list allocation.
next2 := read_ptr next & ~ 11b.to_uinteger_cpu;
- put_ptr next2 to result;
- result := next;
- };
- };
+ put_ptr next2 to result;
+ result := next;
+ };
+ };
result
);
-
+
- micro_free p:POINTER table ptr_table:POINTER <-
( + next,last:POINTER;
{p != NULL} ? "Memory: Pointer NULL.";
-
+
last := read_ptr ptr_table;
{last != NULL} ? "Memory: Table NULL.";
next := read_ptr last;
put_ptr (next | 11b) to p;
put_ptr p to last;
);
-
+
Section Private
- copy src:POINTER to dst:POINTER size sz:UINTEGER_CPU <-
( + na_src,na_dst:NATIVE_ARRAY(POINTER);
+ siz:INTEGER;
-
+
siz := sz.to_integer;
{(siz & (POINTER.object_size -1)) = 0} ? "Memory: Copy alignment.";
siz := siz / POINTER.object_size;
na_src := CONVERT(POINTER, NATIVE_ARRAY(POINTER)).on src;
na_dst := CONVERT(POINTER, NATIVE_ARRAY(POINTER)).on dst;
- //
- (siz - 1).downto 0 do { j:INTEGER;
+ //
+ (siz - 1).downto 0 do { j:INTEGER;
na_dst.put (na_src.item j) to j;
- };
+ };
);
-
+
- fill_memory src:POINTER size sz:UINTEGER_CPU <-
// Just for debug.
( + na_src:NATIVE_ARRAY(POINTER);
+ siz:UINTEGER_CPU;
-
+
{(sz & (POINTER.object_size -1)) = 0} ? "Memory: Copy alignment.";
-
- siz := sz.align_power (POINTER.object_size) / POINTER.object_size;
- na_src := CONVERT(POINTER,NATIVE_ARRAY(POINTER)).on src;
+
+ siz := sz.align_power (POINTER.object_size) / POINTER.object_size;
+ na_src := CONVERT(POINTER,NATIVE_ARRAY(POINTER)).on src;
((siz-1).to_integer).downto 0 do { j:INTEGER;
na_src.put NULL to j;
- };
- );
+ };
+ );
/*
Section External
-
+
- calloc (nb,sz:UINTEGER) :POINTER <-
( + result:POINTER;
+ size:UINTEGER_32;
+ tab:NATIVE_ARRAY(UINTEGER_8);
-
+
size := nb*sz;
"calloc = ".print;
- size.print; '\n'.print;
+ size.print; '\n'.print;
result := malloc (size.to_uinteger);
tab := CONVERT(POINTER,NATIVE_ARRAY(UINTEGER_8)).on result;
0.to (size-1) do { i:INTEGER;
@@ -489,11 +489,11 @@ Section External
};
result
);
-
+
- malloc sz:UINTEGER :POINTER <-
( + result:POINTER;
"malloc = ".print;
- sz.print; '\n'.print;
+ sz.print; '\n'.print;
result := MEMORY.alloc_dynamic (sz.to_pointer);
(result = NULL).if {
"MEMORY : MERDE\n".print;
@@ -501,10 +501,10 @@ Section External
"MEMORY :sortie\n".print;
result
);
-
+
- free ptr:POINTER <-
( + mem:MEMORY;
-
+
"FREE\n".print;
(ptr != NULL).if {
mem := CONVERT(POINTER, MEMORY).on (ptr - object_size);
@@ -518,127 +518,127 @@ Section Public
//
// MICRO ALLOCATOR
//
-
+
- alloc_type t:UINTEGER_32 size sz:UINTEGER_CPU :POINTER <-
// Allocation for object without type. (LAB_TYPE)
- ( + ptr_table,result:POINTER;
+ ( + ptr_table,result:POINTER;
+ new_size:UINTEGER_CPU;
-
+
verify_memory "Begin alloc_type size";
-
+
{sz <= minimum_size} ? "Memory: Size bound.";
- new_size := sz.align_power (POINTER.object_size);
- {(new_size & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
+ new_size := sz.align_power (POINTER.object_size);
+ {(new_size & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
ptr_table := table_type t;
- result := micro_alloc new_size table ptr_table lab (t | 1b);
-
+ result := micro_alloc new_size table ptr_table lab (t | 1b);
+
verify_memory "End alloc_type size";
-
+
result
);
-
+
- free p:POINTER type t:UINTEGER_32 <-
( + ptr_table:POINTER;
{p != NULL} ? "Memory: Pointer NULL.";
-
+
verify_memory "Begin free type";
-
+
ptr_table := table_type t;
micro_free p table ptr_table;
-
+
verify_memory "End free type";
);
-
+
- alloc_size sz:UINTEGER_CPU :POINTER <-
// Allocation for object with type. (LAB_SIZE)
( + ptr_table,result:POINTER;
+ new_size:UINTEGER_CPU;
-
+
verify_memory "Begin alloc_size";
-
+
{sz <= minimum_size} ? "Memory: Size bound.";
-
- new_size := sz.align_power (POINTER.object_size);
-
+
+ new_size := sz.align_power (POINTER.object_size);
+
{(new_size & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
-
- ptr_table := table_size (new_size / POINTER.object_size);
+
+ ptr_table := table_size (new_size / POINTER.object_size);
result := micro_alloc new_size table ptr_table lab (new_size.to_uinteger_32);
-
+
verify_memory "End alloc_size";
result
);
-
+
- free p:POINTER size sz:UINTEGER_CPU <-
( + ptr_table:POINTER;
+ new_size:UINTEGER_CPU;
{p != NULL} ? "Memory: Pointer NULL.";
-
+
verify_memory "Begin free size";
-
- new_size := sz.align_power (POINTER.object_size);
-
+
+ new_size := sz.align_power (POINTER.object_size);
+
{(new_size & (POINTER.object_size - 1)) = 0} ? "Memory: Alignment.";
-
+
ptr_table := table_size (new_size / POINTER.object_size);
micro_free p table ptr_table;
-
+
verify_memory "End free size";
);
-
+
- alloc_dynamic sz:UINTEGER_CPU :POINTER <-
// Allocation NATIVE_ARRAY[E]. (LAB_SIZE or malloc)
( + new_size,new_size2:UINTEGER_CPU;
+ result:POINTER;
{sz != 0} ? "Memory: Size = 0";
-
+
verify_memory "Begin alloc_dynamic";
-
- new_size := sz.align_power (POINTER.object_size);
+
+ new_size := sz.align_power (POINTER.object_size);
new_size2 := new_size; // + UINTEGER_CPU.object_size;
(new_size2 <= minimum_size).if {
- result := alloc_size new_size2;
+ result := alloc_size new_size2;
//put_32 3 to result; // 3 : 2=NATIVE_ARRAY
result := result; // + UINTEGER_CPU.object_size;
- } else {
- result := search new_size .begin;
+ } else {
+ result := search new_size .begin;
};
-
+
verify_memory "End alloc_dynamic";
-
- result
+
+ result
);
-
+
- realloc_dynamic p:POINTER old_size old_sz:UINTEGER_CPU new_size new_sz:UINTEGER_CPU :POINTER <-
( + old_size,old_size2,new_size:UINTEGER_CPU;
+ mem:MEMORY;
- + result:POINTER;
+ + result:POINTER;
{old_size < new_sz} ? "Memory: New size < Old size.";
-
+
verify_memory "Begin realloc_dynamic";
-
- old_size := old_sz.align_power (POINTER.object_size);
- old_size2 := old_size; // + UINTEGER_CPU.object_size;
- new_size := new_sz.align_power (POINTER.object_size);
- (old_size2 <= minimum_size).if {
- result := alloc_dynamic new_size;
+
+ old_size := old_sz.align_power (POINTER.object_size);
+ old_size2 := old_size; // + UINTEGER_CPU.object_size;
+ new_size := new_sz.align_power (POINTER.object_size);
+ (old_size2 <= minimum_size).if {
+ result := alloc_dynamic new_size;
copy p to result size old_size;
- free (p /*- UINTEGER_CPU.object_size*/) size old_size2;
- } else {
+ free (p /*- UINTEGER_CPU.object_size*/) size old_size2;
+ } else {
mem := CONVERT(POINTER, MEMORY).on (p - object_size);
- result := mem.resize new_size index (get_index p).begin;
+ result := mem.resize new_size index (get_index p).begin;
};
-
+
verify_memory "End realloc_dynamic";
-
+
result
);
-
+
- free_dynamic p:POINTER size sz:UINTEGER_CPU <-
( + new_size,new_size2:UINTEGER_CPU;
+ mem:MEMORY;
-
+
new_size := sz.align_power (POINTER.object_size); // BSBS: Optim, alignment by compilo.
new_size2 := new_size; // + UINTEGER_CPU.object_size;
(new_size2 <= minimum_size).if {
@@ -648,19 +648,19 @@ Section Public
mem.to_free (get_index p);
};
);
-
+
//
// GARBAGE COLLECTOR
//
/*
- garbage_collector_pass <-
(
- mark;
+ mark;
sweep;
);
-
-Section Private
-
+
+Section Private
+
- mark <-
( + stack,lab:NATIVE_ARRAY(POINTER);
+ ptr,beg_mem,end_mem,ptr_lab,ptr_table,lim_lab:POINTER;
@@ -669,10 +669,10 @@ Section Private
+ mem:MEMORY;
+ type:UINTEGER_32;
+ type_object, size_object,step:UINTEGER_32;
-
+
// Mark Global + BSS.
- mark_static_object;
-
+ mark_static_object;
+
// Mark Stack object.
stack := `top_stack()`:NATIVE_ARRAY(POINTER);
size_stack := (`@stack - begin_stack`:UINTEGER_32) / POINTER.object_size.to_uinteger_32;
@@ -687,7 +687,7 @@ Section Private
mem := get_last (ptr_mem >> 26);
(ptr > mem.next_linear.this).if {
// `ptr' is in LAB.
- ptr_lab := begin_memory + (ptr_mem & 0FFFFF000h);
+ ptr_lab := begin_memory + (ptr_mem & 0FFFFF000h);
type := read ptr_lab .to_uinteger_32;
(type & 01b != 0).if {
// LAB Type.
@@ -713,15 +713,15 @@ Section Private
};
};
);
-
+
- sweep <-
( + last:MEMORY;
+ ptr_lab,ptr_end,ptr,ptr_table,end_lab,ptr_max:POINTER;
+ type,type_object,size_object:UINTEGER_32;
-
+
// Demark a Global + BSS.
demark_static_object;
-
+
// Demark a Store.
ptr_end := begin_memory + 64.mb;
(nb_page-1).downto 0 do { i:UINTEGER_32;
@@ -747,7 +747,7 @@ Section Private
ptr := ptr + size_object;
};
} else {
- // LAB Size.
+ // LAB Size.
size_object := type;
ptr_table := table_size (size_object / POINTER.object_size.to_uinteger_32);
end_lab := read ptr_table;
@@ -761,19 +761,19 @@ Section Private
demark_object ptr type type_object;
ptr := ptr + size_object;
};
- };
+ };
};
ptr_end := ptr_end + 64.mb;
};
);
*/
-
+
Section Private
-
+
- verify_memory msg:STRING_CONSTANT<-
( + m,next,prev:MEMORY;
+ msg_intern:STRING_CONSTANT;
-
+
(is_debug_memory).if {
(begin_memory != NULL).if {
next := CONVERT(POINTER, MEMORY).on begin_memory;
@@ -781,16 +781,16 @@ Section Private
m := next;
next := m.next_linear;
prev := m.previous_linear;
-
+
(prev = NULL).if {
(m != begin_memory).if {
msg_intern := "Begin list fail!\n";
};
- } else {
+ } else {
(prev.next_linear != m).if {
msg_intern := "Previous fail!\n";
};
- };
+ };
(m.id = id_busy).if {
// Busy
} else {
@@ -800,12 +800,12 @@ Section Private
};
};
(m.is_end).if {
-
+
} else {
(next.previous_linear != m).if {
msg_intern := "Next fail!\n";
};
- };
+ };
}.do_until {(m.is_end) || {msg_intern != NULL}};
(msg_intern != NULL).if {
"************* Crash memory *************\n".print;
@@ -817,28 +817,28 @@ Section Private
};
};
);
-
+
- print_memory <-
( + m,next:MEMORY;
-
+
"------------------------------------\n".print;
"first free : ".print;
- first_free.this.print_hex;
+ first_free.this.print_hex;
'\n'.print;
-
+
next := CONVERT(POINTER, MEMORY).on begin_memory;
{
m := next;
next := m.next_linear;
-
+
'['.print;
(m.previous_linear = NULL).if {
"NULL".print;
} else {
- (m.previous_linear.this).print_hex;
+ (m.previous_linear.this).print_hex;
};
"<-".print;
- m.this.print_hex;
+ m.this.print_hex;
(m.id = id_busy).if {
"(B)".print;
} else {
diff --git a/lib/internal/portable/number/fixed_real.li b/lib/internal/portable/number/fixed_real.li
index 9dba77c..e9152b3 100644
--- a/lib/internal/portable/number/fixed_real.li
+++ b/lib/internal/portable/number/fixed_real.li
@@ -19,55 +19,55 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FIXED_REAL;
-
+
- comment := "Real number of fixed decimal part.";
-
+
Section Insert
-
+
- parent_real:REAL := REAL;
-
+
Section SELF
- - shift_bits:INTEGER <-
+ - shift_bits:INTEGER <-
(
deferred;
0
);
-
+
Section Public
-
+
- floor:INTEGER <-
(
deferred;
);
-
- //
+
+ //
// Conversions with tests
//
-
+
//
// - To unsigned integers
//
- - to_uinteger_8:UINTEGER_8 <-
- (
+ - to_uinteger_8:UINTEGER_8 <-
+ (
floor.to_raw_uinteger_8
);
- - to_uinteger_16:UINTEGER_16 <-
- (
+ - to_uinteger_16:UINTEGER_16 <-
+ (
floor.to_raw_uinteger_16
);
- to_uinteger_32:UINTEGER_32 <-
- (
+ (
floor.to_raw_uinteger_32
);
- - to_uinteger_64:UINTEGER_64 <-
- (
+ - to_uinteger_64:UINTEGER_64 <-
+ (
floor.to_raw_uinteger_64
);
@@ -76,30 +76,30 @@ Section Public
//
- to_integer_8:INTEGER_8 <-
- (
+ (
floor.to_raw_integer_8
);
- to_integer_16:INTEGER_16 <-
- (
+ (
floor.to_raw_integer_16
);
- to_integer_32:INTEGER_32 <-
- (
+ (
floor.to_raw_integer_32
);
- to_integer_64:INTEGER_64 <-
- (
+ (
floor.to_raw_integer_64
);
-
+
- to_integer:INTEGER <-
(
floor
);
-
+
//
// - To unsigned fixed reals
//
@@ -131,13 +131,13 @@ Section Public
} else {
result := to_raw_uinteger_32 >> (shift_bits - 6);
};
- result.to_raw_ureal_26_6
+ result.to_raw_ureal_26_6
);
-
+
//
// - To signed fixed reals
//
-
+
- to_real_16_16:REAL_16_16 <-
( + result:UINTEGER_32;
(shift_bits < 16).if {
@@ -165,36 +165,36 @@ Section Public
} else {
result := to_raw_integer_32 >> (shift_bits - 6);
};
- result.to_raw_ureal_26_6
+ result.to_raw_ureal_26_6
);
-
+
//
// - To float reals
//
-
+
- to_real_32:REAL_32 <-
- (
+ (
to_raw_real_32 / (1 << shift_bits)
);
- to_real_64:REAL_64 <-
- (
+ (
to_raw_real_64 / (1 << shift_bits)
);
- to_real_80:REAL_80 <-
- (
+ (
to_raw_real_80 / (1 << shift_bits)
);
- atan:SELF <- not_yet_implemented;
- - sqrt:SELF <-
+ - sqrt:SELF <-
// The Heron approximation Algorithm.
[ -? {Self > 0}; ]
( + result:SELF;
result := Self;
- 0.to 7 do { j:INTEGER;
+ 0.to 7 do { j:INTEGER;
result := (result + Self / result) /# 2;
};
result
@@ -211,27 +211,27 @@ Section Public
//
// Comparaison.
//
-
+
- Self:SELF '~=' other:SELF :BOOLEAN <-
(
Self = other
);
-
+
- is_not_a_number:BOOLEAN <- FALSE;
-
+
- is_infinity:BOOLEAN <- FALSE;
-
+
//
// Print.
//
-
+
- append_in buffer:STRING decimal n:INTEGER <-
- (
+ (
not_yet_implemented;
);
-
- - scientific_append_in buffer:STRING <-
- (
+
+ - scientific_append_in buffer:STRING <-
+ (
not_yet_implemented;
);
-
+
diff --git a/lib/internal/portable/number/float_map.li b/lib/internal/portable/number/float_map.li
index f7c4132..606b56e 100644
--- a/lib/internal/portable/number/float_map.li
+++ b/lib/internal/portable/number/float_map.li
@@ -19,46 +19,46 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FLOAT_MAP;
-
+
- comment := "Mapping for REAL_xx.";
-
+
Section PRIVATE
-
+
- deferred <- crash_with_message "Slot deferred.";
-
+
Section REAL, REAL_32, REAL_64, REAL_80
-
+
- get_map f:SELF <-
(
deferred;
);
-
+
- sign:BOOLEAN <- deferred; // TRUE if positif, FALSE else.
-
+
- exponent:UINTEGER_32 <- deferred;
-
- - mantissa:UINTEGER_64 <- deferred;
-
+
+ - mantissa:UINTEGER_64 <- deferred;
+
//
// Consultation.
//
-
- - is_infinite:BOOLEAN <-
+
+ - is_infinite:BOOLEAN <-
(exponent = ((1 << exponent_bits) - 1)) && {(mantissa >> (mantissa_bits-1)) = 0};
-
+
- is_nan:BOOLEAN <-
(exponent = ((1 << exponent_bits) - 1)) && {(mantissa >> (mantissa_bits-1)) != 0};
-
+
- is_zero:BOOLEAN <- (exponent = 0) && {mantissa = 0};
-
+
Section Public
//
// Format.
//
-
+
- mantissa_bits:INTEGER_8 <- deferred;
- exponent_bits:INTEGER_8 <- deferred;
diff --git a/lib/internal/portable/number/float_map32.li b/lib/internal/portable/number/float_map32.li
index b657219..0cd0a51 100644
--- a/lib/internal/portable/number/float_map32.li
+++ b/lib/internal/portable/number/float_map32.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FLOAT_MAP32;
-
+
- comment := "Mapping for REAL_32.";
-
+
Section Inherit
-
+
- parent_float_map:FLOAT_MAP := FLOAT_MAP;
-
+
Section Mapping
-
+
+ map_32:UINTEGER_32;
Section REAL, REAL_32, REAL_64, REAL_80
-
+
- get_map f:SELF <-
( + tab:NATIVE_ARRAY(SELF);
tab := CONVERT(FLOAT_MAP32,NATIVE_ARRAY(SELF)).on FLOAT_MAP32;
tab.put f to 0;
);
-
+
- sign:BOOLEAN <- (map_32 >> 31) = 0; // TRUE if positif, FALSE else.
-
+
- exponent:UINTEGER_32 <- (map_32 >> mantissa_bits) & 0FFh;
-
+
- mantissa:UINTEGER_64 <- (map_32 & 7F_FFFFh);
-
+
Section Public
//
// Format.
//
-
+
- mantissa_bits:INTEGER_8 := 23;
- exponent_bits:INTEGER_8 := 8;
-
+
diff --git a/lib/internal/portable/number/float_map64.li b/lib/internal/portable/number/float_map64.li
index efe6575..e35b866 100644
--- a/lib/internal/portable/number/float_map64.li
+++ b/lib/internal/portable/number/float_map64.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FLOAT_MAP64;
-
+
- comment := "Mapping for REAL_64.";
-
+
Section Inherit
-
+
- parent_float_map:FLOAT_MAP := FLOAT_MAP;
-
+
Section Mapping
-
+
+ map_64:UINTEGER_64;
-
+
Section REAL, REAL_32, REAL_64, REAL_80
-
+
- get_map f:SELF <-
( + tab:NATIVE_ARRAY(SELF);
tab := CONVERT(FLOAT_MAP64,NATIVE_ARRAY(SELF)).on FLOAT_MAP64;
- tab.put f to 0;
+ tab.put f to 0;
);
-
+
- sign:BOOLEAN <- (map_64 >> 63) = 0; // TRUE if positif, FALSE else.
-
+
- exponent:UINTEGER_32 <- ((map_64 >> mantissa_bits) & 07_FFh).to_uinteger_32;
-
+
- mantissa:UINTEGER_64 <- map_64 & ((1 << mantissa_bits)-1);
-
+
Section Public
//
// Format.
//
-
+
- mantissa_bits:INTEGER_8 := 52;
- exponent_bits:INTEGER_8 := 11;
-
+
diff --git a/lib/internal/portable/number/float_map80.li b/lib/internal/portable/number/float_map80.li
index 94cbfd9..3b8ceec 100644
--- a/lib/internal/portable/number/float_map80.li
+++ b/lib/internal/portable/number/float_map80.li
@@ -19,41 +19,41 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FLOAT_MAP80;
-
+
- comment := "Mapping for REAL_80.";
-
+
Section Inherit
-
+
- parent_float_map:FLOAT_MAP := FLOAT_MAP;
-
+
Section Mapping
-
+
+ exp_16:UINTEGER_16;
+ man_64:UINTEGER_64;
-
+
Section REAL, REAL_32, REAL_64, REAL_80
-
+
- get_map f:SELF <-
( + tab:NATIVE_ARRAY(SELF);
tab := CONVERT(FLOAT_MAP80,NATIVE_ARRAY(SELF)).on FLOAT_MAP80;
- tab.put f to 0;
+ tab.put f to 0;
);
-
+
- sign:BOOLEAN <- (exp_16 >> 15) = 0; // TRUE if positif, FALSE else.
-
+
- exponent:UINTEGER_32 <- exp_16 & 07F_FFh;
-
+
- mantissa:UINTEGER_64 <- man_64;
-
+
Section Public
//
// Format.
//
-
+
- mantissa_bits:INTEGER_8 := 64;
- exponent_bits:INTEGER_8 := 15;
-
+
diff --git a/lib/internal/portable/number/float_real.li b/lib/internal/portable/number/float_real.li
index 0476467..8aac6aa 100644
--- a/lib/internal/portable/number/float_real.li
+++ b/lib/internal/portable/number/float_real.li
@@ -19,15 +19,15 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FLOAT_REAL;
-
+
- comment := "Real number of variable decimal part.";
-
- - external := `#include <math.h>`;
-
+
+ - external := `#include <math.h>`;
+
Section Insert
-
+
- parent_float_map:FLOAT_MAP := FLOAT_MAP;
-
+
- parent_real:REAL := REAL;
diff --git a/lib/internal/portable/number/numeric.li b/lib/internal/portable/number/numeric.li
index b61df09..98c9a7f 100644
--- a/lib/internal/portable/number/numeric.li
+++ b/lib/internal/portable/number/numeric.li
@@ -19,38 +19,38 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NUMERIC;
-
+
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag, 2007 Xavier Oswald";
-
+
- comment :="Generic number.";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
//
// Features
//
-
+
- one:SELF <- 1; // Neutral element for `*' and `/'.
-
+
- zero:SELF <- 0; // Neutral element for `+' and `-'.
//
// Functions
- //
-
- - in_range low:SELF to up:SELF :BOOLEAN <-
+ //
+
+ - in_range low:SELF to up:SELF :BOOLEAN <-
(low <= Self) && {up >= Self};
-
+
- sign:INTEGER <-
// Sign of Current (0 -1 or 1).
( + result:INTEGER;
-
+
(Self > 0).if {
result := 1;
}.elseif {Self < 0} then {
@@ -60,74 +60,74 @@ Section Public
)
[
+? {-1 <= result};
- +? {result <= 1};
+ +? {result <= 1};
];
//
// binary operator :
//
-
+
- Self:SELF '-' Left 80 other:SELF :SELF <- `3`;
-
+
- Self:SELF '*' Left 100 other:SELF :SELF <- `4`;
-
+
- Self:SELF '/' Left 100 other:SELF :SELF <- `5`; // ? {other/=0}
-
+
- Self:SELF '+' Left 80 other:SELF :SELF <- Self - -other;
-
+
//
// Unary operator
//
-
+
- '+' Self:SELF :SELF <- Self;
-
+
- '-' Self:SELF :SELF <- SELF.zero - Self;
//
// Compatibility Binary operator
//
-
+
- Self:SELF '-#' Left 80 other:INTEGER :SELF <- Self - other;
-
+
- Self:SELF '*#' Left 100 other:INTEGER :SELF <- Self * other;
-
+
- Self:SELF '/#' Left 100 other:INTEGER :SELF <- Self / other;
-
+
- Self:SELF '+#' Left 80 other:INTEGER :SELF <- Self + other;
-
+
- Self:SELF '>#' Right 60 other:INTEGER :BOOLEAN <- Self > other;
-
+
- Self:SELF '<#' Right 60 other:INTEGER :BOOLEAN <- ! (Self >=# other);
-
+
- Self:SELF '<=#' Right 60 other:INTEGER :BOOLEAN <- ! (Self ># other);
-
+
- Self:SELF '>=#' Right 60 other:INTEGER :BOOLEAN <- (Self ># other) | (Self ==# other);
-
+
- Self:SELF '==#' Right 60 other:INTEGER :BOOLEAN <- (Self = other);
//
// Test binary operator :
//
-
+
- Self:SELF '>' Right 60 other:SELF :BOOLEAN <- `2`;
-
+
- Self:SELF '<' Right 60 other:SELF :BOOLEAN <- ! (Self >= other);
-
+
- Self:SELF '<=' Right 60 other:SELF :BOOLEAN <- ! (Self > other);
-
+
- Self:SELF '>=' Right 60 other:SELF :BOOLEAN <- (Self > other) | (Self = other);
-
- - Self:SELF '==' Right 60 other:E :BOOLEAN <-
+
+ - Self:SELF '==' Right 60 other:E :BOOLEAN <-
( + my_other:SELF;
-
+
my_other := other;
Self = my_other
);
-
+
//
// Switch case :
//
-
+
- when value:SELF then block:{} :SELF <-
// when `value' equals `Self', execute `block'
// You can chain "when ... then ..." between them like : <br/>
@@ -136,22 +136,22 @@ Section Public
(Self = value).if block;
Self
);
-
+
- when value1:SELF or value2:SELF then block:{} :SELF <-
// when `value1' or `value2' equal `Self', execute `block'
(
((Self = value1) || {Self = value2}).if block;
Self
);
-
+
- when first_value:SELF to last_value:SELF then block:{} :SELF <-
// Execute `block' when `Self' is in range of `first_value' to `last_value'
- (
+ (
? {first_value <= last_value};
((Self >= first_value) && {Self <= last_value}).if block;
Self
);
-
+
- else block:{} <-
(
block;
@@ -159,7 +159,7 @@ Section Public
//
// Looping.
//
-
+
- to limit_up:SELF do blc:{SELF;} <-
// Classical loop from `Self' to `limit_up'
(
@@ -168,7 +168,7 @@ Section Public
(Self + 1).to limit_up do blc;
};
);
-
+
- downto limit_down:SELF do blc:{SELF;} <-
// Classical backward loop from `Self' to `limit_up'
(
@@ -177,7 +177,7 @@ Section Public
(Self-1).downto limit_down do blc;
};
);
-
+
- to limit_up:SELF by step:SELF do blc:{SELF;} <-
// Classical loop from `Self' to `limit_up' stepping `step'
(
@@ -186,7 +186,7 @@ Section Public
(Self + step).to limit_up by step do blc;
};
);
-
+
- downto limit_down:SELF by step:SELF do blc:{SELF;} <-
// Classical backward loop from `Self' to `limit_up' stepping `step'
(
@@ -211,11 +211,11 @@ Section Public
//
// Function :
//
-
- - abs:SELF <-
+
+ - abs:SELF <-
// Absolute value of `Self'.
( + result:SELF;
-
+
(Self < 0).if {
result := - Self;
} else {
@@ -223,11 +223,11 @@ Section Public
};
result
);
-
+
- min other:SELF :SELF <-
// Minimum between value of `Self' and `other'
( + result:SELF;
-
+
(Self > other).if {
result := other;
} else {
@@ -235,11 +235,11 @@ Section Public
};
result
);
-
+
- max other:SELF :SELF <-
// Maximum between value of `Self' and `other'
( + result:SELF;
-
+
(Self > other).if {
result := Self;
} else {
@@ -247,31 +247,31 @@ Section Public
};
result
);
-
+
//
// Conversion for other type.
//
-
+
- to_string:STRING <-
// Convert the decimal view of `self' into a new allocated STRING.
// For example, if `self' is -1 the new STRING is -1.
// * See: `append_in' to save memory.
( + result:STRING;
-
+
result := STRING.create 11;
append_in result;
result
);
-
- - to_boolean:BOOLEAN <-
+
+ - to_boolean:BOOLEAN <-
// TRUE if `Self' not zero
Self != 0;
-
+
- append_in buffer:STRING <- deferred;
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
-
- - to_string_format s:SELF :STRING <-
+
+ - to_string_format s:SELF :STRING <-
// Same as `to_string' but the result is on `s' character and the
// number is right aligned.
// * Require: s size large enough for `Self'
@@ -281,21 +281,21 @@ Section Public
-? {to_string.count <= s};
]
( + result:STRING;
-
+
result := to_string;
result.precede_multiple ' ' by (s.to_integer - result.count);
-
+
result
)
[
+? {Result.count = s};
];
-
+
- append_in str:STRING format s:INTEGER <-
// Append the equivalent of `to_string_format' at the end of
// `str'. Thus you can save memory because no other
// STRING is allocate for the job.
- (
+ (
append_in str format s with ' ';
);
@@ -311,7 +311,7 @@ Section Public
-? {to_string.count <= s};
]
( + old_count:INTEGER;
-
+
old_count := str.count;
append_in str;
str.insert char to old_count on (s - (str.count - old_count));
@@ -319,11 +319,11 @@ Section Public
[
+? {str.count = (Old str.count + s)};
];
-
+
//
// Print
//
-
+
- print <-
// Print
(
@@ -331,15 +331,15 @@ Section Public
append_in string_tmp;
string_tmp.print;
);
-
+
- print_format s:SELF <-
- // Print with format size `s'
+ // Print with format size `s'
(
string_tmp.clear;
append_in string_tmp format s;
string_tmp.print;
);
-
+
- print_format s:SELF with c:CHARACTER <-
// Print with format size `s' replacing blank character by `c'
(
@@ -347,170 +347,170 @@ Section Public
append_in string_tmp format s with c;
string_tmp.print;
);
-
+
//
// Conversions with tests
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
deferred;
FALSE
);
-
+
//
// - To unsigned integers
//
- - to_uinteger_8:UINTEGER_8 <-
+ - to_uinteger_8:UINTEGER_8 <-
// [ -? {bound_test (UINTEGER_8.minimum) to (UINTEGER_8.maximum)}; ]
- (
+ (
to_raw_uinteger_8
);
- - to_uinteger_16:UINTEGER_16 <-
+ - to_uinteger_16:UINTEGER_16 <-
[ -? {bound_test (UINTEGER_16.minimum) to (UINTEGER_16.maximum)}; ]
- (
+ (
to_raw_uinteger_16
);
- to_uinteger_32:UINTEGER_32 <-
[ -? {bound_test (UINTEGER_32.minimum) to (UINTEGER_32.maximum)}; ]
- (
+ (
to_raw_uinteger_32
);
- - to_uinteger_64:UINTEGER_64 <-
+ - to_uinteger_64:UINTEGER_64 <-
[ -? {bound_test (UINTEGER_64.minimum) to (UINTEGER_64.maximum)}; ]
- (
+ (
to_raw_uinteger_64
);
- - to_uinteger_big:UINTEGER_BIG <-
- (
+ - to_uinteger_big:UINTEGER_BIG <-
+ (
UINTEGER_BIG.create Self
);
-
+
- to_uinteger:UINTEGER <-
[ -? {Self >= 0}; ]
(
to_raw_uinteger
);
-
+
- to_uinteger_cpu:UINTEGER_CPU <-
- [ -? {Self >= 0}; ]
+ [ -? {Self >= 0}; ]
(
to_raw_uinteger_cpu
);
-
+
//
// - To signed integers
//
-
- - to_integer:INTEGER <- to_raw_integer;
-
+
+ - to_integer:INTEGER <- to_raw_integer;
+
- to_integer_8:INTEGER_8 <-
[ -? {bound_test (INTEGER_8.minimum) to (INTEGER_8.maximum)}; ]
- (
+ (
to_raw_integer_8
);
- to_integer_16:INTEGER_16 <-
[ -? {bound_test (INTEGER_16.minimum) to (INTEGER_16.maximum)}; ]
- (
+ (
to_raw_integer_16
);
- to_integer_32:INTEGER_32 <-
[ -? {bound_test (INTEGER_32.minimum) to (INTEGER_32.maximum)}; ]
- (
+ (
to_raw_integer_32
);
- to_integer_64:INTEGER_64 <-
//[ -? {bound_test (INTEGER_64.minimum) to (INTEGER_64.maximum)}; ]
- (
+ (
to_raw_integer_64
);
- - to_integer_big:UINTEGER_BIG <-
- (
+ - to_integer_big:UINTEGER_BIG <-
+ (
deferred;
NULL
);
-
+
//
// - To unsigned fixed reals
//
- to_ureal_16_16:UREAL_16_16 <-
[ -? {bound_test (UREAL_16_16.minimum) to (UREAL_16_16.maximum)}; ]
- (
+ (
(Self *# 1_0000h).to_raw_ureal_16_16
);
- to_ureal_24_8:UREAL_24_8 <-
[ -? {bound_test (UREAL_24_8.minimum) to (UREAL_24_8.maximum)}; ]
- (
+ (
(Self *# 1_00h).to_raw_ureal_24_8
);
- to_ureal_26_6:UREAL_26_6 <-
[ -? {bound_test (UREAL_26_6.minimum) to (UREAL_26_6.maximum)}; ]
- (
+ (
(Self *# 100_0000b).to_raw_ureal_26_6
);
-
+
//
// - To signed fixed reals
//
-
+
- to_real_16_16:REAL_16_16 <-
[ -? {bound_test (REAL_16_16.minimum) to (REAL_16_16.maximum)}; ]
- (
+ (
(Self *# 1_0000h).to_raw_real_16_16
);
- to_real_24_8:REAL_24_8 <-
[ -? {bound_test (REAL_24_8.minimum) to (REAL_24_8.maximum)}; ]
- (
+ (
(Self *# 1_00h).to_raw_real_24_8
);
- to_real_26_6:REAL_26_6 <-
[ -? {bound_test (REAL_26_6.minimum) to (REAL_26_6.maximum)}; ]
- (
+ (
(Self *# 100_0000b).to_raw_real_26_6
);
-
+
//
// - To float reals
//
-
+
- to_real:REAL <- to_raw_real;
-
+
- to_real_32:REAL_32 <-
- (
+ (
to_raw_real_32
);
- to_real_64:REAL_64 <-
- (
+ (
to_raw_real_64
);
- to_real_80:REAL_80 <-
- (
+ (
to_raw_real_80
);
-
+
Section Public
-
+
//
// Convertion format without test.
//
-
+
- to_raw_integer:INTEGER <- CONVERT(SELF,INTEGER ).on Self;
- to_raw_uinteger:UINTEGER <- CONVERT(SELF,UINTEGER ).on Self;
@@ -522,9 +522,9 @@ Section Public
- to_raw_uinteger_32:UINTEGER_32 <- CONVERT(SELF,UINTEGER_32 ).on Self;
- to_raw_uinteger_64:UINTEGER_64 <- CONVERT(SELF,UINTEGER_64 ).on Self;
-
+
- to_raw_uinteger_cpu:UINTEGER_CPU<- CONVERT(SELF,UINTEGER_CPU).on Self;
-
+
- to_raw_integer_8:INTEGER_8 <- CONVERT(SELF,INTEGER_8 ).on Self;
- to_raw_integer_16:INTEGER_16 <- CONVERT(SELF,INTEGER_16 ).on Self;
@@ -532,29 +532,29 @@ Section Public
- to_raw_integer_32:INTEGER_32 <- CONVERT(SELF,INTEGER_32 ).on Self;
- to_raw_integer_64:INTEGER_64 <- CONVERT(SELF,INTEGER_64 ).on Self;
-
+
- to_raw_real:REAL <- CONVERT(SELF,REAL ).on Self;
-
+
- to_raw_ureal_16_16:UREAL_16_16 <- CONVERT(SELF,UREAL_16_16 ).on Self;
- to_raw_ureal_24_8:UREAL_24_8 <- CONVERT(SELF,UREAL_24_8 ).on Self;
- - to_raw_ureal_26_6:UREAL_26_6 <- CONVERT(SELF,UREAL_26_6 ).on Self;
+ - to_raw_ureal_26_6:UREAL_26_6 <- CONVERT(SELF,UREAL_26_6 ).on Self;
- to_raw_real_16_16:REAL_16_16 <- CONVERT(SELF,REAL_16_16 ).on Self;
- to_raw_real_24_8:REAL_24_8 <- CONVERT(SELF,REAL_24_8).on Self;
- - to_raw_real_26_6:REAL_26_6 <- CONVERT(SELF,REAL_26_6).on Self;
+ - to_raw_real_26_6:REAL_26_6 <- CONVERT(SELF,REAL_26_6).on Self;
- to_raw_real_32:REAL_32 <- CONVERT(SELF,REAL_32).on Self;
-
+
- to_raw_real_64:REAL_64 <- CONVERT(SELF,REAL_64).on Self;
- to_raw_real_80:REAL_80 <- CONVERT(SELF,REAL_80).on Self;
Section Private
-
+
- string_tmp:STRING := STRING.create 32;
-
+
diff --git a/lib/internal/portable/number/signed_fixed_real.li b/lib/internal/portable/number/signed_fixed_real.li
index bcd7238..6f22146 100644
--- a/lib/internal/portable/number/signed_fixed_real.li
+++ b/lib/internal/portable/number/signed_fixed_real.li
@@ -19,123 +19,123 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SIGNED_FIXED_REAL;
-
+
- comment := "Signed real number of fixed decimal part.";
-
+
Section Insert
-
+
- parent_fixed_real:FIXED_REAL := FIXED_REAL;
-
+
Section Public
-
+
//
// Bound test
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
(low < to_raw_integer_64) && {up > to_raw_uinteger_64}
);
-
+
//
// Around
//
-
+
- object_size:INTEGER := 4;
- floor:INTEGER <-
// Greatest integral value no greater than Current.
- (
- to_raw_integer_32 >> shift_bits
+ (
+ to_raw_integer_32 >> shift_bits
)
[
+? {Self >= Result};
+? {(Self - Result) < 1};
];
-
+
- ceiling:INTEGER <-
// Smallest integral value no smaller than Current.
- (
- (to_raw_integer_32 + ((1 << shift_bits) - 1)) >> shift_bits
+ (
+ (to_raw_integer_32 + ((1 << shift_bits) - 1)) >> shift_bits
)
[
+? {Self <= Result};
+? {(Self - Result) < 1};
];
-
+
- rounded:INTEGER <-
// Rounded integral value.
(
(to_raw_integer_32 + ((1 << shift_bits) / 2)) >> shift_bits
);
-
+
- truncated_to_integer:INTEGER <- floor;
// Integer part (largest absolute value no greater than Current).
-
+
//
// binary operator :
//
-
- - Self:SELF '-' Left 80 other:SELF :SELF <-
+
+ - Self:SELF '-' Left 80 other:SELF :SELF <-
(
CONVERT(INTEGER_32,SELF).on (to_raw_integer_32 - other.to_raw_integer_32)
);
- - Self:SELF '*#' Left 100 other:INTEGER :SELF <-
- (
+ - Self:SELF '*#' Left 100 other:INTEGER :SELF <-
+ (
CONVERT(INTEGER_32,SELF).on (to_raw_integer_32 * other)
);
-
- - Self:SELF '*' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '*' Left 100 other:SELF :SELF <-
(
CONVERT(INTEGER_64,SELF).on ((to_raw_integer_64 * other.to_raw_integer_64) >> shift_bits)
);
-
- - Self:SELF '/#' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '/#' Left 100 other:INTEGER :SELF <-
(
CONVERT(INTEGER_32,SELF).on (to_raw_integer_32 / other)
);
-
- - Self:SELF '/' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '/' Left 100 other:SELF :SELF <-
(
CONVERT(INTEGER_64,SELF).on ((to_raw_integer_64 << shift_bits) / other.to_raw_integer_64)
);
-
+
- Self:SELF '&' Left 100 other:SELF :SELF <-
(
CONVERT(INTEGER_32,SELF).on (to_raw_integer_32 & other.to_raw_integer_32)
);
-
- - Self:SELF '>>' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '>>' Left 100 other:INTEGER :SELF <-
(
CONVERT(INTEGER_32,SELF).on (to_raw_integer_32 >> other)
);
-
- - Self:SELF '<<' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '<<' Left 100 other:INTEGER :SELF <-
(
CONVERT(INTEGER_32,SELF).on (to_raw_integer_32 << other)
);
-
+
//
// Test binary operator :
//
-
- - Self:SELF '>' Right 60 other:SELF :BOOLEAN <-
+
+ - Self:SELF '>' Right 60 other:SELF :BOOLEAN <-
(
to_raw_integer_32 > other.to_raw_integer_32
);
-
+
//
// prefix : Unary operator
//
-
- - '~' Self:SELF :SELF <-
+
+ - '~' Self:SELF :SELF <-
(
CONVERT(INTEGER_32,SELF).on (~ to_raw_integer_32)
);
-
+
diff --git a/lib/internal/portable/number/signed_integer.li b/lib/internal/portable/number/signed_integer.li
index 4965740..fb33543 100644
--- a/lib/internal/portable/number/signed_integer.li
+++ b/lib/internal/portable/number/signed_integer.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SIGNED_INTEGER;
-
+
- comment := "Generic Signed Integer.";
-
+
Section Insert
-
+
- parent_integer:INTEGER := INTEGER;
-
+
Section Public
-
+
- append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,j:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
@@ -46,27 +46,27 @@ Section Public
val := - Self;
buffer.extend '-';
};
-
+
i := buffer.upper+1;
-
- {val = 0}.until_do {
+
+ {val = 0}.until_do {
buffer.extend ((val % 10).digit);
val := val / 10;
};
-
+
j := buffer.upper;
{i >= j}.until_do {
buffer.swap i with j;
j := j - 1;
i := i + 1;
- };
+ };
};
);
-
+
- to_octal:SELF <-
// Gives coresponding octal value.
( + result, unit, current:SELF;
-
+
(Self < 0).if {
result := -((-Self).to_octal);
} else {
@@ -80,33 +80,32 @@ Section Public
};
result
);
-
+
//
// Hashing:
//
-
+
- hash_code:INTEGER <-
( + result:INTEGER;
-
+
(Self < 0).if {
result := ~ Self;
} else {
result := Self;
};
-
+
result
)
[
+? {Result>=0};
];
-
+
//
// Bound test
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
(low < to_raw_integer_64) && {up > to_raw_uinteger_64}
);
-
\ No newline at end of file
diff --git a/lib/internal/portable/number/unsigned_fixed_real.li b/lib/internal/portable/number/unsigned_fixed_real.li
index df3dea7..264d78a 100644
--- a/lib/internal/portable/number/unsigned_fixed_real.li
+++ b/lib/internal/portable/number/unsigned_fixed_real.li
@@ -19,125 +19,125 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := UNSIGNED_FIXED_REAL;
-
+
- comment := "Unsigned real number of fixed decimal part.";
-
+
Section Inherit
-
+
- parent_fixed_real:FIXED_REAL := FIXED_REAL;
-
+
Section Public
-
+
//
// Bound test
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
(up > to_raw_uinteger_64)
);
-
+
//
// Around
//
-
+
- object_size:INTEGER := 4;
-
- - minimum:INTEGER_64 <- 0;
+
+ - minimum:INTEGER_64 <- 0;
- floor:INTEGER <-
// Greatest integral value no greater than Current.
- (
- to_raw_uinteger_32 >> shift_bits
+ (
+ to_raw_uinteger_32 >> shift_bits
)
[
+? {Self <= Result};
+? {(Self - Result) < 1};
];
-
+
- ceiling:INTEGER <-
// Smallest integral value no smaller than Current.
- (
- (to_raw_uinteger_32 + ((1 << shift_bits) - 1)) >> shift_bits
+ (
+ (to_raw_uinteger_32 + ((1 << shift_bits) - 1)) >> shift_bits
)
[
+? {Self >= Result};
+? {(Self - Result) < 1};
];
-
+
- rounded:INTEGER <-
// Rounded integral value.
(
(to_raw_uinteger_32 + ((1 << shift_bits) / 2)) >> shift_bits
);
-
+
- truncated_to_integer:INTEGER <- floor;
// Integer part (largest absolute value no greater than Current).
-
+
//
// binary operator :
//
-
- - Self:SELF '-' Left 80 other:SELF :SELF <-
+
+ - Self:SELF '-' Left 80 other:SELF :SELF <-
(
CONVERT(UINTEGER_32,SELF).on (to_raw_uinteger_32 - other.to_raw_uinteger_32)
);
- - Self:SELF '*#' Left 100 other:INTEGER :SELF <-
- (
+ - Self:SELF '*#' Left 100 other:INTEGER :SELF <-
+ (
CONVERT(UINTEGER_32,SELF).on (to_raw_uinteger_32 * other)
);
-
- - Self:SELF '*' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '*' Left 100 other:SELF :SELF <-
(
CONVERT(UINTEGER_64,SELF).on ((to_raw_uinteger_64 * other.to_raw_uinteger_64) >> shift_bits)
);
-
- - Self:SELF '/#' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '/#' Left 100 other:INTEGER :SELF <-
(
CONVERT(UINTEGER_32,SELF).on (to_raw_uinteger_32 / other)
);
-
- - Self:SELF '/' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '/' Left 100 other:SELF :SELF <-
(
CONVERT(UINTEGER_64,SELF).on ((to_raw_uinteger_64 << shift_bits) / other.to_raw_uinteger_64)
);
-
+
- Self:SELF '&' Left 100 other:SELF :SELF <-
(
CONVERT(UINTEGER_32,SELF).on (to_raw_uinteger_32 & other.to_raw_uinteger_32)
);
-
- - Self:SELF '>>' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '>>' Left 100 other:INTEGER :SELF <-
(
CONVERT(UINTEGER_32,SELF).on (to_raw_uinteger_32 >> other)
);
-
- - Self:SELF '<<' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '<<' Left 100 other:INTEGER :SELF <-
(
CONVERT(UINTEGER_32,SELF).on (to_raw_uinteger_32 << other)
);
-
+
//
// Test binary operator :
//
-
- - Self:SELF '>' Right 60 other:SELF :BOOLEAN <-
+
+ - Self:SELF '>' Right 60 other:SELF :BOOLEAN <-
(
to_raw_uinteger_32 > other.to_raw_uinteger_32
);
-
+
//
// prefix : Unary operator
//
-
- - '~' Self:SELF :SELF <-
+
+ - '~' Self:SELF :SELF <-
(
CONVERT(UINTEGER_32,SELF).on (~ to_raw_uinteger_32)
);
-
+
diff --git a/lib/internal/portable/number/unsigned_integer.li b/lib/internal/portable/number/unsigned_integer.li
index 63fdc08..23836cf 100644
--- a/lib/internal/portable/number/unsigned_integer.li
+++ b/lib/internal/portable/number/unsigned_integer.li
@@ -19,59 +19,59 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := UNSIGNED_INTEGER;
-
+
- comment := "Generic Unsigned Integer.";
-
+
Section Insert
-
+
- parent_integer:INTEGER := INTEGER;
-
+
Section Public
-
+
//
// Range
//
-
+
- minimum:INTEGER_64 := 0.to_raw_integer_64;
-
+
//
// Function :
//
-
+
- sign:INTEGER <-
// Sign of Current (0 -1 or 1).
- (
- (Self != 0).to_integer;
+ (
+ (Self != 0).to_integer;
);
-
+
- abs:SELF <- Self; // Absolute value of `self'.
-
+
//
// Convertion
//
-
+
- append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:SELF;
+ i,j:INTEGER;
? {buffer!=NULL};
-
+
(Self = 0).if {
buffer.extend '0';
} else {
-
+
i := buffer.upper+1;
-
+
val := Self;
{val = 0}.until_do {
buffer.extend ((val % 10).digit);
val := val / 10;
};
j := buffer.upper;
-
+
{i >= j}.until_do {
buffer.swap i with j;
j := j - 1;
@@ -80,16 +80,16 @@ Section Public
};
);
-
+
- print <-
- (
+ (
print_positif;
);
-
+
- to_octal:SELF <-
// Gives coresponding octal value.
( + result, unit, current:SELF;
-
+
current := Self;
unit := 1;
{current!=0}.while_do {
@@ -99,31 +99,31 @@ Section Public
};
result
);
-
+
//
// Hashing:
//
-
+
- hash_code:INTEGER <- to_integer;
-
+
//
// Looping
//
-
+
- downto limit_down:SELF do blc:{SELF; } <-
(
- (Self+1).downto_unsigned limit_down do blc;
+ (Self+1).downto_unsigned limit_down do blc;
);
-
+
//
// Bound test
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
(up > to_raw_uinteger_64)
);
-
+
Section Private
- downto_unsigned limit_down:SELF do blc:{SELF; } <-
@@ -134,4 +134,3 @@ Section Private
};
);
-
\ No newline at end of file
diff --git a/lib/internal/portable/string/character_ref.li b/lib/internal/portable/string/character_ref.li
index b973d00..1c93cec 100644
--- a/lib/internal/portable/string/character_ref.li
+++ b/lib/internal/portable/string/character_ref.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CHARACTER_REF;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :=" .";
-
+
Section Inherit
-
+
- parent_hashable:HASHABLE <- HASHABLE;
-
+
- parent_comparable:COMPARABLE <- COMPARABLE;
-
+
Section Public
-
+
- item:CHARACTER;
-
+
- set_item value:CHARACTER <-
(
item := value;
@@ -46,7 +46,7 @@ Section Public
(
item < other.item
);
-
+
- code:INTEGER_8 <-
// ASCII code of Current
(
@@ -67,14 +67,14 @@ Section Public
// Object Printing:
- out_in_tagged_out_memory <- fill_tagged_out_memory;
-
+
- fill_tagged_out_memory <-
(
item.fill_tagged_out_memory;
);
-
+
// Hashing:
-
+
- hash_code:INTEGER <-
(
item.hash_code
diff --git a/lib/internal/portable/string/string_buffer.li b/lib/internal/portable/string/string_buffer.li
index 6008935..fac1a0b 100644
--- a/lib/internal/portable/string/string_buffer.li
+++ b/lib/internal/portable/string/string_buffer.li
@@ -56,7 +56,7 @@ Section Public
- from_string s:STRING :SELF <- create_from s;
- to_string :STRING <- parent_string;
-
+
- to_abstract_string:ABSTRACT_STRING <- parent_string;
- Self:SELF '+' other:ABSTRACT_STRING :STRING_BUFFER <-
diff --git a/lib/internal/portable/system/system_detect.li b/lib/internal/portable/system/system_detect.li
index 02759ef..00bb24f 100644
--- a/lib/internal/portable/system/system_detect.li
+++ b/lib/internal/portable/system/system_detect.li
@@ -26,7 +26,7 @@ Section Header
- copyright := "2008 Mildred Ki'Lya";
- bibliography := "";
- comment := "Detect charecteristics of the system/C compiler";
-
+
// Don't hesitate to add others slots to detect your platform.
Section Inherit
diff --git a/lib/standard/boolean/boolean.li b/lib/standard/boolean/boolean.li
index 968d70d..0a6263a 100644
--- a/lib/standard/boolean/boolean.li
+++ b/lib/standard/boolean/boolean.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded BOOLEAN;
@@ -29,111 +29,111 @@ Section Header
- type := `char`;
- default := FALSE;
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
-Section Private
-
+
+Section Private
+
- deferred_boolean:BOOLEAN <-
( + result:BOOLEAN;
-
+
deferred;
result
);
-
+
Section Public
//
// Conditional :
//
-
+
- if_true block:{} <- deferred;
-
+
- if_false block:{} <- deferred;
-
+
- if true_block:{} else false_block:{} <- `ERROR`; //deferred;
-
+
- if_true true_block:{} else false_block:{} <- deferred;
-
+
- if_false true_block:{} else false_block:{} <- deferred;
-
+
- if true_block:{} :BOOLEAN <- deferred_boolean;
-
+
- elseif cond:{BOOLEAN} then block:{} :BOOLEAN <- deferred_boolean;
-
+
- elseif cond:{BOOLEAN} then block:{} else block_else:{} <- deferred;
-
- - else_if cond:{BOOLEAN} then block:{} :BOOLEAN <-
+
+ - else_if cond:{BOOLEAN} then block:{} :BOOLEAN <-
// Alias.
elseif cond then block;
-
- - else_if cond:{BOOLEAN} then block:{} else block_else:{} <-
+
+ - else_if cond:{BOOLEAN} then block:{} else block_else:{} <-
// Alias.
elseif cond then block else block_else;
-
+
//
// Binary operator :
//
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <- Self = other;
-
+
- Self:SELF '!==' Right 60 other:SELF :BOOLEAN <- Self != other;
-
+
- Self:SELF '||' Left 10 other:{BOOLEAN} :BOOLEAN <- deferred_boolean;
-
- - Self:SELF '&&' Left 20 other:{BOOLEAN} :BOOLEAN <- deferred_boolean;
-
+
+ - Self:SELF '&&' Left 20 other:{BOOLEAN} :BOOLEAN <- deferred_boolean;
+
- Self:SELF '|' Left 10 other:BOOLEAN :BOOLEAN <- deferred_boolean;
-
+
- Self:SELF '&' Left 20 other:BOOLEAN :BOOLEAN <- deferred_boolean;
-
+
- Self:SELF '^' Left 10 other:BOOLEAN :BOOLEAN <- deferred_boolean;
-
+
- Self:SELF '->' Right 25 other:BOOLEAN :BOOLEAN <- deferred_boolean;
- Self:SELF '->>' Right 25 other:{BOOLEAN} :BOOLEAN <- deferred_boolean;
-
+
- Self:SELF '=>' s:ABSTRACT_STRING <- deferred;
-
+
//
// Prefix operator
//
-
+
- '!' Self:SELF :BOOLEAN <- deferred;
-
+
//
// Convertion
//
-
- - to_string:STRING <-
+
+ - to_string:STRING <-
( + result:STRING;
-
+
deferred;
result
);
-
- - to_integer:INTEGER <-
+
+ - to_integer:INTEGER <-
( + result:INTEGER;
-
+
deferred;
result
);
-
- - to_character:CHARACTER <-
+
+ - to_character:CHARACTER <-
( + result:CHARACTER;
-
+
deferred;
result
);
-
+
- append_in str:STRING <- str.append to_string;
//
// Output.
//
-
+
- print <-
(
deferred;
diff --git a/lib/standard/boolean/false.li b/lib/standard/boolean/false.li
index 078c39e..5c88a40 100644
--- a/lib/standard/boolean/false.li
+++ b/lib/standard/boolean/false.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded FALSE;
@@ -29,24 +29,24 @@ Section Header
- type := `char`;
- default := FALSE;
-
+
Section Inherit
-
+
- inherit_boolean:BOOLEAN := BOOLEAN;
-
+
Section Public
-
+
//
// Conditional :
//
-
+
- if_true block:{};
-
+
- if_false block:{} <-
( //? {block!=NULL};
block.value;
);
-
+
- if true_block:{} else false_block:{} <-
(
false_block.value;
@@ -56,24 +56,24 @@ Section Public
(
false_block.value;
);
-
- - if_false true_block:{} else false_block:{} <-
+
+ - if_false true_block:{} else false_block:{} <-
(
true_block.value;
);
-
+
- if true_block:{} :BOOLEAN <- FALSE;
-
+
- elseif cond:{BOOLEAN} then block:{} :BOOLEAN <-
( + result:BOOLEAN;
-
+
result := cond.value;
result.if {
block.value;
};
result
);
-
+
- elseif cond:{BOOLEAN} then block:{} else block_else:{} <-
(
(cond.value).if {
@@ -82,49 +82,49 @@ Section Public
block_else.value;
};
);
-
+
//
// Binary operator :
//
-
+
- Self:SELF '||' Left 10 other:{BOOLEAN} :BOOLEAN <- other.value;
-
+
- Self:SELF '&&' Left 20 other:{BOOLEAN} :BOOLEAN <- FALSE;
-
+
- Self:SELF '|' Left 10 other:BOOLEAN :BOOLEAN <- other;
-
+
- Self:SELF '&' Left 20 other:BOOLEAN :BOOLEAN <- FALSE;
-
+
- Self:SELF '^' Left 10 other:BOOLEAN :BOOLEAN <- other;
-
+
- Self:SELF '->' Right 25 other:BOOLEAN :BOOLEAN <- TRUE;
-
+
- Self:SELF '->>' Right 25 other:{BOOLEAN} :BOOLEAN <- TRUE;
-
+
- Self:SELF '=>' s:ABSTRACT_STRING <-
(
);
-
+
//
// Prefix operator
//
-
+
- '!' Self:SELF :BOOLEAN <- TRUE;
-
+
//
// Convertion
//
-
+
- to_string:STRING <- "0".to_string;
-
+
- to_integer:INTEGER <- 0;
-
+
- to_character:CHARACTER <- '0';
-
+
//
// Output.
//
-
+
- print <-
(
"FALSE".print;
diff --git a/lib/standard/boolean/true.li b/lib/standard/boolean/true.li
index 592bce9..3e60d8b 100644
--- a/lib/standard/boolean/true.li
+++ b/lib/standard/boolean/true.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded TRUE;
@@ -29,87 +29,87 @@ Section Header
- type := `char`;
- default := TRUE;
-
+
Section Inherit
-
+
- inherit_boolean:BOOLEAN := BOOLEAN;
-
+
Section Public
-
+
//
// Conditional :
//
-
+
- if_true block:{} <-
(
block.value;
);
-
+
- if_false block:{};
-
+
- if true_block:{} else false_block:{} <-
(
true_block.value;
);
-
+
- if_true true_block:{} else false_block:{} <-
(
true_block.value;
);
-
- - if_false true_block:{} else false_block:{} <-
+
+ - if_false true_block:{} else false_block:{} <-
(
false_block.value;
);
-
+
- if true_block:{} :BOOLEAN <-
(
true_block.value;
TRUE
);
-
+
- elseif cond:{BOOLEAN} then block:{} :BOOLEAN <- TRUE;
-
+
- elseif cond:{BOOLEAN} then block:{} else block_else:{};
-
+
//
// Binary operator :
//
-
+
- Self:SELF '||' Left 10 other:{BOOLEAN} :BOOLEAN <- TRUE; // or else
-
+
- Self:SELF '&&' Left 20 other:{BOOLEAN} :BOOLEAN <- other.value; // and then
-
+
- Self:SELF '|' Left 10 other:BOOLEAN :BOOLEAN <- TRUE; // or
-
+
- Self:SELF '&' Left 20 other:BOOLEAN :BOOLEAN <- other; // and
-
+
- Self:SELF '^' Left 10 other:BOOLEAN :BOOLEAN <- ! other;
-
+
- Self:SELF '->' Right 25 other:BOOLEAN :BOOLEAN <- other;
- Self:SELF '->>' Right 25 other:{BOOLEAN} :BOOLEAN <- other.value;
-
+
- Self:SELF '=>' s:ABSTRACT_STRING <-
(
s.print;
`while (1)`;
);
-
+
//
// Prefix operator
//
-
+
- '!' Self:SELF :BOOLEAN <- FALSE;
-
+
//
// Conversion
//
-
+
- to_string:STRING <- "1".to_string; // BSBS: A revoir ...
-
+
- to_integer:INTEGER <- 1;
-
+
- to_character:CHARACTER <- '1';
//
diff --git a/lib/standard/collection/array.li b/lib/standard/collection/array.li
index eaa5955..f68abd6 100644
--- a/lib/standard/collection/array.li
+++ b/lib/standard/collection/array.li
@@ -19,48 +19,48 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ARRAY(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment :=" General purpose resizable ARRAYs .";
-
+
// General purpose resizable ARRAYs as they are define in the Eiffel language definition.
// The `lower' bound can be any arbitrary value, even a negative one.<br/> <br/>
//
- // This implementation uses only one chunk of memory, the `storage' area which is a
- // NATIVE_ARRAY. One must keep in mind that this internal `storage' area is always kept
+ // This implementation uses only one chunk of memory, the `storage' area which is a
+ // NATIVE_ARRAY. One must keep in mind that this internal `storage' area is always kept
// left align. Thus, you can expect good performances while using an ARRAY to modelize a
// stack behavior with `add_last' / `last' / `remove_last'.<br/>
- // Conversely `add_first' and `remove_first' are likely to slow down your program if
- // they are too often used. If the fact that `lower' is always stuck to 0 is not a
+ // Conversely `add_first' and `remove_first' are likely to slow down your program if
+ // they are too often used. If the fact that `lower' is always stuck to 0 is not a
// problem for you, also consider FAST_ARRAY to get better performances.<br/>
-
+
Section Inherit
-
+
+ parent_arrayed_collection:Expanded ARRAYED_COLLECTION(V);
-
+
Section Public
-
+
+ lower:INTEGER; // Lower index bound.
-
+
//
// Creation and Modification:
//
-
+
- create min_index:INTEGER to max_index:INTEGER :SELF <-
// Prepare the array to hold values for indexes in range
// [`min_index' .. `max_index']. Set all values to default.
// When `max_index' = `min_index' - 1, the array `is_empty'.
( + result:SELF;
-
+
result := SELF.clone;
result.make min_index to max_index;
result
);
-
+
- make min_index:INTEGER to max_index:INTEGER <-
// Prepare the array to hold values for indexes in range
// [`min_index' .. `max_index']. Set all values to default.
@@ -72,25 +72,25 @@ Section Public
[ ...
{min_index <= max_index + 1} -? "Valid bounds.";
]
- (
+ (
ensure_capacity (max_index - min_index + 1) and_bounds min_index to max_index;
)
[ ...
"Lower set." +? { lower = min_index };
"Upper set." +? { upper = max_index };
- "Items set." +? { all_default };
+ "Items set." +? { all_default };
];
-
+
- create_with_capacity needed_capacity:INTEGER lower low:INTEGER :SELF <-
// Create an empty array with `capacity' initialized
// at least to `needed_capacity' and `lower' set to `low'.
( + result:SELF;
-
+
result := clone;
result.with_capacity needed_capacity lower low;
result
);
-
+
- with_capacity needed_capacity:INTEGER lower low:INTEGER <-
// Create an empty array with `capacity' initialized
// at least to `needed_capacity' and `lower' set to `low'.
@@ -105,9 +105,9 @@ Section Public
+? { needed_capacity <= capacity };
+? { lower = low };
];
-
+
Section Public
-
+
- ensure_capacity needed_capacity:INTEGER and_bounds low:INTEGER to up:INTEGER <-
// Extend needed capacity and bouds if necessary
// * Require: `up' superior or equal to `low' - 1
@@ -129,11 +129,11 @@ Section Public
+? { upper = up };
+? {all_default};
];
-
+
//
// Modification:
//
-
+
- resize min_index:INTEGER to max_index:INTEGER <-
// Resize to bounds `min_index' and `max_index'. Do not lose any
// item whose index is in both [`lower' .. `upper'] and
@@ -146,7 +146,7 @@ Section Public
-? { min_index <= max_index + 1 };
]
( + needed, offset, intersize:INTEGER;
-
+
needed := max_index - min_index + 1;
( needed > 0 ).if {
( needed > capacity ).if {
@@ -188,15 +188,15 @@ Section Public
+? { lower = min_index };
+? { upper = max_index };
];
-
-
+
+
- reindex new_lower:INTEGER <-
// Change indexing to take in account the expected `new_lower'
// index. The `upper' index is translated accordingly.
// * Ensure: `lower' is equal to `new_lower'
// * Ensure: `count' is equal to `count' before
( + i:INTEGER;
-
+
i := new_lower - lower;
lower := lower + i;
upper := upper + i;
@@ -205,15 +205,15 @@ Section Public
+? { lower = new_lower };
+? { count = Old count };
];
-
+
//
// Implementation of deferred:
//
-
+
- subarray min:INTEGER to max:INTEGER :SELF <-
// Return the subarray between `min' to `max'
// * Ensure: `Result.lower' is equal to `min' before
- ( + result:SELF;
+ ( + result:SELF;
result := slice min to max;
result.reindex min;
@@ -222,34 +222,34 @@ Section Public
[ ...
+? { Result.lower = min };
];
-
+
- is_empty:BOOLEAN <-
// Is Self empty ?
( upper < lower );
-
- - count:INTEGER <-
- //Size of current
+
+ - count:INTEGER <-
+ //Size of current
( upper - lower + 1 );
-
+
- item i:INTEGER :V <-
// Item at the corresponding index `i'.
// * Description en Francais : Item à l'index `i'
// * See: `lower', `upper', `valid_index', `put', `swap'
- (
+ (
storage.item (i - lower)
);
-
+
- put element:V to i:INTEGER <-
// Make `element' the item at index `i'.
// * See: `lower', `upper', `valid_index', `item', `swap', `force'.
- (
- storage.put element to (i - lower);
+ (
+ storage.put element to (i - lower);
);
-
+
- force element:V to index:INTEGER <-
// Make `element' the item at index `i', reindexing array if necessary.
// * See: `lower', `upper', `valid_index', `item', `swap', `force'.
- (
+ (
(upper < index).if {
(index = upper + 1).if {
add_last element;
@@ -265,13 +265,13 @@ Section Public
};
)
[ ...
- +? { lower = index.min (Old lower) };
+ +? { lower = index.min (Old lower) };
];
-
+
- copy other:SELF <-
// Copy `other' into Self
( + needed_capacity:INTEGER;
-
+
lower := other.lower;
upper := other.upper;
needed_capacity := upper - lower + 1;
@@ -283,24 +283,24 @@ Section Public
storage.copy_from (other.storage) until (needed_capacity - 1);
};
);
-
+
- set_all_with v:V <-
- // Set all element with `v'
- (
- storage.set_all_with v until (upper - lower);
+ // Set all element with `v'
+ (
+ storage.set_all_with v until (upper - lower);
);
-
+
- remove_first <-
// Remove the first `element'
// * Ensure: `upper' has same value before and after
- (
+ (
storage.remove_first (upper - lower);
lower := lower + 1;
)
[ ...
+? {upper = Old upper};
];
-
+
- remove_head n:INTEGER <-
// Remove the n firsts `element'
// * Ensure: `upper' has same value before and after
@@ -311,31 +311,31 @@ Section Public
[ ...
+? {upper = Old upper};
];
-
+
- remove index:INTEGER <-
// Remove the nth `element'
- (
+ (
storage.remove (index - lower) until (upper - lower);
- upper := upper - 1;
+ upper := upper - 1;
);
-
+
- clear <-
// Clear the array
// * Ensure: `capacity' has same value before and after
(
- upper := lower - 1;
+ upper := lower - 1;
)
[ ...
- +? {capacity = Old capacity};
+ +? {capacity = Old capacity};
];
-
+
- add_first element:V <-
// Add a new item in first position : `count' is increased by
// one and all other items are shifted right.
//
// * See: `add_last', `first', `last', `add'.
- (
+ (
(upper < lower).if {
add_last element;
} else {
@@ -344,13 +344,13 @@ Section Public
put (element,lower);
};
);
-
+
- add_last element:V <-
// Add a new item at the end : `count' is increased by one.
//
// * See: `add_first', `last', `first', `add'.
( + new_capacity:INTEGER;
-
+
( capacity < count + 1 ).if {
( capacity = 0 ).if {
new_capacity := 16;
@@ -363,14 +363,14 @@ Section Public
};
};
upper := upper + 1;
- put element to upper;
+ put element to upper;
);
-
+
- from_collection model:COLLECTION(V) <-
// Initialize the current object with the contents of `model'
(
- with_capacity ((model.count),(model.lower));
- upper := modele.upper;
+ with_capacity ((model.count),(model.lower));
+ upper := modele.upper;
(model.lower).to (model.upper) do { i:INTEGER;
put ((model.item i),i);
};
@@ -379,56 +379,56 @@ Section Public
+? { lower = model.lower };
+? { upper = model.upper };
];
-
+
- all_default:BOOLEAN <-
(
storage.all_default (upper - lower)
);
-
+
- occurrences element:V :INTEGER <-
- (
+ (
storage.occurrences element until (upper - lower)
);
-
+
- fast_occurrences element:V :INTEGER <-
- (
+ (
storage.fast_occurrences element until (upper - lower)
);
-
+
- first_index_of element:V :INTEGER <-
( + result:INTEGER;
-
+
(upper >= lower).if {
result := lower + storage.first_index_of element until (upper - lower);
} else {
result := lower;
};
);
-
+
- index_of element:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
-
+
(upper >= lower).if {
result := lower + storage.index_of (element,start_index - lower) until (upper - lower);
} else {
result := lower;
};
- result
+ result
);
-
+
- reverse_index_of element:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
-
+
(upper >= lower).if {
result := lower + storage.reverse_index_of element from (start_index - lower);
} else {
result := lower;
};
);
-
+
- fast_index_of element:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
-
+
(upper >= lower).if {
result := lower + storage.fast_index_of (element,start_index - lower) until (upper - lower);
} else {
@@ -436,10 +436,10 @@ Section Public
};
result
);
-
+
- fast_reverse_index_of element:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
-
+
(upper >= lower).if {
result := lower + storage.fast_reverse_index_of element from (start_index - lower);
} else {
@@ -447,36 +447,36 @@ Section Public
};
result
);
-
+
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <-
- ( + result:BOOLEAN;
-
+ ( + result:BOOLEAN;
+
(Self = other).if {
result := true;
}.elseif {(lower = other.lower) && {upper = other.upper}} then {
result := storage.fast_memcmp (other.storage) until count;
- };
+ };
result
);
-
+
- is_equal_map other:SELF :BOOLEAN <-
( + result:BOOLEAN;
-
+
( Self = other ).if {
result := true;
}.elseif {(lower = other.lower) && {upper = other.upper}} then {
result := storage.memcmp (other.storage) until count;
- };
+ };
result
);
-
+
- slice min:INTEGER to max:INTEGER :SELF <-
( + result:SELF;
-
+
result := SELF.create lower to (lower + max - min);
(max >= min).if {
// Slice not empty
result.storage.slice_copy storage to 0 from (min - lower) to (max - lower);
- };
+ };
);
-
+
diff --git a/lib/standard/collection/array2.li b/lib/standard/collection/array2.li
index ed833d9..fb5cf90 100644
--- a/lib/standard/collection/array2.li
+++ b/lib/standard/collection/array2.li
@@ -19,46 +19,46 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ARRAY2(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :=" General prurpose, resizable, two dimensional array.";
-
+
Section Inherit
+ parent_collection2:Expanded COLLECTION2(V);
-
+
Section Public
-
+
+ lower1:INTEGER;
+ lower2:INTEGER;
-
+
+ upper1:INTEGER;
+ upper2:INTEGER;
-
+
Section ARRAY2
-
+
+ storage:NATIVE_ARRAY(V);
// To store elements line by line.
+ capacity:INTEGER;
// Number of elements in `storage'.
-
+
Section Public
-
+
//
// Creation / modification:
//
-
+
- create (line_min, column_min:INTEGER) to (line_max, column_max:INTEGER) :SELF <-
// Reset all bounds `line_minimum' / `line_maximum' / `column_minimum' and
// `column_maximum' using arguments as new values.
// All elements are set to the default value of type E.
( + result:SELF;
-
+
result:= clone;
result.make (line_min, column_min) to (line_max, column_max);
result
@@ -83,7 +83,7 @@ Section Public
} else {
capacity := count;
storage := NATIVE_ARRAY(V).create count;
- };
+ };
)
[ ...
+? {line_minimum = line_min};
@@ -94,13 +94,13 @@ Section Public
- from_collection2 model:COLLECTION2(V) <-
(
- make (model.line_minimum,model.column_minimum)
+ make (model.line_minimum,model.column_minimum)
to (model.line_maximum,model.column_maximum);
-
+
line_minimum.to line_maximum do { i:INTEGER;
column_minimum.to column_maximum do { j:INTEGER;
put (model.item (i,j)) to (i,j);
- };
+ };
};
)
[ ...
@@ -108,7 +108,7 @@ Section Public
+? { lower2 = model.lower2 };
];
- - from_collection contents:COLLECTION(V)
+ - from_collection contents:COLLECTION(V)
size (line_min,column_min:INTEGER) to (line_max,column_max:INTEGER) <-
// Reset all bounds using `line_min', `line_max', `column_min',
// and `column_max' .
@@ -118,11 +118,11 @@ Section Public
-? { column_min <= column_max };
-? { contents.count = (line_max - line_min + 1) * (column_max - column_min +1) };
]
- (
- make (line_min,column_min) to (line_max,column_max);
+ (
+ make (line_min,column_min) to (line_max,column_max);
0.to (count - 1) do { i:INTEGER;
storage.put (contents.item (contents.lower + i)) to i;
- };
+ };
)
[ ...
+? { line_minimum = line_min };
@@ -131,7 +131,7 @@ Section Public
+? { column_maximum = column_max };
+? { count = contents.count };
];
-
+
- from_model model:COLLECTION(COLLECTION(V)) <-
// The `model' is used to fill line by line the COLLECTION2.
// Assume all sub-collections of `model' have the same indexing.
@@ -141,7 +141,7 @@ Section Public
(model.lower).to (modele.upper) do { line:INTEGER;
(model.first.lower).to (model.first.upper) do { column:INTEGER;
put (model.item line.item column) to (line,column);
- };
+ };
};
)
[ ...
@@ -150,11 +150,11 @@ Section Public
-? { column_minimum = model.first.lower};
-? { column_maximum = model.first.upper};
];
-
+
//
// Resizing:
//
-
+
- resize (line_min, column_min:INTEGER) to (line_max, column_max:INTEGER) <-
// Resize bounds of the Current array
[ ...
@@ -162,17 +162,17 @@ Section Public
-? { column_max >= column_min };
]
( + tmp:SELF;
-
- tmp := SELF.create (line_min,column_min) to (line_max, column_max);
+
+ tmp := SELF.create (line_min,column_min) to (line_max, column_max);
// BSBS: It may be possible to avoid this ceation when :
// BSBS: new `capacity' <= old `capacity'
lower1.to line_maximum do { l:INTEGER;
lower2.to column_maximum do { c:INTEGER;
(tmp.valid_index (l,c)).if {
tmp.put (item (l,c)) to (l,c);
- };
- };
- };
+ };
+ };
+ };
standard_copy tmp;
)
[ ...
@@ -181,72 +181,72 @@ Section Public
+? { column_minimum = column_min };
+? { column_maximum = column_max };
];
-
+
//
// Implementation of others feature from COLLECTION2:
//
-
+
- item (line,column:INTEGER) :V <-
(
storage.item ((line - lower1) * count2 + column - lower2)
);
-
+
- put element:V to (line,column:INTEGER) <-
(
storage.put element to ((line - lower1) * count2 + column - lower2);
);
-
+
- count1:INTEGER <-
(
upper1 - lower1 + 1
);
-
+
- count2:INTEGER <-
(
upper2 - lower2 + 1
);
-
+
- count:INTEGER <-
(
count1 * count2
);
-
+
- force x:V to (line, column:INTEGER) <-
(
(! valid_index (line,column)).if {
- resize (line.min lower1,column.min lower2) to
+ resize (line.min lower1,column.min lower2) to
(line.max upper1,column.max upper2);
};
put x to (line,column);
);
-
+
- set_all_with element:V <-
(
storage.set_all_with element until (count - 1);
);
-
+
- replace_all old_value:V with new_value:V <-
(
storage.replace_all old_value with new_value until (count - 1);
);
-
+
- fast_replace_all old_value:V with new_value:V <-
(
storage.fast_replace_all old_value with new_value until (count - 1);
);
-
- - sub_collection2 (line_min, column_min:INTEGER) to (line_max, column_max:INTEGER) :SELF <-
+
+ - sub_collection2 (line_min, column_min:INTEGER) to (line_max, column_max:INTEGER) :SELF <-
( + k:INTEGER;
+ result:SELF;
-
- result := SELF.create (line_min,column_min) to (line_max,column_max);
+
+ result := SELF.create (line_min,column_min) to (line_max,column_max);
k := 0;
- line_min.to line_max do { i:INTEGER;
+ line_min.to line_max do { i:INTEGER;
column_min.to column_max do { j:INTEGER;
result.storage.put (item (i,j)) to k;
k := k + 1;
- };
- };
+ };
+ };
result
)
[ ...
@@ -255,51 +255,51 @@ Section Public
+? { result.upper1 = line_max };
+? { result.upper2 = column_max };
];
-
+
//
// Looking and comparison:
//
-
+
- occurrences elt:V :INTEGER <-
(
- storage.occurrences elt until (count - 1)
+ storage.occurrences elt until (count - 1)
);
-
+
- fast_occurrences elt:V :INTEGER <-
(
- storage.fast_occurrences elt until (count - 1)
+ storage.fast_occurrences elt until (count - 1)
);
-
+
- has x:V :BOOLEAN <-
// Search if a element x is in the array using `equal'.
// See also `fast_has' to chose the apropriate one.
( + result:BOOLEAN;
-
+
(count > 0).if {
result := storage.first_index_of x until (count - 1) <= count - 1;
};
result
);
-
+
- fast_has x:V :BOOLEAN <-
// Search if a element x is in the array using `='.
( + result:BOOLEAN;
-
+
(count > 0).if {
result := storage.fast_first_index_of x until (count - 1) <= count - 1;
};
result
);
-
+
- all_default:BOOLEAN <-
(
storage.all_default (count - 1)
);
-
+
- swap (line1, column1:INTEGER) with (line2, column2:INTEGER) <-
( + tmp:V;
- + c2, index1, index2:INTEGER;
-
+ + c2, index1, index2:INTEGER;
+
c2 := count2;
index1 := (line1 - lower1) * c2 + column1 - lower2;
index2 := (line2 - lower1) * c2 + column2 - lower2;
@@ -307,7 +307,7 @@ Section Public
storage.put (storage.item index2) to index1;
storage.put tmp to index2;
);
-
+
- copy other:SELF <-
(
lower1 := other.lower1;
@@ -320,7 +320,7 @@ Section Public
};
storage.copy_from (other.storage) until (count - 1);
);
-
+
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <-
(
+ result:BOOLEAN;
@@ -334,32 +334,32 @@ Section Public
} else {
result := storage.memcmp (other.storage) until count;
};
-
+
result
);
-
+
//
// Other features:
//
-
+
- transpose <-
// Transpose the Current array
( + oldu1,oldu2 :INTEGER;
+ oldl1,oldl2 :INTEGER;
+ tmp1,tmp2:INTEGER;
-
+
oldu1 := line_maximum;
oldu2 := column_maximum;
oldl1 := lower1;
oldl2 := lower2;
tmp1 := lower1.min lower2;
tmp2 := line_maximum.max column_maximum;
- resize (tmp1,tmp1) to (tmp2,tmp2);
- lower1.to line_maximum do { i:INTEGER;
+ resize (tmp1,tmp1) to (tmp2,tmp2);
+ lower1.to line_maximum do { i:INTEGER;
(i + 1).to column_maximum do { j:INTEGER;
swap (i,j) with (j,i);
};
- };
+ };
resize (oldl2,oldl1) to (oldu2,oldu1);
)
[ ...
@@ -369,19 +369,19 @@ Section Public
+? { column_maximum = Old line_maximum };
+? { count = Old count };
];
-
+
- to_external:POINTER <-
// Gives C access to the internal `storage' (may be dangerous).
(
storage.to_external
);
-
+
//
// Invariant.
//
-
+
// [ ...
// -? { count2 = upper2 - lower2 + 1 };
// -? { capacity >= count }
-// ];
-
+// ];
+
diff --git a/lib/standard/collection/array3.li b/lib/standard/collection/array3.li
index 362c849..273d681 100644
--- a/lib/standard/collection/array3.li
+++ b/lib/standard/collection/array3.li
@@ -19,60 +19,60 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ARRAY3(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment :=" General prurpose, resizable, three dimensional array..";
-
+
Section Inherit
-
+
+ parent_collection3:Expanded COLLECTION3(V);
-
+
Section Public
-
+
+ lower1:INTEGER;
+ lower2:INTEGER;
+ lower3:INTEGER;
-
+
+ upper1:INTEGER;
+ upper2:INTEGER;
+ upper3:INTEGER;
-
+
+ count1:INTEGER;
+ count2:INTEGER;
+ count3:INTEGER;
-
+
+ count:INTEGER;
-
+
Section ARRAY3
-
+
+ storage:NATIVE_ARRAY(V);
// To store elements line by line.
-
+
+ capacity:INTEGER;
// Number of elements in `storage'.
-
+
Section Public
-
+
//
// Creation / modification:
- //
-
- - create (line_min, column_min, depth_min:INTEGER)
+ //
+
+ - create (line_min, column_min, depth_min:INTEGER)
to (line_max, column_max, depth_max:INTEGER) :SELF <-
// Reset all bounds `line_minimum' / `line_maximum' / `column_minimum'
// `column_maximum' / `depth_min' and `depth_max' using arguments as
// new values. All elements are set to the default value of type E.
( + result:SELF;
-
+
result := clone;
result.make (line_min, column_min, depth_min) to (line_max, column_max, depth_max);
result
- );
-
+ );
+
- make (line_min, column_min, depth_min:INTEGER) to (line_max, column_max, depth_max:INTEGER) <-
// Reset all bounds `line_minimum' / `line_maximum' / `column_minimum'
// `column_maximum' / `depth_min' and `depth_max' using arguments as
@@ -82,7 +82,7 @@ Section Public
-? { column_min <= column_max };
-? { depth_min <= depth_max };
]
- (
+ (
lower1 := line_min;
upper1 := line_max;
lower2 := column_min;
@@ -108,28 +108,28 @@ Section Public
+? { depth_minimum = depth_min };
+? { depth_maximum = depth_max };
];
-
+
- from_collection3 model:COLLECTION3(V) <-
(
- make (model.line_minimum, model.column_minimum, model.depth_minimum)
+ make (model.line_minimum, model.column_minimum, model.depth_minimum)
to (model.line_maximum, model.column_maximum, model.depth_maximum);
-
- line_minimum.to line_maximum do { i:INTEGER;
- column_minimum.to column_maximum do { j:INTEGER;
+
+ line_minimum.to line_maximum do { i:INTEGER;
+ column_minimum.to column_maximum do { j:INTEGER;
depth_minimum.to depth_maximum do { k:INTEGER;
put (model.item (i,j,k)) to (i,j,k);
- };
- };
- };
+ };
+ };
+ };
)
[ ...
+? { lower1 = model.lower1 };
+? { lower2 = model.lower2 };
+? { lower3 = model.lower3 };
];
-
- - from_collection contents:COLLECTION(V)
- size (line_min,column_min,depth_min:INTEGER)
+
+ - from_collection contents:COLLECTION(V)
+ size (line_min,column_min,depth_min:INTEGER)
to (line_max,column_max,depth_max:INTEGER) <-
// Reset all bounds using `line_min', `line_max', `column_min',
// `column_max', `depth_min', and `depth_max'.
@@ -138,18 +138,18 @@ Section Public
-? { line_min <= line_max };
-? { column_min <= column_max };
-? { depth_min <= depth_max };
- -? {
- contents.count = (line_max - line_min + 1) *
- (column_max - column_min + 1) *
- (depth_max - depth_min + 1)
+ -? {
+ contents.count = (line_max - line_min + 1) *
+ (column_max - column_min + 1) *
+ (depth_max - depth_min + 1)
};
]
- (
+ (
make (line_min,column_min,depth_min) to (line_max,column_max,depth_max);
-
+
0.to (count - 1) do { i:INTEGER;
storage.put (contents.item (contents.lower + i)) to i;
- };
+ };
)
[ ...
+? { line_minimum = line_min };
@@ -160,19 +160,19 @@ Section Public
+? { depth_maximum = depth_max };
+? { count = contents.count };
];
-
+
- from_model model:COLLECTION(COLLECTION(COLLECTION(V))) <-
//The `model' is used to fill line by line the COLLECTION3.
//Assume all sub-collections of have the same indexing.
(
- make (model.lower,model.first.lower,model.first.first.lower)
+ make (model.lower,model.first.lower,model.first.first.lower)
to (model.upper,model.first.upper,model.first.first.upper);
-
+
(model.lower).to (model.upper) do { line:INTEGER;
(model.first.lower).to (model.first.upper) do { column:INTEGER;
(model.first.first.lower).to (model.first.first.upper) do { depth:INTEGER;
put (model.item line.item column.item depth) to (line,column,depth);
- };
+ };
};
};
)
@@ -184,11 +184,11 @@ Section Public
-? { depth_minimum = model.first.first.lower };
-? { depth_maximum = model.first.first.upper };
];
-
+
//
// Resizing:
//
-
+
- resize (line_min, column_min, depth_min:INTEGER) to (line_max, column_max, depth_max:INTEGER) <-
// Resize bounds of the Current array
[ ...
@@ -197,22 +197,22 @@ Section Public
-? { depth_max >= depth_min };
]
( + tmp:SELF;
-
+
tmp := SELF.clone;
tmp.make (line_min, column_min, depth_min) to (line_max, column_max, depth_max);
//BSBS: It may be possible to avoid this creation when :
//BSBS: new `capacity' <= old `capacity'
-
+
lower1.to line_maximum do { l:INTEGER;
lower2.to column_maximum do { c:INTEGER;
lower3.to depth_maximum do { d:INTEGER;
(tmp.valid_index (l,c,d)).if {
tmp.put (item (l,c,d)) to (l,c,d);
- };
- };
- };
- };
-
+ };
+ };
+ };
+ };
+
standard_copy tmp;
)
[ ...
@@ -223,128 +223,128 @@ Section Public
+? { depth_minimum = depth_min };
+? { depth_maximum = depth_max };
];
-
+
//
// Implementation of others feature from COLLECTION3:
//
-
+
- item (line, column, depth:INTEGER) :V <-
(
storage.item (
- (line - lower1) * count2 * count3 +
+ (line - lower1) * count2 * count3 +
(column - lower2) * count3 + depth - lower3
)
);
-
+
- put element:V to (line, column, depth:INTEGER) <-
(
storage.put element to (
- (line - lower1) * count2 * count3 +
+ (line - lower1) * count2 * count3 +
(column - lower2) * count3 + depth - lower3
);
);
-
+
- force x:V to (line, column, depth:INTEGER) <-
(
(! valid_index (line,column,depth)).if {
- resize (line.min lower1,column.min lower2,depth.min lower3)
+ resize (line.min lower1,column.min lower2,depth.min lower3)
to (line.max upper1,column.max upper2,depth.max upper3);
};
put x to (line,column,depth);
);
-
+
- set_all_with element:V <-
(
storage.set_all_with element with (count - 1);
);
-
+
- replace_all old_value:V with new_value:V <-
(
storage.replace_all old_value with new_value until (count - 1);
);
-
+
- fast_replace_all old_value:V with new_value:V <-
(
storage.fast_replace_all old_value with new_value until (count - 1);
);
-
- - sub_collection3 (line_min, column_min, depth_min:INTEGER)
+
+ - sub_collection3 (line_min, column_min, depth_min:INTEGER)
to (line_max, column_max, depth_max:INTEGER) :SELF <-
( + n:INTEGER;
+ result:SELF;
-
+
result := create (line_min,column_min,depth_min) to (line_max,column_max,depth_max);
-
+
line_min.to line_max do { i:INTEGER;
column_min.to column_max do { j:INTEGER;
depth_min.to depth_max do { k:INTEGER;
result.storage.put (item (i,j,k)) to n;
n := n + 1;
- };
+ };
};
};
result
)
- [ ...
+ [ ...
+? { result.lower1 = line_min };
+? { result.lower2 = column_min };
+? { result.lower3 = depth_min };
+? { result.upper1 = line_max };
+? { result.upper2 = column_max };
- +? { result.upper3 = depth_max };
+ +? { result.upper3 = depth_max };
];
-
+
//
// Looking and comparison:
//
-
+
- occurrences elt:V :INTEGER <-
(
storage.occurrences elt until (count - 1)
);
-
+
- fast_occurrences elt:V :INTEGER <-
(
storage.fast_occurrences elt until (count - 1)
);
-
+
- has x:V :BOOLEAN <-
//Search if a element x is in the array using `equal'.
//See also `fast_has' to choose the apropriate one.
( + result:BOOLEAN;
-
+
(count > 0).if {
result := storage.index_of x until (count - 1) <= count - 1;
};
result
);
-
+
- fast_has x:V :BOOLEAN <-
// Search if a element x is in the array using `='.
( + result:BOOLEAN;
-
+
(count > 0).if {
result := storage.fast_index_of x until (count - 1) <= count -1;
};
result
);
-
+
- all_default:BOOLEAN <-
(
storage.all_default (count - 1)
);
-
+
- swap (line1, column1, depth1:INTEGER) with (line2, column2, depth2:INTEGER) <-
( + tmp:V;
+ index1, index2:INTEGER;
-
+
index1 := (line1 - lower1) * count2 * count3 + (column1 - lower2) * count3 + depth1 - lower3;
index2 := (line2 - lower1) * count2 * count3 + (column2 - lower2) * count3 + depth2 - lower3;
tmp := storage.item index1;
storage.put(storage.item index2) to index1;
storage.put tmp to index2;
);
-
+
- copy other:SELF <-
(
lower1 := other.lower1;
@@ -363,25 +363,25 @@ Section Public
};
storage.copy_from (other.storage) until (count - 1);
);
-
+
//
// Invariant.
//
-
+
// [ ...
// -? { count1 = upper1 - lower1 + 1 };
// -? { count2 = upper2 - lower2 + 1 };
// -? { count3 = upper3 - lower3 + 1 };
// -? { capacity >= count };
// ];
-
-
-/*
+
+
+/*
- '==' Right 60 other:SELF :BOOLEAN <-
(
+ result:BOOLEAN;
result := FALSE;
-
+
( other = Self ).if {
result := true;
}.elseif { lower1 != other.lower1 } then {
@@ -393,7 +393,7 @@ Section Public
} else {
result := storage.memcmp (other.storage) until count;
};
-
+
result
);
*/
\ No newline at end of file
diff --git a/lib/standard/collection/avl_dictionary.li b/lib/standard/collection/avl_dictionary.li
index 94a7ede..a69fcf1 100644
--- a/lib/standard/collection/avl_dictionary.li
+++ b/lib/standard/collection/avl_dictionary.li
@@ -19,42 +19,42 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := AVL_DICTIONARY(V, K);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Associative memory. Values of type `V' are stored using Keys of type `K'.";
-
- // Efficient implementation of DICTIONARY using an AVL balanced tree.
- // AVL stands for the names of G. M. Adel'son-Velskii and E. M. Landis,
- // two Russian mathematicians who first came up with this method of keeping
+
+ // Efficient implementation of DICTIONARY using an AVL balanced tree.
+ // AVL stands for the names of G. M. Adel'son-Velskii and E. M. Landis,
+ // two Russian mathematicians who first came up with this method of keeping
// the tree balanced.
Section Insert
-
+
+ parent_avl_tree:Expanded AVL_TREE(K);
Section Inherit
-
+
+ parent_simple_dictionary:Expanded SIMPLE_DICTIONARY(V, K);
-
+
Section Private
-
+
- key_memory:K <- item_memory;
-
+
Section Public
-
+
- capacity:INTEGER <- count;
- - at k:K :V <-
+ - at k:K :V <-
( + dic:AVL_DICTIONARY_NODE(V,K);
dic ?= root.at k;
dic.value
);
- - fast_at k:K :V <-
+ - fast_at k:K :V <-
( + dic:AVL_DICTIONARY_NODE(V,K);
dic ?= root.fast_at k;
dic.value
@@ -63,7 +63,7 @@ Section Public
- reference_at k:K :V <-
( + result:V;
+ n:AVL_DICTIONARY_NODE(V, K);
-
+
(root != NULL).if {
n := root.at k;
(n != NULL).if {
@@ -76,7 +76,7 @@ Section Public
- fast_reference_at k:K :V <-
( + result:V;
+ n:AVL_DICTIONARY_NODE(V, K);
-
+
(root != NULL).if {
n := root.fast_at k;
(n != NULL).if {
@@ -85,9 +85,9 @@ Section Public
};
result
);
-
+
- put v:V to k:K <- add v to k;
-
+
- add v:V to k:K <-
(
value_memory := v;
@@ -104,7 +104,7 @@ Section Public
- occurrences v:V :INTEGER <-
( + result:INTEGER;
-
+
(root != NULL).if {
result := root.occurrences v;
};
@@ -113,7 +113,7 @@ Section Public
- fast_occurrences v:V :INTEGER <-
( + result:INTEGER;
-
+
(root != NULL).if {
result := root.fast_occurrences v;
};
@@ -121,7 +121,7 @@ Section Public
);
- key_at v:V :K <- root.key_at v;
-
+
- fast_key_at v:V :K <- root.fast_key_at v;
- clear_count <- clear_count_and_capacity;
@@ -154,7 +154,7 @@ Section Public
);
- internal_key k:K :K <- root.at(k).key;
-
+
- make <-
(
map := FAST_ARRAY(AVL_TREE_NODE(K)).create 0;
@@ -166,19 +166,19 @@ Section Public
);
Section Private
-
+
+ value_memory:V;
- set_value_and_key n:AVL_TREE_NODE(K) <-
( + dic:AVL_DICTIONARY_NODE(V,K);
-
+
dic ?= n;
dic.make (value_memory, key_memory);
);
- set_value n:AVL_TREE_NODE(K) <-
( + dic:AVL_DICTIONARY_NODE(V,K);
-
+
dic ?= n;
dic.set_value value_memory;
);
@@ -195,7 +195,7 @@ Section Private
- discard_node n:AVL_DICTIONARY_NODE(V, K) <-
( + v:V;
+ k:K;
-
+
n.make (v, k);
);
@@ -203,12 +203,12 @@ Section Private
(
AVL_DICTIONARY_NODE(V, K).clone
);
-
-
- //
+
+
+ //
//invariant
//
-
+
//[ ...
// -? {lost_nodes != NULL};
// -? {lost_nodes = common_lost_nodes.at generating_type};
diff --git a/lib/standard/collection/avl_set.li b/lib/standard/collection/avl_set.li
index 873aab8..be21856 100644
--- a/lib/standard/collection/avl_set.li
+++ b/lib/standard/collection/avl_set.li
@@ -19,20 +19,20 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := AVL_SET(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
Section Inherit
-
+
+ parent_set:Expanded SET(V);
-
+
+ parent_avl_tree:Expanded AVL_TREE(V);
-
-Section Public
-
+
+Section Public
+
- add e:V <-
(
item_memory := e;
@@ -58,7 +58,7 @@ Section Public
- reference_at e:V :V <-
( + n:AVL_SET_NODE(V);
+ result:V;
-
+
(root != NULL).if {
n := root.at e;
(n != NULL).if {
@@ -70,18 +70,18 @@ Section Public
- item index:INTEGER :V <-
( + result:V;
-
+
(map_dirty).if {
build_map;
};
map.item (index - 1).item
);
-
+
Section Private
-
+
- set_item n:AVL_SET_NODE(V) <-
(
- n.make item_memory;
+ n.make item_memory;
);
- set_value n:AVL_SET_NODE(V);
@@ -97,7 +97,7 @@ Section Private
- discard_node n:AVL_SET_NODE(V) <-
( //+ i:V;
-
+
//n.make i;
//n.set_left (lost_nodes.item);
//lost_nodes.set_item n;
@@ -108,16 +108,16 @@ Section Private
AVL_SET_NODE(V).create
);
-Section Public
-
+Section Public
+
- create:SELF <-
( + result:SELF;
-
+
result := clone;
result.make;
result
);
-
+
- make <-
(
//(lost_nodes != NULL).if {
@@ -131,11 +131,11 @@ Section Public
// };
// };
);
-
+
//
// Invariant.
//
-
+
// [
// -? {lost_nodes != NULL};
// -? {lost_nodes = common_lost_nodes.at generating_type};
diff --git a/lib/standard/collection/fast_array.li b/lib/standard/collection/fast_array.li
index ed7ac33..028f759 100644
--- a/lib/standard/collection/fast_array.li
+++ b/lib/standard/collection/fast_array.li
@@ -19,80 +19,80 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FAST_ARRAY(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- author :="Boutet Jerome (boutet at loria.fr)";
-
+
- comment :="Resizable, fixed lower bound array.\
\Unlike ARRAY, the `lower' bound of a FAST_ARRAY is frozen \
\to 0. Thus, some memory is saved and looping toward `lower' \
\bound (which is 0) run a little bit faster.";
-
- // General purpose resizable FAST_ARRAYs. The only difference with ARRAY is the
+
+ // General purpose resizable FAST_ARRAYs. The only difference with ARRAY is the
// fact that the `lower' bound is actually frozen to 0. The `item' access is likely
- // to be more efficient as well as loop going from `upper' to `lower' just because
+ // to be more efficient as well as loop going from `upper' to `lower' just because
// `lower' is 0. Keep in mind that even if the `lower' is frozen to 0
- // it is really better to use the `lower' attribute, and not 0 directly, just because
+ // it is really better to use the `lower' attribute, and not 0 directly, just because
// you may decide in the future to use another COLLECTION implementation.
//
- // Like ARRAY, the FAST_ARRAY implementation uses only one chunk of memory, the
- // `storage' area which is a NATIVE_ARRAY. One must keep in mind that this internal
- // `storage' area is always kept left align. Thus, you can expect good performances
- // while using a FAST_ARRAY to modelize a stack behavior with
- // `add_last' / `last' / `remove_last'. Conversely `add_first' and `remove_first' are
- // likely to slow down your program if they are too often used. If the fact that
+ // Like ARRAY, the FAST_ARRAY implementation uses only one chunk of memory, the
+ // `storage' area which is a NATIVE_ARRAY. One must keep in mind that this internal
+ // `storage' area is always kept left align. Thus, you can expect good performances
+ // while using a FAST_ARRAY to modelize a stack behavior with
+ // `add_last' / `last' / `remove_last'. Conversely `add_first' and `remove_first' are
+ // likely to slow down your program if they are too often used. If the fact that
// `lower' is stuck to 0 do matter, also consider ARRAY.
-
+
Section Inherit
-
+
+ parent_arrayed_collection:Expanded ARRAYED_COLLECTION(V);
-
+
Section Public
-
+
- lower:INTEGER := 0; // Frozen lower bound.
-
+
//
// Creation and modification:
//
-
+
- create new_count:INTEGER :SELF <-
// Make array with range [0 .. `new_count' - 1].
// When `new_count' = 0 the array is empty.
( + result:SELF;
-
- result := clone;
+
+ result := clone;
result.make new_count;
result
);
-
+
- create_with_capacity new_count:INTEGER :SELF <-
// Create an empty array with at least `needed_capacity'.
( + result:SELF;
-
- result := clone;
+
+ result := clone;
result.with_capacity new_count;
result
);
-
+
- create_with_native_array_byte na:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :SELF <-
( + result:SELF;
-
+
result := clone;
result.make_with_native_array_byte na size s;
result
);
-
+
- make_with_map_object obj:OBJECT <-
// BSBS: A revoir.
[ ...
//-? {obj.object_size!=0};
-? {element_sizeof = 1};
]
- (
+ (
storage := CONVERT(OBJECT,NATIVE_ARRAY(V)).on obj;
capacity := obj.object_size;
upper := -1;
@@ -100,13 +100,13 @@ Section Public
[ ...
+? {storage != NULL};
];
-
+
- make_with_native_array_byte na:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER <-
[ ...
-? {s > 0};
-? {na != NULL};
]
- (
+ (
storage := na;
capacity := s;
upper := -1;
@@ -114,36 +114,36 @@ Section Public
[ ...
+? {storage != NULL};
];
-
+
- make new_count:INTEGER <-
// Make array with range [0 .. `new_count' - 1].
// When `new_count' = 0 the array is empty.
[ ...
-? { new_count >= 0};
]
- (
+ (
( new_count.to_integer > capacity).if {
// The new one is bigger:
- storage := NATIVE_ARRAY(V).create new_count;
+ storage := NATIVE_ARRAY(V).create new_count;
capacity := new_count;
- }.elseif { (capacity > 0) && { upper >= 0}} then {
+ }.elseif { (capacity > 0) && { upper >= 0}} then {
// The new one is smaller and just need to be cleared:
storage.clear 0 to upper;
- };
+ };
upper := new_count - 1;
)
[ ...
+? { count = new_count };
+? { capacity >= Old capacity };
- +? { (upper >= 0) ->> {all_default} };
- ];
-
+ +? { (upper >= 0) ->> {all_default} };
+ ];
+
- with_capacity needed_capacity:INTEGER <-
// Create an empty array with at least `needed_capacity'.
[ ...
-? { needed_capacity >= 0 };
]
- (
+ (
(capacity < needed_capacity).if {
storage := NATIVE_ARRAY(V).create needed_capacity;
capacity := needed_capacity;
@@ -154,16 +154,16 @@ Section Public
)
[ ...
+? { capacity >= needed_capacity };
- +? { is_empty };
- ];
-
+ +? { is_empty };
+ ];
+
//
// Hashable.
//
-
+
- hash_code:INTEGER <-
( + result:INTEGER;
-
+
(! is_empty).if {
(last != NULL).if {
result := last.hash_code;
@@ -173,7 +173,7 @@ Section Public
};
result
);
-
+
//
// Modification:
//
@@ -183,28 +183,28 @@ Section Public
[
-? {new_capacity >= 0};
]
- (
+ (
(new_capacity > capacity).if {
(capacity = 0).if {
storage := NATIVE_ARRAY(V).create new_capacity;
} else {
- storage := storage.realloc capacity with new_capacity;
- };
- capacity := new_capacity;
- };
+ storage := storage.realloc capacity with new_capacity;
+ };
+ capacity := new_capacity;
+ };
)
[
- +? { capacity >= Old capacity };
+ +? { capacity >= Old capacity };
];
-
+
- fast_resize new_count:INTEGER <-
[
- ? {new_count <= capacity};
+ ? {new_count <= capacity};
]
(
upper := new_count - 1;
);
-
+
- resize new_count:INTEGER <-
// Resize the array. When `new_count' is greater than
// `count', new positions are initialized with appropriate
@@ -213,7 +213,7 @@ Section Public
-? {new_count >= 0};
]
( + new_capacity:INTEGER;
-
+
( new_count > count).if {
(capacity = 0).if {
storage := NATIVE_ARRAY(V).create new_count;
@@ -222,37 +222,37 @@ Section Public
new_capacity := capacity * 2;
{ new_capacity >= new_count }.until_do {
new_capacity := new_capacity * 2;
- };
+ };
storage := storage.realloc capacity with new_capacity;
- capacity := new_capacity;
- };
+ capacity := new_capacity;
+ };
}.elseif { new_count != count } then {
storage.clear new_count to (count - 1);
- };
-
+ };
+
upper := new_count - 1;
- )
+ )
[ ...
+? { count = new_count };
- +? { capacity >= Old capacity };
- ];
-
+ +? { capacity >= Old capacity };
+ ];
+
//
// Implementation of deferred:
//
-
+
- is_empty:BOOLEAN <- ( upper < 0 ); // end is_empty
-
- - item i:INTEGER :V <-
- (
+
+ - item i:INTEGER :V <-
+ (
storage.item i
- );
-
+ );
+
- put element:V to i:INTEGER <-
- (
- storage.put element to i;
- );
-
+ (
+ storage.put element to i;
+ );
+
- add element:V first n:INTEGER <-
[ -? {n > 0}; ]
( + new_capacity,new_count:INTEGER;
@@ -272,9 +272,9 @@ Section Public
storage.move 0 to upper by n;
storage.set_slice_with element from lower until (n-1);
);
-
+
- add_first element:V <-
- (
+ (
add_last element;
(upper = 0).if {
}.elseif {upper = 1} then {
@@ -282,12 +282,12 @@ Section Public
} else {
move 0 to (upper - 1) by 1;
storage.put element to 0;
- };
- );
-
+ };
+ );
+
- add_last element:V <-
( + new_capacity:INTEGER;
-
+
(upper + 1 <= capacity - 1 ).if {
upper := upper + 1;
}.elseif {capacity = 0} then {
@@ -299,93 +299,93 @@ Section Public
storage := storage.realloc capacity with new_capacity;
capacity := new_capacity;
upper := upper + 1;
- };
+ };
storage.put element to upper;
- );
-
+ );
+
- count:INTEGER <- ( upper + 1 ); // end count
-
+
- clear <-
- (
+ (
upper := -1;
)
[ ...
- +? { capacity = Old capacity };
- ];
-
+ +? { capacity = Old capacity };
+ ];
+
- copy other:SELF <-
// Copy `other' onto Current.
( + other_upper, new_capacity:INTEGER;
-
- other_upper := other.upper;
+
+ other_upper := other.upper;
(other_upper >= 0).if {
new_capacity := other_upper + 1;
-
+
( capacity < new_capacity ).if {
storage := NATIVE_ARRAY(V).create new_capacity;
capacity := new_capacity;
//}.elseif { capacity > 0 } then {
// storage.clear_all (capacity - 1);
- };
+ };
storage.copy_from (other.storage) until other_upper;
//}.elseif { capacity > 0 } then {
// storage.clear_all (capacity - 1);
- };
+ };
upper := other_upper;
- );
-
+ );
+
- set_all_with v:V <-
- (
- storage.set_all_with v until upper;
- ) ;
-
+ (
+ storage.set_all_with v until upper;
+ ) ;
+
//
// Sort (BSBS: to put in ARRAYED_COLLECTION)
//
-
+
- bubble_sort <-
- // Bubble sort
- (
+ // Bubble sort
+ (
bubble_sort_with { (a,b:V); a > b};
);
-
+
- bubble_sort_with cmp:{ (V,V); BOOLEAN} <-
- // Bubble sort
+ // Bubble sort
( + low,up,idx,max:INTEGER;
+ sw:BOOLEAN;
-
+
max := upper-1;
-
+
low := 0;
up := max;
{
sw:=FALSE;
- low.to up do { i:INTEGER;
+ low.to up do { i:INTEGER;
(cmp.value (item i,item (i+1))).if {
swap i with (i+1);
sw := TRUE;
};
-
+
idx := max - i;
(cmp.value (item idx,item (idx+1))).if {
swap idx with (idx+1);
sw := TRUE;
- };
+ };
};
up := up - 1;
low := low + 1;
}.do_while {sw};
);
-
- - quick_sort_from low:INTEGER to up:INTEGER <-
+
+ - quick_sort_from low:INTEGER to up:INTEGER <-
quick_sort_from low to up with { (a,b:V); a > b};
-
+
- quick_sort_from low:INTEGER to up:INTEGER with cmp:{ (V,V); BOOLEAN} <-
// Quick sort algorithm (naive implementation)
( + i, p:INTEGER;
+ pivot, tmp:INTEGER;
- (up > low).if {
+ (up > low).if {
pivot := (low + up) >> 1;
swap pivot with low;
p := low;
@@ -400,130 +400,130 @@ Section Public
quick_sort_from (p + 1) to up;
};
);
-
+
- quick_sort <- quick_sort_from lower to upper;
-
+
- quick_sort_with cmp:{ (V,V); BOOLEAN} <- quick_sort_from lower to upper with cmp;
-
+
//
// Other.
//
-
+
- from_collection model:COLLECTION(V) <-
( + i1:INTEGER;
-
+
with_capacity model.count;
upper := model.count - 1;
- i1 := 0;
+ i1 := 0;
(model.lower).to (model.upper) do { i2:INTEGER;
storage.put (model.item i2) to i1;
i1 := i1 + 1;
- };
- );
-
+ };
+ );
+
- Self:SELF '==' Right 60 other:E :BOOLEAN <-
( + result:BOOLEAN;
+ same:SELF;
-
+
( Self = other).if {
result := TRUE;
- } else {
+ } else {
same ?= other;
((same != NULL) && { upper = same.upper }).if {
result := storage.fast_memcmp (same.storage) until (upper + 1) ;
};
};
-
+
result
- );
-
- - is_equal_map other:SELF :BOOLEAN <-
+ );
+
+ - is_equal_map other:SELF :BOOLEAN <-
( + result:BOOLEAN;
-
+
( Self = other).if {
result := TRUE;
}.elseif {upper = other.upper} then {
result := storage.memcmp (other.storage) until (upper + 1);
- };
-
+ };
+
result
- );
-
- - all_default:BOOLEAN <-
+ );
+
+ - all_default:BOOLEAN <-
[
-? {storage != NULL};
]
- (
+ (
storage.all_default upper
- );
-
- - occurrences element:V :INTEGER <-
- (
- storage.occurrences element until upper
- );
-
- - fast_occurrences element:V :INTEGER <-
- (
- storage.fast_occurrences element until upper
- );
-
- - first_index_of element:V :INTEGER <-
+ );
+
+ - occurrences element:V :INTEGER <-
+ (
+ storage.occurrences element until upper
+ );
+
+ - fast_occurrences element:V :INTEGER <-
+ (
+ storage.fast_occurrences element until upper
+ );
+
+ - first_index_of element:V :INTEGER <-
( + result:INTEGER;
-
+
(upper >= 0).if {
result := storage.first_index_of element until upper;
};
result
- );
+ );
- - index_of element:V start start_index:INTEGER :INTEGER <-
+ - index_of element:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
-
+
(upper >= 0).if {
result := storage.index_of (element,start_index) until upper;
- };
- result
- );
-
+ };
+ result
+ );
+
- reverse_index_of element:V start start_index:INTEGER :INTEGER <-
(
storage.reverse_index_of (element, start_index)
);
-
- - fast_first_index_of element:V :INTEGER <-
- ( + result:INTEGER;
-
+
+ - fast_first_index_of element:V :INTEGER <-
+ ( + result:INTEGER;
+
(upper >= 0).if {
result := storage.fast_first_index_of element until upper;
- };
+ };
result
- );
+ );
+
+ - fast_index_of element:V start start_index:INTEGER :INTEGER <-
+ ( + result:INTEGER;
- - fast_index_of element:V start start_index:INTEGER :INTEGER <-
- ( + result:INTEGER;
-
(upper >= 0).if {
result := storage.fast_index_of (element,start_index) until upper;
- };
+ };
result
- );
-
+ );
+
- fast_reverse_index_of element:V start start_index:INTEGER :INTEGER <-
(
storage.fast_reverse_index_of (element, start_index)
);
-
+
- subarray min:INTEGER to max:INTEGER :SELF <- // slice
( + result:SELF;
-
+
result := SELF.create (max - min + 1);
result.storage.slice_copy storage to 0 from min to max;
-
+
result
- );
-
- - force element:V to index:INTEGER <-
- (
+ );
+
+ - force element:V to index:INTEGER <-
+ (
( index <= upper ).if {
storage.put element to index;
}.elseif { index = (upper + 1) } then {
@@ -531,12 +531,12 @@ Section Public
} else {
resize (index + 1);
storage.put element to index;
- };
- );
-
- - remove_first <-
+ };
+ );
+
+ - remove_first <-
( + void_storage:NATIVE_ARRAY(V);
-
+
( upper = 0).if {
storage := void_storage;
capacity := 0;
@@ -544,30 +544,30 @@ Section Public
} else {
storage.remove_first upper;
upper := upper - 1;
- };
+ };
)
[ ...
+? {lower = Old lower};
- ];
-
+ ];
+
- remove_head n:INTEGER <-
(
storage.move n to upper by (-n);
upper := upper - n;
);
-
- - remove index:INTEGER <-
- (
+
+ - remove index:INTEGER <-
+ (
storage.remove index until upper;
upper := upper - 1;
- );
-
+ );
+
- remove beg:INTEGER to end:INTEGER <-
[ ...
-? {beg <= end};
]
( + s:INTEGER;
-
+
(beg = end).if {
remove beg;
} else {
@@ -581,16 +581,16 @@ Section Public
[
-? {beg >= 0};
]
- (
- (beg <= upper).if {
- upper := beg - 1;
+ (
+ (beg <= upper).if {
+ upper := beg - 1;
};
);
-
+
//
// Guru Section.
//
-
+
- set_upper new_up:INTEGER <-
(
upper := new_up;
diff --git a/lib/standard/collection/fast_array2.li b/lib/standard/collection/fast_array2.li
index 9744008..b4274ad 100644
--- a/lib/standard/collection/fast_array2.li
+++ b/lib/standard/collection/fast_array2.li
@@ -129,7 +129,7 @@ Section Public
// The `model' is used to fill line by line the COLLECTION2.
// Assume all sub-collections of `model' have the number of items.
( + l,c:INTEGER;
-
+
make(model.count, model.first.count);
l := model.lower;
lower1.to upper1 do { line:INTEGER;
@@ -145,13 +145,13 @@ Section Public
- sub_collection2 (line_min,column_min:INTEGER) to (line_max,column_max:INTEGER) :SELF <-
( + l,c:INTEGER;
+ result:SELF;
-
+
result := create (line_max - line_min + 1, column_max - column_min + 1);
l := line_min;
(result.lower1).to (result.upper1) do { line:INTEGER;
c := column_min;
(result.lower2).to (result.upper2) do { column:INTEGER;
- result.put (item (l, c)) to (line, column);
+ result.put (item (l, c)) to (line, column);
c := c + 1;
};
l := l + 1;
diff --git a/lib/standard/collection/fast_array3.li b/lib/standard/collection/fast_array3.li
index 632d337..d2760df 100644
--- a/lib/standard/collection/fast_array3.li
+++ b/lib/standard/collection/fast_array3.li
@@ -19,63 +19,63 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FAST_ARRAY3(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Resizable three dimensional array.\
\Unlike ARRAY3, the `lower1', `lower2' and `lower3' bounds \
\are frozen to 0. Thus, one can expect better performances. .";
-
+
Section Inherit
-
+
+ parent_collection3:Expanded COLLECTION3(V);
-
+
Section Public
-
+
+ upper1:INTEGER;
+ count1:INTEGER;
-
+
+ upper2:INTEGER;
+ count2:INTEGER;
-
+
+ upper3:INTEGER;
+ count3:INTEGER;
-
+
+ count:INTEGER;
-
+
Section Private
-
+
+ count2x3:INTEGER;
// To speed up access, this value is always equal to
// `count2' * `count3'
-
+
Section FAST_ARRAY3
-
+
+ storage:NATIVE_ARRAY(V);
-
+
+ capacity:INTEGER; // of `storage'.
-
+
Section Public
-
+
- lower1:INTEGER := 0;
-
+
- lower2:INTEGER := 0;
-
+
- lower3:INTEGER := 0;
-
+
- create (new_count1, new_count2, new_count3:INTEGER) :SELF<-
// Create or reset `Current' with new dimensions.
// All elements are set to the default value of type E.
( + result:SELF;
-
+
result := clone;
result.make (new_count1, new_count2, new_count3);
result
);
-
+
- make (new_count1, new_count2, new_count3 :INTEGER) <-
// Create or reset `self' with new dimensions.
// All elements are set to the default value of type E.
@@ -84,7 +84,7 @@ Section Public
-? { new_count2 > 0 };
-? { new_count3 > 0 };
]
- (
+ (
count1 := new_count1;
upper1 := new_count1 - 1;
count2 := new_count2;
@@ -106,7 +106,7 @@ Section Public
+? { count3 = new_count3 };
+? { all_default };
];
-
+
- from_collection3 model:COLLECTION3(V) <-
// Uses the `model' to update self.
(
@@ -119,7 +119,7 @@ Section Public
};
};
);
-
+
- from_collection contents:COLLECTION(V) size (new_count1, new_count2, new_count3:INTEGER) <-
// Reset all bounds using `new_count#i'.
// Copy all elements of `contents', line by line into self.
@@ -129,7 +129,7 @@ Section Public
-? { new_count3 >= 0 };
-? { contents.count = new_count1 * new_count2 * new_count3 };
]
- (
+ (
make (new_count1, new_count2, new_count3);
lower1.to (count - 1) do { i:INTEGER;
storage.put (contents.item (contents.lower + i)) to i;
@@ -141,19 +141,19 @@ Section Public
+? { depth_maximum = new_count3 - 1 };
+? { count = contents.count };
];
-
-
+
+
- from_model model:COLLECTION(COLLECTION(COLLECTION(V))) <-
// The `model' is used to fill line by line the COLLECTION3.
// Assume all sub-collections of have the same indexing.
( + n:INTEGER;
-
+
make (
- model.upper - model.lower + 1,
- model.first.upper - model.first.lower + 1,
+ model.upper - model.lower + 1,
+ model.first.upper - model.first.lower + 1,
model.first.first.upper - model.first.first.lower + 1
);
-
+
(model.lower).to (model.upper) do { line:INTEGER;
(model.first.lower).to (model.first.upper) do { column:INTEGER;
(model.first.first.lower).to (model.first.first.upper) do { depth:INTEGER;
@@ -168,22 +168,22 @@ Section Public
+? { column_maximum = model.first.upper - model.first.lower };
+? { depth_maximum = model.first.first.upper - model.first.first.lower };
];
-
+
//
// Implementation of others feature from COLLECTION3:
//
-
+
- item (line, column, depth:INTEGER) :V <-
(
storage.item (line * count2x3 + column * count3 + depth)
);
-
+
- put element:V to (line, column, depth:INTEGER) <-
(
storage.put element to (line * count2x3 + column * count3 + depth);
);
-
-
+
+
- force element:V to (line, column, depth :INTEGER) <-
(
(! valid_index (line, column, depth)).if {
@@ -191,8 +191,8 @@ Section Public
};
put element to (line,column,depth);
);
-
-
+
+
- copy other:SELF <-
(
count1 := other.count1;
@@ -209,18 +209,18 @@ Section Public
};
storage.copy_from (other.storage) until (count - 1);
);
-
- - sub_collection3 (line_min,column_min,depth_min:INTEGER)
+
+ - sub_collection3 (line_min,column_min,depth_min:INTEGER)
to (line_max,column_max,depth_max:INTEGER) :SELF <-
( + n:INTEGER;
+ result:SELF;
-
+
result := SELF.create (
- line_max - line_min + 1,
- column_max - column_min + 1,
+ line_max - line_min + 1,
+ column_max - column_min + 1,
depth_max - depth_min + 1
);
-
+
line_min.to line_max do { i:INTEGER;
column_min.to column_max do { j:INTEGER;
depth_min.to depth_max do { k:INTEGER;
@@ -234,30 +234,30 @@ Section Public
[ ...
+? { result.upper1 = line_max - line_min };
+? { result.upper2 = column_max - column_min };
- +? { result.upper3 = depth_max - depth_min };
+ +? { result.upper3 = depth_max - depth_min };
];
-
+
//
// Writing:
//
-
+
- set_all_with x:V <-
// All element are set with the value x.
(
storage.set_all_with x until (count - 1);
);
-
+
- all_default:BOOLEAN <-
(
storage.all_default (count - 1)
);
-
+
- slice (l1,up1:INTEGER) to (l2,up2:INTEGER) to (l3,up3:INTEGER) :SELF <-
// Create a new collection initialized with elements of
// range `low'..`up'. result has the same dynamic type
// as self collection.
( + result:SELF;
-
+
result := SELF.create (up1 - l1 + 1, up2 - l2 + 1, up3 - l3 + 1);
l1.to up1 do { line:INTEGER;
l2.to up2 do { column:INTEGER;
@@ -266,8 +266,8 @@ Section Public
};
};
};
- );
-
+ );
+
- set_slice (l1,up1:INTEGER) to (l2,up2:INTEGER) to (l3,up3:INTEGER) with element:V <-
// Set all the elements in the
// range [(l1,up1),(l2,up2),(l3,up3)] of
@@ -280,8 +280,8 @@ Section Public
};
};
};
- );
-
+ );
+
- swap (line1, column1, depth1:INTEGER) with (line2, column2, depth2:INTEGER) <-
( + tmp:V;
+ c3, c2x3, index1, index2:INTEGER;
@@ -293,25 +293,25 @@ Section Public
storage.put (storage.item index2) to index1;
storage.put tmp to index2;
);
-
+
//
// Looking and comparison:
//
-
+
- occurrences elt:V :INTEGER <-
(
storage.occurrences elt until (count - 1)
);
-
+
- fast_occurrences elt:V :INTEGER <-
(
storage.fast_occurrences elt until (count - 1)
);
-
+
//
// Resizing:
//
-
+
- resize (new_count1,new_count2,new_count3:INTEGER) <-
[ ...
-? { new_count1 > 0};
@@ -319,11 +319,11 @@ Section Public
-? { new_count3 > 0};
]
( + tmp:SELF;
-
+
tmp := SELF.create (new_count1, new_count2, new_count3);
// BSBS: It may be possible to avoid this creation when :
// BSBS: new `capacity' <= old `capacity'
-
+
line_maximum.downto 0 do { l:INTEGER;
column_maximum.downto 0 do { c:INTEGER;
depth_maximum.downto 0 do { d:INTEGER;
@@ -344,65 +344,65 @@ Section Public
+? { count3 = new_count3 };
+? { count = new_count1 * new_count2 * new_count3 };
];
-
+
//
// Looking and Searching:
//
-
+
- has x:V :BOOLEAN <-
// Look for `x' using `equal' for comparison.
( + result:BOOLEAN;
-
+
(count > 0).if {
result := storage.index_of x until (count-1) <= (count-1);
};
result
- );
-
+ );
+
- fast_has x:V :BOOLEAN <-
// Same as `has' but use `=' for comparison
( + result:BOOLEAN;
-
+
(count > 0).if {
result := storage.fast_index_of x until (count - 1) <= (count - 1);
};
result
- );
-
+ );
+
//
// Other features:
//
-
+
- replace_all old_value:V with new_value:V <-
(
storage.replace_all old_value with new_value until (count - 1);
);
-
-
+
+
- fast_replace_all old_value:V with new_value:V <-
(
storage.fast_replace_all old_value with new_value until (count - 1);
);
-
+
//
// Invariant.
//
-
+
// [ ...
// -? {count1 = upper1 + 1};
-// -? {count2 = upper2 + 1};
+// -? {count2 = upper2 + 1};
// -? {count3 = upper3 + 1};
// -? {count = count1 * count2 * count3};
// -? {count2x3 = count2 * count3};
// -? {capacity >= count};
// ];
-
+
/*
- '==' Right 60 other:SELF :BOOLEAN <-
(
+ result:BOOLEAN;
result := FALSE;
-
+
(other = Self).if {
result := TRUE;
}.elseif { upper1 != other.upper1} then {
@@ -411,7 +411,7 @@ Section Public
} else {
result := storage.memcmp (other.storage) until count;
};
-
+
result
);
*/
\ No newline at end of file
diff --git a/lib/standard/collection/hashed_dictionary.li b/lib/standard/collection/hashed_dictionary.li
index a20916d..c7a0ee9 100644
--- a/lib/standard/collection/hashed_dictionary.li
+++ b/lib/standard/collection/hashed_dictionary.li
@@ -29,7 +29,7 @@ Section Header
\Values of type `V' are stored using Keys of type `K'.";
// Efficient implementation of DICTIONARY using `hash_code' on keys.
-
+
Section Inherit
- parent_simple_dictionary:Expanded SIMPLE_DICTIONARY(V,K);
@@ -310,7 +310,7 @@ Section Public
- fast_remove k:K <-
( + h, idx:INTEGER;
+ node, previous_node:HASHED_DICTIONARY_NODE(V,K);
-
+
cache_user := -1;
h := k.hash_code;
idx := h % capacity;
@@ -320,10 +320,10 @@ Section Public
count := count - 1;
node := dispose_node node;
buckets.put node to idx;
- } else {
+ } else {
previous_node := node;
- node := node.next;
- {(node = NULL) || {node.key = k}}.until_do {
+ node := node.next;
+ {(node = NULL) || {node.key = k}}.until_do {
previous_node := node;
node := node.next;
};
@@ -369,7 +369,7 @@ Section Public
+ idx:INTEGER;
node := buckets.item idx;
- count.downto 1 do { i:INTEGER;
+ count.downto 1 do { i:INTEGER;
{node != NULL}.until_do {
idx := idx + 1;
? {idx < capacity};
@@ -582,7 +582,7 @@ Section Public
+? { is_empty };
+? { capacity >= medium_size };
];
-
+
//
// Invariant
//
diff --git a/lib/standard/collection/hashed_set.li b/lib/standard/collection/hashed_set.li
index 58bc7f4..58b7fdf 100644
--- a/lib/standard/collection/hashed_set.li
+++ b/lib/standard/collection/hashed_set.li
@@ -19,53 +19,53 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := HASHED_SET(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Definition of a mathematical set of hashable objects.";
-
+
// All common operations on mathematical sets are available.
-
+
Section Inherit
-
+
+ parent_set:Expanded SET(V);
-
+
Section Public
-
+
- default_size:INTEGER := 53;
// Minimum size for storage in number of items.
-
+
Section SET
-
+
+ buckets:NATIVE_ARRAY(HASHED_SET_NODE(V));
// The `buckets' storage area is the primary hash table of `capacity'
// elements. To search some element, the first access is done in
// `buckets' using the remainder of the division of the key `hash_code' by
// `capacity'. In order to try to avoid clashes, `capacity' is always a
// prime number (selected using HASH_TABLE_SIZE).
-
+
//
// Internal cache handling:
//
-
+
+ cache_user:INTEGER;
// The last user's external index in range [1 .. `count'] (see `item'
// and `valid_index' for example) may be saved in `cache_user' otherwise
// -1 to indicate that the cache is not active. When the cache is
// active, the corresponding index in `buckets' is save in
// `cache_buckets' and the corresponding node in `cache_node'.
-
+
+ cache_node:HASHED_SET_NODE(V);
// Meaningful only when `cache_user' is not -1.
-
+
+ cache_buckets:INTEGER;
// Meaningful only when `cache_user' is not -1.
-
+
Section Public
-
+
- create:SELF <-
// Create an empty set. Internal storage `capacity' of the set is
// initialized using the `Default_size' value. Then, tuning of needed
@@ -77,15 +77,15 @@ Section Public
result.make;
result
);
-
- - make <-
- (
+
+ - make <-
+ (
with_capacity default_size;
)
[ ...
+? { capacity = default_size };
];
-
+
- create_with_capacity sz:INTEGER :SELF <-
// Create an empty set using `medium_size' as an appropriate value
// to help initialization of `capacity'. Thus, this feature may be used
@@ -96,18 +96,18 @@ Section Public
// `capacity'. Keep in mind that the `capacity' tuning is done
// automatically according to usage.
( + result:SELF;
-
+
result := clone;
- result.with_capacity sz;
+ result.with_capacity sz;
result
);
-
+
- with_capacity medium_size:INTEGER <-
[ ...
-? {medium_size > 0};
]
( + new_capacity:INTEGER;
-
+
new_capacity := HASH_TABLE_SIZE.prime_number_ceiling medium_size;
buckets := NATIVE_ARRAY(HASHED_SET_NODE(V)).create new_capacity;
capacity := new_capacity;
@@ -118,29 +118,29 @@ Section Public
+? { is_empty };
+? { capacity >= medium_size };
];
-
+
//
// Counting:
//
-
+
+ capacity:INTEGER; // Of the `buckets' storage area.
-
+
+ count:INTEGER;
-
+
//
// Adding and removing:
//
-
+
- add e:V <-
// Add a new item to the set:the mathematical definition of
// adding in a set is followed.
( + h, idx:INTEGER;
+ node:HASHED_SET_NODE(V);
-
+
cache_user := -1;
h := e.hash_code;
idx := h % capacity;
- node := buckets.item idx;
+ node := buckets.item idx;
{(node = NULL) || {node.item == e}}.until_do {
node := node.next;
};
@@ -160,11 +160,11 @@ Section Public
// adding in a set is followed.
( + h, idx:INTEGER;
+ node:HASHED_SET_NODE(V);
-
+
cache_user := -1;
h := e.hash_code;
idx := h % capacity;
- node := buckets.item idx;
+ node := buckets.item idx;
{(node = NULL) || {node.item = e}}.until_do {
node := node.next;
};
@@ -176,15 +176,15 @@ Section Public
node := HASHED_SET_NODE(V).create e next (buckets.item idx);
buckets.put node to idx;
count := count + 1;
- };
- );
-
+ };
+ );
+
- remove e:V <-
// Remove item `e' from the set:the mathematical definition of
// removing from a set is followed.
( + h, idx:INTEGER;
+ node, previous_node:HASHED_SET_NODE(V);
-
+
cache_user := -1;
h := e.hash_code;
idx := h % capacity;
@@ -206,15 +206,15 @@ Section Public
previous_node.set_next (node.next);
};
};
- };
+ };
);
-
+
- fast_remove e:V <-
// Remove item `e' from the set:the mathematical definition of
// removing from a set is followed.
( + h, idx:INTEGER;
+ node, previous_node:HASHED_SET_NODE(V);
-
+
cache_user := -1;
h := e.hash_code;
idx := h % capacity;
@@ -236,9 +236,9 @@ Section Public
previous_node.set_next (node.next);
};
};
- };
+ };
);
-
+
- clear <-
// Empty the current set.
(
@@ -249,29 +249,29 @@ Section Public
[ ...
+? {capacity = Old capacity};
];
-
+
//
// Looking and searching:
//
-
+
- has e:V :BOOLEAN <-
// Is element `e' in the set?
( + idx:INTEGER;
+ node:HASHED_SET_NODE(V);
-
+
idx := e.hash_code % capacity;
node := buckets.item idx;
{(node = NULL) || {node.item == e}}.until_do {
node := node.next;
};
- node != NULL
+ node != NULL
);
-
+
- fast_has e:V :BOOLEAN <-
// Is element `e' in the set?
( + idx:INTEGER;
+ node:HASHED_SET_NODE(V);
-
+
idx := e.hash_code % capacity;
node := buckets.item idx;
{(node = NULL) || {node.item = e}}.until_do {
@@ -279,12 +279,12 @@ Section Public
};
node != NULL
);
-
+
- reference_at e:V :V <-
- ( + idx:INTEGER;
+ ( + idx:INTEGER;
+ node:HASHED_SET_NODE(V);
+ result:V;
-
+
idx := e.hash_code % capacity;
node := buckets.item idx;
{(node = NULL) || {node.item == e}}.until_do {
@@ -297,10 +297,10 @@ Section Public
);
- reference_at e:V with cmp:{(V,V); BOOLEAN} :V <-
- ( + idx:INTEGER;
+ ( + idx:INTEGER;
+ node:HASHED_SET_NODE(V);
+ result:V;
-
+
idx := e.hash_code % capacity;
node := buckets.item idx;
{(node = NULL) || {cmp.value (node.item,e)}}.until_do {
@@ -311,27 +311,27 @@ Section Public
};
result
);
-
+
//
// To provide iterating facilities:
//
-
+
- item i:INTEGER :V <-
// Return the item indexed by `index'.
- (
+ (
set_cache_user i;
cache_node.item
- );
-
+ );
+
//
// Mathematical operations:
//
-
+
- intersection other:SELF <-
// Make the intersection of the `self' set with `other'.
( + i,c:INTEGER;
+ node1, node2:HASHED_SET_NODE(V);
-
+
cache_user := -1;
i := capacity - 1;
c := count;
@@ -350,17 +350,17 @@ Section Public
(! other.has (node2.item)).if {
node1.set_next (node2.next);
count := count - 1;
- } else {
+ } else {
node1 := node2;
- };
+ };
node2 := node2.next;
c := c - 1;
};
};
i := i - 1;
- };
+ };
);
-
+
- copy other:SELF <-
// Copy 'other' into the current set
(
@@ -371,15 +371,15 @@ Section Public
} else {
clear;
};
-
+
lower.to (other.count) do { i:INTEGER;
add (other.item i);
};
);
-
+
- from_collection model:COLLECTION(V) <-
( + i, up:INTEGER;
-
+
with_capacity (model.count.max 1);
up := model.upper;
i := model.lower;
@@ -388,15 +388,15 @@ Section Public
i := i + 1;
};
);
-
-Section Private
-
+
+Section Private
+
- increase_capacity <-
// There is no more free slots:the set must grow.
( + i,idx, new_capacity:INTEGER;
+ old_buckets:NATIVE_ARRAY(HASHED_SET_NODE(V));
+ node1, node2:HASHED_SET_NODE(V);
-
+
new_capacity := HASH_TABLE_SIZE.prime_number_ceiling (capacity + 1);
old_buckets := buckets;
buckets := buckets.create new_capacity;
@@ -413,11 +413,11 @@ Section Private
};
i := i - 1;
};
- cache_user := -1;
+ cache_user := -1;
);
-
+
- set_cache_user index:INTEGER <-
- (
+ (
(index = cache_user + 1).if {
cache_user := index;
cache_node := cache_node.next;
@@ -440,16 +440,16 @@ Section Private
set_cache_user (cache_user + 1);
};
};
-
+
? { cache_user = index};
? { cache_buckets.in_range 0 to (capacity - 1)};
? { cache_node != NULL};
);
-
+
//
// Invariant.
//
-
+
// [
// -? {capacity > 0};
// -? {capacity >= count};
@@ -457,21 +457,21 @@ Section Private
// -? {(cache_user > 0) ->> {cache_node != NULL}};
// -? {(cache_user > 0) ->> {cache_buckets.in_range 0 to (capacity - 1)}}
// ];
-
- // -----------------OLD-----------------
-
+
+ // -----------------OLD-----------------
+
/*
-
-
-
+
+
+
- union other:SELF <-
// Make the union of the `self' set with `other'.
( + e:V;
+ old_count:INTEGER;
-
- ? {old_count := count;
+
+ ? {old_count := count;
other != NULL};
-
+
lower.to (other.count) do { i:INTEGER;
e := other.item i;
add e;
@@ -483,39 +483,39 @@ Section Private
// Make the union of the `self' set with `other'.
( + old_count:INTEGER;
+ e:V;
- ? {old_count := count;
+ ? {old_count := count;
other != NULL};
-
+
lower.to (other.count) do { i:INTEGER;
e := other.item i;
fast_add e;
};
? { count <= (old_count + other.count)};
);
-
-
+
+
- '+' Left 1 other:SELF :SELF <-
// Return the union of the `self' set with `other'.
(
+ result:SELF;
-
+
? { other != NULL};
-
+
result := twin ;
result.union other ;
-
+
? { result.count <= count + other.count};
? { (Self.is_subset_of result) && (other.is_subset_of result)};
-
+
result
);
-
-
-
+
+
+
- is_disjoint other:SELF :BOOLEAN <-
( + j:INTEGER;
+ result:BOOLEAN;
-
+
(other.count<count).if {
result := other.is_disjoint Self;
} else {
@@ -526,12 +526,12 @@ Section Private
result := (j=0);
};
result
- );
+ );
- fast_is_disjoint other:SELF :BOOLEAN <-
( + j:INTEGER;
+ result:BOOLEAN;
-
+
(other.count<count).if {
result := other.fast_is_disjoint Self;
} else {
@@ -543,63 +543,63 @@ Section Private
};
result
);
-
+
- '^' other:SELF :SELF <-
// Return the intersection of the `self' set with `other'.
(
+ result:SELF;
? {other != NULL};
-
+
result := twin;
result.intersection(other) ;
-
+
? { result.count <= other.count.min count};
? { (result.is_subset_of Self) && { result.is_subset_of other}};
);
-
+
- minus other:SELF <-
// Make the set `self' - `other'.
(
+ old_count:INTEGER;
-
+
? { other != NULL};
-
+
old_count:=count;
-
+
lower.to (other.count) do { i:INTEGER;
remove (other.item i);
};
-
+
? { count <= old count};
);
-
-
+
+
- '-' other:SELF :SELF <-
// Return the set `self' - `other'.
(
+ result:SELF;
-
+
? { other != NULL};
-
+
result := twin ;
result.minus other;
-
+
? { result.count <= count};
? { result.is_subset_of(Self)};
-
+
result
);
-
+
// Comparison:
-
+
- is_subset_of other:SELF :BOOLEAN <-
// Is the `self' set a subset of `other'?
(
+ i:INTEGER;
+ result:BOOLEAN;
-
+
? { other != NULL};
-
+
result := FALSE;
(Self = other).if {
result := TRUE;
@@ -612,21 +612,21 @@ Section Private
};
};
? { result ->> {count <= other.count}};
-
+
result
);
-
-
+
+
- is_disjoint_from other:SELF :BOOLEAN <-
// Is the `self' set disjoint from `other' ?
(
+ result:BOOLEAN;
+ i:INTEGER;
-
+
? { other != NULL};
-
+
result := FALSE;
-
+
( Self != other).if {
result := TRUE;
i := 1;
@@ -643,17 +643,17 @@ Section Private
};
};
? { result = (Self ^ other).is_empty };
-
+
result
);
-
-
+
+
- '==' Right 60 other:SELF :BOOLEAN <-
// Is the `self' set equal to `other'?
(
+ i:INTEGER;
+ result:BOOLEAN;
-
+
result := FALSE;
( Self = other ).if {
result := TRUE;
@@ -667,11 +667,11 @@ Section Private
};
//ensure then
//? { result = ((is_subset_of other) & (other.is_subset_of self))};
-
+
result
);
-
-
+
+
- fast_copy other:SELF <-
// Copy 'other' into the current set
@@ -683,17 +683,17 @@ Section Private
} else {
clear;
};
-
+
lower.to (other.count) do { i:INTEGER;
fast_add (other.item i);
};
);
-
-
+
+
// NONE
-
-
- - force e:V <-
+
+
+ - force e:V <-
// Add a new item to the set: the mathematical definition of
// adding in a set is followed.
( + h, idx: INTEGER;
@@ -710,7 +710,7 @@ Section Private
count := count + 1;
? {fast_has e};
);
-
+
- search e:V :V <-
// Is element `e' in the set?
( + idx:INTEGER;
@@ -727,7 +727,7 @@ Section Private
};
result
);
-
+
- get_if cmp:BLOCK with_hash h:INTEGER :V <-
// Is element `e' in the set?
( + idx:INTEGER;
@@ -761,10 +761,10 @@ Section Private
};
result
);
-
+
- fast_index_of elt:V :INTEGER <-
( + result:INTEGER;
-
+
result := upper;
{(result<lower) || {item result = elt}}.until_do {
result := result - 1;
diff --git a/lib/standard/collection/iterator.li b/lib/standard/collection/iterator.li
index f85c5cf..9bbd279 100644
--- a/lib/standard/collection/iterator.li
+++ b/lib/standard/collection/iterator.li
@@ -81,8 +81,8 @@ Section Public
- make t:TRAVERSABLE(V) increment inc:INTEGER :SELF <-
make t index (t.lower) increment inc;
- - make t:TRAVERSABLE(V) index i:INTEGER increment inc:INTEGER :SELF <-
- [
+ - make t:TRAVERSABLE(V) index i:INTEGER increment inc:INTEGER :SELF <-
+ [
-? {inc != 0};
-? {t != NULL};
-? {t.valid_index i};
@@ -91,7 +91,7 @@ Section Public
increment := inc;
traversable := t;
index := i;
- Self
+ Self
);
- make t:TRAVERSABLE(V) index i:INTEGER :SELF <-
diff --git a/lib/standard/collection/linked2_list.li b/lib/standard/collection/linked2_list.li
index 9307f4c..0e99725 100644
--- a/lib/standard/collection/linked2_list.li
+++ b/lib/standard/collection/linked2_list.li
@@ -19,48 +19,48 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED2_LIST(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Two way linked list with internal automatic memorization \
\of the last access .";
-
+
Section Inherit
-
+
+ parent_linked_collection:Expanded LINKED_COLLECTION(V);
-
+
Section LINKED2_LIST
-
+
+ first_link:LINK2(V);
// NULL when empty or gives access to the first element.
-
+
+ last_link:LINK2(V);
// NULL when empty or gives access to the last element.
-
- + mem_idx:INTEGER;
-
+
+ + mem_idx:INTEGER;
+
+ mem_lnk:LINK2(V);
// To speed up accessing, `mem_idx' and `mem_lnk' is the
// memory of the last access done. For example, after
// item(1), `mem_idx' is 1 and `mem_lnk' is `first_link'.
// When list is empty, `first_link' is NULL as well as
// `mem_lnk' and `mem_idx' is 0;
-
+
Section Public
-
+
- create:SELF <-
// Make an empty list;
- (
+ (
SELF.clone
);
-
+
- is_empty:BOOLEAN <- first_link = NULL;
-
+
- add_first element:V <-
- (
+ (
(first_link = NULL).if {
first_link := LINK2(V).create element previous NULL next NULL;
last_link := first_link;
@@ -77,9 +77,9 @@ Section Public
[ ...
+? { upper = 1 + Old upper };
];
-
+
- add_last element:V <-
- (
+ (
(first_link = NULL).if {
first_link := LINK2(V).create element previous NULL next NULL;
last_link := first_link;
@@ -92,10 +92,10 @@ Section Public
upper := upper + 1;
};
);
-
+
- add element:V to index:INTEGER <-
( + link:LINK2(V);
-
+
(index = 1).if {
add_first element;
}.elseif {index = upper + 1} then {
@@ -108,18 +108,18 @@ Section Public
link.next.set_previous link;
mem_lnk.set_next link;
upper := upper + 1;
- };
+ };
);
-
+
- remove_first <-
- (
+ (
(upper = 1).if {
- first_link := NULL;
+ first_link := NULL;
last_link := NULL;
mem_lnk := NULL;
mem_idx := 0;
upper := 0;
- } else {
+ } else {
first_link := first_link.next;
first_link.set_previous NULL;
upper := upper - 1;
@@ -128,13 +128,13 @@ Section Public
} else {
mem_lnk := first_link;
mem_idx := 1;
- };
+ };
};
);
-
+
- remove index:INTEGER <-
( + link:LINK2(V);
-
+
(index = 1).if {
remove_first;
}.elseif { index = upper} then {
@@ -149,11 +149,11 @@ Section Public
upper := upper - 1;
};
);
-
+
- first:V <- first_link.item;
-
+
- last:V <- last_link.item;
-
+
- item index:INTEGER :V <-
(
(index != mem_idx).if {
@@ -161,33 +161,33 @@ Section Public
};
mem_lnk.item
);
-
+
- put element:V to index:INTEGER <-
- (
+ (
(index != mem_idx).if {
go_item index;
};
- mem_lnk.set_item element;
+ mem_lnk.set_item element;
);
-
+
- count:INTEGER <- upper;
-
+
- set_all_with v:V <-
- (
+ (
(first_link != NULL).if {
first_link.set_all_with v;
- };
+ };
);
-
+
- copy other:SELF <-
(
from_collection other;
);
-
+
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <-
( + result:BOOLEAN;
+ lnk1, lnk2:LINK2(V);
-
+
(Self = other).if {
result := TRUE;
}.elseif {upper = other.upper} then {
@@ -199,15 +199,15 @@ Section Public
lnk1 := lnk1.next;
lnk2 := lnk2.next;
};
- };
+ };
result
);
-
+
- is_equal_map other:SELF :BOOLEAN <-
( + result:BOOLEAN;
+ lnk1, lnk2:LINK2(V);
+ safe_equal:SAFE_EQUAL(V);
-
+
( Self = other ).if {
result := TRUE;
}.elseif {upper = other.upper} then {
@@ -219,27 +219,27 @@ Section Public
lnk1 := lnk1.next;
lnk2 := lnk2.next;
};
- };
+ };
result
);
-
+
- index_of x:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
+ safe_equal:SAFE_EQUAL(V);
-
+
result := start_index;
{(result > upper) || {safe_equal.test x with (item result)}}.until_do {
result := result + 1;
- };
+ };
result
);
-
+
- reverse_index_of element:V start start_index:INTEGER :INTEGER <-
- ( + safe_equal:SAFE_EQUAL(V);
+ ( + safe_equal:SAFE_EQUAL(V);
+ temporary_idx:INTEGER;
+ temporary_lnk:LINK2(V);
+ result:INTEGER;
-
+
(start_index != mem_idx).if {
go_item start_index;
};
@@ -260,25 +260,25 @@ Section Public
- fast_index_of x:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
+ u:INTEGER;
-
+
result := lower;
u := upper;
{(result > u) || {x = item result}}.until_do {
result := result + 1;
};
result
- );
+ );
- fast_reverse_index_of element:V start start_index:INTEGER :INTEGER <-
( + temporary_idx:INTEGER;
+ temporary_lnk:LINK2(V);
+ result:INTEGER;
-
+
(start_index != mem_idx).if {
go_item start_index;
};
temporary_idx := mem_idx;
- temporary_lnk := mem_lnk;
+ temporary_lnk := mem_lnk;
{(temporary_idx < lower) || {element = temporary_lnk.item}}.until_do {
temporary_idx := temporary_idx - 1;
temporary_lnk := temporary_lnk.previous;
@@ -289,7 +289,7 @@ Section Public
mem_lnk := temporary_lnk;
};
);
-
+
- clear <-
(
(first_link != NULL).if {
@@ -303,10 +303,10 @@ Section Public
[ ...
+? {upper = 0};
];
-
+
- from_collection model:COLLECTION(V) <-
( + lnk:LINK2(V);
-
+
(first_link = NULL).if {
(model.lower).to (model.upper) do { i:INTEGER;
add_last (model.item i);
@@ -335,14 +335,14 @@ Section Public
upper := i;
last_link := mem_lnk;
};
- };
+ };
);
-
+
- slice low:INTEGER to up:INTEGER :SELF <-
( + lnk:LINK2(V);
+ result:SELF;
- result := SELF.create;
+ result := SELF.create;
(mem_idx != low).if {
go_item low;
};
@@ -353,26 +353,26 @@ Section Public
};
result
);
-
+
- occurrences element:V :INTEGER <-
( + lnk:LINK2(V);
+ safe_equal:SAFE_EQUAL(V);
+ result:INTEGER;
-
+
lnk := first_link;
{lnk = NULL}.until_do {
(safe_equal.test element with (lnk.item)).if {
result := result + 1;
};
lnk := lnk.next;
- };
+ };
result
);
-
+
- fast_occurrences element:V :INTEGER <-
( + lnk:LINK2(V);
+ result:INTEGER;
-
+
lnk := first_link;
{lnk = NULL}.until_do {
(element = lnk.item).if {
@@ -382,21 +382,21 @@ Section Public
};
result
);
-
+
- force element:V to index:INTEGER <-
( + v:V;
-
+
{index <= upper}.until_do {
add_last v;
};
put element to index;
);
-
+
- all_default:BOOLEAN <-
( + l:LINK2(V);
+ d:V;
+ result:BOOLEAN;
-
+
result := TRUE;
l := first_link;
{(! result) || {l = NULL}}.until_do {
@@ -405,12 +405,12 @@ Section Public
result := d.is_default;
};
l := l.next;
- };
+ };
result
);
-
+
- remove_last <-
- (
+ (
(upper = 1).if {
first_link := NULL;
last_link := NULL;
@@ -426,37 +426,37 @@ Section Public
mem_lnk := first_link;
};
upper := upper - 1;
- };
+ };
);
-
+
- replace_all old_value:V with new_value:V <-
( + safe_equal:SAFE_EQUAL(V);
-
+
lower.to upper do { i:INTEGER;
(safe_equal.test (item i) with old_value).if {
put new_value to i;
};
- };
+ };
);
-
+
- fast_replace_all old_value:V with new_value:V <-
- (
+ (
lower.to upper do { i:INTEGER;
(item i = old_value).if {
put new_value to i;
};
- };
+ };
);
-
+
- reverse <-
- ( + temp:V;
- + low:LINK2(V);
+ ( + temp:V;
+ + low:LINK2(V);
+ high:LINK2(V);
+ i:INTEGER;
-
+
low := first_link;
high := last_link;
-
+
i := count / 2;
? {(i > 0) -> ((low != NULL) & (high != NULL))};
? {(i > 0) -> ((low != high) & (low.previous != high))};
@@ -467,11 +467,11 @@ Section Public
low := low.next;
high := high.previous;
i := i - 1;
- };
+ };
);
-
+
Section Private
-
+
- go_item index:INTEGER <-
[ ...
-? { valid_index index };
@@ -512,15 +512,15 @@ Section Private
+? { mem_idx = index };
+? { mem_lnk != NULL };
];
-
+
//
// Invariant.
//
-
+
// [ ...
// "Empty status." -? {(first_link = NULL) ->
// ((last_link = NULL) & (upper = 0) & (mem_idx = 0) & (mem_lnk = NULL))};
-
+
// "Not empty status." -? {(first_link != NULL) ->
// ((last_link != NULL) & (upper > 0) & (mem_idx > 0) & (mem_lnk != NULL))};
// ];
diff --git a/lib/standard/collection/linked_list.li b/lib/standard/collection/linked_list.li
index be74681..677fd77 100644
--- a/lib/standard/collection/linked_list.li
+++ b/lib/standard/collection/linked_list.li
@@ -19,59 +19,59 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED_LIST(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="One way linked list with internal automatic memorization of the last access.";
-
- // One way linked list implementation with internal automatic cached memorization
- // of the last access. Because of the last access memory cache, the traversal of a
- // LINKED_LIST from the `lower' index to the `upper' index using `item' is quite
+
+ // One way linked list implementation with internal automatic cached memorization
+ // of the last access. Because of the last access memory cache, the traversal of a
+ // LINKED_LIST from the `lower' index to the `upper' index using `item' is quite
// efficient. As one can expect, adding element using `add_first' or
- // `add_last' is really efficient too, actually, the total number of elements
- // (i.e. `count') as well as a reference to the last cell is also cached automatically.
- // Keep in mind that LINKED_LIST uses a one way linked storage from `lower' to `upper',
- // so traversing a LINKED_LIST from `upper' to `lower' will be extremely time consumming
+ // `add_last' is really efficient too, actually, the total number of elements
+ // (i.e. `count') as well as a reference to the last cell is also cached automatically.
+ // Keep in mind that LINKED_LIST uses a one way linked storage from `lower' to `upper',
+ // so traversing a LINKED_LIST from `upper' to `lower' will be extremely time consumming
// (also consider LINKED2_LIST).
-
+
Section Inherit
-
+
+ parent_linked_collection:Expanded LINKED_COLLECTION(V);
-
+
Section LINKED_LIST
-
+
+ first_link:LINKED_LIST_NODE(V);
// NULL when empty or gives access to the first element.
-
+
+ last_link:LINKED_LIST_NODE(V);
// NULL when empty or gives access to the last element.
-
- + mem_idx:INTEGER;
+
+ + mem_idx:INTEGER;
+ mem_lnk:LINKED_LIST_NODE(V);
// To speed up accessing, `mem_idx' and `mem_lnk' is the
// memory of the last access done. For example, after
// item(1), `mem_idx' is 1 and `mem_lnk' is `first_link'.
// When list is empty, `first_link' is NULL as well as
// `mem_lnk' and `mem_idx' is 0;
-
+
Section Public
-
+
- create:SELF <-
// Make an empty list;
- (
- SELF.clone
+ (
+ SELF.clone
)
[ ...
+? {count = 0};
];
-
+
- is_empty:BOOLEAN <- first_link = NULL;
-
+
- add_first element:V <-
- (
+ (
(first_link = NULL).if {
first_link := LINKED_LIST_NODE(V).create element next NULL;
upper := 1;
@@ -82,12 +82,12 @@ Section Public
first_link := LINKED_LIST_NODE(V).create element next first_link;
upper := upper + 1;
mem_idx := mem_idx + 1;
- };
+ };
);
-
+
- add_last element:V <-
( + lnk:LINKED_LIST_NODE(V);
-
+
(first_link = NULL).if {
first_link := LINKED_LIST_NODE(V).create element next NULL;
upper := 1;
@@ -101,7 +101,7 @@ Section Public
last_link := lnk;
};
);
-
+
- add element:V to index:INTEGER <-
( + link:LINKED_LIST_NODE(V);
@@ -118,11 +118,11 @@ Section Public
upper := upper + 1;
};
);
-
+
- remove_first <-
- (
+ (
(upper = 1).if {
- first_link := NULL;
+ first_link := NULL;
last_link := NULL;
mem_lnk := NULL;
mem_idx := 0;
@@ -135,12 +135,12 @@ Section Public
mem_idx := mem_idx - 1;
};
upper := upper - 1;
- };
+ };
);
-
+
- remove index:INTEGER <-
- ( + link:LINKED_LIST_NODE(V);
-
+ ( + link:LINKED_LIST_NODE(V);
+
(index = 1).if {
remove_first;
}.elseif {index = upper} then {
@@ -152,13 +152,13 @@ Section Public
link := mem_lnk.next;
mem_lnk.set_next (link.next);
upper := upper - 1;
- };
+ };
);
-
+
- first:V <- first_link.item;
-
+
- last:V <- last_link.item;
-
+
- item i:INTEGER :V <-
(
(i != mem_idx).if {
@@ -166,33 +166,33 @@ Section Public
};
mem_lnk.item
);
-
+
- put element:V to i:INTEGER <-
- (
+ (
(i != mem_idx).if {
go_item i;
};
mem_lnk.set_item element;
);
-
+
- count:INTEGER <- upper;
-
+
- set_all_with v:V <-
- (
+ (
(first_link != NULL).if {
first_link.set_all_with v;
- };
+ };
);
-
+
- copy other:SELF <-
(
from_collection other;
);
-
+
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <-
( + result:BOOLEAN;
+ lnk1, lnk2:LINKED_LIST_NODE(V);
-
+
(Self = other).if {
result := TRUE;
}.elseif {upper = other.upper} then {
@@ -204,15 +204,15 @@ Section Public
lnk1 := lnk1.next;
lnk2 := lnk2.next;
};
- };
+ };
result
);
-
+
- is_equal_map other:SELF :BOOLEAN <-
( + result:BOOLEAN;
- + lnk1, lnk2:LINKED_LIST_NODE(V);
+ + lnk1, lnk2:LINKED_LIST_NODE(V);
+ safe_equal:SAFE_EQUAL(V);
-
+
( Self = other).if {
result := TRUE;
}.elseif {upper = other.upper} then {
@@ -224,24 +224,24 @@ Section Public
lnk1 := lnk1.next;
lnk2 := lnk2.next;
};
- };
+ };
result
);
-
+
- index_of element:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
//+ safe_equal:SAFE_EQUAL(V);
-
+
result := start_index;
//{(result > upper) || {safe_equal.test x with (item result)}}.until_do {
{(result > upper) || {element == item result}}.until_do {
result := result + 1;
- };
+ };
result
);
- reverse_index_of element:V start start_index:INTEGER :INTEGER <-
- ( + safe_equal: SAFE_EQUAL(V);
+ ( + safe_equal: SAFE_EQUAL(V);
+ temporary_idx, new_mem_idx:INTEGER;
+ temporary_lnk, new_mem_lnk:LINKED_LIST_NODE(V);
+ result:INTEGER;
@@ -265,11 +265,11 @@ Section Public
};
result
);
-
+
- fast_index_of element:V start start_index:INTEGER :INTEGER <-
( + u:INTEGER;
+ result:INTEGER;
-
+
result := start_index;
u := upper;
{(result > u) || {element = item result}}.until_do {
@@ -277,9 +277,9 @@ Section Public
};
result
);
-
+
- fast_reverse_index_of element:V start start_index:INTEGER :INTEGER <-
- ( + safe_equal: SAFE_EQUAL(V);
+ ( + safe_equal: SAFE_EQUAL(V);
+ temporary_idx, new_mem_idx:INTEGER;
+ temporary_lnk, new_mem_lnk:LINKED_LIST_NODE(V);
+ result:INTEGER;
@@ -303,7 +303,7 @@ Section Public
};
result
);
-
+
- clear <-
(
(first_link != NULL).if {
@@ -315,12 +315,12 @@ Section Public
};
)
[ ...
- +? {upper = 0};
+ +? {upper = 0};
];
-
+
- from_collection model:COLLECTION(V) <-
( + lnk:LINKED_LIST_NODE(V);
-
+
(first_link = NULL).if {
(model.lower).to (model.upper) do { i:INTEGER;
add_last (model.item i);
@@ -336,7 +336,7 @@ Section Public
};
};
(lnk = first_link).if {
- ? { model.count = 0 };
+ ? { model.count = 0 };
clear;
}.elseif { lnk != NULL } then {
+ i:INTEGER;
@@ -344,19 +344,19 @@ Section Public
(mem_idx != i).if {
go_item i;
};
- ? { lnk = mem_lnk.next };
+ ? { lnk = mem_lnk.next };
mem_lnk.set_next NULL;
upper := i;
last_link := mem_lnk;
};
- };
+ };
);
-
+
- slice low:INTEGER to up:INTEGER :SELF <-
( + result:SELF;
+ lnk:LINKED_LIST_NODE(V);
-
- result := SELF.create;
+
+ result := SELF.create;
(mem_idx != low).if {
go_item low;
};
@@ -365,29 +365,29 @@ Section Public
result.add_last (lnk.item);
lnk := lnk.next;
};
-
+
result
);
-
+
- occurrences element:V :INTEGER <-
( + lnk:LINKED_LIST_NODE(V);
+ result:INTEGER;
+ safe_equal:SAFE_EQUAL(V);
-
+
lnk := first_link;
{lnk = NULL}.until_do {
(safe_equal.test element with (lnk.item)).if {
result := result + 1;
};
lnk := lnk.next;
- };
+ };
result
);
-
+
- fast_occurrences element:V :INTEGER <-
( + lnk:LINKED_LIST_NODE(V);
+ result:INTEGER;
-
+
lnk := first_link;
{lnk = NULL}.until_do {
(element = lnk.item).if {
@@ -397,21 +397,21 @@ Section Public
};
result
);
-
+
- force element:V to index:INTEGER <-
( + v:V;
-
+
{index <= upper}.until_do {
add_last v;
};
put element to index;
);
-
+
- all_default:BOOLEAN <-
( + result:BOOLEAN;
+ l:LINKED_LIST_NODE(V);
+ d:V;
-
+
result := TRUE;
l := first_link;
{(! result) || {l = NULL}}.until_do {
@@ -421,12 +421,12 @@ Section Public
};
l := l.next;
};
-
+
result
);
-
+
- remove_last <-
- (
+ (
(upper = 1).if {
first_link := NULL;
last_link := NULL;
@@ -440,21 +440,21 @@ Section Public
upper := upper - 1;
last_link := mem_lnk;
last_link.set_next NULL;
- };
+ };
);
-
+
- replace_all old_value:V with new_value:V <-
( + safe_equal:SAFE_EQUAL(V);
-
+
lower.to upper do { i:INTEGER;
(safe_equal.test (item i) with old_value).if {
put new_value to i;
};
- };
+ };
);
-
+
- fast_replace_all old_value:V with new_value:V <-
- (
+ (
lower.to upper do { i:INTEGER;
(item i = old_value).if {
put new_value to i;
@@ -464,8 +464,8 @@ Section Public
- reverse <-
( + prev, lnk, next:LINKED_LIST_NODE(V);
-
- lnk := first_link;
+
+ lnk := first_link;
{lnk = NULL}.until_do {
next := lnk.next;
lnk.set_next prev;
@@ -478,17 +478,17 @@ Section Public
mem_idx := count - mem_idx + 1;
};
);
-
+
Section Private
-
+
- go_item i:INTEGER <-
- [
+ [
-? { valid_index i};
-? { mem_idx != i};
-? { mem_idx > 0};
-? { mem_lnk != NULL};
- ]
- (
+ ]
+ (
(mem_idx > i).if {
mem_idx := 1;
mem_lnk := first_link;
@@ -502,15 +502,15 @@ Section Private
+? {mem_idx = i};
+? {mem_lnk != NULL};
];
-
+
//
// Invariant
//
-
+
// [ ...
-// "Empty status." -? {(first_link = NULL) ->>
+// "Empty status." -? {(first_link = NULL) ->>
// {(last_link = NULL) & (upper = 0) & (mem_idx = 0) & (mem_lnk = NULL)}};
-// "Not empty status." -? {(first_link != NULL) ->>
-// {(last_link != NULL) & (upper > 0) & (mem_idx > 0) & (mem_lnk != NULL)}};
+// "Not empty status." -? {(first_link != NULL) ->>
+// {(last_link != NULL) & (upper > 0) & (mem_idx > 0) & (mem_lnk != NULL)}};
// ];
diff --git a/lib/standard/collection/linked_xor_list.li b/lib/standard/collection/linked_xor_list.li
index 6651a5c..204151c 100644
--- a/lib/standard/collection/linked_xor_list.li
+++ b/lib/standard/collection/linked_xor_list.li
@@ -19,55 +19,55 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LINKED_XOR_LIST(V);
- copyright := "2003-2007 Benoit Sonntag";
-
+
- comment := "One Xor way linked list with internal automatic memorization \
\of the last access .";
-
+
Section Inherit
-
+
+ parent_linked_collection:Expanded LINKED_COLLECTION(V);
-
+
Section LINKED2_LIST
-
+
+ first_link:LINKED_XOR_NODE(V);
// NULL when empty or gives access to the first element.
-
+
+ last_link:LINKED_XOR_NODE(V);
// NULL when empty or gives access to the last element.
-
- + mem_idx:INTEGER;
-
+
+ + mem_idx:INTEGER;
+
+ mem_lnk:LINKED_XOR_NODE(V);
+ mem_lnk_prev:LINKED_XOR_NODE(V);
- + mem_lnk_next:LINKED_XOR_NODE(V);
+ + mem_lnk_next:LINKED_XOR_NODE(V);
// To speed up accessing, `mem_idx' and `mem_lnk' is the
// memory of the last access done. For example, after
// item(1), `mem_idx' is 1 and `mem_lnk' is `first_link'.
// When list is empty, `first_link' is NULL as well as
// `mem_lnk' and `mem_idx' is 0;
-
+
Section Public
-
+
- create:SELF <-
// Make an empty list;
- (
+ (
SELF.clone
);
-
+
- is_empty:BOOLEAN <- first_link = NULL;
-
+
- add_first element:V <-
( + new:LINKED_XOR_NODE(V);
(first_link = NULL).if {
first_link := LINKED_XOR_NODE(V).create element previous NULL next NULL;
last_link := first_link;
upper := mem_idx := 1;
- mem_lnk := first_link;
+ mem_lnk := first_link;
} else {
new := LINKED_XOR_NODE(V).create element previous NULL next first_link;
first_link.set_link new and (first_link.next NULL);
@@ -82,7 +82,7 @@ Section Public
[ ...
+? { upper = 1 + Old upper };
];
-
+
- add_last element:V <-
( + new:LINKED_XOR_NODE(V);
(first_link = NULL).if {
@@ -101,10 +101,10 @@ Section Public
upper := upper + 1;
};
);
-
+
- add element:V to index:INTEGER <-
( + link:LINKED_XOR_NODE(V);
-
+
(index = 1).if {
add_first element;
}.elseif {index = upper + 1} then {
@@ -118,18 +118,18 @@ Section Public
mem_lnk.set_link mem_lnk_prev and link;
mem_lnk_next := link;
upper := upper + 1;
- };
+ };
);
-
+
- remove_first <-
( + next,next_next:LINKED_XOR_NODE;
(upper = 1).if {
- first_link := NULL;
+ first_link := NULL;
last_link := NULL;
mem_lnk := mem_lnk_prev := mem_lnk_next := NULL;
mem_idx := 0;
upper := 0;
- } else {
+ } else {
next := first_link.next NULL;
next_next := next.next first_link;
next.set_link NULL and next_next;
@@ -144,13 +144,13 @@ Section Public
mem_lnk := first_link;
mem_lnk_next := next_next;
mem_idx := 1;
- };
+ };
};
);
-
+
- remove index:INTEGER <-
( + next_next:LINKED_XOR_NODE(V);
-
+
(index = 1).if {
remove_first;
}.elseif { index = upper} then {
@@ -167,11 +167,11 @@ Section Public
upper := upper - 1;
};
);
-
+
- first:V <- first_link.item;
-
+
- last:V <- last_link.item;
-
+
- item index:INTEGER :V <-
(
(index != mem_idx).if {
@@ -179,39 +179,39 @@ Section Public
};
mem_lnk.item
);
-
+
- put element:V to index:INTEGER <-
- (
+ (
(index != mem_idx).if {
go_item index;
};
- mem_lnk.set_item element;
+ mem_lnk.set_item element;
);
-
+
- count:INTEGER <- upper;
-
+
- set_all_with v:V <-
- (
+ (
not_yet_implemented;
-
+
(first_link != NULL).if {
first_link.set_all_with v;
- };
+ };
);
-
+
- copy other:SELF <-
(
not_yet_implemented;
-
+
from_collection other;
);
-
+
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <-
( + result:BOOLEAN;
+ lnk1, lnk2:LINKED_XOR_NODE(V);
-
+
not_yet_implemented;
-
+
(Self = other).if {
result := TRUE;
}.elseif {upper = other.upper} then {
@@ -223,17 +223,17 @@ Section Public
lnk1 := lnk1.next;
lnk2 := lnk2.next;
};
- };
+ };
result
);
-
+
- is_equal_map other:SELF :BOOLEAN <-
( + result:BOOLEAN;
+ lnk1, lnk2:LINKED_XOR_NODE(V);
+ safe_equal:SAFE_EQUAL(V);
-
+
not_yet_implemented;
-
+
( Self = other ).if {
result := TRUE;
}.elseif {upper = other.upper} then {
@@ -245,31 +245,31 @@ Section Public
lnk1 := lnk1.next;
lnk2 := lnk2.next;
};
- };
+ };
result
);
-
+
- index_of x:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
+ safe_equal:SAFE_EQUAL(V);
-
+
not_yet_implemented;
-
+
result := start_index;
{(result > upper) || {safe_equal.test x with (item result)}}.until_do {
result := result + 1;
- };
+ };
result
);
-
+
- reverse_index_of element:V start start_index:INTEGER :INTEGER <-
- ( + safe_equal:SAFE_EQUAL(V);
+ ( + safe_equal:SAFE_EQUAL(V);
+ temporary_idx:INTEGER;
+ temporary_lnk:LINKED_XOR_NODE(V);
+ result:INTEGER;
-
+
not_yet_implemented;
-
+
(start_index != mem_idx).if {
go_item start_index;
};
@@ -290,29 +290,29 @@ Section Public
- fast_index_of x:V start start_index:INTEGER :INTEGER <-
( + result:INTEGER;
+ u:INTEGER;
-
+
not_yet_implemented;
-
+
result := lower;
u := upper;
{(result > u) || {x = item result}}.until_do {
result := result + 1;
};
result
- );
+ );
- fast_reverse_index_of element:V start start_index:INTEGER :INTEGER <-
( + temporary_idx:INTEGER;
+ temporary_lnk:LINKED_XOR_NODE(V);
+ result:INTEGER;
-
+
not_yet_implemented;
-
+
(start_index != mem_idx).if {
go_item start_index;
};
temporary_idx := mem_idx;
- temporary_lnk := mem_lnk;
+ temporary_lnk := mem_lnk;
{(temporary_idx < lower) || {element = temporary_lnk.item}}.until_do {
temporary_idx := temporary_idx - 1;
temporary_lnk := temporary_lnk.previous;
@@ -323,12 +323,12 @@ Section Public
mem_lnk := temporary_lnk;
};
);
-
+
- clear <-
(
-
+
not_yet_implemented;
-
+
(first_link != NULL).if {
first_link := NULL;
mem_idx := 0;
@@ -340,12 +340,12 @@ Section Public
[ ...
+? {upper = 0};
];
-
+
- from_collection model:COLLECTION(V) <-
( + lnk:LINKED_XOR_NODE(V);
-
+
not_yet_implemented;
-
+
(first_link = NULL).if {
(model.lower).to (model.upper) do { i:INTEGER;
add_last (model.item i);
@@ -374,16 +374,16 @@ Section Public
upper := i;
last_link := mem_lnk;
};
- };
+ };
);
-
+
- slice low:INTEGER to up:INTEGER :SELF <-
( + lnk:LINKED_XOR_NODE(V);
+ result:SELF;
-
+
not_yet_implemented;
-
- result := SELF.create;
+
+ result := SELF.create;
(mem_idx != low).if {
go_item low;
};
@@ -394,30 +394,30 @@ Section Public
};
result
);
-
+
- occurrences element:V :INTEGER <-
( + lnk:LINKED_XOR_NODE(V);
+ safe_equal:SAFE_EQUAL(V);
+ result:INTEGER;
-
+
not_yet_implemented;
-
+
lnk := first_link;
{lnk = NULL}.until_do {
(safe_equal.test element with (lnk.item)).if {
result := result + 1;
};
lnk := lnk.next;
- };
+ };
result
);
-
+
- fast_occurrences element:V :INTEGER <-
( + lnk:LINKED_XOR_NODE(V);
+ result:INTEGER;
-
+
not_yet_implemented;
-
+
lnk := first_link;
{lnk = NULL}.until_do {
(element = lnk.item).if {
@@ -427,25 +427,25 @@ Section Public
};
result
);
-
+
- force element:V to index:INTEGER <-
( + v:V;
-
+
not_yet_implemented;
-
+
{index <= upper}.until_do {
add_last v;
};
put element to index;
);
-
+
- all_default:BOOLEAN <-
( + l:LINKED_XOR_NODE(V);
+ d:V;
+ result:BOOLEAN;
-
+
not_yet_implemented;
-
+
result := TRUE;
l := first_link;
{(! result) || {l = NULL}}.until_do {
@@ -454,12 +454,12 @@ Section Public
result := d.is_default;
};
l := l.next;
- };
+ };
result
);
-
+
- remove_last <-
- (
+ (
(upper = 1).if {
first_link := NULL;
last_link := NULL;
@@ -469,7 +469,7 @@ Section Public
} else {
link := last_link.previous NULL;
link.set_link (link.previous last_link) and NULL;
- last_link := link;
+ last_link := link;
(mem_idx = upper).if {
mem_idx := 1;
mem_lnk := first_link;
@@ -477,44 +477,44 @@ Section Public
mem_lnk_next := mem_lnk.next NULL;
};
upper := upper - 1;
- };
+ };
);
-
+
- replace_all old_value:V with new_value:V <-
( + safe_equal:SAFE_EQUAL(V);
-
+
not_yet_implemented;
-
+
lower.to upper do { i:INTEGER;
(safe_equal.test (item i) with old_value).if {
put new_value to i;
};
- };
+ };
);
-
+
- fast_replace_all old_value:V with new_value:V <-
- (
-
+ (
+
not_yet_implemented;
-
+
lower.to upper do { i:INTEGER;
(item i = old_value).if {
put new_value to i;
};
- };
+ };
);
-
+
- reverse <-
- ( + temp:V;
- + low:LINKED_XOR_NODE(V);
+ ( + temp:V;
+ + low:LINKED_XOR_NODE(V);
+ high:LINKED_XOR_NODE(V);
+ i:INTEGER;
-
+
not_yet_implemented;
-
+
low := first_link;
high := last_link;
-
+
i := count / 2;
? {(i > 0) -> ((low != NULL) & (high != NULL))};
? {(i > 0) -> ((low != high) & (low.previous != high))};
@@ -525,11 +525,11 @@ Section Public
low := low.next;
high := high.previous;
i := i - 1;
- };
+ };
);
-
+
Section Private
-
+
- go_item index:INTEGER <-
[ ...
-? { valid_index index };
@@ -562,7 +562,7 @@ Section Private
{index = mem_idx}.until_do {
mem_lnk_next := mem_lnk;
mem_lnk := mem_lnk_prev;
- mem_lnk_prev := mem_lnk.previous mem_lnk_next;
+ mem_lnk_prev := mem_lnk.previous mem_lnk_next;
mem_idx := mem_idx - 1;
};
} else {
@@ -573,7 +573,7 @@ Section Private
{index = mem_idx}.until_do {
mem_lnk_prev := mem_lnk;
mem_lnk := mem_lnk_next;
- mem_lnk_next := mem_lnk.next mem_lnk_prev;
+ mem_lnk_next := mem_lnk.next mem_lnk_prev;
mem_idx := mem_idx + 1;
};
};
@@ -582,15 +582,15 @@ Section Private
+? { mem_idx = index };
+? { mem_lnk != NULL };
];
-
+
//
// Invariant.
//
-
+
// [ ...
// "Empty status." -? {(first_link = NULL) ->
// ((last_link = NULL) & (upper = 0) & (mem_idx = 0) & (mem_lnk = NULL))};
-
+
// "Not empty status." -? {(first_link != NULL) ->
// ((last_link != NULL) & (upper > 0) & (mem_idx > 0) & (mem_lnk != NULL))};
// ];
diff --git a/lib/standard/file_system/directory.li b/lib/standard/file_system/directory.li
index e715a6b..fbf80fa 100644
--- a/lib/standard/file_system/directory.li
+++ b/lib/standard/file_system/directory.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DIRECTORY;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Basic Directory management";
-
+
Section Inherit
-
+
- parent_entry:ENTRY := ENTRY;
-
+
Section DIRECTORY
-
+
+ list:LINKED_LIST(ENTRY);
- - alias:HASHED_DICTIONARY(ENTRY,ABSTRACT_STRING) :=
+ - alias:HASHED_DICTIONARY(ENTRY,ABSTRACT_STRING) :=
HASHED_DICTIONARY(ENTRY,ABSTRACT_STRING).create;
-
+
Section Public
-
+
//
// Manager.
//
-
+
- remove_me <- remove_path ".";
-
+
- remove p:ABSTRACT_STRING :BOOLEAN <-
// Remove file or directory (WARNING: delete recursive)
( + dir:DIRECTORY;
+ i:INTEGER;
+ result:BOOLEAN;
+ e:ENTRY;
-
+
e := get_entry p;
(e != NULL).if {
(e.is_directory).if {
dir ?= e;
result := dir.open;
(result).if {
- i := dir.lower;
+ i := dir.lower;
{(i > dir.upper) || {! result}}.until_do {
result := remove (dir.item i.path);
i := i + 1;
- };
+ };
result.if {
result := physical_remove (e.path);
};
@@ -73,25 +73,25 @@ Section Public
};
(result).if {
// Remove Alias.
- alias.remove (e.path);
+ alias.remove (e.path);
};
};
result
);
-
+
- move old_path:ABSTRACT_STRING to new_path:ABSTRACT_STRING :BOOLEAN <-
( + result:BOOLEAN;
+ e:ENTRY;
-
+
"WARNING : Et les alias des sous répertoires, fichiers, ...\n".print;
-
+
string_tmp.copy path;
string_tmp.add_last '/';
- string_tmp.append old_path;
+ string_tmp.append old_path;
reduce_path string_tmp;
string_tmp2.copy path;
string_tmp2.add_last '/';
- string_tmp2.append new_path;
+ string_tmp2.append new_path;
reduce_path string_tmp2;
e := alias.reference_at string_tmp;
((result := physical_move string_tmp to string_tmp2) && {e != NULL}).if {
@@ -101,41 +101,41 @@ Section Public
};
result
);
-
- - get_entry p:ABSTRACT_STRING :ENTRY <-
+
+ - get_entry p:ABSTRACT_STRING :ENTRY <-
( + result:ENTRY;
+ idx:INTEGER;
string_tmp2.copy path;
string_tmp2.add_last '/';
string_tmp2.append p;
reduce_path string_tmp2;
- string_tmp3.copy string_tmp2;
+ string_tmp3.copy string_tmp2;
{
result := alias.reference_at string_tmp2; // with { (e1,e2:ABSTRACT_STRING); e1 ~= e2 };
(result = NULL).if {
- idx := string_tmp2.fast_last_index_of '/';
+ idx := string_tmp2.fast_last_index_of '/';
(idx > 0).if {
string_tmp2.keep_head (idx-1);
} else {
string_tmp2.clear;
};
};
- }.do_while {(result = NULL) && {! string_tmp2.is_empty}};
+ }.do_while {(result = NULL) && {! string_tmp2.is_empty}};
(result = NULL).if {
result := FILE_SYSTEM.physical_get_entry string_tmp3;
}.elseif {string_tmp3.count != string_tmp2.count} then {
+ dir:DIRECTORY;
- dir ?= result;
- result := dir.physical_get_entry string_tmp3;
+ dir ?= result;
+ result := dir.physical_get_entry string_tmp3;
};
result
- );
-
+ );
+
//
// Indexing.
//
-
+
- open:BOOLEAN <-
(
deferred;
@@ -143,105 +143,105 @@ Section Public
[
+? {list != NULL};
];
-
+
- is_open:BOOLEAN <- list != NULL;
-
+
- lower:INTEGER := 1;
// Minimum index.
-
- - upper:INTEGER <-
+
+ - upper:INTEGER <-
[
{is_open} -? "Directory not open.";
]
(
list.upper
- );
-
+ );
+
// Maximum index.
-
- - valid_index index:INTEGER :BOOLEAN <-
+
+ - valid_index index:INTEGER :BOOLEAN <-
// True when `index' is valid (ie. inside actual
// bounds of the collection).
[
{is_open} -? "Directory not open.";
]
- (
- index.in_range lower to upper
+ (
+ index.in_range lower to upper
)
[
+? {Result = index.in_range lower to upper};
+? {list.count = Old list.count};
];
-
+
//
// Counting.
//
-
+
- count:INTEGER <- (upper - lower + 1);
// Number of available indices.
-
+
- is_empty:BOOLEAN <- count = 0;
// Is collection empty ?
-
+
//
// Accessing.
//
-
+
- item i:INTEGER :ENTRY <-
- // Item at the corresponding index `i'.
+ // Item at the corresponding index `i'.
[
-? {valid_index i};
{is_open} -? "Directory not open.";
]
- (
+ (
list.item i
- );
-
- - first:ENTRY <-
- // The very `first' item.
+ );
+
+ - first:ENTRY <-
+ // The very `first' item.
[
{is_open} -? "Directory not open.";
-? {! is_empty};
]
- (
+ (
item lower
);
-
-
+
+
- last:ENTRY <-
// The `last' item.
[
{is_open} -? "Directory not open.";
-? {! is_empty};
]
- (
+ (
item upper
);
-
+
- parent:ENTRY <-
(
get_entry ".."
);
-
+
//
// Writing:
//
-
+
- make_directory p:ABSTRACT_STRING :DIRECTORY <-
- ( + result:DIRECTORY;
+ ( + result:DIRECTORY;
string_tmp.copy path;
string_tmp.add_last '/';
- string_tmp.append p;
- reduce_path string_tmp;
+ string_tmp.append p;
+ reduce_path string_tmp;
(physical_make_directory string_tmp).if {
- result ?= get_entry string_tmp;
+ result ?= get_entry string_tmp;
? {result != NULL};
};
result
);
-
+
- make_file p:ABSTRACT_STRING :FILE <-
- ( + result:FILE;
+ ( + result:FILE;
string_tmp.copy path;
string_tmp.add_last '/';
string_tmp.append p;
@@ -252,20 +252,20 @@ Section Public
};
result
);
-
+
- create_file p:ABSTRACT_STRING :FILE <-
(
make_file p
);
-
+
//
// Display.
//
-
+
- print <-
- (
- lower.to upper do { j:INTEGER;
- string_tmp.copy (item j.path);
+ (
+ lower.to upper do { j:INTEGER;
+ string_tmp.copy (item j.path);
(item j.is_directory).if {
string_tmp.append " D ";
} else {
@@ -275,49 +275,49 @@ Section Public
string_tmp.add_last ' ';
};
string_tmp.print;
- };
+ };
'\n'.print;
);
-
+
Section DIRECTORY
-
+
//
// Physical implementation.
//
- physical_get_entry new_path:ABSTRACT_STRING :ENTRY <-
( + result:ENTRY;
-
- ((! is_open) && {open}).if {
+
+ ((! is_open) && {open}).if {
result := get_entry new_path;
};
result
);
-
+
- physical_make_directory new_path:ABSTRACT_STRING :BOOLEAN <-
- (
+ (
deferred;
FALSE
);
- physical_make_file new_path:ABSTRACT_STRING :BOOLEAN <-
- (
+ (
deferred;
FALSE
);
- physical_remove p:ABSTRACT_STRING :BOOLEAN <-
- (
+ (
deferred;
FALSE
);
-
+
- physical_move old_path:ABSTRACT_STRING to new_path:ABSTRACT_STRING :BOOLEAN <-
- (
+ (
deferred;
FALSE
);
-
+
Section Private
-
+
- string_tmp3:STRING := STRING.create 255;
diff --git a/lib/standard/file_system/entry.li b/lib/standard/file_system/entry.li
index 51020f3..e1049f4 100644
--- a/lib/standard/file_system/entry.li
+++ b/lib/standard/file_system/entry.li
@@ -19,102 +19,102 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ENTRY;
- copyright := "2003-2007 Benoit Sonntag, Jerome Hilbert";
-
+
- comment := "Abstract Entry.";
-
-Section Inherit
-
+
+Section Inherit
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
//
// Path.
//
-
+
+ path:STRING_CONSTANT;
-
- + name:STRING_CONSTANT;
-
+
+ + name:STRING_CONSTANT;
+
- dirname:STRING <-
( + result:STRING;
-
+
result := STRING.create (path.count);
get_parent_path path in result;
result
);
-
+
//
// Date / Time.
//
-
+
- access:UINTEGER_16 <- ( deferred; 0);
-
+
- access_time:TIME <- ( deferred; TIME);
- access_date:DATE <- ( deferred; DATE);
-
+
- update_time:TIME <- ( deferred; TIME);
- update_date:DATE <- ( deferred; DATE);
-
+
- create_time:TIME <- ( deferred; TIME);
- create_date:DATE <- ( deferred; DATE);
-
+
//
// type.
//
-
+
- is_directory:BOOLEAN <-
( + dir:DIRECTORY;
+ e:ENTRY;
-
+
e := Self; // Bug Compilo
dir ?= e;
dir != NULL
);
-
+
- is_file:BOOLEAN <- ! is_directory;
-
+
//
// Open / Close
//
-
+
- open:BOOLEAN <-
// Return FILE or DIRECTORY, NULL:error.
- (
+ (
deferred;
- );
-
- - is_open:BOOLEAN <-
+ );
+
+ - is_open:BOOLEAN <-
(
deferred;
FALSE
);
-
+
Section ENTRY
-
+
- string_tmp:STRING := STRING.create 255;
-
+
- string_tmp2:STRING := STRING.create 255;
-
+
- set_path n:ABSTRACT_STRING <-
( + idx:INTEGER;
path := STRING_CONSTANT.create_copy n;
- idx := path.last_index_of '/';
+ idx := path.last_index_of '/';
(name = NULL).if {
name := STRING_CONSTANT.clone;
};
- name.set_storage (path.storage + idx) count (path.count - idx);
+ name.set_storage (path.storage + idx) count (path.count - idx);
);
-
+
- reduce_path st:STRING <-
( + i:INTEGER;
+ stat:INTEGER;
+ car:CHARACTER;
-
+
st.replace_all '\\' with '/';
i := st.lower;
@@ -138,7 +138,7 @@ Section ENTRY
i := i - 2;
stat := 1;
}.when 3 then {
- // toto/foo/../bar => toto/bar
+ // toto/foo/../bar => toto/bar
// ^ ^
+ idx:INTEGER;
idx := st.last_index_of '/' since (i-4);
@@ -167,18 +167,18 @@ Section ENTRY
// foo/...bar => foo/...bar
stat := 0;
};
- }.elseif {(car = ':') && {i > 2} &&
+ }.elseif {(car = ':') && {i > 2} &&
{st.item (i-1).is_letter} && {st.item (i-2) = '/'}
} then {
st.remove_first (i-2);
- i := st.lower;
+ i := st.lower;
} else {
// Other character.
stat := 0;
};
i := i + 1;
};
-
+
stat.when 0 then {
// foo/bar => foo/bar
// ^ ^
@@ -189,9 +189,9 @@ Section ENTRY
}.when 2 then {
// foo/. => foo
// ^ ^
- st.remove_last 2;
+ st.remove_last 2;
}.when 3 then {
- // toto/foo/.. => toto
+ // toto/foo/.. => toto
// ^ ^
+ idx:INTEGER;
idx := st.last_index_of '/' since (i-4);
@@ -201,7 +201,7 @@ Section ENTRY
st.remove_between idx to (i-1);
};
};
-
+
(st.is_empty).if {
st.add_last '/';
};
@@ -210,13 +210,13 @@ Section ENTRY
//
// Alias Entry.
//
-
+
- get_parent_path p:ABSTRACT_STRING in tmp:STRING <-
- [
+ [
-? {p.last != '/'};
]
( + i:INTEGER;
-
+
(tmp != p).if {
tmp.copy p;
};
@@ -225,7 +225,7 @@ Section ENTRY
tmp.copy "../";
} else {
tmp.keep_head (i-1);
- (tmp.is_empty).if {
+ (tmp.is_empty).if {
tmp.add_last '/';
};
};
diff --git a/lib/standard/file_system/file.li b/lib/standard/file_system/file.li
index 50feea1..fff6398 100644
--- a/lib/standard/file_system/file.li
+++ b/lib/standard/file_system/file.li
@@ -19,55 +19,55 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FILE;
- copyright := "2003-2007 Benoit Sonntag, Jerome Hilbert";
-
+
- comment := "Abstract File Management";
-
+
Section Inherit
-
- - parent_entry:ENTRY := ENTRY;
-
+
+ - parent_entry:ENTRY := ENTRY;
+
Section Public
-
+
- cursor:UINTEGER_32 <-
[
-? {is_open};
]
- (
+ (
deferred;
0
);
-
+
- size:UINTEGER_32 <-
- (
+ (
deferred;
0
);
-
+
- set_cursor n:UINTEGER_32 <-
[
-? {is_open};
-? {n <= size};
]
(
- deferred;
+ deferred;
);
-
+
//
// Update.
//
-
+
- is_empty:BOOLEAN <- size = 0;
// Is collection empty ?
-
+
//
// Read.
//
-
- - read dest:OBJECT :INTEGER <-
+
+ - read dest:OBJECT :INTEGER <-
// WARNING: It's good for Mapping objects, else serializable is necessary.
[
-? {is_open};
@@ -75,8 +75,8 @@ Section Public
( + buf:NATIVE_ARRAY(UINTEGER_8);
buf := CONVERT(OBJECT,NATIVE_ARRAY(UINTEGER_8)).on dest;
physical_read buf size (dest.object_size)
- );
-
+ );
+
- read dest:ARRAYED size nb_elt:INTEGER :INTEGER <-
[
-? {is_open};
@@ -85,22 +85,22 @@ Section Public
+ index,s:INTEGER;
+ result:INTEGER;
+ new_count:INTEGER;
-
+
new_count := dest.count + nb_elt;
dest.set_capacity new_count;
buf := dest.to_native_array_uinteger_8;
index := dest.count * dest.element_sizeof;
- s := nb_elt * dest.element_sizeof;
+ s := nb_elt * dest.element_sizeof;
result := physical_read (buf+index) size s;
dest.set_count new_count;
? {result % dest.element_sizeof = 0};
result / dest.element_sizeof
);
-
+
//
// Write.
//
-
+
- write src:ARRAYED from start:INTEGER size nb_elt:INTEGER :INTEGER <-
[
-? {is_open};
@@ -108,7 +108,7 @@ Section Public
( + buf:NATIVE_ARRAY(UINTEGER_8);
+ index,s:INTEGER;
+ result:INTEGER;
-
+
buf := src.to_native_array_uinteger_8;
index := (start-src.lower) * src.element_sizeof;
s := nb_elt * src.element_sizeof;
@@ -116,36 +116,36 @@ Section Public
? {result % src.element_sizeof = 0};
result / src.element_sizeof
);
-
+
- write src:ARRAYED size nb_elt:INTEGER :INTEGER <-
(
write src from (src.lower) size nb_elt
);
-
+
- write src:ARRAYED :INTEGER <-
(
write src size (src.count)
);
-
+
//
// Close.
//
-
+
- close <-
- (
+ (
deferred;
)
[
+? {! is_open};
];
-
+
- open_read_only:BOOLEAN <-
(
deferred;
);
-
+
Section FILE
-
+
- physical_read buf:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :INTEGER <-
[
-? {is_open};
@@ -157,19 +157,19 @@ Section FILE
[
+? {cursor = Old cursor + s};
];
-
+
- physical_write buf:NATIVE_ARRAY(UINTEGER_8) size s:INTEGER :INTEGER <-
[
-? {is_open};
]
- (
+ (
deferred;
0
)
[
+? {cursor = Old cursor + s};
];
-
-
-
-
+
+
+
+
diff --git a/lib/standard/http/http_server.li b/lib/standard/http/http_server.li
index a095ba0..a9db798 100644
--- a/lib/standard/http/http_server.li
+++ b/lib/standard/http/http_server.li
@@ -19,16 +19,16 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := HTTP_SERVER;
- copyright := "2003-2010 Sonntag Benoit";
- author := "Sonntag Benoit (sonntag at icps.u-strasbg.fr)";
- comment := "The main prototype";
-
+
- external :=
-`
+`
#include <sys/types.h>
#include <string.h>
#include <unistd.h>
@@ -36,49 +36,49 @@ Section Header
#include <netinet/in.h>
#include <netdb.h>
-#include <sys/socket.h>
+#include <sys/socket.h>
struct sockaddr_in address;
`;
-
+
Section Inherit
- parent_object:OBJECT := OBJECT;
-
+
Section Private
-
+
//
// Parameters
//
-
+
+ h_socket:INTEGER;
-
+
- queue_size:INTEGER := 5;
-
+
- buffer:STRING := STRING.create 1024;
-
+
//
// Error.
//
-
+
- socket_error:INTEGER := -1;
-
+
- error msg:ABSTRACT_STRING <-
(
msg.print; '\n'.print;
die_with_code 1;
);
-
+
Section Public
-
+
- log:STRING := STRING.create 1024;
-
+
- listen port:INTEGER action act:{} <-
( + h_server_socket,error,tmp:INTEGER;
+ n_address_size:INTEGER;
+ storage:NATIVE_ARRAY(CHARACTER);
-
- n_address_size := `sizeof(address)`:INTEGER;
+
+ n_address_size := `sizeof(address)`:INTEGER;
h_server_socket := `socket(AF_INET,SOCK_STREAM,0)`:INTEGER;
(h_server_socket = socket_error).if {
error "Error : create socket!";
@@ -88,114 +88,114 @@ Section Public
address.sin_port=htons(@port);
address.sin_family=AF_INET;
`;
-
+
error := `bind(@h_server_socket,(struct sockaddr*)&address,sizeof(address))`:INTEGER;
(error = socket_error).if {
error "Error : Bind()";
};
- `getsockname(@h_server_socket, (struct sockaddr *) &address,(socklen_t *)&@n_address_size)`;
-
+ `getsockname(@h_server_socket, (struct sockaddr *) &address,(socklen_t *)&@n_address_size)`;
+
log.append "Opened socket as fd (";
h_server_socket.append_in log;
log.append ") on port (";
`ntohs(address.sin_port)`:INTEGER.append_in log;
log.append ") for stream i/o\n";
-
+
/*
"Server\
\\nsin_family = ".print;
`address.sin_family`:INTEGER.print;
"\nsin_addr.s_addr = ".print;
- `address.sin_addr.s_addr`:INTEGER.print;
+ `address.sin_addr.s_addr`:INTEGER.print;
"\nsin_port = ".print;
`ntohs(address.sin_port)`:INTEGER.print;
- '\n'.print;
+ '\n'.print;
"\nMaking a listen queue of ".print;
queue_size.print;
" elements".print;
*/
-
- // establish listen queue
+
+ // establish listen queue
tmp := queue_size;
(`listen(@h_server_socket, at tmp)`:INTEGER = socket_error).if {
error "Could not listen";
};
{
log.append "Waiting for a connection\n";
- // get the connected socket
+ // get the connected socket
h_socket := `accept(@h_server_socket,(struct sockaddr*)&address,(socklen_t *)&@n_address_size)`:INTEGER;
- log.append "Got a connection\n";
- act.value;
+ log.append "Got a connection\n";
+ act.value;
}.endless_loop;
);
-
+
- send buf:ABSTRACT_STRING <-
( + storage:NATIVE_ARRAY(CHARACTER);
+ loc_h_socket,count:INTEGER;
-
+
log.append "send buffer\n";
storage := buf.to_external;
count := buf.count + 1;
loc_h_socket := h_socket;
`write(@loc_h_socket, at storage, at count)`;
);
-
+
- receive buf:STRING <-
// BSBS: Plutot faire un append que un copy
( + loc_h_socket,capacity:INTEGER;
+ storage:NATIVE_ARRAY(CHARACTER);
-
+
log.append "receive buffer\n";
storage := buf.to_external;
capacity := buf.capacity;
loc_h_socket := h_socket;
`read(@loc_h_socket, at storage, at capacity)`;
buf.from_external storage;
- );
-
+ );
+
- close <-
- // close socket
+ // close socket
( + loc_h_socket:INTEGER;
- log.append "Closing the socket\n";
+ log.append "Closing the socket\n";
loc_h_socket := h_socket;
(`close(@loc_h_socket)`:INTEGER = socket_error).if {
error "Could not close socket";
- };
- );
-
+ };
+ );
+
- convert buf:STRING to_dictionary dico:HASHED_DICTIONARY(STRING,STRING) <-
( + idx_start,idx_end,idx:INTEGER;
+ key,value:STRING;
+ sep:CHARACTER;
-
+
sep := ' ';
idx_start := buf.lower;
{
- idx_end := buf.index_of '\n' since idx_start;
+ idx_end := buf.index_of '\n' since idx_start;
idx := buf.index_of sep since idx_start;
(idx < idx_end).if {
- sep := ':';
+ sep := ':';
key := buf.substring idx_start to (idx-1);
- {buf.item (idx + 1) = ' '}.while_do {
- idx := idx + 1;
+ {buf.item (idx + 1) = ' '}.while_do {
+ idx := idx + 1;
+ };
+ {buf.item (idx_end - 1) <= ' '}.while_do {
+ idx_end := idx_end - 1;
};
- {buf.item (idx_end - 1) <= ' '}.while_do {
- idx_end := idx_end - 1;
- };
value := buf.substring (idx+1) to (idx_end-1);
dico.put value to key;
};
idx_start := idx_end + 1;
}.do_while {idx_end <= buf.count};
);
-
+
//
// High level.
//
-
+
- send buf:ABSTRACT_STRING type_mime type:ABSTRACT_STRING <-
(
- buffer.copy
+ buffer.copy
"HTTP/1.1 200 OK\n\
\Date: ";
SYSTEM.get_current_date.append_in buffer;
@@ -206,7 +206,7 @@ Section Public
\Content-Length: ";
buf.count.append_in buffer;
buffer.append "\n\
- \Connection: close\n\
+ \Connection: close\n\
\Content-type: ";
buffer.append type;
buffer.append "\n\n";
diff --git a/lib/standard/io/io.li b/lib/standard/io/io.li
index 181235d..431658a 100644
--- a/lib/standard/io/io.li
+++ b/lib/standard/io/io.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := IO;
@@ -28,7 +28,7 @@ Section Header
- comment := "Standard Input Output.";
Section Inherit
-
+
- inherit_std_input:STD_INPUT := STD_INPUT;
-
+
- inherit_std_output:STD_OUTPUT := STD_OUTPUT;
diff --git a/lib/standard/io/std_error.li b/lib/standard/io/std_error.li
index 3fde7a2..dfacdda 100644
--- a/lib/standard/io/std_error.li
+++ b/lib/standard/io/std_error.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := STD_ERROR;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
- - comment := " To write on the standard error output. As for UNIX, the default\
+
+ - comment := " To write on the standard error output. As for UNIX, the default\
\ standard error file is the screen. \
\Note: only one instance of this class should be necessary (have a look\
\in the root classes to search for the good name to use).";
-
+
Section Inherit
-
+
- inherit_output_stream:OUTPUT_STREAM := OUTPUT_STREAM;
-
+
Section Public
- is_connected:BOOLEAN := TRUE;
-
+
- make <-
(
);
diff --git a/lib/standard/io/std_input.li b/lib/standard/io/std_input.li
index 3fa5cfc..597814b 100644
--- a/lib/standard/io/std_input.li
+++ b/lib/standard/io/std_input.li
@@ -19,27 +19,27 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := STD_INPUT;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :=" To use the standard input file. As for UNIX, the default standard input is the keyboard.";
-
+
Section Inherit
-
+
- inherit_input_stream:INPUT_STREAM := INPUT_STREAM;
-
+
Section Private
- memory:CHARACTER;
// Memory of the last available user's value.
Section Public
-
+
- is_connected:BOOLEAN := TRUE;
-
+
- read_character:CHARACTER<-
// Read character from stdin
(
@@ -50,21 +50,21 @@ Section Public
};
last_character
);
-
-
+
+
- unread_character <-
(
push_back_flag := TRUE;
);
-
-
+
+
- last_character:CHARACTER <-
// Return last character from stdin
(
memory
);
-
-
+
+
- end_of_input:BOOLEAN <-
// Return TRUE if end of input
(
@@ -74,7 +74,7 @@ Section Public
};
result
);
-
+
- read_line_in buffer:STRING <-
// Real all character until \n (so read a line)
(
@@ -83,7 +83,7 @@ Section Public
( (last_character != '\n') && { memory != basic_io_eof } ).if {
buffer.extend memory;
mem := basic_io_getc;
-
+
{ (mem = basic_io_eof) || {mem = '\n'} }.until_do {
buffer.extend mem;
mem := basic_io_getc;
@@ -91,6 +91,6 @@ Section Public
memory := mem;
};
);
-
+
diff --git a/lib/standard/io/std_output.li b/lib/standard/io/std_output.li
index fa0c5b5..85af284 100644
--- a/lib/standard/io/std_output.li
+++ b/lib/standard/io/std_output.li
@@ -19,27 +19,27 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=STD_OUTPUT;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="Standard Output (UNIX Operating System).";
-
+
Section Inherit
-
+
- inherit_output_stream:OUTPUT_STREAM := OUTPUT_STREAM;
-
+
Section Public
-
+
- is_connected:BOOLEAN := TRUE;
-
+
- put_character c:CHARACTER <- basic_io_putc c;
// Put `c' on stdout
-
+
diff --git a/lib/standard/kernel/convert.li b/lib/standard/kernel/convert.li
index 4bf64f1..deb361b 100644
--- a/lib/standard/kernel/convert.li
+++ b/lib/standard/kernel/convert.li
@@ -19,16 +19,15 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CONVERT(S,D);
- copyright := "2003-2007 Benoit Sonntag";
-
+
- comment := "Don't use this prototype !";
Section Public
-
+
- on src:S :D <- `13`;
-
-
\ No newline at end of file
+
diff --git a/lib/standard/kernel/i_dont_know_prototyping.li b/lib/standard/kernel/i_dont_know_prototyping.li
index d95a0f6..350d1d5 100644
--- a/lib/standard/kernel/i_dont_know_prototyping.li
+++ b/lib/standard/kernel/i_dont_know_prototyping.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := I_DONT_KNOW_PROTOTYPING;
@@ -28,11 +28,11 @@ Section Header
- comment := "Facility, but it's not in prototype spirit.";
Section Public
-
+
//
// Conditional.
//
-
+
- if cond:BOOLEAN then true_block:{} :BOOLEAN <-
(
cond.if true_block
@@ -42,32 +42,32 @@ Section Public
(
cond.if true_block else false_block;
);
-
+
//
// Loop.
//
-
+
- while cond:{} do body:{} <-
(
cond.while_do body;
);
-
+
- do body:{} while cond:{} <-
(
body.do_while cond;
);
-
+
- repeat body:{} until cond:{} <-
(
body.do_until cond;
);
-
+
//
// Print.
//
-
+
- printf str:ABSTRACT_STRING <-
(
str.print;
);
-
+
diff --git a/lib/standard/kernel/object.li b/lib/standard/kernel/object.li
index 94733c7..4ca1ae1 100644
--- a/lib/standard/kernel/object.li
+++ b/lib/standard/kernel/object.li
@@ -19,198 +19,198 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := OBJECT;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
- comment := "Root object.";
-
+
Section Insert
-
+
- im_an_idiot:Expanded I_DONT_KNOW_PROTOTYPING;
-
+
Section Public
-
+
//
// Compiler consideration.
//
-
+
- object_size:INTEGER <- `12`;
-
+
//- pointer_size:INTEGER <- POINTER.pointer_size;
- is_debug_mode:BOOLEAN <- debug_level != 0;
-
+
- debug_level:INTEGER <- `11`;
- compiler_inlining_level:INTEGER <- `18`;
- - compiler_optimization:BOOLEAN <- `19`;
+ - compiler_optimization:BOOLEAN <- `19`;
- compiler_built_on:STRING_CONSTANT <- `20`;
-
+
- is_ansi:BOOLEAN := SYSTEM.is_ansi;
-
+
//
// Control Error.
//
-
+
- top_runtime_stack:POINTER <- `14`;
-
- - print_runtime_stack_on ptr:POINTER <-
+
+ - print_runtime_stack_on ptr:POINTER <-
(
(debug_level != 0).if {
`lisaac_stack_print((_____CONTEXT *)@ptr)`;
};
);
-
+
- wait_all_the_time <- `pthread_join(c_thread, NULL)`;
-
+
- print_runtime_stack <- print_runtime_stack_on top_runtime_stack;
-
+
- crash_on ptr:POINTER with_message msg:ABSTRACT_STRING <-
(
print_runtime_stack_on ptr;
msg.print;
'\n'.print;
- die_with_code exit_failure_code;
+ die_with_code exit_failure_code;
);
-
+
- crash_with_message msg:ABSTRACT_STRING <-
- (
+ (
crash_on top_runtime_stack with_message msg;
);
- die_with_code code:INTEGER <- SYSTEM.exit code;
// Terminate execution with exit status code `code'.
-
+
- exit_success_code:INTEGER := 0;
-
+
- exit_failure_code:INTEGER := 1;
-
+
- deferred <-
( + ptr:POINTER;
ptr := top_runtime_stack;
crash_on ptr with_message "Slot deferred.";
);
-
+
- crash <-
( + ptr:POINTER;
ptr := top_runtime_stack;
crash_on ptr with_message "Crash system.";
);
-
+
- not_yet_implemented <-
( + ptr:POINTER;
ptr := top_runtime_stack;
crash_on ptr with_message "Sorry, Some Feature is Not Yet Implemented.";
);
-
+
//
// Common Function.
//
-
+
- Self:SELF '==' Right 60 other:E :BOOLEAN <- ( deferred; FALSE);
-
+
- Self:SELF '!==' Right 60 other:OBJECT :BOOLEAN <- (! (Self == other));
-
-
+
+
- clone_allocation_size:UINTEGER_CPU;
-
- - clone:SELF <-
+
+ - clone:SELF <-
( + result:SELF;
+ ptr:POINTER;
+ sz:UINTEGER_CPU;
+ typ_id:INTEGER;
-
- sz := object_size;
- (sz = 0).if {
+
+ sz := object_size;
+ (sz = 0).if {
result := Self;
- } else {
- typ_id := type_id_intern;
- //ptr := `malloc(((unsigned long)(@sz + 3)) & 0xFFFFFFFC)`:POINTER;
- clone_allocation_size := clone_allocation_size + sz;
+ } else {
+ typ_id := type_id_intern;
+ //ptr := `malloc(((unsigned long)(@sz + 3)) & 0xFFFFFFFC)`:POINTER;
+ clone_allocation_size := clone_allocation_size + sz;
(typ_id = -1).if {
ptr := MEMORY.alloc_size sz;
- } else {
+ } else {
ptr := MEMORY.alloc_type (typ_id.to_uinteger_32) size sz;
- };
- result := CONVERT(POINTER,SELF).on ptr;
+ };
+ result := CONVERT(POINTER,SELF).on ptr;
//MEMORY.copy to_pointer to ptr size (CONVERT(POINTER,UINTEGER_32).on sz);
- copy_intern_in result;
- (is_cop_type).if {
+ copy_intern_in result;
+ (is_cop_type).if {
`((lith_object *)@result)->first = NULL`;
`((lith_object *)@result)->last = NULL`;
};
};
result
);
-
- - free_allocation_memory <-
+
+ - free_allocation_memory <-
// Static free, don't use with GC.
( + ptr:POINTER;
+ sz:UINTEGER_CPU;
+ typ_id:INTEGER;
-
- sz := object_size;
- (sz != 0).if {
- typ_id := type_id_intern;
- //ptr := `free(@Self)`;
- clone_allocation_size := clone_allocation_size - sz;
+
+ sz := object_size;
+ (sz != 0).if {
+ typ_id := type_id_intern;
+ //ptr := `free(@Self)`;
+ clone_allocation_size := clone_allocation_size - sz;
ptr := to_pointer;
(typ_id = -1).if {
MEMORY.free ptr size sz;
} else {
MEMORY.free ptr type (typ_id.to_uinteger_32);
- };
+ };
};
);
-
+
- to_pointer:POINTER <- CONVERT(SELF,POINTER).on Self;
- to_string :STRING <- to_pointer.to_string;
- print <- to_string.print;
- - println <-
- (
- to_string.println;
+ - println <-
+ (
+ to_string.println;
);
-
+
- dynamic_type:SELF <- SELF;
-
+
- same_dynamic_type other:OBJECT :BOOLEAN <-
( + convert:SELF;
convert ?= other;
- convert != NULL
+ convert != NULL
);
-
+
- to_self_on obj:OBJECT :SELF <-
[
-? {obj != NULL};
- ]
+ ]
( + result:SELF;
-
+
result ?= obj;
result
)
[
+? {Result != NULL};
- ];
-
+ ];
+
//
// Reflexivity.
//
-
+
- forall_data action:{ E; } <- `21`;
-
+
//
// The Guru section (Don't touch, don't use !)
//
-
+
- is_expanded_type:BOOLEAN <- `0`;
-
+
- type_id_intern:INTEGER <- `1`;
-
+
- is_cop_type:BOOLEAN <- `15`;
-
+
- copy_intern_in other:SELF <- `*@other = *@Self`;
diff --git a/lib/standard/kernel/pointer.li b/lib/standard/kernel/pointer.li
index 3522db2..1bbe25a 100644
--- a/lib/standard/kernel/pointer.li
+++ b/lib/standard/kernel/pointer.li
@@ -19,59 +19,59 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded POINTER;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "References to objects (POINTER is mapped as C type 'void *')";
-
+
- export := UINTEGER_CPU;
-
+
- type := `void *`;
-
+
- default := `NULL`:POINTER;
-
+
Section Insert
-
+
- parent_unsigned_integer:UNSIGNED_INTEGER := UNSIGNED_INTEGER;
-
+
Section Public
-
+
- in_range low:SELF to up:SELF :BOOLEAN <- TRUE; // BSBS: A revoir.
-
+
- object_size:INTEGER <- `sizeof(void *)`:INTEGER;
-
+
- is_null:BOOLEAN <- (Self = NULL);
// Is the external POINTER a NULL pointer ?
-
+
- is_not_null:BOOLEAN <- ! is_null;
// Is the external POINTER a non-NULL pointer ?
-
+
- to_native_array:NATIVE_ARRAY(UINTEGER_8) <- NATIVE_ARRAY(UINTEGER_8).force_conversion Self;
// Convert `pointer' into 'native_array' type.
-
+
// - to_uinteger_32:UINTEGER_32 <- `(unsigned int)@Self`:UINTEGER_32;
// convert `pointer' into uinteger type (adress of the pointer)
-
+
// - from_uinteger p:UINTEGER_32 :POINTER <- CONVERT(UINTEGER_32,POINTER).on p;
// create POINTER from an adress
-
+
// - to_integer:INTEGER <- to_raw_integer;
- to_string :STRING <- to_uinteger_cpu.to_hexadecimal;
-
+
//
// Convertion format without test.
//
-
+
- to_raw_uinteger_cpu:UINTEGER_CPU <- CONVERT(SELF,UINTEGER_CPU).on Self;
-
+
- to_raw_integer:INTEGER <- CONVERT(UINTEGER_CPU,INTEGER).on to_raw_uinteger_cpu;
-
+
- to_raw_uinteger:UINTEGER <- CONVERT(UINTEGER_CPU,UINTEGER).on to_raw_uinteger_cpu;
-
+
- to_raw_uinteger_8:UINTEGER_8 <- CONVERT(UINTEGER_CPU,UINTEGER_8 ).on to_raw_uinteger_cpu;
- to_raw_uinteger_16:UINTEGER_16 <- CONVERT(UINTEGER_CPU,UINTEGER_16).on to_raw_uinteger_cpu;
@@ -79,7 +79,7 @@ Section Public
- to_raw_uinteger_32:UINTEGER_32 <- CONVERT(UINTEGER_CPU,UINTEGER_32).on to_raw_uinteger_cpu;
- to_raw_uinteger_64:UINTEGER_64 <- CONVERT(UINTEGER_CPU,UINTEGER_64).on to_raw_uinteger_cpu;
-
+
- to_raw_integer_8:INTEGER_8 <- CONVERT(UINTEGER_CPU,INTEGER_8 ).on to_raw_uinteger_cpu;
- to_raw_integer_16:INTEGER_16 <- CONVERT(UINTEGER_CPU,INTEGER_16).on to_raw_uinteger_cpu;
@@ -87,4 +87,3 @@ Section Public
- to_raw_integer_32:INTEGER_32 <- CONVERT(UINTEGER_CPU,INTEGER_32).on to_raw_uinteger_cpu;
- to_raw_integer_64:INTEGER_64 <- CONVERT(UINTEGER_CPU,INTEGER_64).on to_raw_uinteger_cpu;
-
\ No newline at end of file
diff --git a/lib/standard/kernel/reference.li b/lib/standard/kernel/reference.li
index 869182a..ac1ca52 100644
--- a/lib/standard/kernel/reference.li
+++ b/lib/standard/kernel/reference.li
@@ -19,12 +19,12 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := REFERENCE(E);
-
+
- import := E;
- export := E,POINTER;
-
+
- copyright := "2003-2008 Sonntag Benoit";
- author := "Sonntag Benoit (sonntag at icps.u-strasbg.fr)";
@@ -35,9 +35,9 @@ Section Inherit
- parent_object:OBJECT := OBJECT;
Section Public
-
+
+ value:E;
-
+
//
// Creation.
//
@@ -50,14 +50,14 @@ Section Public
);
- make v:E <-
- (
+ (
value := v;
);
-
+
//
// Cast.
//
-
+
- to_e:E <- value;
-
+
- from_e v:E :SELF <- create v;
diff --git a/lib/standard/number/fixed_real/real_16_16.li b/lib/standard/number/fixed_real/real_16_16.li
index c06ed41..1c132ea 100644
--- a/lib/standard/number/fixed_real/real_16_16.li
+++ b/lib/standard/number/fixed_real/real_16_16.li
@@ -19,55 +19,55 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL_16_16;
- export := REAL_32, REAL_64;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "signed 16.16 fixed float.";
-
+
- type := `signed long`;
- default := (0.to_raw_real_16_16);
-
+
Section Insert
-
+
- parent_signed_fixed_real:SIGNED_FIXED_REAL := SIGNED_FIXED_REAL;
-
+
Section SELF
- shift_bits:INTEGER <- 16;
Section Public
-
+
//
// Range.
//
-
- - minimum:INTEGER_64 <- INTEGER_16.minimum;
- - maximum:UINTEGER_64 <- INTEGER_16.maximum;
-
+ - minimum:INTEGER_64 <- INTEGER_16.minimum;
+
+ - maximum:UINTEGER_64 <- INTEGER_16.maximum;
+
//
// Convertion format with test.
//
-
+
- to_real_16_16:REAL_16_16 <- Self;
-
+
//
// Convertion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:INTEGER;
+ old_count,new_count:INTEGER;
? {buffer!=NULL};
-
+
val := to_raw_integer;
-
+
(val < 0).if {
val := - val;
buffer.extend '-';
@@ -83,12 +83,12 @@ Section Public
buffer.insert '0' to old_count;
};
);
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
diff --git a/lib/standard/number/fixed_real/real_24_8.li b/lib/standard/number/fixed_real/real_24_8.li
index a804856..79ef0f7 100644
--- a/lib/standard/number/fixed_real/real_24_8.li
+++ b/lib/standard/number/fixed_real/real_24_8.li
@@ -19,53 +19,53 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL_24_8;
- export := REAL_32, REAL_64;
-
+
- comment := "signed 24.8 fixed float.";
-
+
- type := `signed long`;
- default := (0.to_raw_real_24_8);
-
+
Section Insert
-
+
- parent_signed_fixed_real:SIGNED_FIXED_REAL := SIGNED_FIXED_REAL;
-
+
Section SELF
- shift_bits:INTEGER <- 8;
Section Public
-
+
//
// Range.
//
-
- - minimum:INTEGER_64 <- - 7F_FFFFh.to_raw_integer_64;
- - maximum:UINTEGER_64 <- 7F_FFFFh.to_raw_uinteger_64;
-
+ - minimum:INTEGER_64 <- - 7F_FFFFh.to_raw_integer_64;
+
+ - maximum:UINTEGER_64 <- 7F_FFFFh.to_raw_uinteger_64;
+
//
// Convertion format with test.
//
-
+
- to_real_24_8:REAL_24_8 <- Self;
-
+
//
// Convertion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:INTEGER;
+ old_count,new_count:INTEGER;
? {buffer!=NULL};
-
+
val := to_raw_integer;
-
+
(val < 0).if {
val := - val;
buffer.extend '-';
@@ -82,13 +82,13 @@ Section Public
};
);
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
diff --git a/lib/standard/number/fixed_real/real_26_6.li b/lib/standard/number/fixed_real/real_26_6.li
index b7ea699..174bbcd 100644
--- a/lib/standard/number/fixed_real/real_26_6.li
+++ b/lib/standard/number/fixed_real/real_26_6.li
@@ -19,62 +19,62 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL_26_6;
- export := REAL_32, REAL_64;
-
+
- comment := "signed 26.6 fixed float.";
- type := `unsigned long`;
- default := (0.to_raw_real_26_6);
-
+
Section Insert
-
+
- parent_signed_fixed_real:SIGNED_FIXED_REAL := SIGNED_FIXED_REAL;
Section SELF
- shift_bits:INTEGER <- 6;
-
+
Section Public
-
+
//
// Range.
//
-
+
- minimum:INTEGER_64 <- - 1FF_FFFFh.to_raw_integer_64;
-
+
- maximum:UINTEGER_64 <- 1FF_FFFFh.to_raw_uinteger_64;
-
+
//
// Convertion format with test.
//
-
+
- to_real_26_6:REAL_26_6 <- Self;
-
+
//
// Convertion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:INTEGER_32;
+ old_count,new_count:INTEGER;
? {buffer!=NULL};
-
+
val := to_raw_integer;
-
+
(val < 0).if {
val := - val;
buffer.extend '-';
};
(val >> 6).append_in buffer;
buffer.extend '.';
-
+
old_count:=buffer.count;
- // 1/64 = 0.015625 => 6 digit.
+ // 1/64 = 0.015625 => 6 digit.
(((val & 63) * 1000000)>>6).append_in buffer;
new_count:=old_count+6;
{buffer.count!=new_count}.while_do {
@@ -82,13 +82,13 @@ Section Public
};
);
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
diff --git a/lib/standard/number/fixed_real/ureal_16_16.li b/lib/standard/number/fixed_real/ureal_16_16.li
index 49e1b06..263e403 100644
--- a/lib/standard/number/fixed_real/ureal_16_16.li
+++ b/lib/standard/number/fixed_real/ureal_16_16.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UREAL_16_16;
- export := REAL_32, REAL_64;
-
+
- comment := "unsigned 16.16 fixed float.";
-
+
- type := `signed long`;
- default := (0.to_raw_ureal_16_16);
-
+
Section Insert
-
+
- parent_unsigned_fixed_real:UNSIGNED_FIXED_REAL := UNSIGNED_FIXED_REAL;
Section SELF
- shift_bits:INTEGER <- 16;
-
+
Section Public
-
+
//
// Range.
//
-
- - maximum:UINTEGER_64 <- UINTEGER_16.maximum;
-
+
+ - maximum:UINTEGER_64 <- UINTEGER_16.maximum;
+
//
// Convertion format with test.
//
-
+
- to_real_16_16:REAL_16_16 <- Self;
-
+
//
// Convertion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:INTEGER;
+ old_count,new_count:INTEGER;
? {buffer!=NULL};
-
+
val := to_raw_integer;
-
+
(val < 0).if {
val := - val;
buffer.extend '-';
@@ -79,12 +79,12 @@ Section Public
buffer.insert '0' to old_count;
};
);
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
diff --git a/lib/standard/number/fixed_real/ureal_24_8.li b/lib/standard/number/fixed_real/ureal_24_8.li
index eb5322d..4b53639 100644
--- a/lib/standard/number/fixed_real/ureal_24_8.li
+++ b/lib/standard/number/fixed_real/ureal_24_8.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UREAL_24_8;
- export := REAL_32, REAL_64;
-
+
- comment := "signed 24.8 fixed float.";
-
+
- type := `signed long`;
- default := (0.to_raw_ureal_24_8);
-
+
Section Insert
-
+
- parent_unsigned_fixed_real:UNSIGNED_FIXED_REAL := UNSIGNED_FIXED_REAL;
-
+
Section SELF
- - shift_bits:INTEGER <- 8;
-
+ - shift_bits:INTEGER <- 8;
+
Section Public
-
+
//
// Range.
//
-
- - maximum:UINTEGER_64 <- 0FF_FFFFh.to_raw_uinteger_64;
-
+
+ - maximum:UINTEGER_64 <- 0FF_FFFFh.to_raw_uinteger_64;
+
//
// Convertion format with test.
//
-
+
- to_real_24_8:REAL_24_8 <- Self;
-
+
//
// Convertion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:INTEGER;
+ old_count,new_count:INTEGER;
? {buffer!=NULL};
-
+
val := to_raw_integer;
-
+
(val < 0).if {
val := - val;
buffer.extend '-';
@@ -80,13 +80,13 @@ Section Public
};
);
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
diff --git a/lib/standard/number/fixed_real/ureal_26_6.li b/lib/standard/number/fixed_real/ureal_26_6.li
index 2a34844..2757838 100644
--- a/lib/standard/number/fixed_real/ureal_26_6.li
+++ b/lib/standard/number/fixed_real/ureal_26_6.li
@@ -19,56 +19,56 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UREAL_26_6;
- export := REAL_32, REAL_64;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "unsigned 26.6 fixed float.";
-
+
- type := `unsigned long`;
- default := (0.to_raw_ureal_26_6);
-
+
Section Insert
-
+
- parent_unsigned_fixed_real:UNSIGNED_FIXED_REAL := UNSIGNED_FIXED_REAL;
Section SELF
- shift_bits:INTEGER <- 6;
-
+
Section Public
-
+
//
// Range.
//
-
+
- maximum:UINTEGER_64 <- 3FF_FFFFh.to_raw_uinteger_64;
-
+
//
// Convertion format with test.
//
-
+
- to_ureal_26_6:UREAL_26_6 <- Self;
-
+
//
// Convertion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
( + val:UINTEGER_32;
+ old_count,new_count:INTEGER;
? {buffer!=NULL};
-
+
val := to_raw_uinteger_32;
(val >> 6).append_in buffer;
buffer.extend '.';
old_count:=buffer.count;
- // 1/64 = 0.015625 => 6 digit.
+ // 1/64 = 0.015625 => 6 digit.
(((val & 63) * 1000000)>>6).append_in buffer;
new_count:=old_count+6;
{buffer.count!=new_count}.while_do {
@@ -76,13 +76,13 @@ Section Public
};
);
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
diff --git a/lib/standard/number/integer/integer.li b/lib/standard/number/integer/integer.li
index 8972d13..bbe5f0c 100644
--- a/lib/standard/number/integer/integer.li
+++ b/lib/standard/number/integer/integer.li
@@ -19,61 +19,61 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded INTEGER;
-
- - export :=
- // Integer:
+
+ - export :=
+ // Integer:
UINTEGER_8, UINTEGER_16, UINTEGER_32 , UINTEGER_64,
INTEGER_8 , INTEGER_16 , INTEGER_32 , INTEGER_64 ,
UINTEGER_BIG,UINTEGER , UINTEGER_CPU,//INTEGER_BIG,
// Fixed real:
- UREAL_16_16, UREAL_24_8 , UREAL_26_6 ,
- REAL_16_16 , REAL_24_8 , REAL_26_6 ,
+ UREAL_16_16, UREAL_24_8 , UREAL_26_6 ,
+ REAL_16_16 , REAL_24_8 , REAL_26_6 ,
// Float Real:
REAL, REAL_32, REAL_64, REAL_80,
// Other:
POINTER;
-
+
- comment := "Generic Integer.";
-
+
- type := `signed int`;
- default := 0;
Section Insert
-
+
- inherit_numeric:NUMERIC := NUMERIC;
-
+
Section Public
-
+
//
// Range.
//
-
- - maximum:UINTEGER_64 <-
- // Maximum of integer
- 07FFFFFFFh.to_raw_uinteger_64;
- - minimum:INTEGER_64 <-
+ - maximum:UINTEGER_64 <-
+ // Maximum of integer
+ 07FFFFFFFh.to_raw_uinteger_64;
+
+ - minimum:INTEGER_64 <-
// Minimum of integer
- (- 07FFFFFFFh).to_raw_integer_64;
+ (- 07FFFFFFFh).to_raw_integer_64;
//
// Binary Operator.
//
-
- - Self:SELF '%' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '%' Left 100 other:SELF :SELF <-
// Modulo
Self - ((Self / other) * other);
-
- - Self:SELF '%#' Left 100 other:INTEGER :SELF <-
+
+ - Self:SELF '%#' Left 100 other:INTEGER :SELF <-
// Modulo
Self % other;
-
+
- Self:SELF '**' Right 120 exp:SELF :SELF <-
// Power
( + result:SELF;
-
+
(exp = 0).if {
result := 1;
} else {
@@ -94,28 +94,28 @@ Section Public
//
// Conversion format with test.
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
TRUE
);
-
+
// - to_integer:INTEGER <- Self;
-
+
- to_pointer:POINTER <-
(
to_raw_pointer
);
-
+
//
- // BCD Format.
+ // BCD Format.
//
-
+
- to_binary:SELF <-
// Self is BCD formatted, convert to binary value
( + result:SELF;
+ val,mul:SELF;
-
+
val := Self;
mul := 1;
{val!=0}.while_do {
@@ -123,112 +123,112 @@ Section Public
mul := mul * 10;
val := val >> 4;
};
-
+
result
);
-
+
- to_bcd:SELF <-
// Self is binary formatted, convert to bcd value
( + result:SELF;
+ val,mul:SELF;
-
+
val := Self;
{val != 0}.while_do {
result := result | ((val % 10) << mul);
mul := mul + 4;
val := val / 10;
};
-
- result
+
+ result
);
-
+
//
// Facility typing.
//
-
- - kb:SELF <-
+
+ - kb:SELF <-
// Self in Kilobyte (ie. 1kb = 1024 bytes)
Self << 10;
-
- - mb:SELF <-
+
+ - mb:SELF <-
// Self in megabytes
Self << 20;
- - gb:SELF <-
+ - gb:SELF <-
// Self in gigabytes
Self << 30;
- - tb:SELF <-
+ - tb:SELF <-
// Self in terabytes
Self << 40;
//
// Logic Operator
//
-
- - Self:SELF '&' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '&' Left 100 other:SELF :SELF <-
// AND operator
`6`;
- - Self:SELF '|' Left 80 other:SELF :SELF <-
+ - Self:SELF '|' Left 80 other:SELF :SELF <-
// OR operator
~(~Self & ~other);
- - Self:SELF '^' Left 80 other:SELF :SELF <-
+ - Self:SELF '^' Left 80 other:SELF :SELF <-
// XOR operator
(~Self & other) | (Self & ~other);
- - Self:SELF '>>' Left 100 other:INTEGER :SELF <-
+ - Self:SELF '>>' Left 100 other:INTEGER :SELF <-
// Shift right
`7`;
- - Self:SELF '<<' Left 100 other:INTEGER :SELF <-
+ - Self:SELF '<<' Left 100 other:INTEGER :SELF <-
// Shift left
`8`;
-
+
//
// Unary operator
//
-
- - '~' Self:SELF :SELF <- - Self - SELF.one;
-
+
+ - '~' Self:SELF :SELF <- - Self - SELF.one;
+
//
- // Test.
+ // Test.
//
-
+
- align_power step:SELF :SELF <-
- [
+ [
-? {step.is_power_2};
]
( + a:SELF;
-
+
a := step - 1;
(Self + a) & (~ a)
);
-
+
- is_power_2:BOOLEAN <-
// TRUE is Self is power of 2
( + val:SELF;
+ result:BOOLEAN;
-
- (Self != 0).if {
+
+ (Self != 0).if {
val := Self;
{val.is_even}.while_do {
val := val >> 1;
- };
- result := val = 1;
+ };
+ result := val = 1;
};
result
);
-
+
//
// Function :
//
-
+
- sqrt:SELF <-
// Square root
( + r,x:SELF;
-
+
x:=(Self + 1) >> 1;
{x > r}.while_do {
x:=x-r;
@@ -236,11 +236,11 @@ Section Public
};
r
);
-
- - Self:SELF '!' :SELF <-
+
+ - Self:SELF '!' :SELF <-
// Factorial. Use it like "45!" or "bar!.print;"
factorial;
-
+
- factorial:SELF <-
// Factorial
// * Require: Self >= 0
@@ -248,7 +248,7 @@ Section Public
-? {Self >= 0};
]
( + result,value:SELF;
-
+
result := 1;
value := Self;
{value <= 1}.until_do {
@@ -257,7 +257,7 @@ Section Public
};
result
);
-
+
- fibonacci:SELF <-
// Fibonacci
// * Require: Self >= 0
@@ -265,7 +265,7 @@ Section Public
-? {Self >= 0};
]
( + result:SELF;
-
+
(Self <= 1).if {
result := 1;
} else {
@@ -273,32 +273,32 @@ Section Public
};
result
);
-
- - is_odd:BOOLEAN <-
+
+ - is_odd:BOOLEAN <-
// Is odd ?
- (Self & 1) = 1;
+ (Self & 1) = 1;
- - is_even:BOOLEAN <-
+ - is_even:BOOLEAN <-
// Is even ?
- ! is_odd;
+ ! is_odd;
- gcd other:SELF :SELF <-
// Great Common Divisor of `self' and `other'.
// * Require: Self >= 0
// * Require: `other' >= 0
- // * Ensure:
+ // * Ensure:
[
-? {Self >= 0};
-? {other >= 0};
]
( + result:SELF;
-
+
(other = 0).if {
result := Self;
} else {
result := other.gcd (Self % other);
};
-
+
result
)
[
@@ -341,8 +341,8 @@ Section Public
- random_upper:SELF <-
// Random number between 0 to `Self'.
- [
- -? {Self > 0};
+ [
+ -? {Self > 0};
]
(
random % (Self+1)
@@ -356,28 +356,28 @@ Section Public
[
-? {lower < upper};
]
- (
- lower + (upper-lower).random_upper
+ (
+ lower + (upper-lower).random_upper
)
[
+? {Result.in_range lower to upper};
];
-
+
//
// Looping.
//
-
+
- times action:{} <-
(
1.to Self do { i:INTEGER;
action.value;
};
);
-
+
//
// Convertion
//
-
+
// *French, Slot, Description : Renvoi une chaîne représentant le nombre en base 10
// *English, Slot, Description : String of the number in base 10
@@ -391,88 +391,88 @@ Section Public
- append_in buffer:STRING <- to_integer_32.append_in buffer;
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
-
+
- decimal_digit:CHARACTER <-
// Gives the corresponding CHARACTER for range 0..9.
[
-? {in_range 0 to 9};
]
- (
+ (
(Self.to_integer_8 + '0'.code).to_character
)
[
+? {"0123456789".has Result};
+? {Result.decimal_value = Self};
];
-
+
- digit:CHARACTER <- decimal_digit;
-
+
- hexadecimal_digit:CHARACTER <-
// Gives the corresponding CHARACTER for range 0..15.
[
-? {in_range 0 to 15};
]
( + result:CHARACTER;
-
+
(Self <= 9).if {
result := digit;
} else {
result := ('A'.code + (Self - 10).to_integer_8).to_character;
- };
+ };
result
)
[
+? {"0123456789ABCDEF".has Result};
];
-
+
- to_character:CHARACTER <- to_integer_8.to_character;
// Return the coresponding ASCII character.
-
+
- to_octal:SELF <-
// Gives coresponding octal value.
( + result:SELF;
-
+
deferred;
result
);
-
+
- to_hexadecimal:STRING <-
// Convert the hexadecimal view of `self' into a new allocated
// STRING. For example, if `self' is -1 the new STRING is
// "FFFFFFFF" on a 32 bit machine.
// * See: `to_hexadecimal_in' to save memory.
( + result:STRING;
-
+
result := STRING.create 8;
to_hexadecimal_in result;
result
);
-
+
- to_hexadecimal_format s:INTEGER :STRING <-
// Convert the hexadecimal view of `self' into a new allocated
// STRING. For example, if `self' is -1 the new STRING is
// "FFFFFFFF" on a 32 bit machine.
// * See: `to_hexadecimal_in' to save memory.
( + result:STRING;
-
+
result := STRING.create 8;
to_hexadecimal_in result format s;
result
- );
-
+ );
+
- to_hexadecimal_in buffer:STRING <-
// Append in `buffer' the equivalent of `to_hexadecimal'. No new STRING
// creation during the process.
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,old_count:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
i := buffer.count + 1;
val := Self;
- {val != 0}.while_do { //JBJB
+ {val != 0}.while_do { //JBJB
buffer.extend ((val & 15).hexadecimal_digit);
val := val >> 4;
};
@@ -484,20 +484,20 @@ Section Public
};
};
);
-
+
- to_hexadecimal_in buffer:STRING format s:INTEGER <-
// Append in `buffer' the equivalent of `to_hexadecimal'. No new STRING
// creation during the process.
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,old_count:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
i := buffer.count + 1;
val := Self;
- {val != 0}.while_do { //JBJB
+ {val != 0}.while_do { //JBJB
buffer.extend ((val & 15).hexadecimal_digit);
val := val >> 4;
};
@@ -509,7 +509,7 @@ Section Public
};
};
buffer.precede_multiple '0' by (s.to_integer - buffer.count);
- );
+ );
- to_binary_in buffer:STRING format s:INTEGER <-
// Append in `buffer' the equivalent of `to_binary_string'. No new STRING
@@ -518,13 +518,13 @@ Section Public
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,old_count:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
i := buffer.count + 1;
val := Self;
- {val != 0}.while_do {
+ {val != 0}.while_do {
buffer.extend ('0' +# (val & 1));
val := val >> 1;
};
@@ -536,20 +536,20 @@ Section Public
};
};
buffer.precede_multiple '0' by ((s.to_integer) - buffer.count);
- );
-
+ );
+
//
// Hashing:
//
-
+
- hash_code:INTEGER <-
// Hash code
to_integer_32.hash_code; // BSBS: Il faut revoir => Depending processor
-
+
//
// Print
//
-
+
- print <-
// Print
(
@@ -562,14 +562,14 @@ Section Public
print_positif;
};
);
-
+
- print_positif <-
// Display this number without memory.
// * Require: Self >= 0
[ -? {Self >=# 0}; ]
( + char:CHARACTER;
- + val:SELF;
-
+ + val:SELF;
+
char := (Self % 10).decimal_digit;
val := Self / 10;
(val != 0).if {
@@ -582,23 +582,23 @@ Section Public
// Display this number without memory.
( + char:CHARACTER;
+ val:SELF;
-
- char := (Self & 0Fh).hexadecimal_digit;
- val := Self / 16;
+
+ char := (Self & 0Fh).hexadecimal_digit;
+ val := Self / 16;
(val != 0).if {
val.print_hex;
};
char.print;
);
-
+
//
// Debug manager facility.
//
-
+
- Self:SELF '?' blc:{BOOLEAN} <- blc ?# Self;
-
-Section INTEGER
-
+
+Section INTEGER
+
- to_raw_pointer:POINTER <- CONVERT(UINTEGER_CPU,POINTER).on to_uinteger_cpu;
diff --git a/lib/standard/number/integer/integer_16.li b/lib/standard/number/integer/integer_16.li
index 7f46d8a..6775db9 100644
--- a/lib/standard/number/integer/integer_16.li
+++ b/lib/standard/number/integer/integer_16.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded INTEGER_16;
- export := INTEGER, INTEGER_64, INTEGER_32;
-
+
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag, 2007 Xavier Oswald";
-
+
- comment := "Signed 16 bits integer.";
- type := `signed short`;
- default := (0.to_raw_integer_16);
-
+
Section Insert
-
+
- parent_signed_integer:SIGNED_INTEGER := SIGNED_INTEGER;
-
+
Section Public
-
+
- object_size:INTEGER := 2;
//
// Range
//
-
+
- maximum:UINTEGER_64 <- 32767.to_raw_uinteger_64;
-
+
- minimum:INTEGER_64 <- - 32767.to_raw_integer_64;
-
+
//
// Conversion with test.
//
diff --git a/lib/standard/number/integer/integer_32.li b/lib/standard/number/integer/integer_32.li
index 056c2e4..52b5f8c 100644
--- a/lib/standard/number/integer/integer_32.li
+++ b/lib/standard/number/integer/integer_32.li
@@ -19,39 +19,39 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded INTEGER_32;
-
+
- export := INTEGER, INTEGER_64, POINTER;
-
+
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag, 2007 Xavier Oswald";
- comment :="Signed 32 bits integer.";
- type := `signed int`;
- default := (0.to_raw_integer_32);
-
+
Section Insert
-
+
- parent_signed_integer:SIGNED_INTEGER := SIGNED_INTEGER;
-
+
Section Public
-
+
- object_size:INTEGER := 4;
//
// Range
//
-
- - maximum:UINTEGER_64 <- 07FFF_FFFFh.to_raw_uinteger_64;
-
+
+ - maximum:UINTEGER_64 <- 07FFF_FFFFh.to_raw_uinteger_64;
+
- minimum:INTEGER_64 <- - 07FFF_FFFFh.to_raw_integer_64;
-
+
//
// Conversion with test.
//
-
- - to_integer_32:INTEGER_32 <- Self;
+
+ - to_integer_32:INTEGER_32 <- Self;
diff --git a/lib/standard/number/integer/integer_64.li b/lib/standard/number/integer/integer_64.li
index 26fe87f..6d8d0ef 100644
--- a/lib/standard/number/integer/integer_64.li
+++ b/lib/standard/number/integer/integer_64.li
@@ -19,41 +19,41 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded INTEGER_64;
- export := INTEGER;
-
+
- comment := "Signed 64 bits integer.";
- type := `signed long long `;
- default := (0.to_raw_integer_64);
-
+
Section Insert
-
+
- parent_signed_integer:SIGNED_INTEGER := SIGNED_INTEGER;
-
+
Section Public
- object_size:INTEGER := 8;
-
-
+
+
- '-' Self:SELF :SELF <- zero - Self;
-
+
//
// Range
//
-
+
- maximum:UINTEGER_64 <- `0x7FFFFFFFFFFFFFFFLLU`:UINTEGER_64;
-
+
- minimum:INTEGER_64 <- `-0x8000000000000000LL`:INTEGER_64;
-
+
//
// Conversion with test.
//
-
+
- to_integer_64:INTEGER_64 <- Self;
-
+
diff --git a/lib/standard/number/integer/integer_8.li b/lib/standard/number/integer/integer_8.li
index fafaa16..45fe223 100644
--- a/lib/standard/number/integer/integer_8.li
+++ b/lib/standard/number/integer/integer_8.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name :=Expanded INTEGER_8;
- export := INTEGER, INTEGER_64, INTEGER_32, INTEGER_16;
- - copyright :=
+ - copyright :=
"2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag, 2007 Xavier Oswald";
- comment :="Signed 8 bits integer.";
- type := `signed char`;
- default := (`(0)`:INTEGER_8); //CONVERT[INTEGER,INTEGER_8].on 0); //0.to_raw_integer_8);
-
+
Section Insert
-
+
- parent_signed_integer:SIGNED_INTEGER := SIGNED_INTEGER;
-
+
Section Public
- object_size:INTEGER := 1;
-
+
//
// Range
//
-
+
- maximum:UINTEGER_64 <- 127.to_raw_uinteger_64;
-
+
- minimum:INTEGER_64 <- - 127.to_raw_integer_64;
-
+
//
// Conversion.
//
-
- - to_integer_8:INTEGER_8 <-
+
+ - to_integer_8:INTEGER_8 <-
[ ]
(
Self
@@ -60,11 +60,11 @@ Section Public
[ ];
- to_character:CHARACTER <- `@Self`:CHARACTER; // `13`;
-
-
+
+
diff --git a/lib/standard/number/integer/uinteger.li b/lib/standard/number/integer/uinteger.li
index 7607a83..116653d 100644
--- a/lib/standard/number/integer/uinteger.li
+++ b/lib/standard/number/integer/uinteger.li
@@ -19,56 +19,56 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
//
// BSBS : Tout a REVOIR !!!!!!!!!!!
//
-
+
+ name := Expanded UINTEGER;
-
+
- export := // BSBS : A revoir!
- // Integer:
+ // Integer:
UINTEGER_8, UINTEGER_16, UINTEGER_32, UINTEGER_64,
INTEGER_8 , INTEGER_16 , INTEGER_32 , INTEGER_64 ,
UINTEGER_BIG,//INTEGER_BIG,
// Fixed real:
- UREAL_16_16, UREAL_24_8 , UREAL_26_6 ,
- REAL_16_16 , REAL_24_8 , REAL_26_6 ,
+ UREAL_16_16, UREAL_24_8 , UREAL_26_6 ,
+ REAL_16_16 , REAL_24_8 , REAL_26_6 ,
// Float Real:
REAL, REAL_32, REAL_64, REAL_80,
// Other:
POINTER;
-
+
- comment := "Generic Integer.";
-
+
- type := `unsigned int`;
- default := 0;
Section Insert
-
+
- parent_numeric:NUMERIC := NUMERIC;
-
+
Section Public
-
+
//
// Range.
//
-
- - maximum:UINTEGER_64 <- 07FFFFFFFh.to_raw_uinteger_64;
-
- - minimum:INTEGER_64 <- (0).to_raw_integer_64;
-
+
+ - maximum:UINTEGER_64 <- 07FFFFFFFh.to_raw_uinteger_64;
+
+ - minimum:INTEGER_64 <- (0).to_raw_integer_64;
+
//
// Binary Operator.
//
-
+
- Self:SELF '%' Left 100 other:SELF :SELF <- Self - ((Self / other) * other);
-
+
- Self:SELF '%#' Left 100 other:INTEGER :SELF <- Self % other;
-
+
- Self:SELF '**' Right 120 exp:SELF :SELF <-
( + result:SELF;
-
+
(exp = 0).if {
result := 1;
} else {
@@ -89,28 +89,28 @@ Section Public
//
// Conversion format with test.
//
-
+
- bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
TRUE
);
-
+
// - to_integer:INTEGER <- Self;
-
+
- to_pointer:POINTER <-
(
to_raw_pointer
);
-
+
//
- // BCD Format.
+ // BCD Format.
//
-
+
- to_binary:SELF <-
// Self is BCD formatted, convert to binary value
( + result:SELF;
+ val,mul:SELF;
-
+
val := Self;
mul := 1;
{val!=0}.while_do {
@@ -118,29 +118,29 @@ Section Public
mul := mul * 10;
val := val >> 4;
};
-
+
result
);
-
+
- to_bcd:SELF <-
// Self is binary formatted, convert to bcd value
( + result:SELF;
+ val,mul:SELF;
-
+
val := Self;
{val != 0}.while_do {
result := result | ((val % 10) << mul);
mul := mul + 4;
val := val / 10;
};
-
- result
+
+ result
);
-
+
//
// Facility typing.
//
-
+
- kb:SELF <- Self << 10;
// Self in Kilobyte (ie. 1kb = 1024 bytes)
@@ -156,7 +156,7 @@ Section Public
//
// Logic Operator
//
-
+
- Self:SELF '&' Left 100 other:SELF :SELF <- `6`;
// AND operator
@@ -175,46 +175,46 @@ Section Public
//
// Unary operator
//
-
+
- '~' Self:SELF :SELF <- -Self - SELF.one; //(-SELF.one) - Self;
-
+
//
- // Test.
+ // Test.
//
-
+
- align_power step:SELF :SELF <-
- [
+ [
-? {step.is_power_2};
]
( + a:SELF;
-
+
a := step - 1;
(Self + a) & (~ a)
);
-
+
- is_power_2:BOOLEAN <-
// TRUE is Self is power of 2
( + val:SELF;
+ result:BOOLEAN;
-
- (Self != 0).if {
+
+ (Self != 0).if {
val := Self;
{val.is_even}.while_do {
val := val >> 1;
- };
- result := val = 1;
+ };
+ result := val = 1;
};
result
);
-
+
//
// Function :
//
-
+
- sqrt:SELF <-
// Square root
( + r,x:SELF;
-
+
x:=(Self + 1) >> 1;
{x > r}.while_do {
x:=x-r;
@@ -222,18 +222,18 @@ Section Public
};
r
);
-
+
- Self:SELF '!' :SELF <- factorial;
// Factorial. Use it like "45!;" or "bar!.print;"
-
+
- factorial:SELF <-
- // Factorial.
+ // Factorial.
// * Require: Self >= 0
[
-? {Self >= 0};
]
( + result,value:SELF;
-
+
result := 1;
value := Self;
{value <= 1}.until_do {
@@ -242,7 +242,7 @@ Section Public
};
result
);
-
+
- fibonacci:SELF <-
// Fibonacci
// * Require: Self >= 0
@@ -250,7 +250,7 @@ Section Public
-? {Self >= 0};
]
( + result:SELF;
-
+
(Self <= 1).if {
result := 1;
} else {
@@ -258,11 +258,11 @@ Section Public
};
result
);
-
+
- is_odd:BOOLEAN <- (Self & 1) = 1; // Is odd ?
-
+
- is_even:BOOLEAN <- ! is_odd; // Is even ?
-
+
- gcd other:SELF :SELF <-
// Great Common Divisor of `self' and `other'.
[
@@ -270,19 +270,19 @@ Section Public
-? {other >= 0};
]
( + result:SELF;
-
+
(other = 0).if {
result := Self;
} else {
result := other.gcd (Self % other);
};
-
+
result
)
[
+? {result == other.gcd self};
];
-
+
//
// Random
//
@@ -299,8 +299,8 @@ Section Public
- random_upper upper:SELF :SELF <-
// Random number between 0 to `upper'.
- [
- -? {upper > 0};
+ [
+ -? {upper > 0};
]
(
random % (upper+1)
@@ -314,28 +314,28 @@ Section Public
[
-? {lower < upper};
]
- (
+ (
lower + random_upper (upper-lower)
)
[
+? {Result.in_range lower to upper};
];
-
+
//
// Looping.
//
-
+
- times action:BLOCK <-
(
1.to Self do { i:INTEGER;
action.value;
};
);
-
+
//
// Convertion
//
-
+
// *French, Slot, Description : Renvoi une chaîne représentant le nombre en base 10
// *English, Slot, Description : String of the number in base 10
@@ -349,88 +349,88 @@ Section Public
- append_in buffer:STRING <- to_integer_32.append_in buffer;
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
-
+
- decimal_digit:CHARACTER <-
// Gives the corresponding CHARACTER for range 0..9.
[
-? {in_range 0 to 9};
]
- (
+ (
(Self.to_integer_8 + '0'.code).to_character
)
[
+? {"0123456789".has Result};
+? {Result.decimal_value = Self};
];
-
+
- digit:CHARACTER <- decimal_digit;
-
+
- hexadecimal_digit:CHARACTER <-
// Gives the corresponding CHARACTER for range 0..15.
[
-? {in_range 0 to 15};
]
( + result:CHARACTER;
-
+
(Self <= 9).if {
result := digit;
} else {
result := ('A'.code + (Self - 10).to_integer_8).to_character;
- };
+ };
result
)
[
+? {"0123456789ABCDEF".has Result};
];
-
+
- to_character:CHARACTER <- to_integer_8.to_character;
// Return the coresponding ASCII character.
-
+
- to_octal:SELF <-
// Gives coresponding octal value.
( + result:SELF;
-
+
deferred;
result
);
-
+
- to_hexadecimal:STRING <-
// Convert the hexadecimal view of `self' into a new allocated
// STRING. For example, if `self' is -1 the new STRING is
// "FFFFFFFF" on a 32 bit machine.
// * See: `to_hexadecimal_in' to save memory.
( + result:STRING;
-
+
result := STRING.create 8;
to_hexadecimal_in result;
result
);
-
+
- to_hexadecimal_format s:INTEGER :STRING <-
// Convert the hexadecimal view of `self' into a new allocated
// STRING. For example, if `self' is -1 the new STRING is
// "FFFFFFFF" on a 32 bit machine.
// * See: `to_hexadecimal_in' to save memory.
( + result:STRING;
-
+
result := STRING.create 8;
to_hexadecimal_in result format s;
result
- );
-
+ );
+
- to_hexadecimal_in buffer:STRING <-
// Append in `buffer' the equivalent of `to_hexadecimal'. No new STRING
// creation during the process.
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,old_count:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
i := buffer.count + 1;
val := Self;
- {val != 0}.while_do { //JBJB
+ {val != 0}.while_do { //JBJB
buffer.extend ((val & 15).hexadecimal_digit);
val := val >> 4;
};
@@ -442,20 +442,20 @@ Section Public
};
};
);
-
+
- to_hexadecimal_in buffer:STRING format s:INTEGER <-
// Append in `buffer' the equivalent of `to_hexadecimal'. No new STRING
// creation during the process.
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,old_count:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
i := buffer.count + 1;
val := Self;
- {val != 0}.while_do { //JBJB
+ {val != 0}.while_do { //JBJB
buffer.extend ((val & 15).hexadecimal_digit);
val := val >> 4;
};
@@ -467,7 +467,7 @@ Section Public
};
};
buffer.precede_multiple '0' by (s.to_integer - buffer.count);
- );
+ );
- to_binary_in buffer:STRING format s:INTEGER <-
// Append in `buffer' the equivalent of `to_binary_string'. No new STRING
@@ -475,13 +475,13 @@ Section Public
[ -? {buffer!=NULL}; ]
( + val:SELF;
+ i,old_count:INTEGER;
-
+
(Self = 0).if {
buffer.extend '0';
} else {
i := buffer.count + 1;
val := Self;
- {val != 0}.while_do {
+ {val != 0}.while_do {
buffer.extend ('0' +# (val & 1));
val := val >> 1;
};
@@ -493,18 +493,18 @@ Section Public
};
};
buffer.precede_multiple '0' by ((s.to_integer) - buffer.count);
- );
-
+ );
+
//
// Hashing:
//
-
+
- hash_code:INTEGER <- to_integer_32.hash_code; // BSBS: Il faut revoir => Depending processor
-
+
//
// Print
//
-
+
- print <-
(
(Self = 0).if {
@@ -516,13 +516,13 @@ Section Public
print_positif;
};
);
-
+
- print_positif <-
// Display this number without memory.
[ -? {Self >=# 0}; ]
( + char:CHARACTER;
- + val:SELF;
-
+ + val:SELF;
+
char := (Self % 10).decimal_digit;
val := Self / 10;
(val != 0).if {
@@ -535,23 +535,23 @@ Section Public
// Display this number without memory.
( + char:CHARACTER;
+ val:SELF;
-
- char := (Self & 0Fh).hexadecimal_digit;
- val := Self / 16;
+
+ char := (Self & 0Fh).hexadecimal_digit;
+ val := Self / 16;
(val != 0).if {
val.print_hex;
};
char.print;
);
-
+
//
// Debug manager facility.
//
-
+
- Self:SELF '?' blc:BLOCK <- blc ?# Self;
-
-Section INTEGER
-
+
+Section INTEGER
+
- to_raw_pointer:POINTER <- CONVERT(SELF,POINTER).on Self;
diff --git a/lib/standard/number/integer/uinteger_16.li b/lib/standard/number/integer/uinteger_16.li
index 8acee90..a65d23b 100644
--- a/lib/standard/number/integer/uinteger_16.li
+++ b/lib/standard/number/integer/uinteger_16.li
@@ -19,39 +19,39 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UINTEGER_16;
- export :=
- UINTEGER_64, UINTEGER_32,
+ UINTEGER_64, UINTEGER_32,
INTEGER_64 , INTEGER_32 ,
INTEGER;
-
+
- comment :="Unsigned 16 bits integer.";
- type := `unsigned short`;
- default := (0.to_raw_uinteger_16);
-
+
Section Insert
-
+
- parent_unsigned_integer:UNSIGNED_INTEGER := UNSIGNED_INTEGER;
-
+
Section Public
- - object_size:INTEGER := 2;
+ - object_size:INTEGER := 2;
//
// Range.
//
-
- - maximum:UINTEGER_64 := 65535.to_raw_uinteger_64;
-
+
+ - maximum:UINTEGER_64 := 65535.to_raw_uinteger_64;
+
//
// Conversion with test.
//
-
+
- to_uinteger_16:UINTEGER_16 <- Self;
-
+
//- to_char_unicode:CHAR_UNICODE <- CHAR_UNICODE.force_conversion Self;
diff --git a/lib/standard/number/integer/uinteger_32.li b/lib/standard/number/integer/uinteger_32.li
index 8d60296..28de9bb 100644
--- a/lib/standard/number/integer/uinteger_32.li
+++ b/lib/standard/number/integer/uinteger_32.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UINTEGER_32;
- export := INTEGER, UINTEGER_64, INTEGER_64;
-
+
- comment := "Unsigned 32 bits integer.";
-
+
- type := `unsigned int`;
- default := (0.to_raw_uinteger_32);
Section Insert
-
+
- parent_unsigned_integer:UNSIGNED_INTEGER := UNSIGNED_INTEGER;
-
+
Section Public
-
+
- object_size:INTEGER := 4;
//
// Range.
//
-
+
- maximum:UINTEGER_64 := ~ 0.to_raw_uinteger_32;
-
+
//
// Conversion with test.
//
-
+
- to_uinteger_32:UINTEGER_32 <- Self;
- to_uinteger_64:UINTEGER_64 <- to_raw_uinteger_64;
diff --git a/lib/standard/number/integer/uinteger_64.li b/lib/standard/number/integer/uinteger_64.li
index 769be07..4584258 100644
--- a/lib/standard/number/integer/uinteger_64.li
+++ b/lib/standard/number/integer/uinteger_64.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UINTEGER_64;
- export := INTEGER;
@@ -28,24 +28,23 @@ Section Header
- type := `unsigned long long`;
- default := (0.to_raw_uinteger_64);
-
+
Section Insert
-
+
- parent_unsigned_integer:UNSIGNED_INTEGER := UNSIGNED_INTEGER;
-
+
Section Public
-
+
- object_size:INTEGER := 8;
//
// Range.
//
-
- - maximum:UINTEGER_64 := `0xFFFFFFFFFFFFFFFFLLU`:UINTEGER_64; //BSBS pb C 0FFFFFFFFFFFFFFFFh;
-
+
+ - maximum:UINTEGER_64 := `0xFFFFFFFFFFFFFFFFLLU`:UINTEGER_64; //BSBS pb C 0FFFFFFFFFFFFFFFFh;
+
//
// Conversion with test.
//
-
+
- to_uinteger_64:UINTEGER_64 <- Self;
-
\ No newline at end of file
diff --git a/lib/standard/number/integer/uinteger_8.li b/lib/standard/number/integer/uinteger_8.li
index 18dfcc9..d8b9274 100644
--- a/lib/standard/number/integer/uinteger_8.li
+++ b/lib/standard/number/integer/uinteger_8.li
@@ -19,11 +19,11 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UINTEGER_8;
-
- - export :=
- UINTEGER_64, UINTEGER_32, UINTEGER_16,
+
+ - export :=
+ UINTEGER_64, UINTEGER_32, UINTEGER_16,
INTEGER_64 , INTEGER_32 , INTEGER_16 ,
INTEGER;
@@ -31,30 +31,30 @@ Section Header
- type := `unsigned char`;
- default := (0.to_raw_uinteger_8);
-
+
Section Insert
-
+
- parent_unsigned_integer:UNSIGNED_INTEGER := UNSIGNED_INTEGER;
-
+
Section Public
-
+
- object_size:INTEGER := 1;
//
// Range.
//
-
+
- maximum:UINTEGER_64 := 255.to_raw_uinteger_64;
-
+
//
// Conversion with test.
//
-
+
- to_uinteger_8:UINTEGER_8 <- Self;
-
- - to_character:CHARACTER <-
+
+ - to_character:CHARACTER <-
[ -? {in_range (CHARACTER.minimum) to (CHARACTER.maximum)}; ]
- (
+ (
CONVERT(UINTEGER_8, CHARACTER).on Self
);
diff --git a/lib/standard/number/integer/uinteger_big.li b/lib/standard/number/integer/uinteger_big.li
index eefe675..d69b3ae 100644
--- a/lib/standard/number/integer/uinteger_big.li
+++ b/lib/standard/number/integer/uinteger_big.li
@@ -22,7 +22,7 @@ Section Header
+ name := UINTEGER_BIG; // Aucun Auto-Cast pour l'instant...(peut etre
// INTEGER_BIG ...)
-
+
- comment := "Integer without bits limit! (Just for fun!)";
Section Inherit
@@ -30,11 +30,11 @@ Section Inherit
- parent_object:OBJECT := OBJECT;
Section UINTEGER_BIG
-
+
+ storage:FAST_ARRAY(UINTEGER_32);
-
+
- last_modulo:UINTEGER_32;
-
+
- count:INTEGER <- storage.count;
- lower:INTEGER <- storage.lower;
@@ -46,40 +46,40 @@ Section UINTEGER_BIG
- copy other:UINTEGER_BIG <- storage.copy (other.storage);
- force elt:UINTEGER_32 to idx:INTEGER <- storage.force elt to idx;
-
+
- put elt:UINTEGER_32 to idx:INTEGER <- storage.put elt to idx;
-
+
- add_last elt:UINTEGER_32 <- storage.add_last elt;
-
+
- resize new_size:INTEGER <-
(
- ? { new_size > 0};
+ ? { new_size > 0};
storage.resize new_size;
);
-
+
- last:UINTEGER_32 <- storage.last;
-
+
- normalize <-
(
{(storage.count != 1) && {storage.last == 0}}.while_do {
storage.remove_last;
- };
+ };
);
-Section Public
+Section Public
- - create init:UINTEGER_32 :UINTEGER_BIG <-
+ - create init:UINTEGER_32 :UINTEGER_BIG <-
( + result:SELF;
-
+
result := clone;
result.make init;
result
);
-
+
- make init:UINTEGER_32 :SELF <-
- (
+ (
(storage = NULL).if {
- storage := FAST_ARRAY(UINTEGER_32).create_with_capacity 4;
+ storage := FAST_ARRAY(UINTEGER_32).create_with_capacity 4;
} else {
storage.clear;
};
@@ -89,72 +89,72 @@ Section Public
//
// Conversion format with test.
//
-
- - to_uinteger_64:UINTEGER_64 <-
+
+ - to_uinteger_64:UINTEGER_64 <-
[ -? {count <= 2}; ] // Bound limit control.
( + result:UINTEGER_64;
-
+
result := storage.first;
(count > 1).if {
result := result | (storage.item 1.to_uinteger_64 << 32);
};
result
);
-
- - to_uinteger_32:UINTEGER_32 <-
+
+ - to_uinteger_32:UINTEGER_32 <-
[ -? {count = 1}; ]
- (
+ (
storage.first
);
-
- - to_uinteger_16:UINTEGER_16 <-
+
+ - to_uinteger_16:UINTEGER_16 <-
[ -? {count = 1}; ]
- (
+ (
storage.first.to_uinteger_16
);
-
- - to_uinteger_8:UINTEGER_8 <-
+
+ - to_uinteger_8:UINTEGER_8 <-
[ -? {count = 1}; ]
- (
+ (
storage.first.to_uinteger_8
);
-
- - to_integer_64:INTEGER_64 <-
+
+ - to_integer_64:INTEGER_64 <-
[ -? {(to_uinteger_64 >> 63) = 0}; ]
- (
+ (
to_uinteger_64.to_integer_64
);
-
- - to_integer:INTEGER <-
+
+ - to_integer:INTEGER <-
[ -? {(to_uinteger_64 >> 31) = 0}; ]
- (
+ (
storage.first.to_integer
);
-
- - to_integer_16:INTEGER_16 <-
+
+ - to_integer_16:INTEGER_16 <-
[ -? {(to_uinteger_16 >> 15) = 0}; ]
- (
+ (
storage.first.to_uinteger_16
);
-
- - to_integer_8:INTEGER_8 <-
+
+ - to_integer_8:INTEGER_8 <-
[ -? {(to_uinteger_8 >> 7) = 0}; ]
- (
+ (
storage.first.to_integer_8
);
-
+
//
// binary operator :
//
-
- - substract other:SELF :SELF <-
+
+ - substract other:SELF :SELF <-
[ ? {Self >= other}; ]
( + over,substr,part1,part2:UINTEGER_64;
+ idx:INTEGER;
(Self == other).if {
set_with_zero;
- } else {
+ } else {
idx := lower;
{idx > other.upper}.until_do {
part1 := item idx;
@@ -170,11 +170,11 @@ Section Public
over := substr >> 32;
put ((substr & 0FFFF_FFFFh).to_uinteger_32) to idx;
idx := idx + 1;
- };
+ };
normalize;
- };
+ };
);
-
+
- substract_integer other:INTEGER :SELF <-
[ ? {Self >=# other}; ]
( + part1,over,substr:UINTEGER_64;
@@ -182,7 +182,7 @@ Section Public
(Self ==# other).if {
set_with_zero;
- } else {
+ } else {
part1 := item 0;
substr := part1 - other;
over := substr >> 32;
@@ -194,16 +194,16 @@ Section Public
over := substr >> 32;
put ((substr & 0FFFF_FFFFh).to_uinteger_32) to idx;
idx := idx + 1;
- };
+ };
normalize;
- };
+ };
);
-
- - addition other:SELF :SELF <-
+
+ - addition other:SELF :SELF <-
[ -? {Self >= other}; ]
( + part1,part2,sum,over:UINTEGER_64;
+ idx:INTEGER;
-
+
idx := lower;
{idx > other.upper}.until_do {
part1 := item idx;
@@ -221,13 +221,13 @@ Section Public
};
(over != 0).if {
add_last (over.to_uinteger_32);
- };
- );
-
+ };
+ );
+
- addition_integer other:INTEGER :SELF <-
( + part1,sum,over:UINTEGER_64;
+ idx:INTEGER;
-
+
part1 := item 0;
sum := part1 + other;
put ((sum & 0FFFF_FFFFh).to_uinteger_32) to 0;
@@ -237,28 +237,28 @@ Section Public
part1 := item idx;
sum := part1 + over;
put ((sum & 0FFFF_FFFFh).to_uinteger_32) to idx;
- idx := idx + 1;
+ idx := idx + 1;
over := sum >> 32;
- };
+ };
(over != 0).if {
add_last (over.to_uinteger_32);
- };
+ };
);
-
- - multiply other:SELF :SELF <-
+
+ - multiply other:SELF :SELF <-
( + part1,part2,product:UINTEGER_64;
+ index_result:INTEGER;
-
+
lower.to upper do { idx:INTEGER;
+ result_current:UINTEGER_BIG;
-
+
result_current := 0;
result_current.resize count;
part1 := item idx;
index_result := idx;
(other.lower).to (other.upper) do { idx_other:INTEGER;
part2 := other.item idx_other;
- product := part1 * part2;
+ product := part1 * part2;
(product < (UINTEGER_32.maximum.to_uinteger_64)).if {
result_current.put (product.to_uinteger_32) to index_result;
} else {
@@ -268,24 +268,24 @@ Section Public
index_result := index_result + 1;
};
};
-
+
result := result + result_current;
-
+
};
result.clean;
result
);
-
+
- Self:SELF '*#' Left 100 other:INTEGER :SELF <-
(
+ result:UINTEGER_BIG;
+ part1,product,over:UINTEGER_64;
-
+
result := 0;
result.resize count;
- lower.to upper do { idx:INTEGER;
- part1 := item idx;
- product := part1 * other + over;
+ lower.to upper do { idx:INTEGER;
+ part1 := item idx;
+ product := part1 * other + over;
(product < (UINTEGER_32.maximum.to_uinteger_64)).if {
result.put (product.to_uinteger_32) to idx;
over := 0;
@@ -294,30 +294,30 @@ Section Public
over := product >> 32;
};
};
-
+
(over!==0).if {
result.add_last (over.to_uinteger_32);
- };
-
+ };
+
result.clean;
result
);
-
- - Self:SELF '/' Left 100 other:SELF :SELF <-
+
+ - Self:SELF '/' Left 100 other:SELF :SELF <-
( + result:UINTEGER_BIG;
-
-
+
+
);
-
-
+
+
- Self:SELF '/#' Left 100 other:INTEGER :SELF <-
( + result:SELF;
+ last_mod,div:UINTEGER_64;
+ idx:INTEGER;
-
+
result.resize count;
idx := upper;
- last_mod := item idx;
+ last_mod := item idx;
{idx < lower}.until_do {
div := 0;
(last_mod < other).if {
@@ -329,8 +329,8 @@ Section Public
};
} else {
div := last_mod / (other.to_uinteger_64);
- last_mod := last_mod % (other.to_uinteger_64);
- };
+ last_mod := last_mod % (other.to_uinteger_64);
+ };
(div !== 0).if {
result.put ((div & (UINTEGER_32.maximum.to_uinteger_64)).to_uinteger_32) to idx;
};
@@ -339,9 +339,9 @@ Section Public
result.clean;
result
);
-
+
- and_binary other:SELF :SELF <-
- (
+ (
(other.upper < upper).if {
storage.remove_tail (upper - other.upper);
};
@@ -350,22 +350,22 @@ Section Public
};
normalize;
);
-
+
- or_binary other:SELF :SELF <-
- (
+ (
lower.to (upper.min (other.upper)) do { i:INTEGER;
put (item i | other.item i) to i;
};
upper.to (other.upper) do { i:INTEGER;
add_last (other.item i);
- };
+ };
);
//
// Test binary operator :
//
-
- - Self:SELF '>' Right 60 other:SELF :BOOLEAN <-
+
+ - Self:SELF '>' Right 60 other:SELF :BOOLEAN <-
(
+ result:BOOLEAN;
(count > (other.count)).if {
@@ -386,14 +386,14 @@ Section Public
find := TRUE;
};
- i := i + 1;
+ i := i + 1;
};
};
-
+
result
);
-
-
+
+
- Self:SELF '>#' Right 60 other:INTEGER :BOOLEAN <-
(
+ result:BOOLEAN;
@@ -404,7 +404,7 @@ Section Public
};
result
);
-
+
- Self:SELF '==' Right 60 other:SELF :BOOLEAN <-
(
+ result:BOOLEAN;
@@ -418,61 +418,61 @@ Section Public
result := TRUE;
};
};
-
+
result
);
-
+
//
// Function.
//
- factorial_integer n:INTEGER <-
[ -? {n >= 0}; ]
- (
+ (
(n = 0).if {
set_with_zero;
put 1 to 0;
} else {
2.to n do { i:INTEGER;
- multiply_integer i;
+ multiply_integer i;
};
};
);
-
+
//
// conversion
//
-
- - append_in buffer:STRING <-
+
+ - append_in buffer:STRING <-
// Append in the `buffer' the equivalent of `to_string'. No new STRING
// creation during the process.
- ( + value:UINTEGER_BIG;
+ ( + value:UINTEGER_BIG;
+ mod:UINTEGER_32;
+ counter:INTEGER;
+ old_upper,new_upper:INTEGER;
-
+
old_upper:=buffer.upper + 1;
-
- (upper = 0).if {
+
+ (upper = 0).if {
item 0.append_in buffer;
} else {
value:=Self;
{
value:=value /# 1000000000;
- mod:=last_modulo;
+ mod:=last_modulo;
{counter==0}.until_do {
buffer.extend '0';
counter:=counter-1;
};
counter := 9;
- {
+ {
buffer.extend ((mod % 10).digit);
mod := mod / 10;
counter := counter-1;
}.do_while {mod!==0};
}.do_while {value!==0};
-
- new_upper := buffer.upper;
+
+ new_upper := buffer.upper;
// Swap.
{old_upper >= new_upper}.until_do {
@@ -482,30 +482,30 @@ Section Public
};
};
);
-
+
- print_positif <-
(
string_tmp.clear;
append_in string_tmp;
string_tmp.print;
);
-/*
+/*
- append_in buffer:STRING <-
( + val:SELF;
- + i,j:INTEGER;
+ + i,j:INTEGER;
? {buffer!=NULL};
-
+
(self == 0).if {
buffer.extend '0';
- } else {
- i := buffer.upper + 1;
+ } else {
+ i := buffer.upper + 1;
val.copy Self;
{val == 0}.until_do {
buffer.extend ((val %# 10).digit);
val := val /# 10;
};
j := buffer.upper;
-
+
{i >= j}.until_do {
buffer.swap i with j;
j := j - 1;
@@ -515,15 +515,15 @@ Section Public
);
*/
Section Public
-
+
- set_with_zero <-
(
storage.clear;
storage.add_last 0;
);
-
+
- is_zero:BOOLEAN <- ((storage.count = 1) && {storage.first = 0});
-
+
- compare other:SELF :INTEGER <-
// -1 if Self < other
// 0 if Self = other
@@ -531,7 +531,7 @@ Section Public
( + result,up_s,up_o:INTEGER;
+ v_s,v_o:INTEGER_32;
+ i:INTEGER;
-
+
up_s := upper;
up_o := other.upper;
(up_s = up_o).if {
@@ -551,13 +551,13 @@ Section Public
} else {
(up_s < up_o).if {
result := -1;
- } else {
+ } else {
result := 1;
};
};
result
);
-
+
- divide_one_word divisor:UINTEGER_32 :UINTEGER_32 <-
// This method is used by `divide'. The one word divisor is
// specified by `divisor' is saw as unsigned.
@@ -568,7 +568,7 @@ Section Public
( + i, remainder_word1, remainder_word0:INTEGER;
+ result:UINTEGER_32;
+ x:UINTEGER_64;
-
+
(count = 1).if {
result := first;
(result < divisor).if {
@@ -584,7 +584,7 @@ Section Public
remainder_word0 := item i;
x := (remainder_word1.to_uinteger_64 << 32) | remainder_word0;
remainder_word1 := x % divisor;
- put (x / divisor) to i;
+ put (x / divisor) to i;
i := i - 1;
};
(item upper = 0).if {
@@ -592,17 +592,17 @@ Section Public
? {item upper != 0};
};
result := remainder_word1;
- };
+ };
result
);
-
+
- normalize_shift:INTEGER_8 <-
// Shift left until the most significant bit is on.
// Result give the number of left shift.
[ -? {! is_zero}; ]
( + head:UINTEGER_32;
+ result:INTEGER_8;
-
+
head := item upper;
{(head & 8000_0000h) != 0}.until_do {
head := head << 1;
@@ -614,7 +614,7 @@ Section Public
result
)
[ +? {item upper < 0}; ];
-
+
- shift_left n:INTEGER <-
// Shift bits of magnitude by `n' position left. (Note that no bit can
// be lost because the `storage' area is automatically extended when
@@ -623,11 +623,11 @@ Section Public
( + left,right: INTEGER_8;
+ word_shift:INTEGER;
+ new_value:UINTEGER_32;
-
+
(last != 0).if {
word_shift := n >> 5;
- left := (n & 1Fh).to_integer_8; // Optimistic prediction
- right := 32 - left;
+ left := (n & 1Fh).to_integer_8; // Optimistic prediction
+ right := 32 - left;
((last >> right) = 0).if {
storage.add 0 first (word_shift+1);
word_shift.to (upper-1) do { i:INTEGER;
@@ -644,20 +644,20 @@ Section Public
new_value := item word_shift << left;
storage.put new_value to word_shift;
};
- };
+ };
);
-
+
- shift_right n:INTEGER <-
- // Shift bits of magnitude by `n' position right.
+ // Shift bits of magnitude by `n' position right.
[ -? {n > 0}; ]
( + left,right: INTEGER_8;
+ word_right:INTEGER;
+ new_value:UINTEGER_32;
-
+
(last != 0).if {
word_right := n >> 5;
- right := (n & 1Fh).to_integer_8; // Optimistic prediction
- left := 32 - right;
+ right := (n & 1Fh).to_integer_8; // Optimistic prediction
+ left := 32 - right;
word_shift.to (upper-1) do { i:INTEGER;
new_value := (item (i+1) << left) | (item i >> right);
storage.put new_value to (i - word_shift);
@@ -668,28 +668,28 @@ Section Public
} else {
storage.put new_value to (upper - word_shift);
storage.remove_tail word_shift;
- };
- };
+ };
+ };
);
-
- - multiply_and_subtract (u1, qhat: INTEGER, d_storage: FAST_ARRAY(UINTEGER_32),
+
+ - multiply_and_subtract (u1, qhat: INTEGER, d_storage: FAST_ARRAY(UINTEGER_32),
d_offset:INTEGER, r_storage:FAST_ARRAY(UINTEGER_32),r_offset, length: INTEGER):BOOLEAN <-
// Only used by `divide'.
[ -? {qhat != 0}; ]
- ( + i, j, jmax, m1, m2: INTEGER;
+ ( + i, j, jmax, m1, m2: INTEGER;
+ dec,result:BOOLEAN;
-
+
(qhat = 1).if {
i := d_offset;
j := r_offset;
- jmax := r_offset + length;
+ jmax := r_offset + length;
{j = jmax}.until_do {
(dec).if {
- x_32 := r_storage.item j - d_storage.item i - 1;
+ x_32 := r_storage.item j - d_storage.item i - 1;
dec := x_32 >= r_storage.item j;
r_storage.put x_32 to j;
} else {
- x_32 := r_storage.item j - d_storage.item i;
+ x_32 := r_storage.item j - d_storage.item i;
dec := x_32 > r_storage.item j;
r_storage.put x_32 to j;
};
@@ -700,11 +700,11 @@ Section Public
(u1 = 0).if {
result := TRUE;
} else {
- x_32 := r_storage.item j - 1;
+ x_32 := r_storage.item j - 1;
result := r_storage.item j = 0;
r_storage.put x_32 to j;
- ? {! result};
- };
+ ? {! result};
+ };
};
} else {
i := d_offset;
@@ -715,11 +715,11 @@ Section Public
m2 := (x & 0FFFF_FFFFh).to_uinteger_32;
m1 := (x >> 32).to_uinteger_32;
(dec).if {
- x_32 := r_storage.item j - m2 - 1;
+ x_32 := r_storage.item j - m2 - 1;
dec := x_32 >= r_storage.item j;
r_storage.put x_32 to j;
} else {
- x_32 := r_storage.item j - m2;
+ x_32 := r_storage.item j - m2;
dec := x_32 > r_storage.item j;
r_storage.put x_32 to j;
};
@@ -730,7 +730,7 @@ Section Public
(u1 = 0).if {
result := TRUE;
} else {
- x_32 := r_storage.item j - m1 - 1;
+ x_32 := r_storage.item j - m1 - 1;
result := x_32 >= r_storage.item j;
r_storage.put x_32 to j;
};
@@ -739,7 +739,7 @@ Section Public
}.elseif {u1 = 0} then {
result := TRUE;
} else {
- x_32 := r_storage.item j - m1;
+ x_32 := r_storage.item j - m1;
result := x_32 > r_storage.item j;
r_storage.put x_32 to j;
};
@@ -751,15 +751,15 @@ Section Public
r_storage:FAST_ARRAY(UINTEGER_32),r_offset, length:INTEGER):BOOLEAN <-
// Only used by `divide'.
// `old_u1' is the value of `u1' before `multiply_and_subtract'.
- ( + i, j, jmax:INTEGER;
+ ( + i, j, jmax:INTEGER;
+ inc,result:BOOLEAN;
-
+
i := d_offset;
j := r_offset;
jmax := r_offset + length;
- {j = jmax}.until_do {
+ {j = jmax}.until_do {
(inc).if {
- x_32 := r_storage.item j + d_storage.item i + 1;
+ x_32 := r_storage.item j + d_storage.item i + 1;
inc := x_32 <= r_storage.item j;
r_storage.put x_32 to j;
} else {
@@ -786,19 +786,19 @@ Section Public
-? {other != NULL};
-? {quotient != NULL};
-? {remainder != NULL};
- ]
- ( + v:SELF;
+ ]
+ ( + v:SELF;
v := other.twin;
v.multiply quotient;
v.add remainder;
Self == v
);
-
+
- divide_to (other, quotient, remainder:SELF) <-
// Euclidian division.
// Calculates the `quotient' and `remainder' of `Current'
// divided by `other'. (The contents of `Current' and `other' are
- // not changed.)
+ // not changed.)
// Note: Uses Algorithm D in Knuth
[ -? {! other.is_zero};
-? {quotient != NULL};
@@ -809,43 +809,43 @@ Section Public
-? {remainder != Self};
]
( + cmp, shift, nlen, dlen, qlen, j, k, v1, v2, u1, u2, rem: INTEGER;
- + qhat, rhat, v2qhat_1, v2qhat_2, d_offset: INTEGER;
+ + qhat, rhat, v2qhat_1, v2qhat_2, d_offset: INTEGER;
+ q_storage, r_storage, d_storage:FAST_ARRAY(UINTEGER_32);
+ q_capacity, r_capacity:INTEGER;
+ borrow:BOOLEAN;
-
+
(is_zero).if {
// Dividend is zero:
quotient.set_with_zero;
remainder.set_with_zero;
} else {
cmp := compare other;
- (cmp < 0).if {
+ (cmp < 0).if {
// Dividend less than divisor:
quotient.set_with_zero;
- remainder.copy Self;
+ remainder.copy Self;
}.elseif {cmp = 0} then {
- // Dividend equal to divisor:
+ // Dividend equal to divisor:
quotient.from_integer 1;
remainder.set_with_zero;
}.elseif {other.count = 1} then {
// Special case one word divisor:
- quotient.copy Self;
+ quotient.copy Self;
remainder.storage.clear;
- rem := quotient.divide_one_word (other.first);
- remainder.add_last rem;
+ rem := quotient.divide_one_word (other.first);
+ remainder.add_last rem;
} else {
// Copy divisor storage to protect divisor:
register1.copy other;
remainder.copy Self;
// D1 normalize the divisor:
- shift := register1.normalize_shift;
+ shift := register1.normalize_shift;
(shift != 0).if {
remainder.shift_left shift;
};
- // D2 Initialize j:
+ // D2 Initialize j:
r_storage := remainder.storage;
- r_capacity := remainder.capacity;
+ r_capacity := remainder.capacity;
nlen := remainder.count; // To avoid invariant class violation
remainder.set_with_zero;
d_storage := register1.storage;
@@ -877,11 +877,11 @@ Section Public
};
// To avoid invariant violation on quotient
quotient.set_with_zero;
- {k < 0}.until_do {
+ {k < 0}.until_do {
j := j - 1; // D3 Calculate qhat - estimate qhat
(u1 = v1).if {
qhat := ~0;
- } else {
+ } else {
x := (u1.to_uinteger_64 << 32) | u2;
rhat := (x % v1).to_uinteger_32;
qhat := (x / v1).to_uinteger_32; // Correct qhat
@@ -928,10 +928,10 @@ Section Public
(borrow).if {
// D6 Add back
borrow := add_back(u1, d_storage, d_offset, r_storage, j - dlen + 2, dlen);
- ? {borrow};
+ ? {borrow};
q_storage.put (qhat - 1) to k;
} else {
- q_storage.put qhat to k;
+ q_storage.put qhat to k;
};
};
// D7 loop on j
@@ -946,24 +946,24 @@ Section Public
};
quotient.set_all(q_storage, q_capacity, qlen, 0, FALSE);
// Remove leading zero of remainder
- j := dlen - 1;
+ j := dlen - 1;
{(j < 0) || {r_storage.item j != 0}}.until_do {
j := j - 1;
};
j := j + 1;
? {j >= 0};
(j = 0).if {
- ? {remainder.is_zero};
+ ? {remainder.is_zero};
} else {
remainder.set_all(r_storage, r_capacity, j, 0, FALSE);
};
// D8 Unnormalize:
(shift > 0).if {
remainder.shift_right shift;
- };
+ };
};
};
)
- [
- ? {is_a_good_divide(other, quotient, remainder)};
+ [
+ ? {is_a_good_divide(other, quotient, remainder)};
];
diff --git a/lib/standard/number/integer/uinteger_cpu.li b/lib/standard/number/integer/uinteger_cpu.li
index 5382811..87d040b 100644
--- a/lib/standard/number/integer/uinteger_cpu.li
+++ b/lib/standard/number/integer/uinteger_cpu.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded UINTEGER_CPU;
- export := UINTEGER_64, POINTER;
-
+
- comment := "Unsigned integer (variable size according to CPU word).";
-
+
- type := `unsigned long`;
- default := (0.to_raw_uinteger_cpu);
Section Insert
-
+
- parent_unsigned_integer:UNSIGNED_INTEGER := UNSIGNED_INTEGER;
-
+
Section Public
-
+
- object_size:INTEGER <- `sizeof(unsigned long)`:INTEGER;
//
// Range.
//
-
+
- maximum:UINTEGER_64 := (~ 0.to_uinteger_cpu).to_raw_uinteger_64;
-
+
//
// Conversion with test.
//
-
+
- to_uinteger_64:UINTEGER_64 <- to_raw_uinteger_64;
-
+
- to_pointer:POINTER <- to_raw_pointer;
\ No newline at end of file
diff --git a/lib/standard/number/real/real.li b/lib/standard/number/real/real.li
index 25cddfe..a0d6f60 100644
--- a/lib/standard/number/real/real.li
+++ b/lib/standard/number/real/real.li
@@ -19,9 +19,9 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL;
-
+
- export :=
REAL_32, REAL_64, REAL_80,
REAL_16_16, REAL_24_8, REAL_26_6,
@@ -29,28 +29,28 @@ Section Header
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag, 2007 Xavier Oswald";
- comment := "Generic real number.";
-
+
- type := `float`;
- default := 0.0;
-
+
- lip <-
(
add_lib "-lm";
);
Section Insert
-
+
- inherit_numeric:NUMERIC := NUMERIC;
-
+
Section Public
-
+
- Self:SELF '+' Left 80 other:SELF :SELF <- `@Self + @other`:SELF;
- - bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
+ - bound_test low:INTEGER_64 to up:UINTEGER_64 :BOOLEAN <-
(
TRUE
);
-
+
- pi :SELF <- 3.14159265358979323846;
// Pi number
@@ -78,7 +78,7 @@ Section Public
Self.pow exp
);
- - Self:SELF '^' Right 120 exp:SELF :SELF <-
+ - Self:SELF '^' Right 120 exp:SELF :SELF <-
// Power
(
Self.pow exp
@@ -87,46 +87,46 @@ Section Public
//
// Convertion format with test.
//
-
+
- floor:INTEGER <-
// Greatest integral value no greater than Current.
- (
+ (
to_raw_integer
);
-
+
- ceiling:INTEGER <-
// Smallest integral value no smaller than Current.
- (
+ (
(Self + 0.9999).floor
);
-
+
- rounded:INTEGER <-
// Rounded integral value.
(
(Self + 0.5).floor
);
-
+
- truncated_to_integer:INTEGER <- floor;
// Integer part (largest absolute value no greater than Current).
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' other:SELF :BOOLEAN <-
// Equal, close to 0.001
(
(Self - other).abs < 0.001
);
-
+
- is_not_a_number:BOOLEAN <- deferred;
-
+
- is_infinity:BOOLEAN <- deferred;
-
+
//
// Print.
//
-
+
- append_in buffer:STRING <-
// Append `Self' decimal representation in `buffer' with 4 decimal
(
@@ -141,31 +141,31 @@ Section Public
append_in result;
result
);
-
+
- append_in buffer:STRING format n:INTEGER decimal d:INTEGER <-
(
append_in buffer format n with ' ' decimal d;
);
-
+
- append_in buffer:STRING format n:INTEGER with c:CHARACTER decimal d:INTEGER <-
- // String of the number in base 10 with `c' replacing blanck
- [
+ // String of the number in base 10 with `c' replacing blanck
+ [
-? {n >= 3};
]
( + old_count:INTEGER;
-
+
old_count := buffer.count;
append_in buffer decimal d;
buffer.insert c to old_count on (n - (buffer.count - old_count));
);
-
+
- append_in buffer:STRING decimal n:INTEGER <-
// String of the number in base 10 with 4 decimal
( + val:SELF;
- + val_10:INTEGER;
+ + val_10:INTEGER;
+ char:CHARACTER;
+ i:INTEGER;
-
+
get_map Self;
// Sign.
(sign).if {
@@ -173,9 +173,9 @@ Section Public
} else {
buffer.add_last '-';
val := - Self;
- };
+ };
(is_zero).if {
- // Zero case.
+ // Zero case.
buffer.add_last '0';
}.elseif {is_infinite} then {
// Infinite case.
@@ -183,38 +183,38 @@ Section Public
}.elseif {is_nan} then {
// Nan case.
buffer.append "Nan";
- } else {
+ } else {
// Value case = 1.mantisse x 2^(exp-127)
(val > INTEGER.maximum.to_real_32).if {
scientific_append_in buffer;
} else {
- val_10 := val.to_integer;
- val_10.append_in buffer;
- val := val - val_10;
+ val_10 := val.to_integer;
+ val_10.append_in buffer;
+ val := val - val_10;
(n != 0).if {
buffer.add_last '.';
i := n;
- {(val != 0) && {i > 0}}.while_do {
+ {(val != 0) && {i > 0}}.while_do {
val := val * 10;
val_10 := val.to_integer;
char := val_10.decimal_digit;
buffer.add_last char;
val := val - val_10;
i := i - 1;
- };
+ };
buffer.extend_multiple '0' by i;
};
};
- };
+ };
);
-
- - scientific_append_in buffer:STRING <-
+
+ - scientific_append_in buffer:STRING <-
// Scientific number representation
( + val:SELF;
+ val_10:INTEGER;
+ exp_10:INTEGER;
+ char:CHARACTER;
-
+
get_map Self;
// Sign.
(sign).if {
@@ -222,7 +222,7 @@ Section Public
} else {
buffer.add_last '-';
val := - Self;
- };
+ };
(is_zero).if {
// Zero case.
buffer.add_last '0';
@@ -247,7 +247,7 @@ Section Public
buffer.add_last char;
buffer.add_last '.';
val := val - val_10;
- {val != 0}.while_do {
+ {val != 0}.while_do {
val := val * 10;
val_10 := val.to_integer;
char := val_10.decimal_digit;
@@ -258,19 +258,19 @@ Section Public
exp_10.append_in buffer;
};
);
-
+
- append_in buffer:STRING format_c fmt:ABSTRACT_STRING <-
- ( + nc_buf,nc_fmt:NATIVE_ARRAY(CHARACTER);
+ ( + nc_buf,nc_fmt:NATIVE_ARRAY(CHARACTER);
+ old_count,cap:INTEGER;
-
+
old_count := buffer.count;
cap := buffer.capacity - old_count;
nc_buf := buffer.to_external + old_count;
nc_fmt := fmt.to_external;
`snprintf(@nc_buf, at cap, at nc_fmt, at Self)`;
buffer.restore_after_external;
- );
-
+ );
+
- print_decimal s:INTEGER <-
// print with `s' decimal
(
@@ -278,17 +278,17 @@ Section Public
append_in string_tmp decimal s;
string_tmp.print;
);
-
+
- print_int i:INTEGER decimal d:INTEGER <-
(
print_format (i+d+1) decimal d;
);
-
+
- print_format s:INTEGER decimal d:INTEGER <-
[
-? {s > d};
]
- (
+ (
print_format s with ' ' decimal d;
);
@@ -296,16 +296,16 @@ Section Public
[
-? {s > d};
]
- (
+ (
string_tmp.clear;
append_in string_tmp format s with c decimal d;
string_tmp.print;
);
-
+
- print_format_c fmt:ABSTRACT_STRING <-
(
string_tmp.clear;
append_in string_tmp format_c fmt;
string_tmp.print;
);
-
+
diff --git a/lib/standard/number/real/real_32.li b/lib/standard/number/real/real_32.li
index 83020d4..7c2c3ce 100644
--- a/lib/standard/number/real/real_32.li
+++ b/lib/standard/number/real/real_32.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL_32;
- export := REAL, REAL_64, REAL_80;
-
+
- comment := "Float (C `float' mapping).";
-
+
- type := `float`;
- default := (0.to_raw_real_32);
-
+
Section Insert
-
+
- parent_float_map32:FLOAT_MAP32 := FLOAT_MAP32;
- parent_float_real:FLOAT_REAL := FLOAT_REAL;
-
+
diff --git a/lib/standard/number/real/real_64.li b/lib/standard/number/real/real_64.li
index 44d9ec0..28eb47f 100644
--- a/lib/standard/number/real/real_64.li
+++ b/lib/standard/number/real/real_64.li
@@ -19,23 +19,23 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL_64;
- export := REAL, REAL_80;
-
+
- comment := "Float (C `double' mapping).";
-
+
- type := `double`;
- default := (0.to_raw_real_64);
-
+
Section Insert
-
+
- parent_float_map64:FLOAT_MAP64 := FLOAT_MAP64;
-
+
- parent_float_real:FLOAT_REAL := FLOAT_REAL;
-
-
-
-
+
+
+
+
diff --git a/lib/standard/number/real/real_80.li b/lib/standard/number/real/real_80.li
index 010d493..ed47fa0 100644
--- a/lib/standard/number/real/real_80.li
+++ b/lib/standard/number/real/real_80.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded REAL_80;
- export := REAL;
-
+
- comment := "Float 80 bits (C `long double' mapping).";
-
+
- type := `long double`;
- default := (0.to_raw_real_80);
-
+
Section Insert
-
+
- parent_float_map80:FLOAT_MAP80 := FLOAT_MAP80;
- parent_float_real:FLOAT_REAL := FLOAT_REAL;
-
+
diff --git a/lib/standard/property/comparable.li b/lib/standard/property/comparable.li
index d4df7bc..787a70b 100644
--- a/lib/standard/property/comparable.li
+++ b/lib/standard/property/comparable.li
@@ -19,22 +19,22 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COMPARABLE;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := " All classes handling COMPARABLE objects with a total order\
\relation should inherit from this class.";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
- - Self:SELF '==' Right 60 other:E :BOOLEAN <-
+
+ - Self:SELF '==' Right 60 other:E :BOOLEAN <-
( + result:BOOLEAN;
+ same:SELF;
same ?= other;
@@ -53,11 +53,11 @@ Section Public
// Is `self' less than or equal `other'?
(
+ result:BOOLEAN;
-
+
? { other != NULL };
result := ! (other < Self);
? { result = ((Self < other) | == other)};
-
+
result
);
@@ -74,7 +74,7 @@ Section Public
?{ other != NULL };
! (Self < other)
);
-
+
- in_range lower:SELF to upper:SELF :BOOLEAN <-
// Return true if `self' is in range [`lower'..`upper']
(
@@ -94,7 +94,7 @@ Section Public
} else {
result := 0;
};
-
+
? { (result = 0) = ( == other)};
? { (result = -1) = (Self < other)};
? { (result = 1) = (Self > other)};
@@ -106,27 +106,27 @@ Section Public
// Minimum of `self' and `other'.
(
+ result:SELF;
-
+
?{ other != NULL };
( Self <= other ).if {
result := Self;
} else {
result := other;
};
-
+
? { (result <= Self) && { result <= other}};
? { (compare result = 0) || { other.compare result = 0 }};
-
+
result
);
-
-
+
+
- max other:SELF :SELF <-
// Maximum of `self' and `other'.
(
+ result:SELF;
?{ other != NULL };
-
+
( Self >= other ).if {
result := Self;
} else {
diff --git a/lib/standard/property/hashable.li b/lib/standard/property/hashable.li
index 7e136e6..7db6847 100644
--- a/lib/standard/property/hashable.li
+++ b/lib/standard/property/hashable.li
@@ -19,20 +19,20 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := HASHABLE;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :=" .";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
+
- hash_code:INTEGER <-
// The hash-code value of `Current'.
(
diff --git a/lib/standard/property/safe_equal.li b/lib/standard/property/safe_equal.li
index 6b851b0..d3e215d 100644
--- a/lib/standard/property/safe_equal.li
+++ b/lib/standard/property/safe_equal.li
@@ -19,23 +19,23 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SAFE_EQUAL(E);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment :="The goal of this class is to share the definition of \
\feature `safe_equal'. Feature `safe_equal' compares \
\two arguments of type E, by calling `==' only \
\and only if both arguments have the `same_type'..";
-
+
Section Inherit
-
+
- parent:OBJECT := OBJECT;
-
+
Section Public
-
+
- safe_equal (e1, e2:E) :BOOLEAN <-
// In order to avoid run-time type errors, feature `safe_equal' call
// `==' only when `e1' and `e2' have exactly the same `generating_type'.
@@ -44,7 +44,7 @@ Section Public
// allocation of some reference type during the comparison).
( /*
+ result:BOOLEAN;
-
+
( e1.is_basic_expanded_type).if { then
result := (e1 = e2);
}.elseif {e1.is_expanded_type} then {
@@ -55,10 +55,10 @@ Section Public
}.elseif {e1.generating_type = e2.generating_type} then {
result := e1 == e2;
}; // end if
-
+
result
*/
(e1=e2) || {(e1!=NULL) && {e1==e2}}
);
-
+
diff --git a/lib/standard/property/traversable.li b/lib/standard/property/traversable.li
index c47a9cf..1aeaa68 100644
--- a/lib/standard/property/traversable.li
+++ b/lib/standard/property/traversable.li
@@ -19,18 +19,18 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TRAVERSABLE(V);
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "A `TRAVERSABLE(E_)' is a finite readable sequence of objects of type E_.";
-
+
// For instance, `COLLECTION's and `STRING's are `TRAVERSABLE'.
//
- // A good performance should always be obtained by sequentially acessing a
- // `TRAVERSABLE' with increasing indexes (from `lower' to `upper'), as
+ // A good performance should always be obtained by sequentially acessing a
+ // `TRAVERSABLE' with increasing indexes (from `lower' to `upper'), as
// demonstrated in the following code snippet :
//
// i := a_traversable.lower;
@@ -39,20 +39,20 @@ Section Header
// i := i + 1;
// };
//
- // Other accessing methods (including random access and sequential access
- // from `upper' to `lower') may or may not lead to acceptable performance,
+ // Other accessing methods (including random access and sequential access
+ // from `upper' to `lower') may or may not lead to acceptable performance,
// depending on the particular implementation of `TRAVERSABLE'.
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
+
//
// Indexing:
//
-
+
- lower:INTEGER <-
// Minimum index.
//
@@ -69,23 +69,23 @@ Section Public
(
deferred;
0
- );
-
+ );
+
- valid_index i:INTEGER :BOOLEAN <-
// True when `i' is valid (i.e., inside actual bounds).
//
// See also `lower', `upper', `item'.
- (
+ (
(lower <= i) && {i <= upper}
)
- [
+ [
"Definition." +? {Result = ((lower <= i) & (i <= upper))};
];
//
// Counting:
//
-
+
- count:INTEGER <-
// Number of available indices.
//
@@ -108,11 +108,11 @@ Section Public
[
"Definition." +? {Result = (count = 0)};
];
-
+
//
// Accessing:
//
-
+
- item i:INTEGER :V <-
// Item at the corresponding index `i'.
//
@@ -135,7 +135,7 @@ Section Public
(
item lower
)
- [
+ [
"Definition." +? {Result = item lower};
];
@@ -143,7 +143,7 @@ Section Public
// The `last' item.
//
// See also `first', `item'.
- [
+ [
-? {! is_empty};
]
(
@@ -152,7 +152,7 @@ Section Public
[
"Definition." +? {Result = item upper};
];
-
+
//
// Iterate:
//
diff --git a/lib/standard/string/character.li b/lib/standard/string/character.li
index 2a9d8e3..1517504 100644
--- a/lib/standard/string/character.li
+++ b/lib/standard/string/character.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded CHARACTER;
- export := INTEGER_8, CHAR_UNICODE;
@@ -30,25 +30,25 @@ Section Header
- type := `char`;
- default := '\0';
-
+
Section Insert
-
+
- parent_character_ref:CHARACTER_REF := CHARACTER_REF;
-
+
Section Public
-
+
- in_range lower:SELF to upper:SELF :BOOLEAN <- ((Self >= lower) && {Self<= upper});
-
+
//
// General :
//
-
+
- object_size:INTEGER := 1;
-
+
- maximum:INTEGER := 255;
-
+
- minimum:INTEGER := 0;
-
+
- to_integer:INTEGER <-
// Sign-extended conversion.
( + result:INTEGER;
@@ -56,7 +56,7 @@ Section Public
? {result.in_range (INTEGER_8.minimum) to (INTEGER_8.maximum)};
result
);
-
+
- code:INTEGER_8 <-
// ASCII code of Current.
// No Sign-extended conversion.
@@ -65,22 +65,22 @@ Section Public
//? {result.in_range minimum to maximum};
result
);
-
+
- to_integer_8:INTEGER_8 <- CONVERT(CHARACTER,INTEGER_8).on Self;
// Auto-cast.
-
+
- to_uinteger_8:UINTEGER_8 <- CONVERT(CHARACTER,UINTEGER_8).on Self;
-
+
//
// Print.
//
-
+
- print <- IO.put_character Self;
-
+
//
// Switch case :
//
-
+
- when value:CHARACTER then block:{} :CHARACTER <-
(
(Self=value).if block;
@@ -92,7 +92,7 @@ Section Public
((Self = value1) || {Self = value2}).if block;
Self
);
-
+
- when first_value:CHARACTER to last_value:CHARACTER then block:{} :CHARACTER <-
( ? {first_value<=last_value};
@@ -103,7 +103,7 @@ Section Public
//
// Looping.
//
-
+
- to limit_up:SELF do blc:{CHARACTER;} <-
(
(Self<=limit_up).if {
@@ -111,7 +111,7 @@ Section Public
(Self+1.to_character).to limit_up do blc;
};
);
-
+
- downto limit_down:SELF do blc:{CHARACTER;} <-
(
(Self>=limit_down).if {
@@ -119,7 +119,7 @@ Section Public
(Self-1.to_character).downto limit_down do blc;
};
);
-
+
- to limit_up:SELF by step:SELF do blc:{CHARACTER;} <-
(
(Self<=limit_up).if {
@@ -127,7 +127,7 @@ Section Public
(Self+step.to_character).to limit_up by step do blc;
};
);
-
+
- downto limit_down:SELF by step:SELF do blc:{CHARACTER;} <-
(
(Self>=limit_down).if {
@@ -135,33 +135,33 @@ Section Public
(Self-step.to_character).downto limit_down by step do blc;
};
);
-
+
//
// Binary operator :
//
-
+
- Self:SELF '+' other:CHARACTER :CHARACTER <- (code+other.code).to_character;
-
+
- Self:SELF '-' other:CHARACTER :CHARACTER <- (code-other.code).to_character;
- Self:SELF '-!' other:CHARACTER :INTEGER <- code - other.code;
-
+
- Self:SELF '+#' other:INTEGER :CHARACTER <- (code + other).to_character;
- Self:SELF '-#' other:INTEGER :CHARACTER <- (code - other).to_character;
-
+
- Self:SELF '<' other:SELF :BOOLEAN <- ( code < other.code );
// Comparison using `code'.
-
+
- Self:SELF '<=' other:SELF :BOOLEAN <- ( code <= other.code );
// Comparison using `code'.
-
+
- Self:SELF '>' other:SELF :BOOLEAN <- ( code > other.code );
// Comparison using `code'.
-
+
- Self:SELF '>=' other:SELF :BOOLEAN <- ( code >= other.code );
// Comparison using `code'.
-
+
- decimal_value:INTEGER <-
// Gives the value of a decimal digit.
( + result:INTEGER;
@@ -170,7 +170,7 @@ Section Public
? {result.in_range 0 to 9};
result
);
-
+
- binary_value:INTEGER <-
// Gives the value of a binary digit.
( + result:INTEGER;
@@ -179,7 +179,7 @@ Section Public
? {result.in_range 0 to 1};
result
);
-
+
- octal_value:INTEGER <-
// Gives the value of an octal digit.
( + result:INTEGER;
@@ -188,7 +188,7 @@ Section Public
? {result.in_range 0 to 7};
result
);
-
+
- hexadecimal_value:INTEGER <-
// Gives the value of an hexadecimal digit.
( + result:INTEGER;
@@ -203,7 +203,7 @@ Section Public
? {result.in_range 0 to 15};
result
);
-
+
- same_as other:CHARACTER :BOOLEAN <-
// Case insensitive comparison.
// No difference between upper/lower case letters.
@@ -222,7 +222,7 @@ Section Public
};
result
);
-
+
- to_upper:SELF <-
// Conversion to the corresponding upper case.
( + result:SELF;
@@ -233,7 +233,7 @@ Section Public
};
result
);
-
+
- to_lower:SELF <-
// Conversion to the corresponding lower case.
( + result:SELF;
@@ -244,7 +244,7 @@ Section Public
};
result
);
-
+
- is_letter:BOOLEAN <-
// Is it a letter ('a' .. 'z' or 'A' .. 'Z') ?
( + result:BOOLEAN;
@@ -256,7 +256,7 @@ Section Public
? {result = (in_range 'A' to 'Z' | in_range 'a' to 'z')};
result
);
-
+
- is_digit:BOOLEAN <-
// Belongs to '0'..'9'.
( + result:BOOLEAN;
@@ -266,7 +266,7 @@ Section Public
? {result = in_range '0' to '9'};
result
);
-
+
- is_binary_digit:BOOLEAN <-
// Belongs to '0'..'1'.
( + result:BOOLEAN;
@@ -274,7 +274,7 @@ Section Public
? {result = in_range '0' to '1'};
result
);
-
+
- is_octal_digit:BOOLEAN <-
// Belongs to '0'..'7'.
( + result:BOOLEAN;
@@ -284,7 +284,7 @@ Section Public
? {result = in_range '0' to '7'};
result
);
-
+
- is_hexadecimal_digit:BOOLEAN <-
// Is it one character of "0123456789abcdefABCDEF" ?
( + result:BOOLEAN;
@@ -298,7 +298,7 @@ Section Public
? {result = ("0123456789abcdefABCDEF".has Self)};
result
);
-
+
- is_lower:BOOLEAN <-
// Is it some lowercase letter ('a'..'z')?
( + result:BOOLEAN;
@@ -307,7 +307,7 @@ Section Public
};
result
);
-
+
- is_upper:BOOLEAN <-
// Is it some uppercase letter ('A'..'Z')?
( + result:BOOLEAN;
@@ -316,14 +316,14 @@ Section Public
};
result
);
-
+
- is_separator:BOOLEAN <-
// True when character is a separator (' ', '\t', '\n', '\r', '\0', '\f', '\v')?
(
(Self= ' ') || {Self = '\t'} || {Self='\n'} ||
{Self='\r'} || {Self = '\0'} || {Self='\f'} || {Self='\v'}
);
-
+
- is_letter_or_digit:BOOLEAN <-
// Is it a letter (see `is_letter') or a digit (see `is_digit') ?
( + result:BOOLEAN;
@@ -331,35 +331,35 @@ Section Public
? {result = (is_letter | is_digit)};
result
);
-
+
- is_identifier:BOOLEAN <-
// Is it a letter or a digit or '_' ?
(
(is_letter_or_digit) || {Self = '_'}
);
-
+
- is_ascii:BOOLEAN := TRUE;
// Is character a 8-bit ASCII character?
-
+
- is_bit:BOOLEAN <- ((Self='0') || {Self='1'});
// True for `0' and `1'.
-
+
- next:CHARACTER <-
// Give the next character (the following `code');
( ? {code<255};
(code + 1).to_character
);
-
+
- previous:CHARACTER <-
// Give the previous character (the `code' before);
( ? {code > 0};
(code - 1).to_character
);
-
+
//
// Conversions:
//
-
+
- to_string:STRING <-
// Create a new STRING containing only this character.
(
@@ -385,13 +385,13 @@ Section Public
? {result.count = 2};
result
);
-
+
- to_hexadecimal_in str:STRING <-
// Append the equivalent of `to_hexadecimal' at the end of
// `str'. Thus you can save memory because no other
// STRING is allocate for the job.
( + c, old_count:INTEGER;
-
+
old_count:=str.count;
c := code >> 4;
(c<10).if {
@@ -407,11 +407,11 @@ Section Public
};
? {str.count = (2 + old_count)};
);
-
+
//
// Miscellaneous:
//
-
+
- is_alpha:BOOLEAN <-
// See `is_letter' (yes this is just a call to `is_letter').
// Isn't `is_letter' better English ;-)
@@ -420,12 +420,12 @@ Section Public
? {result = is_letter};
result
);
-
+
//
// Hashing :
//
-
+
- hash_code: INTEGER <- code;
-
-
+
+
diff --git a/lib/standard/string/string.li b/lib/standard/string/string.li
index f3e7187..2f76595 100644
--- a/lib/standard/string/string.li
+++ b/lib/standard/string/string.li
@@ -76,7 +76,7 @@ Section Public
// characters of storage.
( ? {needed_capacity >= 0};
(needed_capacity > 0).if {
- (capacity < needed_capacity).if {
+ (capacity < needed_capacity).if {
storage := NATIVE_ARRAY(CHARACTER).create needed_capacity;
capacity := needed_capacity;
};
diff --git a/lib/standard/string/string_constant.li b/lib/standard/string/string_constant.li
index 2817305..06bab2a 100644
--- a/lib/standard/string/string_constant.li
+++ b/lib/standard/string/string_constant.li
@@ -19,64 +19,64 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
- + name := Strict STRING_CONSTANT;
+
+ + name := Strict STRING_CONSTANT;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "String built in.";
-
+
Section Inherit
-
+
- inherit_abstract_string:ABSTRACT_STRING := ABSTRACT_STRING;
-
+
Section Public
-
- + storage:NATIVE_ARRAY(CHARACTER);
-
+
+ + storage:NATIVE_ARRAY(CHARACTER);
+
+ count:INTEGER;
-
+
Section Public
-
+
- to_string:STRING <-
( + new:Strict STRING;
new := STRING.create capacity;
new.copy Self;
new
);
-
+
Section Public
- capacity:INTEGER <- count;
-
+
//
// Aliasing String.
//
-
+
- bucket:SET(STRING_CONSTANT) := SET(STRING_CONSTANT).make;
-
+
//
// The Guru section: The Compiler consideration.
//
-
+
- set_storage p:NATIVE_ARRAY(CHARACTER) count nb_char:INTEGER <-
// Do not use directly.
(
storage := p;
count := nb_char;
);
-
+
- new_intern p:NATIVE_ARRAY(CHARACTER) count nb_char:INTEGER :STRING_CONSTANT<-
- // Do not use directly. WARNING: Use by c_string and c_argument (COMMAND_LINE).
+ // Do not use directly. WARNING: Use by c_string and c_argument (COMMAND_LINE).
( + result:STRING_CONSTANT;
-
+
result := clone;
- result.set_storage p count nb_char;
+ result.set_storage p count nb_char;
//bucket.add result;
result
);
-
+
- to_external:NATIVE_ARRAY(CHARACTER) <-
// Gives C access to the internal `storage' (may be dangerous).
// To be compatible with C, a null character is added at the end
@@ -88,15 +88,15 @@ Section Public
- create_copy other:ABSTRACT_STRING :SELF <-
( + result:SELF;
-
+
result := clone;
result.make_copy other;
result
);
-
+
- make_copy other:ABSTRACT_STRING <-
( + c:INTEGER;
-
+
c := other.count;
(c != 0).if {
storage := NATIVE_ARRAY(CHARACTER).create (c+1);
@@ -109,11 +109,11 @@ Section Public
//
// Debug: Require / Ensure / Check
//
-
+
- Self:SELF '?' test:{BOOLEAN} <- test ? Self;
-
+
- Self:SELF '-?' test:{BOOLEAN} <- test -? Self;
-
+
- Self:SELF '+?' test:{BOOLEAN} <- test +? Self;
-
+
diff --git a/lib/standard/time/time.li b/lib/standard/time/time.li
index c5a1a01..3b4f127 100644
--- a/lib/standard/time/time.li
+++ b/lib/standard/time/time.li
@@ -19,23 +19,23 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded TIME;
- copyright := "2003-2005 Jérome Boutet, 2003-2007 Benoit Sonntag";
-
+
- comment := "Time";
-
+
- type := `unsigned long`;
-
+
- default := `0`:TIME;
-
+
Section Insert
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Private
-
+
- to_raw:UINTEGER_32 <-
(
CONVERT(SELF, UINTEGER_32).on Self
@@ -47,12 +47,12 @@ Section Public
(
(to_raw >> 24).to_uinteger_8
);
-
+
- minute:UINTEGER_8 <-
(
((to_raw & 0FF0000h) >> 16).to_uinteger_8
);
-
+
- second:UINTEGER_8 <-
(
((to_raw & 0FF00h) >> 8).to_uinteger_8
@@ -62,73 +62,73 @@ Section Public
(
(to_raw & 0FFh).to_uinteger_8
);
-
+
Section Public
-
+
- Self:SELF '>' Right 60 other:SELF :BOOLEAN <- to_raw > other.to_raw;
-
+
- Self:SELF '<' Right 60 other:SELF :BOOLEAN <- to_raw < other.to_raw;
-
+
- Self:SELF '>=' Right 60 other:SELF :BOOLEAN <- to_raw >= other.to_raw;
-
+
- Self:SELF '<=' Right 60 other:SELF :BOOLEAN <- to_raw <= other.to_raw;
-
- - to_csecond:INTEGER <- hour.to_integer * (60*60*100) +
- minute.to_integer * (60*100) +
- second.to_integer * 100 +
+
+ - to_csecond:INTEGER <- hour.to_integer * (60*60*100) +
+ minute.to_integer * (60*100) +
+ second.to_integer * 100 +
csecond;
-
- - Self:SELF '-' Right 60 other:SELF :SELF <-
- (
+
+ - Self:SELF '-' Right 60 other:SELF :SELF <-
+ (
create_csecond (Self -# other)
);
-
+
// BSBS: A uniformiser -# +# ???
-
+
- Self:SELF '-#' Right 60 other:SELF :INTEGER <- to_csecond - other.to_csecond;
-
+
- Self:SELF '+#' Right 60 other:INTEGER :TIME <-
- (
+ (
create_csecond (to_csecond + other)
);
-
+
- create (h,m,s,cs:INTEGER) :TIME <-
( + t:UINTEGER_32;
? {h.in_range 0 to 23};
? {m.in_range 0 to 59};
? {s.in_range 0 to 59};
? {cs.in_range 0 to 99};
-
+
t := h.to_uinteger_32 <<24;
t := t | (m.to_uinteger_32 << 16);
t := t | (s.to_uinteger_32 << 8);
t := t | cs;
CONVERT(UINTEGER_32, SELF).on t
);
-
+
- create_csecond csec:INTEGER :SELF <-
( + h,m,s,cs,diff:INTEGER;
-
+
diff := csec;
h := diff / (60*60*100);
diff := diff % (60*60*100);
-
+
m := diff / (60*100);
diff := diff % (60*100);
-
+
s := diff / 100;
- cs := diff % 100;
-
+ cs := diff % 100;
+
create (h,m,s,cs)
);
-
+
- to_string:STRING <-
( + result:STRING;
result := STRING.create 8;
append_in result;
result
);
-
+
- append_in str:STRING <-
(
hour.append_in str format 2 with '0';
@@ -146,12 +146,12 @@ Section Public
str.add_last ':';
minute.append_in str format 2 with '0';
);
-
+
- update <-
(
- // JBJB A FAIRE !!
+ // JBJB A FAIRE !!
);
-
+
- print <-
(
to_string.print;
diff --git a/shorter/belinda.li b/shorter/belinda.li
index 052d54e..81c947d 100644
--- a/shorter/belinda.li
+++ b/shorter/belinda.li
@@ -11,100 +11,100 @@
\</head>\n\
\<body BGCOLOR=\"#FFFFFF\">\n\
\\n";
-
- - end :=
+
+ - end :=
"\n</body>\n\
\</html>\n";
-
+
//
// Syntax.
//
-
- - keyword :=
+
+ - keyword :=
"<strong><font color=\"#A020F0\">" + token + "</font></strong>";
- - keyword_section :=
+ - keyword_section :=
"<dd><strong><font color=\"#A020F0\">" + token + "</font></strong></dd>";
-
+
- operator :=
"<font color=\"#B8860B\">" + token + "</font>";
-
+
- keyprototype :=
" <font color=\"#008000\">"+token+"</font>";
- prototype :=
" <a href=\"" + token + ".html\">\
\<font color=\"#008000\">"+token+"</font></a>";
-
+
- comment_line :=
"<br><font FACE=\"Helvetica\" color=\"#000000\"><B>" + token + "</B></font>";
- comment_slot_line :=
"<dd>" + token + "</dd>";
-
+
- comment_new_line_extern := "<br>";
- comment_new_line_slot := "<br>";
-
- - slot :=
+
+ - slot :=
" <strong><font color=\"#0000FF\">" + token + "</font></strong> ";
-
+
- slot_style :=
"<dd><strong><font color=\"#FF0000\">" + token + " </font></strong>";
-
- - local := " "+token+" ";
- - block :=
- "<font color=\"#FF0000\">" + token + "</font>";
+ - local := " "+token+" ";
+
+ - block :=
+ "<font color=\"#FF0000\">" + token + "</font>";
+
+ - warning :=
+ "<font color=\"#FF0000\"><b>" + token + "</b></font><br>";
- - warning :=
- "<font color=\"#FF0000\"><b>" + token + "</b></font><br>";
-
//
// Java doc style.
- //
-
+ //
+
- title := "<td align=\"right\"><em><b>Lisaac<sup><font size=\"-2\">TM</font></sup> Platform</b></em></td><hr><h2>" + token + "</h2><hr>";
-
+
- table_begin := "<table summary=\"\" width=\"100%\" border=\"1\" cellpadding=\"3\" cellspacing=\"0\"><tbody><tr class=\"TableHeadingColor\" bgcolor=\"#ccccff\"><td colspan=\"2\"><font size=\"+2\"><b>" + token + "</b></font></td></tr>";
-
+
- table_item := "<tr class=\"TableRowColor\" bgcolor=\"white\"><td>" + token + "</td></tr>";
-
+
- table_slot_name := "<code><dt><b><a href=\"#"+token+"\">" + token + "</a></b></code>";
- table_slot_comment := "<dd>" + token;
-
+
- table_end := "</tbody></table> ";
-
- - sub_title := "</dl></p><table summary=\"\" width=\"100%\" border=\"1\" cellpadding=\"3\" cellspacing=\"0\"><tbody><tr class=\"TableHeadingColor\" bgcolor=\"#ccccff\"><td colspan=\"1\"><font size=\"+2\"><b>" + token + "</b></font></td></tr></tbody></table>";
-
+
+ - sub_title := "</dl></p><table summary=\"\" width=\"100%\" border=\"1\" cellpadding=\"3\" cellspacing=\"0\"><tbody><tr class=\"TableHeadingColor\" bgcolor=\"#ccccff\"><td colspan=\"1\"><font size=\"+2\"><b>" + token + "</b></font></td></tr></tbody></table>";
+
- slot_title := "</dl><a name=\"" + token + "\"><!-- --></a><hr><h3>" + token + "</h3><dl>";
-
+
- subsub_title := "<dt><b><br>" + token + "</b></dt>";
-
+
- prototype_path := "<dd><code>" + token + "</code></dd>";
- identifier := "<em><b><font color=\"#000000\">" + token + "</font></em></b>";
-
+
- identifier_slot := "<code><b><a href=\"#"+token+"\">" + token + "</a></b></code>";
-
+
- parameter := "<dd>" + token + "</dd>";
- require := "<dd>" + token + "</dd>";
- ensure := "<dd>" + token + "</dd>";
- see := "<dd>" + token + "</dd>";
-
+
- description_en_francais := "<dd><em><strong><font color=\"#707070\">" + token + "</font></strong></em></dd>";
- necessite := "<dd><em><strong><font color=\"#707070\">" + token + "</font></strong></em></dd>";
- garantie := "<dd><em><strong><font color=\"#707070\">" + token + "</font></strong></em></dd>";
- - voir := "<dd><em><strong><font color=\"#707070\">" + token + "</font></strong></em></dd>";
-
+ - voir := "<dd><em><strong><font color=\"#707070\">" + token + "</font></strong></em></dd>";
+
- prototype_comment_light := "<strong>" + token + "</strong><hr>";
- prototype_comment := "<em>" + token + "</em>";
-
-
+
+
//
// Recursive Option.
//
-
+
- index :=
"<html><head><title>Lisaac Documentation</title></head>\n\
\<frameset cols=\"300,*\" border=\"3\" frameborder=\"yes\" \
@@ -121,9 +121,9 @@
\<h3>Frame Error</h3>\n\
\<p>This web site works only with frames.</p>\n\
\</noframes>\n\
- \</html>\n";
-
- - default :=
+ \</html>\n";
+
+ - default :=
"<html><head><title>Proto</title></head>\n\
\<body bgcolor=\"#FFFFFF\">\n\
\<H1>Lisaac documentation</H1>\n\
@@ -135,24 +135,24 @@
"<html><head><title>List Directories</title></head>\n\
\<body bgcolor=\"#FFFFFF\">\n\
\<a href=\"file_list.html\" target=\"file\">All</a>\n";
-
+
- directory_list_item :=
"<br><a href=\""+token+".html\" target=\"file\">"+token+"</a>\n";
-
- - directory_list_end :=
+
+ - directory_list_end :=
"</body>\n\
\</html>";
- file_list_begin :=
"<html><head><title>All Files</title></head>\n\
\<body bgcolor=\"#F0F0FF\" link=\"black\" vlink=\"black\">\n";
-
+
- file_list_item :=
"<br><a href=\""+token+".html\" target=\"content\">"+token+"</a>\n";
-
+
- file_list_end :=
"</body>\n\
\</html>";
-
+
diff --git a/shorter/html.li b/shorter/html.li
index 2d54772..c430a29 100644
--- a/shorter/html.li
+++ b/shorter/html.li
@@ -11,36 +11,36 @@
\</head>\n\
\<body BGCOLOR=\"#FFFFFF\">\n\
\\n";
-
- - end :=
+
+ - end :=
"\n</body>\n\
\</html>\n";
-
- - keyword :=
+
+ - keyword :=
"<strong><font color=\"#A020F0\">" + token + "</font></strong>";
- - keyword_section :=
+ - keyword_section :=
"<br><br><strong><font color=\"#A020F0\">" + token + "</font></strong>";
-
- - integer :=
+
+ - integer :=
"<font color=\"#A020F0\">" + token + "</font>";
-
- - character :=
+
+ - character :=
"<font color=\"#5F9EA0\">" + token + "</font>";
-
+
- string :=
"<font color=\"#BC8F8F\">" + token + "</font>";
-
+
- operator :=
"<font color=\"#B8860B\">" + token + "</font>";
-
+
- keyprototype :=
"<font color=\"#008000\">"+token+"</font>";
- prototype :=
"<a href=\"" + token + ".html\">\
\<font color=\"#008000\">"+token+"</font></a>";
-
+
- comment_header_line := " ";
- comment_line :=
@@ -48,29 +48,29 @@
- comment_slot_line :=
"<br><em><strong><font color=\"#707070\">        " + token + "</font></strong></em>";
-
- - comment :=
+
+ - comment :=
" ";
-
- - slot :=
+
+ - slot :=
"<strong><font color=\"#0000FF\">" + token + "</font></strong>";
- - slot_call :=
+ - slot_call :=
"<font color=\"#0000FF\">" + token + "</font>";
-
+
- slot_style :=
"<br><br><strong><font color=\"#FF0000\">    " + token + "</font></strong>";
-
- - block :=
- "<font color=\"#FF0000\">" + token + "</font>";
-
- - external :=
+
+ - block :=
+ "<font color=\"#FF0000\">" + token + "</font>";
+
+ - external :=
"<em><strong><font color=\"#A4DEA4\">" + token + "</font></strong></em>";
-
+
//
// Recursive Option.
//
-
+
- index :=
"<html><head><title>Lisaac Documentation</title></head>\n\
\<frameset cols=\"260,*\" border=\"3\" frameborder=\"yes\" \
@@ -87,9 +87,9 @@
\<h3>Frame Error</h3>\n\
\<p>This web site works only with frames.</p>\n\
\</noframes>\n\
- \</html>\n";
-
- - default :=
+ \</html>\n";
+
+ - default :=
"<html><head><title>Proto</title></head>\n\
\<body bgcolor=\"#FFFFFF\">\n\
\<H1>Lisaac documentation</H1>\n\
@@ -101,24 +101,24 @@
"<html><head><title>List Directories</title></head>\n\
\<body bgcolor=\"#FFFFFF\">\n\
\<a href=\"file_list.html\" target=\"file\">All</a>\n";
-
+
- directory_list_item :=
"<br><a href=\""+token+".html\" target=\"file\">"+token+"</a>\n";
-
- - directory_list_end :=
+
+ - directory_list_end :=
"</body>\n\
\</html>";
- file_list_begin :=
"<html><head><title>All Files</title></head>\n\
\<body bgcolor=\"#F0F0FF\" link=\"black\" vlink=\"black\">\n";
-
+
- file_list_item :=
"<br><a href=\""+token+".html\" target=\"content\">"+token+"</a>\n";
-
+
- file_list_end :=
"</body>\n\
\</html>";
-
+
diff --git a/shorter/html_raw.li b/shorter/html_raw.li
index bbeb4f5..ccc212d 100644
--- a/shorter/html_raw.li
+++ b/shorter/html_raw.li
@@ -11,36 +11,36 @@
\</head>\n\
\<body BGCOLOR=\"#FFFFFF\">\n\
\<pre>\n";
-
- - end :=
+
+ - end :=
"\n</body>\n\
\</html>\n";
-
- - keyword :=
+
+ - keyword :=
"<strong><font color=\"#A020F0\">" + token + "</font></strong>";
- - keyword_section :=
+ - keyword_section :=
"<strong><font color=\"#A020F0\">" + token + "</font></strong>";
-
- - integer :=
+
+ - integer :=
"<font color=\"#A020F0\">" + token + "</font>";
-
- - character :=
+
+ - character :=
"<font color=\"#5F9EA0\">" + token + "</font>";
-
+
- string :=
"<font color=\"#BC8F8F\">" + token + "</font>";
-
+
- operator :=
"<font color=\"#B8860B\">" + token + "</font>";
-
+
- keyprototype :=
"<font color=\"#008000\">"+token+"</font>";
- prototype :=
"<a href=\"" + token + ".html\">\
\<font color=\"#008000\">"+token+"</font></a>";
-
+
- comment_header_line :=
"<em><font color=\"#FF0000\">//" + token + "</font></em>";
@@ -49,38 +49,38 @@
- comment_slot_line :=
"<em><font color=\"#FF0000\">//" + token + "</font></em>";
-
- - french :=
+
+ - french :=
"<em><font color=\"#FF0FF0\">//" + token + "</font></em>";
- - english :=
+ - english :=
"<em><font color=\"#8080FF\">//" + token + "</font></em>";
-
- - greek :=
+
+ - greek :=
"<em><font color=\"#808000\">//" + token + "</font></em>";
- - comment :=
+ - comment :=
"<em><font color=\"#5F9EA0\">" + token + "</font></em>";
-
- - slot :=
+
+ - slot :=
"<strong><font color=\"#0000FF\">" + token + "</font></strong>";
- - slot_call :=
+ - slot_call :=
"<font color=\"#0000FF\">" + token + "</font>";
-
+
- slot_style :=
"<strong><font color=\"#FF0000\">" + token + "</font></strong>";
-
- - block :=
- "<font color=\"#FF0000\">" + token + "</font>";
-
- - external :=
+
+ - block :=
+ "<font color=\"#FF0000\">" + token + "</font>";
+
+ - external :=
"<em><strong><font color=\"#A4DEA4\">" + token + "</font></strong></em>";
-
+
//
// Recursive Option.
//
-
+
- index :=
"<html><head><title>Lisaac Documentation</title></head>\n\
\<frameset cols=\"260,*\" border=\"3\" frameborder=\"yes\" \
@@ -97,9 +97,9 @@
\<h3>Frame Error</h3>\n\
\<p>This web site works only with frames.</p>\n\
\</noframes>\n\
- \</html>\n";
-
- - default :=
+ \</html>\n";
+
+ - default :=
"<html><head><title>Proto</title></head>\n\
\<body bgcolor=\"red\">\n\
\Content proto documentation.\n\
@@ -110,24 +110,24 @@
"<html><head><title>List Directories</title></head>\n\
\<body bgcolor=\"#FFFFFF\">\n\
\<a href=\"file_list.html\" target=\"file\">All</a>\n";
-
+
- directory_list_item :=
"<br><a href=\""+token+".html\" target=\"file\">"+token+"</a>\n";
-
- - directory_list_end :=
+
+ - directory_list_end :=
"</body>\n\
\</html>";
- file_list_begin :=
"<html><head><title>All Files</title></head>\n\
\<body bgcolor=\"#F0F0FF\" link=\"black\" vlink=\"black\">\n";
-
+
- file_list_item :=
"<br><a href=\""+token+".html\" target=\"content\">"+token+"</a>\n";
-
+
- file_list_end :=
"</body>\n\
\</html>";
-
+
diff --git a/shorter/latex.li b/shorter/latex.li
index 77f2dd4..b0c0291 100644
--- a/shorter/latex.li
+++ b/shorter/latex.li
@@ -1,34 +1,34 @@
- begin :=
"\\begin{verbatim}\n";
-
- - end :=
+
+ - end :=
"\\end{verbatim}\n";
-
- - keyword :=
+
+ - keyword :=
"{\\bf{}" + last_string + "}";
-
+
- integer := last_string;
-
- - character :=
+
+ - character :=
"{\\it{}" + last_string + "}";
-
+
- string :=
"{\\it{}" + last_string + "}";
-
+
- operator := last_string;
-
+
- prototype :=
"<a href=\""+last_string+".html\">\
\<font color=\"#008000\">"+last_string+"</font></a>";
-
+
- comment_line :=
"{\\it{}" + last_string + "}";
-
+
- comment := "";
-
- - slot :=
+
+ - slot :=
"{\\bf{}" + last_string + "}";
-
+
- slot_style := last_string;
-
+
- block := "\\" + last_string;
\ No newline at end of file
diff --git a/src/aliaser_local.li b/src/aliaser_local.li
index 2004801..c013bc0 100644
--- a/src/aliaser_local.li
+++ b/src/aliaser_local.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ALIASER_LOCAL;
- copyright := "2003-2009 Sonntag Benoit";
@@ -30,27 +30,27 @@ Section Header
Section Inherit
- parent_any:ANY := ANY;
-
+
Section ALIASER_LOCAL,LIST
-
+
- free_context:FAST_ARRAY(LOCAL) := FAST_ARRAY(LOCAL).create_with_capacity 64;
-
+
- top_context:INTEGER;
-
+
- var_size:FAST_ARRAY(FAST_ARRAY(LOCAL)) :=
( + result:FAST_ARRAY(FAST_ARRAY(LOCAL));
-
+
result := FAST_ARRAY(FAST_ARRAY(LOCAL)).create_with_capacity 4;
0.to 3 do { j:INTEGER;
result.add_last (FAST_ARRAY(LOCAL).create_with_capacity 32);
};
result
);
-
+
Section Public
-
- - is_on:BOOLEAN := TRUE;
-
+
+ - is_on:BOOLEAN := TRUE;
+
- reset <-
(
(var_size.lower).to (var_size.upper) do { i:INTEGER;
@@ -60,13 +60,13 @@ Section Public
top_context := -1;
current_list_level := 0;
);
-
+
- write wr:WRITE_LOCAL :STRING_CONSTANT <-
( + loc,loc2:LOCAL;
+ result:STRING_CONSTANT;
-
+
loc := wr.local;
- ((is_on) && {loc.style = '+'}).if {
+ ((is_on) && {loc.style = '+'}).if {
loc2 := loc.my_alias;
(loc2 = NULL).if {
loc2 := search_alias loc;
@@ -81,7 +81,7 @@ Section Public
*/
loc2.set_ensure_count (loc.ensure_count);
};
- loc2.set_list_level current_list_level;
+ loc2.set_list_level current_list_level;
loc.set_my_alias loc2;
};
result := loc2.intern_name;
@@ -97,13 +97,13 @@ Section Public
- read rd:READ_LOCAL :STRING_CONSTANT <-
( + loc,loc2:LOCAL;
+ result:STRING_CONSTANT;
-
+
loc := rd.local;
loc2 := loc.my_alias;
- loc.unread rd;
+ loc.unread rd;
((loc2 = NULL) || {! is_on}).if {
result := loc.intern_name;
- } else {
+ } else {
/*
"----> READ ".print;
loc.intern_name.print; "->".print;
@@ -111,51 +111,51 @@ Section Public
loc.ensure_count.print;
'\n'.print;
*/
- loc2.set_ensure_count (loc.ensure_count);
+ loc2.set_ensure_count (loc.ensure_count);
result := loc2.intern_name;
};
result
);
-
+
- push p:PUSH :STRING_CONSTANT <-
- ( + loc,loc2:LOCAL;
+ ( + loc,loc2:LOCAL;
+ result:STRING_CONSTANT;
-
+
loc := p.context;
- (is_on).if {
- (p.is_first).if {
+ (is_on).if {
+ (p.is_first).if {
top_context := top_context + 1;
- (top_context <= free_context.upper).if {
+ (top_context <= free_context.upper).if {
loc2 := free_context.item top_context;
- } else {
+ } else {
free_context.add_last loc;
loc2 := loc;
add_var_size loc;
- };
+ };
loc.set_my_alias loc2;
- loc.set_list_level top_context;
+ loc.set_list_level top_context;
} else {
top_context := loc.list_level;
};
result := loc.my_alias.intern_name;
} else {
- (p.is_first).if {
+ (p.is_first).if {
add_var_size loc;
};
result := loc.intern_name;
};
result
);
-
+
Section ALIASER_LOCAL, READ_LOCAL
-
+
- add_var_size v:LOCAL <-
( + tab:FAST_ARRAY(LOCAL);
+ j:INTEGER;
+ t:TYPE_FULL;
-
+
? {v.style = '+'};
-
+
(v.style != '+').if {
v.intern_name.print; " style [".print; v.style.print; "] ".print;
'\n'.print;
@@ -164,7 +164,7 @@ Section ALIASER_LOCAL, READ_LOCAL
// BSBS: C'est pas top, avec des HASHED_SET ce serait mieux...
t := v.type;
tab := var_size.item (v.type.size);
- j := tab.lower;
+ j := tab.lower;
{(j <= tab.upper) && {tab.item j.type != t}}.while_do {
j := j + 1;
};
@@ -175,39 +175,39 @@ Section ALIASER_LOCAL, READ_LOCAL
j := j + 1;
};
((j > tab.upper) || {tab.item j != v}).if {
- tab.add v to j;
+ tab.add v to j;
};
};
);
-
+
Section Private
-
+
- search_alias v:LOCAL :LOCAL <-
( + tab:FAST_ARRAY(LOCAL);
+ j:INTEGER;
+ t:TYPE_FULL;
+ result:LOCAL;
+ is_void:BOOLEAN;
-
+
(v.name.first = 'R').if {
result := v;
} else {
t := v.type;
is_void := (! t.is_expanded) && {! t.is_strict} && {! t.raw.is_block};
tab := var_size.item (v.type.size);
- j := tab.lower;
+ j := tab.lower;
{
- (j <= tab.upper) &&
+ (j <= tab.upper) &&
{
(
- (tab.item j.type != t) &&
+ (tab.item j.type != t) &&
{
(! is_void) ||
{tab.item j.type.is_expanded} ||
{tab.item j.type.is_strict} ||
{tab.item j.type.raw.is_block}
}
- ) ||
+ ) ||
{tab.item j.ensure_count != 0} ||
{tab.item j.list_level < current_list_level}
}
diff --git a/src/any.li b/src/any.li
index 3eacb1b..cd8ee5f 100644
--- a/src/any.li
+++ b/src/any.li
@@ -56,7 +56,7 @@ Section Public
- loop_invariant:LOOP;
//
-
+
- late_binding_counter:INTEGER;
- null_counter:INTEGER;
diff --git a/src/code_life/call_slot.li b/src/code_life/call_slot.li
index c7aa7f3..6dd4582 100644
--- a/src/code_life/call_slot.li
+++ b/src/code_life/call_slot.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CALL_SLOT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Call slot method.";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
- count_no_recursive:INTEGER;
- count_context_sensitive:INTEGER;
-
+
- reset_count_no_recursive <-
(
count_no_recursive := 0;
@@ -46,59 +46,59 @@ Section Public
(
count_context_sensitive := 0;
);
-
+
+ profil:PROFIL;
-
+
- set_profil p:PROFIL <-
(
profil := p;
);
-
+
- source:LIST <- profil.code;
-
+
- is_interrupt:BOOLEAN <- profil.is_interrupt;
-
+
- is_external:BOOLEAN <- profil.is_external;
-
+
//
// Argument.
//
-
+
+ argument_list:FAST_ARRAY(WRITE);
-
+
+ result_list:Expanded SLIM_ARRAY(RESULT); // BSBS: utiliter de RESULT ? => WRITE_LOCAL
-
+
+ cop_argument:EXPR;
-
+
+ is_cop_return:BOOLEAN;
-
+
- set_args args:FAST_ARRAY(WRITE) <-
(
argument_list := args;
);
-
+
- set_cop_argument arg:EXPR <-
(
cop_argument := arg;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION profil prof:PROFIL with l_arg:FAST_ARRAY(WRITE) cop arg:EXPR :SELF <-
( + result:SELF;
result := clone;
result.make p profil prof with l_arg cop arg;
result
);
-
+
- make p:POSITION profil prof:PROFIL with l_arg:FAST_ARRAY(WRITE) cop arg:EXPR <-
- ( + n:INTEGER;
- position := p;
+ ( + n:INTEGER;
+ position := p;
cop_argument := arg;
// Choice profil.
- profil := prof;
+ profil := prof;
argument_list := l_arg;
profil.link Self;
//
@@ -107,24 +107,24 @@ Section Public
} else {
n := profil.result_list.count;
};
- result_list.make_with_capacity n;
+ result_list.make_with_capacity n;
);
-
+
- my_copy:SELF <-
( + result:SELF;
+ wrt:WRITE;
+ new_arg:FAST_ARRAY(WRITE);
+ res:RESULT;
result := clone;
-
+
new_arg := FAST_ARRAY(WRITE).create_with_capacity (argument_list.count);
(argument_list.lower).to (argument_list.upper) do { j:INTEGER;
(argument_list.item j = NULL).if {
wrt := NULL;
} else {
// No Alias := Alias.
- wrt := argument_list.item j;
- wrt := wrt.variable.write_direct (wrt.position) with NULL value (wrt.value.my_copy);
+ wrt := argument_list.item j;
+ wrt := wrt.variable.write_direct (wrt.position) with NULL value (wrt.value.my_copy);
//wrt := argument_list.item j.my_copy;
};
new_arg.add_last wrt;
@@ -135,7 +135,7 @@ Section Public
};
//
result.result_list.make_with_capacity (result_list.count);
- (result_list.lower).to (result_list.upper) do { j:INTEGER;
+ (result_list.lower).to (result_list.upper) do { j:INTEGER;
(result_list.item j = NULL).if {
res := NULL;
} else {
@@ -154,19 +154,19 @@ Section Public
- remove <-
( + e:WRITE;
-
+
((profil.link_count = 0) && {profil.cop_link_count = 0}).if { // BSBS: Debug...
"CALL_SLOT : ".print;
debug_display;
};
-
+
profil.unlink Self;
(argument_list.lower).to (argument_list.upper) do { j:INTEGER;
e := argument_list.item j;
(e != NULL).if {
e.remove;
};
- };
+ };
(cop_argument != NULL).if {
cop_argument.remove;
};
@@ -174,20 +174,20 @@ Section Public
result_list.item j.remove;
};
);
-
-Section Private
-
- - execute_inline:(BOOLEAN,INSTR) <-
+
+Section Private
+
+ - execute_inline:(BOOLEAN,INSTR) <-
// Simple inlining
( + result:INSTR;
+ is_good:BOOLEAN;
+ new_src:LIST;
+ wrt:WRITE;
- + old_val:EXPR;
+ + old_val:EXPR;
+ loc:LOCAL;
+ prof_block:PROFIL_BLOCK;
-
- (source = list_current).if {
+
+ (source = list_current).if {
POSITION.put_error semantic text "Recursivity without end (call_slot).";
source.position.put_position;
position.put_position;
@@ -196,7 +196,7 @@ Section Private
/*
(profil.name == "to__do__AAJH").if {
"HERE!\n".print;
- (profil.is_inlinable).if {
+ (profil.is_inlinable).if {
"YES!\n".print;
} else {
"NO\n".print;
@@ -207,30 +207,30 @@ Section Private
'\n'.print;
};
*/
- (profil.is_inlinable).if {
+ (profil.is_inlinable).if {
(profil.link_count = 1).if {
- //
+ //
// Inlining simple.
- //
+ //
(list_current.old_seq_or_and = seq_or_and).if {
- argument_to_assignment source index 1 alias FALSE style '+';
- (result_list.lower).to (result_list.upper) do { j:INTEGER;
+ argument_to_assignment source index 1 alias FALSE style '+';
+ (result_list.lower).to (result_list.upper) do { j:INTEGER;
source.add_last (result_list.item j.write);
};
- result := source.execute;
- profil.remove_inline;
+ result := source.execute;
+ profil.remove_inline;
new_execute_pass;
is_good := TRUE;
};
} else {
//
- // Inline by copy:
+ // Inline by copy:
//
- (list_current.old_seq_or_and = seq_or_and).if {
- profil.unlink Self;
-
+ (list_current.old_seq_or_and = seq_or_and).if {
+ profil.unlink Self;
+
prof_block ?= profil;
- (prof_block != NULL).if {
+ (prof_block != NULL).if {
(profil.argument_list.lower).to (profil.argument_list.upper) do { j:INTEGER;
loc := profil.argument_list.item j;
(loc != NULL).if {
@@ -241,17 +241,17 @@ Section Private
LOCAL.alias_on;
};
//LOCAL.alias_on;
-
- new_src := source.my_copy;
+
+ new_src := source.my_copy;
argument_to_assignment new_src index 1 alias TRUE style '+';
(result_list.lower).to (result_list.upper) do { j:INTEGER;
- wrt := result_list.item j.write;
- old_val := wrt.value;
- wrt.set_value (old_val.my_copy);
- old_val.remove;
+ wrt := result_list.item j.write;
+ old_val := wrt.value;
+ wrt.set_value (old_val.my_copy);
+ old_val.remove;
new_src.add_last wrt;
- };
-
+ };
+
(prof_block != NULL).if {
(profil.argument_list.lower).to (profil.argument_list.upper) do { j:INTEGER;
loc := profil.argument_list.item j;
@@ -261,39 +261,39 @@ Section Private
};
} else {
LOCAL.alias_off;
- };
- //LOCAL.alias_off;
-
+ };
+ //LOCAL.alias_off;
+
result := new_src.execute;
is_good := TRUE;
- new_execute_pass;
+ new_execute_pass;
};
};
};
is_good,
result
- );
-
+ );
+
- execute_normal <-
( + wrt:WRITE_LOCAL;
-
+
// Pour l'instant ne change pas le profil
// il faut faire une copie de l'ancien !!
-
+
//profil := profil.update self link FALSE;
-
- (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
- wrt ?= argument_list.item j;
- (wrt != NULL).if {
+
+ (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
+ wrt ?= argument_list.item j;
+ (wrt != NULL).if {
(wrt.execute_argument).if {
new_execute_pass;
- argument_list.put NULL to j;
+ argument_list.put NULL to j;
(wrt.ensure_count = 0).if {
profil.argument_list.put NULL to j;
};
};
};
- };
+ };
/* BSBS: A revoir avec pb `list' l.352 et `profil' pour result
(result_list.lower).to (result_list.upper) do { j:INTEGER;
result_list.item j.execute;
@@ -302,26 +302,26 @@ Section Private
(cop_argument != NULL).if {
cop_argument := cop_argument.execute_link;
(
- (! is_cop_return) &&
- {profil_current != NULL} &&
- {profil_current.cop_link_count != 0} &&
+ (! is_cop_return) &&
+ {profil_current != NULL} &&
+ {profil_current.cop_link_count != 0} &&
{profil_current.link_count = 0} &&
{profil_current.result_list.is_empty}
).if {
// BSBS: Il faut produire reellement 2 versions (une COP et une non COP)
// Ainsi tu pourras generaliser l'optim et l'appliquer que sur la version COP.
- is_cop_return := profil_current.i_am_the_last Self;
+ is_cop_return := profil_current.i_am_the_last Self;
};
- };
+ };
(profil.is_context_sensitive).if {
seq_call_local_and_loop := seq_call_local_and_loop + 1;
};
seq_call_and_loop := seq_call_and_loop + 1;
seq_inline := seq_inline + 1;
-
+
//
// Counter.
- //
+ //
(! profil.is_recursive).if {
count_no_recursive := count_no_recursive + 1;
};
@@ -329,26 +329,26 @@ Section Private
count_context_sensitive := count_context_sensitive + 1;
};
);
-
+
Section Public
-
+
- execute:INSTR <-
- ( + result:INSTR;
- + is_good:BOOLEAN;
+ ( + result:INSTR;
+ + is_good:BOOLEAN;
(is_good,result) := execute_inline;
- (! is_good).if {
+ (! is_good).if {
execute_normal;
(source.is_empty).if {
- // Suppression.
- profil.unlink Self;
+ // Suppression.
+ profil.unlink Self;
new_execute_pass;
} else {
result := Self;
profil.set_life;
};
};
-
+
result
);
@@ -360,7 +360,7 @@ Section Public
( + t:HASHED_SET(TYPE);
buffer.append (profil.name);
buffer.add_last '(';
-
+
type_list.lower.to (type_list.upper) do { j:INTEGER;
t := type_list.item j;
t.lower.to (t.upper - 1) do { k:INTEGER;
@@ -383,7 +383,7 @@ Section Public
argument_list.is_empty.if {
buffer.append "()";
} else {
- buffer.append "(";
+ buffer.append "(";
argument_list.lower.to (argument_list.upper) do { j:INTEGER;
arg := argument_list.item j;
(arg = NULL).if {
@@ -392,8 +392,8 @@ Section Public
arg.value.display buffer;
};
buffer.add_last ',';
- };
- buffer.put ')' to (buffer.upper);
+ };
+ buffer.put ')' to (buffer.upper);
};
);
@@ -416,7 +416,7 @@ Section Public
//
// Generation.
//
-
+
- genere buffer:STRING <-
( + val:WRITE;
+ arg:LOCAL;
@@ -424,40 +424,40 @@ Section Public
+ np:INTEGER;
+ low:INTEGER;
+ back:INTEGER;
-
+
(cop_argument != NULL).if {
(
- (argument_list.count >=1) &&
- {argument_list.first != NULL} &&
+ (argument_list.count >=1) &&
+ {argument_list.first != NULL} &&
{argument_list.first.variable.name = ALIAS_STR.variable_self}
).if {
low := 1;
};
- (argument_list.count-low > 0).if {
+ (argument_list.count-low > 0).if {
back := buffer.count;
buffer.append "pthread_mutex_lock (&(";
- cop_argument.genere buffer;
- buffer.append "->thread.mutex));\n";
- (low).to (argument_list.upper) do { j:INTEGER;
- val := argument_list.item j;
- (val != NULL).if {
+ cop_argument.genere buffer;
+ buffer.append "->thread.mutex));\n";
+ (low).to (argument_list.upper) do { j:INTEGER;
+ val := argument_list.item j;
+ (val != NULL).if {
buffer.append indent;
cop_argument.genere buffer;
buffer.append "->param_";
np.append_in buffer;
buffer.append "=(int)";
- val.genere_value buffer;
- buffer.append ";\n";
+ val.genere_value buffer;
+ buffer.append ";\n";
np := np + 1;
} else {
"arg null\n".print;
};
- };
+ };
buffer.append indent;
(np = 0).if {
buffer.keep_head back;
};
- };
+ };
cop_argument.genere buffer;
buffer.append "->thread.procedure = COP_";
buffer.append (profil.name);
@@ -471,23 +471,23 @@ Section Public
buffer.append "((lith_object *)";
cop_argument.genere buffer;
buffer.add_last ')';
- } else {
+ } else {
(result_list.is_empty).if_false {
wrt ?= result_list.first.write;
(wrt.local.ensure_count != 0).if {
- wrt.genere_first_result buffer;
- };
+ wrt.genere_first_result buffer;
+ };
};
buffer.append (profil.name);
-
+
(is_graph).if {
(profil_current = NULL).if {
- profil_main.add_call profil;
+ profil_main.add_call profil;
} else {
- profil_current.add_call profil;
- };
+ profil_current.add_call profil;
+ };
};
-
+
(is_interrupt || {is_external}).if {
(argument_list.first != NULL).if {
semantic_error (argument_list.first.position,
@@ -495,15 +495,15 @@ Section Public
};
};
(! is_interrupt).if {
- buffer.add_last '(';
- (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
+ buffer.add_last '(';
+ (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
val := argument_list.item j;
arg := profil.argument_list.item j;
- (val != NULL).if {
+ (val != NULL).if {
(buffer.last != '(').if {
buffer.add_last ',';
};
- val.genere_value buffer;
+ val.genere_value buffer;
};
};
(result_list.count > 1).if {
@@ -512,75 +512,75 @@ Section Public
buffer.add_last ',';
};
wrt ?= result_list.item j.write;
- wrt.genere_argument_result buffer;
+ wrt.genere_argument_result buffer;
};
};
buffer.add_last ')';
};
};
);
-
+
//
// Intern routine.
//
-
+
Section PROFIL
-/*
+/*
- to_tail_recursive:LOOP <-
( + switch:SWITCH;
- + msg_slot:CALL_SLOT;
- + body:LIST;
+ + msg_slot:CALL_SLOT;
+ + body:LIST;
+ wrt:WRITE;
+ new_val:EXPR;
+ new_wrt:INSTR;
+ result:LOOP;
+ push:PUSH;
-
+
result := LOOP.create position name (profil.name) body source;
-
+
//
// Main List.
//
-
- // Argument -> Affectation.
+
+ // Argument -> Affectation.
wrt := argument_list.first;
(wrt != NULL).if {
- argument_list.put NULL to 0;
- (! wrt.value.static_type.is_expanded).if {
+ argument_list.put NULL to 0;
+ (! wrt.value.static_type.is_expanded).if {
new_val := CAST.create (wrt.static_type) value (wrt.value);
wrt.set_value new_val;
- };
+ };
wrt.variable.set_style '+';
new_wrt := wrt.execute;
- (new_wrt != NULL).if {
- list_current.insert new_wrt to (list_current.index);
+ (new_wrt != NULL).if {
+ list_current.insert new_wrt to (list_current.index);
};
};
(argument_list.lower + 1).to (argument_list.upper) do { k:INTEGER;
wrt := argument_list.item k;
- (wrt != NULL).if {
- argument_list.put NULL to k;
+ (wrt != NULL).if {
+ argument_list.put NULL to k;
wrt.variable.set_style '+';
new_wrt := wrt.execute;
- (new_wrt != NULL).if {
+ (new_wrt != NULL).if {
list_current.insert new_wrt to (list_current.index);
};
};
};
-
- (debug_level_option != 0).if {
+
+ (debug_level_option != 0).if {
push ?= source.first;
- list_current.insert (push.my_copy) to (list_current.index);
+ list_current.insert (push.my_copy) to (list_current.index);
push.set_first FALSE;
};
-
+
// Extract Switch/body:
switch ?= source.last;
(switch.list.lower).to (switch.list.upper) do { k:INTEGER;
body := switch.list.item k.code;
- (body.is_empty).if_false {
+ (body.is_empty).if_false {
msg_slot ?= body.last;
- ((msg_slot != NULL) && {msg_slot.profil = profil}).if {
+ ((msg_slot != NULL) && {msg_slot.profil = profil}).if {
// DEBUG
(msg_slot = Self).if {
semantic_error (position,"CALL_SLOT : BUG!!!!");
@@ -588,33 +588,33 @@ Section PROFIL
// FIN DEBUG
msg_slot.argument_to_assignment body index (body.upper) alias FALSE;
body.put (LOOP_END.create (msg_slot.position) loop result) to (body.upper);
- };
+ };
};
};
result
);
*/
- - argument_to_assignment lst:LIST
- index idx:INTEGER
- alias is_alias:BOOLEAN
+ - argument_to_assignment lst:LIST
+ index idx:INTEGER
+ alias is_alias:BOOLEAN
style styl:CHARACTER <-
- ( + val,new_wrt:WRITE;
+ ( + val,new_wrt:WRITE;
+ loc:LOCAL;
-
+
// Argument -> Affectation.
(argument_list.upper).downto (argument_list.lower) do { k:INTEGER;
val := argument_list.item k;
- (val != NULL).if {
+ (val != NULL).if {
argument_list.put NULL to k;
(is_alias).if {
- loc ?= val.variable;
- new_wrt := loc.write (val.position) value (val.value);
- loc.unwrite val;
+ loc ?= val.variable;
+ new_wrt := loc.write (val.position) value (val.value);
+ loc.unwrite val;
} else {
- new_wrt := val;
+ new_wrt := val;
};
- lst.insert new_wrt to idx;
+ lst.insert new_wrt to idx;
new_wrt.variable.set_style styl;
};
- };
+ };
);
diff --git a/src/code_life/case.li b/src/code_life/case.li
index c758bfe..2142512 100644
--- a/src/code_life/case.li
+++ b/src/code_life/case.li
@@ -19,45 +19,45 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CASE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Case for Switch.";
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
+ id:TYPE;
-
- + code:LIST;
-
+
+ + code:LIST;
+
- set_code new_code:LIST <-
(
code := new_code;
);
-
+
//
// Creation.
//
-
+
- create val:TYPE with c:LIST :SELF <-
( + result:SELF;
-
+
result := clone;
result.make val with c;
result
);
-
+
- make val:TYPE with c:LIST <-
( + tb:PROFIL_BLOCK;
- id := val;
+ id := val;
code := c;
//
tb ?= val;
@@ -65,14 +65,14 @@ Section Public
tb.inc_id;
};
);
-
+
- my_copy:SELF <-
( + result:SELF;
-
+
result := SELF.create id with (code.my_copy);
- result
+ result
);
-
+
- remove <-
( + tb:PROFIL_BLOCK;
code.remove;
@@ -81,45 +81,44 @@ Section Public
tb.dec_id;
};
);
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' other:CASE :BOOLEAN <-
// BSBS : Naive implantation...
( + result:BOOLEAN;
+ wrt1,wrt2:WRITE_LOCAL;
-
+
((code.count = 1) && {code.count = other.code.count}).if {
wrt1 ?= code.first;
wrt2 ?= other.code.first;
result := (
- (wrt1 != NULL) &&
- {wrt2 != NULL} &&
- {wrt1.variable = wrt2.variable} &&
+ (wrt1 != NULL) &&
+ {wrt2 != NULL} &&
+ {wrt1.variable = wrt2.variable} &&
{wrt1.value ~= wrt2.value}
);
};
result
);
-
+
//
// Execute
//
-
+
- execute <-
- (
+ (
id.set_late_binding;
code.execute_case;
);
-
+
//
// Genere
//
-
+
- genere buffer:STRING <-
- (
+ (
code.genere buffer;
);
-
\ No newline at end of file
diff --git a/src/code_life/cast.li b/src/code_life/cast.li
index 989ffaa..d167f23 100644
--- a/src/code_life/cast.li
+++ b/src/code_life/cast.li
@@ -19,80 +19,80 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CAST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Cast type.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
+
Section Public
-
+
- is_invariant:BOOLEAN <- value.is_invariant;
-
+
+ static_type:TYPE_FULL;
-
+
+ value:EXPR;
-
+
//
// Creation.
//
-
+
- create t:TYPE_FULL value v:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make t value v;
- result
+ result
);
-
+
- make t:TYPE_FULL value v:EXPR <-
(
position := v.position;
static_type := t;
value := v;
);
-
+
- my_copy:SELF <-
(
create static_type value (value.my_copy)
);
-
+
//
// Searching.
//
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add (static_type.raw);
);
-
+
//
// Executing pass.
//
-
+
- remove <-
- (
+ (
value.remove;
);
-
- - execute_unlink:INSTR <-
+
+ - execute_unlink:INSTR <-
(
value.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ int:INTEGER_CST;
+ lst_typ:TYPES_TMP;
+ other:CAST;
-
+
value := value.execute_link;
result := Self;
//
@@ -100,12 +100,12 @@ Section Public
result := value;
new_execute_pass;
}.elseif {
- (ALIAS_STR.is_integer (static_type.raw.name)) &&
+ (ALIAS_STR.is_integer (static_type.raw.name)) &&
{value.is_constant} &&
{ int ?= value; // BSBS: Merde avc les prototype_cst de type type_id : INTEGER
int != NULL
}
- } then {
+ } then {
int.cast_type static_type;
result := value;
new_execute_pass;
@@ -124,27 +124,27 @@ Section Public
new_execute_pass;
};
lst_typ.free;
- };
+ };
//
result
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
- (
+ (
buffer.add_last '(';
buffer.add_last '(';
- static_type.genere_declaration buffer;
+ static_type.genere_declaration buffer;
buffer.add_last ' ';
- static_type.genere_star_declaration buffer;
+ static_type.genere_star_declaration buffer;
buffer.add_last ')';
value.genere buffer;
buffer.add_last ')';
);
-
+
//
// Display.
//
diff --git a/src/code_life/cop_lock.li b/src/code_life/cop_lock.li
index 7d3a921..f2edac3 100644
--- a/src/code_life/cop_lock.li
+++ b/src/code_life/cop_lock.li
@@ -19,63 +19,63 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COP_LOCK;
- copyright := "2003-2007 Benoit Sonntag";
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "COP in for data or function.";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
+ data:EXPR;
-
+
//
// Creation.
//
-
+
- create p:POSITION with dta:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with dta;
result
);
-
+
- make p:POSITION with dta:EXPR <-
(
position := p;
data := dta;
);
-
- - my_copy:SELF <-
- (
+
+ - my_copy:SELF <-
+ (
create position with (data.my_copy)
);
-
+
- remove <-
(
data.remove;
);
-
+
//
// Execute.
//
-
+
- execute:INSTR <-
(
Self
);
-
+
//
// Generation.
//
-
+
- genere buffer:STRING <-
(
buffer.append "// Pre thread.\n";
@@ -83,21 +83,21 @@ Section Public
// buffer.append "print_char('\\n');\n";
buffer.append indent;
buffer.append "{ lith_node node,*n;\n";
- indent.append " ";
+ indent.append " ";
buffer.append indent;
buffer.append "lith_object *obj;\n";
buffer.append indent;
- buffer.append "void *thread_save;\n";
+ buffer.append "void *thread_save;\n";
buffer.append indent;
buffer.append "obj = &((";
data.genere buffer;
- buffer.append ")->thread);\n";
+ buffer.append ")->thread);\n";
buffer.append indent;
buffer.append "node.next = NULL;\n";
buffer.append indent;
buffer.append "pthread_mutex_init(&node.mutex,NULL);\n";
buffer.append indent;
- buffer.append "pthread_mutex_lock(&obj->mutex);\n";
+ buffer.append "pthread_mutex_lock(&obj->mutex);\n";
buffer.append indent;
buffer.append "n = obj->last;\n";
buffer.append indent;
@@ -113,28 +113,28 @@ Section Public
buffer.append indent;
buffer.append "};\n";
buffer.append indent;
- buffer.append "obj->last = &node;\n";
+ buffer.append "obj->last = &node;\n";
buffer.append indent;
buffer.append "pthread_mutex_unlock(&obj->mutex);\n";
//
- buffer.append indent;
+ buffer.append indent;
buffer.append "pthread_mutex_lock (&node.mutex);\n";
- buffer.append indent;
+ buffer.append indent;
buffer.append "thread_save=pthread_getspecific(current_thread);\n";
buffer.append indent;
buffer.append "pthread_setspecific(current_thread,";
data.genere buffer;
- buffer.add_last ')';
+ buffer.add_last ')';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append "COP_LOCK(";
data.display buffer;
buffer.add_last ')';
);
-
+
diff --git a/src/code_life/cop_unlock.li b/src/code_life/cop_unlock.li
index ff69c56..84119f9 100644
--- a/src/code_life/cop_unlock.li
+++ b/src/code_life/cop_unlock.li
@@ -19,63 +19,63 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COP_UNLOCK;
- copyright := "2003-2007 Benoit Sonntag";
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "COP in for data or function.";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
//
// Creation.
//
-
+
- create p:POSITION :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p;
result
);
-
+
- make p:POSITION <-
(
- position := p;
+ position := p;
);
-
- - my_copy:SELF <-
- (
+
+ - my_copy:SELF <-
+ (
create position
);
-
+
- remove <-
(
// Nothing.
);
-
+
//
// Execute.
//
-
+
- execute:INSTR <-
(
Self
);
-
+
//
// Generation.
//
-
+
- genere buffer:STRING <-
(
- buffer.append "pthread_mutex_lock(&(obj->mutex));\n";
+ buffer.append "pthread_mutex_lock(&(obj->mutex));\n";
buffer.append indent;
buffer.append "n = obj->first->next;\n";
buffer.append indent;
@@ -91,20 +91,20 @@ Section Public
buffer.append indent;
buffer.append "obj->first = n;\n";
buffer.append indent;
- buffer.append "pthread_mutex_unlock(&obj->mutex);\n";
+ buffer.append "pthread_mutex_unlock(&obj->mutex);\n";
buffer.append indent;
- buffer.append "pthread_setspecific(current_thread,thread_save);\n";
+ buffer.append "pthread_setspecific(current_thread,thread_save);\n";
indent.remove_last 2;
buffer.append indent;
buffer.add_last '}';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append "COP_UNLOCK()";
);
-
+
diff --git a/src/code_life/expr.li b/src/code_life/expr.li
index 4e99ce2..bc4ff56 100644
--- a/src/code_life/expr.li
+++ b/src/code_life/expr.li
@@ -84,15 +84,15 @@ Section Public
result := Self;
} else {
? {list_current != NULL};
- (static_type.is_export_to t).if {
- // Auto-export.
+ (static_type.is_export_to t).if {
+ // Auto-export.
local := static_type.get_temporary position;
- instr := local.write position value Self;
+ instr := local.write position value Self;
list_current.add_last instr;
//
- slot_name := ALIAS_STR.get (TYPE.last_cast_name);
+ slot_name := ALIAS_STR.get (TYPE.last_cast_name);
slot_msg := static_type.get_slot slot_name;
- (slot_msg = NULL).if {
+ (slot_msg = NULL).if {
string_tmp.clear;
static_type.append_name_in string_tmp;
string_tmp.append " -> ";
@@ -107,14 +107,14 @@ Section Public
static_type.prototype.position.put_position;
POSITION.send_error;
//semantic_error p,string_tmp;
- };
- (slot_msg.argument_count != 1).if {
+ };
+ (slot_msg.argument_count != 1).if {
semantic_error (slot_msg.position,"No argument for this slot.");
};
ts ?= slot_msg.result_type;
- ((ts = NULL) || {ts.to_run_for (t.raw) != t}).if {
+ ((ts = NULL) || {ts.to_run_for (t.raw) != t}).if {
string_tmp.copy "Type result `";
- slot_msg.result_type.append_in string_tmp;
+ slot_msg.result_type.append_in string_tmp;
string_tmp.append "' is incorrect (Used for auto-conversion to `";
t.append_name_in string_tmp;
string_tmp.append "').";
@@ -123,22 +123,22 @@ Section Public
position.put_position;
POSITION.send_error;
};
- //
+ //
rec := local.read position;
node := NODE.new_read position slot slot_msg
receiver rec self rec intern FALSE;
list_current.add_last node;
- //
+ //
result := node.result_expr;
}.elseif {t.is_import_to static_type} then {
// Auto-import.
local := static_type.get_temporary position;
- instr := local.write position value Self;
+ instr := local.write position value Self;
list_current.add_last instr;
- //
+ //
slot_name := ALIAS_STR.get (TYPE.last_cast_name);
slot_msg := t.get_slot slot_name;
- (slot_msg = NULL).if {
+ (slot_msg = NULL).if {
string_tmp.clear;
t.append_name_in string_tmp;
string_tmp.append " <- ";
@@ -153,13 +153,13 @@ Section Public
t.prototype.position.put_position;
POSITION.send_error;
//semantic_error p,string_tmp;
- };
+ };
(slot_msg.argument_count != 2).if {
semantic_error (slot_msg.position,"Incorrect argument for this slot.");
};
ts ?= slot_msg.result_type;
- ((ts = NULL) || {ts != ITM_TYPE_PARAMETER.type_self}).if {
- string_tmp.copy "Type result `";
+ ((ts = NULL) || {ts != ITM_TYPE_PARAMETER.type_self}).if {
+ string_tmp.copy "Type result `";
slot_msg.result_type.append_in string_tmp;
string_tmp.append "' is incorrect (Used for auto-conversion to `";
t.append_name_in string_tmp;
@@ -169,19 +169,19 @@ Section Public
position.put_position;
POSITION.send_error;
};
- //
+ //
args := FAST_ARRAY(EXPR).create_with_capacity 2;
args.add_last (PROTOTYPE_CST.create position type t);
args.add_last (local.read position);
node := NODE.new_read position slot slot_msg
receiver (args.first.my_copy) with args intern FALSE;
list_current.add_last node;
- //
- result := node.result_expr;
+ //
+ result := node.result_expr;
} else {
- // Type Error
+ // Type Error
string_tmp.copy "Type `";
- t.append_name_in string_tmp;
+ t.append_name_in string_tmp;
string_tmp.append "' is invalid with `";
static_type.append_name_in string_tmp;
string_tmp.append "'.";
diff --git a/src/code_life/expr_multiple.li b/src/code_life/expr_multiple.li
index 46a556a..dda8d7d 100644
--- a/src/code_life/expr_multiple.li
+++ b/src/code_life/expr_multiple.li
@@ -19,41 +19,41 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_MULTIPLE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Multiple expression manager";
-
- // BSBS: Utiliser ca une seule fois ! cela doit etre possible!
-
+
+ // BSBS: Utiliser ca une seule fois ! cela doit etre possible!
+
Section Inherit
-
+
- parent_expr:EXPR := EXPR;
-
+
Section Public
-
+
+ expr_list:FAST_ARRAY(EXPR);
-
+
- cardinality:INTEGER <- expr_list.count;
-
+
- static_type:TYPE_FULL <-
(
expr_list.first.static_type
);
-
+
- get_type t:TYPES_TMP <-
(
crash_with_message "EXPR_MULTIPLE.get_type";
);
-
+
//
// Creation
//
-
+
// BSBS: Optim : Il faut que ce soit alouer et free après !!!
- create l:FAST_ARRAY(EXPR) :SELF <-
( + result:SELF;
@@ -61,70 +61,70 @@ Section Public
result.make l;
result
);
-
+
- make l:FAST_ARRAY(EXPR) <-
(
expr_list := l;
position := l.last.position;
);
-
+
- my_copy:SELF <-
( + new_lst:FAST_ARRAY(EXPR);
-
+
new_lst := FAST_ARRAY(EXPR).create_with_capacity (expr_list.count);
(expr_list.lower).to (expr_list.upper) do { j:INTEGER;
new_lst.add_last (expr_list.item j.my_copy);
};
SELF.create new_lst
);
-
+
//
// Remove.
//
-
+
- remove <-
(
(expr_list.lower).to (expr_list.upper) do { j:INTEGER;
expr_list.item j.remove;
};
);
-
+
//
// Execute.
//
-
- - execute_unlink:INSTR <-
+
+ - execute_unlink:INSTR <-
(
(expr_list.lower).to (expr_list.upper) do { j:INTEGER;
expr_list.item j.remove;
};
NULL
);
-
+
- execute_link:EXPR <-
(
list_current.debug_display;
crash_with_message "EXPR_MULTIPLE.execute_link";
NULL
);
-
+
//
// Access facility.
//
-
+
- lower:INTEGER <- expr_list.lower;
- upper:INTEGER <- expr_list.upper;
-
+
- item i:INTEGER :EXPR <- expr_list.item i;
- last:EXPR <- expr_list.last;
- first:EXPR <- expr_list.first;
-
- - count:INTEGER <- expr_list.count;
-
+
+ - count:INTEGER <- expr_list.count;
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.add_last '(';
@@ -135,4 +135,3 @@ Section Public
expr_list.last.display buffer;
buffer.add_last ')';
);
-
\ No newline at end of file
diff --git a/src/code_life/instr.li b/src/code_life/instr.li
index 5ba2cd8..9b58bdc 100644
--- a/src/code_life/instr.li
+++ b/src/code_life/instr.li
@@ -19,58 +19,58 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := INSTR;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all Instruction.";
-
+
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
-
+
Section Public
-
+
- is_invariant:BOOLEAN <- FALSE;
-
+
//
//
//
-
+
- hash_code:INTEGER <- INTEGER.force_conversion position;
- - my_copy:SELF <-
- (
+ - my_copy:SELF <-
+ (
debug_display;
- deferred;
- NULL
- );
-
+ deferred;
+ NULL
+ );
+
//
// Executing pass.
//
- cmp other:INSTR :BOOLEAN := FALSE;
-
+
- i_am_the_last i:INSTR :BOOLEAN <- (i = Self);
-
- - execute:INSTR <-
- (
+
+ - execute:INSTR <-
+ (
debug_display;
- deferred;
+ deferred;
NULL
);
-
- - remove <-
+
+ - remove <-
(
- debug_display;
+ debug_display;
deferred;
);
- - genere buffer:STRING <-
+ - genere buffer:STRING <-
(
// BUG.
display buffer;
@@ -92,34 +92,34 @@ Section Public
};
);
- - display buffer:STRING <-
+ - display buffer:STRING <-
(
"INSTR.display\n".print;
- deferred;
+ deferred;
);
- debug_display <-
( + voir:STRING;
-
+
voir := STRING.create 250;
display voir;
voir.print;
'\n'.print;
);
-
+
- simplify_type v:VARIABLE <-
( + tmp_type:TYPES_TMP;
-
+
((! v.is_static) && {! v.type.is_strict}).if {
tmp_type := TYPES_TMP.new;
v.get_type tmp_type;
(tmp_type.count != 0).if {
(tmp_type.first = TYPE_NULL).if {
tmp_type.remove_first;
- (tmp_type.count = 1).if {
- v.set_type (tmp_type.first.default.to_strict);
+ (tmp_type.count = 1).if {
+ v.set_type (tmp_type.first.default.to_strict);
};
- };
+ };
};
tmp_type.free;
};
diff --git a/src/code_life/list.li b/src/code_life/list.li
index e417314..35dc7aa 100644
--- a/src/code_life/list.li
+++ b/src/code_life/list.li
@@ -19,29 +19,29 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Expression list, immediate evaluation";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
-Section Private
-
+
+Section Private
+
+ expr_list:FAST_ARRAY(INSTR);
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <-
( + result:BOOLEAN;
+ j:INTEGER;
-
+
result := TRUE;
j := expr_list.lower;
{(j <= expr_list.upper) && {result}}.while_do {
@@ -49,125 +49,125 @@ Section Public
j := j + 1;
};
result
- );
-
+ );
+
- old_seq_or_and:UINTEGER_32;
-
+
//
// Linked list INSTR.
//
-
+
- lower:INTEGER <- expr_list.lower + 1;
- upper:INTEGER <- expr_list.upper + 1;
- count:INTEGER <- expr_list.count;
-
- - first:INSTR <- expr_list.first;
+
+ - first:INSTR <- expr_list.first;
- second:INSTR <- expr_list.second;
-
+
- item i:INTEGER :INSTR <- expr_list.item (i-1);
-
+
- current_item:INSTR <- expr_list.item index;
-
+
- last:INSTR <- expr_list.last;
-
+
- add_first i:INSTR <-
(
expr_list.add_first i;
-
+
verify_once;
-
+
);
-
- - add_last i:INSTR <-
+
+ - add_last i:INSTR <-
(
expr_list.add_last i;
-
+
verify_once;
-
- );
-
+
+ );
+
- add e:INSTR to idx:INTEGER <-
(
expr_list.add e to (idx-1);
-
+
verify_once;
-
+
);
-
+
- put e:INSTR to idx:INTEGER <-
(
- expr_list.put e to (idx-1);
- );
+ expr_list.put e to (idx-1);
+ );
- remove_last <-
(
expr_list.remove_last;
);
-
+
- remove_index idx:INTEGER <-
(
((list_current = Self) && {idx != index}).if {
"LIST.remove_index ! ".print; idx.print; '/'.print; index.print; ' '.print; print; '\n'.print;
};
-
+
expr_list.remove (idx-1);
);
-
+
//
// Iterator.
- //
-
+ //
+
+ index:INTEGER;
-
+
- inc_index <-
(
index := index + 1;
);
-
+
- insert_before e:INSTR <-
- (
+ (
? {e != NULL};
expr_list.add e to (index - 1);
index := index + 1;
-
+
verify_once;
-
+
);
- insert e:INSTR to idx:INTEGER <-
- (
+ (
? {e != NULL};
expr_list.add e to (idx - 1);
(idx <= index).if {
index := index + 1;
};
-
+
verify_once;
-
+
);
-
+
//
// Flags.
//
-
+
- is_empty:BOOLEAN <- count = 0;
-
+
//
// Creation.
//
-
+
- create p:POSITION :SELF <-
( + result:SELF;
result := clone;
result.make p;
result
);
-
+
- make p:POSITION <-
(
new_depend_pass;
position := p;
- expr_list := FAST_ARRAY(INSTR).create_with_capacity 2;
+ expr_list := FAST_ARRAY(INSTR).create_with_capacity 2;
);
- my_copy:SELF <-
@@ -177,9 +177,9 @@ Section Public
(lower).to (upper) do { j:INTEGER;
result.add_last (item j.my_copy);
};
-
+
verify_once;
-
+
result
);
@@ -188,86 +188,86 @@ Section Public
//
- remove <-
- (
- (lower).to (upper) do { j:INTEGER;
+ (
+ (lower).to (upper) do { j:INTEGER;
item j.remove;
- };
+ };
);
-
+
//
// Execute.
//
-
- - i_am_the_last i:INSTR :BOOLEAN <-
+
+ - i_am_the_last i:INSTR :BOOLEAN <-
(
last.i_am_the_last i
);
-
+
- execute:INSTR <-
- ( + result:INSTR;
-
- execute_case;
+ ( + result:INSTR;
+
+ execute_case;
(list_current != NULL).if {
- // Fusion list.
+ // Fusion list.
(expr_list.is_empty).if_false {
lower.to (upper-1) do { j:INTEGER;
list_current.insert_before (item j);
- };
- result := last;
- ? {result != NULL};
+ };
+ result := last;
+ ? {result != NULL};
new_execute_pass;
};
- } else {
+ } else {
result := Self;
- };
-
+ };
+
verify_once;
-
- result
- );
-
- - execute_case <-
- ( + new_expr:INSTR;
+
+ result
+ );
+
+ - execute_case <-
+ ( + new_expr:INSTR;
+ old_list_current:LIST;
-
+
+ old_expr:INSTR;
+ old_index:INTEGER;
-
+
//
- seq_list.add_last Self;
+ seq_list.add_last Self;
seq_inline := seq_inline + 1;
-
- // Update Context.
+
+ // Update Context.
old_list_current := list_current;
- list_current := Self;
-
+ list_current := Self;
+
// Execute expression list.
? {index = 0};
-
+
//"LIST BEG : ".print; print; '\n'.print;
-
+
index := lower;
- {index <= upper}.while_do {
- old_seq_or_and := seq_or_and;
-
+ {index <= upper}.while_do {
+ old_seq_or_and := seq_or_and;
+
old_expr := item index;
old_index := index;
-
- new_expr := item index.execute;
- (new_expr != NULL).if {
-
+
+ new_expr := item index.execute;
+ (new_expr != NULL).if {
+
((index = old_index) && {index > 1} && {item (old_index-1) = new_expr}).if {
- `*((unsigned int *)@old_expr)`:INTEGER_32.print;
+ `*((unsigned int *)@old_expr)`:INTEGER_32.print;
'\n'.print;
old_expr.debug_display;
"\nDevient\n".print;
new_expr.debug_display;
semantic_error (new_expr.position,"ICI");
- };
-
- put new_expr to index;
-
+ };
+
+ put new_expr to index;
+
(verify_once).if_false {
old_index.print; '-'.print;
index.print; '\n'.print;
@@ -275,8 +275,8 @@ Section Public
debug_display;
crash;
};
-
- index := index + 1;
+
+ index := index + 1;
(new_expr = CALL_NULL).if {
// Delete all ...
{index <= upper}.while_do {
@@ -286,94 +286,94 @@ Section Public
};
} else {
remove_index index;
- };
+ };
};
-
+
//"LIST END : ".print; print; '\n'.print;
-
- // Last.
- old_seq_or_and := seq_or_and;
+
+ // Last.
+ old_seq_or_and := seq_or_and;
index := 0; // Debug necessity
-
+
// Restore Context.
- list_current := old_list_current;
+ list_current := old_list_current;
//
- seq_list.remove_last;
+ seq_list.remove_last;
seq_inline := seq_inline + 1;
-
+
verify_once;
);
-
+
Section Public
-
+
//
// Generation.
//
-
+
- genere buffer:STRING <-
- (
+ (
buffer.append "{\n";
indent.append " ";
-
+
current_list_level := current_list_level + 1;
-
+
genere_body buffer;
-
+
current_list_level := current_list_level - 1;
-
- indent.remove_last 2;
+
+ indent.remove_last 2;
buffer.append indent;
buffer.add_last '}';
);
-
+
- genere_extern buffer:STRING <-
- ( + pos_local:INTEGER;
-
- // Local.
+ ( + pos_local:INTEGER;
+
+ // Local.
pos_local := buffer.count+1;
stack_local.clear;
-
+
ALIASER_LOCAL.reset;
-
+
genere_body buffer;
-
- // Local.
- string_tmp.clear;
+
+ // Local.
+ string_tmp.clear;
add_local (ALIASER_LOCAL.var_size.item 3) in string_tmp; // 64 bits
add_local (ALIASER_LOCAL.var_size.item 2) in string_tmp; // 32 bits
add_local (ALIASER_LOCAL.var_size.item 1) in string_tmp; // 16 bits
add_local (ALIASER_LOCAL.var_size.item 0) in string_tmp; // 8 bits
- buffer.insert_string string_tmp to pos_local;
+ buffer.insert_string string_tmp to pos_local;
);
-
+
//
// Display.
//
- display buffer:STRING <-
- (
- // Begin List.
+ (
+ // Begin List.
buffer.add_last '(';
-
+
// Code.
buffer.add_last '\n';
indent.append " ";
-
+
(lower).to (upper) do { j:INTEGER;
- buffer.append indent;
+ buffer.append indent;
item j.display buffer;
buffer.add_last '\n';
- };
+ };
indent.remove_last 2;
buffer.append indent;
-
+
// End List.
buffer.add_last ')';
display_ref buffer;
);
-
-Section Private
-
+
+Section Private
+
- verify_once:BOOLEAN <-
( + result:BOOLEAN;
result := TRUE;
@@ -386,9 +386,9 @@ Section Private
};
result
);
-
+
- genere_body buffer:STRING <-
- ( + old_count,j:INTEGER;
+ ( + old_count,j:INTEGER;
j := lower;
{j <= upper}.while_do {
buffer.append indent;
@@ -396,26 +396,26 @@ Section Private
{
item j.genere buffer;
j := j + 1;
- }.do_while {(j <= upper) && {old_count = buffer.count}};
+ }.do_while {(j <= upper) && {old_count = buffer.count}};
buffer.append ";\n";
- };
- );
-
+ };
+ );
+
- add_local tab:FAST_ARRAY(LOCAL) in buf:STRING <-
( + loc:LOCAL;
+ t:TYPE_FULL;
+ cur:INTEGER;
//+ i:INTEGER;
-
+
(! tab.is_empty).if {
(tab.lower).to (tab.upper) do { j:INTEGER;
- loc := tab.item j;
+ loc := tab.item j;
loc.is_result.if_false {
(loc.type.raw = TYPE_CONTEXT).if {
context_counter := context_counter + 1;
} else {
local_counter := local_counter + 1;
- };
+ };
//
simplify_type loc; // BSBS: Pas utile (c est un pb de result non utiliser)
//
@@ -436,12 +436,12 @@ Section Private
buf.append (loc.intern_name);
};
};
- buf.append ";\n";
+ buf.append ";\n";
};
);
-
+
Section LISAAC
- local_counter:INTEGER;
-
+
- context_counter:INTEGER;
\ No newline at end of file
diff --git a/src/code_life/loop.li b/src/code_life/loop.li
index 1072b73..5cc23d9 100644
--- a/src/code_life/loop.li
+++ b/src/code_life/loop.li
@@ -19,72 +19,72 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LOOP;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Loop (call tail recursive).";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
+ link_count:INTEGER;
-
+
+ body:LIST;
-
+
+ name:STRING_CONSTANT;
-
+
- set_link <-
(
link_count := link_count + 1;
);
-
+
- unset_link <-
(
link_count := link_count - 1;
? {link_count >= 0};
);
-
+
//
// Creation.
//
-
+
- create p:POSITION name lab:STRING_CONSTANT body lst:LIST :SELF <-
( + result:SELF;
result := clone;
result.make p name lab body lst;
result
);
-
+
- make p:POSITION name lab:STRING_CONSTANT body lst:LIST <-
- (
- position := p;
+ (
+ position := p;
name := lab;
body := lst;
);
-
+
- my_copy:SELF <-
( + result:SELF;
+ new_body:LIST;
+ switch:SWITCH;
+ case:LIST;
+ loop_end:LOOP_END;
-
+
new_body := body.my_copy;
result := LOOP.create position name (ALIAS_STR.get_intern name) body new_body;
//
- switch ?= new_body.last;
+ switch ?= new_body.last;
(switch.list.lower).to (switch.list.upper) do { k:INTEGER;
case := switch.list.item k.code;
(! case.is_empty).if {
loop_end ?= case.last;
- (loop_end != NULL).if {
+ (loop_end != NULL).if {
? {loop_end.loop = Self};
(loop_end.loop != Self).if {
semantic_error (position,"LOOP.my_copy BUG!!!");
@@ -94,20 +94,20 @@ Section Public
};
};
};
-
- (result.link_count != link_count).if {
+
+ (result.link_count != link_count).if {
name.print;
" Origin:".print;
link_count.print;
" copy:".print;
result.link_count.print;
'\n'.print;
-
+
body.debug_display;
-
+
semantic_error (position,"LOOP: Bug in copy.");
};
-
+
? {result.link_count = link_count};
result
);
@@ -117,21 +117,21 @@ Section Public
//
- remove <-
- (
- body.remove;
+ (
+ body.remove;
? {link_count = 0};
);
-
+
- execute:INSTR <-
- ( + result:INSTR;
+ ( + result:INSTR;
+ cur_seq_call_local_and_loop:INTEGER;
+ cur_seq_call_and_loop:INTEGER;
-
+
(link_count = 0).if {
result := body.execute;
new_execute_pass;
- } else {
- cur_seq_call_local_and_loop :=
+ } else {
+ cur_seq_call_local_and_loop :=
seq_call_local_and_loop := seq_call_local_and_loop + link_count;
//
cur_seq_call_and_loop :=
@@ -140,7 +140,7 @@ Section Public
seq_inline := seq_inline + 1;
//
result := Self;
- body.execute_case;
+ body.execute_case;
(loop_invariant = Self).if {
loop_list := list_current;
loop_seq_index := Old seq_index;
@@ -150,19 +150,19 @@ Section Public
//
seq_call_local_and_loop := seq_call_local_and_loop + link_count;
seq_call_and_loop := seq_call_and_loop + link_count;
- body.execute_case;
+ body.execute_case;
loop_invariant := NULL;
};
};
result
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
- (
+ (
buffer.append name;
display_ref buffer;
buffer.append ":\n";
@@ -173,34 +173,34 @@ Section Public
//
// Generation.
//
-
+
- genere buffer:STRING <-
- (
+ (
(! genere_while buffer).if {
-
- current_list_level := current_list_level + link_count;
-
+
+ current_list_level := current_list_level + link_count;
+
buffer.append name;
buffer.append ":\n";
buffer.append indent;
body.genere buffer;
};
);
-
+
- genere_while buffer:STRING :BOOLEAN <-
( + switch:SWITCH;
+ lst_true,lst_false,lst:LIST;
+ inverse:BOOLEAN;
+ result:BOOLEAN;
-
- (body.is_empty).if {
+
+ (body.is_empty).if {
semantic_error (position,"LOOP BUG: Body loop empty !");
};
switch ?= body.last;
(
- (switch != NULL) &&
+ (switch != NULL) &&
{switch.list.count = 2} &&
- {switch.list.first.id = type_true } &&
+ {switch.list.first.id = type_true } &&
{switch.list.second.id = type_false}
).if {
lst_true := switch.list.first.code;
@@ -212,23 +212,23 @@ Section Public
lst_true := lst_false;
lst_false := lst;
};
-
- current_list_level := current_list_level + 1;
-
+
+ current_list_level := current_list_level + 1;
+
(body.count = 1).if {
//
// While (...) do {...}.
//
result := TRUE;
inverse.if {
- buffer.append "while (!";
+ buffer.append "while (!";
} else {
- buffer.append "while (";
+ buffer.append "while (";
};
switch.expr.genere buffer;
//
buffer.append ") ";
- lst_true.remove_last;
+ lst_true.remove_last;
lst_true.genere buffer;
}.elseif {lst_true.count = 1} then {
//
@@ -239,19 +239,19 @@ Section Public
body.remove_last;
body.genere buffer;
inverse.if {
- buffer.append " while (!";
+ buffer.append " while (!";
} else {
- buffer.append " while (";
- };
+ buffer.append " while (";
+ };
//
switch.expr.genere buffer;
buffer.add_last ')';
- };
-
- current_list_level := current_list_level - 1;
-
+ };
+
+ current_list_level := current_list_level - 1;
+
};
};
result
);
-
+
diff --git a/src/code_life/loop_end.li b/src/code_life/loop_end.li
index dfd5891..8746cf3 100644
--- a/src/code_life/loop_end.li
+++ b/src/code_life/loop_end.li
@@ -19,43 +19,43 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LOOP_END;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Loop end (call tail recursive).";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
+ loop:LOOP;
-
+
//
// Creation.
//
-
+
- create p:POSITION loop l:LOOP :SELF <-
( + result:SELF;
result := clone;
result.make p loop l;
result
);
-
+
- make p:POSITION loop l:LOOP <-
- (
- position := p;
+ (
+ position := p;
loop := l;
loop.set_link;
);
-
+
- my_copy:SELF <-
- (
+ (
// Warning: See LOOP.my_copy
Self
);
@@ -65,35 +65,35 @@ Section Public
//
- remove <-
- (
- loop.unset_link;
+ (
+ loop.unset_link;
);
-
+
- execute:INSTR <-
- (
+ (
(list_current = loop.body).if {
POSITION.put_error semantic text "Recursivity without end (LOOP_END).";
loop.position.put_position;
position.put_position;
POSITION.send_error;
};
-
+
((is_optimization) && {loop_invariant = NULL} && {loop.link_count = 1}).if {
loop_invariant := loop;
};
-
+
seq_call_local_and_loop := seq_call_local_and_loop - 1;
- seq_call_and_loop := seq_call_and_loop - 1;
+ seq_call_and_loop := seq_call_and_loop - 1;
seq_inline := seq_inline + 1;
Self
);
-
+
//
// Display.
//
- display buffer:STRING <-
- (
+ (
buffer.append "goto ";
buffer.append (loop.name);
display_ref buffer;
@@ -102,12 +102,12 @@ Section Public
//
// Generation.
//
-
+
- genere buffer:STRING <-
- (
+ (
buffer.append "goto ";
buffer.append (loop.name);
-
- current_list_level := current_list_level - 1;
+
+ current_list_level := current_list_level - 1;
);
-
+
diff --git a/src/code_life/nop.li b/src/code_life/nop.li
index 4c2e22e..e801b02 100644
--- a/src/code_life/nop.li
+++ b/src/code_life/nop.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NOP;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "The nop instruction";
-
+
// BSBS: il faurai voir si c'est encore utile... (attention à la phase recursive)
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
- my_copy:SELF <- Self;
-
+
//
// Execute.
//
@@ -46,7 +46,7 @@ Section Public
(
// Nothing.
);
-
+
- execute:INSTR <- NULL;
//
diff --git a/src/code_life/push.li b/src/code_life/push.li
index 08503e5..5dd2d34 100644
--- a/src/code_life/push.li
+++ b/src/code_life/push.li
@@ -19,73 +19,73 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PUSH;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Push context for debug mode";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section PUSH,LISAAC
-
- - source_line:HASHED_DICTIONARY(STRING,UINTEGER_32) :=
+
+ - source_line:HASHED_DICTIONARY(STRING,UINTEGER_32) :=
HASHED_DICTIONARY(STRING,UINTEGER_32).create;
-
+
Section Public
-
+
+ context:LOCAL;
-
+
+ is_first:BOOLEAN;
-
+
- set_first f:BOOLEAN <-
(
is_first := f;
);
-
+
//
// Creation.
//
-
+
- create pos:POSITION context v:LOCAL first f:BOOLEAN :SELF <-
( + result:SELF;
? {v != NULL};
-
+
result := clone;
result.make pos context v first f;
result
);
-
+
- make pos:POSITION context v:LOCAL first f:BOOLEAN <-
- ( ? {pos.code != 0};
+ ( ? {pos.code != 0};
? {v != NULL};
(v = NULL).if {
crash_with_message "PUSH";
- };
+ };
position := pos;
context := v;
- is_first := f;
+ is_first := f;
);
-
- - my_copy:SELF <-
+
+ - my_copy:SELF <-
( + result:SELF;
+ new_context:LOCAL;
-
+
(LOCAL.is_alias).if {
new_context := context.get_alias;
new_context.set_ensure_count 1;
result := create position context new_context first is_first;
- } else {
+ } else {
result := create position context context first is_first;
};
- result
+ result
);
-
+
//
// Execute.
//
@@ -94,11 +94,11 @@ Section Public
(
// Nothing.
);
-
- - execute:INSTR <-
+
+ - execute:INSTR <-
( + result:INSTR;
+ other:SELF;
-
+
result := Self;
(list_current.index < list_current.upper).if {
other ?= list_current.item (list_current.index + 1);
@@ -111,7 +111,7 @@ Section Public
}.elseif {(is_first) && {! other.is_first}} then {
result := NULL;
};
- };
+ };
};
result
);
@@ -119,13 +119,13 @@ Section Public
//
// Genere
//
-
+
- genere buffer:STRING <-
( + id:UINTEGER_32;
+ idf:STRING_CONSTANT;
-
- idf := ALIASER_LOCAL.push Self;
- (is_first).if {
+
+ idf := ALIASER_LOCAL.push Self;
+ (is_first).if {
buffer.append "lisaac_push_first(&";
} else {
buffer.append "lisaac_push(&";
@@ -140,12 +140,12 @@ Section Public
buffer.add_last 'L';
};
id.append_in buffer;
- buffer.add_last ')';
-
+ buffer.add_last ')';
+
buffer.append "; /* L";
position.line.append_in buffer;
buffer.add_last ' ';
- buffer.append (position.prototype.name);
+ buffer.append (position.prototype.name);
buffer.append "*/";
);
diff --git a/src/code_life/read.li b/src/code_life/read.li
index 4707212..60dbcbe 100644
--- a/src/code_life/read.li
+++ b/src/code_life/read.li
@@ -19,64 +19,64 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := READ;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Read for local, global or slot";
-
+
Section Inherit
+ parent_expr:Expanded EXPR;
-
+
Section Public
-
+
- is_slot:BOOLEAN <- FALSE;
-
- - variable:VARIABLE <-
+
+ - variable:VARIABLE <-
(
deferred;
NULL
);
- - static_type:TYPE_FULL <-
- (
+ - static_type:TYPE_FULL <-
+ (
variable.type
);
-
+
- my_copy:SELF <-
( + result:SELF;
result ?= variable.read position;
result
);
-
+
//
// Searching.
//
-
+
- get_type t:TYPES_TMP <-
- (
+ (
variable.get_type t;
);
-
+
- get_last_value:EXPR <- variable.get_last_value NULL;
-
+
//
// Executing pass.
//
- remove <-
(
- variable.unread Self;
+ variable.unread Self;
);
-
+
- is_require_constant:CONSTANT <-
( + result:CONSTANT;
+ j:INTEGER;
- + val:EXPR;
+ + val:EXPR;
+ req_list:FAST_ARRAY(WRITE);
//? { variable.require_first != NULL };
/* BSBS: A REVOIR
@@ -109,22 +109,22 @@ Section Public
result
);
- - execute_access_unlink:INSTR <-
+ - execute_access_unlink:INSTR <-
(
deferred;
NULL
);
-
+
- execute_access_link <- deferred;
-
+
- execute_unlink:INSTR <-
// Delete read
(
variable.unread Self;
new_execute_pass;
- execute_access_unlink
+ execute_access_unlink
);
-
+
- execute_link:EXPR <-
( + cst:CONSTANT;
+ rec:INSTR;
@@ -132,19 +132,19 @@ Section Public
+ val:EXPR;
+ s:SLOT_DATA;
+ l:LOCAL;
- + wrt:WRITE;
+ + wrt:WRITE;
//+ old_loop_invariant:LOOP;
-
+
simplify_type variable;
-
+
//
s ?= variable;
- (
+ (
(s = NULL) || {
((s.style != '+') || {! s.id_section.is_mapping}) &&
{(! variable.type.is_expanded) || {variable.type.is_default_expanded}}
}
- ).if {
+ ).if {
cst := is_require_constant; // BSBS: Ce cas devrait rentrer dans get_last_value
(cst != NULL).if {
//
@@ -157,30 +157,30 @@ Section Public
};
result := cst.my_copy;
new_execute_pass;
- }.elseif {
+ }.elseif {
(val := get_last_value) != NULL
} then {
//
// VALUE_EXPR propagation, step by step.
- //
+ //
result := val;
- variable.unread Self;
+ variable.unread Self;
new_execute_pass;
};
};
-
+
(result = NULL).if {
//
// Normal.
- //
- ((is_slot) && {loop_invariant != NULL} && {is_invariant}).if {
+ //
+ ((is_slot) && {loop_invariant != NULL} && {is_invariant}).if {
//old_loop_invariant := loop_invariant;
//loop_invariant := NULL;
//
l := static_type.get_temporary position;
wrt := l.write position value Self;
loop_list.insert_before wrt;
- result := l.read position;
+ result := l.read position;
//
//wrt.execute;
//result := result.execute_link;
@@ -190,7 +190,7 @@ Section Public
} else {
variable.set_read;
execute_access_link;
- result := Self;
+ result := Self;
};
};
result
@@ -223,7 +223,7 @@ Section Public
buffer.add_last '>';
//};
);
-
+
- display buffer:STRING <-
(
buffer.append (variable.intern_name);
diff --git a/src/code_life/read_global.li b/src/code_life/read_global.li
index 0c35093..7ce7d39 100644
--- a/src/code_life/read_global.li
+++ b/src/code_life/read_global.li
@@ -19,80 +19,80 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := READ_GLOBAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Read for global";
-
+
Section Inherit
-
+
+ parent_read:Expanded READ;
-
+
Section Public
-
- - is_invariant:BOOLEAN <- global.is_invariant NULL;
-
+
+ - is_invariant:BOOLEAN <- global.is_invariant NULL;
+
+ global:SLOT_DATA;
-
+
- variable:VARIABLE <- global;
-
+
//
// Comparison.
//
-
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + rd:READ_GLOBAL;
-
+
rd ?= other;
- ((rd != NULL) && {global = rd.global})
+ ((rd != NULL) && {global = rd.global})
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with g:SLOT_DATA :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with g;
- result
+ result
);
-
+
- make p:POSITION with g:SLOT_DATA <-
(
position := p;
global := g;
);
-
+
//
// Execute
//
-
- - execute_access_unlink:INSTR <-
+
+ - execute_access_unlink:INSTR <-
(
global.execute;
NULL
);
- - execute_access_link <-
+ - execute_access_link <-
(
global.execute;
);
-
+
//
// Genere
//
-
+
- genere buffer:STRING <-
- (
+ (
buffer.append (variable.intern_name);
);
-
+
diff --git a/src/code_life/read_local.li b/src/code_life/read_local.li
index 3974221..05074ea 100644
--- a/src/code_life/read_local.li
+++ b/src/code_life/read_local.li
@@ -19,86 +19,86 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := READ_LOCAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Read for local.";
-
+
Section Inherit
-
+
+ parent_read:Expanded READ;
-
+
Section Public
-
- - is_invariant:BOOLEAN <- local.is_invariant;
-
+
+ - is_invariant:BOOLEAN <- local.is_invariant;
+
+ local:LOCAL;
-
+
- variable:VARIABLE <- local;
-
+
//
// Comparison.
//
-
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + rd:READ_LOCAL;
-
+
rd ?= other;
- ((rd != NULL) && {local = rd.local})
+ ((rd != NULL) && {local = rd.local})
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with l:LOCAL :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with l;
- result
+ result
);
-
+
- make p:POSITION with l:LOCAL <-
(
position := p;
- local := l;
+ local := l;
);
-
+
//
// Execute
//
-
+
- execute_access_unlink:INSTR <- NULL;
-
+
- execute_access_link;
-
+
//
// Genere
//
-
+
- genere buffer:STRING <-
( + tb:PROFIL_BLOCK;
+ idf:STRING_CONSTANT;
-
+
idf := ALIASER_LOCAL.read Self;
(local.is_result /*ensure_count = -100*/).if {
buffer.add_last '*';
};
buffer.append idf;
//
-
- tb ?= local.type.raw;
+
+ tb ?= local.type.raw;
(tb != NULL).if {
ALIASER_LOCAL.add_var_size local;
};
-
+
);
-
+
diff --git a/src/code_life/read_slot.li b/src/code_life/read_slot.li
index b6eda5f..f2fa2a1 100644
--- a/src/code_life/read_slot.li
+++ b/src/code_life/read_slot.li
@@ -19,119 +19,119 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := READ_SLOT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Read for slot";
-
+
Section Inherit
-
+
+ parent_read:Expanded READ;
-
+
Section Public
-
+
- is_slot:BOOLEAN <- TRUE;
-
- - is_invariant:BOOLEAN <- slot.is_invariant receiver;
-
+
+ - is_invariant:BOOLEAN <- slot.is_invariant receiver;
+
+ slot:SLOT_DATA;
-
+
+ receiver:EXPR;
-
+
- variable:VARIABLE <- slot;
-
- - get_last_value:EXPR <- variable.get_last_value receiver;
-
+
+ - get_last_value:EXPR <- variable.get_last_value receiver;
+
//
// Comparison.
//
-
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + rd:READ_SLOT;
-
+
rd ?= other;
- ((rd != NULL) && {slot = rd.slot} && {receiver ~= rd.receiver})
+ ((rd != NULL) && {slot = rd.slot} && {receiver ~= rd.receiver})
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with (r:EXPR,s:SLOT_DATA) :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with (r,s);
- result
+ result
);
-
+
- make p:POSITION with (r:EXPR,s:SLOT_DATA) <-
(
position := p;
receiver := r;
slot := s;
);
-
+
- my_copy:SELF <-
( + result:SELF;
-
+
result ?= slot.read position with (receiver.my_copy);
result
);
-
+
//
// Executing pass.
//
-
+
- remove <-
(
receiver.remove;
parent_read.remove;
);
-
- - execute_access_unlink:INSTR <-
+
+ - execute_access_unlink:INSTR <-
(
slot.execute;
receiver.execute_unlink
);
-
- - execute_access_link <-
- (
+
+ - execute_access_link <-
+ (
slot.execute;
- receiver := receiver.execute_link;
+ receiver := receiver.execute_link;
);
//
// Genere
//
-
+
- genere buffer:STRING <-
( + tf,tf2:TYPE_FULL;
+ t:TYPE;
+ add_end:BOOLEAN;
+ ptr,ptr2:BOOLEAN;
-
+
(is_java).if {
receiver.genere buffer;
//not_yet_implemented;
buffer.add_last '.';
buffer.append (variable.intern_name);
- } else {
+ } else {
(slot.intern_name = ALIAS_STR.slot_self).if {
buffer.append "((";
tf := slot.type;
- tf.genere_declaration buffer;
+ tf.genere_declaration buffer;
buffer.add_last ' ';
- tf.genere_star_declaration buffer;
+ tf.genere_star_declaration buffer;
buffer.add_last ')';
receiver.genere buffer;
buffer.append ".self)";
} else {
- tf := receiver.static_type;
+ tf := receiver.static_type;
t := slot.receiver_type;
(t.alias_slot != NULL).if {
tf2 := slot.type;
@@ -150,38 +150,38 @@ Section Public
(tf.is_strict) || {tf.is_expanded_ref} || {tf.is_expanded}
).if {
receiver.genere buffer;
- } else {
- buffer.append "((";
- t.put_reference_declaration buffer;
+ } else {
+ buffer.append "((";
+ t.put_reference_declaration buffer;
buffer.add_last ' ';
- t.put_reference_star_declaration buffer;
+ t.put_reference_star_declaration buffer;
buffer.add_last ')';
receiver.genere buffer;
- buffer.add_last ')';
+ buffer.add_last ')';
};
(t.alias_slot = NULL).if {
((tf.is_expanded) && {! tf.is_expanded_ref} && {! tf.is_strict}).if {
buffer.add_last '.';
} else {
buffer.append "->";
- };
- buffer.append (variable.intern_name);
+ };
+ buffer.append (variable.intern_name);
}.elseif {add_end} then {
buffer.append "))";
};
- };
+ };
};
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
receiver.display buffer;
buffer.append "->";
- parent_read.display buffer;
+ parent_read.display buffer;
);
diff --git a/src/code_life/result.li b/src/code_life/result.li
index f3a4ad9..1247250 100644
--- a/src/code_life/result.li
+++ b/src/code_life/result.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := RESULT;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,16 +32,16 @@ Section Inherit
- parent_expr:EXPR := EXPR;
Section Public
-
+
- position:POSITION <- value.position;
-
- + write:WRITE;
-
+
+ + write:WRITE;
+
- set_write v:WRITE <-
(
write := v;
);
-
+
//
// Creation.
//
@@ -54,48 +54,47 @@ Section Public
);
- make v:WRITE <-
- (
+ (
write := v;
);
-
+
- my_copy:SELF <-
( + wrt:WRITE;
+ rd:READ;
rd ?= write.value;
(rd = NULL).if {
- wrt := write.variable.write (write.position) with NULL value (write.value.my_copy);
+ wrt := write.variable.write (write.position) with NULL value (write.value.my_copy);
} else {
- rd := rd.variable.read_direct (rd.position) with NULL;
- wrt := write.variable.write (write.position) with NULL value rd;
+ rd := rd.variable.read_direct (rd.position) with NULL;
+ wrt := write.variable.write (write.position) with NULL value rd;
};
create wrt
);
-
+
- execute:INSTR <-
(
write ?= write.execute;
Self
);
-
+
//
// Remove
//
-
+
- remove <-
(
write.remove;
);
-
+
//
// Expr definition.
- //
-
+ //
+
- static_type:TYPE_FULL <- write.value.static_type;
-
+
- get_type t:TYPES_TMP <- write.value.get_type t;
-
+
- execute_link:EXPR <- write.execute_link;
-
+
- execute_unlink:INSTR <- write.execute_unlink;
-
-
\ No newline at end of file
+
diff --git a/src/code_life/switch.li b/src/code_life/switch.li
index aafdecc..80c958a 100644
--- a/src/code_life/switch.li
+++ b/src/code_life/switch.li
@@ -19,28 +19,28 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SWITCH;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Switch for late binding resolution";
-
+
// BSBS: Optim. : Détecter les switch identique l'un après l'autre
// pour les fusionner...
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <-
( + result:BOOLEAN;
+ j:INTEGER;
-
+
(expr.is_invariant).if {
result := TRUE;
j := list.lower;
@@ -51,30 +51,30 @@ Section Public
};
result
);
-
+
+ expr:EXPR;
-
+
+ list:FAST_ARRAY(CASE);
-
+
- count:INTEGER <- list.count;
-
+
//
// Creation.
//
-
+
- create n:NODE with e:EXPR size s:INTEGER :SELF <-
[ -? {n.position != 0}; ]
( + result:SELF;
-
+
result := clone;
result.make n with e size s;
result
- );
-
-
- - make n:NODE with e:EXPR size s:INTEGER <-
+ );
+
+
+ - make n:NODE with e:EXPR size s:INTEGER <-
( + first:CASE;
-
+
position := n.position;
expr := e;
list := FAST_ARRAY(CASE).create_with_capacity s;
@@ -83,11 +83,11 @@ Section Public
list.add_last first;
};
);
-
+
//
// Copy.
//
-
+
- set_expr e:EXPR list l:FAST_ARRAY(CASE) <-
(
expr := e;
@@ -97,21 +97,21 @@ Section Public
- my_copy:SELF <-
( + result:SELF;
+ new_list:FAST_ARRAY(CASE);
-
+
new_list := FAST_ARRAY(CASE).create_with_capacity (list.count);
(list.lower).to (list.upper) do { j:INTEGER;
new_list.add_last (list.item j.my_copy);
};
-
+
result := clone;
result.set_expr (expr.my_copy) list new_list;
result
);
-
+
//
// Remove.
//
-
+
- remove <-
(
(expr != NULL).if {
@@ -119,17 +119,17 @@ Section Public
};
(list.lower).to (list.upper) do { j:INTEGER;
list.item j.remove;
- };
+ };
);
-
+
//
// Execute
//
-
- - i_am_the_last i:INSTR :BOOLEAN <-
+
+ - i_am_the_last i:INSTR :BOOLEAN <-
( + result:BOOLEAN;
+ j:INTEGER;
-
+
j := list.lower;
{(j <= list.upper) && {!result}}.while_do {
result := list.item j.code.i_am_the_last i;
@@ -139,28 +139,28 @@ Section Public
);
- execute:INSTR <-
- ( + lst_typ:TYPES_TMP;
+ ( + lst_typ:TYPES_TMP;
+ result:INSTR;
+ typ:TYPE;
+ wrt:WRITE;
+ lst:LIST;
- + tb:PROFIL_BLOCK;
+ + tb:PROFIL_BLOCK;
+ is_end:BOOLEAN;
+ count_empty:INTEGER;
-
+
// Update.
- lst_typ := TYPES_TMP.new;
+ lst_typ := TYPES_TMP.new;
// BSBS: optim a voir si necessaire ...
- /*
+ /*
(expr.static_type.is_strict).if {
- lst_typ.add (expr.static_type.raw);
- } else {
+ lst_typ.add (expr.static_type.raw);
+ } else {
*/
- expr.get_type lst_typ;
+ expr.get_type lst_typ;
//};
- ? {lst_typ.count <= list.count};
-
- (lst_typ.count > list.count).if {
+ ? {lst_typ.count <= list.count};
+
+ (lst_typ.count > list.count).if {
"New type: ".print;
lst_typ.print;
"\nOld type: ".print;
@@ -175,23 +175,23 @@ Section Public
string_tmp.clear;
profil_current.display string_tmp;
string_tmp.print;
-
-
+
+
( + wrt2:WRITE;
+ rd:READ;
+ var:VARIABLE;
-
+
rd ?= expr;
var := rd.variable;
wrt2 := var.require_first;
rd ?= wrt2.value;
var := rd.variable;
-
+
wrt2 := var.require_first;
wrt2.debug_display;
"==============\n".print;
(var.require_list.lower).to (var.require_list.upper) do { i:INTEGER;
- "==============\n".print;
+ "==============\n".print;
i.print; '\n'.print;
wrt2 := var.require_list.item i;
wrt2.debug_display;
@@ -202,32 +202,32 @@ Section Public
);*/
syntax_error (expr.position,"*****SWITCH BUG********");
};
-
- //
+
+ //
// BSBS: Ajoute un pattern pour les elseif ...
- //
- (lst_typ.lower).to (lst_typ.upper) do { j:INTEGER;
- typ := lst_typ.item j;
+ //
+ (lst_typ.lower).to (lst_typ.upper) do { j:INTEGER;
+ typ := lst_typ.item j;
{typ = list.item j.id}.until_do {
list.item j.remove;
- list.remove j;
+ list.remove j;
};
(list.item j.code.is_empty).if {
count_empty := count_empty + 1;
};
- };
- {lst_typ.count = list.count}.until_do {
+ };
+ {lst_typ.count = list.count}.until_do {
list.last.remove;
- list.remove_last;
- };
+ list.remove_last;
+ };
lst_typ.free;
-
+
// Execute.
(
(list.count = 1) || {
- (list.count = 2) &&
- {debug_level_option = 0} &&
- {list.first.id = TYPE_NULL} &&
+ (list.count = 2) &&
+ {debug_level_option = 0} &&
+ {list.first.id = TYPE_NULL} &&
{! list.first.code.is_empty} &&
{
wrt ?= list.first.code.first; // For ?= with NULL type.
@@ -245,7 +245,7 @@ Section Public
};
result := list.last.code.execute;
is_end := TRUE;
- }.elseif {count_empty = list.count} then {
+ }.elseif {count_empty = list.count} then {
result := expr.execute_unlink;
(list.lower).to (list.upper) do { j:INTEGER;
list.item j.remove;
@@ -254,10 +254,10 @@ Section Public
};
//
(! is_end).if {
- // Normal execution.
+ // Normal execution.
(
- (expr.static_type.raw = type_boolean) &&
- {list.count = 2} &&
+ (expr.static_type.raw = type_boolean) &&
+ {list.count = 2} &&
{list.first.code.is_empty}
).if {
? {! list.second.code.is_empty};
@@ -270,34 +270,34 @@ Section Public
seq_or_and := seq_or_and + 1;
seq_inline := seq_inline + 1;
*/
- expr := expr.execute_link;
-
+ expr := expr.execute_link;
+
CALL_SLOT.reset_count_no_recursive;
- ((list.first.id = TYPE_NULL) && {list.count = 2}).if {
+ ((list.first.id = TYPE_NULL) && {list.count = 2}).if {
list.first .code.execute_case;
- list.second.code.execute_case;
+ list.second.code.execute_case;
((list.second.id.is_block) && {debug_level_option != 0}).if {
list.second.id.set_late_binding;
};
- } else {
+ } else {
(list.lower).to (list.upper) do { j:INTEGER;
- list.item j.execute;
+ list.item j.execute;
};
- };
+ };
result := detect_logic_expr;
- (result = NULL).if {
+ (result = NULL).if {
result := Self;
};
- };
+ };
result
);
-
+
//
// Genere.
//
-
+
- count_bug:INTEGER;
-
+
- genere buffer:STRING <-
( + lst:LIST;
+ first_case:INTEGER;
@@ -308,80 +308,80 @@ Section Public
+ c1,c2:CASE;
+ lst_case:FAST_ARRAY(CASE);
+ cases:FAST_ARRAY(FAST_ARRAY(CASE));
-
+
buffer.append "/* ";
- (list.lower).to (list.upper) do { i:INTEGER;
+ (list.lower).to (list.upper) do { i:INTEGER;
list.item i.id.put_id buffer;
buffer.add_last ' ';
};
buffer.append "*/\n";
(
- (list.first.id = TYPE_NULL) &&
- {debug_level_option = 0} &&
- {! list.first.code.is_empty} &&
+ (list.first.id = TYPE_NULL) &&
+ {debug_level_option = 0} &&
+ {! list.first.code.is_empty} &&
{
wrt ?= list.first.code.first; // For ?= with NULL type.
wrt = NULL
}
).if {
list.remove_first;
- };
+ };
typ_first := list.first.id;
- typ_id ?= typ_first;
+ typ_id ?= typ_first;
((list.count <= 2) || {typ_first = TYPE_NULL}).if {
buffer.append "if (";
- //
- ((expr.static_type.raw.is_block) && {typ_first = TYPE_NULL}).if {
+ //
+ ((expr.static_type.raw.is_block) && {typ_first = TYPE_NULL}).if {
expr.genere buffer;
is_genered := TRUE;
buffer.append ".__id==0";
- } else {
- typ_first.put_access_id expr in buffer;
+ } else {
+ typ_first.put_access_id expr in buffer;
is_genered := TRUE;
(expr.static_type.raw != type_boolean).if {
buffer.append "==";
- typ_first.put_id buffer;
+ typ_first.put_id buffer;
} else {
? {typ_first.name = ALIAS_STR.prototype_true};
};
};
buffer.append ") ";
//
- list.first.genere buffer;
+ list.first.genere buffer;
first_case := 1;
//
(list.count = 2).if {
- lst := list.second.code;
+ lst := list.second.code;
(! list.second.code.is_empty).if {
- buffer.append " else ";
- buffer.append "/* ";
+ buffer.append " else ";
+ buffer.append "/* ";
buffer.append (list.second.id.name);
- buffer.append " */ ";
- list.second.genere buffer;
+ buffer.append " */ ";
+ list.second.genere buffer;
};
first_case := 2;
}.elseif {list.count > 2} then {
buffer.append " else {\n";
indent.append " ";
- buffer.append indent;
+ buffer.append indent;
};
};
(first_case <= list.upper).if {
(is_genered).if {
- expr := expr.my_copy;
+ expr := expr.my_copy;
};
cases := case_fusion first_case;
(cases.count = 2).if {
(cases.first.count = 1).if {
c1 := cases.first.first;
- c2 := cases.second.first;
+ c2 := cases.second.first;
}.elseif {cases.second.count = 1} then {
c1 := cases.second.first;
- c2 := cases.first.first;
+ c2 := cases.first.first;
};
};
(c1 != NULL).if {
- buffer.append "if (";
+ buffer.append "if (";
c1.id.put_access_id expr in buffer;
buffer.append "==";
c1.id.put_id buffer;
@@ -390,36 +390,36 @@ Section Public
buffer.append " else /* Other types */ ";
c2.genere buffer;
} else {
- polymorphic_counter := polymorphic_counter + 1;
- buffer.append "switch (";
+ polymorphic_counter := polymorphic_counter + 1;
+ buffer.append "switch (";
list.item first_case.id.put_access_id expr in buffer;
buffer.append ") {\n";
(cases.lower).to (cases.upper) do { j:INTEGER;
lst_case := cases.item j;
(! lst_case.first.code.is_empty).if {
- (lst_case.lower).to (lst_case.upper) do { i:INTEGER;
- buffer.append indent;
+ (lst_case.lower).to (lst_case.upper) do { i:INTEGER;
+ buffer.append indent;
buffer.append "case ";
lst_case.item i.id.put_id buffer;
- buffer.append ": \n";
+ buffer.append ": \n";
};
- buffer.remove_last 1;
- lst_case.first.genere buffer;
+ buffer.remove_last 1;
+ lst_case.first.genere buffer;
buffer.append " break;\n";
- }
-
+ }
+
// Debug...
else {
- (lst_case.lower).to (lst_case.upper) do { i:INTEGER;
- buffer.append indent;
+ (lst_case.lower).to (lst_case.upper) do { i:INTEGER;
+ buffer.append indent;
buffer.append "case ";
lst_case.item i.id.put_id buffer;
- buffer.append ": \n";
+ buffer.append ": \n";
};
- buffer.remove_last 1;
+ buffer.remove_last 1;
buffer.append " break;\n";
- };
- };
+ };
+ };
// Debug...
(debug_level_option != 0).if {
buffer.append indent;
@@ -429,28 +429,28 @@ Section Public
\print_string(\"Call on twilight zone!!!\\n\"); \
\die_with_code(1);\n";
};
-
+
buffer.append indent;
buffer.add_last '}';
};
free_list_cases cases;
(first_case != 0).if {
buffer.add_last '\n';
- indent.remove_last 2;
+ indent.remove_last 2;
buffer.append indent;
buffer.add_last '}';
};
};
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
( + line:{INTEGER; };
-
- line :=
+
+ line :=
{ j:INTEGER;
+ i:LIST;
buffer.append indent;
@@ -466,30 +466,30 @@ Section Public
i.display buffer;
};
};
-
+
buffer.append "Switch ";
expr.display buffer;
buffer.add_last '\n';
(list.count > 0).if {
- indent.append "| ";
+ indent.append "| ";
0.to (list.upper - 1) do { j:INTEGER;
line.value j;
buffer.add_last '\n';
- };
+ };
indent.put ' ' to (indent.upper-1);
line.value (list.upper);
indent.remove_last 2;
};
);
-
+
- switch_new_pass:BOOLEAN;
- reset_switch_new_pass <-
(
switch_new_pass := FALSE;
);
-
+
Section Private
-
+
- detect_logic_expr:INSTR <-
// Detection !, |, &, ||, && :
( + result:INSTR;
@@ -499,37 +499,37 @@ Section Private
+ a,b,c,d:BOOLEAN;
(
- (expr.static_type.raw = type_boolean) &&
- {list.count = 2} &&
- {list.first.code.count = 1} &&
+ (expr.static_type.raw = type_boolean) &&
+ {list.count = 2} &&
+ {list.first.code.count = 1} &&
{list.second.code.count = 1}
).if {
? {list.first.id = type_true };
? {list.second.id = type_false};
-
+
((list.first.id != type_true) || {list.second.id != type_false}).if {
syntax_error (position,"PB dans SWITCH.");
};
-
+
wr_true ?= list.first .code.first;
wr_false ?= list.second.code.first;
(
- (wr_true != NULL) &&
+ (wr_true != NULL) &&
{wr_false != NULL} &&
{wr_true.static_type.raw = type_boolean} &&
{wr_true.variable = wr_false.variable}
).if {
val_true := wr_true .value;
- val_false := wr_false.value;
+ val_false := wr_false.value;
// BSBS: val_true.static_type = type_true ???
(
- (a := val_true.is_constant) &&
+ (a := val_true.is_constant) &&
{b := (val_true.static_type.raw = type_true)}
).if {
// | or ||
- rd ?= val_false;
+ rd ?= val_false;
(rd != NULL).if {
- // |
+ // |
wr_true.remove;
val_false := EXPR_OR_LOGIC.create position with expr and val_false;
wr_false.set_value val_false;
@@ -542,48 +542,48 @@ Section Private
wr_false.set_value val_false;
result := wr_false;
switch_new_pass := TRUE;
- };
+ };
}.elseif {
- (c := val_false.is_constant) &&
+ (c := val_false.is_constant) &&
{d := (val_false.static_type.raw = type_false)}
} then {
- // & or &&
- rd ?= val_true;
+ // & or &&
+ rd ?= val_true;
(rd != NULL).if {
- // &
- wr_false.remove;
+ // &
+ wr_false.remove;
val_true := EXPR_AND_LOGIC.create position with expr and val_true;
wr_true.set_value val_true;
- result := wr_true;
+ result := wr_true;
new_execute_pass;
}.elseif {(CALL_SLOT.count_no_recursive = 0) || {modify_count = 0}} then {
- // &&
+ // &&
wr_false.remove;
val_true := EXPR_AND_AND_LOGIC.create position with expr and val_true;
wr_true.set_value val_true;
result := wr_true;
switch_new_pass := TRUE;
- };
+ };
}.elseif {
(a) && {!b} && {c} && {!d}
} then {
// !
wr_false.remove;
wr_true.set_value (EXPR_NOT_LOGIC.create position with expr);
- result := wr_true;
+ result := wr_true;
new_execute_pass;
};
};
};
result
);
-
+
- switch_fusion <-
( + other:SWITCH;
+ index:INTEGER;
+ wrt:WRITE;
+ rd,rd2:READ;
-
+
index := list_current.index + 1;
other ?= list_current.item index;
((other != NULL) && {other.expr == expr} && {other.list.count = list.count}).if {
@@ -594,11 +594,11 @@ Section Private
// BSBS: Dans ce cas la, tu devrai en avoir 250 !!!!
// Regarde pourquoi tu n'as que 14 cas !
wrt ?= list_current.item index;
- rd ?= expr;
+ rd ?= expr;
((wrt != NULL) && {rd != NULL} && {wrt.variable != rd.variable}).if {
- rd2 ?= wrt.value;
+ rd2 ?= wrt.value;
other ?= list_current.item (index + 1);
- ((rd2 != NULL) && {other != NULL} &&
+ ((rd2 != NULL) && {other != NULL} &&
{other.expr == expr} && {other.list.count = list.count}).if {
(list.lower).to (list.upper-1) do { j:INTEGER;
list.item j.code.add_last (wrt.my_copy);
@@ -606,16 +606,16 @@ Section Private
list.last.code.add_last wrt;
list_current.put NOP to index;
concat_switch other;
- list_current.put NOP to (index + 1);
+ list_current.put NOP to (index + 1);
};
};
};
);
-
+
- concat_switch other:SWITCH <-
( + other_list:FAST_ARRAY(CASE);
+ code:LIST;
-
+
other.expr.remove;
other_list := other.list;
(list.lower).to (list.upper) do { j:INTEGER;
@@ -624,17 +624,17 @@ Section Private
};
new_execute_pass;
);
-
+
//
// Case fusion manager.
//
-
- - store_list_cases:FAST_ARRAY(FAST_ARRAY(FAST_ARRAY(CASE))) :=
+
+ - store_list_cases:FAST_ARRAY(FAST_ARRAY(FAST_ARRAY(CASE))) :=
FAST_ARRAY(FAST_ARRAY(FAST_ARRAY(CASE))).create_with_capacity 32;
-
- - store_cases:FAST_ARRAY(FAST_ARRAY(CASE)) :=
+
+ - store_cases:FAST_ARRAY(FAST_ARRAY(CASE)) :=
FAST_ARRAY(FAST_ARRAY(CASE)).create_with_capacity 32;
-
+
- new_cases:FAST_ARRAY(CASE) <-
( + result:FAST_ARRAY(CASE);
(store_cases.is_empty).if {
@@ -645,7 +645,7 @@ Section Private
};
result
);
-
+
- new_list_cases:FAST_ARRAY(FAST_ARRAY(CASE)) <-
( + result:FAST_ARRAY(FAST_ARRAY(CASE));
(store_list_cases.is_empty).if {
@@ -654,31 +654,31 @@ Section Private
result := store_list_cases.last;
store_list_cases.remove_last;
};
- result
+ result
);
-
+
- free_list_cases l:FAST_ARRAY(FAST_ARRAY(CASE)) <-
( + lst:FAST_ARRAY(CASE);
(l.lower).to (l.upper) do { i:INTEGER;
lst := l.item i;
lst.clear;
- store_cases.add_last lst;
+ store_cases.add_last lst;
};
l.clear;
store_list_cases.add_last l;
);
-
+
- case_fusion low:INTEGER :FAST_ARRAY(FAST_ARRAY(CASE)) <-
( + c1,c2:CASE;
+ lst:FAST_ARRAY(CASE);
- + j:INTEGER;
+ + j:INTEGER;
+ result:FAST_ARRAY(FAST_ARRAY(CASE));
-
+
result := new_list_cases;
(low).to (list.upper) do { i:INTEGER;
- c1 := list.item i;
+ c1 := list.item i;
lst := NULL;
- j := result.lower;
+ j := result.lower;
{(j <= result.upper) && {lst = NULL}}.while_do {
c2 := result.item j.first;
(c1 ~= c2).if {
@@ -689,7 +689,7 @@ Section Private
};
(lst = NULL).if {
lst := new_cases;
- result.add_last lst;
+ result.add_last lst;
};
lst.add_last c1;
};
diff --git a/src/code_life/write.li b/src/code_life/write.li
index a81151b..667bc1a 100644
--- a/src/code_life/write.li
+++ b/src/code_life/write.li
@@ -19,62 +19,62 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := WRITE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write local, global or slot";
-
+
Section Inherit
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
//
// Debug !!!!
//
-
+
+ is_delete:BOOLEAN;
-
+
+ is_create:BOOLEAN;
-
+
- set_delete <-
(
is_delete := TRUE;
);
-
+
- set_create <-
(
is_create := TRUE;
);
-
+
//
// Fin debug !!!!
//
-
+
+ quiet_generation:BOOLEAN;
-
+
- set_quiet_generation <-
(
quiet_generation := TRUE;
);
-
+
- is_invariant:BOOLEAN <- value.is_invariant;
-
+
- variable:VARIABLE <-
(
- deferred;
+ deferred;
NULL
);
-
- - static_type:TYPE_FULL <-
- (
+
+ - static_type:TYPE_FULL <-
+ (
variable.type
);
-
+
+ value:EXPR;
- set_value new:EXPR <-
@@ -83,63 +83,63 @@ Section Public
);
- ensure_count:INTEGER <- variable.ensure_count;
-
+
- get_type t:TYPES_TMP <-
(
(value != NULL).if {
value.get_type t;
};
);
-
+
- my_copy:SELF <-
- ( + new_val:EXPR;
+ ( + new_val:EXPR;
+ result:SELF;
-
+
new_val := value.my_copy;
result ?= variable.write position value new_val;
result
);
-
+
//
// Execute.
//
-
- - execute_access_unlink:INSTR <-
+
+ - execute_access_unlink:INSTR <-
(
deferred;
NULL
);
-
+
- execute_access_link <- deferred;
-
+
- execute:INSTR <-
( + result:INSTR;
+ read:READ;
+ val:INSTR;
+ slot:SLOT_DATA;
-
+
? { variable != NULL };
? { value != NULL };
-
+
simplify_type variable;
//debug_display;
-
+
slot ?= variable;
- (
+ (
( // First case : No link.
(ensure_count = 0) && {(slot = NULL) || {! slot.id_section.is_mapping}}
- ) ||
+ ) ||
{ // Second case : a := a;
read ?= value;
- (read != NULL) &&
+ (read != NULL) &&
{variable = read.variable} &&
{(variable.is_local) || {variable.style = '-'}} // BSBS: Ce cas dans rentrer dans set_write
}
).if {
//
// Supprime affectation.
- //
-
+ //
+
val := execute_access_unlink;
(val != NULL).if {
list_current.insert_before val;
@@ -150,58 +150,58 @@ Section Public
} else {
//
// Execution normal.
- //
+ //
/*( // BSBS: Bug, mais de toute facon le gain n'est pas la... (entre +5 a +20)
- (loop_invariant != NULL) && {list_current = loop_invariant.body} &&
+ (loop_invariant != NULL) && {list_current = loop_invariant.body} &&
{is_invariant} && {variable.get_last_index != -1}
- ).if {
+ ).if {
//old_loop_invariant := loop_invariant;
//loop_invariant := NULL;
//
variable.reset_last_write Self;
loop_list.insert_before Self;
//
- //execute_access_link;
- //value := value.execute_link;
+ //execute_access_link;
+ //value := value.execute_link;
//seq_index := seq_index + 1;
//
//loop_invariant := old_loop_invariant;
result := NOP;
count_invariant := count_invariant + 1;
} else { */
-
- execute_access_link;
- value := value.execute_link;
+
+ execute_access_link;
+ value := value.execute_link;
seq_index := seq_index + 1;
variable.set_write Self;
- result := Self;
+ result := Self;
//};
};
result
);
-
+
- remove <-
(
variable.unwrite Self;
value.remove;
);
-
+
//
// Genere
//
-
+
- genere_value buffer:STRING <-
- (
+ (
(is_java).if {
- value.genere buffer;
- } else {
+ value.genere buffer;
+ } else {
(
- (static_type.is_expanded_ref) &&
+ (static_type.is_expanded_ref) &&
{! value.static_type.is_expanded_ref}
).if {
? {value.static_type.is_expanded};
buffer.append "&(";
- value.genere buffer;
+ value.genere buffer;
buffer.add_last ')';
}.elseif {
(static_type.is_expanded) && {! static_type.is_expanded_ref} &&
@@ -209,32 +209,32 @@ Section Public
{value.static_type.raw != TYPE_NULL} // For Pointer := NULL
} then {
buffer.append "*(";
- value.genere buffer;
+ value.genere buffer;
buffer.add_last ')';
} else {
value.genere buffer;
};
};
);
-
+
//
// Display.
//
- display buffer:STRING <-
- (
+ (
//crash;
buffer.append (variable.intern_name);
-
+
buffer.add_last '[';
variable.type.append_name_in buffer;
buffer.add_last ']';
-
+
buffer.append " :=";
//to_pointer.append_in buffer;
display_ref buffer;
buffer.add_last ' ';
-
+
(value = NULL).if {
buffer.append "<NULL>";
} else {
@@ -247,8 +247,8 @@ Section Public
is_verbose.if {
buffer.add_last '<';
buffer.append (object_id.to_string);
- buffer.add_last '/';
- ensure_count.append_in buffer;
+ buffer.add_last '/';
+ ensure_count.append_in buffer;
buffer.add_last '>';
};
);
diff --git a/src/code_life/write_global.li b/src/code_life/write_global.li
index da4f6ed..3b0aa58 100644
--- a/src/code_life/write_global.li
+++ b/src/code_life/write_global.li
@@ -19,29 +19,29 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := WRITE_GLOBAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write global";
-
+
Section Inherit
+ parent_write:Expanded WRITE;
-
+
Section Public
-
+
+ global:SLOT_DATA;
-
+
- variable:VARIABLE <- global;
-
+
//
// Creation.
//
-
+
- create p:POSITION with val:EXPR in g:SLOT_DATA :SELF <-
( + result:SELF;
? {p.code != 0};
@@ -49,35 +49,35 @@ Section Public
result.make p with val in g;
result
);
-
+
- make p:POSITION with val:EXPR in g:SLOT_DATA <-
- (
+ (
position := p;
value := val;
global := g;
);
-
+
//
// Execute.
//
- - execute_access_unlink:INSTR <-
+ - execute_access_unlink:INSTR <-
(
global.execute;
NULL
);
- - execute_access_link <-
- (
+ - execute_access_link <-
+ (
global.execute;
);
//
// Genere
//
-
+
- genere buffer:STRING <-
- (
+ (
TYPE.add_genere_global global;
(quiet_generation).if_false {
buffer.append (global.intern_name);
@@ -85,12 +85,12 @@ Section Public
((value.static_type.raw = TYPE_NULL) && {variable.type.raw.is_block}).if {
buffer.append ".__id=0";
} else {
- buffer.add_last '=';
+ buffer.add_last '=';
genere_value buffer;
};
};
);
-
+
diff --git a/src/code_life/write_local.li b/src/code_life/write_local.li
index a1c9290..eed4c3c 100644
--- a/src/code_life/write_local.li
+++ b/src/code_life/write_local.li
@@ -19,29 +19,29 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := WRITE_LOCAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write local";
-
+
Section Inherit
+ parent_write:Expanded WRITE;
-
+
Section Public
-
+
+ local:LOCAL;
-
+
- variable:VARIABLE <- local;
-
+
//
// Creation.
//
-
+
- create p:POSITION with val:EXPR in l:LOCAL :SELF <-
( + result:SELF;
? {p.code != 0};
@@ -49,36 +49,36 @@ Section Public
result.make p with val in l;
result
);
-
+
- make p:POSITION with val:EXPR in l:LOCAL <-
- (
+ (
position := p;
local := l;
value := val;
);
-
+
//
// Execute.
//
-
+
- execute_access_unlink:INSTR <- NULL;
-
+
- execute_access_link;
- - execute_argument:BOOLEAN <-
+ - execute_argument:BOOLEAN <-
// BSBS: Cette methode foireuse ne doit plus etre necessaire (utilise execute normal)
( + new_val:INSTR;
- + read:READ;
+ + read:READ;
+ result:BOOLEAN;
-
+
? { variable != NULL };
? { value != NULL };
-
+
read ?= value;
(ensure_count = 0).if {
//
// Supprime affectation.
- //
+ //
new_val := value.execute_unlink;
(new_val = NULL).if {
result := TRUE;
@@ -91,56 +91,56 @@ Section Public
} else {
//
// Execution normal.
- //
+ //
execute_access_link;
- value := value.execute_link;
+ value := value.execute_link;
};
result
- );
-
+ );
+
//
// Genere
//
-
+
- genere buffer:STRING <-
( + idf:STRING_CONSTANT;
-
- idf := ALIASER_LOCAL.write Self;
+
+ idf := ALIASER_LOCAL.write Self;
(quiet_generation).if_false {
- (local.is_result).if {
+ (local.is_result).if {
buffer.add_last '*';
- };
- buffer.append idf;
+ };
+ buffer.append idf;
//
((value.static_type.raw = TYPE_NULL) && {variable.type.raw.is_block}).if {
buffer.append ".__id=0";
- } else {
- buffer.add_last '=';
+ } else {
+ buffer.add_last '=';
genere_value buffer;
};
};
);
-
+
- genere_first_result buffer:STRING <-
( + idf:STRING_CONSTANT;
-
- idf := ALIASER_LOCAL.write Self;
- (local.is_result).if {
+
+ idf := ALIASER_LOCAL.write Self;
+ (local.is_result).if {
buffer.add_last '*';
};
- buffer.append idf;
- //
- buffer.add_last '=';
+ buffer.append idf;
+ //
+ buffer.add_last '=';
);
-
+
- genere_argument_result buffer:STRING <-
( + idf:STRING_CONSTANT;
-
+
idf := ALIASER_LOCAL.write Self;
buffer.add_last '&';
- buffer.append idf;
+ buffer.append idf;
);
-
+
diff --git a/src/code_life/write_slot.li b/src/code_life/write_slot.li
index 3d26de0..9535ab1 100644
--- a/src/code_life/write_slot.li
+++ b/src/code_life/write_slot.li
@@ -19,33 +19,33 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := WRITE_SLOT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write slot";
-
+
Section Inherit
+ parent_write:Expanded WRITE;
-
+
Section Public
-
+
- is_invariant:BOOLEAN <- receiver.is_invariant && {value.is_invariant};
-
+
+ slot:SLOT_DATA;
-
+
- variable:VARIABLE <- slot;
-
+
+ receiver:EXPR;
-
+
//
// Creation.
//
-
+
- create p:POSITION with val:EXPR in (r:EXPR,s:SLOT_DATA) :SELF <-
( + result:SELF;
? {p.code != 0};
@@ -53,19 +53,19 @@ Section Public
result.make p with val in (r,s);
result
);
-
+
- make p:POSITION with val:EXPR in (r:EXPR,s:SLOT_DATA) <-
- (
- position := p;
+ (
+ position := p;
value := val;
receiver := r;
slot := s;
);
-
+
- my_copy:SELF <-
- ( + new_val:EXPR;
+ ( + new_val:EXPR;
+ result:SELF;
-
+
new_val := value.my_copy;
result ?= variable.write position with (receiver.my_copy) value new_val;
(quiet_generation).if {
@@ -73,80 +73,80 @@ Section Public
};
result
);
-
+
//
// Execute.
//
- - execute_access_unlink:INSTR <-
- (
+ - execute_access_unlink:INSTR <-
+ (
slot.execute;
receiver.execute_unlink
);
-
- - execute_access_link <-
- (
+
+ - execute_access_link <-
+ (
slot.execute;
- receiver := receiver.execute_link;
+ receiver := receiver.execute_link;
);
-
+
- remove <-
(
receiver.remove;
parent_write.remove;
);
-
+
//
// Genere
//
-
+
- genere buffer:STRING <-
( + tf:TYPE_FULL;
+ t:TYPE;
-
+
t := slot.receiver_type;
- t.add_genere_list;
+ t.add_genere_list;
(! quiet_generation).if {
(t.alias_slot = variable).if {
- tf := receiver.static_type;
+ tf := receiver.static_type;
((tf.is_strict) || {tf.is_expanded_ref}).if {
buffer.append "(*";
- receiver.genere buffer;
+ receiver.genere buffer;
buffer.add_last ')';
- }.elseif {tf.is_expanded} then {
- receiver.genere buffer;
+ }.elseif {tf.is_expanded} then {
+ receiver.genere buffer;
} else {
buffer.append "*((";
t := slot.receiver_type;
- t.put_reference_declaration buffer;
+ t.put_reference_declaration buffer;
buffer.add_last ' ';
- t.put_reference_star_declaration buffer;
+ t.put_reference_star_declaration buffer;
buffer.add_last ')';
receiver.genere buffer;
- buffer.add_last ')';
- };
+ buffer.add_last ')';
+ };
} else {
- // Receiver.
+ // Receiver.
(is_java).if {
receiver.genere buffer;
- buffer.add_last '.';
- } else {
- tf := receiver.static_type;
+ buffer.add_last '.';
+ } else {
+ tf := receiver.static_type;
((tf.is_strict) || {tf.is_expanded_ref}).if {
receiver.genere buffer;
buffer.append "->";
- }.elseif {tf.is_expanded} then {
+ }.elseif {tf.is_expanded} then {
receiver.genere buffer;
- buffer.add_last '.';
+ buffer.add_last '.';
} else {
buffer.append "((";
t := slot.receiver_type;
- t.put_reference_declaration buffer;
+ t.put_reference_declaration buffer;
buffer.add_last ' ';
- t.put_reference_star_declaration buffer;
+ t.put_reference_star_declaration buffer;
buffer.add_last ')';
receiver.genere buffer;
- buffer.append ")->";
+ buffer.append ")->";
};
};
//
@@ -156,12 +156,12 @@ Section Public
((value.static_type.raw = TYPE_NULL) && {variable.type.raw.is_block}).if {
buffer.append ".__id=0";
} else {
- buffer.add_last '=';
- genere_value buffer;
+ buffer.add_last '=';
+ genere_value buffer;
};
};
);
-
+
//
// Display.
//
@@ -170,11 +170,11 @@ Section Public
(
receiver.display buffer;
buffer.append "->";
- parent_write.display buffer;
+ parent_write.display buffer;
);
-
-
+
+
diff --git a/src/compiler_any/any_option.li b/src/compiler_any/any_option.li
index 9e48f18..48b256e 100644
--- a/src/compiler_any/any_option.li
+++ b/src/compiler_any/any_option.li
@@ -19,29 +19,29 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ANY_OPTION;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Option for compiler (see shorter)";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
+
- is_shorter :BOOLEAN := FALSE;
-
+
- is_shorter2:BOOLEAN := FALSE;
-
+
//
// Option du Shorter.
- //
-
+ //
+
- is_short_private:BOOLEAN;
- is_short_code:BOOLEAN;
-
+
diff --git a/src/constant/character_cst.li b/src/constant/character_cst.li
index 27feeb9..63f0f3a 100644
--- a/src/constant/character_cst.li
+++ b/src/constant/character_cst.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CHARACTER_CST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Character constant";
-
+
Section Inherit
-
+
+ parent_constant:Expanded CONSTANT;
-
+
Section Public
//
@@ -50,7 +50,7 @@ Section Public
result.make p char car;
result
);
-
+
- make p:POSITION char car:STRING_CONSTANT <-
(
position := p;
@@ -63,8 +63,8 @@ Section Public
//
// Comparaison.
//
-
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + s:SELF;
s ?= other;
(s != NULL) && {text = s.text}
@@ -88,7 +88,7 @@ Section Public
- display buffer:STRING <-
(
buffer.add_last '\'';
- buffer.append text;
+ buffer.append text;
buffer.add_last '\'';
display_ref buffer;
);
diff --git a/src/constant/constant.li b/src/constant/constant.li
index 77da3dd..264c420 100644
--- a/src/constant/constant.li
+++ b/src/constant/constant.li
@@ -19,37 +19,37 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CONSTANT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all constants";
-
+
Section Inherit
-
- + parent_expr:Expanded EXPR;
-
+
+ + parent_expr:Expanded EXPR;
+
Section Public
//
// Comparison.
//
-
+
- is_constant:BOOLEAN <- TRUE;
-
+
- is_invariant:BOOLEAN <- TRUE;
-
+
//
// Typing.
//
-
+
+ static_type:TYPE_FULL;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add (static_type.raw);
);
@@ -59,17 +59,17 @@ Section Public
- remove <-
(
- // Nothing.
+ // Nothing.
);
-
+
- execute_unlink:INSTR <-
(
new_execute_pass;
NULL
);
-
+
- execute_link:EXPR <- Self;
-
+
diff --git a/src/constant/integer_cst.li b/src/constant/integer_cst.li
index d782b6e..1d30c60 100644
--- a/src/constant/integer_cst.li
+++ b/src/constant/integer_cst.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := INTEGER_CST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Integer constant";
-
+
Section Inherit
-
+
+ parent_constant:Expanded CONSTANT;
-
+
Section Public
//
@@ -39,22 +39,22 @@ Section Public
//
+ value:INTEGER_64;
-
+
- set_value new_value:INTEGER_64 <-
(
value := new_value;
check_type;
);
-
+
- to_power:INTEGER_64 <-
// 2^Result = self or else -1
( + result,val:INTEGER_64;
-
+
val := value;
(val = 0).if {
result := -1;
- } else {
- {(val & 1) = 0}.while_do {
+ } else {
+ {(val & 1) = 0}.while_do {
val := val >> 1;
result := result + 1;
};
@@ -64,17 +64,17 @@ Section Public
};
result
);
-
+
- is_signed:BOOLEAN <-
( + typ:STRING_CONSTANT;
-
- typ := static_type.raw.name;
+
+ typ := static_type.raw.name;
(typ = ALIAS_STR.prototype_integer_64) ||
{typ = ALIAS_STR.prototype_integer_32} ||
{typ = ALIAS_STR.prototype_integer_16} ||
{typ = ALIAS_STR.prototype_integer_8 }
);
-
+
- is_saturated:BOOLEAN <-
( + result:BOOLEAN;
@@ -95,9 +95,9 @@ Section Public
result := value = 0FFh;
};
};
- result
+ result
);
-
+
//
// Creation.
//
@@ -108,12 +108,12 @@ Section Public
result.make p value v type t;
result
);
-
+
- make p:POSITION value v:INTEGER_64 type t:TYPE_FULL <-
(
position := p;
value := v;
- static_type := t;
+ static_type := t;
check_type;
);
@@ -122,7 +122,7 @@ Section Public
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + p:INTEGER_CST;
p ?= other;
@@ -145,14 +145,14 @@ Section Public
//
- genere buffer:STRING <-
- (
- buffer.add_last ' ';
- value.append_in buffer;
+ (
+ buffer.add_last ' ';
+ value.append_in buffer;
(value > UINTEGER_32.maximum.to_integer_64).if {
buffer.append "LLU";
}.elseif {value > INTEGER.maximum.to_integer_64} then {
buffer.append "LU";
- };
+ };
);
//
@@ -167,13 +167,13 @@ Section Public
value.append_in buffer;
display_ref buffer;
);
-
+
Section Private
-
+
- check_type <-
( + error:BOOLEAN;
+ min,max:INTEGER_64;
-
+
// Check Range.
(static_type.raw.name)
.when (ALIAS_STR.prototype_uinteger_64) then {
@@ -204,7 +204,7 @@ Section Private
// Nothing. (Pb: BSBS : Can't range test.)
}
.when (ALIAS_STR.prototype_integer_32) then {
- ((value < INTEGER.minimum) || {value > INTEGER.maximum.to_integer_64}).if {
+ ((value < INTEGER.minimum) || {value > INTEGER.maximum.to_integer_64}).if {
error := TRUE;
min := INTEGER.minimum;
max := INTEGER.maximum.to_integer_64;
@@ -224,12 +224,12 @@ Section Private
max := INTEGER_8.maximum.to_integer_64;
};
};
-
+
(error).if {
string_tmp.copy "Invalid constant integer (";
value.append_in string_tmp;
string_tmp.append ") cast into ";
- static_type.append_name_in string_tmp;
+ static_type.append_name_in string_tmp;
string_tmp.append " [";
min.append_in string_tmp;
string_tmp.append "..";
@@ -242,7 +242,7 @@ Section Private
value := 0;
};
);
-
+
diff --git a/src/constant/native_array_character_cst.li b/src/constant/native_array_character_cst.li
index 7a10894..9b5646c 100644
--- a/src/constant/native_array_character_cst.li
+++ b/src/constant/native_array_character_cst.li
@@ -19,21 +19,21 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NATIVE_ARRAY_CHARACTER_CST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "String constant";
-
+
Section Inherit
-
+
+ parent_constant:Expanded CONSTANT;
-
+
Section Public
-
+
//
// Value.
//
@@ -50,7 +50,7 @@ Section Public
result.make p text n;
result
);
-
+
- make p:POSITION text n:STRING_CONSTANT <-
(
position := p;
@@ -63,8 +63,8 @@ Section Public
//
// Comparaison.
//
-
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + p:NATIVE_ARRAY_CHARACTER_CST;
p ?= other;
(p != NULL) && {string = p.string}
@@ -75,12 +75,12 @@ Section Public
//
- genere buffer:STRING <-
- (
+ (
buffer.add_last '\"';
buffer.append string;
buffer.add_last '\"';
);
-
+
//
// Display.
//
@@ -92,8 +92,8 @@ Section Public
buffer.add_last '\"';
display_ref buffer;
);
-
-
+
+
diff --git a/src/constant/prototype_cst.li b/src/constant/prototype_cst.li
index 71185ff..448d536 100644
--- a/src/constant/prototype_cst.li
+++ b/src/constant/prototype_cst.li
@@ -19,43 +19,43 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PROTOTYPE_CST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Prototype constant";
-
+
Section Inherit
-
+
+ parent_constant:Expanded CONSTANT;
-
+
Section Public
//
// Creation.
//
-
+
- create p:POSITION type t:TYPE_FULL :SELF<-
( + result:SELF;
? {p.code != 0};
? {t != NULL};
-
+
result := clone;
result.make p type t;
result
);
-
+
- make p:POSITION type t:TYPE_FULL <-
(
- position := p;
- static_type := t.to_strict;
+ position := p;
+ static_type := t.to_strict;
);
- - my_copy:SELF <-
- (
+ - my_copy:SELF <-
+ (
SELF.create position type static_type
);
@@ -63,21 +63,21 @@ Section Public
// Comparaison.
//
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + p:PROTOTYPE_CST;
p ?= other;
(p != NULL) && {static_type = p.static_type}
);
-
+
//
// Execute
//
-
+
- execute_link:EXPR <-
- (
+ (
Self
- );
-
+ );
+
//
// Generation.
//
@@ -94,7 +94,7 @@ Section Public
- display buffer:STRING <-
(
static_type.display buffer;
- display_ref buffer;
+ display_ref buffer;
);
-
+
diff --git a/src/constant/real_cst.li b/src/constant/real_cst.li
index a5fc56d..6c6c25e 100644
--- a/src/constant/real_cst.li
+++ b/src/constant/real_cst.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := REAL_CST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Real float constant";
-
+
Section Inherit
-
+
+ parent_constant:Expanded CONSTANT;
-
+
Section Public
//
@@ -39,7 +39,7 @@ Section Public
//
+ value:STRING_CONSTANT;
-
+
//
// Creation.
//
@@ -50,12 +50,12 @@ Section Public
result.make p value v type t;
result
);
-
+
- make p:POSITION value v:STRING_CONSTANT type t:TYPE_FULL <-
(
position := p;
value := v;
- static_type := t;
+ static_type := t;
);
- my_copy:SELF <- SELF.create position value value type static_type;
@@ -63,7 +63,7 @@ Section Public
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + p:REAL_CST;
p ?= other;
@@ -77,7 +77,7 @@ Section Public
- cast_type p:TYPE_FULL <-
(
? { p != type_real };
- static_type := p;
+ static_type := p;
);
//
@@ -101,8 +101,8 @@ Section Public
buffer.append value;
display_ref buffer;
);
-
-
+
+
diff --git a/src/constant/string_cst.li b/src/constant/string_cst.li
index 4e05965..751f27e 100644
--- a/src/constant/string_cst.li
+++ b/src/constant/string_cst.li
@@ -19,37 +19,37 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := STRING_CST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "String constant";
-
+
Section Inherit
-
+
+ parent_constant:Expanded CONSTANT;
-
+
Section Public
-
- - output:STRING :=
+
+ - output:STRING :=
( + result:STRING;
-
+
result := STRING.create 256;
title "STRING CONSTANT" in result;
result
);
-
+
- output_count:INTEGER;
-
+
//
// Value.
//
+ string:STRING_CONSTANT;
-
+
//
// Creation.
//
@@ -60,7 +60,7 @@ Section Public
result.make p text n length len;
result
);
-
+
- make p:POSITION text n:STRING_CONSTANT length len:INTEGER <-
(
position := p;
@@ -74,8 +74,8 @@ Section Public
//
// Comparaison.
//
-
- - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
+
+ - Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + p:STRING_CST;
p ?= other;
(p != NULL) && {string = p.string}
@@ -86,24 +86,24 @@ Section Public
//
- genere buffer:STRING <-
- ( + idx,count,cur:INTEGER;
+ ( + idx,count,cur:INTEGER;
- is_init:BOOLEAN;
- is_storage:BOOLEAN;
- is_count:BOOLEAN;
-
+
(is_init).if_false {
is_storage := type_string_constant.get_local_slot (ALIAS_STR.slot_storage)
.slot_data_intern.ensure_count != 0;
is_count := type_string_constant.get_local_slot (ALIAS_STR.slot_count)
- .slot_data_intern.ensure_count != 0;
+ .slot_data_intern.ensure_count != 0;
is_init := TRUE;
};
-
+
count := dico_string.fast_at string;
(count >= 0).if {
output_count := output_count + 1;
idx := output_count;
-
+
cur := output.count - 1;
(is_java).if {
output.append "private static ";
@@ -120,7 +120,7 @@ Section Public
(static_type.is_late_binding).if {
output.append "__";
output.append (static_type.raw.intern_name);
- output.append "__,";
+ output.append "__,";
};
};
(is_count).if {
@@ -133,7 +133,7 @@ Section Public
{(output.count - cur) > 78}.while_do {
output.insert_string "\\\n" to (cur+78);
cur := cur + 78;
- };
+ };
output.add_last '\"';
} else {
output.remove_last 1;
@@ -150,14 +150,14 @@ Section Public
//
(is_java).if {
buffer.append "__string_";
- idx.append_in buffer;
+ idx.append_in buffer;
} else {
buffer.append "(&__string_";
idx.append_in buffer;
buffer.add_last ')';
};
);
-
+
//
// Display.
//
@@ -169,10 +169,10 @@ Section Public
buffer.add_last '\"';
display_ref buffer;
);
-
-Section Private
-
- - dico_string:HASHED_DICTIONARY(INTEGER,STRING_CONSTANT) :=
+
+Section Private
+
+ - dico_string:HASHED_DICTIONARY(INTEGER,STRING_CONSTANT) :=
HASHED_DICTIONARY(INTEGER,STRING_CONSTANT).create;
diff --git a/src/dispatcher/dta.li b/src/dispatcher/dta.li
index f81870a..1a9792f 100644
--- a/src/dispatcher/dta.li
+++ b/src/dispatcher/dta.li
@@ -19,62 +19,62 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all late binding";
-
+
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
-
+
Section Public
-
+
+ result_expr:EXPR;
-
+
+ slot:SLOT;
-
+
+ self_arg:EXPR;
-
+
+ context:LOCAL;
-
+
//
// Service
//
-
+
- remove <-
(
// Nothing.
);
-
+
//
// Display.
//
-
- - display buffer:STRING <-
+
+ - display buffer:STRING <-
(
buffer.append "DTA";
deferred;
);
-
-Section NODE_TYPE, DTA
-
+
+Section NODE_TYPE, DTA
+
- product t:TYPE with e:EXPR self type_self:TYPE_FULL :LIST <-
( + result:LIST;
-
+
result := LIST.create (e.position);
- (t = TYPE_NULL).if {
- TYPE_NULL.product_error position in result with context;
+ (t = TYPE_NULL).if {
+ TYPE_NULL.product_error position in result with context;
? {result.count != 0};
} else {
lookup t with e in result;
};
- result
- );
+ result
+ );
- update_branch l:LIST self type_self:TYPE_FULL :BOOLEAN <-
[
@@ -82,12 +82,12 @@ Section NODE_TYPE, DTA
]
( + node:NODE;
+ result:BOOLEAN;
-
+
node ?= l.first;
(node = NULL).if {
result := TRUE;
} else {
-
+
/*
"DTA: ".print;
type_self.print;
@@ -101,43 +101,43 @@ Section NODE_TYPE, DTA
};
result
);
-
-Section NODE_STYLE, SELF
-
- - get_argument:FAST_ARRAY(EXPR) <-
+
+Section NODE_STYLE, SELF
+
+ - get_argument:FAST_ARRAY(EXPR) <-
( + result:FAST_ARRAY(EXPR);
-
+
result := FAST_ARRAY(EXPR).create_with_capacity 1;
result.add_last (self_arg.my_copy);
result
);
-
+
Section DTA
-
- - finalise typ:TYPE with (expr:EXPR,s:SLOT) in lst:LIST <-
+
+ - finalise typ:TYPE with (expr:EXPR,s:SLOT) in lst:LIST <-
( + node:NODE_STYLE;
-
+
node := NODE_STYLE.create (expr.my_copy,s) with Self result result_expr;
- lst.add_last node;
+ lst.add_last node;
);
-
+
Section Private
-
+
- lookup typ:TYPE with expr:EXPR in lst:LIST <-
( + s:SLOT;
+ name:STRING_CONSTANT;
+ node_style:NODE_STYLE;
+ r:EXPR;
-
+
name := slot.name;
- s := typ.get_local_slot name;
+ s := typ.get_local_slot name;
(s = NULL).if {
- // Lookup parent.
- s := typ.get_path_slot name;
+ // Lookup parent.
+ s := typ.get_path_slot name;
r := s.result_type.get_expr_for typ;
node_style := NODE_STYLE.create (expr.my_copy,s) with Self result r;
lst.add_last node_style;
- lst.add_last (NODE_TYPE.create r with Self);
+ lst.add_last (NODE_TYPE.create r with Self);
} else {
// Direct call.
s.is_equal_profil slot;
diff --git a/src/dispatcher/dta_block.li b/src/dispatcher/dta_block.li
index 18de214..85ba921 100644
--- a/src/dispatcher/dta_block.li
+++ b/src/dispatcher/dta_block.li
@@ -19,73 +19,73 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA_BLOCK;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Lisaac IS A Advanced Compiler";
-
+
Section Inherit
-
+
+ parent_dta_rd_args:Expanded DTA_RD_ARGS;
-
+
Section Public
-
+
+ result_expr:EXPR;
-
+
// Add.
-
+
+ model:TYPE_BLOCK;
-
+
//
// Creation.
//
-
+
- create mod:TYPE_BLOCK with larg:FAST_ARRAY(EXPR) :SELF <-
( + result:SELF;
- result := clone;
+ result := clone;
result.make mod with larg;
- result
+ result
);
-
+
- make mod:TYPE_BLOCK with larg:FAST_ARRAY(EXPR) <-
[ -? {mod.position != 0}; ]
- (
+ (
(profil_current = NULL).if {
context := context_main;
} else {
context := profil_current.context;
- };
+ };
model := mod;
position := mod.position;
argument_list := larg;
- result_expr := mod.get_expr_for (mod.position);
+ result_expr := mod.get_expr_for (mod.position);
);
-
+
//
// Display.
//
-
- - display buffer:STRING <-
+
+ - display buffer:STRING <-
(
buffer.append "DTA_BLOCK";
);
-Section NODE_STYLE, SELF
-
- - get_argument:FAST_ARRAY(EXPR) <-
+Section NODE_STYLE, SELF
+
+ - get_argument:FAST_ARRAY(EXPR) <-
( + result:FAST_ARRAY(EXPR);
+ rd:READ_SLOT;
(copy_argument).if {
- result := FAST_ARRAY(EXPR).create_with_capacity (argument_list.count);
+ result := FAST_ARRAY(EXPR).create_with_capacity (argument_list.count);
rd ?= argument_list.first;
result.add_last (rd.receiver.my_copy);
- (argument_list.lower+1).to (argument_list.upper) do { j:INTEGER;
+ (argument_list.lower+1).to (argument_list.upper) do { j:INTEGER;
result.add_last (argument_list.item j.my_copy);
- };
+ };
} else {
result := argument_list;
copy_argument := TRUE;
@@ -93,62 +93,62 @@ Section NODE_STYLE, SELF
result
);
-Section NODE_TYPE, DTA
-
+Section NODE_TYPE, DTA
+
- product t:TYPE with e:EXPR self type_self:TYPE_FULL :LIST <-
( + result:LIST;
+ t_block:PROFIL_BLOCK;
- + wrt:WRITE;
+ + wrt:WRITE;
+ wrt_larg:FAST_ARRAY(WRITE);
+ call:CALL_SLOT;
+ em:EXPR_MULTIPLE;
+ rd:READ;
+ result_var:VARIABLE;
-
+
result := LIST.create (e.position);
- (t = TYPE_NULL).if {
+ (t = TYPE_NULL).if {
TYPE_NULL.product_error (e.position) in result with context;
- } else {
- t_block ?= t;
-
-
- (t_block = NULL).if { // BSBS: debug
+ } else {
+ t_block ?= t;
+
+
+ (t_block = NULL).if { // BSBS: debug
"<<<".print;
t.print;
">>>".print; '\n'.print;
list_current.debug_display;
- syntax_error (argument_list.first.position,"Block not found");
+ syntax_error (argument_list.first.position,"Block not found");
};
-
+
wrt_larg := t_block.write_argument get_argument;
- call := CALL_SLOT.create (e.position) profil t_block with wrt_larg cop NULL;
- (result_expr.static_type.raw != TYPE_VOID).if {
+ call := CALL_SLOT.create (e.position) profil t_block with wrt_larg cop NULL;
+ (result_expr.static_type.raw != TYPE_VOID).if {
em ?= result_expr;
(em != NULL).if {
(em.lower).to (em.upper) do { j:INTEGER;
rd ?= em.item j;
? {rd != NULL};
- result_var := rd.variable;
+ result_var := rd.variable;
rd := call.profil.result_list.item j.read (e.position);
wrt := result_var.write (e.position) value rd;
- call.result_list.add_last (RESULT.create wrt);
- };
+ call.result_list.add_last (RESULT.create wrt);
+ };
} else {
rd ?= result_expr;
- result_var := rd.variable;
+ result_var := rd.variable;
rd := call.profil.result_list.first.read (e.position);
wrt := result_var.write (e.position) value rd;
- call.result_list.add_last (RESULT.create wrt);
- };
+ call.result_list.add_last (RESULT.create wrt);
+ };
};
result.add_last call;
};
- result
- );
-
+ result
+ );
+
- update_branch l:LIST self type_self:TYPE_FULL :BOOLEAN <-
(
TRUE
);
-
+
diff --git a/src/dispatcher/dta_cast.li b/src/dispatcher/dta_cast.li
index e8108f8..a060027 100644
--- a/src/dispatcher/dta_cast.li
+++ b/src/dispatcher/dta_cast.li
@@ -19,36 +19,36 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA_CAST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Cast base";
-
+
Section Inherit
-
+
- parent_dta:DTA := DTA;
-
+
Section Public
+ result_expr:EXPR;
-
+
//
// Creation.
//
-
+
- create p:POSITION type t:TYPE_FULL :SELF <-
[ -? {p != 0}; ]
( + result:SELF;
-
+
result := clone;
result.make p type t;
result
);
-
+
- make p:POSITION type t:TYPE_FULL <-
(
position := p;
@@ -63,24 +63,24 @@ Section Public
//
// Display.
//
-
- - display buffer:STRING <-
+
+ - display buffer:STRING <-
(
buffer.append "DTA_CAST";
);
-
+
//
// Service
//
-
-Section NODE_TYPE, DTA
-
+
+Section NODE_TYPE, DTA
+
- product t:TYPE with e:EXPR self type_self:TYPE_FULL :LIST <-
( + cast:LOCAL;
+ rd:READ;
+ new_value:EXPR;
+ result:LIST;
-
+
result := LIST.create (e.position);
rd ?= result_expr;
cast ?= rd.variable;
@@ -89,7 +89,7 @@ Section NODE_TYPE, DTA
(cast.type.raw = t).if {
new_value := CAST.create (cast.type) value (e.my_copy);
};
- }.elseif {t.is_sub_type (cast.type.raw)} then {
+ }.elseif {t.is_sub_type (cast.type.raw)} then {
new_value := CAST.create (t.default) value (e.my_copy);
};
};
@@ -100,7 +100,7 @@ Section NODE_TYPE, DTA
result.add_last (PROTOTYPE_CST.create (e.position) type (TYPE_VOID.default)); // BSBS : Alias.
result
);
-
+
- update_branch l:LIST self type_self:TYPE_FULL :BOOLEAN <-
(
TRUE
diff --git a/src/dispatcher/dta_rd.li b/src/dispatcher/dta_rd.li
index 42e00b2..2af514b 100644
--- a/src/dispatcher/dta_rd.li
+++ b/src/dispatcher/dta_rd.li
@@ -19,59 +19,59 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA_RD;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Read site";
-
+
Section Inherit
-
+
+ parent_dta:Expanded DTA;
-
- - parent_parameter_to_type:Expanded PARAMETER_TO_TYPE;
-
+
+ - parent_parameter_to_type:Expanded PARAMETER_TO_TYPE;
+
Section Public
-
+
+ is_intern:BOOLEAN;
-
+
- parameter_to_type p:ITM_TYPE_PARAMETER :TYPE_FULL <-
( + result:TYPE_FULL;
-
+
(p.name = ALIAS_STR.prototype_self).if {
// For Self.
- result := self_arg.static_type;
+ result := self_arg.static_type;
} else {
- // For genericity.
+ // For genericity.
result := slot.receiver_type.parameter_to_type p;
- //result := self_arg.static_type.raw.parameter_to_type p;
+ //result := self_arg.static_type.raw.parameter_to_type p;
};
-
+
result
);
-
+
//
// Creation.
//
-
+
- create p:POSITION call sl:SLOT self arg:EXPR intern flag:BOOLEAN :SELF <-
[ -? {p != 0}; ]
( + result:SELF;
-
+
result := clone;
- result.make p call sl self arg intern flag;
+ result.make p call sl self arg intern flag;
result
);
-
+
- make p:POSITION call sl:SLOT self arg:EXPR intern flag:BOOLEAN <-
- ( ? {sl != NULL};
- position := p;
+ ( ? {sl != NULL};
+ position := p;
slot := sl;
- self_arg := arg;
- result_expr := get_expr_result;
+ self_arg := arg;
+ result_expr := get_expr_result;
is_intern := flag;
(profil_current = NULL).if {
context := context_main;
@@ -79,24 +79,24 @@ Section Public
context := profil_current.context;
};
);
-
+
//
//
//
-
+
- display buffer:STRING <-
(
buffer.append "DTA_READ";
);
-
+
Section DTA_RD
-
+
- get_expr_result:EXPR <-
( + result:EXPR;
-
+
(slot.id_section.is_interrupt).if {
result := type_pointer.default.get_temporary_expr position;
- } else {
+ } else {
result := slot.result_type.get_expr_for Self;
};
result
diff --git a/src/dispatcher/dta_rd_args.li b/src/dispatcher/dta_rd_args.li
index d218cdc..4357ce2 100644
--- a/src/dispatcher/dta_rd_args.li
+++ b/src/dispatcher/dta_rd_args.li
@@ -19,38 +19,38 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA_RD_ARGS;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Read site with arguments";
-
+
Section Inherit
-
+
+ parent_dta_rd:Expanded DTA_RD;
-
+
Section Public
-
+
- self_arg:EXPR <- argument_list.first;
-
+
// Add.
-
+
+ argument_list:FAST_ARRAY(EXPR);
-
+
+ copy_argument:BOOLEAN;
-
+
- parameter_to_type p:ITM_TYPE_PARAMETER :TYPE_FULL <-
( + result:TYPE_FULL;
+ idx:INTEGER;
- // For Genericity.
+ // For Genericity.
result := slot.receiver_type.parameter_to_type p;
(result = NULL).if {
// For Self + type parametric.
idx := slot.get_index_argument_type p;
- (idx != - 1).if {
+ (idx != - 1).if {
result := argument_list.item idx.static_type;
};
};
@@ -60,42 +60,42 @@ Section Public
//
// Creation.
//
-
+
- create p:POSITION call sl:SLOT with args:FAST_ARRAY(EXPR) intern flag:BOOLEAN :SELF <-
[ -? {p != 0}; ]
( + result:SELF;
-
+
result := clone;
result.make p call sl with args intern flag;
result
);
-
+
- make p:POSITION call sl:SLOT with args:FAST_ARRAY(EXPR) intern flag:BOOLEAN <-
(
- position := p;
+ position := p;
slot := sl;
argument_list := args;
result_expr := get_expr_result;
- is_intern := flag;
+ is_intern := flag;
(profil_current = NULL).if {
context := context_main;
} else {
context := profil_current.context;
};
);
-
+
//
// Just for ITM_EXPRESSION
//
-
+
- create_partial p:POSITION call sl:SLOT :SELF <-
( + result:SELF;
-
+
result := clone;
result.make_partial p call sl;
result
);
-
+
- make_partial p:POSITION call sl:SLOT <-
(
position := p;
@@ -105,13 +105,13 @@ Section Public
//
// Display.
//
-
- - display buffer:STRING <-
+
+ - display buffer:STRING <-
(
buffer.append "DTA_RD_ARGS:";
buffer.append (slot.name);
);
-
+
//
// Service
//
@@ -125,21 +125,21 @@ Section Public
copy_argument := TRUE;
};
);
-
-Section NODE_STYLE, SELF
-
- - get_argument:FAST_ARRAY(EXPR) <-
+
+Section NODE_STYLE, SELF
+
+ - get_argument:FAST_ARRAY(EXPR) <-
( + result:FAST_ARRAY(EXPR);
-
+
(copy_argument).if {
- result := FAST_ARRAY(EXPR).create_with_capacity (argument_list.count);
- (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
+ result := FAST_ARRAY(EXPR).create_with_capacity (argument_list.count);
+ (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
result.add_last (argument_list.item j.my_copy);
- };
+ };
} else {
result := argument_list;
copy_argument := TRUE;
};
result
);
-
+
diff --git a/src/dispatcher/dta_wr_code.li b/src/dispatcher/dta_wr_code.li
index 1d638eb..00791af 100644
--- a/src/dispatcher/dta_wr_code.li
+++ b/src/dispatcher/dta_wr_code.li
@@ -19,38 +19,38 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA_WR_CODE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write site with code";
-
+
Section Inherit
-
+
+ parent_dta:Expanded DTA;
-
+
Section Public
// Add.
-
+
+ code:ITM_CODE;
-
+
//
// Creation.
//
-
+
- create p:POSITION slot sl:SLOT self arg:EXPR code v:ITM_CODE :SELF <-
[ -? {p != 0}; ]
( + result:SELF;
-
+
result := clone;
result.make p slot sl self arg code v;
result
);
-
+
- make p:POSITION slot sl:SLOT self arg:EXPR code v:ITM_CODE <-
(
position := p;
@@ -68,23 +68,23 @@ Section Public
//
// Display.
//
-
- - display buffer:STRING <-
+
+ - display buffer:STRING <-
(
buffer.append "DTA_WR_CODE:";
- buffer.append (slot.name);
+ buffer.append (slot.name);
);
-
+
//
// Service
//
-
-Section DTA
-
- - finalise typ:TYPE with (expr:EXPR,s:SLOT) in lst:LIST <-
+
+Section DTA
+
+ - finalise typ:TYPE with (expr:EXPR,s:SLOT) in lst:LIST <-
( + id:PROTOTYPE_CST;
+ pos:POSITION;
-
+
pos := expr.position;
id := PROTOTYPE_CST.create pos type (TYPE_ID.get_index (s.add_style code).default);
(s.style = '+').if {
@@ -93,4 +93,4 @@ Section DTA
lst.add_last (s.slot_id.write pos value id);
};
);
-
+
diff --git a/src/dispatcher/dta_wr_value.li b/src/dispatcher/dta_wr_value.li
index 7a0e9d9..dbd59c4 100644
--- a/src/dispatcher/dta_wr_value.li
+++ b/src/dispatcher/dta_wr_value.li
@@ -19,46 +19,46 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := DTA_WR_VALUE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write site with value";
-
+
Section Inherit
-
+
+ parent_dta:Expanded DTA;
-
+
Section Public
// Add.
-
+
+ value:EXPR;
-
+
+ copy_value:BOOLEAN;
//
// Creation.
//
-
+
- create p:POSITION slot sl:SLOT self arg:EXPR value v:EXPR :SELF <-
[ -? {p != 0}; ]
( + result:SELF;
-
+
result := clone;
result.make p slot sl self arg value v;
result
);
-
+
- make p:POSITION slot sl:SLOT self arg:EXPR value v:EXPR <-
(
- position := p;
+ position := p;
slot := sl;
self_arg := arg;
- result_expr := v.my_copy;
+ result_expr := v.my_copy;
value := v;
(profil_current = NULL).if {
context := context_main;
@@ -70,13 +70,13 @@ Section Public
//
// Display.
//
-
- - display buffer:STRING <-
+
+ - display buffer:STRING <-
(
buffer.append "DTA_WR_VALUE:";
- buffer.append (slot.name);
+ buffer.append (slot.name);
);
-
+
//
// Service
//
@@ -88,31 +88,31 @@ Section Public
copy_value := TRUE;
};
);
-
-Section NODE_TYPE, DTA
+
+Section NODE_TYPE, DTA
- product t:TYPE with e:EXPR self type_self:TYPE_FULL :LIST <-
( + result:LIST;
-
+
result := LIST.create (e.position);
(t = TYPE_NULL).if {
TYPE_NULL.product_error position in result with context;
} else {
lookup t with e in result;
};
- result
- );
+ result
+ );
- update_branch l:LIST self type_self:TYPE_FULL :BOOLEAN <-
- ( + result:BOOLEAN;
+ ( + result:BOOLEAN;
+ wrt_slot:WRITE_SLOT;
+ wrt_glob:WRITE_GLOBAL;
-
+
result := parent_dta.update_branch l self type_self;
(l.count < 3).if {
- wrt_slot ?= l.first;
- wrt_glob ?= l.first;
- (wrt_slot != NULL).if {
+ wrt_slot ?= l.first;
+ wrt_glob ?= l.first;
+ (wrt_slot != NULL).if {
(wrt_slot.slot.slot_id != NULL).if {
add_write_id (wrt_slot.receiver,wrt_slot.slot) in l;
} else {
@@ -127,15 +127,15 @@ Section NODE_TYPE, DTA
};
};
result
- );
-
+ );
+
Section DTA
-
- - finalise typ:TYPE with (expr:EXPR,s:SLOT) in lst:LIST <-
+
+ - finalise typ:TYPE with (expr:EXPR,s:SLOT) in lst:LIST <-
( + new_value:EXPR;
+ sd:SLOT_DATA;
+ em:EXPR_MULTIPLE;
-
+
(copy_value).if {
new_value := value.my_copy;
} else {
@@ -144,10 +144,10 @@ Section DTA
};
sd := s.slot_data;
em ?= new_value;
- (em != NULL).if {
+ (em != NULL).if {
(em.lower).to (em.upper - 1) do { j:INTEGER;
lst.add_last (new_write (s.slot_data_list.item j) rec expr value (em.item j));
- };
+ };
new_value := em.last;
};
lst.add_last (new_write sd rec expr value new_value);
@@ -155,22 +155,22 @@ Section DTA
add_write_id (expr,s) in lst;
};
);
-
+
Section Private
-
+
- add_write_id (e:EXPR,s:SLOT) in lst:LIST <-
( + new_value:EXPR;
+ sd:SLOT_DATA;
-
+
new_value := PROTOTYPE_CST.create (lst.position) type (TYPE_ID.get_index 0.default);
sd := s.slot_id;
- lst.add (new_write sd rec e value new_value) to 2;
+ lst.add (new_write sd rec e value new_value) to 2;
);
-
+
- new_write sd:SLOT_DATA rec e:EXPR value val:EXPR :WRITE <-
( + result:WRITE;
-
- (sd.style = '+').if {
+
+ (sd.style = '+').if {
result := sd.write (e.position) with (e.my_copy) value val;
} else {
result := sd.write (e.position) value val;
diff --git a/src/dispatcher/node.li b/src/dispatcher/node.li
index f0eb0d4..780b9b9 100644
--- a/src/dispatcher/node.li
+++ b/src/dispatcher/node.li
@@ -19,113 +19,113 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NODE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all switch node";
-
+
Section Inherit
-
+
+ parent_instr:Expanded INSTR;
-
+
Section NODE, PROFIL_BLOCK, ITM_OLD
-
+
- node_list_base:LINKED_LIST(NODE_TYPE) := node_list;
-
+
- node_list:LINKED_LIST(NODE_TYPE) := LINKED_LIST(NODE_TYPE).create;
-
+
- set_node_list l:LINKED_LIST(NODE_TYPE) <-
(
node_list := l;
);
-
-Section PROTOTYPE
-
+
+Section PROTOTYPE
+
- extend_pass <-
( + j:INTEGER;
+ is_ok:BOOLEAN;
-
+
VARIABLE.update;
- j := node_list.lower;
+ j := node_list.lower;
{j <= node_list.upper}.while_do {
- is_ok := node_list.item j.update;
+ is_ok := node_list.item j.update;
(is_ok).if {
node_list.remove j;
- } else {
+ } else {
j := j + 1;
- };
- };
+ };
+ };
);
-
+
Section Public
-
+
//
// Extern Creation read.
//
-
- - new_read p:POSITION slot s:SLOT receiver rec:EXPR
+
+ - new_read p:POSITION slot s:SLOT receiver rec:EXPR
self my_self:EXPR intern is_intern:BOOLEAN :NODE <-
( + result:NODE_TYPE;
+ dta:DTA_RD;
- //
+ //
dta := DTA_RD.create p call s self my_self intern is_intern;
result := NODE_TYPE.create rec with dta;
- //
+ //
node_list.add_last result;
result
);
- - new_read p:POSITION slot s:SLOT receiver rec:EXPR
+ - new_read p:POSITION slot s:SLOT receiver rec:EXPR
with larg:FAST_ARRAY(EXPR) intern is_intern:BOOLEAN :NODE <-
- ( + dta:DTA_RD_ARGS;
+ ( + dta:DTA_RD_ARGS;
+ result:NODE_TYPE;
-
- // Control argument type.
+
+ // Control argument type.
dta := DTA_RD_ARGS.create p call s with larg intern is_intern;
- s.check_argument_type larg for dta;
+ s.check_argument_type larg for dta;
result := NODE_TYPE.create rec with dta;
- //
+ //
node_list.add_last result;
result
);
-
+
//
// Just for ITM_EXPRESSION.
//
-
+
- new_read_partial p:POSITION slot s:SLOT :NODE_TYPE <-
- ( + dta:DTA_RD_ARGS;
-
+ ( + dta:DTA_RD_ARGS;
+
dta := DTA_RD_ARGS.create_partial p call s;
NODE_TYPE.create_partial dta
);
-
+
- new_read_finalize (rec:EXPR,s:SLOT) with larg:FAST_ARRAY(EXPR) <-
- ( + dta:DTA_RD_ARGS;
- // Control argument type.
+ ( + dta:DTA_RD_ARGS;
+ // Control argument type.
dta ?= data;
-
+
dta.make (data.position) call s with larg intern FALSE;
- data.slot.check_argument_type larg for dta;
+ data.slot.check_argument_type larg for dta;
make rec with data;
- //
+ //
node_list.add_last Self;
);
-
+
//
// Extern creation writes.
//
-
+
- new_write p:POSITION slot s:SLOT receiver rec:EXPR value val:EXPR :NODE <-
- ( + dta:DTA_WR_VALUE;
+ ( + dta:DTA_WR_VALUE;
+ result:NODE_TYPE;
-
+
dta := DTA_WR_VALUE.create p slot s self rec value val;
result := NODE_TYPE.create rec with dta;
- //
+ //
node_list.add_last result;
result
);
@@ -133,54 +133,54 @@ Section Public
- new_write p:POSITION slot s:SLOT receiver rec:EXPR code val:ITM_CODE :NODE <-
( + dta:DTA_WR_CODE;
+ result:NODE_TYPE;
-
+
dta := DTA_WR_CODE.create p slot s self rec code val;
result := NODE_TYPE.create rec with dta;
//
node_list.add_last result;
result
);
-
+
//
// Extern creation cast.
//
-
- - new_cast p:POSITION type typ:TYPE_FULL with val:EXPR :NODE <-
+
+ - new_cast p:POSITION type typ:TYPE_FULL with val:EXPR :NODE <-
[ -? {p != 0}; ]
( + dta:DTA_CAST;
+ result:NODE_TYPE;
-
+
dta := DTA_CAST.create p type typ;
result := NODE_TYPE.create val with dta;
//
node_list.add_last result;
result
);
-
+
//
// Extern creation value block.
//
-
+
- new_block p:POSITION receiver e:EXPR with larg:FAST_ARRAY(EXPR) :NODE <-
( + dta:DTA_BLOCK;
- + result:NODE_TYPE;
+ + result:NODE_TYPE;
+ lst_typ_f:FAST_ARRAY(TYPE_FULL);
+ new_expr:EXPR;
+ block_model:TYPE_BLOCK;
+ pb:PROFIL_BLOCK;
+ pos:POSITION;
-
+
pb ?= e.static_type.raw;
(pb = NULL).if {
block_model ?= e.static_type.raw;
} else {
- block_model := pb.to_type_block;
+ block_model := pb.to_type_block;
};
- // Control argument type.
+ // Control argument type.
lst_typ_f := block_model.argument_list;
pos := block_model.position;
-
- (lst_typ_f.count+1 != larg.count).if {
+
+ (lst_typ_f.count+1 != larg.count).if {
string_tmp.copy "Incorrect size of vector argument for this block. (Value:";
larg.count.append_in string_tmp;
string_tmp.append ", Type:";
@@ -190,12 +190,12 @@ Section Public
pos.put_position;
p .put_position;
POSITION.send_error;
- };
- (larg.lower + 1).to (larg.upper) do { j:INTEGER;
+ };
+ (larg.lower + 1).to (larg.upper) do { j:INTEGER;
new_expr := larg.item j.check_type (lst_typ_f.item (j-1)) with pos;
larg.put new_expr to j;
};
- //
+ //
(debug_level_option != 0).if {
(profil_current = NULL).if {
crash_with_message "NODE";
@@ -206,30 +206,30 @@ Section Public
};
//
dta := DTA_BLOCK.create block_model with larg;
- result := NODE_TYPE.create e with dta;
+ result := NODE_TYPE.create e with dta;
//
node_list.add_last result;
result
);
-
-Section Public
-
- - position:POSITION <-
- (
+
+Section Public
+
+ - position:POSITION <-
+ (
data.position
);
-
+
+ data:DTA;
-
- + expr:EXPR;
-
+
+ + expr:EXPR;
+
+ first_code:LIST;
- + first_type:TYPE;
+ + first_type:TYPE;
+ switch:SWITCH;
-
- - count:INTEGER <-
+
+ - count:INTEGER <-
( + result:INTEGER;
-
+
(switch != NULL).if {
result := switch.count;
}.elseif {first_type != NULL} then {
@@ -237,69 +237,69 @@ Section Public
};
result
);
-
+
- result_expr:EXPR <- deferred;
-
+
//
// Execute.
//
-
+
- remove <-
(
data.remove;
- (switch = NULL).if {
+ (switch = NULL).if {
expr.remove;
(first_code != NULL).if {
first_code.remove;
};
- } else {
+ } else {
switch.remove;
};
);
-
+
- execute:INSTR <-
( + result:INSTR;
data.remove;
(switch != NULL).if {
- result := switch.execute;
- } else {
- expr.remove;
+ result := switch.execute;
+ } else {
+ expr.remove;
(first_code != NULL).if { // Warning: Dead Code!
result := first_code.execute;
};
};
result
);
-
+
- genere buffer:STRING <-
(
"Genere NODE!\n".print;
crash;
);
-
-
-Section NODE, DTA
+
+
+Section NODE, DTA
//
// Update.
//
-
+
- update_link self_type:TYPE_FULL :BOOLEAN <-
(
deferred;
);
-
+
Section Public
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
(switch = NULL).if {
- (first_code = NULL).if {
+ (first_code = NULL).if {
to_pointer.append_in buffer;
buffer.append "<NODE VIDE=";
expr.display buffer;
@@ -316,4 +316,4 @@ Section Public
switch.display buffer;
};
);
-
+
diff --git a/src/dispatcher/node_style.li b/src/dispatcher/node_style.li
index 396b074..42ae8a6 100644
--- a/src/dispatcher/node_style.li
+++ b/src/dispatcher/node_style.li
@@ -19,61 +19,61 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NODE_STYLE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Switch node for style";
-
+
Section Inherit
-
+
+ parent_node:Expanded NODE;
-
+
Section Public
-
+
+ result_expr:EXPR;
-
+
+ slot:SLOT;
Section NODE, DTA
-
+
//
// Creation.
//
-
+
- create (e:EXPR,sl:SLOT) with dta:DTA result r:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make (e,sl) with dta result r;
result
);
-
+
- make (e:EXPR,sl:SLOT) with dta:DTA result r:EXPR <-
- (
+ (
expr := e;
slot := sl;
data := dta;
result_expr := r;
);
-
+
Section Public
-
- - my_copy:SELF <-
- (
+
+ - my_copy:SELF <-
+ (
crash_with_message "NODE_STYLE.my_copy";
- NULL
+ NULL
);
-
-Section NODE, DTA
-
+
+Section NODE, DTA
+
//
// Update.
//
-
+
- update_link self_type:TYPE_FULL :BOOLEAN <-
[
-? {self_type != NULL};
@@ -83,15 +83,15 @@ Section NODE, DTA
+ case:CASE;
+ e:EXPR;
+ low,up,count:INTEGER;
-
+
(slot.slot_id = NULL).if {
(first_code = NULL).if {
first_type := TYPE_ID.get_index (slot.lower_style);
- first_code := call_for first_type self self_type;
+ first_code := call_for first_type self self_type;
};
- } else {
+ } else {
low := slot.lower_style;
- up := slot.upper_style;
+ up := slot.upper_style;
count := up-low + 1;
(switch = NULL).if {
(slot.style = '-').if {
@@ -104,21 +104,21 @@ Section NODE, DTA
};
list := switch.list;
(list.count != count).if {
- 0.to (count-1) do { j:INTEGER;
+ 0.to (count-1) do { j:INTEGER;
typ := TYPE_ID.get_index (j+low);
-
+
((j > list.upper) || {typ != list.item j.id}).if {
case := CASE.create typ with (call_for typ self self_type);
list.add case to j;
- };
- };
+ };
+ };
};
};
FALSE
);
-
-Section Private
-
+
+Section Private
+
- call_for t:TYPE self type_self:TYPE_FULL :LIST <-
[
-? {type_self != NULL};
@@ -128,12 +128,12 @@ Section Private
+ call:CALL_SLOT;
+ em:EXPR_MULTIPLE;
+ rd:READ;
- + wrt:WRITE;
+ + wrt:WRITE;
+ result_var:VARIABLE;
- + new_larg:FAST_ARRAY(EXPR);
+ + new_larg:FAST_ARRAY(EXPR);
+ slot_dta:SLOT_DATA;
+ slot_cod:SLOT_CODE;
- + idx:INTEGER;
+ + idx:INTEGER;
+ type:TYPE_FULL;
+ my_profil:PROFIL;
+ wrt_lst:FAST_ARRAY(WRITE);
@@ -143,23 +143,23 @@ Section Private
+ cop_arg:EXPR;
+ new_val:EXPR;
+ val:EXPR;
-
+
result := LIST.create position;
-
- data_rd ?= data;
+
+ data_rd ?= data;
((type_self.prototype.style = '-') && {data_rd != NULL} && {! data_rd.is_intern}).if {
cop_arg := data.self_arg.my_copy;
};
-
+
typ ?= t;
- idx := typ.index;
+ idx := typ.index;
(idx = 0).if {
- // Data.
+ // Data.
(cop_arg != NULL).if {
result.add_last (COP_LOCK.create position with cop_arg);
};
//
- slot_dta := slot.slot_data;
+ slot_dta := slot.slot_data;
slot_dta.init;
(slot.slot_data_list != NULL).if {
(slot.slot_data_list.lower).to (slot.slot_data_list.upper) do { j:INTEGER;
@@ -171,40 +171,40 @@ Section Private
// BSBS: Pourquoi tu produit quelque chose qui serre à rien ???
(slot_dta.style = '-').if {
result.add_last (slot_dta.read position);
- } else {
+ } else {
result.add_last (slot_dta.read position with (expr.my_copy));
- };
- } else {
+ };
+ } else {
em ?= result_expr;
(em != NULL).if {
(em.lower).to (em.upper - 1) do { j:INTEGER;
rd ?= em.item j;
? {rd != NULL};
- result_var := rd.variable;
- result.add_last (new_write result_var with (expr,slot.slot_data_list.item j));
+ result_var := rd.variable;
+ result.add_last (new_write result_var with (expr,slot.slot_data_list.item j));
};
rd ?= em.last;
} else {
rd ?= result_expr;
- };
-
+ };
+
//(slot_dta.name == "storage").if {
/*
string_tmp.clear;
string_tmp.copy (type_self.raw.name);
string_tmp.add_last ' ';
- string_tmp.append (t.name);
+ string_tmp.append (t.name);
(data.slot != NULL).if {
string_tmp.add_last ' ';
- string_tmp.append (data.slot.name);
+ string_tmp.append (data.slot.name);
};
result.add_last (
EXTERNAL_C.create position text (ALIAS_STR.get string_tmp) access NULL persistant TRUE type (TYPE_NULL.default)
);
- */
+ */
/*
- "Data : ".print; slot_dta.intern_name.print;
- " dans ".print; type_self.raw.name.print;
+ "Data : ".print; slot_dta.intern_name.print;
+ " dans ".print; type_self.raw.name.print;
(profil_current != NULL).if {
profil_current.name.print;
};
@@ -215,21 +215,21 @@ Section Private
result.add_last (new_write result_var with (expr,slot_dta));
};
(cop_arg != NULL).if {
- result.add_last (COP_UNLOCK.create position);
+ result.add_last (COP_UNLOCK.create position);
};
} else {
// Function.
- slot_cod := slot.slot_code idx;
+ slot_cod := slot.slot_code idx;
(slot_cod.id_section.is_inherit_or_insert).if {
new_larg := FAST_ARRAY(EXPR).create_with_capacity 1;
new_larg.add_last (data.self_arg.my_copy);
} else {
new_larg := data.get_argument;
};
- type := new_larg.first.static_type;
+ type := new_larg.first.static_type;
? {type != NULL};
- //
- (debug_level_option != 0).if {
+ //
+ (debug_level_option != 0).if {
// BSBS: Poser le PUSH avant le NODE
//(data.context = NULL).if {
// ctext := context_main;
@@ -237,19 +237,19 @@ Section Private
(data.context = NULL).if {
crash_with_message "NODE_STYLE : data.context = NULL!\n";
};
-
+
ctext := data.context;
//};
result.add_last (
PUSH.create position context ctext first FALSE
- );
+ );
};
//
- rd ?= new_larg.first;
+ rd ?= new_larg.first;
((rd != NULL) && {rd.variable.name = ALIAS_STR.variable_self}).if {
- // Fix Self type for resend call (else it's fixed by NODE_TYPE)
- new_type_self := type;
- } else {
+ // Fix Self type for resend call (else it's fixed by NODE_TYPE)
+ new_type_self := type;
+ } else {
new_type_self := type_self;
};
/*
@@ -258,16 +258,16 @@ Section Private
string_tmp.append " / ";
type_self.display string_tmp;
result.add_last (
- EXTERNAL_C.create (data.position)
+ EXTERNAL_C.create (data.position)
text (ALIAS_STR.get string_tmp) access NULL persistant TRUE type (TYPE_VOID.default)
);
*/
new_val := CAST.create new_type_self value (new_larg.first);
- new_larg.put new_val to 0;
-
-
+ new_larg.put new_val to 0;
+
+
/*
- (new_larg.lower+1).to (new_larg.upper) do { j:INTEGER;
+ (new_larg.lower+1).to (new_larg.upper) do { j:INTEGER;
ts ?= slot_cod.get_argument_type j;
((ts != NULL) && {ts = ITM_TYPE_SIMPLE.type_self}).if {
(new_larg.item j.static_type != new_type_self).if {
@@ -276,9 +276,9 @@ Section Private
ts.print;
string_tmp.clear;
(slot_cod.argument_list.lower).to (slot_cod.argument_list.upper) do { h:INTEGER;
- slot_cod.argument_list.item h.append_in string_tmp;
+ slot_cod.argument_list.item h.append_in string_tmp;
};
- string_tmp.print;
+ string_tmp.print;
'\n'.print;
warning_error (position,"BUG");
semantic_error (new_larg.item j.position,"Type not compatible SELF.");
@@ -287,15 +287,15 @@ Section Private
//new_larg.put new_val to j;
};
};
- */
+ */
(my_profil, wrt_lst) := slot_cod.get_profil new_larg self new_type_self;
- //
- (result_expr.static_type.raw = TYPE_VOID).if {
+ //
+ (result_expr.static_type.raw = TYPE_VOID).if {
result.add_last (
CALL_SLOT.create position profil my_profil with wrt_lst cop cop_arg
);
- } else {
- call := CALL_SLOT.create position profil my_profil with wrt_lst cop NULL;
+ } else {
+ call := CALL_SLOT.create position profil my_profil with wrt_lst cop NULL;
(cop_arg != NULL).if {
result.add_last (COP_LOCK.create position with cop_arg);
result.add_last call;
@@ -308,42 +308,41 @@ Section Private
(em.lower).to (em.upper) do { j:INTEGER;
rd ?= em.item j;
? {rd != NULL};
- result_var := rd.variable;
+ result_var := rd.variable;
rd := call.profil.result_list.item j.read position;
wrt := result_var.write position value rd;
call.result_list.add_last (RESULT.create wrt);
- };
+ };
}.elseif {
- (call.profil.result_list.count != 0) ||
+ (call.profil.result_list.count != 0) ||
{call.is_interrupt}
} then {
rd ?= result_expr;
- result_var := rd.variable;
+ result_var := rd.variable;
(call.is_interrupt).if {
//val := PROTOTYPE_CST.create position type (TYPE_NULL.default);
- val := EXTERNAL_C.create position text "/* NODE_STYLE */"
+ val := EXTERNAL_C.create position text "/* NODE_STYLE */"
access NULL persistant FALSE type (type_pointer.default);
} else {
val := call.profil.result_list.first.read position;
};
wrt := result_var.write position value val;
- call.result_list.add_last (RESULT.create wrt);
- };
- };
- };
+ call.result_list.add_last (RESULT.create wrt);
+ };
+ };
+ };
result
);
-
-Section Private
-
+
+Section Private
+
- new_write var:VARIABLE with (e:EXPR,slot:SLOT_DATA) :WRITE <-
( + rd:READ;
-
+
(slot.style = '-').if {
rd := slot.read position;
- } else {
+ } else {
rd := slot.read position with (e.my_copy);
};
var.write position value rd
);
-
\ No newline at end of file
diff --git a/src/dispatcher/node_type.li b/src/dispatcher/node_type.li
index 91ae3e1..8549b5f 100644
--- a/src/dispatcher/node_type.li
+++ b/src/dispatcher/node_type.li
@@ -19,91 +19,91 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NODE_TYPE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Switch node for type";
-
+
Section Inherit
-
+
+ parent_node:Expanded NODE;
-
+
Section Public
-
+
- result_expr:EXPR <- data.result_expr;
-
+
+ is_self:BOOLEAN;
-
+
//
// Creation.
//
-
+
- create e:EXPR with d:DTA :SELF <-
// Create with back-link.
[ -? {d.position != 0}; ]
( + result:SELF;
-
+
result := clone;
result.make e with d;
result
);
-
+
- make e:EXPR with d:DTA <-
(
expr := e;
data := d;
late_binding_counter := late_binding_counter + 1;
);
-
+
//
// Just for ITM_EXPRESSION
//
-
+
- create_partial d:DTA :SELF <-
( + result:SELF;
-
+
result := clone;
- result.make_partial d;
+ result.make_partial d;
result
);
-
+
- make_partial d:DTA <-
(
data := d;
);
-
+
Section Public
-
+
- my_copy:SELF <-
( + result:SELF;
-
- result := SELF.create (expr.my_copy) with data;
- node_list.add_last result;
+
+ result := SELF.create (expr.my_copy) with data;
+ node_list.add_last result;
result
);
-
+
//
// Update.
//
-
+
- update:BOOLEAN <-
(
update_case NULL & update_depth NULL
);
-
+
Section NODE, DTA
-
+
- update_link self_type:TYPE_FULL :BOOLEAN <-
- (
- update_case self_type & update_depth self_type
+ (
+ update_case self_type & update_depth self_type
);
-
-Section Private
-
+
+Section Private
+
- update_case type_self:TYPE_FULL :BOOLEAN <-
( + typ_f:TYPE_FULL;
+ typ:TYPE;
@@ -111,27 +111,27 @@ Section Private
+ list:FAST_ARRAY(CASE);
+ case:CASE;
+ result:BOOLEAN;
-
+
typ_f := expr.static_type;
-
+
(typ_f.is_expanded && {typ_f.raw != type_boolean}).if {
(first_code = NULL).if {
first_type := typ_f.raw;
first_code := data.product first_type with expr self type_self;
- };
+ };
result := TRUE;
}.elseif {(typ_f.raw = type_boolean) && {count = 2}} then {
result := TRUE;
- } else {
+ } else {
((typ_f.raw.is_block) || {typ_f.raw.subtype_list.count != count}).if {
- lst_typ := TYPES_TMP.new;
- expr.get_type lst_typ;
-
+ lst_typ := TYPES_TMP.new;
+ expr.get_type lst_typ;
+
/*
- ((typ_f.raw = type_boolean) && {! lst_typ.is_empty}).if {
+ ((typ_f.raw = type_boolean) && {! lst_typ.is_empty}).if {
expr.debug_display; '\n'.print;
(lst_typ.first = type_boolean).if {
-
+
crash_with_message "NODE_TYPE : BUG";
};
/*
@@ -153,8 +153,8 @@ Section Private
};
list := switch.list;
(list.count != lst_typ.count).if {
- (lst_typ.lower).to (lst_typ.upper) do { j:INTEGER;
- typ := lst_typ.item j;
+ (lst_typ.lower).to (lst_typ.upper) do { j:INTEGER;
+ typ := lst_typ.item j;
((j > list.upper) || {typ != list.item j.id}).if {
add_stack_type typ;
//
@@ -162,7 +162,7 @@ Section Private
list.add case to j;
//
stack_type.remove_last;
- };
+ };
};
};
};
@@ -171,37 +171,37 @@ Section Private
} else {
//count_flat := count_flat + 1;
//"Yes\n".print;
- };
- };
+ };
+ };
result
);
-
- - update_depth self_type:TYPE_FULL :BOOLEAN <-
+
+ - update_depth self_type:TYPE_FULL :BOOLEAN <-
( + result:BOOLEAN;
+ list:FAST_ARRAY(CASE);
+ new_type_self:TYPE_FULL;
-
+
(switch = NULL).if {
(first_code != NULL).if {
- (self_type = NULL).if {
+ (self_type = NULL).if {
new_type_self := expr.static_type;
((! new_type_self.is_expanded) || {new_type_self.raw = type_boolean}).if {
new_type_self := first_type.default.to_strict;
- };
+ };
} else {
new_type_self := self_type;
};
-
+
add_stack_type first_type;
result := data.update_branch first_code self new_type_self;
stack_type.remove_last;
};
} else {
list := switch.list;
-
+
(list.lower).to (list.upper) do { j:INTEGER;
(self_type = NULL).if {
- new_type_self := list.item j.id.default.to_strict;
+ new_type_self := list.item j.id.default.to_strict;
} else {
new_type_self := self_type;
};
@@ -212,15 +212,15 @@ Section Private
};
result
);
-
-Section Private
-
+
+Section Private
+
- stack_type:FAST_ARRAY(TYPE) := FAST_ARRAY(TYPE).create_with_capacity 16;
-
+
- add_stack_type t:TYPE <-
(
stack_type.add_last t;
- ((stack_type.count > 1) && {stack_type.first = t}).if {
+ ((stack_type.count > 1) && {stack_type.first = t}).if {
string_tmp.copy "Cyclic inheritance : ";
(stack_type.lower).to (stack_type.upper) do { j:INTEGER;
stack_type.item j.append_name_in string_tmp;
diff --git a/src/external/arithmetic/expr_add.li b/src/external/arithmetic/expr_add.li
index 6386f7e..0883d5d 100644
--- a/src/external/arithmetic/expr_add.li
+++ b/src/external/arithmetic/expr_add.li
@@ -19,60 +19,60 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_ADD;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Add Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
+ symbol:STRING_CONSTANT := "+";
-
+
//
// Execute.
//
-
+
- exec_conservator_left left_cst :INTEGER_CST :EXPR <-
//-- 0 + E -> E
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := right;
left_cst.remove;
};
result
);
-
- - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E + 0 -> E
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := left;
right_cst.remove;
};
result
);
-
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 + C2 -> C3
(
- left_cst.set_value (left_cst.value + right_cst.value);
+ left_cst.set_value (left_cst.value + right_cst.value);
right_cst.remove;
left_cst
);
-
-
-
+
+
+
diff --git a/src/external/arithmetic/expr_and.li b/src/external/arithmetic/expr_and.li
index bf36757..56c2c10 100644
--- a/src/external/arithmetic/expr_and.li
+++ b/src/external/arithmetic/expr_and.li
@@ -19,83 +19,83 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_AND;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Add Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
- symbol:STRING_CONSTANT := "&";
-
+
//
// Execute.
//
-
+
- exec_conservator_left left_cst :INTEGER_CST :EXPR <-
- //-- -1 & E -> E
+ //-- -1 & E -> E
( + result:EXPR;
-
+
(left_cst.is_saturated).if {
result := right;
left_cst.remove;
};
result
);
-
- - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E & -1 -> E
( + result:EXPR;
-
+
(right_cst.is_saturated).if {
result := left;
right_cst.remove;
};
result
);
-
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 & C2 -> C3
- (
- left_cst.set_value (left_cst.value & right_cst.value);
+ (
+ left_cst.set_value (left_cst.value & right_cst.value);
right_cst.remove;
left_cst
);
-
+
- exec:EXPR <-
//-- E & E -> E
( + result:EXPR;
-
+
(left ~= right).if {
right.remove;
result := left;
};
- result
+ result
);
-
- - exec_left left_cst :INTEGER_CST :EXPR <-
+
+ - exec_left left_cst :INTEGER_CST :EXPR <-
//-- 0 & E -> 0
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := left_cst;
right.remove;
};
result
);
-
+
- exec_right right_cst:INTEGER_CST :EXPR <-
//-- E & 0 -> 0
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := right_cst;
left.remove;
@@ -103,7 +103,7 @@ Section Public
result
);
-
+
diff --git a/src/external/arithmetic/expr_binary.li b/src/external/arithmetic/expr_binary.li
index ba120a2..2ebf040 100644
--- a/src/external/arithmetic/expr_binary.li
+++ b/src/external/arithmetic/expr_binary.li
@@ -19,124 +19,124 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_BINARY;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- left.is_invariant && {right.is_invariant};
-
+
+ left:EXPR;
-
+
+ right:EXPR;
-
- - symbol:STRING_CONSTANT <-
+
+ - symbol:STRING_CONSTANT <-
(
deferred;
NULL
);
-
+
- static_type:TYPE_FULL <- left.static_type;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
left .get_type t;
//right.get_type t;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with l:EXPR and r:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with l and r;
result
);
-
+
- make p:POSITION with l:EXPR and r:EXPR <-
(
position := p;
left := l;
right := r;
);
-
+
- my_copy:SELF <- SELF.create position with (left.my_copy) and (right.my_copy);
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + same:SELF;
-
+
same ?= other;
(same != NULL) && {left ~= same.left} && {right ~= same.right}
);
-
+
//
// Remove
//
-
+
- remove <-
(
left .remove;
right.remove;
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- ( + instr:INSTR;
+ ( + instr:INSTR;
instr := left.execute_unlink;
(instr != NULL).if {
list_current.insert_before instr;
};
- right.execute_unlink
+ right.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ left_cst,right_cst:INTEGER_CST;
-
- old_seq := seq_call_and_loop;
+
+ old_seq := seq_call_and_loop;
left := left.execute_link;
- right := right.execute_link;
+ right := right.execute_link;
//
left_cst ?= left;
right_cst ?= right;
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {left_cst != NULL}).if {
+ ((result = NULL) && {left_cst != NULL}).if {
result := exec_conservator_left left_cst;
};
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_conservator_right right_cst;
};
(
- (result = NULL) &&
- {right_cst != NULL} &&
+ (result = NULL) &&
+ {right_cst != NULL} &&
{left_cst != NULL}
).if {
result := exec left_cst and right_cst;
- };
- ((result = NULL) && {old_seq = seq_call_and_loop}).if {
- // No conservator transformation.
+ };
+ ((result = NULL) && {old_seq = seq_call_and_loop}).if {
+ // No conservator transformation.
result := exec;
((result = NULL) && {left_cst != NULL}).if {
result := exec_left left_cst;
@@ -151,27 +151,27 @@ Section Public
result.set_position position;
new_execute_pass;
};
-
+
result
);
-
- - exec_conservator:EXPR <- NULL;
+
+ - exec_conservator:EXPR <- NULL;
- exec_conservator_left left_cst :INTEGER_CST :EXPR <- NULL;
- exec_conservator_right right_cst:INTEGER_CST :EXPR <- NULL;
-
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <- NULL;
-
+
- exec:EXPR <- NULL;
- exec_left left_cst :INTEGER_CST :EXPR <- NULL;
- exec_right right_cst:INTEGER_CST :EXPR <- NULL;
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
- (static_type.raw = type_pointer).if {
+ (static_type.raw = type_pointer).if {
buffer.append "(void *)";
} else {
buffer.add_last '(';
@@ -188,7 +188,7 @@ Section Public
buffer.add_last ' ';
buffer.append symbol;
buffer.add_last ' ';
- (static_type.raw = type_pointer).if {
+ (static_type.raw = type_pointer).if {
buffer.append "(unsigned long)";
}.elseif {! right.static_type.is_expanded} then {
buffer.append "(void *)"; // BSBS: A virer quand tu auras optim '=='
@@ -196,11 +196,11 @@ Section Public
right.genere buffer;
buffer.add_last ')';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.add_last '(';
diff --git a/src/external/arithmetic/expr_div.li b/src/external/arithmetic/expr_div.li
index bd518da..e988746 100644
--- a/src/external/arithmetic/expr_div.li
+++ b/src/external/arithmetic/expr_div.li
@@ -19,35 +19,35 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_DIV;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Div Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
- symbol:STRING_CONSTANT := "/";
-
+
//
// Execute.
//
-
- - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E / 0 -> Error.
//-- E / 1 -> E
//-- E / -1 -> - E
//-- E / 2^n -> E >> n
( + result:EXPR;
+ v:INTEGER_64;
-
+
(right_cst.value = 0).if {
warning_error (position,"Division by zero.");
}.elseif {right_cst.value = 1} then {
@@ -56,37 +56,37 @@ Section Public
}.elseif {right_cst.value = -1} then {
result := EXPR_NEG.create position with left;
right_cst.remove;
- }.elseif {(v := right_cst.to_power) != -1} then {
+ }.elseif {(v := right_cst.to_power) != -1} then {
right_cst.set_value v;
result := EXPR_SHIFT_R.create position with left and right_cst;
};
result
);
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 / C2 -> C3
( + result:EXPR;
-
+
(right_cst.value != 0).if {
- left_cst.set_value (left_cst.value / right_cst.value);
+ left_cst.set_value (left_cst.value / right_cst.value);
right_cst.remove;
result := left_cst;
};
result
);
-
+
- exec:EXPR <-
//-- E / E -> 1
//-- -E / E -> -1
//-- E / -E -> -1
( + result:EXPR;
+ neg:EXPR_NEG;
-
+
(right ~= left).if {
result := INTEGER_CST.create position value 1 type static_type;
right.remove;
left .remove;
- } else {
+ } else {
neg ?= left;
((neg != NULL) && {neg.right ~= right}).if {
result := INTEGER_CST.create position value (-1) type static_type;
@@ -99,15 +99,15 @@ Section Public
left.remove;
right.remove;
};
- };
+ };
};
result
);
-
+
- exec_left left_cst :INTEGER_CST :EXPR <-
//-- 0 / E -> 0
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := left_cst;
right.remove;
@@ -117,13 +117,13 @@ Section Public
-
-
-
-
-
-
-
+
+
+
+
+
+
+
diff --git a/src/external/arithmetic/expr_mod.li b/src/external/arithmetic/expr_mod.li
index d9a2dc8..0bb072b 100644
--- a/src/external/arithmetic/expr_mod.li
+++ b/src/external/arithmetic/expr_mod.li
@@ -19,32 +19,32 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_MOD;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Add Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
+ symbol:STRING_CONSTANT := "%";
-
+
//
// Execute.
//
-
+
- exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E % 0 -> Error
//-- E % 2^n -> E & (2^n -1)
( + result:EXPR;
-
+
(right_cst.value = 0).if {
warning_error (position,"Division by zero.");
}.elseif {right_cst.to_power != -1} then {
@@ -53,31 +53,31 @@ Section Public
};
result
);
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 % C2 -> C3
(
- left_cst.set_value (left_cst.value % right_cst.value);
+ left_cst.set_value (left_cst.value % right_cst.value);
right_cst.remove;
left_cst
);
-
+
- exec:EXPR <-
//-- E % E -> 0
( + result:EXPR;
-
+
(left ~= right).if {
result := INTEGER_CST.create position value 0 type static_type;
left.remove;
right.remove;
};
- result
+ result
);
- exec_left left_cst :INTEGER_CST :EXPR <-
//-- 0 % E -> 0
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := left_cst;
right.remove;
@@ -85,25 +85,25 @@ Section Public
result
);
- - exec_right right_cst:INTEGER_CST :EXPR <-
+ - exec_right right_cst:INTEGER_CST :EXPR <-
//-- E % 1 -> 0
//-- E % -1 -> 0
( + result:EXPR;
-
+
(right_cst.value = 1).if {
right_cst.set_value 0;
left.remove;
result := right_cst;
- }.elseif {right_cst.value = -1} then {
+ }.elseif {right_cst.value = -1} then {
right_cst.set_value 0;
result := right_cst;
left.remove;
};
- result
+ result
);
-
-
-
+
+
+
diff --git a/src/external/arithmetic/expr_mul.li b/src/external/arithmetic/expr_mul.li
index ef87374..601e8c8 100644
--- a/src/external/arithmetic/expr_mul.li
+++ b/src/external/arithmetic/expr_mul.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_MUL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Mul Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
-Section Public
-
+
+Section Public
+
- symbol:STRING_CONSTANT := "*";
-
+
//
// Execute.
//
-
+
- exec_conservator_left left_cst :INTEGER_CST :EXPR <-
//-- 1 * E -> E
//-- -1 * E -> - E
//-- 2^n * E -> E << n
( + v:INTEGER_64;
+ result:EXPR;
-
+
(left_cst.value = 1).if {
left_cst.remove;
result := right;
@@ -57,16 +57,16 @@ Section Public
left_cst.set_value v;
result := EXPR_SHIFT_L.create position with right and left_cst;
};
- result
+ result
);
-
+
- exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E * 1 -> E
//-- E * -1 -> - E
//-- E * 2^n -> E << n
( + result:EXPR;
+ v:INTEGER_64;
-
+
(right_cst.value = 1).if {
right_cst.remove;
result := left;
@@ -79,38 +79,38 @@ Section Public
};
result
);
-
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 * C2 -> C3
(
- left_cst.set_value (left_cst.value * right_cst.value);
+ left_cst.set_value (left_cst.value * right_cst.value);
right_cst.remove;
left_cst
);
-
+
- exec_left left_cst :INTEGER_CST :EXPR <-
//-- 0 * E -> 0
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := left_cst;
right.remove;
};
result
);
-
+
- exec_right right_cst:INTEGER_CST :EXPR <-
//-- E * 0 -> 0
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := right_cst;
left.remove;
- };
+ };
result
);
-
-
+
+
diff --git a/src/external/arithmetic/expr_neg.li b/src/external/arithmetic/expr_neg.li
index fb36e0f..e837692 100644
--- a/src/external/arithmetic/expr_neg.li
+++ b/src/external/arithmetic/expr_neg.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_NEG;
- copyright := "2003-2007 Benoit Sonntag";
@@ -27,41 +27,41 @@ Section Header
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Negatif unary arithmetic expression.";
-
+
Section Inherit
-
+
+ parent_expr_unary:Expanded EXPR_UNARY;
-
+
Section Public
-
+
- symbol:CHARACTER <- '-';
-
+
//
// Execute.
//
-
+
- exec_conservator:EXPR <-
- //-- - - E -> E
+ //-- - - E -> E
( + sub:EXPR_NEG;
+ result:EXPR;
-
+
sub ?= right;
(sub != NULL).if {
result := sub.right;
};
result
);
-
+
- exec_right right_cst:INTEGER_CST :EXPR <-
//-- - C1 -> C2
( + result:EXPR;
(right_cst.is_signed).if {
- right_cst.set_value (- right_cst.value);
+ right_cst.set_value (- right_cst.value);
result := right_cst;
};
result
);
-
+
diff --git a/src/external/arithmetic/expr_not.li b/src/external/arithmetic/expr_not.li
index bdc046a..e17a5ad 100644
--- a/src/external/arithmetic/expr_not.li
+++ b/src/external/arithmetic/expr_not.li
@@ -19,27 +19,27 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_NOT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Not unary arithmetic expression.";
-
+
Section Inherit
-
+
+ parent_expr_unary:Expanded EXPR_UNARY;
-
+
Section Public
-
+
- symbol:CHARACTER <- '~';
-
+
//
// Execute.
//
-
+
- exec_conservator:EXPR <-
//-- ~ (~ E1 & ~ E2) -> E1 | E2
//-- ~ (~ E1 | ~ E2) -> E1 & E2
@@ -48,7 +48,7 @@ Section Public
+ and:EXPR_AND;
+ neg1,neg2:EXPR_NOT;
+ result:EXPR;
-
+
and ?= right;
(and != NULL).if {
neg1 ?= and.left;
@@ -73,8 +73,8 @@ Section Public
};
result
);
-
- - exec_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_right right_cst:INTEGER_CST :EXPR <-
//-- ~ C1 -> C2
( + result:EXPR;
(right_cst.is_signed).if {
@@ -82,9 +82,9 @@ Section Public
result := right_cst;
};
result
- );
-
-
+ );
+
+
diff --git a/src/external/arithmetic/expr_or.li b/src/external/arithmetic/expr_or.li
index edd6f86..bb07162 100644
--- a/src/external/arithmetic/expr_or.li
+++ b/src/external/arithmetic/expr_or.li
@@ -19,64 +19,64 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_OR;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Or binary arithmetic expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
- symbol:STRING_CONSTANT := "|";
-
+
//
// Execute.
//
-
+
- exec_conservator_left left_cst :INTEGER_CST :EXPR <-
//-- 0 | E -> E
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := right;
left_cst.remove;
};
result
);
-
- - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E | 0 -> E
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := left;
right_cst.remove;
};
result
);
-
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 | C2 -> C3
- (
- left_cst.set_value (left_cst.value | right_cst.value);
+ (
+ left_cst.set_value (left_cst.value | right_cst.value);
right_cst.remove;
left_cst
);
-
+
- exec:EXPR <-
//-- (! E1 & E2) | (E1 & ! E2) -> E1 ^ E2 (A lot of possibilities, but see '^' in INTEGER)
//-- E | E -> E
( + result:EXPR;
+ and_l,and_r:EXPR_AND;
+ not_l,not_r:EXPR_NOT;
-
+
(left ~= right).if {
right.remove;
result := left;
@@ -94,24 +94,24 @@ Section Public
};
};
};
- result
+ result
);
-
- - exec_left left_cst :INTEGER_CST :EXPR <-
- //-- -1 | E -> -1
+
+ - exec_left left_cst :INTEGER_CST :EXPR <-
+ //-- -1 | E -> -1
( + result:EXPR;
-
+
(left_cst.is_saturated).if {
result := left_cst;
right.remove;
};
result
);
-
+
- exec_right right_cst:INTEGER_CST :EXPR <-
//-- E | -1 -> -1
( + result:EXPR;
-
+
(right_cst.is_saturated).if {
result := right_cst;
left.remove;
@@ -119,7 +119,7 @@ Section Public
result
);
-
+
diff --git a/src/external/arithmetic/expr_shift_l.li b/src/external/arithmetic/expr_shift_l.li
index 2be4257..924b72d 100644
--- a/src/external/arithmetic/expr_shift_l.li
+++ b/src/external/arithmetic/expr_shift_l.li
@@ -19,39 +19,39 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_SHIFT_L;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Add Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
+ symbol:STRING_CONSTANT := "<<";
-
+
//
// Execute.
//
-
- - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
- //-- E << 0 -> E
+
+ - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
+ //-- E << 0 -> E
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := left;
right_cst.remove;
};
result
);
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 << C2 -> C3
//-- C1 << -C2 -> Error.
(
@@ -59,27 +59,27 @@ Section Public
warning_error (position,"Left shift count is negative.");
left_cst.set_value 0;
} else {
- left_cst.set_value (left_cst.value << right_cst.value);
+ left_cst.set_value (left_cst.value << right_cst.value);
};
right_cst.remove;
left_cst
);
- - exec_left left_cst :INTEGER_CST :EXPR <-
+ - exec_left left_cst :INTEGER_CST :EXPR <-
//-- 0 << E -> 0
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := left_cst;
right.remove;
};
result
);
-
- - exec_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_right right_cst:INTEGER_CST :EXPR <-
//-- E << -C2 -> Error.
( + result:EXPR;
-
+
(right_cst.value < 0).if {
warning_error (position,"Left shift count is negative.");
right_cst.set_value 0;
@@ -89,5 +89,5 @@ Section Public
};
result
);
-
-
+
+
diff --git a/src/external/arithmetic/expr_shift_r.li b/src/external/arithmetic/expr_shift_r.li
index a2c159e..c3e73e0 100644
--- a/src/external/arithmetic/expr_shift_r.li
+++ b/src/external/arithmetic/expr_shift_r.li
@@ -19,39 +19,39 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_SHIFT_R;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Add Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
+ symbol:STRING_CONSTANT := ">>";
-
+
//
// Execute.
//
-
- - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
- //-- E >> 0 -> E
+
+ - exec_conservator_right right_cst:INTEGER_CST :EXPR <-
+ //-- E >> 0 -> E
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := left;
right_cst.remove;
};
result
);
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 >> C2 -> C3
//-- C1 >> -C2 -> Error.
(
@@ -59,12 +59,12 @@ Section Public
warning_error (position,"Right shift count is negative.");
left_cst.set_value 0;
} else {
- left_cst.set_value (left_cst.value >> right_cst.value);
+ left_cst.set_value (left_cst.value >> right_cst.value);
};
right_cst.remove;
left_cst
);
-
+
- exec:EXPR <-
//-- E(unsigned) >> E(unsigned) -> 0
( + result:EXPR;
@@ -77,12 +77,12 @@ Section Public
*/
result
);
-
- - exec_left left_cst:INTEGER_CST :EXPR <-
+
+ - exec_left left_cst:INTEGER_CST :EXPR <-
//-- 0 >> E -> 0
//-- -1(signed) >> E -> -1(signed)
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := left_cst;
right.remove;
@@ -92,11 +92,11 @@ Section Public
};
result
);
-
- - exec_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_right right_cst:INTEGER_CST :EXPR <-
//-- E >> -C2 -> Error.
( + result:EXPR;
-
+
(right_cst.value < 0).if {
warning_error (position,"Right shift count is negative.");
right_cst.set_value 0;
@@ -106,7 +106,7 @@ Section Public
};
result
);
-
-
-
-
+
+
+
+
diff --git a/src/external/arithmetic/expr_sub.li b/src/external/arithmetic/expr_sub.li
index decbb76..dabf611 100644
--- a/src/external/arithmetic/expr_sub.li
+++ b/src/external/arithmetic/expr_sub.li
@@ -19,44 +19,44 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_SUB;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Add Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
-Section Public
-
+
+Section Public
+
- symbol:STRING_CONSTANT := "-";
-
+
//
// Execute.
//
-
- - exec_conservator:EXPR <-
+
+ - exec_conservator:EXPR <-
//-- E1 - - E2 -> E1 + E2
( + neg:EXPR_NEG;
+ result:EXPR;
-
- neg ?= right;
+
+ neg ?= right;
(neg != NULL).if {
result := EXPR_ADD.create position with left and (neg.right);
};
result
);
-
- - exec_conservator_left left_cst :INTEGER_CST :EXPR <-
+
+ - exec_conservator_left left_cst :INTEGER_CST :EXPR <-
//-- 0 - E -> - E
- //-- -1 - E -> ~ E
+ //-- -1 - E -> ~ E
( + result:EXPR;
-
+
(left_cst.value = 0).if {
left_cst.remove;
result := EXPR_NEG.create position with right;
@@ -64,16 +64,16 @@ Section Public
left_cst.remove;
result := EXPR_NOT.create position with right;
};
- result
+ result
);
-
+
- exec_conservator_right right_cst:INTEGER_CST :EXPR <-
//-- E - 0 -> E
//-- -E - 1 -> ~ E
//-- E - -C -> E + C
( + result:EXPR;
+ neg:EXPR_NEG;
-
+
(right_cst.value = 0).if {
right_cst.remove;
result := left;
@@ -88,23 +88,23 @@ Section Public
result := EXPR_ADD.create position with left and right_cst;
};
result
- );
-
+ );
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 - C2 -> C3
(
- left_cst.set_value (left_cst.value - right_cst.value);
+ left_cst.set_value (left_cst.value - right_cst.value);
right_cst.remove;
left_cst
);
-
+
- exec:EXPR <-
//-- E - E -> 0
- //-- E1 - ((E1 / E2) * E2) -> E1 % E2
+ //-- E1 - ((E1 / E2) * E2) -> E1 % E2
( + result:EXPR;
+ mul:EXPR_MUL;
+ div:EXPR_DIV;
-
+
(left ~= right).if {
left.remove;
right.remove;
@@ -124,5 +124,4 @@ Section Public
result
);
-
-
\ No newline at end of file
+
diff --git a/src/external/arithmetic/expr_unary.li b/src/external/arithmetic/expr_unary.li
index 32bf833..246d5ab 100644
--- a/src/external/arithmetic/expr_unary.li
+++ b/src/external/arithmetic/expr_unary.li
@@ -19,100 +19,100 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_UNARY;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Unary Expression.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- right.is_invariant;
-
+
+ right:EXPR;
-
- - symbol:CHARACTER <-
+
+ - symbol:CHARACTER <-
(
deferred;
' '
);
-
+
- static_type:TYPE_FULL <- right.static_type;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add (static_type.raw);
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with r:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with r;
result
);
-
+
- make p:POSITION with r:EXPR <-
(
position := p;
right := r;
);
-
+
- my_copy:SELF <- SELF.create position with (right.my_copy);
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + same:SELF;
-
+
same ?= other;
(same != NULL) && {right ~= same.right}
);
-
+
- remove <-
- (
+ (
right.remove;
);
-
+
//
// Execute.
//
-
+
- execute_unlink:INSTR <-
(
right.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ right_cst:INTEGER_CST;
-
- old_seq := seq_call_and_loop;
- right := right.execute_link;
- //
+
+ old_seq := seq_call_and_loop;
+ right := right.execute_link;
+ //
right_cst ?= right;
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_right right_cst;
};
- ((result = NULL) && {old_seq = seq_call_and_loop}).if {
- // No conservator transformation.
- result := exec;
+ ((result = NULL) && {old_seq = seq_call_and_loop}).if {
+ // No conservator transformation.
+ result := exec;
};
(result = NULL).if {
result := Self;
@@ -120,20 +120,20 @@ Section Public
result.set_position position;
new_execute_pass;
};
-
+
result
);
-
- - exec_conservator:EXPR <- NULL;
-
+
+ - exec_conservator:EXPR <- NULL;
+
- exec_right right_cst:INTEGER_CST :EXPR <- NULL;
-
+
- exec:EXPR <- NULL;
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
buffer.add_last '(';
@@ -145,12 +145,12 @@ Section Public
buffer.add_last ' ';
right.genere buffer;
buffer.add_last ')';
- );
-
+ );
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.add_last '(';
diff --git a/src/external/arithmetic/expr_xor.li b/src/external/arithmetic/expr_xor.li
index 7e40b46..3383497 100644
--- a/src/external/arithmetic/expr_xor.li
+++ b/src/external/arithmetic/expr_xor.li
@@ -19,32 +19,32 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_XOR;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Xor Binary arithmetic expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary:Expanded EXPR_BINARY;
-
+
Section Public
-
+
+ symbol:STRING_CONSTANT := "^";
-
+
//
// Execute.
//
-
- - exec_conservator_left left_cst :INTEGER_CST :EXPR <-
+
+ - exec_conservator_left left_cst :INTEGER_CST :EXPR <-
//-- 0 ^ E -> E
- //-- -1 ^ E -> ~ E
+ //-- -1 ^ E -> ~ E
( + result:EXPR;
-
+
(left_cst.value = 0).if {
result := right;
left_cst.remove;
@@ -59,7 +59,7 @@ Section Public
//-- E ^ 0 -> E
//-- E ^ -1 -> ~ E
( + result:EXPR;
-
+
(right_cst.value = 0).if {
result := left;
right_cst.remove;
@@ -69,23 +69,23 @@ Section Public
};
result
);
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 ^ C2 -> C3
(
- left_cst.set_value (left_cst.value ^ right_cst.value);
+ left_cst.set_value (left_cst.value ^ right_cst.value);
right_cst.remove;
left_cst
);
-
+
- exec:EXPR <-
//-- E ^ E -> 0
( + result:EXPR;
-
+
(left ~= right).if {
result := INTEGER_CST.create position value 0 type static_type;
left .remove;
right.remove;
};
- result
+ result
);
diff --git a/src/external/call_null.li b/src/external/call_null.li
index 1bb9a12..7ec5be3 100644
--- a/src/external/call_null.li
+++ b/src/external/call_null.li
@@ -19,62 +19,62 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := CALL_NULL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Call on NULL";
-
+
Section Inherit
-
- + parent_instr:Expanded INSTR;
-
-Section Public
-
+
+ + parent_instr:Expanded INSTR;
+
+Section Public
+
- my_copy:SELF <- Self;
-
+
- is_necessary:BOOLEAN;
-
+
//
// Remove
//
-
+
- remove; // Nothing.
-
+
//
// Execute
//
-
+
- execute:INSTR <- Self;
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
( + code:STRING_CONSTANT;
(debug_level_option != 0).if {
- code :=
+ code :=
"lisaac_stack_print(top_context); \
\print_string(\"Call on NULL\\n\"); \
\die_with_code(1)";
} else {
- code :=
+ code :=
"print_string(\"Call on NULL\\n\
- \(Use `-D' option)\\n\"); \
+ \(Use `-D' option)\\n\"); \
\die_with_code(1)";
};
buffer.append code;
is_necessary := TRUE;
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append "Call on NULL";
diff --git a/src/external/comparison/expr_binary_cmp.li b/src/external/comparison/expr_binary_cmp.li
index 4861d4f..9612f66 100644
--- a/src/external/comparison/expr_binary_cmp.li
+++ b/src/external/comparison/expr_binary_cmp.li
@@ -19,130 +19,130 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_BINARY_CMP;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Binary comparison expression.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- left.is_invariant && {right.is_invariant};
-
+
+ left:EXPR;
-
+
+ right:EXPR;
-
+
- set_left l:EXPR and_right r:EXPR <-
(
left := l;
right := r;
);
-
- - symbol:STRING_CONSTANT <-
+
+ - symbol:STRING_CONSTANT <-
(
deferred;
NULL
);
-
+
- static_type:TYPE_FULL <- type_boolean.default;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add type_true;
t.add type_false;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with l:EXPR and r:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with l and r;
result
);
-
+
- make p:POSITION with l:EXPR and r:EXPR <-
(
position := p;
left := l;
right := r;
);
-
+
- my_copy:SELF <- SELF.create position with (left.my_copy) and (right.my_copy);
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + same:SELF;
-
+
same ?= other;
(same != NULL) && {left ~= same.left} && {right ~= same.right}
- );
-
+ );
+
//
// Remove
//
-
+
- remove <-
(
left .remove;
right.remove;
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
( + instr:INSTR;
instr := left.execute_unlink;
(instr != NULL).if {
list_current.insert_before instr;
};
- right.execute_unlink
+ right.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ left_cst,right_cst:INTEGER_CST;
-
- old_seq := seq_call_and_loop;
+
+ old_seq := seq_call_and_loop;
left := left .execute_link;
- right := right.execute_link;
+ right := right.execute_link;
//
left_cst ?= left;
right_cst ?= right;
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {left_cst != NULL}).if {
+ ((result = NULL) && {left_cst != NULL}).if {
result := exec_conservator_left left_cst;
};
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_conservator_right right_cst;
- };
+ };
(
- (result = NULL) &&
- {right_cst != NULL} &&
+ (result = NULL) &&
+ {right_cst != NULL} &&
{left_cst != NULL}
).if {
result := exec left_cst and right_cst;
- };
- ((result = NULL) && {old_seq = seq_call_and_loop}).if {
- // No conservator transformation.
+ };
+ ((result = NULL) && {old_seq = seq_call_and_loop}).if {
+ // No conservator transformation.
result := exec;
((result = NULL) && {left_cst != NULL}).if {
result := exec_left left_cst;
@@ -150,7 +150,7 @@ Section Public
((result = NULL) && {right_cst != NULL}).if {
result := exec_right right_cst;
};
- };
+ };
//
(result = NULL).if {
result := Self;
@@ -158,33 +158,33 @@ Section Public
result.set_position position;
new_execute_pass;
};
-
+
result
);
-
- - exec_conservator:EXPR <- NULL;
+
+ - exec_conservator:EXPR <- NULL;
- exec_conservator_left left_cst :INTEGER_CST :EXPR <- NULL;
- exec_conservator_right right_cst:INTEGER_CST :EXPR <- NULL;
-
+
- exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <- NULL;
-
+
- exec:EXPR <- NULL;
- exec_left left_cst :INTEGER_CST :EXPR <- NULL;
- exec_right right_cst:INTEGER_CST :EXPR <- NULL;
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
buffer.add_last '(';
(
- (left.static_type.raw = type_pointer) &&
+ (left.static_type.raw = type_pointer) &&
{ALIAS_STR.is_integer (right.static_type.raw.name)}
).if {
buffer.append "(unsigned long)";
- }.elseif {! left.static_type.is_expanded} then {
+ }.elseif {! left.static_type.is_expanded} then {
buffer.append "(void *)"; // BSBS: A virer quand tu auras optim '=='
};
((left.static_type.raw = TYPE_NULL) && {right.static_type.raw.is_block}).if {
@@ -197,15 +197,15 @@ Section Public
(left.static_type.raw.is_block).if {
buffer.append ".__id";
};
- };
+ };
buffer.add_last ' ';
buffer.append symbol;
buffer.add_last ' ';
-
+
(
- (ALIAS_STR.is_integer (left.static_type.raw.name)) &&
+ (ALIAS_STR.is_integer (left.static_type.raw.name)) &&
{right.static_type.raw = type_pointer}
- ).if {
+ ).if {
buffer.append "(unsigned long)";
}.elseif {! right.static_type.is_expanded} then {
buffer.append "(void *)"; // BSBS: A virer quand tu auras optim '=='
@@ -217,18 +217,18 @@ Section Public
(right.static_type.raw.is_block).if {
buffer.append ".__id";
};
- };
+ };
buffer.add_last ')';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
- buffer.add_last '(';
- left.static_type.append_name_in buffer;
+ buffer.add_last '(';
+ left.static_type.append_name_in buffer;
buffer.add_last ' ';
left.display buffer;
buffer.append symbol;
diff --git a/src/external/comparison/expr_equal.li b/src/external/comparison/expr_equal.li
index ec04f85..019f7c2 100644
--- a/src/external/comparison/expr_equal.li
+++ b/src/external/comparison/expr_equal.li
@@ -19,47 +19,47 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_EQUAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Simple Equal Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_cmp:Expanded EXPR_BINARY_CMP;
-
+
Section Public
-
+
- symbol:STRING_CONSTANT := "==";
-
+
//
// Execute.
//
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 == C2 -> TRUE/FALSE
( + result:PROTOTYPE_CST;
-
+
(left_cst.value = right_cst.value).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
left_cst .remove;
right_cst.remove;
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E == E -> TRUE
//-- Expanded == NULL -> FALSE
( + result:PROTOTYPE_CST;
+ r:PROTOTYPE_CST;
-
+
(left ~= right).if {
result := PROTOTYPE_CST.create position type (type_true.default);
left .remove;
@@ -67,8 +67,8 @@ Section Public
} else {
r ?= right;
(
- (r != NULL) &&
- {r.static_type.raw = TYPE_NULL} &&
+ (r != NULL) &&
+ {r.static_type.raw = TYPE_NULL} &&
{left.static_type.is_expanded} &&
{left.static_type.raw != type_pointer}
).if {
@@ -77,19 +77,19 @@ Section Public
result := PROTOTYPE_CST.create position type (type_false.default);
};
};
-
+
result
);
-
+
//
// Genere
//
-
+
- genere buffer:STRING <-
(
(
- (left.static_type.is_expanded) &&
- {right.static_type.is_expanded} &&
+ (left.static_type.is_expanded) &&
+ {right.static_type.is_expanded} &&
{right.static_type.raw.type_c = NULL}
).if {
buffer.append "(memcmp(";
@@ -103,11 +103,11 @@ Section Public
};
right.genere buffer;
buffer.append ",sizeof(";
- left.static_type.raw.put_expanded_declaration buffer;
+ left.static_type.raw.put_expanded_declaration buffer;
buffer.append ")) == 0)";
} else {
parent_expr_binary_cmp.genere buffer;
- };
+ };
);
diff --git a/src/external/comparison/expr_inf.li b/src/external/comparison/expr_inf.li
index bf674fc..e352d40 100644
--- a/src/external/comparison/expr_inf.li
+++ b/src/external/comparison/expr_inf.li
@@ -19,59 +19,59 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_INF;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Inferior binary comparison expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_cmp:Expanded EXPR_BINARY_CMP;
-
-Section Public
-
+
+Section Public
+
- symbol:STRING_CONSTANT := "<";
-
+
//
// Execute.
//
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 < C2 -> TRUE/FALSE
( + result:PROTOTYPE_CST;
-
+
(left_cst.value < right_cst.value).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
left_cst .remove;
right_cst.remove;
-
+
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E < E -> FALSE
( + result:PROTOTYPE_CST;
-
+
(left ~= right).if {
result := PROTOTYPE_CST.create position type (type_false.default);
left .remove;
right.remove;
- };
-
+ };
+
result
);
-
- - exec_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_right right_cst:INTEGER_CST :EXPR <-
//-- E(unsigned) < 0 -> FALSE
( + result:EXPR;
-
+
((right_cst.value = 0) && {left.static_type.raw.name.first = 'U'}).if {
result := PROTOTYPE_CST.create position type (type_false.default);
left .remove;
diff --git a/src/external/comparison/expr_inf_eq.li b/src/external/comparison/expr_inf_eq.li
index 86c3955..f6c8aeb 100644
--- a/src/external/comparison/expr_inf_eq.li
+++ b/src/external/comparison/expr_inf_eq.li
@@ -19,52 +19,52 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_INF_EQ;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Inferior or equal binary comparison expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_cmp:Expanded EXPR_BINARY_CMP;
-
-Section Public
-
+
+Section Public
+
- symbol:STRING_CONSTANT := "<=";
-
+
//
// Execute.
//
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 <= C2 -> TRUE/FALSE
( + result:PROTOTYPE_CST;
-
+
(left_cst.value <= right_cst.value).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
left_cst .remove;
right_cst.remove;
-
+
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E <= E -> TRUE
( + result:PROTOTYPE_CST;
-
+
(left ~= right).if {
result := PROTOTYPE_CST.create position type (type_true.default);
left .remove;
right.remove;
- };
-
+ };
+
result
);
-
+
diff --git a/src/external/comparison/expr_not_equal.li b/src/external/comparison/expr_not_equal.li
index c7ebd0d..fb47c44 100644
--- a/src/external/comparison/expr_not_equal.li
+++ b/src/external/comparison/expr_not_equal.li
@@ -19,48 +19,48 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_NOT_EQUAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Not equal binary comparison expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_cmp:Expanded EXPR_BINARY_CMP;
-
+
Section Public
-
+
- symbol:STRING_CONSTANT := "!=";
-
+
//
// Execute.
//
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 != C2 -> TRUE/FALSE
( + result:PROTOTYPE_CST;
-
+
(left_cst.value != right_cst.value).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
left_cst .remove;
right_cst.remove;
-
+
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E != E -> FALSE
//-- Expanded != NULL -> TRUE
( + result:PROTOTYPE_CST;
+ r:PROTOTYPE_CST;
-
+
(left ~= right).if {
result := PROTOTYPE_CST.create position type (type_false.default);
left .remove;
@@ -68,29 +68,29 @@ Section Public
} else {
r ?= right;
(
- (r != NULL) &&
- {r.static_type.raw = TYPE_NULL} &&
+ (r != NULL) &&
+ {r.static_type.raw = TYPE_NULL} &&
{left.static_type.is_expanded} &&
{left.static_type.raw != type_pointer}
).if {
left .remove;
right.remove;
- result := PROTOTYPE_CST.create position type (type_true.default);
+ result := PROTOTYPE_CST.create position type (type_true.default);
};
- };
-
+ };
+
result
);
//
// Genere
//
-
+
- genere buffer:STRING <- // BSBS: a factoriser avec EXPR_EQUAL
(
(
- (left.static_type.is_expanded) &&
- {right.static_type.is_expanded} &&
+ (left.static_type.is_expanded) &&
+ {right.static_type.is_expanded} &&
{right.static_type.raw.type_c = NULL}
).if {
buffer.append "(memcmp(";
@@ -104,13 +104,13 @@ Section Public
};
right.genere buffer;
buffer.append ",sizeof(";
- left.static_type.raw.put_expanded_declaration buffer;
+ left.static_type.raw.put_expanded_declaration buffer;
buffer.append ")) != 0)";
} else {
parent_expr_binary_cmp.genere buffer;
- };
+ };
);
-
-
+
+
diff --git a/src/external/comparison/expr_sup.li b/src/external/comparison/expr_sup.li
index 65247f6..1a681f0 100644
--- a/src/external/comparison/expr_sup.li
+++ b/src/external/comparison/expr_sup.li
@@ -19,64 +19,64 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_SUP;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Superior binary comparison expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_cmp:Expanded EXPR_BINARY_CMP;
-
-Section Public
-
+
+Section Public
+
- symbol:STRING_CONSTANT := ">";
-
+
//
// Execute.
//
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 > C2 -> TRUE/FALSE
( + result:PROTOTYPE_CST;
-
+
(left_cst.value > right_cst.value).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
left_cst .remove;
right_cst.remove;
-
+
result
);
-
- - exec_left left_cst :INTEGER_CST :EXPR <-
+
+ - exec_left left_cst :INTEGER_CST :EXPR <-
//-- 0 > E (unsigned) -> FALSE
( + result:EXPR;
-
+
((left_cst.value = 0) && {right.static_type.raw.name.first = 'U'}).if {
result := PROTOTYPE_CST.create position type (type_false.default);
left .remove;
right.remove;
};
- result
+ result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E > E -> FALSE
( + result:PROTOTYPE_CST;
-
+
(left ~= right).if {
result := PROTOTYPE_CST.create position type (type_false.default);
left .remove;
right.remove;
- };
-
+ };
+
result
);
-
+
diff --git a/src/external/comparison/expr_sup_eq.li b/src/external/comparison/expr_sup_eq.li
index ad00424..d0ba6af 100644
--- a/src/external/comparison/expr_sup_eq.li
+++ b/src/external/comparison/expr_sup_eq.li
@@ -19,59 +19,59 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_SUP_EQ;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Superior or equal binary comparison expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_cmp:Expanded EXPR_BINARY_CMP;
-
-Section Public
-
+
+Section Public
+
- symbol:STRING_CONSTANT := ">=";
-
+
//
// Execute.
//
-
- - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
+
+ - exec left_cst:INTEGER_CST and right_cst:INTEGER_CST :EXPR <-
//-- C1 >= C2 -> TRUE/FALSE
( + result:PROTOTYPE_CST;
-
+
(left_cst.value >= right_cst.value).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
left_cst .remove;
right_cst.remove;
-
+
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E >= E -> TRUE
( + result:PROTOTYPE_CST;
-
+
(left ~= right).if {
result := PROTOTYPE_CST.create position type (type_true.default);
left .remove;
right.remove;
- };
-
+ };
+
result
);
-
- - exec_right right_cst:INTEGER_CST :EXPR <-
+
+ - exec_right right_cst:INTEGER_CST :EXPR <-
//-- E(unsigned) >= 0 -> TRUE
( + result:EXPR;
-
+
((right_cst.value = 0) && {left.static_type.raw.name.first = 'U'}).if {
result := PROTOTYPE_CST.create position type (type_true.default);
left .remove;
diff --git a/src/external/external_c.li b/src/external/external_c.li
index d068ab5..188b041 100644
--- a/src/external/external_c.li
+++ b/src/external/external_c.li
@@ -19,32 +19,32 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXTERNAL_C;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit";
- comment := "External C instruction.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
+ is_persistant:BOOLEAN;
+ static_type:TYPE_FULL;
- + living_type:TYPES;
-
+ + living_type:TYPES;
+
- set_living_type l:TYPES <-
(
living_type := l;
);
-
+
- get_type t:TYPES_TMP <-
(
(living_type = NULL).if {
@@ -57,18 +57,18 @@ Section Public
//
// External value.
//
-
+
+ code:STRING_CONSTANT;
+ access_list:FAST_ARRAY(EXPR);
//
// Creation.
//
-
- - create p:POSITION
+
+ - create p:POSITION
text c:STRING_CONSTANT
- access ac:FAST_ARRAY(EXPR)
- persistant per:BOOLEAN
+ access ac:FAST_ARRAY(EXPR)
+ persistant per:BOOLEAN
type t:TYPE_FULL :SELF <-
( + result:SELF;
result := clone;
@@ -76,10 +76,10 @@ Section Public
result
);
- - make p:POSITION
+ - make p:POSITION
text c:STRING_CONSTANT
- access ac:FAST_ARRAY(EXPR)
- persistant per:BOOLEAN
+ access ac:FAST_ARRAY(EXPR)
+ persistant per:BOOLEAN
type t:TYPE_FULL <-
(
position := p;
@@ -92,18 +92,18 @@ Section Public
- my_copy:SELF <-
( + result:SELF;
+ new_access:FAST_ARRAY(EXPR);
- + val:EXPR;
-
+ + val:EXPR;
+
(access_list != NULL).if {
new_access := FAST_ARRAY(EXPR).create_with_capacity (access_list.count);
(access_list.lower).to (access_list.upper) do { j:INTEGER;
- val := access_list.item j.my_copy;
+ val := access_list.item j.my_copy;
new_access.add_last val;
- };
+ };
};
- result := SELF.create position text code
- access new_access persistant is_persistant type static_type;
- result.set_living_type living_type;
+ result := SELF.create position text code
+ access new_access persistant is_persistant type static_type;
+ result.set_living_type living_type;
result
);
@@ -119,10 +119,10 @@ Section Public
};
};
);
-
+
- execute_unlink:INSTR <-
( + result,instr:INSTR;
-
+
(is_persistant).if {
// Normal.
static_type := TYPE_VOID.default;
@@ -130,7 +130,7 @@ Section Public
} else {
// Remove.
(access_list != NULL).if {
- (access_list.lower).to (access_list.upper) do { j:INTEGER;
+ (access_list.lower).to (access_list.upper) do { j:INTEGER;
instr := access_list.item j.execute_unlink;
(instr != NULL).if {
list_current.insert_before instr;
@@ -143,11 +143,11 @@ Section Public
- execute_link:EXPR <-
( + e:EXPR;
-
+
// Normal
- (access_list != NULL).if {
+ (access_list != NULL).if {
(access_list.lower).to (access_list.upper) do { j:INTEGER;
- e := access_list.item j.execute_link;
+ e := access_list.item j.execute_link;
access_list.put e to j;
};
};
@@ -164,18 +164,18 @@ Section Public
profil_main.set_external_present TRUE;
};
buffer.append "/* PERSISTANT */";
- };
-
+ };
+
(static_type.raw != TYPE_VOID).if {
buffer.append "((";
- static_type.genere_declaration buffer;
+ static_type.genere_declaration buffer;
buffer.add_last ' ';
- static_type.genere_star_declaration buffer;
- buffer.append ")(";
- } else {
+ static_type.genere_star_declaration buffer;
+ buffer.append ")(";
+ } else {
// buffer.append "if (";
- };
-
+ };
+
(access_list != NULL).if {
beg := code.lower;
idx := code.index_of '@' since beg;
@@ -184,7 +184,7 @@ Section Public
buffer.add_last (code.item k);
};
beg := idx + 1;
- access_list.item j.genere buffer;
+ access_list.item j.genere buffer;
idx := code.index_of '@' since beg;
};
// Copy end.
@@ -206,9 +206,9 @@ Section Public
//
- display buffer:STRING <-
- (
+ (
buffer.add_last '`';
- buffer.append code;
+ buffer.append code;
((access_list != NULL) && { ! access_list.is_empty}).if {
buffer.add_last '(';
access_list.lower.to (access_list.upper - 1) do { j:INTEGER;
@@ -217,12 +217,12 @@ Section Public
};
access_list.last.display buffer;
buffer.add_last ')';
- };
+ };
buffer.add_last '`';
static_type.append_name_in buffer;
(living_type != NULL).if {
- buffer.add_last '(';
- (living_type.lower).to (living_type.upper-1) do { j:INTEGER;
+ buffer.add_last '(';
+ (living_type.lower).to (living_type.upper-1) do { j:INTEGER;
buffer.append (living_type.item j.intern_name);
buffer.add_last ',';
};
@@ -231,7 +231,7 @@ Section Public
};
display_ref buffer;
);
-
+
diff --git a/src/external/forall_data.li b/src/external/forall_data.li
index e0ca3b8..ccbdad2 100644
--- a/src/external/forall_data.li
+++ b/src/external/forall_data.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := FORALL_DATA;
- copyright := "2003-2009 Sonntag Benoit";
@@ -30,13 +30,13 @@ Section Header
Section Inherit
+ parent_instr:Expanded INSTR;
-
+
Section Public
-
+
+ action:ITM_READ_ARG2;
-
+
+ list_data:FAST_ARRAY(COUPLE(SLOT_DATA,EXPR));
-
+
//
// Creation.
//
@@ -52,9 +52,9 @@ Section Public
( + lst:FAST_ARRAY(SLOT);
+ dta:SLOT_DATA;
+ c:COUPLE(SLOT_DATA,EXPR);
-
+
action := ITM_READ_ARG2.create (ac.position) name (ALIAS_STR.slot_value) args (,);
- list_data := FAST_ARRAY(COUPLE(SLOT_DATA,EXPR)).create;
+ list_data := FAST_ARRAY(COUPLE(SLOT_DATA,EXPR)).create;
t.add_reflexivity Self;
lst := t.slot_run;
(lst.lower).to (lst.upper) do { i:INTEGER;
@@ -65,51 +65,51 @@ Section Public
};
};
);
-
+
//
//
//
-
+
- my_copy:SELF <-
(
clone
);
-
+
//
- // Depend.
+ // Depend.
//
-
+
- add var:SLOT_DATA <-
(
-
+
);
-
+
//
// Execute.
//
-
- - execute:INSTR <-
+
+ - execute:INSTR <-
(
-
+
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
(list_data.lower).to (list_data.upper) do { i:INTEGER;
list_data.item i.second.genere buffer;
};
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
- (
+ (
buffer.append "Forall_data:\n";
indent.append " ";
(list_data.lower).to (list_data.upper) do { i:INTEGER;
@@ -120,6 +120,5 @@ Section Public
buffer.append indent;
list_data.item i.second.genere buffer;
};
- indent.remove_last 2;
+ indent.remove_last 2;
);
-
\ No newline at end of file
diff --git a/src/external/get_type_id.li b/src/external/get_type_id.li
index 6ce0975..efa2941 100644
--- a/src/external/get_type_id.li
+++ b/src/external/get_type_id.li
@@ -19,80 +19,80 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := GET_TYPE_ID;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Get intern ID object";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- TRUE;
-
+
+ receiver:TYPE_FULL;
-
+
- static_type:TYPE_FULL <- type_integer.default;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add type_integer;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION receiver e:TYPE_FULL :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p receiver e;
result
);
-
+
- make p:POSITION receiver e:TYPE_FULL <-
(
- position := p;
- receiver := e;
+ position := p;
+ receiver := e;
);
-
+
- my_copy:SELF <- SELF.create position receiver receiver;
// BSBS: Tu peux renvoyer Self ! Non ?
-
+
//
// Remove
//
-
+
- remove <-
(
// Nothing.
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- (
+ (
NULL
);
-
+
- execute_link:EXPR <-
- (
+ (
Self
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
(receiver.is_late_binding).if {
@@ -103,11 +103,11 @@ Section Public
buffer.append (ALIAS_STR.separate); // <=> "__";
};
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append "type_id(";
diff --git a/src/external/is_expanded.li b/src/external/is_expanded.li
index 3e258fb..a2e8217 100644
--- a/src/external/is_expanded.li
+++ b/src/external/is_expanded.li
@@ -19,101 +19,101 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := IS_EXPANDED;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "True, if `Self' is Expanded type.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- TRUE;
-
+
+ receiver:EXPR;
-
+
- static_type:TYPE_FULL <- type_boolean.default;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add type_true;
t.add type_false;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION receiver e:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p receiver e;
result
);
-
+
- make p:POSITION receiver e:EXPR <-
(
- position := p;
- receiver := e;
+ position := p;
+ receiver := e;
);
-
+
- my_copy:SELF <- SELF.create position receiver (receiver.my_copy);
-
+
//
// Remove
//
-
+
- remove <-
(
receiver.remove;
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- (
+ (
receiver.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ instr:INSTR;
-
+
(receiver.static_type.is_expanded).if {
result := PROTOTYPE_CST.create position type (type_true.default);
} else {
result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ };
instr := receiver.execute_unlink;
(instr != NULL).if {
- list_current.insert_before instr;
+ list_current.insert_before instr;
};
new_execute_pass;
result
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
crash_with_message "IS_EXPANDED.genere !";
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append "is_expanded(";
diff --git a/src/external/item.li b/src/external/item.li
index 78fa5ec..4a8941f 100644
--- a/src/external/item.li
+++ b/src/external/item.li
@@ -19,108 +19,108 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITEM;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Item for NATIVE_ARRAY[type].";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- receiver.is_invariant && {index.is_invariant};
-
+
+ receiver:EXPR;
-
+
+ index:EXPR;
-
- - static_type:TYPE_FULL <-
+
+ - static_type:TYPE_FULL <-
( + t:TYPE_GENERIC;
-
+
t ?= receiver.static_type.raw;
- t.generic_list.first
+ t.generic_list.first
);
-
+
- get_type t:TYPES_TMP <-
- ( + typ_gen:TYPE_GENERIC;
-
+ ( + typ_gen:TYPE_GENERIC;
+
typ_gen ?= receiver.static_type.raw;
- typ_gen.get_type t;
+ typ_gen.get_type t;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION base rec:EXPR index idx:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p base rec index idx;
result
);
-
+
- make p:POSITION base rec:EXPR index idx:EXPR <-
(
- position := p;
+ position := p;
receiver := rec;
index := idx;
);
-
+
- my_copy:SELF <- SELF.create position base (receiver.my_copy) index (index.my_copy);
-
+
//
// Remove
//
-
+
- remove <-
(
receiver.remove;
index.remove;
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- ( + instr:INSTR;
+ ( + instr:INSTR;
instr := receiver.execute_unlink;
(instr != NULL).if {
list_current.insert_before instr;
};
- index.execute_unlink
+ index.execute_unlink
);
-
+
- execute_link:EXPR <-
- (
+ (
receiver := receiver.execute_link;
- index := index.execute_link;
+ index := index.execute_link;
Self
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
- receiver.genere buffer;
+ receiver.genere buffer;
buffer.add_last '[';
index.genere buffer;
- buffer.add_last ']';
+ buffer.add_last ']';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
receiver.display buffer;
diff --git a/src/external/logic/expr_and_and_logic.li b/src/external/logic/expr_and_and_logic.li
index b9b0adb..f0044e9 100644
--- a/src/external/logic/expr_and_and_logic.li
+++ b/src/external/logic/expr_and_and_logic.li
@@ -19,49 +19,49 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_AND_AND_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "&& Binary logical expression.";
-
+
Section Inherit
-
+
+ parent_expr_and_logic:Expanded EXPR_AND_LOGIC;
-
+
Section Public
-
+
+ symbol:STRING_CONSTANT := "&&";
-
+
//
// Execute.
//
-
+
- execute_unlink:INSTR <-
- (
+ (
execute_link
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ left_cst,right_cst:PROTOTYPE_CST;
+ left_t,right_t:TYPE;
-
- old_seq := seq_call_and_loop;
- left := left.execute_link;
+
+ old_seq := seq_call_and_loop;
+ left := left.execute_link;
//
seq_or_and := seq_or_and + 1;
seq_inline := seq_inline + 1;
- //
- right := right.execute_link;
+ //
+ right := right.execute_link;
//
left_cst ?= left;
right_cst ?= right;
-
+
(left_cst != NULL).if { // BSBS : Peux faire mieux !!!
(left_cst.static_type.raw = type_true).if {
left_t := type_true;
@@ -76,24 +76,24 @@ Section Public
right_t := type_false;
};
};
-
+
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {left_cst != NULL}).if {
+ ((result = NULL) && {left_cst != NULL}).if {
result := exec_conservator_left left_t;
};
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_conservator_right right_t;
};
(
- (result = NULL) &&
- {right_cst != NULL} &&
+ (result = NULL) &&
+ {right_cst != NULL} &&
{left_cst != NULL}
).if {
result := exec left_t and right_t;
- };
- ((result = NULL) && {(old_seq + 1) = seq_call_and_loop}).if {
- // No conservator transformation.
+ };
+ ((result = NULL) && {(old_seq + 1) = seq_call_and_loop}).if {
+ // No conservator transformation.
result := exec;
((result = NULL) && {left_cst != NULL}).if {
result := exec_left left_t;
@@ -108,28 +108,28 @@ Section Public
} else {
new_execute_pass;
};
-
+
result
);
-
+
- exec_conservator:EXPR <-
//-- E && Var -> E & Var
( + rd:READ;
+ result:EXPR;
-
+
rd ?= right;
(rd != NULL).if {
result := EXPR_AND_LOGIC.create position with left and right;
};
result
);
-
+
//-- for && same &
-
+
- exec_conservator_left left_cst :TYPE :EXPR <-
//-- FALSE && E -> FALSE
( + result:EXPR;
-
+
result := parent_expr_and_logic.exec_conservator_left left_cst;
((result = NULL) && {left_cst = type_false}).if {
result := left;
@@ -137,7 +137,7 @@ Section Public
};
result
);
-
+
diff --git a/src/external/logic/expr_and_logic.li b/src/external/logic/expr_and_logic.li
index d6f1826..504c57c 100644
--- a/src/external/logic/expr_and_logic.li
+++ b/src/external/logic/expr_and_logic.li
@@ -19,53 +19,53 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_AND_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "And binary logical expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_logic:Expanded EXPR_BINARY_LOGIC;
-
-Section Public
-
+
+Section Public
+
+ symbol:STRING_CONSTANT := "&";
-
+
//
// Execute.
//
-
- - exec_conservator_left left_cst :TYPE :EXPR <-
+
+ - exec_conservator_left left_cst :TYPE :EXPR <-
//-- TRUE & E -> E
( + result:EXPR;
-
+
(left_cst = type_true).if {
result := right;
left.remove;
};
result
);
-
- - exec_conservator_right right_cst:TYPE :EXPR <-
+
+ - exec_conservator_right right_cst:TYPE :EXPR <-
//-- E & TRUE -> E
( + result:EXPR;
-
+
(right_cst = type_true).if {
result := left;
right.remove;
};
result
);
-
+
- exec left_cst:TYPE and right_cst:TYPE :EXPR <-
//-- C1 & C2 -> C3
( + result:EXPR;
-
+
(left_cst = type_true).if {
result := right;
left.remove;
@@ -75,33 +75,33 @@ Section Public
};
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- E & E -> E
( + result:EXPR;
-
+
(left ~= right).if {
result := left;
right.remove;
};
- result
+ result
);
- - exec_left left_cst :TYPE :EXPR <-
+ - exec_left left_cst :TYPE :EXPR <-
//-- FALSE & E -> FALSE
( + result:EXPR;
-
+
(left_cst = type_false).if {
result := left;
right.remove;
};
result
);
-
- - exec_right right_cst:TYPE :EXPR <-
+
+ - exec_right right_cst:TYPE :EXPR <-
//-- E & FALSE -> FALSE
( + result:EXPR;
-
+
(right_cst = type_false).if {
result := right;
left.remove;
@@ -109,16 +109,16 @@ Section Public
result
);
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
diff --git a/src/external/logic/expr_binary_logic.li b/src/external/logic/expr_binary_logic.li
index 02e98d9..a366546 100644
--- a/src/external/logic/expr_binary_logic.li
+++ b/src/external/logic/expr_binary_logic.li
@@ -19,109 +19,109 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_BINARY_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Binary logical expression.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- left.is_invariant && {right.is_invariant};
-
+
+ left:EXPR;
-
+
+ right:EXPR;
-
- - symbol:STRING_CONSTANT <-
+
+ - symbol:STRING_CONSTANT <-
(
deferred;
NULL
);
-
+
- static_type:TYPE_FULL <- type_boolean.default;
-
+
- get_type t:TYPES_TMP <-
- (
- t.add type_true;
+ (
+ t.add type_true;
t.add type_false;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with l:EXPR and r:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with l and r;
result
);
-
+
- make p:POSITION with l:EXPR and r:EXPR <-
(
position := p;
left := l;
right := r;
);
-
+
- my_copy:SELF <- SELF.create position with (left.my_copy) and (right.my_copy);
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + same:SELF;
-
+
same ?= other;
(same != NULL) && {left ~= same.left} && {right ~= same.right}
- );
-
+ );
+
//
// Remove
//
-
+
- remove <-
(
left .remove;
right.remove;
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- ( + instr:INSTR;
+ ( + instr:INSTR;
instr := left.execute_unlink;
(instr != NULL).if {
list_current.insert_before instr;
};
- right.execute_unlink
+ right.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ left_cst,right_cst:PROTOTYPE_CST;
+ left_t,right_t:TYPE;
-
- old_seq := seq_call_and_loop;
+
+ old_seq := seq_call_and_loop;
left := left .execute_link;
- right := right.execute_link;
+ right := right.execute_link;
//
left_cst ?= left;
right_cst ?= right;
-
+
(left_cst != NULL).if { // BSBS : Peux faire mieux !!!
(left_cst.static_type.raw = type_true).if {
left_t := type_true;
@@ -136,24 +136,24 @@ Section Public
right_t := type_false;
};
};
-
+
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {left_cst != NULL}).if {
+ ((result = NULL) && {left_cst != NULL}).if {
result := exec_conservator_left left_t;
};
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_conservator_right right_t;
};
(
- (result = NULL) &&
- {right_cst != NULL} &&
+ (result = NULL) &&
+ {right_cst != NULL} &&
{left_cst != NULL}
).if {
result := exec left_t and right_t;
- };
- ((result = NULL) && {old_seq = seq_call_and_loop}).if {
- // No conservator transformation.
+ };
+ ((result = NULL) && {old_seq = seq_call_and_loop}).if {
+ // No conservator transformation.
result := exec;
((result = NULL) && {left_cst != NULL}).if {
result := exec_left left_t;
@@ -169,27 +169,27 @@ Section Public
result.set_position position;
new_execute_pass;
};
-
+
result
);
-
- - exec_conservator:EXPR <- NULL;
+
+ - exec_conservator:EXPR <- NULL;
- exec_conservator_left left_cst :TYPE :EXPR <- NULL;
- exec_conservator_right right_cst:TYPE :EXPR <- NULL;
-
+
- exec left_cst:TYPE and right_cst:TYPE :EXPR <- NULL;
-
+
- exec:EXPR <- NULL;
- exec_left left_cst :TYPE :EXPR <- NULL;
- exec_right right_cst:TYPE :EXPR <- NULL;
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
- buffer.add_last '(';
+ buffer.add_last '(';
left.genere buffer;
buffer.add_last ' ';
buffer.append symbol;
@@ -197,14 +197,14 @@ Section Public
right.genere buffer;
buffer.add_last ')';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
- buffer.add_last '(';
+ buffer.add_last '(';
left.display buffer;
buffer.append symbol;
right.display buffer;
diff --git a/src/external/logic/expr_not_logic.li b/src/external/logic/expr_not_logic.li
index e3cbf10..893eb5b 100644
--- a/src/external/logic/expr_not_logic.li
+++ b/src/external/logic/expr_not_logic.li
@@ -19,28 +19,28 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_NOT_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Unary not logical expression.";
-
+
Section Inherit
-
+
+ parent_expr_unary_logic:Expanded EXPR_UNARY_LOGIC;
-
-Section Public
-
+
+Section Public
+
- symbol:CHARACTER <- '!';
-
+
//
// Execute.
//
-
- - exec_conservator:EXPR <-
+
+ - exec_conservator:EXPR <-
//-- ! (E1 == E2) -> E1 != E2 (see INTEGER)
//-- ! (E1 >= E2) -> E1 < E2 (see INTEGER)
//-- ! (E1 > E2) -> E1 <= E2 (see INTEGER)
@@ -49,12 +49,12 @@ Section Public
+ sup_eq:EXPR_SUP_EQ;
+ sup:EXPR_SUP;
+ not:EXPR_NOT_LOGIC;
- + result:EXPR;
+ + result:EXPR;
not ?= right;
(not != NULL).if {
result := not.right;
- }.elseif {
+ }.elseif {
eq ?= right;
eq != NULL
} then {
@@ -62,7 +62,7 @@ Section Public
}.elseif {
sup_eq ?= right;
sup_eq != NULL
- } then {
+ } then {
result := EXPR_INF.create position with (sup_eq.left) and (sup_eq.right);
}.elseif {
sup ?= right;
@@ -72,21 +72,21 @@ Section Public
};
result
);
-
- - exec_right right_cst:TYPE :EXPR <-
+
+ - exec_right right_cst:TYPE :EXPR <-
// ! TRUE -> FALSE
// ! FALSE -> TRUE
( + pro:PROTOTYPE_CST;
-
+
pro ?= right;
- (right_cst = type_true).if {
+ (right_cst = type_true).if {
pro.make (pro.position) type (type_false.default);
} else {
pro.make (pro.position) type (type_true.default);
};
right
);
-
+
diff --git a/src/external/logic/expr_or_logic.li b/src/external/logic/expr_or_logic.li
index 21db1ce..554aa13 100644
--- a/src/external/logic/expr_or_logic.li
+++ b/src/external/logic/expr_or_logic.li
@@ -19,39 +19,39 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_OR_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Or binary logical expression.";
-
+
Section Inherit
-
+
+ parent_expr_binary_logic:Expanded EXPR_BINARY_LOGIC;
-
-Section Public
-
+
+Section Public
+
+ symbol:STRING_CONSTANT := "|";
-
+
//
// Execute.
//
-
- - exec_conservator_left left_cst :TYPE :EXPR <-
+
+ - exec_conservator_left left_cst :TYPE :EXPR <-
//-- FALSE | E -> E
( + result:EXPR;
- (left_cst = type_false).if {
+ (left_cst = type_false).if {
result := right;
left.remove;
};
result
);
-
- - exec_conservator_right right_cst:TYPE :EXPR <-
+
+ - exec_conservator_right right_cst:TYPE :EXPR <-
//-- E | FALSE -> E
( + result:EXPR;
@@ -61,7 +61,7 @@ Section Public
};
result
);
-
+
- exec left_cst:TYPE and right_cst:TYPE :EXPR <-
//-- C1 | C2 -> C3
( + result:EXPR;
@@ -72,11 +72,11 @@ Section Public
} else {
result := right;
left.remove;
- };
+ };
result
);
-
- - exec:EXPR <-
+
+ - exec:EXPR <-
//-- (E1 > E2) | (E1 = E2) -> E1 >= E2 (a lot of possibilities, but see INTEGER)
//-- E | E -> E
( + result:EXPR;
@@ -96,10 +96,10 @@ Section Public
};
};
};
- result
+ result
);
- - exec_left left_cst :TYPE :EXPR <-
+ - exec_left left_cst :TYPE :EXPR <-
//-- TRUE | E -> TRUE
( + result:EXPR;
@@ -109,19 +109,19 @@ Section Public
};
result
);
-
- - exec_right right_cst:TYPE :EXPR <-
+
+ - exec_right right_cst:TYPE :EXPR <-
//-- E | TRUE -> TRUE
( + result:EXPR;
-
+
(right_cst = type_true).if {
result := right;
left.remove;
};
result
);
-
-
+
+
diff --git a/src/external/logic/expr_or_or_logic.li b/src/external/logic/expr_or_or_logic.li
index 8c4b798..8eeb3be 100644
--- a/src/external/logic/expr_or_or_logic.li
+++ b/src/external/logic/expr_or_or_logic.li
@@ -19,49 +19,49 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_OR_OR_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Or Binary Expression.";
-
+
Section Inherit
-
+
+ parent_expr_or_logic:Expanded EXPR_OR_LOGIC;
-
-Section Public
-
+
+Section Public
+
+ symbol:STRING_CONSTANT := "||";
-
+
//
// Execute.
//
-
+
- execute_unlink:INSTR <-
- (
+ (
execute_link
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ left_cst,right_cst:PROTOTYPE_CST;
+ left_t,right_t:TYPE;
-
- old_seq := seq_call_and_loop;
- left := left.execute_link;
+
+ old_seq := seq_call_and_loop;
+ left := left.execute_link;
//
seq_or_and := seq_or_and + 1;
seq_inline := seq_inline + 1;
//
- right := right.execute_link;
+ right := right.execute_link;
//
left_cst ?= left;
right_cst ?= right;
-
+
(left_cst != NULL).if { // BSBS : Peux faire mieux !!!
(left_cst.static_type.raw = type_true).if {
left_t := type_true;
@@ -79,21 +79,21 @@ Section Public
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {left_cst != NULL}).if {
+ ((result = NULL) && {left_cst != NULL}).if {
result := exec_conservator_left left_t;
};
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_conservator_right right_t;
};
(
- (result = NULL) &&
- {right_cst != NULL} &&
+ (result = NULL) &&
+ {right_cst != NULL} &&
{left_cst != NULL}
).if {
result := exec left_t and right_t;
- };
- ((result = NULL) && {(old_seq + 1) = seq_call_and_loop}).if {
- // No conservator transformation.
+ };
+ ((result = NULL) && {(old_seq + 1) = seq_call_and_loop}).if {
+ // No conservator transformation.
result := exec;
((result = NULL) && {left_cst != NULL}).if {
result := exec_left left_t;
@@ -108,24 +108,24 @@ Section Public
} else {
new_execute_pass;
};
-
+
result
);
-
+
- exec_conservator:EXPR <-
//-- E || Var -> E | Var
( + rd:READ;
+ result:EXPR;
-
+
rd ?= right;
(rd != NULL).if {
result := EXPR_OR_LOGIC.create position with left and right;
};
result
);
-
+
//-- for || same |
-
+
- exec_conservator_left left_cst :TYPE :EXPR <-
//-- TRUE || E -> TRUE
( + result:EXPR;
@@ -133,8 +133,7 @@ Section Public
((result = NULL) && {left_cst = type_true}).if {
result := left;
right.remove;
- };
+ };
result
);
-
-
\ No newline at end of file
+
diff --git a/src/external/logic/expr_unary_logic.li b/src/external/logic/expr_unary_logic.li
index 8b3e908..7684dbf 100644
--- a/src/external/logic/expr_unary_logic.li
+++ b/src/external/logic/expr_unary_logic.li
@@ -19,95 +19,95 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := EXPR_UNARY_LOGIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Unary logical expression.";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
+
+Section Public
+
- is_invariant:BOOLEAN <- right.is_invariant;
-
+
+ right:EXPR;
-
- - symbol:CHARACTER <-
+
+ - symbol:CHARACTER <-
(
deferred;
' '
);
-
+
- static_type:TYPE_FULL <- type_boolean.default;
-
+
- get_type t:TYPES_TMP <-
- (
- t.add type_true;
+ (
+ t.add type_true;
t.add type_false;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION with r:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p with r;
result
);
-
+
- make p:POSITION with r:EXPR <-
(
position := p;
right := r;
);
-
+
- my_copy:SELF <- SELF.create position with (right.my_copy);
-
+
//
// Comparaison.
//
-
+
- Self:SELF '~=' Right 60 other:EXPR :BOOLEAN <-
( + same:SELF;
-
+
same ?= other;
(same != NULL) && {right ~= same.right}
- );
-
+ );
+
- remove <-
- (
+ (
right.remove;
);
-
+
//
// Execute.
//
-
+
- execute_unlink:INSTR <-
(
right.execute_unlink
);
-
+
- execute_link:EXPR <-
( + result:EXPR;
+ old_seq:UINTEGER_32;
+ right_cst:PROTOTYPE_CST;
+ right_t:TYPE;
-
- old_seq := seq_call_and_loop;
- right := right.execute_link;
- //
+
+ old_seq := seq_call_and_loop;
+ right := right.execute_link;
+ //
right_cst ?= right;
- (right_cst != NULL).if {
+ (right_cst != NULL).if {
(right_cst.static_type.raw = type_true).if {
right_t := type_true;
} else {
@@ -117,12 +117,12 @@ Section Public
// Conservator transformation.
result := exec_conservator;
- ((result = NULL) && {right_cst != NULL}).if {
+ ((result = NULL) && {right_cst != NULL}).if {
result := exec_right right_t;
};
- ((result = NULL) && {old_seq = seq_call_and_loop}).if {
- // No conservator transformation.
- result := exec;
+ ((result = NULL) && {old_seq = seq_call_and_loop}).if {
+ // No conservator transformation.
+ result := exec;
};
//
(result = NULL).if {
@@ -131,20 +131,20 @@ Section Public
result.set_position position;
new_execute_pass;
};
-
+
result
);
-
- - exec_conservator:EXPR <- NULL;
-
+
+ - exec_conservator:EXPR <- NULL;
+
- exec_right right_cst:TYPE :EXPR <- NULL;
-
+
- exec:EXPR <- NULL;
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
(
buffer.add_last '(';
@@ -152,12 +152,12 @@ Section Public
buffer.add_last ' ';
right.genere buffer;
buffer.add_last ')';
- );
-
+ );
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.add_last '(';
diff --git a/src/external/put_to.li b/src/external/put_to.li
index 0baefaf..88d5d35 100644
--- a/src/external/put_to.li
+++ b/src/external/put_to.li
@@ -19,54 +19,54 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PUT_TO;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Put for NATIVE_ARRAY(E) (see ITEM)";
-
+
Section Inherit
-
- + parent_expr:Expanded EXPR; // BSBS: C'est une INSTR, mais pb dans ITM_EXTERNAL
-
-Section Public
-
- - is_invariant:BOOLEAN <-
- receiver.is_invariant && {index.is_invariant} && {value.is_invariant};
-
+
+ + parent_expr:Expanded EXPR; // BSBS: C'est une INSTR, mais pb dans ITM_EXTERNAL
+
+Section Public
+
+ - is_invariant:BOOLEAN <-
+ receiver.is_invariant && {index.is_invariant} && {value.is_invariant};
+
+ receiver:EXPR;
-
+
+ index:EXPR;
-
+
+ value:EXPR;
-
+
- static_type:TYPE_FULL <- TYPE_VOID.default;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add TYPE_VOID;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION base rec:EXPR index idx:EXPR value v:EXPR :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p base rec index idx value v;
result
);
-
+
- make p:POSITION base rec:EXPR index idx:EXPR value v:EXPR <-
( + type_generic:TYPE_GENERIC;
+ first_type:TYPE_FULL;
-
- position := p;
+
+ position := p;
receiver := rec;
index := idx;
value := v;
@@ -74,28 +74,28 @@ Section Public
type_generic ?= receiver.static_type.raw;
first_type := type_generic.generic_list.first;
(
- (! first_type.is_expanded) ||
+ (! first_type.is_expanded) ||
{first_type.raw = type_boolean}
).if {
type_generic.add_put_to Self;
};
);
-
- - my_copy:SELF <-
+
+ - my_copy:SELF <-
SELF.create position base (receiver.my_copy) index (index.my_copy) value (value.my_copy);
-
+
//
// Remove
//
-
+
- remove <-
( + type_generic:TYPE_GENERIC;
+ first_type:TYPE_FULL;
-
+
type_generic ?= receiver.static_type.raw;
first_type := type_generic.generic_list.first;
(
- (! first_type.is_expanded) ||
+ (! first_type.is_expanded) ||
{first_type.raw = type_boolean}
).if {
type_generic.remove_put_to Self;
@@ -103,38 +103,38 @@ Section Public
//
receiver.remove;
index.remove;
- value.remove;
+ value.remove;
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- (
+ (
execute_link
);
-
+
- execute_link:EXPR <-
- (
+ (
receiver := receiver.execute_link;
- index := index.execute_link;
+ index := index.execute_link;
value := value.execute_link;
Self
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
( + type_generic:TYPE_GENERIC;
+ first_type:TYPE_FULL;
-
+
receiver.genere buffer;
buffer.add_last '[';
index.genere buffer;
- buffer.append "]=";
+ buffer.append "]=";
type_generic ?= receiver.static_type.raw;
first_type := type_generic.generic_list.first;
((first_type.is_expanded) && {! first_type.is_expanded_c}).if {
@@ -143,17 +143,17 @@ Section Public
value.genere buffer;
buffer.add_last ')';
} else {
- value.genere buffer;
+ value.genere buffer;
};
} else {
value.genere buffer;
};
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
receiver.display buffer;
diff --git a/src/external/size_of.li b/src/external/size_of.li
index f875ef8..f7b77a8 100644
--- a/src/external/size_of.li
+++ b/src/external/size_of.li
@@ -19,91 +19,91 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SIZE_OF;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Size of object";
-
+
Section Inherit
-
+
+ parent_expr:Expanded EXPR;
-
-Section Public
-
- - is_invariant:BOOLEAN <- TRUE;
-
+
+Section Public
+
+ - is_invariant:BOOLEAN <- TRUE;
+
+ receiver:TYPE_FULL;
-
+
- static_type:TYPE_FULL <- type_integer.default;
-
+
- get_type t:TYPES_TMP <-
- (
+ (
t.add type_integer;
);
-
+
//
// Creation.
//
-
+
- create p:POSITION receiver e:TYPE_FULL :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p receiver e;
result
);
-
+
- make p:POSITION receiver e:TYPE_FULL <-
(
- position := p;
- receiver := e;
+ position := p;
+ receiver := e;
);
-
- - my_copy:SELF <- SELF.create position receiver receiver;
+
+ - my_copy:SELF <- SELF.create position receiver receiver;
// BSBS: Tu peux meme juste renvoyer Self! Non ?
-
+
//
// Remove
//
-
+
- remove <-
(
// Nothing.
);
-
+
//
// Execute
//
-
+
- execute_unlink:INSTR <-
- (
+ (
NULL
);
-
+
- execute_link:EXPR <-
- (
+ (
Self
);
-
+
//
// Genere.
//
-
+
- genere buffer:STRING <-
- (
- buffer.append "sizeof(";
+ (
+ buffer.append "sizeof(";
receiver.raw.put_expanded_declaration buffer;
- buffer.add_last ')';
+ buffer.add_last ')';
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append "size_of(";
diff --git a/src/item/itm_arg.li b/src/item/itm_arg.li
index fe206ac..28be22f 100644
--- a/src/item/itm_arg.li
+++ b/src/item/itm_arg.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_ARG;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "One argument";
-
+
Section Inherit
-
+
+ parent_itm_argument:Expanded ITM_ARGUMENT;
-
+
Section Public
+ name:STRING_CONSTANT;
-
+
+ type:ITM_TYPE_MONO;
-
+
- upper:INTEGER := 0;
-
+
//
// Creation.
//
-
+
- create p:POSITION name n:STRING_CONSTANT type t:ITM_TYPE_MONO :SELF <-
( + result:SELF;
-
+
result := SELF.clone;
result.make p name n type t;
result
@@ -58,27 +58,27 @@ Section Public
name := n;
type := t;
);
-
+
//
// Running.
//
-
- - item idx:INTEGER :ITM_TYPE_MONO <-
+
+ - item idx:INTEGER :ITM_TYPE_MONO <-
( ? {idx = 0};
type
- );
+ );
- to_run_in arg_lst:FAST_ARRAY(LOCAL) for p:PARAMETER_TO_TYPE <-
( + t:ITM_TYPE_MONO;
-
+
(name = ALIAS_STR.variable_self).if {
t := ITM_TYPE_SIMPLE.type_self;
} else {
t := type;
- };
+ };
arg_lst.add_last (
LOCAL.create position name name style ' ' type (t.to_run_for p)
- );
+ );
);
- get_index_type p:ITM_TYPE_PARAMETER :INTEGER <-
@@ -88,24 +88,24 @@ Section Public
};
result
);
-
+
- check larg:FAST_ARRAY(EXPR) index idx:INTEGER for p:PARAMETER_TO_TYPE :INTEGER <-
( + new_expr:EXPR;
-
+
new_expr := larg.item idx.check_type (type.to_run_for p) with position;
larg.put new_expr to idx;
idx + 1
- );
+ );
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append name;
buffer.add_last ':';
- type.append_in buffer;
+ type.append_in buffer;
);
- shorter_in buf:STRING <-
@@ -116,7 +116,7 @@ Section Public
put name to buf like (ALIAS_STR.short_local);
};
buf.add_last ':';
- type.shorter_in buf;
+ type.shorter_in buf;
);
-
-
+
+
diff --git a/src/item/itm_args.li b/src/item/itm_args.li
index ef06909..a5a1a6e 100644
--- a/src/item/itm_args.li
+++ b/src/item/itm_args.li
@@ -19,71 +19,71 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_ARGS;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "One argument vector";
-
+
Section Inherit
-
+
+ parent_itm_argument:Expanded ITM_ARGUMENT;
-
+
Section Public
+ name:FAST_ARRAY(STRING_CONSTANT);
-
+
+ type:ITM_TYPE_MULTI;
-
+
- upper:INTEGER <- name.upper;
-
+
//
// Creation.
//
-
- - create p:POSITION name n:FAST_ARRAY(STRING_CONSTANT)
+
+ - create p:POSITION name n:FAST_ARRAY(STRING_CONSTANT)
type t:ITM_TYPE_MULTI :SELF <-
( + result:SELF;
-
+
result := SELF.clone;
result.make p name n type t;
result
);
- - make p:POSITION name n:FAST_ARRAY(STRING_CONSTANT)
+ - make p:POSITION name n:FAST_ARRAY(STRING_CONSTANT)
type t:ITM_TYPE_MULTI <-
(
position := p;
name := n;
type := t;
);
-
+
//
// Running.
//
- - item idx:INTEGER :ITM_TYPE_MONO <-
+ - item idx:INTEGER :ITM_TYPE_MONO <-
( ? {idx.in_range 0 to upper};
type.item idx
);
-
+
- to_run_in arg_lst:FAST_ARRAY(LOCAL) for p:PARAMETER_TO_TYPE <-
( + t:TYPE_FULL;
-
+
(name.lower).to (name.upper) do { j:INTEGER;
- t := type.item j.to_run_for p;
+ t := type.item j.to_run_for p;
arg_lst.add_last (
LOCAL.create position name (name.item j) style ' ' type t
);
};
);
-
+
- get_index_type p:ITM_TYPE_PARAMETER :INTEGER <-
( + i:INTEGER;
-
+
i := name.lower;
{(i <= name.upper) && {type.item i != p}}.while_do {
i := i + 1;
@@ -93,22 +93,22 @@ Section Public
- check larg:FAST_ARRAY(EXPR) index idx:INTEGER for p:PARAMETER_TO_TYPE :INTEGER <-
( + new_expr:EXPR;
-
+
(type.lower).to (type.upper) do { i:INTEGER;
new_expr := larg.item (idx+i).check_type (type.item i.to_run_for p) with position;
larg.put new_expr to (idx+i);
};
idx + type.count
- );
-
+ );
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
- (
+ (
buffer.add_last '(';
- (name.lower).to (name.upper - 1) do { j:INTEGER;
+ (name.lower).to (name.upper - 1) do { j:INTEGER;
buffer.append (name.item j);
buffer.add_last ':';
type.item j.append_in buffer;
@@ -116,14 +116,14 @@ Section Public
};
buffer.append (name.last);
buffer.add_last ':';
- type.last.append_in buffer;
+ type.last.append_in buffer;
buffer.add_last ')';
);
-
+
- shorter_in buf:STRING <-
(
buf.add_last '(';
- (name.lower).to (name.upper - 1) do { j:INTEGER;
+ (name.lower).to (name.upper - 1) do { j:INTEGER;
(name.item j = ALIAS_STR.variable_self).if {
put (name.item j) to buf like (ALIAS_STR.short_keyword);
} else {
@@ -135,8 +135,8 @@ Section Public
};
put (name.last) to buf like (ALIAS_STR.short_local);
buf.add_last ':';
- type.last.shorter_in buf;
+ type.last.shorter_in buf;
buf.add_last ')';
);
-
+
diff --git a/src/item/itm_argument.li b/src/item/itm_argument.li
index f39fc13..d9be173 100644
--- a/src/item/itm_argument.li
+++ b/src/item/itm_argument.li
@@ -19,62 +19,62 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_ARGUMENT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent argument";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_OBJECT;
-
+
Section Public
-
+
- lower:INTEGER <- 0;
-
+
- upper:INTEGER <- ( deferred; 0);
-
+
- count:INTEGER <- upper + 1;
//
// Running.
//
-
- - item idx:INTEGER :ITM_TYPE_MONO <-
+
+ - item idx:INTEGER :ITM_TYPE_MONO <-
(
deferred;
NULL
);
-
+
- to_run_in arg_lst:FAST_ARRAY(LOCAL) for p:PARAMETER_TO_TYPE <-
(
deferred;
);
-
+
- get_index_type p:ITM_TYPE_PARAMETER :INTEGER <-
(
deferred;
);
-
+
- check larg:FAST_ARRAY(EXPR) index idx:INTEGER for p:PARAMETER_TO_TYPE :INTEGER <-
(
deferred;
0
);
-
+
//
// Comparaison.
//
-
- - is_equal other:ITM_ARGUMENT <-
+
+ - is_equal other:ITM_ARGUMENT <-
( + o:SELF;
+ err:STRING_CONSTANT;
? {other != Self};
-
+
o ?= other;
(o = NULL).if {
err := "Invariance number vector argument invalid.";
@@ -90,19 +90,19 @@ Section Public
POSITION.send_error;
};
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
deferred;
);
-
+
- shorter_in buf:STRING <-
(
deferred;
);
-
-
+
+
diff --git a/src/item/itm_binary.li b/src/item/itm_binary.li
index 5b6e120..2dba8f5 100644
--- a/src/item/itm_binary.li
+++ b/src/item/itm_binary.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_BINARY;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Binary operator message";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
//
@@ -46,17 +46,17 @@ Section Public
//
// Constructor
- //
+ //
- - create p:FAST_ARRAY(POSITION) values v:FAST_ARRAY(ITM_CODE)
+ - create p:FAST_ARRAY(POSITION) values v:FAST_ARRAY(ITM_CODE)
operators o:FAST_ARRAY(STRING_CONSTANT) :SELF <-
( + result:SELF;
result := clone;
result.make p values v operators o;
result
);
-
- - make p:FAST_ARRAY(POSITION) values v:FAST_ARRAY(ITM_CODE)
+
+ - make p:FAST_ARRAY(POSITION) values v:FAST_ARRAY(ITM_CODE)
operators o:FAST_ARRAY(STRING_CONSTANT) <-
(
? { p.count=o.count };
@@ -75,7 +75,7 @@ Section Public
+ max_pri :STRING_CONSTANT;
+ expr :INSTR;
+ val_list:FAST_ARRAY(EXPR);
- + val:EXPR;
+ + val:EXPR;
+ typ_list:TYPES_TMP;
+ typ:TYPE;
+ slo_list:FAST_ARRAY(SLOT);
@@ -99,14 +99,14 @@ Section Public
slo_list := ALIAS_ARRAY(SLOT).new;
// ITM_CODE -> EXPR
- (value_list.lower).to (value_list.upper) do { j:INTEGER;
- val := value_list.item j.to_run_expr;
+ (value_list.lower).to (value_list.upper) do { j:INTEGER;
+ val := value_list.item j.to_run_expr;
val_list.add_last val;
- typ := val.static_type.raw;
+ typ := val.static_type.raw;
typ_list.add typ;
};
-
- // Error verification.
+
+ // Error verification.
(operator_list.lower).to (operator_list.upper) do { j:INTEGER;
nam := operator_list.item j;
((nam = ALIAS_STR.operator_equal) || {nam = ALIAS_STR.operator_not_equal}).if {
@@ -127,13 +127,13 @@ Section Public
error_slot (position_list.item j) name nam in typ list typ_list;
} else {
(slo_ref.priority_and_level != slo.priority_and_level).if {
- position.put_error semantic text
+ position.put_error semantic text
"Conflicting declaration associativity or priority.";
slo_ref.position.put_position;
slo.position.put_position;
- position_list.item j.put_position;
+ position_list.item j.put_position;
position.send_error;
- };
+ };
};
};
};
@@ -158,11 +158,11 @@ Section Public
};
} else {
// Other:
- (
+ (
(slo.priority > max_lev) ||
{
- (slo.priority = max_lev) &&
- {slo.associativity = max_pri} &&
+ (slo.priority = max_lev) &&
+ {slo.associativity = max_pri} &&
{max_pri = ALIAS_STR.keyword_right}
}
).if {
@@ -180,20 +180,20 @@ Section Public
{slo_list.item (max_pos+1).associativity != max_pri}
).if {
warning_error ((pos_list.item max_pos),
- "Conflicting left/right priority.");
+ "Conflicting left/right priority.");
};
-
+
(slo_list.item max_pos = NULL).if {
// '=' or '!='.
(ope_list.item max_pos = ALIAS_STR.operator_equal).if {
- extern := EXPR_EQUAL.create (pos_list.item max_pos) with
+ extern := EXPR_EQUAL.create (pos_list.item max_pos) with
(val_list.item max_pos) and (val_list.item (max_pos+1));
} else {
- extern := EXPR_NOT_EQUAL.create (pos_list.item max_pos) with
+ extern := EXPR_NOT_EQUAL.create (pos_list.item max_pos) with
(val_list.item max_pos) and (val_list.item (max_pos+1));
- };
+ };
loc := type_boolean.default.get_temporary (pos_list.item max_pos);
- expr := loc.write (pos_list.item max_pos) value extern;
+ expr := loc.write (pos_list.item max_pos) value extern;
list_current.add_last expr;
val := loc.read (pos_list.item max_pos);
} else {
@@ -201,42 +201,42 @@ Section Public
l_arg := FAST_ARRAY(EXPR).create_with_capacity 2;
l_arg.add_last (val_list.item max_pos);
l_arg.add_last (val_list.item (max_pos + 1));
-
- site := NODE.new_read (pos_list.item max_pos)
+
+ site := NODE.new_read (pos_list.item max_pos)
slot (slo_list.item max_pos)
receiver (l_arg.first.my_copy)
- with l_arg;
-
+ with l_arg;
+
list_current.add_last site;
val := site.result_expr;
};
-
+
// Delete operator.
- slo_list.remove max_pos;
- ope_list.remove max_pos;
- pos_list.remove max_pos;
+ slo_list.remove max_pos;
+ ope_list.remove max_pos;
+ pos_list.remove max_pos;
val_list.remove (max_pos+1);
//
- val_list.put val to max_pos;
+ val_list.put val to max_pos;
};
result := val_list.first;
-
+
// Free Array Temporary.
- ALIAS_ARRAY(STRING_CONSTANT).free ope_list;
- ALIAS_ARRAY(POSITION).free pos_list;
+ ALIAS_ARRAY(STRING_CONSTANT).free ope_list;
+ ALIAS_ARRAY(POSITION).free pos_list;
ALIAS_ARRAY(EXPR).free val_list;
typ_list.free;
ALIAS_ARRAY(SLOT).free slo_list;
-
+
result
);
-
-Section Private
-
+
+Section Private
+
- error_slot p:POSITION name s:STRING_CONSTANT in t:TYPE list st:TYPES_TMP <-
(
- string_tmp.copy "Slot '";
+ string_tmp.copy "Slot '";
string_tmp.append s;
string_tmp.append "' not found in ";
string_tmp.append (t.name);
diff --git a/src/item/itm_block.li b/src/item/itm_block.li
index a1342c5..e8c9057 100644
--- a/src/item/itm_block.li
+++ b/src/item/itm_block.li
@@ -19,65 +19,65 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_BLOCK;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Instruction block";
-
+
// BSBS: Memory : Faire la version sans argument (très courant)
-
+
Section Inherit
-
+
- parent_itm_code:ITM_CODE := ITM_CODE;
-
+
Section Public
-
+
- position:POSITION <- list.position;
-
+
+ list:ITM_LIST;
-
+
+ argument:ITM_ARGUMENT;
-
+
//
// Creation.
//
-
+
- create lst:ITM_LIST argument arg:ITM_ARGUMENT :SELF <-
( + result:SELF;
-
+
result := clone;
result.make lst argument arg;
result
);
-
+
- make lst:ITM_LIST argument arg:ITM_ARGUMENT <-
(
list := lst;
argument := arg;
);
-
+
//
// Runnable.
//
-
+
- to_run_expr:EXPR <-
- ( + tb:PROFIL_BLOCK;
- + t:TYPE_FULL;
- + loc,my_self:LOCAL;
+ ( + tb:PROFIL_BLOCK;
+ + t:TYPE_FULL;
+ + loc,my_self:LOCAL;
+ val,rec:EXPR;
+ wrt:WRITE;
-
+
tb := PROFIL_BLOCK.create Self;
t := tb.default;
//
- loc := t.get_temporary position;
+ loc := t.get_temporary position;
// tmp.id := id_block;
rec := loc.read position;
- val := PROTOTYPE_CST.create position type t;
+ val := PROTOTYPE_CST.create position type t;
wrt := tb.slot_value.write position with rec value val;
list_current.add_last wrt;
// tmp.self := Self;
@@ -89,13 +89,13 @@ Section Public
// tmp
loc.read position
);
-
- //
+
+ //
// Display.
//
-
+
- print <-
(
"{BLOCK}".print;
);
-
+
diff --git a/src/item/itm_character.li b/src/item/itm_character.li
index 95e98fe..9c6c314 100644
--- a/src/item/itm_character.li
+++ b/src/item/itm_character.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_CHARACTER;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Character constant";
-
+
Section Inherit
-
+
+ parent_itm_constant:Expanded ITM_CONSTANT;
-
+
Section Public
//
@@ -50,7 +50,7 @@ Section Public
result.make p char n;
result
);
-
+
- make p:POSITION char n:STRING_CONSTANT <-
(
position:=p;
@@ -62,14 +62,14 @@ Section Public
//
- to_run_expr:EXPR <-
- (
- CHARACTER_CST.create position char character
+ (
+ CHARACTER_CST.create position char character
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.add_last '\'';
diff --git a/src/item/itm_code.li b/src/item/itm_code.li
index 5c92dc4..579366c 100644
--- a/src/item/itm_code.li
+++ b/src/item/itm_code.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_CODE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all item code";
-
+
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
-
+
Section Public
-
- // Use by PARSER, for left expr assignment ( in EXPR1 := EXPR2, EXPR1.is_affect).
+
+ // Use by PARSER, for left expr assignment ( in EXPR1 := EXPR2, EXPR1.is_affect).
- is_affect:POSITION <- position;
-
+
//
// Flags.
//
@@ -45,32 +45,32 @@ Section Public
//
// Runnable.
- //
-
+ //
+
- to_run:INSTR <-
(
to_run_expr
);
-
+
- to_run_expr:EXPR <-
- (
+ (
warning_error (position,"Error: ITM_CODE.to_run");
deferred;
NULL
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
"ITM_CODE : Type:".print;
- type_id_intern.print;
+ type_id_intern.print;
'\n'.print;
deferred;
);
-
+
- print <-
(
string_tmp.clear;
diff --git a/src/item/itm_constant.li b/src/item/itm_constant.li
index cd48718..856123d 100644
--- a/src/item/itm_constant.li
+++ b/src/item/itm_constant.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_CONSTANT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all constant";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
- is_constant:BOOLEAN := TRUE;
diff --git a/src/item/itm_expression.li b/src/item/itm_expression.li
index 8b4adb6..8bf9ad8 100644
--- a/src/item/itm_expression.li
+++ b/src/item/itm_expression.li
@@ -90,7 +90,7 @@ Section Public
{
idx := idx + 1;
itm_op ?= value_list.item idx;
- }.do_while {(itm_op != NULL) && {idx != value_list.upper}};
+ }.do_while {(itm_op != NULL) && {idx != value_list.upper}};
(itm_op != NULL).if {
semantic_error (itm_op.position,"Operator postfix not found.");
};
@@ -99,7 +99,7 @@ Section Public
(typ = TYPE_VOID).if {
semantic_error (val.position,"Expression type `Void'.");
};
- // Post-fix.
+ // Post-fix.
idx_post := idx + 1;
continue := TRUE;
{(idx_post <= value_list.upper) && {continue}}.while_do {
@@ -110,7 +110,7 @@ Section Public
((idx_post = value_list.upper) || {itm_op != NULL}).if {
itm_op ?= value_list.item idx_post;
slo := typ.get_slot (operator (ALIAS_STR.slot_postfix) name (itm_op.name));
- (slo != NULL).if {
+ (slo != NULL).if {
site := NODE.new_read (itm_op.position) slot slo receiver val self val intern FALSE;
list_current.add_last site;
val := site.result_expr;
@@ -130,12 +130,12 @@ Section Public
((idx_pre = low) || {itm_op != NULL}).if {
itm_op ?= value_list.item idx_pre;
slo := typ.get_slot (operator (ALIAS_STR.slot_prefix) name (itm_op.name));
- (slo = NULL).if {
+ (slo = NULL).if {
error_slot (itm_op.position) name "prefix" operator (itm_op.name) in typ;
};
site := NODE.new_read (itm_op.position) slot slo receiver val self val intern FALSE;
list_current.add_last site;
- val := site.result_expr;
+ val := site.result_expr;
idx_pre := idx_pre - 1;
continue := TRUE;
};
@@ -182,7 +182,7 @@ Section Public
max_pri := ALIAS_STR.keyword_right;
max_pos := j;
};
- } else {
+ } else {
// Other:
slo := site.data.slot;
(
@@ -205,8 +205,8 @@ Section Public
right ?= val_list.item (max_pos + 1);
(n_t = NULL).if {
// '=' or '!='.
- extern ?= val_list.item max_pos;
- extern.set_left left and_right right;
+ extern ?= val_list.item max_pos;
+ extern.set_left left and_right right;
loc := type_boolean.default.get_temporary (extern.position);
instr:= loc.write (extern.position) value extern;
list_current.add_last instr;
diff --git a/src/item/itm_extern.li b/src/item/itm_extern.li
index a1beeae..0558ebf 100644
--- a/src/item/itm_extern.li
+++ b/src/item/itm_extern.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_EXTERN;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for externals";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
//
@@ -40,19 +40,19 @@ Section Public
+ extern:STRING_CONSTANT;
- //
+ //
// Constructor.
//
-
+
- last_code:STRING_CONSTANT;
-
+
- get_access:FAST_ARRAY(EXPR) <-
( + idx,base:INTEGER;
+ e:EXPR;
+ loc:STRING_CONSTANT;
+ var:VARIABLE;
+ access_list:FAST_ARRAY(EXPR);
-
+
string_tmp2.copy extern;
idx := string_tmp2.index_of '@' since (string_tmp2.lower);
(idx <= string_tmp2.count).if {
@@ -60,9 +60,9 @@ Section Public
{idx > string_tmp2.upper}.until_do {
base := idx;
idx := idx + 1;
- string_tmp.clear;
+ string_tmp.clear;
{
- (idx > string_tmp2.upper) ||
+ (idx > string_tmp2.upper) ||
{
(! string_tmp2.item idx.is_letter_or_digit) &&
{string_tmp2.item idx != '_'}
@@ -89,7 +89,7 @@ Section Public
};
e := var.read position;
access_list.add_last e;
-
+
string_tmp2.remove_between base to (base+loc.count);
string_tmp2.insert_string "(@)" to base;
idx := string_tmp2.index_of '@' since (base+2);
@@ -99,11 +99,11 @@ Section Public
last_code := ALIAS_STR.get string_tmp2;
access_list
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.add_last '`';
diff --git a/src/item/itm_external.li b/src/item/itm_external.li
index e67770b..30f41b7 100644
--- a/src/item/itm_external.li
+++ b/src/item/itm_external.li
@@ -73,7 +73,7 @@ Section Public
exp1 := profil_slot.argument_list.first.read position;
result := IS_EXPANDED.create position receiver exp1;
}
- .when 1 then { // type_id_intern:INTEGER
+ .when 1 then { // type_id_intern:INTEGER
result := GET_TYPE_ID.create position receiver
(profil_slot.argument_list.first.type);
}
@@ -85,32 +85,32 @@ Section Public
.when 3 then { // INTEGER - INTEGER -> INTEGER.
left := profil_slot.argument_list.first .read position;
right := profil_slot.argument_list.item 1.read position;
- result := EXPR_SUB.create position with left and right;
+ result := EXPR_SUB.create position with left and right;
}
.when 4 then { // INTEGER * INTEGER -> INTEGER.
left := profil_slot.argument_list.first .read position;
right := profil_slot.argument_list.item 1.read position;
- result := EXPR_MUL.create position with left and right;
+ result := EXPR_MUL.create position with left and right;
}
- .when 5 then { // INTEGER / INTEGER -> INTEGER.
+ .when 5 then { // INTEGER / INTEGER -> INTEGER.
left := profil_slot.argument_list.first .read position;
right := profil_slot.argument_list.item 1.read position;
- result := EXPR_DIV.create position with left and right;
+ result := EXPR_DIV.create position with left and right;
}
.when 6 then { // INTEGER & INTEGER -> INTEGER.
left := profil_slot.argument_list.first .read position;
right := profil_slot.argument_list.item 1.read position;
- result := EXPR_AND.create position with left and right;
+ result := EXPR_AND.create position with left and right;
}
.when 7 then { // INTEGER >> INTEGER -> INTEGER.
left := profil_slot.argument_list.first .read position;
right := profil_slot.argument_list.item 1.read position;
- result := EXPR_SHIFT_R.create position with left and right;
+ result := EXPR_SHIFT_R.create position with left and right;
}
.when 8 then { // INTEGER << INTEGER -> INTEGER.
left := profil_slot.argument_list.first .read position;
right := profil_slot.argument_list.item 1.read position;
- result := EXPR_SHIFT_L.create position with left and right;
+ result := EXPR_SHIFT_L.create position with left and right;
}
.when 9 then { // put OBJECT to INTEGER.
exp1 := profil_slot.argument_list.first .read position;
@@ -126,7 +126,7 @@ Section Public
.when 11 then { // debug_level -> INTEGER.
result := INTEGER_CST.create position value debug_level_option type (type_integer.default);
}
- .when 12 then { // object_size -> INTEGER.
+ .when 12 then { // object_size -> INTEGER.
result := SIZE_OF.create position receiver
(profil_slot.argument_list.first.type);
}
@@ -146,9 +146,9 @@ Section Public
.when 15 then { // is_cop_type:BOOLEAN
type := profil_slot.argument_list.first.type;
(type.prototype.style = '-').if {
- result := PROTOTYPE_CST.create position type (type_true.default);
+ result := PROTOTYPE_CST.create position type (type_true.default);
} else {
- result := PROTOTYPE_CST.create position type (type_false.default);
+ result := PROTOTYPE_CST.create position type (type_false.default);
};
}
.when 16 then { // LIST.upper:INTEGER
@@ -162,10 +162,10 @@ Section Public
}
.when 19 then { // compiler_optimization -> BOOLEAN.
(is_optimization).if {
- result := PROTOTYPE_CST.create position type (type_true.default);
+ result := PROTOTYPE_CST.create position type (type_true.default);
} else {
- result := PROTOTYPE_CST.create position type (type_false.default);
- };
+ result := PROTOTYPE_CST.create position type (type_false.default);
+ };
}
.when 20 then { // compiler_built_on -> STRING_CONSTANT.
string_tmp.clear;
diff --git a/src/item/itm_external_type.li b/src/item/itm_external_type.li
index 07880a7..58c2e25 100644
--- a/src/item/itm_external_type.li
+++ b/src/item/itm_external_type.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_EXTERNAL_TYPE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "External C with type result";
-
+
Section Inherit
-
+
+ parent_itm_extern:Expanded ITM_EXTERN;
-
+
Section Public
//
@@ -47,21 +47,21 @@ Section Public
//
// Constructor
//
-
+
- create p:POSITION text n:STRING_CONSTANT persistant per:BOOLEAN :SELF <-
( + result:SELF;
result := clone;
result.make p text n persistant per;
result
);
-
+
- make p:POSITION text n:STRING_CONSTANT persistant per:BOOLEAN <-
(
position := p;
extern := n;
is_persistant := per;
);
-
+
//
// Added
//
@@ -79,23 +79,23 @@ Section Public
//
// Runnable
//
-
- - to_run_expr:EXPR <-
+
+ - to_run_expr:EXPR <-
( + e:EXTERNAL_C;
+ lt:TYPES_TMP;
+ lst_acc:FAST_ARRAY(EXPR);
+ typ:TYPE;
- + tmp:VARIABLE;
+ + tmp:VARIABLE;
lst_acc := get_access;
last_position := position;
- e := EXTERNAL_C.create position text last_code
+ e := EXTERNAL_C.create position text last_code
access lst_acc persistant is_persistant type (type.to_run_for profil_slot);
-
+
(type_list != NULL).if {
lt := TYPES_TMP.new;
(type_list.lower).to (type_list.upper) do { j:INTEGER;
- typ := type_list.item j.to_run_for profil_slot.raw;
+ typ := type_list.item j.to_run_for profil_slot.raw;
lt.add typ;
};
e.set_living_type (lt.to_types);
diff --git a/src/item/itm_ldots.li b/src/item/itm_ldots.li
index 4427dcb..2e8dad5 100644
--- a/src/item/itm_ldots.li
+++ b/src/item/itm_ldots.li
@@ -19,37 +19,37 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_LDOTS;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "`...' for inherit contract";
-
+
Section Inherit
-
+
+ parent_itm_constant:Expanded ITM_CODE;
-
+
Section Public
//
// Constructor
//
-
+
- create p:POSITION :SELF <-
( + result:SELF;
result := clone;
result.make p;
result
);
-
+
- make p:POSITION <-
(
position := p;
);
-
+
//
// Runnable
//
@@ -58,7 +58,7 @@ Section Public
( + contract:ITM_LIST;
+ result:INSTR;
+ slot_code:SLOT_CODE;
-
+
slot_code ?= profil_slot.slot;
contract := slot_code.previous_contract;
(contract != NULL).if {
@@ -68,7 +68,7 @@ Section Public
};
result
);
-
+
- to_run_expr:EXPR <-
(
warning_error (position,"ITM_LDOTS.to_run_expr");
@@ -79,9 +79,8 @@ Section Public
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append "...";
);
-
\ No newline at end of file
diff --git a/src/item/itm_list.li b/src/item/itm_list.li
index f534a9d..6302b18 100644
--- a/src/item/itm_list.li
+++ b/src/item/itm_list.li
@@ -19,38 +19,38 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_LIST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Instruction list";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
-
+
// BSBS: OPTIM : Dans 95% des cas, les list sont sans local (il faudrait spécialiser)
// Mais pb avec le parser...
-
+
//
// Data
//
+ local_list:FAST_ARRAY(ITM_LOCAL); // `+'
-
+
+ static_list:FAST_ARRAY(ITM_LOCAL); // `-'
+ code:FAST_ARRAY(ITM_CODE);
-
+
+ is_check_name:BOOLEAN;
-
+
- is_check_local:INTEGER;
-
+
//
// Constructor
//
@@ -61,12 +61,12 @@ Section Public
result.make p;
result
);
-
+
- make p:POSITION <-
(
- position := p;
+ position := p;
);
-
+
//
// Added
//
@@ -82,19 +82,19 @@ Section Public
? {! l.is_empty};
static_list := l;
);
-
+
- set_code c:FAST_ARRAY(ITM_CODE) <-
(
code := c;
- );
-
+ );
+
Section Public
-
+
- is_affect:POSITION <-
( + result,default:POSITION;
+ j:INTEGER;
+ itm_r:ITM_RESULT;
-
+
j := code.lower;
{(j < code.upper) && {result = default}}.while_do {
itm_r ?= code.item j;
@@ -110,49 +110,49 @@ Section Public
};
result
);
-
+
//
// Runnable.
//
-
- - to_run_expr:EXPR <-
+
+ - to_run_expr:EXPR <-
// List intern.
( + i:INSTR;
- + var:LOCAL;
+ + var:LOCAL;
+ stack_top:INTEGER;
+ result_top:INTEGER;
+ result:EXPR;
+ nb_result:INTEGER;
+ lr:FAST_ARRAY(EXPR);
-
+
stack_top := stack_local .upper + 1;
result_top := stack_result.upper + 1;
-
+
// Push Local.
- (local_list != NULL).if {
+ (local_list != NULL).if {
(local_list.lower).to (local_list.upper) do { j:INTEGER;
var := local_list.item j.to_run;
stack_local.add_last var;
- var.init;
- };
+ var.init;
+ };
};
- (static_list != NULL).if {
+ (static_list != NULL).if {
(static_list.lower).to (static_list.upper) do { j:INTEGER;
var := static_list.item j.to_run_static;
- stack_local.add_last var;
- };
- };
+ stack_local.add_last var;
+ };
+ };
// Append code.
(code.lower).to (code.upper) do { j:INTEGER;
- i := code.item j.to_run;
+ i := code.item j.to_run;
list_current.add_last i;
- };
- // Compute result expr.
- nb_result := stack_result.upper - result_top + 1;
-
- (nb_result = 0).if {
- result := PROTOTYPE_CST.create position type (TYPE_VOID.default); // BSBS: Alias.
- } else {
+ };
+ // Compute result expr.
+ nb_result := stack_result.upper - result_top + 1;
+
+ (nb_result = 0).if {
+ result := PROTOTYPE_CST.create position type (TYPE_VOID.default); // BSBS: Alias.
+ } else {
(nb_result > 1).if {
// Creation Vector.
lr := FAST_ARRAY(EXPR).create_with_capacity nb_result;
@@ -163,40 +163,40 @@ Section Public
} else {
result := stack_result.last.read position;
};
- };
+ };
// Pop local / Result.
- pop_stack_until stack_top;
+ pop_stack_until stack_top;
stack_result.remove_since result_top;
? {stack_result.upper = Old stack_result.upper};
- //
+ //
result
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
(code.count = 1).if {
buffer.add_last '(';
code.first.append_in buffer;
- buffer.add_last ')';
+ buffer.add_last ')';
} else {
- buffer.append "(\n";
+ buffer.append "(\n";
(code.lower).to (code.upper) do { i:INTEGER;
indent.append " ";
code.item i.append_in buffer;
buffer.append ";\n";
};
indent.remove_last 2;
- buffer.append ")";
- };
+ buffer.append ")";
+ };
);
-
+
Section ITM_LIST, ITM_RESULT
-
- - stack_result:FAST_ARRAY(LOCAL) := FAST_ARRAY(LOCAL).create_with_capacity 16;
+
+ - stack_result:FAST_ARRAY(LOCAL) := FAST_ARRAY(LOCAL).create_with_capacity 16;
diff --git a/src/item/itm_list_idf.li b/src/item/itm_list_idf.li
index 9885897..35e8c35 100644
--- a/src/item/itm_list_idf.li
+++ b/src/item/itm_list_idf.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_LIST_IDF;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "List identifier for assignment.";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
-Section Public
-
+
+Section Public
+
- is_affect:POSITION; // Nothing (it s good with 0).
// BSBS: A quoi ca sert ca ??? (Stop the Whisky)
-
+
//
// Data
//
@@ -53,7 +53,7 @@ Section Public
result.make p with lst;
result
);
-
+
- make p:POSITION with lst:FAST_ARRAY(STRING_CONSTANT) <-
(
position := p;
@@ -63,11 +63,10 @@ Section Public
//
// Runnable
//
-
+
- to_run_expr:EXPR <-
- (
+ (
semantic_error (position,"ITM_LIST_IDF.to_run_expr");
NULL
);
-
-
\ No newline at end of file
+
diff --git a/src/item/itm_local.li b/src/item/itm_local.li
index 63224e2..54cdbb3 100644
--- a/src/item/itm_local.li
+++ b/src/item/itm_local.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_LOCAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Local declaration slot";
-
+
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
-
+
Section Public
//
@@ -60,7 +60,7 @@ Section Public
result.set_type t;
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT <-
(
name := n;
@@ -80,10 +80,10 @@ Section Public
// Runnable
//
- - to_run:LOCAL <-
+ - to_run:LOCAL <-
( + pos:POSITION;
+ result:LOCAL;
-
+
last_position := position;
result := LOCAL.create position name name style '+' type (type.to_run_for profil_slot);
last_position := pos;
@@ -97,11 +97,11 @@ Section Public
+ larg:FAST_ARRAY(ITM_ARGUMENT);
+ arg:ITM_ARGUMENT;
+ proto:PROTOTYPE;
-
+
(type = ITM_TYPE_SIMPLE.type_self).if {
semantic_error (position,"Type `SELF' is not possible for `-' style local.");
};
- result := LOCAL.create position name name style '-' type (type.to_run_for profil_slot);
+ result := LOCAL.create position name name style '-' type (type.to_run_for profil_slot);
//
proto := position.prototype;
slot := proto.first_slot;
@@ -109,7 +109,7 @@ Section Public
slot := slot.next;
};
(slot = NULL).if {
- slot := ITM_SLOT.create position name (result.intern_name)
+ slot := ITM_SLOT.create position name (result.intern_name)
feature (SECTION_.get_name (ALIAS_STR.section_private));
slot.set_style '-';
slot.set_result_type type;
@@ -118,7 +118,7 @@ Section Public
type (ITM_TYPE_SIMPLE.type_self);
larg.add_last arg;
larg := ALIAS_ARRAY(ITM_ARGUMENT).copy larg;
- slot.set_argument_list larg;
+ slot.set_argument_list larg;
proto.add_slot slot;
} else {
result.set_intern_name (slot.name);
@@ -126,18 +126,18 @@ Section Public
//
result
);
-
- //
+
+ //
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append name;
buffer.add_last ':';
type.append_in buffer;
);
-
+
diff --git a/src/item/itm_number.li b/src/item/itm_number.li
index a54a89b..2cee426 100644
--- a/src/item/itm_number.li
+++ b/src/item/itm_number.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_NUMBER;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Integer constant";
-
+
Section Inherit
-
+
+ parent_itm_constant:Expanded ITM_CONSTANT;
-
+
Section Public
//
@@ -49,29 +49,29 @@ Section Public
result.make p value n;
result
);
-
+
- make p:POSITION value n:INTEGER_64 <-
(
position:=p;
value:=n;
);
-
+
//
// Runnable
//
- to_run_expr:EXPR <-
- (
- INTEGER_CST.create position value value type (type_integer.default)
+ (
+ INTEGER_CST.create position value value type (type_integer.default)
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
value.append_in buffer;
);
-
+
diff --git a/src/item/itm_object.li b/src/item/itm_object.li
index 5f07b3e..837c296 100644
--- a/src/item/itm_object.li
+++ b/src/item/itm_object.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_OBJECT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent item object";
-
+
Section Inherit
-
+
+ parent_any:Expanded ANY;
-
+
- parent_hashable:HASHABLE := HASHABLE;
-
+
Section Public
-
+
- context_extern:LOCAL;
-
+
- bottom_index:INTEGER;
-
+
- push_context:(INTEGER,INTEGER,LOCAL) <-
(
bottom_index := stack_local.upper + 1;
context_extern := NULL;
bottom_index,Old bottom_index,Old context_extern
- );
-
+ );
+
- pop_context (stack_top:INTEGER,old_bottom_index:INTEGER,old_context:LOCAL) <-
(
stack_local.remove_since stack_top;
@@ -55,25 +55,25 @@ Section Public
context_extern := old_context;
};
);
-
+
- lookup n:STRING_CONSTANT :LOCAL <-
( + result:LOCAL;
+ j:INTEGER;
? {n = ALIAS_STR.get n};
-
+
j := stack_local.upper;
- {(j < stack_local.lower) || {stack_local.item j.name = n}}.until_do {
+ {(j < stack_local.lower) || {stack_local.item j.name = n}}.until_do {
j := j - 1;
};
- (j >= stack_local.lower).if {
- result := stack_local.item j;
+ (j >= stack_local.lower).if {
+ result := stack_local.item j;
((j < bottom_index) && {result.style != '-'} && {result.name != ALIAS_STR.variable_self}).if {
bottom_index := j;
context_extern := result;
};
}.elseif {profil_slot != NULL} then {
- result := profil_slot.lookup n;
+ result := profil_slot.lookup n;
((result != NULL) && {result.name != ALIAS_STR.variable_self}).if {
bottom_index := -1;
context_extern := result;
@@ -81,7 +81,7 @@ Section Public
};
result
);
-
+
//
// Source position.
//
@@ -92,30 +92,30 @@ Section Public
(
position := new_pos;
);
-
+
//
//
//
-
+
- verify:BOOLEAN;
-
+
- set_verify v:BOOLEAN <-
(
verify := v;
);
-
+
- pop_stack_until stack_top:INTEGER <-
( + var,var2:LOCAL;
+ n:STRING_CONSTANT;
-
+
(verify).if {
- // Verify local.
+ // Verify local.
{stack_local.upper >= stack_top}.while_do {
var := stack_local.last;
stack_local.remove_last;
n := var.name;
(
- (n != ALIAS_STR.variable_self) &&
+ (n != ALIAS_STR.variable_self) &&
{n != ALIAS_STR.variable_tmp}
).if {
((var.ensure_count = 0) && {var.style != ' '}).if {
diff --git a/src/item/itm_old.li b/src/item/itm_old.li
index 6163151..039076b 100644
--- a/src/item/itm_old.li
+++ b/src/item/itm_old.li
@@ -19,44 +19,44 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_OLD;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Old primitive for contract";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
-
+
+ value:ITM_CODE;
-
+
//
// Constructor
//
-
+
- create p:POSITION value val:ITM_CODE :SELF <-
( + result:SELF;
result := clone;
result.make p value val;
result
);
-
+
- make p:POSITION value val:ITM_CODE <-
(
position := p;
value := val;
);
-
+
//
// Runnable
//
-
+
- to_run_expr:EXPR <-
( + expr_old:EXPR;
+ instr:INSTR;
@@ -66,21 +66,21 @@ Section Public
+ node:NODE_TYPE;
+ old_stack_local:FAST_ARRAY(LOCAL);
+ old_profil:PROFIL;
-
+
old_stack_local := stack_local;
old_profil := profil_current;
- stack_local := stack_local_empty;
+ stack_local := stack_local_empty;
profil_current := profil_slot;
- ? {stack_local.is_empty};
+ ? {stack_local.is_empty};
//
old_upper := list_current.upper;
expr_old := value.to_run_expr;
result_old := expr_old.static_type.get_temporary position;
list_current.add_last (result_old.write position value expr_old);
diff := list_current.upper - old_upper;
- // Move instr to up.
+ // Move instr to up.
lst := profil_slot.code;
- {diff != 0}.while_do {
+ {diff != 0}.while_do {
instr := list_current.last;
//
(NODE.node_list != NODE.node_list_base).if {
@@ -90,36 +90,36 @@ Section Public
NODE.node_list_base.add_last node;
};
};
-
+
list_current.remove_last;
(debug_level_option != 0).if {
- ? { + push:PUSH;
+ ? { + push:PUSH;
push ?= lst.first;
(push != NULL) && {push.is_first}
};
lst.add instr to (lst.lower + 1);
} else {
- lst.add_first instr;
+ lst.add_first instr;
};
diff := diff - 1;
- };
+ };
//
profil_current := old_profil;
stack_local := old_stack_local;
//
result_old.read position
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append "Old ";
value.append_in buffer;
);
-
+
Section Private
-
+
- stack_local_empty:FAST_ARRAY(LOCAL) := FAST_ARRAY(LOCAL).create 0;
diff --git a/src/item/itm_operator.li b/src/item/itm_operator.li
index 75e5b28..6cdde1b 100644
--- a/src/item/itm_operator.li
+++ b/src/item/itm_operator.li
@@ -19,26 +19,26 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_OPERATOR;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "operator list message";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
+ name:STRING_CONSTANT;
-
+
//
// Constructor
- //
+ //
- create p:POSITION name n:STRING_CONSTANT :SELF <-
[
@@ -49,30 +49,30 @@ Section Public
result.make p name n;
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT <-
- (
+ (
position := p;
name := n;
);
-
+
//
// Runnable.
//
-
+
- to_run_expr:EXPR <-
(
crash_with_message "ITM_OPERATOR.to_run_expr";
NULL
- );
-
+ );
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
- buffer.append name;
+ buffer.append name;
);
diff --git a/src/item/itm_prototype.li b/src/item/itm_prototype.li
index e76d1f7..a70433d 100644
--- a/src/item/itm_prototype.li
+++ b/src/item/itm_prototype.li
@@ -19,74 +19,74 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_PROTOTYPE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Prototype constant";
-
+
Section Inherit
-
+
+ parent_itm_constant:Expanded ITM_CONSTANT;
-
+
Section Public
+ type:ITM_TYPE_MONO;
-
+
//
// Constructor
//
-
+
- create p:POSITION type n:ITM_TYPE_MONO :SELF <-
( + result:SELF;
result := clone;
result.make p type n;
result
);
-
+
- make p:POSITION type n:ITM_TYPE_MONO <-
- (
+ (
position := p;
- type := n;
+ type := n;
);
//
// Runnable
//
- - to_run_expr:EXPR <-
+ - to_run_expr:EXPR <-
( + t:TYPE_FULL;
+ result:EXPR;
-
- t := type.to_run_for profil_slot;
+
+ t := type.to_run_for profil_slot;
(t = NULL).if {
string_tmp.copy "Type `";
type.append_in string_tmp;
- string_tmp.append "' not found (Undefine type parameter).";
+ string_tmp.append "' not found (Undefine type parameter).";
semantic_error (position,string_tmp);
};
- // TYPE Classic.
+ // TYPE Classic.
(
- (t.is_expanded_c) &&
- {t.raw != type_boolean} &&
- {t.raw != type_true} &&
+ (t.is_expanded_c) &&
+ {t.raw != type_boolean} &&
+ {t.raw != type_true} &&
{t.raw != type_false}
).if {
result := t.default_value position;
result := result.check_type t with position;
- } else {
+ } else {
result := PROTOTYPE_CST.create position type t;
};
result
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
type.append_in buffer;
diff --git a/src/item/itm_read.li b/src/item/itm_read.li
index be614d6..e90a087 100644
--- a/src/item/itm_read.li
+++ b/src/item/itm_read.li
@@ -123,7 +123,7 @@ Section ITM_READ, SLOT_DATA
itm_list ?= first_itm;
(itm_list != NULL).if {
itm_read ?= itm_list.code.first;
- } else {
+ } else {
itm_read ?= first_itm;
};
is_resend := (
@@ -187,7 +187,7 @@ Section ITM_READ, SLOT_DATA
position.put_position;
POSITION.send_error;
};
- last_position := slot_msg.position;
+ last_position := slot_msg.position;
(
(profil_slot != NULL) &&
{! slot_msg.id_section.access rec_type with (profil_slot.type_self.raw)}
@@ -237,7 +237,7 @@ Section ITM_READ, SLOT_DATA
string_tmp.copy "Deferred in `";
profil_slot.slot.pretty_name_in string_tmp;
string_tmp.append "' for ";
- rec.static_type.append_name_in string_tmp;
+ rec.static_type.append_name_in string_tmp;
warning_error (position,string_tmp);
};
@@ -248,7 +248,7 @@ Section ITM_READ, SLOT_DATA
} else {
// Classic message with arguments.
(is_resend).if {
- args.put (lookup (ALIAS_STR.variable_self).read position) to 0;
+ args.put (lookup (ALIAS_STR.variable_self).read position) to 0;
} else {
args.put (args.first.my_copy) to 0;
};
@@ -286,7 +286,7 @@ Section Private
args.add_last e;
};
(verify).if {
- (! is_block_value).if {
+ (! is_block_value).if {
itm_arg := slot.argument_list.item idx;
(itm_arg.count != count).if {
string_tmp.copy "Incorrect vector size for #";
diff --git a/src/item/itm_read_arg1.li b/src/item/itm_read_arg1.li
index 27cb5c4..3656704 100644
--- a/src/item/itm_read_arg1.li
+++ b/src/item/itm_read_arg1.li
@@ -19,53 +19,53 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_READ_ARG1;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- - comment :=
- "For send message with one argument\
+ - comment :=
+ "For send message with one argument\
\ (receiver) or unary message";
-
+
Section Inherit
-
+
+ parent_itm_read:Expanded ITM_READ;
-
+
Section Public
-
+
//
// Data
//
-
+
+ arg:ITM_CODE;
//
// Constructor
//
-
+
- create p:POSITION name n:STRING_CONSTANT arg a:ITM_CODE :SELF <-
( + result:SELF;
result := clone;
result.make p name n arg a;
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT arg a:ITM_CODE <-
(
position := p;
name := n;
arg := a;
);
-
+
//
// Runnable
//
- to_run_expr:EXPR <-
- (
+ (
to_run_with arg args NULL
);
diff --git a/src/item/itm_read_arg2.li b/src/item/itm_read_arg2.li
index 98caee4..7b799a5 100644
--- a/src/item/itm_read_arg2.li
+++ b/src/item/itm_read_arg2.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_READ_ARG2;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "For send message with two argument (receiver + argument)\
\ or simple binary message";
-
+
Section Inherit
-
+
+ parent_itm_read:Expanded ITM_READ;
-
+
Section Public
-
+
- is_affect:POSITION <-
( + result:POSITION;
-
+
(arg_first != NULL).if {
result := arg_first.position;
} else {
@@ -45,26 +45,26 @@ Section Public
};
result
);
-
+
//
// Data
//
+ arg_first:ITM_CODE;
-
+
+ arg_second:ITM_CODE;
-
+
//
// Constructor
//
-
+
- create p:POSITION name n:STRING_CONSTANT args (a1,a2:ITM_CODE) :SELF <-
( + result:SELF;
result := clone;
result.make p name n args (a1,a2);
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT args (a1,a2:ITM_CODE) <-
(
? { a2 != NULL };
@@ -77,26 +77,26 @@ Section Public
//
// Runnable
//
-
+
- to_run_expr:EXPR <-
- ( + result:EXPR;
- + l_arg:FAST_ARRAY(ITM_CODE);
+ ( + result:EXPR;
+ + l_arg:FAST_ARRAY(ITM_CODE);
+ v1,v2:EXPR;
+ t1,t2:TYPE_FULL;
+ em1,em2:EXPR_MULTIPLE;
-
+
(
- (name = ALIAS_STR.operator_equal) ||
+ (name = ALIAS_STR.operator_equal) ||
{name = ALIAS_STR.operator_not_equal}
- ).if {
+ ).if {
v1 := arg_first .to_run_expr;
- v2 := arg_second.to_run_expr;
+ v2 := arg_second.to_run_expr;
(verify).if {
t1 := v1.static_type;
t2 := v2.static_type;
(
- (! t1.is_expanded) &&
- {! t2.is_expanded} &&
+ (! t1.is_expanded) &&
+ {! t2.is_expanded} &&
{! t1.is_sub_type t2} &&
{! t2.is_sub_type t1}
).if {
@@ -112,34 +112,34 @@ Section Public
(em1 != NULL).if {
em2 ?= v2;
result := product_cmp (em1.first) with (em2.first);
- (em1.lower+1).to (em1.upper) do { j:INTEGER;
+ (em1.lower+1).to (em1.upper) do { j:INTEGER;
v2 := product_cmp (em1.item j) with (em2.item j);
(name = ALIAS_STR.operator_equal).if {
result := EXPR_AND_AND_LOGIC.create position with result and v2;
} else {
result := EXPR_OR_OR_LOGIC.create position with result and v2;
};
- };
+ };
} else {
result := product_cmp v1 with v2;
};
} else {
- l_arg := ALIAS_ARRAY(ITM_CODE).new;
- l_arg.add_last arg_second;
+ l_arg := ALIAS_ARRAY(ITM_CODE).new;
+ l_arg.add_last arg_second;
result := to_run_with arg_first args l_arg;
};
result
- );
-
+ );
+
Section Private
-
- - product_cmp v1:EXPR with v2:EXPR :EXPR <-
+
+ - product_cmp v1:EXPR with v2:EXPR :EXPR <-
( + result:EXPR;
(name = ALIAS_STR.operator_equal).if {
result := EXPR_EQUAL.create position with v1 and v2;
} else {
result := EXPR_NOT_EQUAL.create position with v1 and v2;
- };
+ };
result
);
diff --git a/src/item/itm_read_args.li b/src/item/itm_read_args.li
index 6569559..5ea51da 100644
--- a/src/item/itm_read_args.li
+++ b/src/item/itm_read_args.li
@@ -19,29 +19,29 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_READ_ARGS;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Message with a lot of arguments";
-
+
Section Inherit
-
+
+ parent_itm_read:Expanded ITM_READ;
-
+
Section Public
-
+
- is_affect:POSITION <-
( + result,default:POSITION;
+ j:INTEGER;
-
+
(args.first != NULL).if {
result := args.first.position;
} else {
- j := args.lower + 1;
+ j := args.lower + 1;
{(j <= args.upper) && {result = default}}.while_do {
result := args.item j.is_affect;
j := j + 1;
@@ -49,7 +49,7 @@ Section Public
};
result
);
-
+
//
// Data
//
@@ -59,14 +59,14 @@ Section Public
//
// Constructor
//
-
+
- create p:POSITION name n:STRING_CONSTANT args arg:FAST_ARRAY(ITM_CODE) :SELF <-
( + result:SELF;
result := clone;
result.make p name n args arg;
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT args arg:FAST_ARRAY(ITM_CODE) <-
(
position := p;
@@ -79,15 +79,15 @@ Section Public
//
- to_run_expr:EXPR <-
- ( + l_arg:FAST_ARRAY(ITM_CODE);
-
- l_arg := ALIAS_ARRAY(ITM_CODE).new;
- (args.lower+1).to (args.upper) do { j:INTEGER;
+ ( + l_arg:FAST_ARRAY(ITM_CODE);
+
+ l_arg := ALIAS_ARRAY(ITM_CODE).new;
+ (args.lower+1).to (args.upper) do { j:INTEGER;
l_arg.add_last (args.item j);
- };
+ };
to_run_with (args.first) args l_arg
);
-
+
diff --git a/src/item/itm_real.li b/src/item/itm_real.li
index 17b1015..b67b001 100644
--- a/src/item/itm_real.li
+++ b/src/item/itm_real.li
@@ -19,19 +19,19 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_REAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Real float constant";
-
+
Section Inherit
-
+
+ parent_itm_constant:Expanded ITM_CONSTANT;
-
+
Section Public
//
@@ -49,26 +49,26 @@ Section Public
result.make p value n;
result
);
-
+
- make p:POSITION value n:STRING_CONSTANT <-
(
position:=p;
value:=n;
);
-
+
//
// Runnable
//
- to_run_expr:EXPR <-
- (
- REAL_CST.create position value value type (type_real.default)
+ (
+ REAL_CST.create position value value type (type_real.default)
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append value;
diff --git a/src/item/itm_result.li b/src/item/itm_result.li
index 0fd8f29..afaedfc 100644
--- a/src/item/itm_result.li
+++ b/src/item/itm_result.li
@@ -19,52 +19,52 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_RESULT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Result value";
-
+
Section Inherit
-
+
- parent_itm_code:ITM_CODE := ITM_CODE;
-
+
Section Public
-
+
- is_affect:POSITION <- value.is_affect;
-
+
- position:POSITION <- value.position;
-
+
//
// Data
//
-
+
+ value:ITM_CODE;
//
// Constructor
//
-
+
- create r:ITM_CODE :SELF <-
[
-? {r != NULL};
-? {r.position.code != 0};
]
( + result:SELF;
-
+
result := clone;
result.make r;
result
);
-
+
- make r:ITM_CODE <-
(
value := r;
);
-
+
//
// Runnable
//
@@ -73,8 +73,8 @@ Section Public
( + mul:EXPR_MULTIPLE;
+ val:EXPR;
+ result:INSTR;
-
- val := value.to_run_expr;
+
+ val := value.to_run_expr;
mul ?= val;
(mul != NULL).if {
(mul.lower).to (mul.upper-1) do { j:INTEGER;
@@ -87,17 +87,17 @@ Section Public
};
result
);
-
+
- to_run_expr:EXPR <-
(
crash;
NULL
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append "return(";
@@ -108,10 +108,10 @@ Section Public
Section Private
- to_run_intern val:EXPR :INSTR <-
- ( + var:LOCAL;
-
+ ( + var:LOCAL;
+
var := val.static_type.get_temporary position;
- ITM_LIST.stack_result.add_last var;
- var.write position value val
+ ITM_LIST.stack_result.add_last var;
+ var.write position value val
);
-
+
diff --git a/src/item/itm_slot.li b/src/item/itm_slot.li
index 32fbc1a..3349945 100644
--- a/src/item/itm_slot.li
+++ b/src/item/itm_slot.li
@@ -19,73 +19,73 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_SLOT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Slot item";
-
+
Section Inherit
-
+
+ parent_named:Expanded NAMED;
-
+
Section Public
-
+
//
// Shorter information.
//
-
+
+ comment:STRING_CONSTANT;
-
+
- set_comment str:STRING_CONSTANT <-
(
comment := str;
);
-
+
+ comment_chapter:STRING_CONSTANT;
-
+
- set_comment_chapter c:STRING_CONSTANT <-
(
comment_chapter := c;
);
-
+
+ stat_shorter:INTEGER_8;
-
+
- set_stat_shorter s:INTEGER_8 <-
(
stat_shorter := s;
);
-
+
//
// Profil
//
-
+
+ id_section:SECTION_;
-
+
- argument_count:INTEGER <-
( + result:INTEGER;
-
+
(argument_list.lower).to (argument_list.upper) do { j:INTEGER;
result := result + argument_list.item j.count;
};
result
);
-
+
+ argument_list:FAST_ARRAY(ITM_ARGUMENT);
+ result_type:ITM_TYPE;
-
+
- set_result_type t:ITM_TYPE <-
( + tm:ITM_TYPE_MONO;
-
+
(id_section.is_inherit_or_insert).if {
tm ?= t;
(
- (tm = NULL) ||
- {tm = ITM_TYPE_SIMPLE.type_self} ||
+ (tm = NULL) ||
+ {tm = ITM_TYPE_SIMPLE.type_self} ||
{tm = ITM_TYPE_SIMPLE.type_void}
).if {
semantic_error (position,"Incorrect type for inheritance slot.");
@@ -104,10 +104,10 @@ Section Public
*/
result_type := t;
);
-
+
- set_argument_list p:FAST_ARRAY(ITM_ARGUMENT) <-
- (
- ((p.count > 1) || {p.first.count > 1}).if {
+ (
+ ((p.count > 1) || {p.first.count > 1}).if {
(id_section.is_interrupt).if {
semantic_error (p.last.position,"No argument for interrupt slot.");
};
@@ -117,22 +117,22 @@ Section Public
};
argument_list := p;
);
-
+
- get_argument_type i:INTEGER :ITM_TYPE_MONO <-
( + idx,j:INTEGER;
+ arg:ITM_ARGUMENT;
-
+
{
arg := argument_list.item j;
idx := idx + arg.count;
j := j + 1;
}.do_while {idx <= i};
- arg.item (i-(idx - arg.count))
- );
-
+ arg.item (i-(idx - arg.count))
+ );
+
- is_equal_profil other:ITM_SLOT <-
- (
- (Self != other).if {
+ (
+ (Self != other).if {
(result_type != other.result_type).if {
string_tmp.copy "Invariance type result invalid."; // (";
//type.to_run.append_name_in string_tmp;
@@ -142,34 +142,34 @@ Section Public
POSITION.put_error semantic text string_tmp;
position.put_position;
(other.position).put_position;
- POSITION.send_error;
+ POSITION.send_error;
};
(id_section != other.id_section).if {
- POSITION.put_error warning text
+ POSITION.put_error warning text
"Invariance section declaration invalid.";
position.put_position;
(other.position).put_position;
POSITION.send_error;
};
(
- ((other.argument_list = NULL) ^ (argument_list = NULL)) ||
+ ((other.argument_list = NULL) ^ (argument_list = NULL)) ||
{(argument_list != NULL) && {argument_list.count != other.argument_list.count}}
).if {
- POSITION.put_error warning text
+ POSITION.put_error warning text
"Invariance argument number.";
position.put_position;
(other.position).put_position;
POSITION.send_error;
} else {
- (argument_list != NULL).if {
+ (argument_list != NULL).if {
(argument_list.lower).to (argument_list.upper) do { j:INTEGER;
argument_list.item j.is_equal (other.argument_list.item j);
- };
+ };
};
};
};
);
-
+
//
// Data.
//
@@ -178,32 +178,32 @@ Section Public
- set_affect a:CHARACTER <-
(
- affect := a;
+ affect := a;
);
+ next:ITM_SLOT;
-
+
- set_next n:ITM_SLOT <-
(
next := n;
);
-
+
//
// Access associativity & priority level.
//
-
+
- priority_and_level:INTEGER <-
- (
+ (
crash_with_message "ITM_SLOT.priority_and_level.";
0
);
-
+
- associativity:STRING_CONSTANT <-
- (
+ (
crash_with_message "ITM_SLOT.associativity.";
NULL
);
-
+
- priority:INTEGER <-
(
crash_with_message "ITM_SLOT.priority.";
@@ -213,63 +213,63 @@ Section Public
//
// Value.
//
-
+
+ require:ITM_LIST;
+ ensure:ITM_LIST;
-
+
+ value:ITM_CODE;
- set_value e:ITM_CODE type p:PROTOTYPE <-
// Static definition.
- [
+ [
-? {affect != '\0'};
]
- (
+ (
(affect = '<').if {
value := e;
} else {
//semantic_error (position,"not_yet_implemented");
value := default_value e in p;
};
- );
+ );
- set_require e:ITM_LIST <-
- (
+ (
require := e;
- );
+ );
- set_ensure e:ITM_LIST <-
- (
+ (
ensure := e;
- );
+ );
//
// Constructeur.
//
-
+
- create p:POSITION name n:STRING_CONSTANT feature sec:SECTION_ :SELF <-
( + result:SELF;
result := clone;
result.make p name n feature sec;
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT feature sec:SECTION_ <-
(
name := n;
- position := p;
+ position := p;
id_section := sec;
);
-
+
//
// Runnable.
//
-
+
- get_index_argument_type p:ITM_TYPE_PARAMETER :INTEGER <-
( + i,result,max:INTEGER;
+ arg:ITM_ARGUMENT;
-
- i := argument_list.lower;
+
+ i := argument_list.lower;
{(i <= argument_list.upper) && {result = max}}.while_do {
arg := argument_list.item i;
max := max + arg.count;
@@ -281,73 +281,73 @@ Section Public
};
result
);
-
- - check_argument_type larg:FAST_ARRAY(EXPR) for p:PARAMETER_TO_TYPE <-
+
+ - check_argument_type larg:FAST_ARRAY(EXPR) for p:PARAMETER_TO_TYPE <-
( + idx:INTEGER;
+ a:ITM_ARGUMENT;
-
+
(argument_list.lower).to (argument_list.upper) do { i:INTEGER;
a := argument_list.item i;
idx := a.check larg index idx for p;
};
- );
-
+ );
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.append name;
- (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
+ (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
buffer.add_last ' ';
argument_list.item j.append_in buffer;
- };
+ };
buffer.add_last ' ';
buffer.add_last ':';
- result_type.append_in buffer;
- );
-
+ result_type.append_in buffer;
+ );
+
- pretty_name:STRING_CONSTANT <-
(
crash_with_message "ITM_SLOT.pretty_name.";
NULL
);
-
+
- pretty_name_in buffer:STRING <-
( + j:INTEGER;
-
+
j := name.lower;
- {j < name.upper}.while_do {
+ {j < name.upper}.while_do {
((name.item j = '_') && {name.item (j+1) = '_'}).if {
buffer.add_last ' ';
j := j + 2;
} else {
buffer.add_last (name.item j);
j := j + 1;
- };
+ };
};
buffer.add_last (name.last);
);
-
+
- shorter_profile_in buf:STRING <-
- (
+ (
// style.
(style = '+').if {
put "+" to buf like (ALIAS_STR.short_slot_style);
} else {
put "-" to buf like (ALIAS_STR.short_slot_style);
- };
+ };
shorter_profile_intern_in buf;
// Result.
- (result_type != ITM_TYPE_SIMPLE.type_void).if {
- buf.add_last ':';
+ (result_type != ITM_TYPE_SIMPLE.type_void).if {
+ buf.add_last ':';
result_type.shorter_in buf;
};
);
-
+
Section ITM_SLOT
-
+
- shorter_profile_intern_in buf:STRING <-
( + j,i:INTEGER;
// Name + arguments.
@@ -355,20 +355,20 @@ Section ITM_SLOT
j := name.lower;
argument_list.first.shorter_in buf;
buf.add_last '.';
- i := argument_list.lower+1;
- {j < name.upper}.while_do {
+ i := argument_list.lower+1;
+ {j < name.upper}.while_do {
((name.item j = '_') && {name.item (j+1) = '_'}).if {
put string_tmp to buf like (ALIAS_STR.short_slot);
buf.add_last ' ';
argument_list.item i.shorter_in buf;
buf.add_last ' ';
- string_tmp.clear;
+ string_tmp.clear;
j := j + 2;
i := i + 1;
} else {
string_tmp.add_last (name.item j);
j := j + 1;
- };
+ };
};
string_tmp.add_last (name.last);
put string_tmp to buf like (ALIAS_STR.short_slot);
@@ -378,9 +378,9 @@ Section ITM_SLOT
buf.add_last ' ';
};
);
-
+
Section Private
-
+
- default_value v:ITM_CODE in t:PROTOTYPE :ITM_CODE <-
( //+ lst:ITM_LIST;
+ s:ITM_SLOT;
@@ -388,28 +388,28 @@ Section Private
+ sec:SECTION_;
+ larg:FAST_ARRAY(ITM_ARGUMENT);
+ a:ITM_CODE;
-
+
// Add function for init.
- string_tmp.copy "__init_";
+ string_tmp.copy "__init_";
string_tmp.append name;
n := ALIAS_STR.get string_tmp;
sec := SECTION_.get_name (ALIAS_STR.section_public);
larg := FAST_ARRAY(ITM_ARGUMENT).create_with_capacity 1;
larg.add_last (
ITM_ARG.create (v.position)
- name (ALIAS_STR.variable_self)
+ name (ALIAS_STR.variable_self)
type (ITM_TYPE_SIMPLE.type_self)
);
s := ITM_SLOT.create (v.position) name n feature sec;
s.set_affect '<';
? {result_type != NULL};
- s.set_value v type t;
- s.set_argument_list larg;
+ s.set_value v type t;
+ s.set_argument_list larg;
s.set_result_type result_type;
- t.slot_list.fast_put s to (s.name);
+ t.slot_list.fast_put s to (s.name);
(t.generic_count = 0).if {
- a := ITM_PROTOTYPE.create (v.position) type (ITM_TYPE_SIMPLE.get (t.name));
+ a := ITM_PROTOTYPE.create (v.position) type (ITM_TYPE_SIMPLE.get (t.name));
};
-
+
ITM_READ_ARG1.create (v.position) name n arg a
);
diff --git a/src/item/itm_slot_operator.li b/src/item/itm_slot_operator.li
index d22ca37..68335b6 100644
--- a/src/item/itm_slot_operator.li
+++ b/src/item/itm_slot_operator.li
@@ -19,28 +19,28 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_SLOT_OPERATOR;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Slot item";
-
+
Section Inherit
-
+
+ parent_itm_slot:Expanded ITM_SLOT;
-
+
Section Public
-
+
+ pretty_name:STRING_CONSTANT;
-
+
- set_pretty_name n:STRING_CONSTANT <-
(
pretty_name := n;
);
-
+
//
// Access associativity & priority level.
//
@@ -56,7 +56,7 @@ Section Public
};
result
);
-
+
- priority:INTEGER <-
(
priority_and_level.abs
@@ -70,28 +70,28 @@ Section Public
priority_and_level := -l;
};
);
-
+
//
// Display.
//
-
+
- pretty_name_in buffer:STRING <-
- (
+ (
(name.has_prefix (ALIAS_STR.slot_postfix)).if {
buffer.append "Postfix '";
}.elseif {name.has_prefix (ALIAS_STR.slot_infix)} then {
buffer.append "Infix '";
} else {
buffer.append "Prefix '";
- };
+ };
buffer.append pretty_name;
buffer.add_last '\'';
);
-
+
Section ITM_SLOT
-
+
- shorter_profile_intern_in buf:STRING <-
- (
+ (
(name.has_prefix (ALIAS_STR.slot_postfix)).if {
argument_list.first.shorter_in buf;
buf.add_last ' ';
@@ -123,5 +123,5 @@ Section ITM_SLOT
buf.add_last ' ';
argument_list.first.shorter_in buf;
buf.add_last ' ';
- };
+ };
);
\ No newline at end of file
diff --git a/src/item/itm_string.li b/src/item/itm_string.li
index b23e374..c0a9d0b 100644
--- a/src/item/itm_string.li
+++ b/src/item/itm_string.li
@@ -19,22 +19,22 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_STRING;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "String constant";
-
+
Section Inherit
-
+
+ parent_itm_constant:Expanded ITM_CONSTANT;
-
+
Section Public
-
- + string:STRING_CONSTANT;
+
+ + string:STRING_CONSTANT;
//
// Constructor
@@ -46,23 +46,23 @@ Section Public
result.make p text n;
result
);
-
+
- make p:POSITION text n:STRING_CONSTANT <-
(
- position := p;
+ position := p;
string := n;
);
-
+
//
// Runnable
//
- to_run_expr:EXPR <-
- ( + result:EXPR;
+ ( + result:EXPR;
+ slt:SLOT_DATA;
+ wrt:WRITE;
+ len:INTEGER;
-
+
len := length;
result := STRING_CST.create position text string length len;
// count
@@ -75,37 +75,37 @@ Section Public
// storage
slt := type_string_constant.get_local_slot (ALIAS_STR.slot_storage).slot_data_intern;
wrt := slt.write position with (result.my_copy) value (
- NATIVE_ARRAY_CHARACTER_CST.create position text string
+ NATIVE_ARRAY_CHARACTER_CST.create position text string
);
wrt.set_quiet_generation;
list_current.add_last wrt;
//
result
);
-
- //
+
+ //
// Display.
//
-
+
- append_in buffer:STRING <-
(
buffer.add_last '\"';
buffer.append string;
buffer.add_last '\"';
);
-
+
Section Private
-
+
- length:INTEGER <-
( + i,result:INTEGER;
i := string.lower;
{i <= string.upper}.while_do {
- (string.item i = '\\').if {
+ (string.item i = '\\').if {
i := i + 1;
(string.item i.is_digit).if {
i := i + 1;
(string.item i.is_digit).if {
- i := i + 2;
+ i := i + 2;
};
};
};
diff --git a/src/item/itm_type.li b/src/item/itm_type.li
index ef95eae..7c94b97 100644
--- a/src/item/itm_type.li
+++ b/src/item/itm_type.li
@@ -19,37 +19,37 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all type";
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
- print <-
(
string_tmp.clear;
append_in string_tmp;
string_tmp.print;
);
-
+
- append_in buffer:STRING <- deferred;
-
+
- shorter_in buf:STRING <- deferred;
-
+
- to_run_in lst:FAST_ARRAY(TYPE_FULL) for p:PARAMETER_TO_TYPE <-
(
deferred;
);
-
+
- get_expr_for p:PARAMETER_TO_TYPE :EXPR <-
(
deferred;
diff --git a/src/item/itm_type_block.li b/src/item/itm_type_block.li
index 9fe4333..1b89ef0 100644
--- a/src/item/itm_type_block.li
+++ b/src/item/itm_type_block.li
@@ -19,48 +19,48 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_BLOCK;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type block definition";
-
+
Section Inherit
-
+
+ parent_itm_type_mono:Expanded ITM_TYPE_MONO;
-
+
Section ITM_TYPE_SIMPLE, ITM_TYPE_SELF
-
+
- dico:FAST_ARRAY(ITM_TYPE_BLOCK) := FAST_ARRAY(ITM_TYPE_BLOCK).create_with_capacity 32;
-
-Section Private
-
+
+Section Private
+
- create typ_arg:ITM_TYPE and typ_res:ITM_TYPE :SELF <-
( + result:SELF;
-
+
result := clone;
result.make typ_arg and typ_res;
result
);
-
+
- make typ_arg:ITM_TYPE and typ_res:ITM_TYPE <-
(
type_argument := typ_arg;
type_result := typ_res;
);
-
+
Section Public
-
+
+ type_argument:ITM_TYPE;
+ type_result:ITM_TYPE;
-
+
- get typ_arg:ITM_TYPE and typ_res:ITM_TYPE :ITM_TYPE_BLOCK <-
- ( + result:ITM_TYPE_BLOCK;
+ ( + result:ITM_TYPE_BLOCK;
+ idx:INTEGER;
-
+
idx := dico.lower;
{
(idx <= dico.upper) && {
@@ -69,7 +69,7 @@ Section Public
}
}.while_do {
idx := idx + 1;
- };
+ };
(idx <= dico.upper).if {
result := dico.item idx;
} else {
@@ -78,12 +78,12 @@ Section Public
};
result
);
-
+
- to_run_for p:PARAMETER_TO_TYPE :TYPE_FULL <-
- (
+ (
TYPE_BLOCK.get Self with p
);
-
+
- append_in buffer:STRING <-
( + typ_mul:ITM_TYPE_MULTI;
buffer.add_last '{';
@@ -91,7 +91,7 @@ Section Public
type_argument.append_in buffer;
buffer.add_last ';';
buffer.add_last ' ';
- };
+ };
(type_result != NULL).if {
typ_mul ?= type_result;
(typ_mul = NULL).if {
@@ -102,7 +102,7 @@ Section Public
};
buffer.add_last '}';
);
-
+
- shorter_in buf:STRING <-
( + typ_mul:ITM_TYPE_MULTI;
put "{" to buf like (ALIAS_STR.short_block);
@@ -110,7 +110,7 @@ Section Public
type_argument.shorter_in buf;
buf.add_last ';';
buf.add_last ' ';
- };
+ };
(type_result != NULL).if {
typ_mul ?= type_result;
(typ_mul = NULL).if {
@@ -121,12 +121,12 @@ Section Public
};
put "}" to buf like (ALIAS_STR.short_block);
);
-
+
//
// Cast.
//
-
- - append_cast_name_in buf:STRING <-
+
+ - append_cast_name_in buf:STRING <-
(
crash_with_message "ITM_TYPE_BLOCK.append_cast_name_in ";
);
\ No newline at end of file
diff --git a/src/item/itm_type_generic.li b/src/item/itm_type_generic.li
index a960799..373d5a0 100644
--- a/src/item/itm_type_generic.li
+++ b/src/item/itm_type_generic.li
@@ -19,58 +19,58 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_GENERIC;
- copyright := "2003-2007 Benoit Sonntag";
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Generic style type";
-
+
Section Inherit
-
+
+ parent_itm_type_style:Expanded ITM_TYPE_STYLE;
-
+
Section Private
-
+
- dico_tg:FAST_ARRAY(ITM_TYPE_GENERIC) := FAST_ARRAY(ITM_TYPE_GENERIC).create_with_capacity 32;
- create n:STRING_CONSTANT style s:STRING_CONSTANT with lt:FAST_ARRAY(ITM_TYPE_MONO) :SELF <-
( + result:SELF;
-
+
result := clone;
result.make n style s with lt;
result
);
-
+
- make n:STRING_CONSTANT style s:STRING_CONSTANT with lt:FAST_ARRAY(ITM_TYPE_MONO) <-
(
name := n;
style := s;
list_type := lt;
);
-
+
Section Public
-
- - hash_code:INTEGER <- name.hash_code;
+
+ - hash_code:INTEGER <- name.hash_code;
+ list_type:FAST_ARRAY(ITM_TYPE_MONO);
-
- - get n:STRING_CONSTANT style s:STRING_CONSTANT
+
+ - get n:STRING_CONSTANT style s:STRING_CONSTANT
with lt:FAST_ARRAY(ITM_TYPE_MONO) :SELF <-
( + result:SELF;
+ idx:INTEGER;
-
+
idx := dico_tg.lower;
{
(idx <= dico_tg.upper) && {
- (dico_tg.item idx.name != n ) ||
- {dico_tg.item idx.style != s } ||
+ (dico_tg.item idx.name != n ) ||
+ {dico_tg.item idx.style != s } ||
{dico_tg.item idx.list_type != lt}
}
}.while_do {
idx := idx + 1;
- };
+ };
(idx <= dico_tg.upper).if {
result ?= dico_tg.item idx;
} else {
@@ -79,35 +79,35 @@ Section Public
};
result
);
-
+
- to_run_for p:PARAMETER_TO_TYPE :TYPE_FULL <-
( + lst:FAST_ARRAY(TYPE_FULL);
+ t:TYPE_FULL;
- + j:INTEGER;
+ + j:INTEGER;
+ result:TYPE_FULL;
+ path:STRING_CONSTANT;
-
+
lst := ALIAS_ARRAY(TYPE_FULL).new;
- j := list_type.lower;
+ j := list_type.lower;
{
- t := list_type.item j.to_run_for p;
+ t := list_type.item j.to_run_for p;
lst.add_last t;
j := j + 1;
}.do_while {(j <= list_type.upper) && {t != NULL}};
(t = NULL).if {
ALIAS_ARRAY(TYPE_FULL).free lst;
- } else {
- lst := ALIAS_ARRAY(TYPE_FULL).alias lst;
+ } else {
+ lst := ALIAS_ARRAY(TYPE_FULL).alias lst;
(p != NULL).if {
path := p.position.prototype.filename;
} else {
path := input_path;
- };
+ };
result := TYPE_GENERIC.get (path,Self) with lst;
};
result
);
-
+
- append_in buffer:STRING <-
(
(style != NULL).if {
@@ -123,7 +123,7 @@ Section Public
list_type.last.append_in buffer;
buffer.add_last ')';
);
-
+
- shorter_in buf:STRING <-
(
(style != NULL).if {
@@ -139,12 +139,12 @@ Section Public
list_type.last.shorter_in buf;
buf.add_last ')';
);
-
+
//
// Cast.
//
-
- - append_cast_name_in buf:STRING <-
+
+ - append_cast_name_in buf:STRING <-
(
parent_itm_type_style.append_cast_name_in buf;
buf.append "_of_";
diff --git a/src/item/itm_type_generic_elt.li b/src/item/itm_type_generic_elt.li
index eabafe4..982114a 100644
--- a/src/item/itm_type_generic_elt.li
+++ b/src/item/itm_type_generic_elt.li
@@ -19,78 +19,78 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_GENERIC_ELT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Virtual element for generic style type";
-
+
Section Inherit
-
+
+ parent_itm_type:Expanded ITM_TYPE_MONO;
-
+
Section Private
-
- - list:FAST_ARRAY(ITM_TYPE_GENERIC_ELT) :=
+
+ - list:FAST_ARRAY(ITM_TYPE_GENERIC_ELT) :=
// 'A' to 'Z'
( + result:FAST_ARRAY(ITM_TYPE_GENERIC_ELT);
-
- result := FAST_ARRAY(ITM_TYPE_GENERIC_ELT).create_with_capacity 26;
+
+ result := FAST_ARRAY(ITM_TYPE_GENERIC_ELT).create_with_capacity 26;
'A'.to 'Z' do { c:CHARACTER;
result.add_last (create c);
};
result
);
-
+
- create idf:CHARACTER :SELF <-
( + result:SELF;
-
+
result := clone;
result.make idf;
result
);
-
+
- make idf:CHARACTER <-
(
- index := idf -! 'A';
+ index := idf -! 'A';
);
Section Public
-
+
+ index:INTEGER;
-
+
- hash_code:INTEGER <- index;
-
+
- get idf:CHARACTER :ITM_TYPE_GENERIC_ELT <-
- (
+ (
list.item (idf -! 'A')
);
-
+
- display buffer:STRING <-
(
buffer.append "Generic[";
- buffer.add_last ('A' +# index);
+ buffer.add_last ('A' +# index);
buffer.add_last ']';
);
-
+
- shorter_in buf:STRING <-
(
string_tmp.clear;
- string_tmp.add_last ('A' +# index);
+ string_tmp.add_last ('A' +# index);
put string_tmp to buf like (ALIAS_STR.short_keyprototype);
- );
-
+ );
+
- string_tmp:STRING := STRING.create 100;
-
+
- to_run:TYPE_FULL <-
( + type_generic:TYPE_GENERIC;
+ result:TYPE_FULL;
+ t:CHARACTER;
-
+
t := 'A' +# index;
- type_generic ?= ITM_TYPE_SELF.self_up;
+ type_generic ?= ITM_TYPE_SELF.self_up;
(type_generic != NULL).if {
result := type_generic.generic_to_type t;
};
@@ -106,8 +106,8 @@ Section Public
//
// Cast.
//
-
- - append_cast_name_in buf:STRING <-
+
+ - append_cast_name_in buf:STRING <-
(
buf.add_last ('a' +# index);
);
\ No newline at end of file
diff --git a/src/item/itm_type_mono.li b/src/item/itm_type_mono.li
index eb426a8..4755917 100644
--- a/src/item/itm_type_mono.li
+++ b/src/item/itm_type_mono.li
@@ -19,62 +19,62 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_MONO;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type simple";
-
+
Section Inherit
-
+
+ parent_itm_type:Expanded ITM_TYPE;
-
+
Section Public
-
- - hash_code:INTEGER <-
+
+ - hash_code:INTEGER <-
(
deferred;
0
);
-
+
//
// Runnable.
//
- to_run_for p:PARAMETER_TO_TYPE :TYPE_FULL <-
- (
+ (
deferred;
NULL
);
-
+
- to_run_in lst:FAST_ARRAY(TYPE_FULL) for p:PARAMETER_TO_TYPE <-
(
lst.add_last (to_run_for p);
);
-
+
- get_expr_for p:PARAMETER_TO_TYPE :EXPR <-
( + t:TYPE_FULL;
+ result:EXPR;
-
- t := to_run_for p;
+
+ t := to_run_for p;
result := t.get_temporary_expr (p.position);
result
- );
-
+ );
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
deferred;
);
-
+
//
// Cast.
//
-
+
- append_cast_name_in buf:STRING <- deferred;
\ No newline at end of file
diff --git a/src/item/itm_type_multi.li b/src/item/itm_type_multi.li
index 4738baa..1ca68f4 100644
--- a/src/item/itm_type_multi.li
+++ b/src/item/itm_type_multi.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_MULTI;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "List of type";
-
+
Section Inherit
-
+
+ parent_itm_type:Expanded ITM_TYPE;
-
+
Section Private
-
+
- dico:FAST_ARRAY(ITM_TYPE_MULTI) := FAST_ARRAY(ITM_TYPE_MULTI).create_with_capacity 32;
- create lt:FAST_ARRAY(ITM_TYPE_MONO) :SELF <-
( + result:SELF;
-
+
result := clone;
result.make lt;
result
);
-
+
- make lt:FAST_ARRAY(ITM_TYPE_MONO) <-
(
list_type := lt;
);
-
+
Section Public
-
+
+ list_type:FAST_ARRAY(ITM_TYPE_MONO);
-
+
- count:INTEGER <- list_type.count;
-
+
- lower:INTEGER <- list_type.lower;
-
+
- upper:INTEGER <- list_type.upper;
-
+
- item i:INTEGER :ITM_TYPE_MONO <-
(
list_type.item i
);
-
+
- last:ITM_TYPE_MONO <-
(
list_type.last
@@ -73,15 +73,15 @@ Section Public
(
list_type.first
);
-
+
- get lt:FAST_ARRAY(ITM_TYPE_MONO) :SELF <-
( + result:SELF;
+ idx:INTEGER;
-
+
idx := dico.lower;
{(idx <= dico.upper) && {dico.item idx.list_type != lt}}.while_do {
idx := idx + 1;
- };
+ };
(idx <= dico.upper).if {
result ?= dico.item idx;
} else {
@@ -90,15 +90,15 @@ Section Public
};
result
);
-
+
//
// Runnable.
//
-
+
- get_expr_for p:PARAMETER_TO_TYPE :EXPR <-
( + lst:FAST_ARRAY(EXPR);
+ t:TYPE_FULL;
-
+
lst := FAST_ARRAY(EXPR).create_with_capacity count;
lower.to upper do { i:INTEGER;
t := item i.to_run_for p;
@@ -106,45 +106,45 @@ Section Public
};
EXPR_MULTIPLE.create lst
);
-
+
- to_run_in lst:FAST_ARRAY(TYPE_FULL) for p:PARAMETER_TO_TYPE <-
( + t:TYPE_FULL;
-
+
lower.to upper do { i:INTEGER;
t := item i.to_run_for p;
lst.add_last t;
};
);
-
+
//
// Display.
- //
-
+ //
+
- append_in buffer:STRING <-
- (
+ (
buffer.add_last '(';
display_raw buffer;
buffer.add_last ')';
);
-
+
- shorter_in buf:STRING <-
(
buf.add_last '(';
shorter_raw_in buf;
buf.add_last ')';
);
-
+
- display_raw buffer:STRING <-
- (
+ (
(list_type.lower).to (list_type.upper - 1) do { j:INTEGER;
list_type.item j.append_in buffer;
buffer.add_last ',';
};
list_type.last.append_in buffer;
);
-
+
- shorter_raw_in buf:STRING <-
- (
+ (
(list_type.lower).to (list_type.upper - 1) do { j:INTEGER;
list_type.item j.shorter_in buf;
buf.add_last ',';
diff --git a/src/item/itm_type_parameter.li b/src/item/itm_type_parameter.li
index 1f24b41..83a4f4f 100644
--- a/src/item/itm_type_parameter.li
+++ b/src/item/itm_type_parameter.li
@@ -19,24 +19,24 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_PARAMETER;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parameter type for argument define.";
-
+
Section Inherit
-
+
+ parent_itm_type_simple:Expanded ITM_TYPE_SIMPLE;
-
+
Section Public
-
+
- to_run_for p:PARAMETER_TO_TYPE :TYPE_FULL <-
( + result:TYPE_FULL;
-
- result := p.parameter_to_type Self;
+
+ result := p.parameter_to_type Self;
(result = NULL).if {
string_tmp.copy "Cannot resolve type for type parameter ";
append_in string_tmp;
@@ -44,16 +44,16 @@ Section Public
};
result
);
-
- //
+
+ //
// Display.
//
-
+
- shorter_in buf:STRING <-
(
(style != NULL).if {
put style to buf like (ALIAS_STR.short_keyword);
buf.add_last ' ';
- };
+ };
put name to buf like (ALIAS_STR.short_keyprototype);
);
diff --git a/src/item/itm_type_simple.li b/src/item/itm_type_simple.li
index 8af94b3..1b7444a 100644
--- a/src/item/itm_type_simple.li
+++ b/src/item/itm_type_simple.li
@@ -19,69 +19,69 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_SIMPLE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Simple type";
-
+
Section Inherit
-
+
+ parent_itm_type_mono:Expanded ITM_TYPE_MONO;
-
+
Section ITM_TYPE_SIMPLE, ITM_TYPE_SELF
-
- - dico:HASHED_DICTIONARY(ITM_TYPE_SIMPLE,STRING_CONSTANT) :=
+
+ - dico:HASHED_DICTIONARY(ITM_TYPE_SIMPLE,STRING_CONSTANT) :=
HASHED_DICTIONARY(ITM_TYPE_SIMPLE,STRING_CONSTANT).create;
Section ITM_TYPE_SIMPLE
-
+
- create n:STRING_CONSTANT :SELF <-
( + result:SELF;
-
+
result := clone;
result.make n;
result
);
-
+
- make n:STRING_CONSTANT <-
(
name := n;
dico.fast_put Self to n;
);
-
+
Section Public
-
+
- type_null:ITM_TYPE_SIMPLE := ITM_TYPE_SIMPLE.get (ALIAS_STR.variable_null);
- type_void:ITM_TYPE_SIMPLE := ITM_TYPE_SIMPLE.get (ALIAS_STR.variable_void);
- type_self:ITM_TYPE_SIMPLE := ITM_TYPE_PARAMETER.create (ALIAS_STR.prototype_self);
-
+
- hash_code:INTEGER <- name.hash_code;
-
+
+ name:STRING_CONSTANT;
-
+
- style:STRING_CONSTANT; // NULL
-
+
- get n:STRING_CONSTANT :ITM_TYPE_SIMPLE <-
[
- -? {n != NULL};
+ -? {n != NULL};
]
( + result:ITM_TYPE_SIMPLE;
-
- result := dico.fast_reference_at n;
+
+ result := dico.fast_reference_at n;
(result = NULL).if {
- result := create n;
- };
+ result := create n;
+ };
result
);
-
+
- to_run_for p:PARAMETER_TO_TYPE :TYPE_FULL <-
- ( + result:TYPE_FULL;
+ ( + result:TYPE_FULL;
+ path:STRING_CONSTANT;
-
+
(Self = type_null).if {
result := TYPE_NULL.default;
}.elseif {Self = type_void} then {
@@ -91,12 +91,12 @@ Section Public
path := p.position.prototype.filename;
} else {
path := input_path;
- };
+ };
result := TYPE.get (path,Self);
};
- result
+ result
);
-
+
- append_in buffer:STRING <-
(
(style != NULL).if {
@@ -105,7 +105,7 @@ Section Public
};
buffer.append name;
);
-
+
- shorter_in buf:STRING <-
(
(style != NULL).if {
@@ -114,16 +114,15 @@ Section Public
};
put name to buf like (ALIAS_STR.short_prototype);
);
-
+
//
// Cast.
//
-
- - append_cast_name_in buf:STRING <-
+
+ - append_cast_name_in buf:STRING <-
(
(name.lower).to (name.upper) do { j:INTEGER;
buf.add_last (name.item j.to_lower);
};
);
-
-
\ No newline at end of file
+
diff --git a/src/item/itm_type_style.li b/src/item/itm_type_style.li
index d3c52d0..510d387 100644
--- a/src/item/itm_type_style.li
+++ b/src/item/itm_type_style.li
@@ -19,49 +19,49 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_TYPE_STYLE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type with style";
-
+
Section Inherit
-
+
+ parent_itm_type_simple:Expanded ITM_TYPE_SIMPLE;
-
-Section Private
-
+
+Section Private
+
- dico_ts:FAST_ARRAY(ITM_TYPE_STYLE) := FAST_ARRAY(ITM_TYPE_STYLE).create_with_capacity 32;
-
+
- create n:STRING_CONSTANT style s:STRING_CONSTANT :SELF <-
( + result:SELF;
-
+
result := clone;
result.make n style s;
result
);
-
+
- make n:STRING_CONSTANT style s:STRING_CONSTANT <-
(
name := n;
style := s;
);
-
-Section Public
-
+
+Section Public
+
+ style:STRING_CONSTANT;
-
+
- get n:STRING_CONSTANT style s:STRING_CONSTANT :SELF <-
- ( + result:SELF;
+ ( + result:SELF;
+ idx:INTEGER;
-
+
idx := dico_ts.lower;
{
(idx <= dico_ts.upper) && {
- (dico_ts.item idx.name != n) ||
+ (dico_ts.item idx.name != n) ||
{dico_ts.item idx.style != s}
}
}.while_do {
@@ -75,5 +75,5 @@ Section Public
};
result
);
-
+
diff --git a/src/item/itm_write.li b/src/item/itm_write.li
index 5648718..5d96aeb 100644
--- a/src/item/itm_write.li
+++ b/src/item/itm_write.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_WRITE;
- copyright := "2003-2007 Benoit Sonntag";
@@ -27,11 +27,11 @@ Section Header
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all write";
-
+
Section Inherit
-
+
+ parent_itm_code:Expanded ITM_CODE;
-
+
Section Public
//
@@ -41,17 +41,17 @@ Section Public
+ assign:ITM_CODE;
+ value:ITM_CODE;
-
+
- type:STRING_CONSTANT <-
(
deferred;
NULL
);
-
+
//
// Constructor
//
-
+
- create p:POSITION assign n:ITM_CODE with v:ITM_CODE :SELF <-
[ -? {p != 0}; ]
( + result:SELF;
@@ -59,7 +59,7 @@ Section Public
result.make p assign n with v;
result
);
-
+
- make p:POSITION assign n:ITM_CODE with v:ITM_CODE <-
(
position := p;
@@ -70,11 +70,11 @@ Section Public
//
// Access.
//
-
+
- get_simple_name:STRING_CONSTANT <-
( + result:STRING_CONSTANT;
+ without_arg:ITM_READ;
-
+
without_arg ?= assign;
(without_arg != NULL).if {
result := without_arg.name;
@@ -83,24 +83,24 @@ Section Public
};
result
);
-
+
//
// Display.
//
-
+
- append_in buffer:STRING <-
(
assign.append_in buffer;
buffer.append type;
value.append_in buffer;
);
-
+
Section Private
-
+
- affect name:STRING_CONSTANT with v:EXPR :EXPR <-
- ( + loc:LOCAL;
- + result:EXPR;
-
+ ( + loc:LOCAL;
+ + result:EXPR;
+
loc := lookup name;
(loc != NULL).if {
result := affect_local loc with v;
@@ -111,10 +111,10 @@ Section Private
);
- affect_local loc:LOCAL with v:EXPR :EXPR <-
- ( + e:INSTR;
- + result:EXPR;
+ ( + e:INSTR;
+ + result:EXPR;
+ val:EXPR;
-
+
(loc.style = '-').if {
result := affect_slot (loc.intern_name) with v;
} else {
@@ -122,11 +122,11 @@ Section Private
POSITION.put_error semantic text "Argument assignment is not possible.";
loc.position.put_position;
position.put_position;
- POSITION.send_error;
+ POSITION.send_error;
};
val := v.check_type (loc.type) with position;
- e := loc.write position value val;
- list_current.add_last e;
+ e := loc.write position value val;
+ list_current.add_last e;
result := loc.read position;
};
result
@@ -143,12 +143,12 @@ Section Private
+ em:EXPR_MULTIPLE;
+ new_val:EXPR;
+ lst:FAST_ARRAY(EXPR);
-
+
loc := lookup (ALIAS_STR.variable_self);
rec := loc.read position;
//
- type := rec.static_type.raw;
- slot := type.get_slot name;
+ type := rec.static_type.raw;
+ slot := type.get_slot name;
(slot = NULL).if {
string_tmp.copy "Slot `";
string_tmp.append name;
@@ -178,4 +178,4 @@ Section Private
result := node.result_expr;
result
);
-
+
diff --git a/src/item/itm_write_cast.li b/src/item/itm_write_cast.li
index 9784c45..5f91d5a 100644
--- a/src/item/itm_write_cast.li
+++ b/src/item/itm_write_cast.li
@@ -19,39 +19,39 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_WRITE_CAST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Assignment slot `?=' style";
-
+
Section Inherit
-
+
+ parent_itm_write:Expanded ITM_WRITE;
-
+
Section Public
- type:STRING_CONSTANT <- "?=";
//
- // Runnable
+ // Runnable
//
- to_run_expr:EXPR <-
( + val:EXPR;
+ loc:LOCAL;
- + node:NODE;
+ + node:NODE;
+ nm:STRING_CONSTANT;
+ typ_cast:TYPE_FULL;
+ slot:SLOT;
+ ts:ITM_TYPE_SIMPLE;
-
+
// Value -> local.
val := value.to_run_expr;
- loc := val.static_type.get_temporary position;
+ loc := val.static_type.get_temporary position;
list_current.add_last (loc.write position value val);
val := loc.read position;
// Assign.
@@ -60,7 +60,7 @@ Section Public
(loc != NULL).if {
typ_cast := loc.type;
} else {
- slot := profil_slot.type_self.get_slot nm;
+ slot := profil_slot.type_self.get_slot nm;
(slot = NULL).if {
string_tmp.copy "Slot `";
string_tmp.append nm;
@@ -70,7 +70,7 @@ Section Public
semantic_error (position,string_tmp);
};
ts ?= slot.result_type;
- typ_cast := ts.to_run_for profil_slot;
+ typ_cast := ts.to_run_for profil_slot;
};
(verify).if {
((typ_cast.affect_with (val.static_type)) && {! val.static_type.is_generic}).if {
@@ -79,7 +79,7 @@ Section Public
};
// Dispatch case.
node := NODE.new_cast position type typ_cast with val;
- list_current.add_last node;
+ list_current.add_last node;
// Assignment result.
affect nm with (node.result_expr)
// Value result.
diff --git a/src/item/itm_write_code.li b/src/item/itm_write_code.li
index 908b204..28c3d52 100644
--- a/src/item/itm_write_code.li
+++ b/src/item/itm_write_code.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_WRITE_CODE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Assignment slot with new code";
-
+
Section Inherit
-
+
+ parent_itm_write:Expanded ITM_WRITE;
-
+
Section Public
- type:STRING_CONSTANT <- "<-";
//
- // Runnable
+ // Runnable
//
- to_run_expr:EXPR <-
@@ -49,15 +49,15 @@ Section Public
+ type:TYPE_FULL;
+ slot:SLOT;
+ name:STRING_CONSTANT;
-
+
itm_read ?= assign;
name := itm_read.name;
- ? {itm_read != NULL};
+ ? {itm_read != NULL};
loc := lookup (ALIAS_STR.variable_self);
rec := loc.read position;
//
- type := rec.static_type;
- slot := type.get_slot name;
+ type := rec.static_type;
+ slot := type.get_slot name;
(slot = NULL).if {
string_tmp.copy "Slot `";
string_tmp.append name;
@@ -70,11 +70,11 @@ Section Public
node := NODE.new_write position slot slot receiver rec code value;
list_current.add_last node;
result := node.result_expr;
-
+
result
);
-
+
diff --git a/src/item/itm_write_value.li b/src/item/itm_write_value.li
index 19d75eb..43b8f57 100644
--- a/src/item/itm_write_value.li
+++ b/src/item/itm_write_value.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ITM_WRITE_VALUE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Write with a value";
-
+
Section Inherit
-
+
+ parent_itm_write:Expanded ITM_WRITE;
-
+
Section Public
- type:STRING_CONSTANT <- ":=";
//
- // Runnable
+ // Runnable
//
- to_run_expr:EXPR <-
@@ -49,26 +49,26 @@ Section Public
+ itm_read:ITM_READ;
+ lst_exp:FAST_ARRAY(EXPR);
+ result:EXPR;
-
+
val := value.to_run_expr;
-
- val_multiple ?= val;
+
+ val_multiple ?= val;
(val_multiple != NULL).if {
//
- // Assignment Vector.
+ // Assignment Vector.
//
lst_exp := FAST_ARRAY(EXPR).create_with_capacity (val_multiple.count);
ass_multiple ?= assign;
- (ass_multiple != NULL).if {
+ (ass_multiple != NULL).if {
lst_idf := ass_multiple.list_name;
(lst_idf.lower).to (lst_idf.upper-1) do { i:INTEGER;
j := affect (lst_idf.item i) with val_multiple index j in lst_exp;
- };
- j := affect (lst_idf.last) with val_multiple index j in lst_exp;
+ };
+ j := affect (lst_idf.last) with val_multiple index j in lst_exp;
} else {
itm_read ?= assign;
? {itm_read != NULL};
- j := affect (itm_read.name) with val_multiple index j in lst_exp;
+ j := affect (itm_read.name) with val_multiple index j in lst_exp;
};
(j <= val_multiple.upper).if {
semantic_error (position,"Incorrect size vector.");
@@ -77,30 +77,30 @@ Section Public
} else {
//
// Assignment simple.
- //
- itm_read ?= assign;
- ? {itm_read != NULL};
+ //
+ itm_read ?= assign;
+ ? {itm_read != NULL};
result := affect (itm_read.name) with val;
};
result
);
Section Private
-
- - affect idf:STRING_CONSTANT with val:EXPR_MULTIPLE
+
+ - affect idf:STRING_CONSTANT with val:EXPR_MULTIPLE
index n:INTEGER in lst:FAST_ARRAY(EXPR) :INTEGER <-
( + loc:LOCAL;
+ result:INTEGER;
+ slot:SLOT;
+ typ_multi:ITM_TYPE_MULTI;
+ lst_expr:FAST_ARRAY(EXPR);
-
+
(n > val.upper).if {
semantic_error (position,"Incorrect size vector.");
};
-
+
loc := lookup idf;
- (loc != NULL).if {
+ (loc != NULL).if {
lst.add_last (affect_local loc with (val.item n));
result := n + 1;
} else {
@@ -120,10 +120,10 @@ Section Private
semantic_error (position,"Incorrect size vector.");
};
//BSBS: Recycle les EXPR_MULTIPLE
- lst_expr := FAST_ARRAY(EXPR).create_with_capacity (typ_multi.count);
+ lst_expr := FAST_ARRAY(EXPR).create_with_capacity (typ_multi.count);
0.to (typ_multi.upper) do { i:INTEGER;
lst_expr.add_last (val.item (n+i));
- };
+ };
lst.add_last (affect_slot idf with (EXPR_MULTIPLE.create lst_expr));
} else {
lst.add_last (affect_slot idf with (val.item n));
diff --git a/src/lip/lip_affect.li b/src/lip/lip_affect.li
index 85595ae..9d87664 100644
--- a/src/lip/lip_affect.li
+++ b/src/lip/lip_affect.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_AFFECT;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,11 +32,11 @@ Section Inherit
+ parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ name:STRING_CONSTANT;
-
+
+ value:LIP_CODE;
-
+
//
// Creation.
//
@@ -49,20 +49,20 @@ Section Public
);
- make p:POSITION name n:STRING_CONSTANT value val:LIP_CODE <-
- (
+ (
position := p;
name := n;
value := val;
);
-
+
//
// Run.
//
-
+
- run <-
( + slot:LIP_SLOT_DATA;
+ val:LIP_CONSTANT;
-
+
slot := get_data name;
(slot = NULL).if {
string_tmp.copy "Slot `";
diff --git a/src/lip/lip_binary.li b/src/lip/lip_binary.li
index 077ee6a..35cdc14 100644
--- a/src/lip/lip_binary.li
+++ b/src/lip/lip_binary.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_BINARY;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,13 +32,13 @@ Section Inherit
+ parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ left:LIP_CODE;
-
+
+ right:LIP_CODE;
-
+
+ operator:CHARACTER;
-
+
//
// Creation.
//
@@ -51,23 +51,23 @@ Section Public
);
- make p:POSITION with l:LIP_CODE operator op:CHARACTER and r:LIP_CODE<-
- (
+ (
position := p;
left := l;
right := r;
operator := op;
);
-
+
//
// Run.
//
-
+
- run_expr:LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ lv,rv:LIP_CONSTANT;
-
+
lv := left.run_expr;
- rv := right.run_expr;
+ rv := right.run_expr;
(operator)
.when '|' then { result := lv | rv; }
.when '&' then { result := lv & rv; }
@@ -83,7 +83,7 @@ Section Public
operator.print; '\n'.print;
lv.print; '\n'.print;
rv.print; '\n'.print;
- semantic_error (position,"Incorrect type operator.");
+ semantic_error (position,"Incorrect type operator.");
};
- result
+ result
);
diff --git a/src/lip/lip_boolean.li b/src/lip/lip_boolean.li
index f55af7e..96d5d7a 100644
--- a/src/lip/lip_boolean.li
+++ b/src/lip/lip_boolean.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_BOOLEAN;
- copyright := "2003-2008 Sonntag Benoit";
@@ -30,31 +30,31 @@ Section Header
Section Inherit
+ parent_lip_constant:Expanded LIP_CONSTANT;
-
+
Section Private
-
- - true:LIP_BOOLEAN :=
+
+ - true:LIP_BOOLEAN :=
( + result:LIP_BOOLEAN;
result := clone;
result.set_value TRUE;
result
);
-
+
- false:LIP_BOOLEAN := LIP_BOOLEAN;
-
+
- set_value i:BOOLEAN <-
(
value := i;
);
-
+
Section Public
+ value:BOOLEAN;
-
+
//
// Creation.
//
-
+
- get b:BOOLEAN :LIP_BOOLEAN <-
( + result:LIP_BOOLEAN;
b.if {
@@ -64,45 +64,44 @@ Section Public
};
result
);
-
+
- free; // Nothing.
-
+
//
// Operation.
//
-
+
- name:STRING_CONSTANT <- "BOOLEAN";
-
+
- '!' Self:SELF :LIP_CONSTANT <- get (! value);
-
+
- copy:LIP_CONSTANT <- Self;
-
+
- print <-
(
value.print;
);
Section LIP_CONSTANT
-
+
- my_copy other:SELF :LIP_CONSTANT <- other;
-
- - Self:SELF '|#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '|#' other:SELF :LIP_CONSTANT <-
+ (
get (value | other.value)
);
-
- - Self:SELF '&#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '&#' other:SELF :LIP_CONSTANT <-
+ (
get (value & other.value)
);
-
- - Self:SELF '=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '=#' other:SELF :LIP_CONSTANT <-
+ (
get (value = other.value)
);
-
- - Self:SELF '!=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '!=#' other:SELF :LIP_CONSTANT <-
+ (
get (value != other.value)
);
-
\ No newline at end of file
diff --git a/src/lip/lip_call.li b/src/lip/lip_call.li
index fb2717f..7e5ab34 100644
--- a/src/lip/lip_call.li
+++ b/src/lip/lip_call.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_CALL;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,13 +32,13 @@ Section Inherit
+ parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ receiver:LIP_CODE;
-
+
+ name:STRING_CONSTANT;
-
+
+ argument:LIP_CODE;
-
+
//
// Creation.
//
@@ -54,7 +54,7 @@ Section Public
[
-? {p.code != 0};
]
- (
+ (
position := p;
receiver := rec;
name := n;
@@ -64,34 +64,34 @@ Section Public
//
// Run.
//
-
+
- run <-
( + slot:LIP_SLOT_CODE;
- + val,rec:LIP_CONSTANT;
- + str:LIP_STRING;
+ + val,rec:LIP_CONSTANT;
+ + str:LIP_STRING;
+ int:LIP_INTEGER;
+ path:STRING_CONSTANT;
+ is_rec:BOOLEAN;
+ idx:INTEGER;
-
-
+
+
(receiver != NULL).if {
rec := receiver.run_expr;
};
(argument != NULL).if {
- val := argument.run_expr;
- };
+ val := argument.run_expr;
+ };
(name = ALIAS_STR.slot_print).if {
(rec = NULL).if {
semantic_error (position,"Incorrect type.");
- };
- (val != NULL).if {
+ };
+ (val != NULL).if {
warning_error (position,"No argument for `print' method.");
};
- rec.print;
- }.elseif {name = ALIAS_STR.slot_die_with_code} then {
+ rec.print;
+ }.elseif {name = ALIAS_STR.slot_die_with_code} then {
int ?= val;
- (int = NULL).if {
+ (int = NULL).if {
semantic_error (position,"Integer argument needed.");
};
die_with_code (int.value);
@@ -110,22 +110,22 @@ Section Public
(str = NULL).if {
semantic_error (position,"String argument needed.");
};
- path := str.value;
+ path := str.value;
((! path.is_empty) && {path.last = '*'}).if {
- string_tmp.copy path;
- string_tmp.remove_last 1;
+ string_tmp.copy path;
+ string_tmp.remove_last 1;
path := ALIAS_STR.get string_tmp;
is_rec := TRUE;
- };
+ };
((path.is_empty) || {path.first != '/'}).if {
- string_tmp.copy (position.prototype.filename);
+ string_tmp.copy (position.prototype.filename);
idx := last_index_str (string_tmp,'/');
(idx < string_tmp.lower).if {
string_tmp.copy "./";
} else {
string_tmp.remove_last (string_tmp.upper-idx);
};
- string_tmp.append path;
+ string_tmp.append path;
path := ALIAS_STR.get string_tmp;
};
(path.is_empty).if_false {
@@ -135,11 +135,11 @@ Section Public
str ?= val;
(str = NULL).if {
semantic_error (position,"String argument needed.");
- };
+ };
string_tmp.clear;
str.append_in string_tmp;
- ENVIRONMENT.execute_command string_tmp;
- } else {
+ ENVIRONMENT.execute_command string_tmp;
+ } else {
slot := get_method name;
(slot = NULL).if {
string_tmp.copy "Slot `";
@@ -158,25 +158,25 @@ Section Public
val.free;
};
);
-
+
- run_expr:LIP_CONSTANT <-
( + slot:LIP_SLOT_DATA;
+ str:LIP_STRING;
+ val:LIP_CONSTANT;
+ result:LIP_CONSTANT;
+ res:INTEGER;
-
+
(argument != NULL).if {
- val := argument.run_expr;
- };
+ val := argument.run_expr;
+ };
(name = ALIAS_STR.slot_run).if {
str ?= val;
(str = NULL).if {
semantic_error (position,"String argument needed.");
- };
+ };
string_tmp.clear;
str.append_in string_tmp;
- res := ENVIRONMENT.execute_command string_tmp;
+ res := ENVIRONMENT.execute_command string_tmp;
result := LIP_INTEGER.get res;
}.elseif {name = ALIAS_STR.slot_get_integer} then {
{
@@ -184,8 +184,8 @@ Section Public
(IO.last_string.is_integer).if_false {
"Error INTEGER needed.\n".print;
};
- }.do_until {IO.last_string.is_integer};
- result := LIP_INTEGER.get (IO.last_string.to_integer);
+ }.do_until {IO.last_string.is_integer};
+ result := LIP_INTEGER.get (IO.last_string.to_integer);
}.elseif {name = ALIAS_STR.slot_get_string} then {
IO.read_line;
result := LIP_STRING.get (ALIAS_STR.get (IO.last_string));
@@ -199,7 +199,7 @@ Section Public
string_tmp.append "' not found.";
semantic_error (position,string_tmp);
};
- };
+ };
result := slot.get_value;
};
(val != NULL).if {
@@ -207,22 +207,22 @@ Section Public
};
result
);
-
+
- load_directory path:ABSTRACT_STRING is_recursive is_rec:BOOLEAN <-
( + entry:ENTRY;
+ dir:DIRECTORY;
-
- entry := FILE_SYSTEM.get_entry path;
+
+ entry := FILE_SYSTEM.get_entry path;
((entry != NULL) && {entry.is_directory} && {entry.open}).if {
- dir ?= entry;
+ dir ?= entry;
(dir.lower).to (dir.upper) do { j:INTEGER;
entry := dir.item j;
(entry.name.has_suffix ".li").if {
- path_file.add_last (entry.path);
+ path_file.add_last (entry.path);
}.elseif {(is_rec) && {entry.is_directory}} then {
load_directory (entry.path) is_recursive TRUE;
};
- };
+ };
} else {
string_tmp.copy "Incorrect directory `";
string_tmp.append path;
diff --git a/src/lip/lip_code.li b/src/lip/lip_code.li
index 94aeda6..9aecc01 100644
--- a/src/lip/lip_code.li
+++ b/src/lip/lip_code.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_CODE;
- copyright := "2003-2008 Sonntag Benoit";
@@ -28,29 +28,29 @@ Section Header
- comment := "The main prototype";
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
Section Public
-
+
- list_parent:FAST_ARRAY(STRING_CONSTANT) := FAST_ARRAY(STRING_CONSTANT).create_with_capacity 1;
-
- - list_method:FAST_ARRAY(LIP_SLOT_CODE) := FAST_ARRAY(LIP_SLOT_CODE).create_with_capacity 32;
-
+
+ - list_method:FAST_ARRAY(LIP_SLOT_CODE) := FAST_ARRAY(LIP_SLOT_CODE).create_with_capacity 32;
+
- list_data:HASHED_DICTIONARY(LIP_SLOT_DATA,STRING_CONSTANT) :=
HASHED_DICTIONARY(LIP_SLOT_DATA,STRING_CONSTANT).create;
-
+
- stack:FAST_ARRAY(LIP_SLOT_DATA) := FAST_ARRAY(LIP_SLOT_DATA).create_with_capacity 8;
-
+
- get_data n:STRING_CONSTANT :LIP_SLOT_DATA <-
(
list_data.fast_reference_at n
);
-
+
- get_method n:STRING_CONSTANT :LIP_SLOT_CODE <-
( + j:INTEGER;
+ result:LIP_SLOT_CODE;
-
+
j := list_method.lower;
{(j <= list_method.upper) && {list_method.item j.name != n}}.while_do {
j := j + 1;
@@ -60,11 +60,11 @@ Section Public
};
result
);
-
+
- print_usage <-
( + slot:LIP_SLOT_CODE;
+ is_ok:BOOLEAN;
-
+
(list_method.lower).to (list_method.upper) do { j:INTEGER;
slot := list_method.item j;
(slot.section = ALIAS_STR.section_public).if {
@@ -76,12 +76,12 @@ Section Public
"\t Sorry, no option (see `make.lip').\n".print;
};
);
-
+
- get_integer n:STRING_CONSTANT :INTEGER <-
( + d:LIP_SLOT_DATA;
+ int:LIP_INTEGER;
+ result:INTEGER;
-
+
d := get_data n;
(d = NULL).if {
"Warning: Slot `".print;
@@ -96,12 +96,12 @@ Section Public
};
result
);
-
+
- get_boolean n:STRING_CONSTANT :BOOLEAN <-
( + d:LIP_SLOT_DATA;
+ bool:LIP_BOOLEAN;
+ result:BOOLEAN;
-
+
d := get_data n;
(d = NULL).if {
"Warning: Slot `".print;
@@ -116,12 +116,12 @@ Section Public
};
result
);
-
+
- get_string n:STRING_CONSTANT :STRING_CONSTANT <-
( + d:LIP_SLOT_DATA;
+ str:LIP_STRING;
+ result:STRING_CONSTANT;
-
+
d := get_data n;
(d = NULL).if {
"Warning: Slot `".print;
@@ -136,78 +136,78 @@ Section Public
};
result
);
-
+
- put_string v:STRING_CONSTANT to n:STRING_CONSTANT <-
( + d:LIP_SLOT_DATA;
+ str:LIP_STRING;
-
+
d := get_data n;
(d = NULL).if {
"Warning: Slot `".print;
n.print;
- "' not found.\n".print;
+ "' not found.\n".print;
} else {
str ?= d.value;
(str = NULL).if {
semantic_error (d.position,"STRING type is needed.");
};
str.set_value v;
- };
+ };
);
-
+
- put_boolean v:BOOLEAN to n:STRING_CONSTANT <-
( + d:LIP_SLOT_DATA;
-
+
d := get_data n;
(d = NULL).if {
"Warning: Slot `".print;
n.print;
- "' not found.\n".print;
- } else {
+ "' not found.\n".print;
+ } else {
(d.set_value (LIP_BOOLEAN.get v)).if_false {
semantic_error (d.position,"BOOLEAN type is needed.");
- };
- };
+ };
+ };
);
-
+
//
// Run.
//
-
+
- run <-
(
warning_error (position,"Unreachable code.");
);
-
+
- run_expr:LIP_CONSTANT <-
(
semantic_error (position,"No expression result.");
NULL
);
-
+
- call_front_end <-
- ( + s:LIP_SLOT_CODE;
+ ( + s:LIP_SLOT_CODE;
// Executing `front_end':
s := LIP_CODE.get_method (ALIAS_STR.slot_front_end);
(s = NULL).if {
"Slot `front_end' not found in *.lip file.\n".print;
die_with_code exit_failure_code;
};
- s.run_with NULL;
+ s.run_with NULL;
);
-
+
- init_path_file order:BOOLEAN <-
( + k,i:INTEGER;
+ p1,p2:STRING_CONSTANT;
-
+
(order).if {
- path_file.bubble_sort_with { (a,b:STRING_CONSTANT);
+ path_file.bubble_sort_with { (a,b:STRING_CONSTANT);
b < a
- };
+ };
} else {
- path_file.bubble_sort_with { (a,b:STRING_CONSTANT);
+ path_file.bubble_sort_with { (a,b:STRING_CONSTANT);
b !< a
- };
+ };
};
k := path_file.upper;
path_begin := path_file.first.upper;
diff --git a/src/lip/lip_constant.li b/src/lip/lip_constant.li
index 6facb50..6ab138f 100644
--- a/src/lip/lip_constant.li
+++ b/src/lip/lip_constant.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_CONSTANT;
- copyright := "2003-2008 Sonntag Benoit";
@@ -28,19 +28,19 @@ Section Header
- comment := "The main prototype";
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
- name:STRING_CONSTANT <- ( deferred; NULL);
-
+
- copy:LIP_CONSTANT <-
(
deferred;
);
-
- - copy_of other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - copy_of other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -49,14 +49,14 @@ Section Public
};
result
);
-
+
- free <- deferred;
-
+
- '-' Self:SELF :LIP_CONSTANT <- NULL;
-
- - '!' Self:SELF :LIP_CONSTANT <- NULL;
- - Self:SELF '|' other:LIP_CONSTANT :LIP_CONSTANT <-
+ - '!' Self:SELF :LIP_CONSTANT <- NULL;
+
+ - Self:SELF '|' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -65,8 +65,8 @@ Section Public
};
result
);
-
- - Self:SELF '&' other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - Self:SELF '&' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -75,8 +75,8 @@ Section Public
};
result
);
-
- - Self:SELF '+' other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - Self:SELF '+' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -85,8 +85,8 @@ Section Public
};
result
);
-
- - Self:SELF '-' other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - Self:SELF '-' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -95,8 +95,8 @@ Section Public
};
result
);
-
- - Self:SELF '>' other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - Self:SELF '>' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -106,7 +106,7 @@ Section Public
result
);
- - Self:SELF '<' other:LIP_CONSTANT :LIP_CONSTANT <-
+ - Self:SELF '<' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -115,7 +115,7 @@ Section Public
};
result
);
-
+
- Self:SELF '~=' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
@@ -125,8 +125,8 @@ Section Public
};
result
);
-
- - Self:SELF '>=' other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - Self:SELF '>=' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -135,8 +135,8 @@ Section Public
};
result
);
-
- - Self:SELF '<=' other:LIP_CONSTANT :LIP_CONSTANT <-
+
+ - Self:SELF '<=' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
s ?= other;
@@ -145,7 +145,7 @@ Section Public
};
result
);
-
+
- Self:SELF '!~=' other:LIP_CONSTANT :LIP_CONSTANT <-
( + result:LIP_CONSTANT;
+ s:SELF;
@@ -155,30 +155,30 @@ Section Public
};
result
);
-
+
- print <- deferred;
-
+
Section LIP_CONSTANT
-
+
- my_copy other:SELF :LIP_CONSTANT <- NULL;
-
+
- Self:SELF '|#' other:SELF :LIP_CONSTANT <- NULL;
-
- - Self:SELF '&#' other:SELF :LIP_CONSTANT <- NULL;
-
+
+ - Self:SELF '&#' other:SELF :LIP_CONSTANT <- NULL;
+
- Self:SELF '+#' other:SELF :LIP_CONSTANT <- NULL;
-
- - Self:SELF '-#' other:SELF :LIP_CONSTANT <- NULL;
-
+
+ - Self:SELF '-#' other:SELF :LIP_CONSTANT <- NULL;
+
- Self:SELF '>#' other:SELF :LIP_CONSTANT <- NULL;
- Self:SELF '<#' other:SELF :LIP_CONSTANT <- NULL;
-
+
- Self:SELF '=#' other:SELF :LIP_CONSTANT <- NULL;
-
+
- Self:SELF '>=#' other:SELF :LIP_CONSTANT <- NULL;
-
+
- Self:SELF '<=#' other:SELF :LIP_CONSTANT <- NULL;
-
+
- Self:SELF '!=#' other:SELF :LIP_CONSTANT <- NULL;
diff --git a/src/lip/lip_if.li b/src/lip/lip_if.li
index 3e42fcc..a3637d5 100644
--- a/src/lip/lip_if.li
+++ b/src/lip/lip_if.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_IF;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,18 +32,18 @@ Section Inherit
+ parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ condition:LIP_CODE;
-
+
+ then:FAST_ARRAY(LIP_CODE);
-
+
+ else:FAST_ARRAY(LIP_CODE);
-
+
//
// Creation.
//
- - create p:POSITION if rec:LIP_CODE then the:FAST_ARRAY(LIP_CODE)
+ - create p:POSITION if rec:LIP_CODE then the:FAST_ARRAY(LIP_CODE)
else els:FAST_ARRAY(LIP_CODE) :SELF <-
( + result:SELF;
result := clone;
@@ -51,9 +51,9 @@ Section Public
result
);
- - make p:POSITION if rec:LIP_CODE then the:FAST_ARRAY(LIP_CODE)
+ - make p:POSITION if rec:LIP_CODE then the:FAST_ARRAY(LIP_CODE)
else els:FAST_ARRAY(LIP_CODE) <-
- (
+ (
position := p;
condition := rec;
then := the;
@@ -65,14 +65,14 @@ Section Public
warning_error (else.last.position,"Unreachable expression.");
};
);
-
+
//
// Run.
//
-
+
- run <-
( + val:LIP_BOOLEAN;
-
+
val ?= condition.run_expr;
(val = NULL).if {
semantic_error (position,"BOOLEAN needed.");
@@ -80,7 +80,7 @@ Section Public
(val.value).if {
(then.lower).to (then.upper-1) do { i:INTEGER;
then.item i.run;
- };
+ };
}.elseif {else != NULL} then {
(else.lower).to (else.upper-1) do { i:INTEGER;
else.item i.run;
diff --git a/src/lip/lip_integer.li b/src/lip/lip_integer.li
index 18c1d6e..10f8567 100644
--- a/src/lip/lip_integer.li
+++ b/src/lip/lip_integer.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_INTEGER;
- copyright := "2003-2008 Sonntag Benoit";
@@ -30,24 +30,24 @@ Section Header
Section Inherit
+ parent_lip_constant:Expanded LIP_CONSTANT;
-
+
Section Private
-
+
- storage:FAST_ARRAY(LIP_INTEGER) := FAST_ARRAY(LIP_INTEGER).create_with_capacity 10;
-
+
- set_value v:INTEGER <-
(
value := v;
);
-
+
Section Public
-
+
+ value:INTEGER;
-
+
//
// Creation.
//
-
+
- get i:INTEGER :LIP_INTEGER <-
( + result:LIP_INTEGER;
(storage.is_empty).if {
@@ -59,113 +59,113 @@ Section Public
result.set_value i;
result
);
-
+
- free <-
(
storage.add_last Self;
);
-
+
//
// Operation.
//
-
+
- name:STRING_CONSTANT <- "INTEGER";
-
+
- '-' Self:SELF :LIP_CONSTANT <-
- (
+ (
value := - value;
Self
);
- '!' Self:SELF :LIP_CONSTANT <-
- (
+ (
value := ~ value;
Self
);
-
+
- copy:LIP_CONSTANT <-
(
get value
);
-
+
- print <-
(
value.print;
);
-
+
Section LIP_CONSTANT
-
+
- my_copy other:SELF :LIP_CONSTANT <-
(
value := other.value;
Self
);
-
+
- Self:SELF '|#' other:SELF :LIP_CONSTANT <-
- (
+ (
value := value | other.value;
other.free;
Self
);
-
- - Self:SELF '&#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '&#' other:SELF :LIP_CONSTANT <-
+ (
value := value & other.value;
other.free;
Self
);
-
- - Self:SELF '+#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '+#' other:SELF :LIP_CONSTANT <-
+ (
value := value + other.value;
other.free;
- Self
+ Self
);
-
+
- Self:SELF '-#' other:SELF :LIP_CONSTANT <-
- (
+ (
value := value - other.value;
other.free;
Self
);
-
+
- Self:SELF '>#' other:SELF :LIP_CONSTANT <-
- (
+ (
other.free;
free;
LIP_BOOLEAN.get (value > other.value)
);
-
- - Self:SELF '<#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '<#' other:SELF :LIP_CONSTANT <-
+ (
other.free;
free;
LIP_BOOLEAN.get (value < other.value)
);
-
- - Self:SELF '=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '=#' other:SELF :LIP_CONSTANT <-
+ (
other.free;
free;
LIP_BOOLEAN.get (value = other.value)
);
-
- - Self:SELF '>=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '>=#' other:SELF :LIP_CONSTANT <-
+ (
other.free;
free;
LIP_BOOLEAN.get (value >= other.value)
);
-
+
- Self:SELF '<=#' other:SELF :LIP_CONSTANT <-
- (
+ (
other.free;
free;
LIP_BOOLEAN.get (value <= other.value)
);
-
- - Self:SELF '!=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '!=#' other:SELF :LIP_CONSTANT <-
+ (
other.free;
free;
LIP_BOOLEAN.get (value != other.value)
diff --git a/src/lip/lip_list.li b/src/lip/lip_list.li
index 8a4f5b6..2d791f1 100644
--- a/src/lip/lip_list.li
+++ b/src/lip/lip_list.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_LIST;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,9 +32,9 @@ Section Inherit
+ parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ list:FAST_ARRAY(LIP_CODE);
-
+
//
// Creation.
//
@@ -47,15 +47,15 @@ Section Public
);
- make p:POSITION with v:FAST_ARRAY(LIP_CODE) <-
- (
+ (
position := p;
list := v;
);
-
+
//
// Run.
//
-
+
- run <-
(
run_intern;
@@ -63,18 +63,18 @@ Section Public
semantic_error (position,"Incorrect expression.");
};
);
-
+
- run_expr:LIP_CONSTANT <-
- (
+ (
run_intern;
(list.last = NULL).if {
semantic_error (position,"Unreachable expression.");
};
list.last.run_expr
);
-
+
Section Private
-
+
- run_intern <-
(
(list.lower).to (list.upper-1) do { i:INTEGER;
diff --git a/src/lip/lip_slot_code.li b/src/lip/lip_slot_code.li
index 9521613..59d9917 100644
--- a/src/lip/lip_slot_code.li
+++ b/src/lip/lip_slot_code.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_SLOT_CODE;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,94 +32,94 @@ Section Inherit
- parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ section:STRING_CONSTANT;
-
+
+ name:STRING_CONSTANT;
-
+
+ argument:LIP_SLOT_DATA;
-
+
+ code:LIP_CODE;
-
+
+ comment:STRING_CONSTANT;
-
+
// + comment_chapter:STRING_CONSTANT;
-
+
- set_comment c:STRING_CONSTANT <-
(
comment := c;
);
-
+
/*
- set_comment_chapter cmt:STRING_CONSTANT <-
(
comment_chapter := cmt;
);
*/
-
+
//
// Creation.
//
- - create p:POSITION section sec:STRING_CONSTANT
- name n:STRING_CONSTANT
+ - create p:POSITION section sec:STRING_CONSTANT
+ name n:STRING_CONSTANT
argument arg:LIP_SLOT_DATA
code c:LIP_CODE :LIP_SLOT_CODE <-
( + result:LIP_SLOT_CODE;
-
+
result := get_method n;
(result != NULL).if {
((arg = NULL) ^ (result.argument = NULL)).if {
semantic_error (result.position,"Incorrect redefinition.");
- };
- } else {
+ };
+ } else {
result := clone;
- result.make p section sec name n argument arg code c;
+ result.make p section sec name n argument arg code c;
};
result
);
- - make p:POSITION section sec:STRING_CONSTANT
- name n:STRING_CONSTANT
- argument arg:LIP_SLOT_DATA
+ - make p:POSITION section sec:STRING_CONSTANT
+ name n:STRING_CONSTANT
+ argument arg:LIP_SLOT_DATA
code c:LIP_CODE <-
- (
+ (
position := p;
section := sec;
name := n;
- argument := arg;
- code := c;
+ argument := arg;
+ code := c;
list_method.add_last Self;
);
-
+
//
// Operation.
//
-
+
- run_with val:LIP_CONSTANT :BOOLEAN <-
( + result:BOOLEAN;
-
+
result := ! ((val = NULL) ^ (argument = NULL));
- (result).if {
+ (result).if {
(argument != NULL).if {
? { val != NULL };
- result := argument.set_value val;
- stack.add_last argument;
+ result := argument.set_value val;
+ stack.add_last argument;
} else {
stack.add_last NULL;
};
- (result).if {
+ (result).if {
code.run;
};
stack.remove_last;
};
result
);
-
+
//
// Print.
//
-
+
- print <-
(
" -".print;
@@ -130,7 +130,7 @@ Section Public
">".print;
};
":\n".print;
- (comment != NULL).if {
+ (comment != NULL).if {
'\t'.print;
(comment.lower).to (comment.upper) do { i:INTEGER;
comment.item i.print;
@@ -142,4 +142,4 @@ Section Public
"\t Sorry, no comment (see `make.lip').\n".print;
};
);
-
+
diff --git a/src/lip/lip_slot_data.li b/src/lip/lip_slot_data.li
index d52391b..0e5c930 100644
--- a/src/lip/lip_slot_data.li
+++ b/src/lip/lip_slot_data.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_SLOT_DATA;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,16 +32,16 @@ Section Inherit
+ parent_lip_slot:Expanded LIP_CODE;
Section Public
-
+
+ name:STRING_CONSTANT;
-
+
+ value:LIP_CONSTANT;
-
+
//
// Creation.
//
- - create p:POSITION name n:STRING_CONSTANT value v:LIP_CONSTANT
+ - create p:POSITION name n:STRING_CONSTANT value v:LIP_CONSTANT
argument is_arg:BOOLEAN :SELF <-
[
-? {v != NULL};
@@ -61,39 +61,38 @@ Section Public
semantic_error (s.position,"Double declaration.");
};
name := n;
- value := v;
+ value := v;
(is_arg).if_false {
list_data.add Self to n;
- };
+ };
);
-
+
//
// Value.
//
-
+
- set_value v:LIP_CONSTANT :BOOLEAN <-
( + new_val:LIP_CONSTANT;
-
+
new_val := value.copy_of v;
- (new_val != NULL).if {
- value := new_val;
- }
+ (new_val != NULL).if {
+ value := new_val;
+ }
);
-
+
- get_value:LIP_CONSTANT <-
(
value.copy
);
-
+
//
// Print.
//
-
+
- print <-
(
name.print;
':'.print;
value.name.print;
);
-
-
\ No newline at end of file
+
diff --git a/src/lip/lip_string.li b/src/lip/lip_string.li
index 04f11a5..d87c851 100644
--- a/src/lip/lip_string.li
+++ b/src/lip/lip_string.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_STRING;
- copyright := "2003-2008 Sonntag Benoit";
@@ -30,13 +30,13 @@ Section Header
Section Inherit
+ parent_lip_constant:Expanded LIP_CONSTANT;
-
+
Section Private
-
+
- storage:FAST_ARRAY(LIP_STRING) := FAST_ARRAY(LIP_STRING).create_with_capacity 10;
-
+
Section Public
-
+
+ value:STRING_CONSTANT;
- set_value v:STRING_CONSTANT <-
@@ -47,64 +47,64 @@ Section Public
//
// Creation.
//
-
+
- get str:STRING_CONSTANT :LIP_STRING <-
( + result:LIP_STRING;
(storage.is_empty).if {
result := clone;
} else {
result := storage.last;
- storage.remove_last;
+ storage.remove_last;
};
result.set_value str;
result
);
-
+
- free <-
- (
+ (
storage.add_last Self;
);
-
+
//
// Operation.
//
-
+
- name:STRING_CONSTANT <- "STRING";
-
+
- copy:LIP_CONSTANT <-
(
get value
);
-
+
- print <-
- (
- string_tmp.clear;
+ (
+ string_tmp.clear;
append_in string_tmp;
string_tmp.print;
);
-
+
- append_in str:STRING <-
( + i:INTEGER;
+ car:CHARACTER;
-
+
i := value.lower;
{i <= value.upper}.while_do {
car := value.item i;
- (car = '\\').if {
+ (car = '\\').if {
i := i + 1;
(i <= value.upper).if {
car := value.item i;
(car)
.when 'a' then { str.add_last '\a'; }
.when 'b' then { str.add_last '\b'; }
- .when 'f' then { str.add_last '\f'; }
- .when 'n' then { str.add_last '\n'; }
- .when 'r' then { str.add_last '\r'; }
- .when 't' then { str.add_last '\t'; }
- .when 'v' then { str.add_last '\v'; }
- .when '\\' then { str.add_last '\\'; }
- .when '?' then { str.add_last '\?'; }
- .when '\'' then { str.add_last '\''; }
+ .when 'f' then { str.add_last '\f'; }
+ .when 'n' then { str.add_last '\n'; }
+ .when 'r' then { str.add_last '\r'; }
+ .when 't' then { str.add_last '\t'; }
+ .when 'v' then { str.add_last '\v'; }
+ .when '\\' then { str.add_last '\\'; }
+ .when '?' then { str.add_last '\?'; }
+ .when '\'' then { str.add_last '\''; }
.when '\"' then { str.add_last '\"'; };
} else {
str.add_last car;
@@ -115,35 +115,34 @@ Section Public
i := i + 1;
};
);
-
+
Section LIP_CONSTANT
-
+
- my_copy other:SELF :LIP_CONSTANT <-
(
value := other.value;
Self
);
-
- - Self:SELF '=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '=#' other:SELF :LIP_CONSTANT <-
+ (
other.free;
free;
LIP_BOOLEAN.get (value = other.value)
);
-
- - Self:SELF '!=#' other:SELF :LIP_CONSTANT <-
- (
+
+ - Self:SELF '!=#' other:SELF :LIP_CONSTANT <-
+ (
other.free;
free;
LIP_BOOLEAN.get (value != other.value)
);
-
+
- Self:SELF '+#' other:SELF :LIP_CONSTANT <-
- (
+ (
string_tmp.copy value;
string_tmp.append (other.value);
value := ALIAS_STR.get string_tmp;
other.free;
Self
);
-
\ No newline at end of file
diff --git a/src/lip/lip_unary.li b/src/lip/lip_unary.li
index 979e143..10f5f2d 100644
--- a/src/lip/lip_unary.li
+++ b/src/lip/lip_unary.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_UNARY;
- copyright := "2003-2008 Sonntag Benoit";
@@ -29,14 +29,14 @@ Section Header
Section Inherit
- + parent_lip_code:Expanded LIP_CODE;
+ + parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ value:LIP_CODE;
-
+
+ operator:CHARACTER;
-
+
//
// Creation.
//
@@ -49,25 +49,25 @@ Section Public
);
- make p:POSITION operator op:CHARACTER with v:LIP_CODE <-
- (
- position := p;
+ (
+ position := p;
operator := op;
value := v;
);
-
+
//
// Run.
//
-
+
- run_expr:LIP_CONSTANT <-
( + result:LIP_CONSTANT;
-
- result := value.run_expr;
+
+ result := value.run_expr;
(operator)
.when '-' then { result := - result; }
.when '!' then { result := ! result; };
(result = NULL).if {
semantic_error (position,"Incorrect type.");
};
- result
+ result
);
diff --git a/src/lip/lip_value.li b/src/lip/lip_value.li
index 24a1179..24251c3 100644
--- a/src/lip/lip_value.li
+++ b/src/lip/lip_value.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LIP_VALUE;
- copyright := "2003-2008 Sonntag Benoit";
@@ -32,9 +32,9 @@ Section Inherit
+ parent_lip_code:Expanded LIP_CODE;
Section Public
-
+
+ value:LIP_CONSTANT;
-
+
//
// Creation.
//
@@ -47,15 +47,15 @@ Section Public
);
- make p:POSITION with v:LIP_CONSTANT <-
- (
+ (
position := p;
value := v;
);
-
+
//
// Run.
//
-
+
- run_expr:LIP_CONSTANT <-
(
value.copy
diff --git a/src/lisaac.li b/src/lisaac.li
index 6bb3318..ad94317 100644
--- a/src/lisaac.li
+++ b/src/lisaac.li
@@ -375,7 +375,7 @@ Section Private
+ key:UINTEGER_32;
title "SOURCE LINE REFERENCE" in output_decl;
-
+
buf.append
"struct __source {\n\
\ unsigned int pos;\n\
@@ -383,7 +383,7 @@ Section Private
\} __src[";
src := PUSH.source_line;
src.count.append_in buf;
- buf.append "]={\n";
+ buf.append "]={\n";
(src.lower).to (src.upper) do { j:INTEGER;
key := src.key j;
output_decl.append "#define L";
@@ -392,7 +392,7 @@ Section Private
(j-1).append_in output_decl;
output_decl.add_last '\n';
//
- buf.append " {";
+ buf.append " {";
key.append_in buf;
buf.append ",\"";
buf.append (src.item j);
@@ -416,12 +416,12 @@ Section Private
\ die_with_code(1); \n\
\} \n\n";
};
-
+
//
// Stack manager.
//
- buf.append
+ buf.append
"void lisaac_push_first(_____CONTEXT *path,unsigned long code)\n\
\{ \n";
(debug_level_option = 20).if {
@@ -430,7 +430,7 @@ Section Private
\ cur = top_context; \n\
\ while ((cur != (void *)0) && (cur != path)) cur = cur->back; \n\
\ if (cur == path) {\n\
- \ loop.back = top_context;\n\
+ \ loop.back = top_context;\n\
\ loop.code = code; \n\
\ lisaac_stack_print(&loop);\n\
\ print_string(\"COMPILER: Debug context looping detected !\\n\");\n\
@@ -444,7 +444,7 @@ Section Private
\} \n\
\ \n\
\void lisaac_push(_____CONTEXT *path,unsigned long code)\n\
- \{ \n\
+ \{ \n\
\ path->code = code;\n\
\ top_context = path;\n\
\} \n\
@@ -479,8 +479,8 @@ Section Private
\ }; \n\
\ print_char('^'); \n\
\ print_char('\\n'); \n\
-\ }; \n";
-
+\ }; \n";
+
} else {
buf.append
" print_string(\"Line #\"); \n\
@@ -500,7 +500,7 @@ Section Private
\ \n\
\void print_integer(unsigned short n) \n\
\{ unsigned short val; \n\
- \ char car; \n\
+ \ char car; \n\
\ car = (n % 10) + '0'; \n\
\ val = n / 10; \n\
\ if (val != 0) print_integer(val); \n\
@@ -859,14 +859,14 @@ Section Public
'\n'.print;
};
};
-
+
/*
PROFIL.list_cpa.lower.to (PROFIL.list_cpa.upper) do { i:INTEGER;
PROFIL.list_cpa.item i.print;
'\n'.print;
};
*/
-
+
//
// Execute finality command (front end).
//
diff --git a/src/make.lip b/src/make.lip
index 7c28fde..7dbf052 100644
--- a/src/make.lip
+++ b/src/make.lip
@@ -19,15 +19,15 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Inherit
-
+
+ parent:STRING;
Section Private
-
+
+ is_valid:BOOLEAN;
-
+
- src_path <-
- (
+ (
path "./";
path "tools/";
path "type/";
@@ -39,67 +39,66 @@ Section Private
path "external/arithmetic/";
path "external/comparison/";
path "dispatcher/";
- path "code_life/";
- path "lip/";
+ path "code_life/";
+ path "lip/";
);
-
+
- compiler_path <-
(
- src_path;
+ src_path;
input_file := "lisaac";
path "compiler_any/";
);
-
+
- shorter_path <-
(
- src_path;
+ src_path;
input_file := "shorter";
path "shorter_any/";
);
-
+
//
// Execute function.
//
-
+
- front_end <-
- (
- general_front_end;
- ((input_file = "") | (input_file = "lisaac")).if {
+ (
+ general_front_end;
+ ((input_file = "") | (input_file = "lisaac")).if {
compiler_path;
(is_valid).if {
boost;
};
- };
+ };
);
-
+
- back_end <-
(
general_back_end;
(is_valid).if {
execute "cp lisaac.c ../bin/.";
execute "cp lisaac ../bin/.";
- };
+ };
);
-
+
Section Public
-
+
- compiler <-
// Compile the Lisaac compiler.
(
compiler_path;
);
-
+
- shorter <-
// Compile the shorter.
(
shorter_path;
);
-
+
- valid <-
- // Compile the Lisaac compiler with `-boost' option and
+ // Compile the Lisaac compiler with `-boost' option and
// update your `/bin' compiler version.
(
- is_valid := TRUE;
+ is_valid := TRUE;
);
-
-
\ No newline at end of file
+
diff --git a/src/parameter_to_type.li b/src/parameter_to_type.li
index 50900ad..14bea7b 100644
--- a/src/parameter_to_type.li
+++ b/src/parameter_to_type.li
@@ -19,23 +19,23 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PARAMETER_TO_TYPE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type parameter -> type full";
-
+
Section Public
-
- - position:POSITION <-
+
+ - position:POSITION <-
( + result:POSITION;
deferred;
result
);
-
+
- parameter_to_type p:ITM_TYPE_PARAMETER :TYPE_FULL <-
(
deferred;
diff --git a/src/parser.li b/src/parser.li
index 87b085d..08a22d4 100644
--- a/src/parser.li
+++ b/src/parser.li
@@ -19,42 +19,42 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PARSER;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parser for Lisaac language.";
-
- // You can to get with
+
+ // You can to get with
// `grep "//++" parser.li' : Current grammar.
// `grep "//--" parser.li' : Syntax rules.
- // `grep "////" parser.li' : lip grammar.
+ // `grep "////" parser.li' : lip grammar.
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
//
// Shorter Section.
//
-
+
- is_active_short:BOOLEAN;
-
+
- short_dico:HASHED_DICTIONARY(LINKED_LIST(STRING_CONSTANT),STRING_CONSTANT) :=
HASHED_DICTIONARY(LINKED_LIST(STRING_CONSTANT),STRING_CONSTANT).create;
-
+
- short_derive:INTEGER;
-
+
- token:STRING := STRING.create 100;
-
+
- short key:STRING_CONSTANT token beg:INTEGER to end:INTEGER <-
( + pos:INTEGER;
+ add_text:ABSTRACT_STRING;
+ fmt:LINKED_LIST(STRING_CONSTANT);
-
+
(is_shorter).if {
(is_active_short).if {
//
@@ -66,57 +66,57 @@ Section Public
pos := beg + short_derive;
beg.to (end-1) do { j:INTEGER;
token.add_last (source.item j);
- output_code.remove pos;
- };
+ output_code.remove pos;
+ };
short_derive := short_derive - token.count;
// Insert format.
- fmt := short_dico.at key;
+ fmt := short_dico.at key;
fmt.lower.to (fmt.upper) do { j:INTEGER;
(fmt.item j = NULL).if {
add_text := token;
} else {
add_text := fmt.item j;
- };
- output_code.insert_string add_text to pos;
+ };
+ output_code.insert_string add_text to pos;
pos := pos + add_text.count;
- short_derive := short_derive + add_text.count;
+ short_derive := short_derive + add_text.count;
};
};
};
};
);
-
+
- short_remove begin:INTEGER to end:INTEGER <-
(
- output_code.remove_between
- (begin + short_derive) to (end + short_derive);
+ output_code.remove_between
+ (begin + short_derive) to (end + short_derive);
short_derive := short_derive - (end - begin + 1);
);
-
+
- short_local:HASHED_SET(STRING_CONSTANT);
-
-Section Private
-
+
+Section Private
+
//
// Source information.
//
-
+
- object : PROTOTYPE;
-
+
- source : STRING;
-
+
- position : INTEGER;
-
+
- pos_cur : INTEGER;
- pos_line : INTEGER;
- pos_col : INTEGER;
-
+
- begin_position:INTEGER; // begin item position
-
+
- current_position:POSITION <-
( + result:POSITION;
? {pos_cur <= position};
-
+
{pos_cur = position}.until_do {
(source.item pos_cur = '\n').if {
pos_col := 0;
@@ -136,18 +136,18 @@ Section Private
};
POSITION.create object line pos_line column pos_col
);
-
+
//
// AMBIGU Manager.
//
-
+
- old_position:INTEGER;
- old_pos_cur :INTEGER;
- old_pos_line:INTEGER;
- old_pos_col :INTEGER;
//
- old_short_derive:INTEGER;
-
+
- save_context <-
(
old_position := position;
@@ -157,27 +157,27 @@ Section Private
//
old_short_derive := short_derive;
);
-
+
- restore_context <-
( + beg:INTEGER;
-
+
(is_shorter).if {
- token.clear;
- beg := old_position + old_short_derive;
+ token.clear;
+ beg := old_position + old_short_derive;
output_code.remove_between beg to (position+short_derive-1);
(old_position).to (position-1) do { j:INTEGER;
token.add_last (source.item j);
- };
+ };
output_code.insert_string token to beg;
short_derive := old_short_derive;
};
-
+
position := old_position;
pos_cur := old_pos_cur;
pos_line := old_pos_line;
pos_col := old_pos_col;
);
-
+
//
// Syntax parser.
//
@@ -196,12 +196,12 @@ Section Private
- last_real : STRING_CONSTANT;
- last_string : STRING_CONSTANT;
- is_parameter_type:BOOLEAN;
-
+
- last_comment_extern:STRING_CONSTANT;
- last_comment_slot :STRING_CONSTANT;
- skip_comment:BOOLEAN;
-
- - put_new_line_comment str:STRING with cmt:STRING_CONSTANT <-
+
+ - put_new_line_comment str:STRING with cmt:STRING_CONSTANT <-
( + lst:LINKED_LIST(STRING_CONSTANT);
+ idx,idx_beg:INTEGER;
lst := PARSER.short_dico.fast_reference_at cmt;
@@ -210,75 +210,75 @@ Section Private
idx_beg := idx;
idx := idx + 1;
{
- (idx <= str.upper) &&
- {str.item idx <= ' ' } &&
+ (idx <= str.upper) &&
+ {str.item idx <= ' ' } &&
{str.item idx != '\n'}
}.while_do {
idx := idx + 1;
- };
+ };
(str.item idx = '\n').if {
str.replace_substring (lst.first) from idx_beg to (idx-1);
idx := idx_beg + (lst.first.count)-1;
};
};
- };
+ };
);
-
+
- read_space:BOOLEAN <-
- ( + posold,pos,pos2:INTEGER;
+ ( + posold,pos,pos2:INTEGER;
+ level_comment:INTEGER;
+ stat:INTEGER;
-
-
+
+
pos := position;
- posold := -1;
+ posold := -1;
(is_shorter2).if {
string_tmp3.clear;
string_tmp4.clear;
};
{posold = position}.until_do {
posold := position;
-
- // Skip spaces :
- {(last_character = 0.to_character) || {last_character > ' '}}.until_do {
+
+ // Skip spaces :
+ {(last_character = 0.to_character) || {last_character > ' '}}.until_do {
((is_shorter2) || {is_shorter}).if {
(last_character = '\n').if {
(stat)
.when 0 then { stat := 1; }
.when 1 then { stat := 2; }
- .when 2 then { };
+ .when 2 then { };
};
};
- position := position + 1;
+ position := position + 1;
};
-
+
(position < source.upper).if {
// Skip C++ comment style :
((last_character = '/') && {source.item (position + 1) = '/'}).if {
position := position + 2;
- pos2 := position;
- {
- (last_character = 0.to_character) ||
+ pos2 := position;
+ {
+ (last_character = 0.to_character) ||
{last_character = '\n'}
- }.until_do {
+ }.until_do {
(is_shorter2).if {
(stat)
- .when 0 or 1 then {
+ .when 0 or 1 then {
string_tmp3.add_last last_character;
}
- .when 2 then {
+ .when 2 then {
string_tmp4.add_last last_character;
- };
+ };
};
position := position + 1;
};
(is_shorter2).if {
(stat)
.when 0 or 1 then { string_tmp3.add_last '\n'; }
- .when 2 then { string_tmp4.add_last '\n'; };
+ .when 2 then { string_tmp4.add_last '\n'; };
};
(is_shorter).if {
- // BSBS: A revoir ...
+ // BSBS: A revoir ...
((pos2-2+short_derive).in_range (output_code.lower) to (output_code.upper)).if {
output_code.remove_between (pos2-2+short_derive) to (pos2-1+short_derive);
short_derive := short_derive - 2;
@@ -311,7 +311,7 @@ Section Private
// Skip C comment style :
pos2 := position;
((last_character = '/') && {source.item (position+1) = '*'}).if {
- position := position + 2;
+ position := position + 2;
level_comment := 1;
{
(last_character = 0.to_character) || {level_comment = 0}
@@ -337,12 +337,12 @@ Section Private
};
};
};
- ((is_shorter2) && {! skip_comment}).if {
+ ((is_shorter2) && {! skip_comment}).if {
(string_tmp3.is_empty).if {
last_comment_slot := NULL;
} else {
- put_new_line_comment string_tmp3 with (ALIAS_STR.short_comment_new_line_slot);
- last_comment_slot := ALIAS_STR.get string_tmp3;
+ put_new_line_comment string_tmp3 with (ALIAS_STR.short_comment_new_line_slot);
+ last_comment_slot := ALIAS_STR.get string_tmp3;
};
(string_tmp4.is_empty).if_false {
put_new_line_comment string_tmp4 with (ALIAS_STR.short_comment_new_line_extern);
@@ -353,7 +353,7 @@ Section Private
begin_position := position;
((position != pos) | (last_character != 0.to_character))
);
-
+
- read_symbol st:STRING_CONSTANT :BOOLEAN <-
( + posold,j:INTEGER;
+ result:BOOLEAN;
@@ -361,7 +361,7 @@ Section Private
(! read_space).if {
result := FALSE;
} else {
- posold := position;
+ posold := position;
j := st.lower;
{(last_character = 0.to_character) ||
{(j > st.upper) || {last_character != st.item j}}}.until_do {
@@ -392,15 +392,15 @@ Section Private
};
result
);
-
+
//-- affect -> ":=" | "<-" | "?="
- read_affect:BOOLEAN <-
- (
+ (
(read_symbol (ALIAS_STR.symbol_affect_immediate)) ||
{read_symbol (ALIAS_STR.symbol_affect_cast)} ||
{read_symbol (ALIAS_STR.symbol_affect_code)}
);
-
+
//-- style -> '-' | '+'
- read_style:CHARACTER <-
( + result:CHARACTER;
@@ -415,7 +415,7 @@ Section Private
};
result
);
-
+
//-- identifier -> 'a'-'z' {'a'-'z' | '0'-'9' | '_'}
- read_identifier:BOOLEAN <-
( + result:BOOLEAN;
@@ -425,22 +425,22 @@ Section Private
((! read_space) || {! last_character.is_lower}).if {
result := FALSE;
} else {
- posold := position;
+ posold := position;
string_tmp.clear;
{
- (last_character = 0.to_character) ||
+ (last_character = 0.to_character) ||
{
(! last_character.is_lower) &&
- {! last_character.is_digit} &&
+ {! last_character.is_digit} &&
{last_character != '_'}
}
}.until_do {
string_tmp.add_last last_character;
- position := position+1;
+ position := position+1;
};
(! string_tmp.is_empty).if {
idx := string_tmp.first_substring_index "__";
- (idx != 0).if {
+ (idx != 0).if {
position := posold+idx;
syntax_error (current_position,"Identifier is incorrect.");
};
@@ -450,9 +450,9 @@ Section Private
};
result
);
-
+
- read_word st:STRING_CONSTANT :BOOLEAN <-
- ( + posold,idx:INTEGER;
+ ( + posold,idx:INTEGER;
+ result:BOOLEAN;
// On passe les espaces :
(! read_space).if {
@@ -476,22 +476,22 @@ Section Private
- read_this_keyword st:STRING_CONSTANT :BOOLEAN <-
( + result:BOOLEAN;
-
+
result := read_word st;
(is_shorter).if {
- (result).if {
+ (result).if {
(st = ALIAS_STR.keyword_section).if {
- short (ALIAS_STR.short_keyword_section) token
+ short (ALIAS_STR.short_keyword_section) token
(position-last_string.count) to position;
} else {
- short (ALIAS_STR.short_keyword) token
+ short (ALIAS_STR.short_keyword) token
(position-last_string.count) to position;
};
};
};
result
);
-
+
//-- keyword -> 'A'-'Z' 'a'-'z' {'a'-'z' | '0'-'9' | '_'}
- read_keyword:BOOLEAN <-
( + result:BOOLEAN;
@@ -506,24 +506,24 @@ Section Private
string_tmp.add_last last_character;
position := position + 1;
{(last_character != 0.to_character) &&
- {(last_character.is_lower) ||
+ {(last_character.is_lower) ||
{last_character.is_digit} ||
{last_character = '_'}}}.while_do {
string_tmp.add_last last_character;
- position := position+1;
+ position := position+1;
};
last_string := ALIAS_STR.get string_tmp;
result := TRUE;
- short (ALIAS_STR.short_keyword) token
+ short (ALIAS_STR.short_keyword) token
(position-last_string.count) to position;
} else {
position := position - 1;
result := FALSE;
- };
+ };
};
result
- );
-
+ );
+
//-- cap_identifier -> 'A'-'Z' {'A'-'Z' | '0'-'9' | '_'}
- read_cap_identifier:BOOLEAN <-
( + posold,idx:INTEGER;
@@ -541,29 +541,29 @@ Section Private
{
(last_character = 0.to_character) ||
{
- (! last_character.is_upper) &&
+ (! last_character.is_upper) &&
{! last_character.is_digit} &&
{last_character != '_'}
}
}.until_do {
car := last_character;
is_parameter_type := is_parameter_type && {car.is_digit};
- string_tmp.add_last car;
- position := position+1;
- };
+ string_tmp.add_last car;
+ position := position+1;
+ };
idx := string_tmp.first_substring_index "__";
- (idx != 0).if {
+ (idx != 0).if {
position := posold + idx;
syntax_error (current_position,"Identifier is incorrect.");
- };
- last_string := ALIAS_STR.get string_tmp;
- result := TRUE;
+ };
+ last_string := ALIAS_STR.get string_tmp;
+ result := TRUE;
};
result
);
-
- //-- integer -> number
- //-- number -> {'0'-'9'} ['d']
+
+ //-- integer -> number
+ //-- number -> {'0'-'9'} ['d']
//-- | '0'-'9' {'0'-'9' | 'A'-'F' | 'a'-'f'} 'h'
//-- | {'0'-'7'} 'o'
//-- | {'0' | '1'} 'b'
@@ -575,7 +575,7 @@ Section Private
((read_space) && {last_character.is_digit}).if {
result := TRUE;
string_tmp.clear;
- string_tmp.add_last last_character;
+ string_tmp.add_last last_character;
pos_old := position;
position := position + 1;
{(last_character.is_hexadecimal_digit) || {last_character = '_'}}.while_do {
@@ -605,13 +605,13 @@ Section Private
last_integer := string_tmp.to_binary;
position := position+1;
} else {
- (last_character='d').if {
+ (last_character='d').if {
position := position+1;
};
(! string_tmp.is_integer_64).if {
syntax_error (current_position,"Incorrect decimal number.");
};
- last_integer := string_tmp.to_integer_64;
+ last_integer := string_tmp.to_integer_64;
};
};
};
@@ -627,20 +627,20 @@ Section Private
+ pos_old:INTEGER;
// On passe les espaces :
- ((read_space) && {last_character.is_digit}).if {
+ ((read_space) && {last_character.is_digit}).if {
string_tmp.clear;
- string_tmp.add_last last_character;
- pos_old := position;
+ string_tmp.add_last last_character;
+ pos_old := position;
position := position + 1;
{(last_character.is_digit) || {last_character = '_'}}.while_do {
(last_character != '_').if {
string_tmp.add_last last_character;
};
position := position + 1;
- };
- (last_character = '.').if {
+ };
+ (last_character = '.').if {
string_tmp.add_last '.';
- position := position + 1;
+ position := position + 1;
(last_character.is_digit).if {
result := TRUE;
string_tmp.add_last last_character;
@@ -653,7 +653,7 @@ Section Private
(last_character = 'E').if {
result := TRUE;
string_tmp.add_last 'E';
- position := position + 1;
+ position := position + 1;
((last_character = '+') || {last_character = '-'}).if {
string_tmp.add_last last_character;
position := position + 1;
@@ -664,7 +664,7 @@ Section Private
{last_character.is_digit}.while_do {
string_tmp.add_last last_character;
position := position + 1;
- };
+ };
} else {
syntax_error (current_position,"Incorrect real number.");
};
@@ -676,19 +676,19 @@ Section Private
position := pos_old;
};
};
- (result).if {
+ (result).if {
short (ALIAS_STR.short_integer) token pos_old to position;
- };
- result
+ };
+ result
);
-
+
- read_escape_character <-
( + nothing:BOOLEAN;
+ val:INTEGER;
- last_character.is_separator.if {
+ last_character.is_separator.if {
position := position+1;
{
- (last_character = 0.to_character) ||
+ (last_character = 0.to_character) ||
{! last_character.is_separator}
}.until_do {
position := position+1;
@@ -700,7 +700,7 @@ Section Private
syntax_error (current_position,"Unknown escape sequence.");
};
}.elseif {last_character != 0.to_character} then {
- ( (last_character = 'a') ||
+ ( (last_character = 'a') ||
{last_character = 'b'} ||
{last_character = 'f'} ||
{last_character = 'n'} ||
@@ -716,8 +716,8 @@ Section Private
position := position+1;
}.elseif {last_character.in_range '0' to '9'} then {
(
- (last_character='0') &&
- {position<source.upper} &&
+ (last_character='0') &&
+ {position<source.upper} &&
{! source.item(position+1).is_hexadecimal_digit}
).if {
string_tmp.add_last last_character;
@@ -737,23 +737,23 @@ Section Private
(last_character='\\').if {
position := position + 1;
} else {
- syntax_error (current_position,"Character '\' is needed.");
+ syntax_error (current_position,"Character '\' is needed.");
};
};
} else {
syntax_error (current_position,"Unknown escape sequence.");
- };
+ };
};
);
-
+
//-- character -> '\'' ascii '\''
- read_characters:BOOLEAN <-
( + result:BOOLEAN;
+ old_pos:INTEGER;
+ count:INTEGER;
// On passe les espaces :
- ((read_space) && {last_character='\''}).if {
- old_pos := position;
+ ((read_space) && {last_character='\''}).if {
+ old_pos := position;
position := position+1;
string_tmp.clear;
{
@@ -764,10 +764,10 @@ Section Private
string_tmp.add_last last_character;
(last_character='\\').if {
position := position+1;
- read_escape_character;
+ read_escape_character;
count := count + 1;
} else {
- position := position+1;
+ position := position+1;
count := count + 1;
};
};
@@ -787,30 +787,30 @@ Section Private
};
result
);
-
+
//-- string -> '\"' ascii_string '\"'
- read_string:BOOLEAN <-
( + result:BOOLEAN;
+ old_pos:INTEGER;
// On passe les espaces :
- ((read_space) && {last_character='\"'}).if {
+ ((read_space) && {last_character='\"'}).if {
old_pos := position;
position := position+1;
string_tmp.clear;
{
(last_character=0.to_character) ||
- {last_character='\n'} ||
+ {last_character='\n'} ||
{last_character='\"'}
- }.until_do {
+ }.until_do {
string_tmp.add_last last_character;
(last_character='\\').if {
position := position+1;
read_escape_character;
} else {
- position := position+1;
+ position := position+1;
};
};
- (last_character='\"').if {
+ (last_character='\"').if {
position := position+1;
last_string := ALIAS_STR.get string_tmp;
result := TRUE;
@@ -822,7 +822,7 @@ Section Private
};
result
);
-
+
//-- external -> '`' ascii_c_code '`'
- read_external:BOOLEAN <-
( + result:BOOLEAN;
@@ -830,7 +830,7 @@ Section Private
// On passe les espaces :
((! read_space) || {last_character != '`'}).if {
result := FALSE;
- } else {
+ } else {
pos_old:=position;
position := position+1;
string_tmp.clear;
@@ -857,15 +857,15 @@ Section Private
};
result
);
-
- //-- operator -> '!' | '@' | '#' | '$' | '%' | '^' | '&' | '<' | '|'
+
+ //-- operator -> '!' | '@' | '#' | '$' | '%' | '^' | '&' | '<' | '|'
//-- | '*' | '-' | '+' | '=' | '~' | '/' | '?' | '\' | '>'
- read_operator:BOOLEAN <-
( + result:BOOLEAN;
+ old_pos:INTEGER;
// On passe les espaces :
(read_space).if {
- };
+ };
old_pos:=position;
string_tmp.clear;
{(last_character = 0.to_character) ||
@@ -882,7 +882,7 @@ Section Private
).if {
syntax_error (current_position,"Incorrect operator.");
};
- short (ALIAS_STR.short_operator) token old_pos to position;
+ short (ALIAS_STR.short_operator) token old_pos to position;
result := TRUE;
};
result
@@ -891,58 +891,58 @@ Section Private
//
// Variable & function Global.
//
-
+
- last_slot:ITM_SLOT;
- last_group:ITM_LIST;
- last_section:SECTION_;
-
+
//
// PARSER
//
-
- //++ PROGRAM -> { "Section" (section|TYPE_LIST) { SLOT } } [CONTRACT ';']
+
+ //++ PROGRAM -> { "Section" (section|TYPE_LIST) { SLOT } } [CONTRACT ';']
- read_program:BOOLEAN <-
( + result:BOOLEAN;
+ pos_sec,old_derive:INTEGER;
+ t:FAST_ARRAY(ITM_TYPE_MONO);
-
+
result := TRUE;
-
+
pos_sec := position;
old_derive := short_derive;
-
+
read_space;
-
+
(is_shorter).if {
output_code.remove_between (source.lower+old_derive) to (position-1+short_derive);
short_derive := short_derive - ((position+short_derive) - (source.lower+old_derive));
- };
+ };
pos_sec := position;
old_derive := short_derive;
last_comment_extern := NULL;
//
// Read Section Header.
- //
+ //
(read_this_keyword (ALIAS_STR.keyword_section)).if_false {
syntax_error (current_position,"`Section' is needed.");
};
(read_this_keyword (ALIAS_STR.section_header)).if_false {
syntax_error (current_position,"Section `Header' is needed.");
- };
+ };
(read_slot_header TRUE).if_false {
- syntax_error (current_position,"Slot `name' not found.");
+ syntax_error (current_position,"Slot `name' not found.");
};
{read_slot_header FALSE}.while_do {
}; // loop
-
+
(is_shorter2).if {
object.set_comment_header last_comment_extern;
};
-
+
//
- // Read Section Other.
+ // Read Section Other.
//
{read_this_keyword (ALIAS_STR.keyword_section)}.while_do {
last_comment_extern := NULL;
@@ -950,31 +950,31 @@ Section Private
// Public, Private, ...
(ALIAS_STR.is_section last_string).if_false {
syntax_error (current_position,"Incorrect type section.");
- };
- last_section := SECTION_.get_name last_string;
+ };
+ last_section := SECTION_.get_name last_string;
(last_section.is_mapping).if {
object.set_mapping;
}.elseif {last_section.is_external} then {
object.set_external;
}.elseif {
- (last_section.is_inherit_or_insert) &&
- {object.last_slot != NULL} &&
+ (last_section.is_inherit_or_insert) &&
+ {object.last_slot != NULL} &&
{! object.last_slot.id_section.is_inherit_or_insert}
- } then {
+ } then {
syntax_error (current_position,
"`Section Inherit/Insert' must to be first section.");
- }.elseif {
- (last_section.is_inherit) &&
+ }.elseif {
+ (last_section.is_inherit) &&
{object.type_style = ALIAS_STR.keyword_expanded} &&
- {object.name != ALIAS_STR.prototype_true } &&
+ {object.name != ALIAS_STR.prototype_true } &&
{object.name != ALIAS_STR.prototype_false}
- } then {
+ } then {
warning_error (current_position,
"`Section Inherit' is not possible with Expanded object (Use `Section Insert').");
};
} else {
// TYPE_LIST.
- t := read_type_list TRUE;
+ t := read_type_list TRUE;
(t = NULL).if {
syntax_error (current_position,"Incorrect type section.");
};
@@ -982,26 +982,26 @@ Section Private
};
{read_slot}.while_do {
}; // loop
-
+
(is_shorter).if {
(
- (! is_short_private) &&
+ (! is_short_private) &&
{last_section.is_private}
).if {
- output_code.remove_between
- (pos_sec + old_derive) to (position + short_derive - 1);
+ output_code.remove_between
+ (pos_sec + old_derive) to (position + short_derive - 1);
short_derive := old_derive - (position - pos_sec);
};
-
+
pos_sec:=position;
old_derive:=short_derive;
};
-
+
}; // loop
- (read_invariant).if {
+ (read_invariant).if {
warning_error (current_position,"Invariant: Sorry, Not yet implemented.");
};
-
+
// End of file :
result := result | read_space;
(last_character != 0.to_character).if {
@@ -1019,27 +1019,27 @@ Section Private
+ affect:CHARACTER;
+ old_pos,old_derive:INTEGER;
+ s:ITM_SLOT;
-
+
style := read_style;
- (style != ' ').if {
+ (style != ' ').if {
//
// Classic slot.
- //
+ //
result := TRUE;
//
last_slot := read_type_slot;
(last_slot = NULL).if {
syntax_error (current_position,"Incorrect slot declaration.");
- };
-
+ };
+
last_slot.set_style style;
-
+
(read_affect).if {
affect := last_string.first;
} else {
affect := ' ';
};
-
+
// ':' (TYPE|'('TYPE_LIST')'
((affect = ' ') && {read_character ':'}).if {
(read_character '(').if {
@@ -1052,24 +1052,24 @@ Section Private
};
t := ITM_TYPE_MULTI.get lt;
} else {
- t := read_type FALSE;
+ t := read_type FALSE;
(t = NULL).if {
syntax_error (current_position,"Incorrect result type.");
};
- };
-
+ };
+
(read_affect).if {
affect := last_string.first;
};
} else {
t := ITM_TYPE_SIMPLE.type_void;
- };
+ };
last_slot.set_result_type t;
last_slot.set_affect affect;
-
+
(affect != ' ').if {
read_space;
- (is_shorter2).if {
+ (is_shorter2).if {
(last_comment_slot != NULL).if {
last_slot.set_comment last_comment_slot;
};
@@ -1077,7 +1077,7 @@ Section Private
last_slot.set_comment_chapter last_comment_extern;
};
skip_comment := TRUE;
- };
+ };
old_pos := position;
old_derive := short_derive;
read_def_slot;
@@ -1093,14 +1093,14 @@ Section Private
last_slot.set_comment last_comment_slot;
};
};
-
+
(is_shorter).if {
(
- (! is_short_code) &&
+ (! is_short_code) &&
{old_pos != 0} &&
{! last_section.is_header}
).if {
- (current_position.column<5).if {
+ (current_position.column<5).if {
{
(last_character != 0.to_character) &&
{last_character.is_separator} &&
@@ -1112,8 +1112,8 @@ Section Private
position := position + 1;
};
};
- output_code.remove_between
- (old_pos + old_derive) to (position + short_derive - 1);
+ output_code.remove_between
+ (old_pos + old_derive) to (position + short_derive - 1);
short_derive := old_derive - (position - old_pos);
};
};
@@ -1134,62 +1134,62 @@ Section Private
};
result
); // read_slot
-
+
//++ TYPE_SLOT -> [ LOC_ARG '.' ] identifier [ LOC_ARG { identifier LOC_ARG } ]
//++ | [ LOC_ARG ] '\'' operator '\'' [("Left"|"Right") [integer]] [LOC_ARG]
- read_type_slot:ITM_SLOT <-
( + arg:ITM_ARGUMENT;
+ result:ITM_SLOT;
+ list_arg:FAST_ARRAY(ITM_ARGUMENT);
-
+
list_arg := ALIAS_ARRAY(ITM_ARGUMENT).new;
arg := read_loc_arg FALSE with_self TRUE;
-
+
(arg = NULL).if {
(read_character '\'').if {
result := read_slot_operator list_arg;
} else {
- arg := ITM_ARG.create current_position
+ arg := ITM_ARG.create current_position
name (ALIAS_STR.variable_self) type (ITM_TYPE_SIMPLE.type_self);
- list_arg.add_last arg;
+ list_arg.add_last arg;
result := read_slot_keyword list_arg;
};
} else {
list_arg.add_last arg;
(read_character '.').if {
result := read_slot_keyword list_arg;
- }.elseif {read_character '\''} then {
+ }.elseif {read_character '\''} then {
result := read_slot_operator list_arg;
};
};
(result != NULL).if {
list_arg := ALIAS_ARRAY(ITM_ARGUMENT).copy list_arg;
- result.set_argument_list list_arg;
+ result.set_argument_list list_arg;
};
result
);
-
+
- read_slot_keyword list_arg:FAST_ARRAY(ITM_ARGUMENT) :ITM_SLOT <-
( + n:STRING;
+ arg:ITM_ARGUMENT;
+ result:ITM_SLOT;
-
+
read_identifier.if {
- short (ALIAS_STR.short_slot) token
+ short (ALIAS_STR.short_slot) token
(position-last_string.count) to position;
-
- n := ALIAS_STR.new;
- n.copy last_string;
+
+ n := ALIAS_STR.new;
+ n.copy last_string;
arg := read_loc_arg FALSE with_self FALSE;
(arg != NULL).if {
- list_arg.add_last arg;
+ list_arg.add_last arg;
(read_identifier).if {
(last_section.is_external).if {
syntax_error (current_position,"Incorrect in `Section External'.");
- };
- {
- short (ALIAS_STR.short_slot) token
- (position-last_string.count) to position;
+ };
+ {
+ short (ALIAS_STR.short_slot) token
+ (position-last_string.count) to position;
n.append (ALIAS_STR.separate);
n.append last_string;
arg := read_loc_arg FALSE with_self FALSE;
@@ -1204,14 +1204,14 @@ Section Private
};
result
);
-
+
- read_slot_operator list_arg:FAST_ARRAY(ITM_ARGUMENT) :ITM_SLOT <-
- ( + name,pretty_name:STRING_CONSTANT;
+ ( + name,pretty_name:STRING_CONSTANT;
+ associativity:STRING_CONSTANT;
+ priority:INTEGER;
+ arg:ITM_ARGUMENT;
+ result:ITM_SLOT_OPERATOR;
-
+
(! read_operator).if {
syntax_error (current_position,"Operator is needed.");
};
@@ -1220,7 +1220,7 @@ Section Private
{last_string = ALIAS_STR.symbol_not_equal}
).if {
syntax_error (current_position,"Incorrect operator.");
- };
+ };
pretty_name := name := last_string;
(! read_character '\'').if {
warning_error (current_position,"Added `''.");
@@ -1232,9 +1232,9 @@ Section Private
associativity := last_string;
(read_integer).if {
priority := last_integer.to_integer;
- };
+ };
};
-
+
(list_arg.is_empty).if {
// Prefix operator.
arg := read_loc_arg FALSE with_self TRUE;
@@ -1251,10 +1251,10 @@ Section Private
(arg != NULL).if {
// Infix operator.
list_arg.add_last arg;
- name := operator (ALIAS_STR.slot_infix) name name;
+ name := operator (ALIAS_STR.slot_infix) name name;
(associativity = NULL).if {
associativity := ALIAS_STR.keyword_left;
- };
+ };
} else {
// Postfix operator.
name := operator (ALIAS_STR.slot_postfix) name name;
@@ -1262,17 +1262,17 @@ Section Private
syntax_error (current_position,"Not associativity for prefix operator.");
};
};
- };
+ };
result := ITM_SLOT_OPERATOR.create current_position name name feature last_section;
result.set_associativity associativity priority priority;
- result.set_pretty_name pretty_name;
+ result.set_pretty_name pretty_name;
result
); // read_slot_operator
-
+
//++ DEF_SLOT -> [CONTRACT] EXPR [CONTRACT]
- read_def_slot <-
( + expr:ITM_CODE;
-
+
read_require;
expr := read_expr;
(expr = NULL).if {
@@ -1281,7 +1281,7 @@ Section Private
last_slot.set_value expr type object;
read_ensure;
);
-
+
//++ LOC_ARG -> identifier ':' TYPE
//++ | '(' LOCAL ')'
- read_loc_arg mute:BOOLEAN with_self self_first:BOOLEAN :ITM_ARGUMENT <-
@@ -1290,11 +1290,11 @@ Section Private
+ pos:POSITION;
+ n:STRING_CONSTANT;
+ tb:ITM_TYPE_BLOCK;
-
+
(
- (( self_first) && {read_this_keyword (ALIAS_STR.variable_self)}) ||
+ (( self_first) && {read_this_keyword (ALIAS_STR.variable_self)}) ||
{(! self_first) && {read_identifier}}
- ).if {
+ ).if {
pos := current_position;
n := last_string;
((read_character ':') && {last_character != '='}).if {
@@ -1302,19 +1302,19 @@ Section Private
(t = NULL).if {
syntax_error (current_position,"Incorrect type.");
};
-
+
(
- (self_first) &&
- {t != ITM_TYPE_SIMPLE.type_self} &&
+ (self_first) &&
+ {t != ITM_TYPE_SIMPLE.type_self} &&
{
- (object.name != ALIAS_STR.prototype_block) ||
+ (object.name != ALIAS_STR.prototype_block) ||
{tb ?= t; tb = NULL}
}
- ).if {
+ ).if {
syntax_error (current_position,"Type `SELF' is needed.");
};
result := ITM_ARG.create pos name n type t;
-
+
(is_shorter).if {
short_local.add n;
};
@@ -1322,14 +1322,14 @@ Section Private
mute.if_false {
warning_error (current_position,"Added ':' is needed.");
};
- };
- }.elseif {read_character '('} then {
+ };
+ }.elseif {read_character '('} then {
result := read_local_arg mute with_self self_first;
(result = NULL).if {
mute.if_false {
syntax_error (current_position,"Incorrect argument definition.");
};
- } else {
+ } else {
(read_character ')').if_false {
warning_error (current_position,"Added ')'.");
};
@@ -1337,18 +1337,18 @@ Section Private
};
result
);
-
+
//++ LOCAL -> { identifier [ ':' TYPE ] ',' } identifier ':' TYPE
- read_local m:BOOLEAN :FAST_ARRAY(ITM_LOCAL) <-
( + t:ITM_TYPE_MONO;
+ loc:ITM_LOCAL;
- + result:FAST_ARRAY(ITM_LOCAL);
+ + result:FAST_ARRAY(ITM_LOCAL);
+ beg:INTEGER;
+ mute:BOOLEAN;
-
+
mute := m;
(read_identifier).if {
- result := ALIAS_ARRAY(ITM_LOCAL).new;
+ result := ALIAS_ARRAY(ITM_LOCAL).new;
beg := result.lower;
{
((result.count != 0) && {! read_identifier} && {! mute}).if {
@@ -1366,7 +1366,7 @@ Section Private
result.item j.set_type t;
};
beg := result.upper + 1;
- };
+ };
}.do_while {read_character ','};
(beg != result.upper + 1).if {
(mute).if {
@@ -1374,10 +1374,10 @@ Section Private
result := NULL;
} else {
syntax_error (current_position,"Incorrect local type.");
- };
+ };
} else {
result := ALIAS_ARRAY(ITM_LOCAL).copy result;
-
+
(is_shorter).if {
(result.lower).to (result.upper) do { j:INTEGER;
short_local.add (result.item j.name);
@@ -1385,27 +1385,27 @@ Section Private
};
};
};
-
+
result
); // read_local
-
+
- read_local_arg m:BOOLEAN with_self s:BOOLEAN :ITM_ARGUMENT <-
( + t:ITM_TYPE_MONO;
+ tm:ITM_TYPE_MULTI;
+ type:FAST_ARRAY(ITM_TYPE_MONO);
- + name:FAST_ARRAY(STRING_CONSTANT);
+ + name:FAST_ARRAY(STRING_CONSTANT);
+ beg:INTEGER;
+ mute:BOOLEAN;
+ result:ITM_ARGUMENT;
+ tb:ITM_TYPE_BLOCK;
-
+
mute := m;
(
((s) && {read_this_keyword (ALIAS_STR.variable_self)}) ||
{read_identifier}
- ).if {
+ ).if {
name := ALIAS_ARRAY(STRING_CONSTANT).new;
- type := ALIAS_ARRAY(ITM_TYPE_MONO).new;
+ type := ALIAS_ARRAY(ITM_TYPE_MONO).new;
beg := name.lower;
{
((name.count != 0) && {! read_identifier} && {! mute}).if {
@@ -1422,19 +1422,19 @@ Section Private
type.add_last t;
};
beg := name.upper + 1;
- };
+ };
}.do_while {read_character ','};
(beg != name.upper + 1).if {
(mute).if_false {
syntax_error (current_position,"Incorrect argument type.");
- };
+ };
ALIAS_ARRAY(STRING_CONSTANT).free name;
ALIAS_ARRAY(ITM_TYPE_MONO).free type;
} else {
(
(s) && {
(type.first != ITM_TYPE_SIMPLE.type_self) || {
- (object.name = ALIAS_STR.prototype_block) &&
+ (object.name = ALIAS_STR.prototype_block) &&
{tb ?= type.first; tb = NULL}
}
}
@@ -1443,7 +1443,7 @@ Section Private
};
(name.count = 1).if {
// Single Argument.
- result := ITM_ARG.create current_position
+ result := ITM_ARG.create current_position
name (name.first)
type (type.first);
ALIAS_ARRAY(STRING_CONSTANT).free name;
@@ -1455,7 +1455,7 @@ Section Private
tm := ITM_TYPE_MULTI.get type;
result := ITM_ARGS.create current_position name name type tm;
};
-
+
(is_shorter).if {
(name.lower).to (name.upper) do { j:INTEGER;
short_local.add (name.item j);
@@ -1463,18 +1463,18 @@ Section Private
};
};
};
-
+
result
- ); // read_local
-
+ ); // read_local
+
//++ TYPE_LIST -> TYPE { ',' TYPE }
- read_type_list is_section:BOOLEAN :FAST_ARRAY(ITM_TYPE_MONO) <-
( + lst:FAST_ARRAY(ITM_TYPE_MONO);
+ t:ITM_TYPE_MONO;
+ ts:ITM_TYPE_SIMPLE;
-
- t := read_type FALSE;
- (t != NULL).if {
+
+ t := read_type FALSE;
+ (t != NULL).if {
(is_section).if {
ts ?= t;
(ts = NULL).if {
@@ -1483,7 +1483,7 @@ Section Private
};
};
lst := ALIAS_ARRAY(ITM_TYPE_MONO).new;
- lst.add_last t;
+ lst.add_last t;
{read_character ','}.while_do {
t := read_type FALSE;
(t = NULL).if {
@@ -1502,7 +1502,7 @@ Section Private
};
lst
);
-
+
//++ TYPE -> '{' [ (TYPE | '(' TYPE_LIST ')') ';' ] [ TYPE_LIST ] '}'
//++ | [type] PROTOTYPE [ CONTRACT ]
- read_type is_local:BOOLEAN :ITM_TYPE_MONO <-
@@ -1511,9 +1511,9 @@ Section Private
+ lst:FAST_ARRAY(ITM_TYPE_MONO);
+ typ_arg,typ_res:ITM_TYPE;
+ contract:ITM_LIST;
-
+
(read_character '{').if {
- // '{' [ (TYPE | '(' TYPE_LIST ')') ';' ] [ TYPE_LIST ] '}'
+ // '{' [ (TYPE | '(' TYPE_LIST ')') ';' ] [ TYPE_LIST ] '}'
(read_character '(').if {
// Read vector argument.
lst := read_type_list FALSE;
@@ -1521,13 +1521,13 @@ Section Private
syntax_error (current_position,"Incorrect type list.");
};
(lst.count = 1).if {
- typ_arg := lst.first;
+ typ_arg := lst.first;
} else {
typ_arg := ITM_TYPE_MULTI.get lst;
};
(! read_character ')').if {
warning_error (current_position,"Added ')'.");
- }; // if
+ }; // if
(! read_character ';').if {
warning_error (current_position,"Added ';'.");
}; // if
@@ -1535,7 +1535,7 @@ Section Private
} else {
lst := read_type_list FALSE;
(lst != NULL).if {
- (read_character ';').if {
+ (read_character ';').if {
(lst.count = 1).if {
typ_arg := lst.first;
} else {
@@ -1546,8 +1546,8 @@ Section Private
warning_error (current_position,string_tmp);
};
lst := read_type_list FALSE;
- };
- };
+ };
+ };
};
(lst != NULL).if {
(lst.count = 1).if {
@@ -1558,19 +1558,19 @@ Section Private
};
(! read_character '}').if {
warning_error (current_position,"Added '}'.");
- }; // if
- result := ITM_TYPE_BLOCK.get typ_arg and typ_res;
- } else {
- // Expanded | Strict
+ }; // if
+ result := ITM_TYPE_BLOCK.get typ_arg and typ_res;
+ } else {
+ // Expanded | Strict
(
- (read_this_keyword (ALIAS_STR.keyword_expanded)) ||
- {read_this_keyword (ALIAS_STR.keyword_strict)}
- ).if {
+ (read_this_keyword (ALIAS_STR.keyword_expanded)) ||
+ {read_this_keyword (ALIAS_STR.keyword_strict)}
+ ).if {
style := last_string;
((is_local) && {last_string = ALIAS_STR.keyword_expanded}).if {
syntax_error (current_position,"`Expanded' is not possible.");
};
- };
+ };
// PROTOTYPE
result := read_prototype style;
contract := read_contract;
@@ -1580,17 +1580,17 @@ Section Private
};
result
); // read_type
-
+
//++ PROTOTYPE -> cap_identifier{('.'|'...')cap_identifier}['('PARAM_TYPE{','PARAM_TYPE}')']
- read_prototype styl:STRING_CONSTANT :ITM_TYPE_MONO <-
- ( + nam:STRING_CONSTANT;
- + genericity:FAST_ARRAY(ITM_TYPE_MONO);
- + result,t:ITM_TYPE_MONO;
+ ( + nam:STRING_CONSTANT;
+ + genericity:FAST_ARRAY(ITM_TYPE_MONO);
+ + result,t:ITM_TYPE_MONO;
+ old_pos,old_derive,sav_derive,pos_before:INTEGER;
+ continue:BOOLEAN;
-
-
- (read_cap_identifier).if {
+
+
+ (read_cap_identifier).if {
old_pos := position;
old_derive := short_derive;
string_tmp2.copy last_string;
@@ -1612,10 +1612,10 @@ Section Private
position := pos_before;
};
};
- }.do_while {continue};
+ }.do_while {continue};
nam := ALIAS_STR.get string_tmp2;
//
- (read_character '(').if {
+ (read_character '(').if {
// Multiple Genericity.
genericity := ALIAS_ARRAY(ITM_TYPE_MONO).new;
{
@@ -1624,14 +1624,14 @@ Section Private
syntax_error (current_position,"Type needed.");
};
genericity.add_last t;
- }.do_while {read_character ','};
+ }.do_while {read_character ','};
genericity := ALIAS_ARRAY(ITM_TYPE_MONO).alias genericity;
result := ITM_TYPE_GENERIC.get nam style styl with genericity;
(read_character ')').if_false {
warning_error (current_position,"Added ')'.");
};
- } else {
- // Simple type.
+ } else {
+ // Simple type.
(is_parameter_type).if {
(styl != NULL).if {
string_tmp.copy "Style `";
@@ -1647,7 +1647,7 @@ Section Private
string_tmp.copy "Style `";
string_tmp.append styl;
string_tmp.append "' ignored.";
- warning_error (current_position,string_tmp);
+ warning_error (current_position,string_tmp);
result := ITM_TYPE_SIMPLE.type_self;
} else {
result := ITM_TYPE_STYLE.get nam style styl;
@@ -1658,13 +1658,13 @@ Section Private
sav_derive := short_derive;
short_derive := old_derive;
(
- (result = ITM_TYPE_SIMPLE.type_self) ||
+ (result = ITM_TYPE_SIMPLE.type_self) ||
{result = ITM_TYPE_SIMPLE.type_null}
).if {
- short (ALIAS_STR.short_keyprototype) token
+ short (ALIAS_STR.short_keyprototype) token
(old_pos - nam.count) to old_pos;
} else {
- short (ALIAS_STR.short_prototype) token
+ short (ALIAS_STR.short_prototype) token
(old_pos - nam.count) to old_pos;
};
short_derive := sav_derive + (short_derive - old_derive);
@@ -1672,41 +1672,41 @@ Section Private
}; // if
result
); // read_prototype
-
+
- read_param_type:ITM_TYPE_MONO <-
//++ PARAM_TYPE -> TYPE
//++ | CONSTANT
//++ | identifier
( + result:ITM_TYPE_MONO;
+ cst:ITM_CONSTANT;
-
+
result := read_type FALSE;
- (result = NULL).if {
+ (result = NULL).if {
cst := read_constant;
(cst != NULL).if {
syntax_error (current_position,"1) Sorry, not yet implemented.");
- //result :=
+ //result :=
}.elseif {read_identifier} then {
syntax_error (current_position,"2) Sorry, not yet implemented.");
- //result :=
+ //result :=
};
};
result
);
-
+
//++ EXPR -> { ASSIGN !!AMBIGU!! affect } EXPR_OPERATOR
//++ ASSIGN -> '(' IDF_ASSIGN { ',' IDF_ASSIGN } ')'
//++ | IDF_ASSIGN
//++ IDF_ASSIGN -> identifier { identifier }
- read_expr:ITM_CODE <-
- ( + result,value:ITM_CODE;
- + affect:CHARACTER;
+ ( + result,value:ITM_CODE;
+ + affect:CHARACTER;
+ again:BOOLEAN;
+ l_assignment:FAST_ARRAY(STRING_CONSTANT);
+ p:INTEGER;
+ name:STRING_CONSTANT;
-
- // !! AMBIGU resolution !!
+
+ // !! AMBIGU resolution !!
save_context;
(read_character '(').if {
l_assignment := ALIAS_ARRAY(STRING_CONSTANT).new;
@@ -1721,22 +1721,22 @@ Section Private
};
name := ALIAS_STR.get string_tmp2;
l_assignment.add_last name;
-
+
(is_shorter).if {
- (! short_local.fast_has name).if {
- short (ALIAS_STR.short_slot_call) token p to position;
+ (! short_local.fast_has name).if {
+ short (ALIAS_STR.short_slot_call) token p to position;
};
};
-
+
(read_character ',').if {
again := TRUE;
};
};
}.do_while {again};
- ((! l_assignment.is_empty) && {read_character ')'} && {read_affect}).if {
+ ((! l_assignment.is_empty) && {read_character ')'} && {read_affect}).if {
l_assignment := ALIAS_ARRAY(STRING_CONSTANT).copy l_assignment;
result := ITM_LIST_IDF.create current_position with l_assignment;
- affect := last_string.first;
+ affect := last_string.first;
value := read_expr;
(value = NULL).if {
syntax_error (current_position,"Incorrect expression.");
@@ -1751,7 +1751,7 @@ Section Private
.when '?' then {
syntax_error (current_position,"Sorry, Not yet implemented !");
result := ITM_WRITE_CAST.create (result.position) assign result with value;
- };
+ };
} else {
ALIAS_ARRAY(STRING_CONSTANT).free l_assignment;
};
@@ -1763,16 +1763,16 @@ Section Private
string_tmp2.append last_string;
};
name := ALIAS_STR.get string_tmp2;
-
+
(is_shorter).if {
- (! short_local.fast_has name).if {
- short (ALIAS_STR.short_slot_call) token p to position;
+ (! short_local.fast_has name).if {
+ short (ALIAS_STR.short_slot_call) token p to position;
};
};
-
+
(read_affect).if {
result := ITM_READ.create current_position name name;
- affect := last_string.first;
+ affect := last_string.first;
value := read_expr;
(value = NULL).if {
syntax_error (current_position,"Incorrect expression.");
@@ -1786,7 +1786,7 @@ Section Private
}
.when '?' then {
result := ITM_WRITE_CAST.create (result.position) assign result with value;
- };
+ };
};
};
(result = NULL).if {
@@ -1794,45 +1794,45 @@ Section Private
result := read_expr_operator;
};
result
- );
-
+ );
+
//++ EXPR_OPERATOR-> { operator } EXPR_MESSAGE { operator {operator} EXPR_MESSAGE } {operator}
- read_expr_operator:ITM_CODE <-
( + result:ITM_CODE;
+ expr :ITM_CODE;
- + l_expr:FAST_ARRAY(ITM_CODE);
- + itm_op:ITM_OPERATOR;
+ + l_expr:FAST_ARRAY(ITM_CODE);
+ + itm_op:ITM_OPERATOR;
+ last_msg,first_msg:INTEGER;
-
+
l_expr := ALIAS_ARRAY(ITM_CODE).new;
{read_operator}.while_do {
expr := ITM_OPERATOR.create current_position name last_string;
l_expr.add_last expr;
};
expr := read_expr_message;
- (expr = NULL).if {
+ (expr = NULL).if {
// Error.
(! l_expr.is_empty).if {
syntax_error (current_position,"Incorrect expression.");
};
- ALIAS_ARRAY(ITM_CODE).free l_expr;
+ ALIAS_ARRAY(ITM_CODE).free l_expr;
} else {
- // { operator {operator} EXPR_MESSAGE } {operator}
+ // { operator {operator} EXPR_MESSAGE } {operator}
first_msg := l_expr.count;
{
last_msg := l_expr.count;
- l_expr.add_last expr;
+ l_expr.add_last expr;
(read_operator).if {
{
expr := ITM_OPERATOR.create current_position name last_string;
l_expr.add_last expr;
- }.do_while {read_operator};
+ }.do_while {read_operator};
expr := read_expr_message;
- } else {
+ } else {
expr := NULL;
};
}.do_while {expr != NULL};
-
+
// Last Post-fix operator.
{last_msg < l_expr.upper}.while_do {
itm_op ?= l_expr.item (last_msg + 1);
@@ -1841,7 +1841,7 @@ Section Private
arg (l_expr.item last_msg);
l_expr.put expr to last_msg;
l_expr.remove (last_msg + 1);
- };
+ };
((last_msg - first_msg) < 3).if {
// First Pre-fix operator.
{first_msg != 0}.while_do {
@@ -1852,19 +1852,19 @@ Section Private
l_expr.put expr to first_msg;
first_msg := first_msg - 1;
l_expr.remove first_msg;
- };
+ };
};
(l_expr.count = 1).if {
- result := l_expr.first;
+ result := l_expr.first;
ALIAS_ARRAY(ITM_CODE).free l_expr;
}.elseif {l_expr.count = 3} then {
- // Simple binary message.
+ // Simple binary message.
itm_op ?= l_expr.second;
- result := ITM_READ_ARG2.create (itm_op.position)
- name (operator (ALIAS_STR.slot_infix) name (itm_op.name))
+ result := ITM_READ_ARG2.create (itm_op.position)
+ name (operator (ALIAS_STR.slot_infix) name (itm_op.name))
args (l_expr.first,l_expr.item 2);
//
- ALIAS_ARRAY(ITM_CODE).free l_expr;
+ ALIAS_ARRAY(ITM_CODE).free l_expr;
} else {
// Complex expression.
l_expr := ALIAS_ARRAY(ITM_CODE).copy l_expr;
@@ -1877,9 +1877,9 @@ Section Private
//++ EXPR_MESSAGE -> EXPR_BASE { '.' SEND_MSG }
- read_expr_message:ITM_CODE <-
( + result:ITM_CODE;
-
+
result := read_expr_base;
- (result != NULL).if {
+ (result != NULL).if {
{read_character '.'}.while_do {
result := read_send_msg result;
(result=NULL).if {
@@ -1894,15 +1894,15 @@ Section Private
//++ | EXPR_PRIMARY
//++ | SEND_MSG
- read_expr_base:ITM_CODE <-
- ( + result,old_value:ITM_CODE;
-
+ ( + result,old_value:ITM_CODE;
+
(read_this_keyword (ALIAS_STR.keyword_old)).if {
old_value := read_expr;
- (old_value = NULL).if {
- syntax_error (current_position,"Incorrect `Old' expression.");
- };
+ (old_value = NULL).if {
+ syntax_error (current_position,"Incorrect `Old' expression.");
+ };
result := ITM_OLD.create current_position value old_value;
- } else {
+ } else {
result := read_expr_primary;
(result = NULL).if {
result := read_send_msg NULL;
@@ -1925,8 +1925,8 @@ Section Private
+ ext :ITM_EXTERNAL_TYPE;
+ group_sav:ITM_LIST;
+ arg:ITM_ARGUMENT;
- + result_id:STRING_CONSTANT;
-
+ + result_id:STRING_CONSTANT;
+
(read_this_keyword (ALIAS_STR.variable_self)).if {
result := ITM_READ.create current_position name last_string;
}.elseif {read_this_keyword (ALIAS_STR.keyword_result)} then {
@@ -1949,50 +1949,50 @@ Section Private
}.elseif {
type := read_prototype NULL;
type != NULL
- } then {
- result := ITM_PROTOTYPE.create current_position type type;
- }.elseif {(result := read_constant) != NULL} then {
- }.elseif {read_character '(' } then {
+ } then {
+ result := ITM_PROTOTYPE.create current_position type type;
+ }.elseif {(result := read_constant) != NULL} then {
+ }.elseif {read_character '(' } then {
group_sav := last_group;
last_group := ITM_LIST.create current_position;
result := last_group;
last_group.set_code read_group;
- (read_character ')').if_false {
+ (read_character ')').if_false {
warning_error (current_position,"Added ')'.");
}; // if
last_group := group_sav;
}.elseif {read_character '{' } then {
short (ALIAS_STR.short_block) token (position-1) to position;
- group_sav := last_group;
+ group_sav := last_group;
last_group := ITM_LIST.create current_position;
-
+
save_context; // !! SAVE CONTEXT !!
-
+
//
arg := read_loc_arg TRUE with_self FALSE;
- //
- (arg != NULL).if {
- (read_character ';').if_false {
+ //
+ (arg != NULL).if {
+ (read_character ';').if_false {
warning_error (current_position,"Added ';'.");
}; // if
} else {
-
+
restore_context; // !! RESTORE CONTEXT !!
-
+
};
result := ITM_BLOCK.create last_group argument arg;
-
+
last_group.set_code read_group;
(! read_character '}').if {
warning_error (current_position,"Added '}'.");
}; // if
short (ALIAS_STR.short_block) token (position-1) to position;
- last_group := group_sav;
+ last_group := group_sav;
}.elseif {read_external} then {
(! read_character ':').if {
result := ITM_EXTERNAL.create current_position text last_string;
} else {
- ext := ITM_EXTERNAL_TYPE.create current_position text
+ ext := ITM_EXTERNAL_TYPE.create current_position text
last_string persistant (read_character '(');
type := read_type FALSE;
(type = NULL).if {
@@ -2009,7 +2009,7 @@ Section Private
};
ext.set_type_list ltype;
};
- ((ext.is_persistant) && {! read_character ')'}).if {
+ ((ext.is_persistant) && {! read_character ')'}).if {
warning_error (current_position,"Added ')'.");
};
result := ext;
@@ -2017,14 +2017,14 @@ Section Private
};
result
); // read_expr_primaire
-
+
- read_constant:ITM_CONSTANT <-
//++ CONSTANT -> integer
//++ | real
//++ | characters
//++ | string
( + result:ITM_CONSTANT;
-
+
(read_real).if {
result := ITM_REAL.create current_position value last_real;
}.elseif {read_integer} then {
@@ -2032,18 +2032,18 @@ Section Private
}.elseif {read_characters} then {
result := ITM_CHARACTER.create current_position char last_string;
}.elseif {read_string} then {
- result := ITM_STRING.create current_position text last_string;
+ result := ITM_STRING.create current_position text last_string;
};
result
);
-
+
//++ GROUP -> DEF_LOCAL {EXPR ';'} [ EXPR {',' {EXPR ';'} EXPR } ]
- read_group:FAST_ARRAY(ITM_CODE) <-
- ( + e:ITM_CODE;
+ ( + e:ITM_CODE;
+ result:FAST_ARRAY(ITM_CODE);
-
+
read_def_local;
-
+
result := ALIAS_ARRAY(ITM_CODE).new;
e := read_expr;
{(e != NULL) && {read_character ';'}}.while_do {
@@ -2051,7 +2051,7 @@ Section Private
e := read_expr;
};
(e != NULL).if {
- (read_character ',').if {
+ (read_character ',').if {
{
e := ITM_RESULT.create e;
result.add_last e;
@@ -2062,26 +2062,26 @@ Section Private
};
(e = NULL).if {
syntax_error (current_position,"Incorrect multiple result expression.");
- };
- }.do_while {read_character ','};
+ };
+ }.do_while {read_character ','};
};
e := ITM_RESULT.create e;
result.add_last e;
- };
+ };
ALIAS_ARRAY(ITM_CODE).copy result
);
-
+
- read_invariant:BOOLEAN <-
( + lst:ITM_LIST;
-
+
lst := read_contract;
- lst != NULL
+ lst != NULL
);
-
+
- read_require:BOOLEAN <-
( + lst:ITM_LIST;
+ result:BOOLEAN;
-
+
lst := read_contract;
(lst != NULL).if {
last_slot.set_require lst;
@@ -2093,7 +2093,7 @@ Section Private
- read_ensure:BOOLEAN <-
( + lst:ITM_LIST;
+ result:BOOLEAN;
-
+
lst := read_contract;
(lst != NULL).if {
last_slot.set_ensure lst;
@@ -2101,18 +2101,18 @@ Section Private
};
result
);
-
+
//++ CONTRACT -> '[' DEF_LOCAL { ( EXPR ';' | "..." ) } ']'
- read_contract:ITM_LIST <-
( + continue:BOOLEAN;
+ e:ITM_CODE;
+ result:ITM_LIST;
+ lst:FAST_ARRAY(ITM_CODE);
-
+
(read_character '[').if {
result := last_group := ITM_LIST.create current_position;
read_def_local;
-
+
lst := ALIAS_ARRAY(ITM_CODE).new;
{
e := read_expr;
@@ -2129,7 +2129,7 @@ Section Private
continue := TRUE;
};
}.do_while {continue};
-
+
(! read_character ']').if {
warning_error (current_position,"Added ']'.");
};
@@ -2140,15 +2140,15 @@ Section Private
};
result
);
-
+
//++ DEF_LOCAL -> { style LOCAL ';' } !! AMBIGU !!
- read_def_local <-
( + loc_lst:FAST_ARRAY(ITM_LOCAL);
- + local_list,static_list:FAST_ARRAY(ITM_LOCAL);
+ + local_list,static_list:FAST_ARRAY(ITM_LOCAL);
+ styl:CHARACTER;
-
+
save_context; // !! SAVE CONTEXT !!
-
+
styl := read_style;
local_list := ALIAS_ARRAY(ITM_LOCAL).new;
static_list := ALIAS_ARRAY(ITM_LOCAL).new;
@@ -2163,16 +2163,16 @@ Section Private
(read_character ';').if_false {
warning_error (current_position,"Added ';'.");
};
-
+
save_context; // !! SAVE CONTEXT !!
-
+
styl := read_style;
} else {
-
+
restore_context; // !! RESTORE CONTEXT !!
-
+
styl := ' ';
- };
+ };
};
(local_list.is_empty).if {
ALIAS_ARRAY(ITM_LOCAL).free local_list;
@@ -2182,10 +2182,10 @@ Section Private
(static_list.is_empty).if {
ALIAS_ARRAY(ITM_LOCAL).free static_list;
} else {
- last_group.set_static_list (ALIAS_ARRAY(ITM_LOCAL).copy static_list);
+ last_group.set_static_list (ALIAS_ARRAY(ITM_LOCAL).copy static_list);
};
);
-
+
//++ SEND_MSG -> identifier [ ARGUMENT { identifier ARGUMENT } ]
- read_send_msg first_arg:ITM_CODE :ITM_CODE <-
( + result:ITM_CODE;
@@ -2194,7 +2194,7 @@ Section Private
+ l_arg:FAST_ARRAY(ITM_CODE);
+ arg:ITM_CODE;
+ p1,p2,old_derive,sav_derive:INTEGER;
-
+
read_identifier.if {
//
// Classic Message.
@@ -2202,19 +2202,19 @@ Section Private
p1 := position - last_string.count;
p2 := position;
old_derive := short_derive;
-
+
n := ALIAS_STR.new;
n.copy last_string;
// Argument list.
l_arg := ALIAS_ARRAY(ITM_CODE).new;
arg := read_argument;
- (arg != NULL).if {
- l_arg.add_last arg;
+ (arg != NULL).if {
+ l_arg.add_last arg;
{read_identifier}.while_do {
-
- short (ALIAS_STR.short_slot_call) token
+
+ short (ALIAS_STR.short_slot_call) token
(position-last_string.count) to position;
-
+
n.append (ALIAS_STR.separate);
n.append last_string;
arg := read_argument;
@@ -2225,10 +2225,10 @@ Section Private
}; // loop
}; // if
name := ALIAS_STR.alias n;
-
+
(is_shorter).if {
(
- (! l_arg.is_empty) ||
+ (! l_arg.is_empty) ||
{first_arg != NULL} ||
{! short_local.fast_has last_string}
).if {
@@ -2238,23 +2238,23 @@ Section Private
short_derive := sav_derive + (short_derive-old_derive);
};
};
-
+
l_arg.is_empty.if {
(first_arg=NULL).if {
// Local ou Implicite Slot without argument.
- result := ITM_READ.create current_position name name;
- } else {
- result := ITM_READ_ARG1.create current_position name name arg first_arg;
+ result := ITM_READ.create current_position name name;
+ } else {
+ result := ITM_READ_ARG1.create current_position name name arg first_arg;
};
ALIAS_ARRAY(ITM_CODE).free l_arg;
}.elseif {l_arg.count=1} then {
- result := ITM_READ_ARG2.create current_position name
- name args (first_arg,(l_arg.first));
+ result := ITM_READ_ARG2.create current_position name
+ name args (first_arg,(l_arg.first));
ALIAS_ARRAY(ITM_CODE).free l_arg;
} else {
l_arg.add_first first_arg;
- l_arg := ALIAS_ARRAY(ITM_CODE).copy l_arg;
- result := ITM_READ_ARGS.create current_position name name args l_arg;
+ l_arg := ALIAS_ARRAY(ITM_CODE).copy l_arg;
+ result := ITM_READ_ARGS.create current_position name name args l_arg;
};
}; // if
result
@@ -2268,7 +2268,7 @@ Section Private
((result = NULL) && {read_identifier}).if {
(is_shorter).if {
(short_local.fast_has last_string).if_false {
- short (ALIAS_STR.short_slot_call) token
+ short (ALIAS_STR.short_slot_call) token
(position-last_string.count) to position;
};
};
@@ -2276,12 +2276,12 @@ Section Private
};
result
); // read_argument
-
+
// name, export, import, type, default, external, version, lip,
- // date, comment, author, bibliography, language, bug_report,
+ // date, comment, author, bibliography, language, bug_report,
// copyright.
- read_slot_header first:BOOLEAN :BOOLEAN <-
- ( + result:BOOLEAN;
+ ( + result:BOOLEAN;
+ v:ITM_CODE;
+ cast:FAST_ARRAY(ITM_TYPE_MONO);
+ style:CHARACTER;
@@ -2289,7 +2289,7 @@ Section Private
+ parameter_type:ITM_TYPE_PARAMETER;
+ instr:LIP_CODE;
+ param:{ITM_TYPE_PARAMETER};
-
+
style := read_style;
(style != ' ').if {
result := TRUE;
@@ -2301,14 +2301,14 @@ Section Private
//
// Read `name' slot.
//
-
- (style = '-').if {
+
+ (style = '-').if {
semantic_error (current_position,"COP not yet implemented.");
- is_cop := TRUE;
+ is_cop := TRUE;
(is_java).if {
semantic_error (current_position,"COP not yet implemented.");
} else {
- output_decl.append
+ output_decl.append
"#include <pthread.h>\n\
\#include <limits.h>\n\n\
\void print_char(char car);\n\
@@ -2316,7 +2316,7 @@ Section Private
\static pthread_key_t current_thread;\n\
\static pthread_attr_t thread_attr;\n\
\pthread_t c_thread;\n\
- \int thread_counter;\n\n\
+ \int thread_counter;\n\n\
\static char thread_stack[512][PTHREAD_STACK_MIN];\n\n\
\typedef struct lith_object_struct lith_object;\n\
\typedef struct lith_node_struct lith_node;\n\
@@ -2324,7 +2324,7 @@ Section Private
\ pthread_mutex_t mutex;\n\
\ lith_node *next;\n\
\ lith_object *object;\n\
- \};\n\
+ \};\n\
\struct lith_object_struct {\n\
\ unsigned long __id; // Just for late binding.\n\
\ lith_node *first;\n\
@@ -2338,7 +2338,7 @@ Section Private
\} pool;\n\n\
\void *thread_life(void *ptr)\n\
\{ lith_node node,*n;\n\
- \ lith_object *obj,*new_obj;\n\n\
+ \ lith_object *obj,*new_obj;\n\n\
\ pthread_mutex_init(&node.mutex,NULL);\n\
\ pthread_mutex_lock(&node.mutex);\n\
\ node.object = (lith_object *)ptr;\n\
@@ -2392,7 +2392,7 @@ Section Private
\ };\n\
\ pthread_mutex_unlock(&pool.mutex);\n\
\ // Run thread.\n\
- \ if (node == NULL) {\n\
+ \ if (node == NULL) {\n\
\ pthread_attr_setstack(&thread_attr, thread_stack[thread_counter++],PTHREAD_STACK_MIN);\n\
\ if ((thread_counter>512) || pthread_create(&c_thread,&thread_attr, thread_life, (void *)obj)) {\n\
\ while (*msg != 0) print_char(*(msg++));\n\
@@ -2405,40 +2405,40 @@ Section Private
\};\n\n";
};
};
-
+
// style "name" ':=' [type] cap_identifier [ '(' PARAM {',' PARAM}')' ]
// PARAM -> cap_identifier | identifier ':' TYPE
- short (ALIAS_STR.short_slot) token
- (position-last_string.count) to position;
-
+ short (ALIAS_STR.short_slot) token
+ (position-last_string.count) to position;
+
object.set_position current_position;
- object.set_style style;
+ object.set_style style;
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if_false {
warning_error (current_position,"Added ':='.");
};
-
+
(
(read_this_keyword (ALIAS_STR.keyword_expanded)) ||
- {read_this_keyword (ALIAS_STR.keyword_strict)}
+ {read_this_keyword (ALIAS_STR.keyword_strict)}
).if {
- object.set_type_style last_string;
+ object.set_type_style last_string;
};
-
+
(! read_cap_identifier).if {
syntax_error (current_position,"Prototype identifier is needed.");
};
short (ALIAS_STR.short_prototype) token
(position-last_string.count) to position;
-
+
(object.shortname != last_string).if {
syntax_error (current_position,"Incorrect name (filename != name).");
- };
+ };
(read_character '(').if {
//
// Generic loader.
//
param := { + res:ITM_TYPE_PARAMETER;
- (read_identifier).if {
+ (read_identifier).if {
(read_character ':').if_false {
warning_error (current_position,"Added ':'.");
};
@@ -2457,44 +2457,44 @@ Section Private
};
res
};
-
- ((! is_shorter) && {! is_shorter2}).if {
- (object.generic_count = 0).if {
+
+ ((! is_shorter) && {! is_shorter2}).if {
+ (object.generic_count = 0).if {
syntax_error (current_position,"Object can't be generic.");
};
};
parameter_type := param.value;
(parameter_type = NULL).if {
syntax_error (current_position,"Identifier parameter type is needed.");
- };
-
- object.idf_generic_list.add_last parameter_type;
- {read_character ','}.while_do {
+ };
+
+ object.idf_generic_list.add_last parameter_type;
+ {read_character ','}.while_do {
parameter_type := param.value;
(parameter_type = NULL).if {
syntax_error (current_position,"Identifier parameter type is needed.");
- };
+ };
object.idf_generic_list.add_last parameter_type;
}; // loop
-
+
(! read_character ')').if {
warning_error (current_position,"Added ')'.");
};
-
- ((! is_shorter) && {! is_shorter2}).if {
+
+ ((! is_shorter) && {! is_shorter2}).if {
(object.idf_generic_list.count != object.generic_count).if {
syntax_error (current_position,"Invalid generic list number.");
};
};
- };
+ };
} else {
syntax_error (current_position,"Slot `name' must to be first slot.");
};
}.elseif {
- (is_export := read_word (ALIAS_STR.slot_export)) ||
+ (is_export := read_word (ALIAS_STR.slot_export)) ||
{read_word (ALIAS_STR.slot_import)}
} then {
- // - ("export"|"import") ':=' TYPE_LIST
+ // - ("export"|"import") ':=' TYPE_LIST
short (ALIAS_STR.short_slot) token
(position-last_string.count) to position;
@@ -2514,7 +2514,7 @@ Section Private
//
// Read `external' slot.
//
-
+
// - "external" ':=' `<code_c>`
short (ALIAS_STR.short_slot) token
(position-last_string.count) to position;
@@ -2528,17 +2528,17 @@ Section Private
output_decl.append "/* ";
output_decl.append (object.name);
output_decl.append " */\n";
- output_decl.append last_string;
+ output_decl.append last_string;
output_decl.add_last '\n';
}.elseif {read_word(ALIAS_STR.slot_default)} then {
//
// Read `default' slot.
//
-
+
// '-' "default" ':=' EXPR_PRIMARY
short (ALIAS_STR.short_slot) token
(position-last_string.count) to position;
-
+
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if_false {
warning_error (current_position,"Added ':='.");
};
@@ -2554,11 +2554,11 @@ Section Private
//
// Read `type' slot.
//
-
+
// '-' "type" ':=' `<type C>`
short (ALIAS_STR.short_slot) token
(position-last_string.count) to position;
-
+
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if_false {
warning_error (current_position,"Added ':='.");
};
@@ -2573,32 +2573,32 @@ Section Private
//
// Read `version' slot.
//
-
+
// '-' "version" ':=' integer
short (ALIAS_STR.short_slot) token
(position-last_string.count) to position;
-
+
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if_false {
warning_error (current_position,"Added ':='.");
};
(read_integer).if_false {
syntax_error (current_position,"Incorrect number.");
};
-
+
}.elseif {read_word (ALIAS_STR.slot_lip)} then {
//
// LIP interpreter.
//
-
+
// '-' lip <- ( { LIP_EXPR ';' } )
(read_symbol (ALIAS_STR.symbol_affect_code)).if_false {
warning_error (current_position,"Added '<-' is needed.");
- };
+ };
(read_character '(').if_false {
warning_error (current_position,"Added '(' is needed.");
- };
+ };
{(instr := readlip_expr) != NULL}.while_do {
- ((! is_shorter) && {! is_shorter2}).if {
+ ((! is_shorter) && {! is_shorter2}).if {
instr.run;
};
(read_character ';').if_false {
@@ -2607,7 +2607,7 @@ Section Private
};
(read_character ')').if_false {
warning_error (current_position,"Added ')' is needed.");
- };
+ };
}.elseif {
(read_word (ALIAS_STR.slot_date)) ||
{read_word (ALIAS_STR.slot_comment)} ||
@@ -2617,22 +2617,22 @@ Section Private
{read_word (ALIAS_STR.slot_copyright)} ||
{read_word (ALIAS_STR.slot_bug_report)}
} then {
- //
- // Read `date', `comment', `author', `bibliography',
+ //
+ // Read `date', `comment', `author', `bibliography',
// `language', `copyright' or `bug_report' slots.
//
-
- // '-' ("date"|"comment"|"author"|"bibliography"|"language"|"copyright"|"bug_report")
+
+ // '-' ("date"|"comment"|"author"|"bibliography"|"language"|"copyright"|"bug_report")
// ':=' string
- short (ALIAS_STR.short_slot) token
- (position-last_string.count) to position;
-
+ short (ALIAS_STR.short_slot) token
+ (position-last_string.count) to position;
+
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if_false {
warning_error (current_position,"Added ':='.");
- };
+ };
(read_string).if_false {
syntax_error (current_position,"Incorrect string.");
- };
+ };
(is_shorter2).if {
object.set_comment_slot last_string;
};
@@ -2645,20 +2645,20 @@ Section Private
};
result
);
-
+
//
// Parser for LIP file.
- //
-
- - readlip_program <-
- //// PROGRAM -> { 'Section' ('Inherit' | 'Public' | 'Private') { SLOT ';' } }
+ //
+
+ - readlip_program <-
+ //// PROGRAM -> { 'Section' ('Inherit' | 'Public' | 'Private') { SLOT ';' } }
( + idx:INTEGER;
+ section:STRING_CONSTANT;
-
- idx := LIP_CODE.list_parent.lower;
- {read_this_keyword (ALIAS_STR.keyword_section)}.while_do {
+
+ idx := LIP_CODE.list_parent.lower;
+ {read_this_keyword (ALIAS_STR.keyword_section)}.while_do {
(read_this_keyword (ALIAS_STR.section_inherit)).if {
- // { '+' string ':' STRING [ ':=' string ] ';' }
+ // { '+' string ':' STRING [ ':=' string ] ';' }
{read_character '+'}.while_do {
(read_identifier).if_false {
warning_error (current_position,"Identifier needed.");
@@ -2669,19 +2669,19 @@ Section Private
(read_word (ALIAS_STR.prototype_string)).if_false {
warning_error (current_position,"`STRING' type needed.");
};
- (read_symbol (ALIAS_STR.symbol_affect_immediate)).if {
- (read_string).if_false {
- syntax_error (current_position,"String needed.");
- };
+ (read_symbol (ALIAS_STR.symbol_affect_immediate)).if {
+ (read_string).if_false {
+ syntax_error (current_position,"String needed.");
+ };
string_tmp.copy (object.filename);
{
- (!string_tmp.is_empty) &&
- {string_tmp.last != '/'} &&
+ (!string_tmp.is_empty) &&
+ {string_tmp.last != '/'} &&
{string_tmp.last != '\\'}
}.while_do {
string_tmp.remove_last 1;
};
- string_tmp.append last_string;
+ string_tmp.append last_string;
} else {
string_tmp.clear;
};
@@ -2693,7 +2693,7 @@ Section Private
};
}.elseif {
(read_this_keyword (ALIAS_STR.section_public)) ||
- {read_this_keyword (ALIAS_STR.section_private)}
+ {read_this_keyword (ALIAS_STR.section_private)}
} then {
section := last_string;
{readlip_slot section}.while_do {
@@ -2706,19 +2706,19 @@ Section Private
};
};
);
-
+
- readlip_slot sec:STRING_CONSTANT :BOOLEAN <-
//// SLOT -> '+' identifier ':' TYPE [ ':=' EXPR_CONSTANT ]
- //// | '-' identifier [ identifier ':' TYPE ] '<-' EXPR
+ //// | '-' identifier [ identifier ':' TYPE ] '<-' EXPR
( + result:BOOLEAN;
+ t:LIP_CONSTANT;
+ n,na:STRING_CONSTANT;
+ data:LIP_SLOT_DATA;
+ slot_code:LIP_SLOT_CODE;
- + exp:LIP_CODE;
+ + exp:LIP_CODE;
+ pos:POSITION;
+ cst:LIP_CONSTANT;
-
+
(read_character '+').if {
// Data.
result := TRUE;
@@ -2735,14 +2735,14 @@ Section Private
t := readlip_type;
(t = NULL).if {
syntax_error (current_position,"type is incorrect.");
- };
+ };
data := LIP_SLOT_DATA.create current_position name n value t argument FALSE;
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if {
cst := readlip_expr_constant;
(cst = NULL).if {
syntax_error (current_position,"Incorrect expression.");
};
- data.set_value cst;
+ data.set_value cst;
cst.free;
};
}.elseif {read_character '-'} then {
@@ -2751,7 +2751,7 @@ Section Private
(read_identifier).if_false {
syntax_error (current_position,"Identifier is incorrect.");
};
- pos := current_position;
+ pos := current_position;
n := last_string;
(read_identifier).if {
na := last_string;
@@ -2763,19 +2763,19 @@ Section Private
syntax_error (current_position,"Incorrect type.");
};
data := LIP_SLOT_DATA.create current_position name na value t argument TRUE;
- };
- //
+ };
+ //
(read_symbol (ALIAS_STR.symbol_affect_code)).if_false {
warning_error (current_position,"Added '<-' is needed.");
- };
+ };
is_shorter2 := TRUE;
read_space;
is_shorter2 := FALSE;
exp := readlip_expr;
(exp = NULL).if {
syntax_error (current_position,"Expression needed.");
- };
- slot_code := LIP_SLOT_CODE.create pos section sec
+ };
+ slot_code := LIP_SLOT_CODE.create pos section sec
name n argument data code exp;
(sec = ALIAS_STR.section_public).if {
(last_comment_slot = NULL).if {
@@ -2783,61 +2783,61 @@ Section Private
} else {
slot_code.set_comment (ALIAS_STR.get last_comment_slot);
};
- };
+ };
};
result
);
-
+
- readlip_type:LIP_CONSTANT <-
//// TYPE -> 'BOOLEAN' | 'STRING' | 'INTEGER' | 'LIP'
( + result:LIP_CONSTANT;
-
- (read_cap_identifier).if {
+
+ (read_cap_identifier).if {
(last_string = ALIAS_STR.prototype_integer).if {
result := LIP_INTEGER.get 0;
- }.elseif {last_string = ALIAS_STR.prototype_string} then {
- result := LIP_STRING.get (ALIAS_STR.get "");
- }.elseif {last_string = ALIAS_STR.prototype_boolean} then {
+ }.elseif {last_string = ALIAS_STR.prototype_string} then {
+ result := LIP_STRING.get (ALIAS_STR.get "");
+ }.elseif {last_string = ALIAS_STR.prototype_boolean} then {
result := LIP_BOOLEAN.get FALSE;
}.elseif {last_string = ALIAS_STR.prototype_lip} then {
not_yet_implemented;
} else {
syntax_error (current_position,"Incorrect type.");
- };
+ };
};
result
);
-
- - readlip_expr_affect:LIP_CODE <-
+
+ - readlip_expr_affect:LIP_CODE <-
//// EXPR_AFFECT -> [ identifier !!AMBIGU!! ':=' ] EXPR
( + result,val:LIP_CODE;
+ nam:STRING_CONSTANT;
-
+
save_context; // !! SAVE CONTEXT !!
-
+
(read_identifier).if {
nam := last_string;
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if {
val := readlip_expr;
(val = NULL).if {
syntax_error (current_position,"Incorrect expression.");
- };
+ };
result := LIP_AFFECT.create current_position name nam value val;
} else {
restore_context; // !! RESTORE CONTEXT !!
};
- };
+ };
(result = NULL).if {
- result := readlip_expr;
+ result := readlip_expr;
};
result
);
-
- - readlip_expr:LIP_CODE <-
- //// EXPR -> EXPR_CMP { ('|' | '&') EXPR_CMP }
+
+ - readlip_expr:LIP_CODE <-
+ //// EXPR -> EXPR_CMP { ('|' | '&') EXPR_CMP }
( + result,right:LIP_CODE;
- + is_or:BOOLEAN;
-
+ + is_or:BOOLEAN;
+
result := readlip_expr_cmp;
(result != NULL).if {
{(is_or := read_character '|') || {read_character '&'}}.while_do {
@@ -2854,21 +2854,21 @@ Section Private
};
result
);
-
+
- readlip_expr_cmp:LIP_CODE <-
//// EXPR_CMP -> EXPR_BINARY { ('='|'!='|'>'|'<'|'>='|'<=') EXPR_BINARY }
( + result,right:LIP_CODE;
- + op:STRING_CONSTANT;
+ + op:STRING_CONSTANT;
+ type:CHARACTER;
-
+
result := readlip_expr_binary;
(result != NULL).if {
{
- (read_symbol (ALIAS_STR.symbol_great_equal)) ||
+ (read_symbol (ALIAS_STR.symbol_great_equal)) ||
{read_symbol (ALIAS_STR.symbol_less_equal)} ||
- {read_symbol (ALIAS_STR.symbol_not_equal)} ||
+ {read_symbol (ALIAS_STR.symbol_not_equal)} ||
{read_symbol (ALIAS_STR.symbol_equal)} ||
- {read_symbol (ALIAS_STR.symbol_great)} ||
+ {read_symbol (ALIAS_STR.symbol_great)} ||
{read_symbol (ALIAS_STR.symbol_less)}
}.while_do {
op := last_string;
@@ -2888,12 +2888,12 @@ Section Private
};
result
);
-
- - readlip_expr_binary:LIP_CODE <-
+
+ - readlip_expr_binary:LIP_CODE <-
//// EXPR_BINARY -> EXPR_UNARY { ('-'|'+') EXPR_UNARY }
( + result,right:LIP_CODE;
+ is_sub:BOOLEAN;
-
+
result := readlip_expr_unary;
(result != NULL).if {
{(is_sub := read_character '-') || {read_character '+'}}.while_do {
@@ -2910,15 +2910,15 @@ Section Private
};
result
);
-
- - readlip_expr_unary:LIP_CODE <-
+
+ - readlip_expr_unary:LIP_CODE <-
//// EXPR_UNARY -> ( '-' | '!' ) EXPR_UNARY
- //// | EXPR_BASE
+ //// | EXPR_BASE
( + result:LIP_CODE;
+ is_neg:BOOLEAN;
+ type:CHARACTER;
-
- ((is_neg := read_character '-') || {read_character '!'}).if {
+
+ ((is_neg := read_character '-') || {read_character '!'}).if {
result := readlip_expr_unary;
(result = NULL).if {
syntax_error (current_position,"Incorrect expression.");
@@ -2934,7 +2934,7 @@ Section Private
};
result
);
-
+
- readlip_expr_list cod:FAST_ARRAY(LIP_CODE) <-
//// EXPR_LIST -> { EXPR_AFFECT ';' } [ EXPR_AFFECT ]
( + instr:LIP_CODE;
@@ -2942,15 +2942,15 @@ Section Private
((instr := readlip_expr_affect) != NULL) &&
{read_character ';'}
}.while_do {
- cod.add_last instr;
+ cod.add_last instr;
};
cod.add_last instr;
);
-
- - readlip_expr_base:LIP_CODE <-
- //// EXPR_BASE -> EXPR_RECEIVER { '.' EXPR_MESSAGE }
+
+ - readlip_expr_base:LIP_CODE <-
+ //// EXPR_BASE -> EXPR_RECEIVER { '.' EXPR_MESSAGE }
( + result:LIP_CODE;
-
+
result := readlip_expr_receiver;
{read_character '.'}.while_do {
result := readlip_expr_message result;
@@ -2960,9 +2960,9 @@ Section Private
};
result
);
-
+
- readlip_expr_receiver:LIP_CODE <-
- //// EXPR_RECEIVER-> EXPR_PRIMARY
+ //// EXPR_RECEIVER-> EXPR_PRIMARY
//// | EXPR_MESSAGE
( + result:LIP_CODE;
result := readlip_expr_primary;
@@ -2971,20 +2971,20 @@ Section Private
};
result
);
-
+
- readlip_expr_message rec:LIP_CODE :LIP_CODE <-
- //// EXPR_MESSAGE -> identifier [ EXPR_ARGUMENT ]
- //// | 'if' '{' EXPR_LIST '}' [ 'else' '{' EXPR_LIST '}' ]
+ //// EXPR_MESSAGE -> identifier [ EXPR_ARGUMENT ]
+ //// | 'if' '{' EXPR_LIST '}' [ 'else' '{' EXPR_LIST '}' ]
( + result,arg:LIP_CODE;
+ nam:STRING_CONSTANT;
+ the,els:FAST_ARRAY(LIP_CODE);
-
+
(read_word (ALIAS_STR.slot_if)).if {
- the := ALIAS_ARRAY(LIP_CODE).new;
+ the := ALIAS_ARRAY(LIP_CODE).new;
(read_character '{').if_false {
warning_error (current_position,"Added '(' is needed.");
};
- readlip_expr_list the;
+ readlip_expr_list the;
(read_character '}').if_false {
warning_error (current_position,"Added '(' is needed.");
};
@@ -2994,66 +2994,66 @@ Section Private
(read_character '{').if_false {
warning_error (current_position,"Added '(' is needed.");
};
- readlip_expr_list els;
+ readlip_expr_list els;
(read_character '}').if_false {
warning_error (current_position,"Added '(' is needed.");
};
els := ALIAS_ARRAY(LIP_CODE).copy els;
};
- result := LIP_IF.create current_position if rec then the else els;
+ result := LIP_IF.create current_position if rec then the else els;
}.elseif {read_identifier} then {
nam := last_string;
arg := readlip_expr_argument;
- result := LIP_CALL.create current_position
+ result := LIP_CALL.create current_position
receiver rec name nam with arg;
};
result
);
-
+
- readlip_expr_argument:LIP_CODE <-
- //// EXPR_ARGUMENT-> identifier
+ //// EXPR_ARGUMENT-> identifier
//// | EXPR_PRIMARY
( + result:LIP_CODE;
-
+
(read_identifier).if {
- result := LIP_CALL.create current_position
+ result := LIP_CALL.create current_position
receiver NULL name last_string with NULL;
} else {
result := readlip_expr_primary;
};
result
);
-
+
- readlip_expr_primary:LIP_CODE <-
//// EXPR_PRIMARY -> EXPR_CONSTANT
//// | '(' EXPR_LIST ')'
( + result:LIP_CODE;
+ val:LIP_CONSTANT;
+ lst:FAST_ARRAY(LIP_CODE);
-
- val := readlip_expr_constant;
+
+ val := readlip_expr_constant;
(val != NULL).if {
result := LIP_VALUE.create current_position with val;
}.elseif {read_character '('} then {
- lst := ALIAS_ARRAY(LIP_CODE).new;
- readlip_expr_list lst;
+ lst := ALIAS_ARRAY(LIP_CODE).new;
+ readlip_expr_list lst;
(read_character ')').if_false {
warning_error (current_position,"Added ')'.");
};
lst := ALIAS_ARRAY(LIP_CODE).copy lst;
result := LIP_LIST.create current_position with lst;
};
- result
+ result
);
-
+
- readlip_expr_constant:LIP_CONSTANT <-
- //// EXPR_CONSTANT-> integer
+ //// EXPR_CONSTANT-> integer
//// | string
//// | TRUE
//// | FALSE
( + result:LIP_CONSTANT;
- (read_integer).if {
+ (read_integer).if {
result := LIP_INTEGER.get last_integer;
}.elseif {read_string} then {
result := LIP_STRING.get last_string;
@@ -3065,21 +3065,21 @@ Section Private
} else {
syntax_error (current_position,"Type incorrect.");
};
- };
+ };
result
);
-
+
//
// Parser for FORMAT.LI
- //
+ //
//|| FORMAT -> { '-' identifier ':=' SHORT_DEF ';' }
- read_format <-
( + def:LINKED_LIST(STRING_CONSTANT);
-
+
{read_character '-'}.while_do {
(read_identifier).if_false {
- syntax_error (current_position,"Incorrect slot identifier.");
+ syntax_error (current_position,"Incorrect slot identifier.");
};
def := LINKED_LIST(STRING_CONSTANT).create;
(short_dico.fast_has last_string).if {
@@ -3088,15 +3088,15 @@ Section Private
short_dico.fast_put def to last_string;
(read_symbol (ALIAS_STR.symbol_affect_immediate)).if_false {
syntax_error (current_position,"Assignment ':=' is needed.");
- };
+ };
(read_short_def def).if_false {
syntax_error (current_position,"Incorrect definition.");
};
(read_character ';').if_false {
warning_error (current_position,"Added ';' is needed.");
- };
+ };
};
-
+
// End of file :
read_space;
(last_character != 0.to_character).if {
@@ -3107,10 +3107,10 @@ Section Private
//|| SHORT_DEF -> { SHORT_ELT '+' } SHORT_ELT
- read_short_def def:LINKED_LIST(STRING_CONSTANT) :BOOLEAN <-
( + result:BOOLEAN;
-
+
read_short_elt.if {
result := TRUE;
- def.add_last last_string;
+ def.add_last last_string;
{read_character '+'}.while_do {
(read_short_elt).if_false {
syntax_error (current_position,"Incorrect format expression.");
@@ -3125,7 +3125,7 @@ Section Private
- read_short_elt:BOOLEAN <-
( + result:BOOLEAN;
+ j:INTEGER;
-
+
read_identifier.if {
(last_string != ALIAS_STR.short_token).if {
warning_error (current_position,"Variable not `token'.");
@@ -3137,7 +3137,7 @@ Section Private
j := last_string.lower;
{j <= last_string.upper}.while_do {
(last_string.item j = '\\').if {
- j := j+1;
+ j := j+1;
last_string.item j
.when 'a' then { string_tmp.add_last '\a'; }
.when 'b' then { string_tmp.add_last '\b'; }
@@ -3160,17 +3160,17 @@ Section Private
};
result
);
-
-Section Public
-
+
+Section Public
+
//
// Parser Entry.
//
-
+
- go_on obj:PROTOTYPE <-
(
? { object=NULL};
-
+
// Source information.
object := obj;
source := obj.source;
@@ -3178,52 +3178,52 @@ Section Public
pos_cur := source.lower;
pos_line := 1;
pos_col := 0;
-
+
(is_shorter).if {
- is_active_short := TRUE;
+ is_active_short := TRUE;
short_derive := 0;
output_code.copy source;
short_local := HASHED_SET(STRING_CONSTANT).create;
short (ALIAS_STR.short_begin) token 1 to 1;
};
-
+
// Parse.
(! read_program).if {
syntax_error (current_position,"Incorrect symbol.");
};
-
+
short (ALIAS_STR.short_end) token (source.upper) to (source.upper);
-
+
object := NULL; // Parser is Free (see require test...)
);
-
+
- read_lip path_lip:STRING_CONSTANT :BOOLEAN <-
- ( + entry:POINTER;
-
+ ( + entry:POINTER;
+
entry := FS_MIN.open_read path_lip;
(entry != NULL).if {
FS_MIN.close entry;
object := PROTOTYPE.create path_lip
name path_lip generic_count 0;
-
+
source := object.source;
position := source.lower;
pos_cur := source.lower;
pos_line:=1;
pos_col :=0;
is_shorter := is_shorter2 := FALSE;
-
+
// Parse.
readlip_program;
//
is_shorter := Old is_shorter;
is_shorter2 := Old is_shorter2;
object := NULL; // Parser is Free (see require test...)
- }
+ }
);
- parse_format fmt_name:STRING_CONSTANT <-
- (
+ (
// Source information.
(FILE_SYSTEM.get_entry fmt_name = NULL).if {
STD_ERROR.put_string "Error: File format `";
@@ -3231,20 +3231,20 @@ Section Public
STD_ERROR.put_string "' is not open !\n";
die_with_code exit_failure_code;
};
-
- object := PROTOTYPE.create fmt_name
- name (ALIAS_STR.short_format)
- generic_count 0;
-
+
+ object := PROTOTYPE.create fmt_name
+ name (ALIAS_STR.short_format)
+ generic_count 0;
+
source := object.source;
position := source.lower;
pos_cur := source.lower;
pos_line := 1;
pos_col := 0;
-
+
// Parse.
read_format;
-
+
object := NULL; // Parser is Free (see require test...)
);
diff --git a/src/profil.li b/src/profil.li
index ed344cd..3b4f12d 100644
--- a/src/profil.li
+++ b/src/profil.li
@@ -227,10 +227,10 @@ Section Public
(argument_list.lower).to (argument_list.upper) do { j:INTEGER;
loc := argument_list.item j;
val := args.item j;
- (loc != NULL).if {
+ (loc != NULL).if {
wrt := loc.write (val.position) value val;
result.add_last wrt;
- } else {
+ } else {
result.add_last NULL;
val.remove;
};
@@ -324,20 +324,20 @@ Section Public
{result_list.is_empty}
).if {
switch ?= code.last;
- (switch != NULL).if {
+ (switch != NULL).if {
// Verification cases:
(switch.list.lower).to (switch.list.upper) do { j:INTEGER;
lst := switch.list.item j.code;
(lst.is_empty).if_false {
msg ?= lst.last;
- ((msg != NULL) && {msg.profil = Self}).if {
+ ((msg != NULL) && {msg.profil = Self}).if {
count_recur := count_recur + 1;
};
};
};
(count_recur = switch.list.count).if {
semantic_error (slot.position,"Recursivity without end.");
- };
+ };
((count_intern_call - 1) = count_recur).if {
((link_count = count_intern_call) || {! is_context_sensitive}).if {
new_execute_pass;
@@ -360,21 +360,21 @@ Section Public
(stat = -1).if {
count_intern_call := count_intern_call + 1;
- (count_intern_call = 1).if {
+ (count_intern_call = 1).if {
old_list_current := list_current;
old_profil_current := profil_current;
//
profil_current := Self;
execute 3;
- //
+ //
list_current := old_list_current;
profil_current := old_profil_current;
? {code != NULL};
- (count_intern_call = 1).if {
+ (count_intern_call = 1).if {
stat := 0;
} else {
stat := recursivity_bit;
- };
+ };
};
};
);
@@ -474,7 +474,7 @@ Section Public
v := argument_list.item j;
(v != NULL).if {
? {(v.style = ' ') || {v.style = '!'}};
- genere v result FALSE in buffer;
+ genere v result FALSE in buffer;
buffer.add_last ',';
};
};
@@ -552,7 +552,7 @@ Section Public
{! t.is_expanded_c}
).if {
buffer.add_last '&';
- };
+ };
(loc.my_alias = NULL).if {
idf := loc.intern_name;
} else {
@@ -578,7 +578,7 @@ Section Public
buffer.append indent;
v := argument_list.first;
((v != NULL) && {v.name = ALIAS_STR.variable_self}).if {
- genere v result FALSE in buffer;
+ genere v result FALSE in buffer;
buffer.add_last '=';
put_cast_self buffer;
buffer.append "obj;\n";
@@ -590,12 +590,12 @@ Section Public
v := argument_list.item j;
(v != NULL).if {
buffer.append indent;
- genere v result FALSE in buffer;
+ genere v result FALSE in buffer;
buffer.append "=(";
ts := v.type;
ts.genere_declaration buffer;
buffer.add_last ' ';
- ts.genere_star_declaration buffer;
+ ts.genere_star_declaration buffer;
buffer.append ")((";
put_cast_self buffer;
buffer.append "obj)->param_";
@@ -649,7 +649,7 @@ Section Private
- put_cast_self buffer:STRING <-
(
buffer.add_last '(';
- type_self.genere_declaration buffer;
+ type_self.genere_declaration buffer;
buffer.add_last ' ';
type_self.genere_star_declaration buffer;
buffer.add_last ')';
@@ -676,7 +676,7 @@ Section Private
};
buffer.append " */\n";
);
-
+
/*
- recur_cpa buf:STRING arg n:INTEGER <-
( + var:LOCAL;
@@ -702,7 +702,7 @@ Section Private
};
);
*/
-
+
- append_type buffer:STRING <-
( + v:VARIABLE;
+ nb_arg,nb_arg_poly,tmp:INTEGER;
@@ -775,7 +775,7 @@ Section Private
ts.genere_declaration buffer;
buffer.add_last ' ';
- ts.genere_star_declaration buffer;
+ ts.genere_star_declaration buffer;
(is_res).if {
buffer.add_last '*';
};
@@ -811,13 +811,13 @@ Section Private
switch ?= code.last;
(switch.list.lower).to (switch.list.upper) do { k:INTEGER;
body := switch.list.item k.code;
- (body.is_empty).if_false {
+ (body.is_empty).if_false {
msg_slot ?= body.last;
- ((msg_slot != NULL) && {msg_slot.profil = Self}).if {
+ ((msg_slot != NULL) && {msg_slot.profil = Self}).if {
link_count := link_count - 1;
msg_slot.argument_to_assignment body index (body.upper) alias FALSE style '!';
body.put (LOOP_END.create (msg_slot.position) loop loop) to (body.upper);
- };
+ };
};
};
count_intern_call := 1;
diff --git a/src/profil_block.li b/src/profil_block.li
index 9d8c354..bf3246a 100644
--- a/src/profil_block.li
+++ b/src/profil_block.li
@@ -254,7 +254,7 @@ Section Public
lst.add_last (loc.type.get_temporary_expr (loc.position));
};
result := EXPR_MULTIPLE.create lst;
- }.elseif {result_list.count = 1} then {
+ }.elseif {result_list.count = 1} then {
loc := result_list.first;
result := loc.type.get_temporary_expr (loc.position);
} else {
diff --git a/src/profil_list.li b/src/profil_list.li
index ce68f19..6d76ab9 100644
--- a/src/profil_list.li
+++ b/src/profil_list.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PROFIL_LIST;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Profil list manager.";
-
+
Section Inherit
-
- + parent_any:Expanded ANY;
-
+
+ + parent_any:Expanded ANY;
+
Section LISAAC
-
- - profil_list:FAST_ARRAY(PROFIL) := FAST_ARRAY(PROFIL).create_with_capacity 65536;
-
+
+ - profil_list:FAST_ARRAY(PROFIL) := FAST_ARRAY(PROFIL).create_with_capacity 65536;
+
- life_limit:INTEGER;
-
+
- life_limit_base:INTEGER;
-
+
- current:INTEGER;
-
+
- swap i1:INTEGER with i2:INTEGER <-
(
profil_list.item i2.set_life_index i1;
profil_list.item i1.set_life_index i2;
- profil_list.swap i1 with i2;
+ profil_list.swap i1 with i2;
);
- clean <-
(
reduce_profil := profil_list.upper >= life_limit;
- {profil_list.upper >= life_limit}.while_do {
- profil_list.last.remove;
+ {profil_list.upper >= life_limit}.while_do {
+ profil_list.last.remove;
profil_list.remove_last;
};
);
-
+
Section Public
-
+
- reduce_profil:BOOLEAN := TRUE;
-
+
- add p:PROFIL <-
- (
+ (
(p.is_external).if {
profil_list.add_first p;
life_limit_base := life_limit_base + 1;
@@ -72,13 +72,13 @@ Section Public
profil_list.item i.set_life_index i;
};
} else {
- profil_list.add_last p;
+ profil_list.add_last p;
p.set_life_index (profil_list.upper);
};
);
-
+
- set_life p:PROFIL <-
- [
+ [
(p.life_index = -1).if {
p.name.print;
semantic_error (p.slot.position,"LA");
@@ -87,57 +87,57 @@ Section Public
-? { profil_list.item (p.life_index) = p };
]
( + idx:INTEGER;
-
+
idx := p.life_index;
(idx = life_limit).if {
life_limit := life_limit + 1;
- }.elseif {idx > life_limit} then {
- swap idx with life_limit;
+ }.elseif {idx > life_limit} then {
+ swap idx with life_limit;
life_limit := life_limit + 1;
};
)
- [
+ [
+? { profil_list.item (p.life_index) = p };
+? { p.life_index < life_limit };
];
-
+
- unset_life p:PROFIL <-
[
-? { p.life_index != -1 };
]
( + idx:INTEGER;
-
+
idx := p.life_index;
(idx < life_limit).if {
- life_limit := life_limit - 1;
+ life_limit := life_limit - 1;
(idx < life_limit).if {
(idx > current).if {
- swap idx with life_limit;
- } else {
+ swap idx with life_limit;
+ } else {
swap idx with current;
- swap current with life_limit;
+ swap current with life_limit;
current := current - 1;
};
};
- };
+ };
);
-
+
- remove p:PROFIL <-
[
-? { p.life_index != -1 };
]
( + idx:INTEGER;
-
+
unset_life p;
idx := p.life_index;
(idx != profil_list.upper).if {
swap idx with (profil_list.upper);
};
profil_list.remove_last;
- // Debug.
+ // Debug.
! {p.set_life_index (-1)};
);
-
+
- execute_pass_recursive <-
(
(profil_list.lower).to (profil_list.upper) do { i:INTEGER;
@@ -147,30 +147,30 @@ Section Public
life_limit := life_limit_base;
PROFIL.set_mode_recursive TRUE;
profil_current := profil_slot := NULL;
- list_current := NULL;
- list_main.execute;
+ list_current := NULL;
+ list_main.execute;
PROFIL.set_mode_recursive FALSE;
clean;
reduce_profil := TRUE;
);
-
+
- inline_level_current:INTEGER := 3;
-
+
- execute_pass <-
- (
+ (
VARIABLE.update;
life_limit := life_limit_base;
profil_slot := NULL;
- list_current := NULL;
- list_main.execute;
+ list_current := NULL;
+ list_main.execute;
current := profil_list.lower;
- {current < life_limit}.while_do {
+ {current < life_limit}.while_do {
profil_current := profil_list.item current;
profil_current.execute inline_level_current;
current := current + 1;
- };
+ };
current := 0;
- clean;
+ clean;
((! reduce_profil) && {inline_level_current < inline_level}).if {
inline_level_current := inline_level_current + 3;
new_execute_pass;
@@ -180,35 +180,34 @@ Section Public
TYPE_GENERIC.detect_alias;
};
);
-
+
//
// Genere.
//
-
+
- genere_handler buffer:STRING <-
(
(profil_list.lower).to (profil_list.upper) do { j:INTEGER;
- profil_list.item j.genere_handler buffer;
+ profil_list.item j.genere_handler buffer;
};
);
-
+
- genere buffer:STRING <-
(
(profil_list.lower).to (profil_list.upper) do { j:INTEGER;
- profil_list.item j.genere buffer;
+ profil_list.item j.genere buffer;
};
);
//
// Display.
//
-
+
- display <-
- (
+ (
string_tmp.clear;
(profil_list.upper).downto (profil_list.lower) do { j:INTEGER;
profil_list.item j.display_all string_tmp;
};
string_tmp.print;
);
-
\ No newline at end of file
diff --git a/src/profil_slot.li b/src/profil_slot.li
index ec5e9a9..60dbcfc 100644
--- a/src/profil_slot.li
+++ b/src/profil_slot.li
@@ -19,35 +19,35 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PROFIL_SLOT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Method with costumization";
-
+
Section Inherit
-
- + parent_profil:Expanded PROFIL;
-
+
+ + parent_profil:Expanded PROFIL;
+
- parent_parameter_to_type:Expanded PARAMETER_TO_TYPE;
-
+
Section Public
-
+
- position:POSITION <- slot.position;
-
+
- slot:SLOT <- slot_code;
-
- - is_interrupt:BOOLEAN <- slot_code.id_section.is_interrupt;
- - is_external:BOOLEAN <- slot_code.id_section.is_external;
+
+ - is_interrupt:BOOLEAN <- slot_code.id_section.is_interrupt;
+ - is_external:BOOLEAN <- slot_code.id_section.is_external;
+ slot_code:SLOT_CODE;
-
- + is_context_sensitive:BOOLEAN;
+
+ + is_context_sensitive:BOOLEAN;
// BSBS: Le bloc passé en argument peux ne pas etre context sensitive
// Et puis, cet stat peu changer dans le temps...
-
+
- set_context_sensitive <-
(
is_context_sensitive := TRUE;
@@ -56,21 +56,21 @@ Section Public
//
// Creation.
//
-
+
- arg_type_tmp:FAST_ARRAY(EXPR);
- parameter_to_type p:ITM_TYPE_PARAMETER :TYPE_FULL <-
( + idx:INTEGER;
+ result:TYPE_FULL;
-
+
(p.name = ALIAS_STR.prototype_self).if {
// For Self.
- result := type_self;
- } else {
- // For Genericity.
+ result := type_self;
+ } else {
+ // For Genericity.
//result := type_self.raw.parameter_to_type p;
result := slot_code.receiver_type.parameter_to_type p;
- (result = NULL).if {
- // For Type parametric.
+ (result = NULL).if {
+ // For Type parametric.
idx := slot_code.get_index_argument_type p;
(idx != - 1).if {
result := arg_type_tmp.item idx.static_type + TYPE_FULL.generic_bit;
@@ -79,56 +79,56 @@ Section Public
};
result
);
-
- - make s:SLOT_CODE
- with (typ_self:TYPE_FULL,call_lst:FAST_ARRAY(EXPR))
+
+ - make s:SLOT_CODE
+ with (typ_self:TYPE_FULL,call_lst:FAST_ARRAY(EXPR))
verify is_first:BOOLEAN :FAST_ARRAY(WRITE) <-
- [
+ [
-? {typ_self != NULL};
]
( + loc:LOCAL;
+ typ:TYPE_FULL;
- + item_lst:FAST_ARRAY(ITM_ARGUMENT);
+ + item_lst:FAST_ARRAY(ITM_ARGUMENT);
+ result:FAST_ARRAY(WRITE);
+ tm:ITM_TYPE_MULTI;
- + ts:ITM_TYPE_MONO;
-
+ + ts:ITM_TYPE_MONO;
+
(is_graph).if {
set_call := HASHED_DICTIONARY(INTEGER,PROFIL).create;
set_back := HASHED_SET(PROFIL).create;
- };
+ };
(s.id_section.is_external).if {
name := s.name;
} else {
- name := ALIAS_STR.get_intern (s.name);
+ name := ALIAS_STR.get_intern (s.name);
};
-
+
slot_code := s;
type_self := typ_self;
PROFIL_LIST.add Self;
//
list_current := LIST.create (s.position);
- profil_current := profil_slot := Self;
+ profil_current := profil_slot := Self;
//
(debug_level_option != 0).if {
// Debug mode : Add context local.
- context := TYPE_CONTEXT.default.new_local (s.position)
+ context := TYPE_CONTEXT.default.new_local (s.position)
name (ALIAS_STR.variable_context) style '+';
- context.set_ensure_count 1;
+ context.set_ensure_count 1;
list_current.add_last (PUSH.create (slot_code.position) context context first TRUE);
};
//
- code := list_current;
+ code := list_current;
//
- // Arguments.
+ // Arguments.
arg_type_tmp := call_lst;
- item_lst := s.argument_list;
- argument_list := FAST_ARRAY(LOCAL).create_with_capacity (s.argument_count);
+ item_lst := s.argument_list;
+ argument_list := FAST_ARRAY(LOCAL).create_with_capacity (s.argument_count);
(item_lst.lower).to (item_lst.upper) do { j:INTEGER;
item_lst.item j.to_run_in argument_list for Self;
};
((s.id_section.is_external) && {argument_list.count > 1}).if {
- (argument_list.lower+1).to (argument_list.upper) do { j:INTEGER;
+ (argument_list.lower+1).to (argument_list.upper) do { j:INTEGER;
loc := argument_list.item j;
loc.set_ensure_count 1;
loc.write (loc.position) value (
@@ -136,55 +136,55 @@ Section Public
access NULL persistant FALSE type (loc.type)
);
};
- };
-
+ };
+
// Results
- tm ?= s.result_type;
- (tm != NULL).if {
- result_list.make_with_capacity (tm.count);
- (tm.lower).to (tm.upper) do { k:INTEGER;
- typ := tm.item k.to_run_for Self;
+ tm ?= s.result_type;
+ (tm != NULL).if {
+ result_list.make_with_capacity (tm.count);
+ (tm.lower).to (tm.upper) do { k:INTEGER;
+ typ := tm.item k.to_run_for Self;
loc := typ.get (s.position) result (k+1);
- result_list.add_last loc;
- };
- } else {
- ts ?= s.result_type;
+ result_list.add_last loc;
+ };
+ } else {
+ ts ?= s.result_type;
(ts != ITM_TYPE_SIMPLE.type_void).if {
- typ := ts.to_run_for Self;
+ typ := ts.to_run_for Self;
result_list.add_last (typ.get (s.position) result 0);
(is_external).if {
result_list.last.set_ensure_count 1;
};
};
- };
+ };
//
(call_lst != NULL).if {
result := write_argument call_lst;
};
- //
- slot_code.create_code is_first;
+ //
+ slot_code.create_code is_first;
//
result
);
-
+
//
// Execute.
//
-
+
- remove_inline <-
(
parent_profil.remove_inline;
- slot_code.remove_profil Self;
+ slot_code.remove_profil Self;
);
-
+
- remove <-
- (
- parent_profil.remove;
- slot_code.remove_profil Self;
+ (
+ parent_profil.remove;
+ slot_code.remove_profil Self;
);
-
+
//
// Genere.
//
-
+
- is_static:BOOLEAN <- (! slot.id_section.is_interrupt) && {! slot.id_section.is_external};
diff --git a/src/shorter.li b/src/shorter.li
index 80ed3b7..6f6eced 100644
--- a/src/shorter.li
+++ b/src/shorter.li
@@ -19,44 +19,44 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SHORTER;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- bibliography:= "http://IsaacOS.com";
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Shorter source code.";
-
+
- external := `#include "path.h"`;
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Private
-
+
- is_lip:BOOLEAN;
-
+
- output_name : STRING_CONSTANT;
-
+
- input_name : STRING_CONSTANT;
-
+
- format_name : STRING_CONSTANT;
-
+
- proto_input:PROTOTYPE;
-
+
//
// Buffer.
//
-
+
- directory_list:STRING;
-
+
- file_list:STRING;
-
+
- current_list:STRING;
-
+
//
// Command.
//
@@ -83,7 +83,7 @@ Section Private
\ \n\
\Examples: \n\
\ * Output format file: \n\
- \ shorter -c -p -f latex hello_world.li \n\
+ \ shorter -c -p -f latex hello_world.li \n\
\ \n\
\ * Build html documentation: \n\
\ shorter -r -f html ~/lisaac/lib \n\
@@ -92,7 +92,7 @@ Section Private
\ - With directory: \n\
\ shorter -d -f belinda ~/lisaac/lib \n\
\ - With current `make.lip' \n\
- \ shorter -d -f belinda \n\
+ \ shorter -d -f belinda \n\
\ - With specific `make.lip' \n\
\ shorter -d -f belinda ../make.lip \n\
\ \n\
@@ -104,17 +104,17 @@ Section Private
usage.print;
die_with_code exit_failure_code;
);
-
+
//
// Options.
//
-
+
- read_options <-
( + cmd:STRING;
+ j:INTEGER;
+ var_lisaac:STRING_CONSTANT;
+ path:NATIVE_ARRAY(CHARACTER);
-
+
// Read argument.
is_shorter := TRUE;
j := 1;
@@ -129,13 +129,13 @@ Section Private
j := j+1;
(j > COMMAND_LINE.count).if {
display_usage;
- };
+ };
output_name := ALIAS_STR.get (COMMAND_LINE.item j);
}.elseif {cmd.item 2 = 'f'} then {
j := j+1;
(j > COMMAND_LINE.count).if {
display_usage;
- };
+ };
format_name := ALIAS_STR.get (COMMAND_LINE.item j);
}.elseif {cmd.item 2 = 'c'} then {
is_short_code := TRUE;
@@ -144,7 +144,7 @@ Section Private
}.elseif {cmd.item 2 = 'r'} then {
is_short_recursive := TRUE;
}.elseif {cmd.item 2 = 'd'} then {
- is_shorter := FALSE;
+ is_shorter := FALSE;
is_shorter2 := TRUE;
is_short_recursive := TRUE;
} else {
@@ -158,14 +158,14 @@ Section Private
display_usage;
};
string_tmp.copy (COMMAND_LINE.item j);
- input_name := ALIAS_STR.get string_tmp;
+ input_name := ALIAS_STR.get string_tmp;
};
j := j+1;
};
-
+
(input_name = NULL).if {
- (is_shorter2).if {
- load_lip "make.lip";
+ (is_shorter2).if {
+ load_lip "make.lip";
is_lip := TRUE;
} else {
display_usage;
@@ -174,7 +174,7 @@ Section Private
load_lip input_name;
is_lip := TRUE;
};
-
+
(format_name != NULL).if {
path := `LISAAC_DIRECTORY`:NATIVE_ARRAY(CHARACTER);
var_lisaac := STRING_CONSTANT.new_intern path
@@ -200,26 +200,26 @@ Section Private
PARSER.parse_format (ALIAS_STR.get string_tmp);
};
);
-
+
- extract_proto_name st:ABSTRACT_STRING :STRING_CONSTANT <-
( + i:INTEGER;
-
+
string_tmp.copy st;
string_tmp.replace_all '\\' with '/';
i := last_index_str (string_tmp,'/');
- (i >= string_tmp.lower).if {
+ (i >= string_tmp.lower).if {
string_tmp.remove_first i;
};
i := last_index_str (string_tmp,'.');
- ? {i > string_tmp.lower};
- string_tmp.remove_last (string_tmp.upper-i+1);
+ ? {i > string_tmp.lower};
+ string_tmp.remove_last (string_tmp.upper-i+1);
string_tmp.to_upper;
ALIAS_STR.get string_tmp
);
-
+
- add_ext n:STRING_CONSTANT :STRING_CONSTANT <-
( + txt:STRING_CONSTANT;
- string_tmp.copy n;
+ string_tmp.copy n;
(PARSER.short_dico.fast_has (ALIAS_STR.short_type_file)).if {
txt := PARSER.short_dico.fast_at (ALIAS_STR.short_type_file).first;
string_tmp.append txt;
@@ -228,11 +228,11 @@ Section Private
};
ALIAS_STR.get string_tmp
);
-
+
- save_file n:STRING_CONSTANT with buf:STRING <-
( + file:FILE;
+ entry:ENTRY;
-
+
(is_short_recursive).if {
(output_name != NULL).if {
string_tmp.copy output_name;
@@ -266,13 +266,13 @@ Section Private
- build_with_path_file <-
( + tok:STRING_CONSTANT;
- + tok_lst:LINKED_LIST(STRING_CONSTANT);
+ + tok_lst:LINKED_LIST(STRING_CONSTANT);
+ idx:INTEGER;
-
- (path_file.lower).to (path_file.upper) do { i:INTEGER;
+
+ (path_file.lower).to (path_file.upper) do { i:INTEGER;
string_tmp.copy (path_file.item i);
idx := last_index_str (string_tmp,'/');
- (idx >= string_tmp.lower).if {
+ (idx >= string_tmp.lower).if {
string_tmp.remove_first idx;
};
string_tmp.remove_last 3;
@@ -290,11 +290,11 @@ Section Private
};
};
} else {
- current_list.append tok;
+ current_list.append tok;
current_list.add_last '\n';
file_list.append tok;
file_list.add_last '\n';
- };
+ };
// Creation prototype file.
(PROTOTYPE.prototype_dico.fast_has tok).if {
"Error: Double definition prototype:\n".print;
@@ -306,15 +306,15 @@ Section Private
//
PARSER.go_on proto_input;
(is_shorter).if {
- save_file (add_ext tok) with output_code;
+ save_file (add_ext tok) with output_code;
};
(
- (i = path_file.upper) ||
- {path_file.item (i+1).first_difference_index (path_file.item i) < idx} ||
+ (i = path_file.upper) ||
+ {path_file.item (i+1).first_difference_index (path_file.item i) < idx} ||
{last_index_str (path_file.item (i+1),'/') != idx}
).if {
// Detect new directory.
- current_list.is_empty.if_false {
+ current_list.is_empty.if_false {
(PARSER.short_dico.fast_has (ALIAS_STR.short_file_list_begin)).if {
tok := PARSER.short_dico.fast_at (ALIAS_STR.short_file_list_begin).first;
current_list.prepend tok;
@@ -327,9 +327,9 @@ Section Private
string_tmp.remove_last (string_tmp.upper-idx+1);
string_tmp.remove_first path_begin;
string_tmp.is_empty.if_false {
- string_tmp.replace_all '/' with '-';
- tok := ALIAS_STR.get string_tmp;
-
+ string_tmp.replace_all '/' with '-';
+ tok := ALIAS_STR.get string_tmp;
+
(PARSER.short_dico.fast_has (ALIAS_STR.short_directory_list_item)).if {
tok_lst := PARSER.short_dico.fast_at (ALIAS_STR.short_directory_list_item);
(tok_lst.lower).to (tok_lst.upper) do { j:INTEGER;
@@ -340,27 +340,27 @@ Section Private
};
};
} else {
- directory_list.append tok;
+ directory_list.append tok;
directory_list.add_last '\n';
};
-
+
save_file (add_ext tok) with current_list;
current_list.clear;
};
};
};
- };
+ };
);
-
+
- check_in entry:ENTRY begin n:INTEGER <-
- ( + name:STRING_CONSTANT;
- + dir:DIRECTORY;
+ ( + name:STRING_CONSTANT;
+ + dir:DIRECTORY;
(! entry.open).if {
"Warning: directory `".print;
entry.path.print;
"\' not open.\n".print;
- } else {
+ } else {
dir ?= entry;
// Directory
(dir.lower).to (dir.upper) do { i:INTEGER;
@@ -373,46 +373,46 @@ Section Private
(! dir.item i.is_directory).if {
name := dir.item i.name;
(name.has_suffix ".li").if {
- path_file.add_last (dir.item i.path);
+ path_file.add_last (dir.item i.path);
};
}; // Lisaac file `.li'
- };
+ };
};
);
-
-Section Public
-
+
+Section Public
+
//
// Creation.
//
- main <-
- ( + txt:STRING_CONSTANT;
+ ( + txt:STRING_CONSTANT;
+ p:PROTOTYPE;
-
+
ALIAS_STR.make;
-
+
//
read_options;
-
+
// SELF, NULL, VOID, CONTEXT
- TYPE_NULL.make_null;
+ TYPE_NULL.make_null;
TYPE_VOID.make_void;
TYPE_CONTEXT.make_context;
TYPE_ID.make_type_id; // Pas utile !
-
+
(is_short_recursive).if {
+ dir:DIRECTORY;
+ ent:ENTRY;
-
+
directory_list := STRING.create 100;
file_list := STRING.create 100;
current_list := STRING.create 100;
-
+
(is_lip).if {
LIP_CODE.call_front_end;
LIP_CODE.init_path_file TRUE;
- } else {
+ } else {
ent := FILE_SYSTEM.get_entry input_name;
((ent = NULL) || {! ent.is_directory}).if {
"Error: directory `".print;
@@ -451,7 +451,7 @@ Section Public
directory_list.append txt;
};
save_file (add_ext "directory_list") with directory_list;
-
+
// file_list file.
(PARSER.short_dico.fast_has (ALIAS_STR.short_file_list_begin)).if {
txt := PARSER.short_dico.fast_at (ALIAS_STR.short_file_list_begin).first;
@@ -461,24 +461,24 @@ Section Public
txt := PARSER.short_dico.fast_at (ALIAS_STR.short_file_list_end).first;
file_list.append txt;
};
- save_file (add_ext "file_list") with file_list;
+ save_file (add_ext "file_list") with file_list;
} else {
- // Input.
+ // Input.
(input_name.has_suffix ".li").if_false {
string_tmp.copy input_name;
string_tmp.append ".li";
input_name := ALIAS_STR.get string_tmp;
};
-
- proto_input := PROTOTYPE.create input_name
+
+ proto_input := PROTOTYPE.create input_name
name (extract_proto_name input_name)
generic_count 0;
PARSER.go_on proto_input;
-
+
(output_name = NULL).if {
output_name := add_ext (proto_input.name);
- };
- save_file output_name with output_code;
+ };
+ save_file output_name with output_code;
};
(is_shorter2).if {
(PROTOTYPE.prototype_list.lower).to (PROTOTYPE.prototype_list.upper) do { j:INTEGER;
@@ -487,7 +487,7 @@ Section Public
put "" to output_code like (ALIAS_STR.short_begin);
p.shorter_out output_code;
put "" to output_code like (ALIAS_STR.short_end);
- save_file (add_ext (p.name)) with output_code;
+ save_file (add_ext (p.name)) with output_code;
};
};
);
diff --git a/src/shorter_any/any_option.li b/src/shorter_any/any_option.li
index ed17ed4..7f450d9 100644
--- a/src/shorter_any/any_option.li
+++ b/src/shorter_any/any_option.li
@@ -19,36 +19,36 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ANY_OPTION;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
-
+
Section Inherit
-
+
- parent_object:OBJECT := OBJECT;
-
+
Section Public
-
+
- is_shorter2:BOOLEAN;
-
+
- is_shorter :BOOLEAN;
-
+
- is_short_code:BOOLEAN;
- is_short_private:BOOLEAN;
- is_short_recursive:BOOLEAN;
-
+
- put tok:ABSTRACT_STRING to buf:STRING like key:STRING_CONSTANT <-
( + lst:LINKED_LIST(STRING_CONSTANT);
-
+
(key != NULL).if {
lst := PARSER.short_dico.fast_reference_at key;
(lst != NULL).if {
(lst.lower).to (lst.upper) do { j:INTEGER;
- (lst.item j = NULL).if {
+ (lst.item j = NULL).if {
buf.append tok;
} else {
buf.append (lst.item j);
diff --git a/src/tools/alias_array.li b/src/tools/alias_array.li
index f387252..e164f12 100644
--- a/src/tools/alias_array.li
+++ b/src/tools/alias_array.li
@@ -19,51 +19,51 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ALIAS_ARRAY(E);
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Aliser collection.";
-
-Section Inherit
-
+
+Section Inherit
+
- parent_any:ANY := ANY;
-
+
Section Private
-
- - bucket:HASHED_SET(FAST_ARRAY(E)) :=
+
+ - bucket:HASHED_SET(FAST_ARRAY(E)) :=
HASHED_SET(FAST_ARRAY(E)).create;
-
- - free_list:FAST_ARRAY(FAST_ARRAY(E)) :=
+
+ - free_list:FAST_ARRAY(FAST_ARRAY(E)) :=
FAST_ARRAY(FAST_ARRAY(E)).create_with_capacity 5;
-
+
- empty_list:FAST_ARRAY(E) := FAST_ARRAY(E).create_with_capacity 0;
-
+
Section Public
-
+
//
// Temporary manager.
//
-
+
- new:FAST_ARRAY(E) <-
( + result:FAST_ARRAY(E);
-
+
(free_list.is_empty).if {
result := FAST_ARRAY(E).create_with_capacity 16;
} else {
result := free_list.last;
free_list.remove_last;
};
-
+
result
);
-
+
- alias tmp:FAST_ARRAY(E) :FAST_ARRAY(E) <-
( + result:FAST_ARRAY(E);
-
+
(tmp.is_empty).if {
result := empty_list;
} else {
@@ -74,21 +74,21 @@ Section Public
bucket.fast_add result;
};
};
- free tmp;
+ free tmp;
result
);
-
+
- copy tmp:FAST_ARRAY(E) :FAST_ARRAY(E) <-
( + result:FAST_ARRAY(E);
-
+
result := FAST_ARRAY(E).create_with_capacity (tmp.count);
- result.copy_collection tmp;
+ result.copy_collection tmp;
free tmp;
result
- );
-
+ );
+
- free tmp:FAST_ARRAY(E) <-
- (
+ (
tmp.clear;
free_list.add_last tmp;
);
diff --git a/src/tools/couple.li b/src/tools/couple.li
index a5a4db0..c4a1d4c 100644
--- a/src/tools/couple.li
+++ b/src/tools/couple.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COUPLE(E,F);
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Couple object";
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
+ first :E;
+ second:F;
-
+
- create elt1:E and elt2:F :SELF <-
( + result:SELF;
-
+
result := clone;
result.make elt1 and elt2;
result
);
-
+
- make elt1:E and elt2:F <-
(
first := elt1;
second := elt2;
- );
+ );
diff --git a/src/tools/coupled.li b/src/tools/coupled.li
index 5eefb49..095ad1c 100644
--- a/src/tools/coupled.li
+++ b/src/tools/coupled.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := COUPLED(E);
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Couple object";
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
+ first :E;
+ second:E;
-
+
- create elt1:E and elt2:E :SELF <-
( + result:SELF;
-
+
result := clone;
result.make elt1 and elt2;
result
);
-
+
- make elt1:E and elt2:E <-
(
first := elt1;
second := elt2;
- );
+ );
diff --git a/src/tools/position.li b/src/tools/position.li
index ff9bb07..42a2240 100644
--- a/src/tools/position.li
+++ b/src/tools/position.li
@@ -19,35 +19,35 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := Expanded POSITION;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Coding position : \
\ 9 bits : Index prototype [1..511]. \
\ 8 bits : Column [0..255]. \
\ 15 bits : Line [1..32767].";
-
+
- type := `unsigned long`;
- default := ( CONVERT(INTEGER,POSITION).on 0 );
-
-Section Insert
-
+
+Section Insert
+
- parent_any:ANY := ANY;
-
+
Section Public
-
+
- object_size:INTEGER <- POINTER.object_size;
-
+
- code:UINTEGER_32 <- CONVERT(POSITION,UINTEGER_32).on Self;
-
+
//
// Creation.
//
-
+
- create proto:PROTOTYPE line l:INTEGER column c:INTEGER :POSITION <-
( + cod:UINTEGER_32;
? {l .in_range 0 to 131071};
@@ -56,7 +56,7 @@ Section Public
cod := proto.index.to_uinteger_32 | (c << 9) | (l << 17);
CONVERT(UINTEGER_32,POSITION).on cod
);
-
+
//
// Localization.
//
@@ -64,13 +64,13 @@ Section Public
- prototype:PROTOTYPE <- PROTOTYPE.prototype_list.item (code.to_integer & 01FFh);
- line:UINTEGER_32 <- code >> 17;
-
+
- column:UINTEGER_32 <- (code >> 9) & 0FFh;
//
// Information Generation.
//
-
+
- nb_warning:INTEGER;
- send_error <-
@@ -79,7 +79,7 @@ Section Public
is_verbose.if {
msg_err.print;
};
- (type_error = warning).if {
+ (type_error = warning).if {
nb_warning := nb_warning + 1;
} else {
die_with_code exit_failure_code;
@@ -102,20 +102,20 @@ Section Public
};
msg_err.append txt;
);
-
+
- put_position <-
( + pos:INTEGER;
+ c,cols:UINTEGER_32;
+ src:STRING;
+ char:CHARACTER;
? {code != 0};
-
+
msg_err.append "\nLine ";
- line.append_in msg_err;
+ line.append_in msg_err;
msg_err.append " column ";
column.append_in msg_err;
msg_err.append " in ";
- msg_err.append (prototype.name);
+ msg_err.append (prototype.name);
msg_err.add_last '(';
prototype.append_filename msg_err;
msg_err.append "):\n";
@@ -131,7 +131,7 @@ Section Public
// copy line :
string_tmp.clear;
cols := column;
- {(pos > src.upper) ||
+ {(pos > src.upper) ||
{src.item pos='\n'}}.until_do {
char := src.item pos;
msg_err.add_last char;
@@ -149,7 +149,7 @@ Section Public
msg_err.append string_tmp;
msg_err.append "^\n";
);
-
+
- extract_line:STRING <-
( + pos:INTEGER;
+ src:STRING;
@@ -165,32 +165,32 @@ Section Public
pos := pos + 1;
};
// copy line :
- string_tmp.clear;
+ string_tmp.clear;
{
- (pos > src.upper) ||
+ (pos > src.upper) ||
{src.item pos='\n'}
}.until_do {
char := src.item pos;
(char)
.when '\\' then { string_tmp.add_last '\\'; }
.when '\"' then { string_tmp.add_last '\\'; };
- string_tmp.add_last char;
+ string_tmp.add_last char;
pos := pos + 1;
- };
+ };
(string_tmp.last.code = 0Dh).if {
string_tmp.remove_last 1;
};
STRING.create_from_string string_tmp
);
-
-Section Private
-
+
+Section Private
+
//
// Service manager
//
-
+
- type_error:INTEGER;
-
+
- msg_err:STRING := STRING.create 256;
diff --git a/src/tools/slim_array.li b/src/tools/slim_array.li
index fe97746..086c5b1 100644
--- a/src/tools/slim_array.li
+++ b/src/tools/slim_array.li
@@ -19,7 +19,7 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SLIM_ARRAY(E); // BSBS: A mettre en Expanded.
- copyright := "2003-2008 Sonntag Benoit";
@@ -30,15 +30,15 @@ Section Header
Section Insert
- parent_object:OBJECT := OBJECT;
-
+
Section Private
-
+
+ list:FAST_ARRAY(E);
-
+
Section Public
-
+
+ first:E;
-
+
- last:E <-
( + result:E;
(list != NULL).if {
@@ -48,10 +48,10 @@ Section Public
};
result
);
-
+
- lower:INTEGER <- 0;
-
- - upper:INTEGER <-
+
+ - upper:INTEGER <-
( + result:INTEGER;
(first = NULL).if {
result := -1;
@@ -60,14 +60,14 @@ Section Public
};
result
);
-
+
- count:INTEGER <- upper + 1;
-
+
- is_empty:BOOLEAN <- first = NULL;
-
+
- item i:INTEGER :E <-
( + result:E;
-
+
(i = 0).if {
result := first;
} else {
@@ -75,7 +75,7 @@ Section Public
};
result
);
-
+
- put e:E to i:INTEGER <-
(
(i = 0).if {
@@ -83,8 +83,8 @@ Section Public
} else {
list.put e to (i-1);
};
- );
-
+ );
+
- add_last e:E <-
(
(first = NULL).if {
@@ -96,7 +96,7 @@ Section Public
list.add_last e;
};
);
-
+
- make_with_capacity n:INTEGER <-
(
first := NULL;
@@ -104,4 +104,4 @@ Section Public
list := FAST_ARRAY(E).create_with_capacity (n-1);
};
);
-
+
diff --git a/src/tools/table.li b/src/tools/table.li
index aad188b..a9325a3 100644
--- a/src/tools/table.li
+++ b/src/tools/table.li
@@ -19,53 +19,53 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
- name := TABLE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Display array manager.";
-
-Section Inherit
-
+
+Section Inherit
+
- parent_object:OBJECT := OBJECT;
-
+
Section Private
-
+
- table:FAST_ARRAY2(ABSTRACT_STRING) := FAST_ARRAY2(ABSTRACT_STRING).create (10,10);
-
+
- size:FAST_ARRAY(INTEGER) := FAST_ARRAY(INTEGER).create_with_capacity 10;
-
+
- line:INTEGER;
- column:INTEGER;
-
+
Section Public
-
+
- new_table (l,c:INTEGER) <-
(
table.make (l,c);
- line := column := 0;
+ line := column := 0;
);
-
+
- add n:ABSTRACT_STRING <-
(
? {n != NULL};
-
+
table.put n to (line,column);
(column = table.upper2).if {
column := 0;
line := line + 1;
} else {
column := column + 1;
- };
+ };
);
-
+
- append_in buffer:STRING <-
( + siz:INTEGER;
+ append_line,append_bar:BLOCK;
-
+
// Size column.
size.make (table.count2);
0.to (table.upper1) do { l:INTEGER;
@@ -76,15 +76,15 @@ Section Public
};
};
};
-
+
// Sub-code for one line.
- append_line :=
+ append_line :=
{ l:INTEGER;
+ n:ABSTRACT_STRING;
buffer.append "// ";
0.to (table.upper2) do { c:INTEGER;
n := table.item (l,c);
- buffer.append "| ";
+ buffer.append "| ";
buffer.append n;
buffer.extend_multiple ' ' by (size.item c - n.count + 1);
};
diff --git a/src/tools/types.li b/src/tools/types.li
index 7607882..fb09162 100644
--- a/src/tools/types.li
+++ b/src/tools/types.li
@@ -19,56 +19,56 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPES;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Aliser TYPE collection.";
-
-Section Inherit
-
+
+Section Inherit
+
- parent_any:ANY := ANY;
-
+
Section TYPES
-
+
+ storage:NATIVE_ARRAY(TYPE);
// Internal access to storage location.
-
+
Section LISAAC
-
+
- size:INTEGER;
-
+
Section Public
-
+
- lower:INTEGER := 0;
-
+
+ upper:INTEGER := -1; // Upper index bound.
-
+
- count:INTEGER <- upper + 1;
-
+
- is_empty:BOOLEAN <- upper = -1;
-
- - first:TYPE <-
+
+ - first:TYPE <-
[ -? {! is_empty}; ]
(
storage.item 0
);
- - second:TYPE <-
+ - second:TYPE <-
[ -? {upper >= 1}; ]
(
storage.item 1
);
-
- - last:TYPE <-
+
+ - last:TYPE <-
[ -? {! is_empty}; ]
(
storage.item upper
);
-
+
- item i:INTEGER :TYPE <-
[ -? {i.in_range lower to upper}; ]
(
@@ -77,10 +77,10 @@ Section Public
[ +? {Result != NULL}; ];
- Self:SELF '~=' Right 60 other:TYPES :BOOLEAN <-
- (
- (Self = other) ||
+ (
+ (Self = other) ||
{
- (upper = other.upper) &&
+ (upper = other.upper) &&
{(is_empty) || {storage.fast_memcmp (other.storage) until (upper + 1)}}
}
);
@@ -90,7 +90,7 @@ Section Public
( + result:BOOLEAN;
+ j1,j2:INTEGER;
+ t:TYPE;
-
+
(upper <= other.upper).if {
j1 := j2 := lower;
result := TRUE;
@@ -101,24 +101,24 @@ Section Public
};
result := (j2 <= other.upper);
j1 := j1 + 1;
- };
+ };
};
- result
+ result
);
-
+
- hash_code:INTEGER <-
( + result:INTEGER;
-
+
(! is_empty).if {
result := (upper << 8) + last.index;
};
result
);
-
+
//
// Display.
//
-
+
- append_in buf:STRING <-
(
(! is_empty).if {
@@ -130,36 +130,36 @@ Section Public
};
last.append_name_in buf;
buf.add_last '(';
- last.index.append_in buf;
+ last.index.append_in buf;
buf.add_last ')';
} else {
buf.append "<Vide>";
};
);
-
+
- print <-
(
string_tmp.clear;
append_in string_tmp;
string_tmp.print;
);
-
+
Section TYPES_TMP
-
+
- create tab:TYPES_TMP :TYPES <-
( + result:TYPES;
-
+
result := clone;
result.make tab;
result
);
-
+
- make tab:TYPES_TMP <-
( + up:INTEGER;
-
+
up := tab.upper;
storage := NATIVE_ARRAY(TYPE).calloc_intern (up + 1);
storage.copy_from (tab.storage) until up;
- upper := up;
- size := size + count * 4;
+ upper := up;
+ size := size + count * 4;
);
\ No newline at end of file
diff --git a/src/tools/types_tmp.li b/src/tools/types_tmp.li
index 9cc1db3..f21fc69 100644
--- a/src/tools/types_tmp.li
+++ b/src/tools/types_tmp.li
@@ -19,77 +19,77 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPES_TMP;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Aliser TYPE collection.";
-
+
Section Inherit
-
+
+ parent_types:Expanded TYPES;
-
+
Section Private
-
+
- bucket:HASHED_SET(TYPES) := HASHED_SET(TYPES).create;
-
+
- free_list:FAST_ARRAY(TYPES_TMP) := FAST_ARRAY(TYPES_TMP).create_with_capacity 5;
-
+
+ capacity:INTEGER;
-
+
- create_types_tmp:TYPES_TMP <-
( + result:TYPES_TMP;
-
+
result := clone;
result.make_types_tmp;
result
);
-
+
- make_types_tmp <-
(
capacity := 256;
storage := NATIVE_ARRAY(TYPE).calloc_intern capacity;
)
[ +? {is_empty}; ];
-
+
Section LISAAC
-
+
- print_types <-
(
(bucket.lower).to (bucket.upper) do { j:INTEGER;
bucket.item j.print; '\n'.print;
};
);
-
+
Section Public
-
+
- types_empty:TYPES := TYPES;
-
+
//
// Creation.
//
-
+
- new:TYPES_TMP <-
( + result:TYPES_TMP;
-
+
(free_list.is_empty).if {
result := create_types_tmp;
} else {
result := free_list.last;
free_list.remove_last;
- };
+ };
result
);
-
+
- update t:TYPES :TYPES <-
[
-? { + tmp:TYPES_TMP; tmp ?= t; tmp = NULL};
]
( + result:TYPES;
-
+
((t != NULL) && {t.count = count}).if {
result := t;
free;
@@ -98,12 +98,12 @@ Section Public
};
result
);
-
+
- to_types:TYPES <-
( + result:TYPES;
-
+
(is_empty).if {
- result := types_empty;
+ result := types_empty;
} else {
result := bucket.reference_at Self with { (e1,e2:TYPES); e1 ~= e2};
(result = NULL).if {
@@ -112,40 +112,40 @@ Section Public
};
};
20 ? {result ~= Self};
-
+
free;
result
);
-
+
- clear <-
(
upper := -1;
);
-
+
- free <-
(
clear;
free_list.add_last Self;
);
-
+
//
// Update list.
//
-
+
- remove_first <-
(
(lower + 1).to upper do { i:INTEGER;
storage.put (item i) to (i - 1);
- };
+ };
upper := upper - 1;
);
-
+
- add t:TYPE <-
( + idx:INTEGER;
-
+
(is_empty).if {
add_last t;
- } else {
+ } else {
idx := search t from 0 to count;
(idx > upper).if {
add_last t;
@@ -154,45 +154,45 @@ Section Public
};
};
)
- [
- 20 ? {order_test};
+ [
+ 20 ? {order_test};
];
- union other:TYPES <-
( + idx1,idx2,t2idx:INTEGER;
+ t2:TYPE;
-
+
{idx2 > other.upper}.until_do {
t2 := other.item idx2;
t2idx := t2.index;
{(idx1 <= upper) && {item idx1.index < t2idx}}.while_do {
idx1 := idx1 + 1;
};
- ((idx1 > upper) || {item idx1 != t2}).if {
- add t2 to idx1;
- };
+ ((idx1 > upper) || {item idx1 != t2}).if {
+ add t2 to idx1;
+ };
idx1 := idx1 + 1;
idx2 := idx2 + 1;
- };
+ };
)
- [
- 20 ? {order_test};
+ [
+ 20 ? {order_test};
];
-
+
Section Private
-
+
- add_last t:TYPE <-
( + new_capacity:INTEGER;
-
+
(upper + 1 > capacity - 1 ).if {
new_capacity := capacity * 2;
storage := storage.realloc capacity with new_capacity;
- capacity := new_capacity;
- };
+ capacity := new_capacity;
+ };
upper := upper + 1;
storage.put t to upper;
);
-
+
- add t:TYPE to index:INTEGER <-
( + new_capacity:INTEGER;
(index = upper + 1).if {
@@ -201,30 +201,30 @@ Section Private
(upper + 1 > capacity - 1 ).if {
new_capacity := capacity * 2;
storage := storage.realloc capacity with new_capacity;
- capacity := new_capacity;
- };
+ capacity := new_capacity;
+ };
upper := upper + 1;
(upper - 1).downto index do { i:INTEGER;
storage.put (item i) to (i + 1);
- };
+ };
storage.put t to index;
};
);
-
+
- search t:TYPE from beg:INTEGER to end:INTEGER :INTEGER <-
// Dichotomic research.
( + middle,result:INTEGER;
-
+
((end - beg) < 2).if {
(t.index > item beg.index).if {
result := end;
} else {
result := beg;
};
- } else {
+ } else {
middle := (beg + end) >> 1;
(t.index > item middle.index).if {
- result := search t from middle to end;
+ result := search t from middle to end;
} else {
result := search t from beg to middle;
};
@@ -236,7 +236,7 @@ Section Private
( + j:INTEGER;
{(j < upper) && {item j.index < item (j+1).index}}.while_do {
- j := j + 1;
+ j := j + 1;
};
j >= upper
);
diff --git a/src/type/prototype.li b/src/type/prototype.li
index 9c96f0f..c153d38 100644
--- a/src/type/prototype.li
+++ b/src/type/prototype.li
@@ -19,46 +19,46 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := PROTOTYPE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Prototype source code.";
-
+
Section Inherit
+ parent_named:Expanded NAMED;
-
+
Section Public
-
+
- prototype_list:FAST_ARRAY(PROTOTYPE) :=
FAST_ARRAY(PROTOTYPE).create_with_capacity 512;
// BSBS: Voir si il faut le conserver !
-
- - prototype_dico:HASHED_DICTIONARY(PROTOTYPE,STRING_CONSTANT) :=
+
+ - prototype_dico:HASHED_DICTIONARY(PROTOTYPE,STRING_CONSTANT) :=
HASHED_DICTIONARY(PROTOTYPE,STRING_CONSTANT).create;
-
+
Section Public
-
+
+ index:INTEGER; // in `prototype_list', for POSITION.
-
+
+ shortname:STRING_CONSTANT;
-
+
//
// Slots
//
-
+
+ slot_list:HASHED_DICTIONARY(ITM_SLOT,STRING_CONSTANT);
-
+
+ first_slot:ITM_SLOT;
-
+
+ last_slot:ITM_SLOT;
-
+
- add_slot s:ITM_SLOT <-
- (
+ (
slot_list.fast_put s to (s.name);
(first_slot = NULL).if {
first_slot := s;
@@ -66,36 +66,36 @@ Section Public
last_slot.set_next s;
};
last_slot := s;
- );
-
+ );
+
- search_parent n:STRING_CONSTANT :BOOLEAN <-
( + slot:ITM_SLOT;
+ result:BOOLEAN;
-
+
slot := first_slot;
{
- (result := (slot != NULL) && {slot.id_section.is_inherit_or_insert})
+ (result := (slot != NULL) && {slot.id_section.is_inherit_or_insert})
&& {slot.name != n}
}.while_do {
slot := slot.next;
};
result
);
-
+
//
// Run Slot.
//
-
+
- init_slot_for typ:TYPE <-
( + cur:ITM_SLOT;
+ slot:SLOT;
+ slot_code:SLOT_CODE;
+ old_profil_current:PROFIL;
-
+
// Parent.
//last_position := position;
cur := first_slot;
- {(cur != NULL) && {cur.id_section.is_inherit_or_insert}}.while_do {
+ {(cur != NULL) && {cur.id_section.is_inherit_or_insert}}.while_do {
typ.slot_run.add_last (SLOT.create cur type typ);
typ.verify_cyclic_inheritance typ;
typ.verify_itm_slot_parent cur;
@@ -104,7 +104,7 @@ Section Public
// Mapping.
((is_mapping) || {is_external}).if {
{cur != NULL}.while_do {
- ((cur.id_section.is_mapping) || {cur.id_section.is_external}).if {
+ ((cur.id_section.is_mapping) || {cur.id_section.is_external}).if {
typ.verify_itm_slot_parent cur;
slot := SLOT.create cur type typ;
typ.slot_run.add_last slot;
@@ -119,19 +119,19 @@ Section Public
};
cur := cur.next;
};
- };
+ };
);
-
+
//
// Mapping / Late binding / Expanded
//
-
+
+ type_style:STRING_CONSTANT; // Reference / Expanded / Strict.
-
+
+ is_mapping:BOOLEAN;
-
+
+ is_external:BOOLEAN;
-
+
- set_mapping <-
(
is_mapping := TRUE;
@@ -141,12 +141,12 @@ Section Public
(
is_external := TRUE;
);
-
- - set_type_style s:STRING_CONSTANT <-
- (
+
+ - set_type_style s:STRING_CONSTANT <-
+ (
type_style := s;
);
-
+
//
// Cast information.
//
@@ -171,11 +171,11 @@ Section Public
+ filename:STRING_CONSTANT; // Pathname of prototype.
+ source : STRING; // Text source code.
-
+
+ generic_count:INTEGER;
-
+
+ idf_generic_list:FAST_ARRAY(ITM_TYPE_PARAMETER);
-
+
- append_filename buffer:STRING <-
(
(path_begin != 1).if {
@@ -183,9 +183,9 @@ Section Public
};
path_begin.to (filename.upper) do { j:INTEGER;
buffer.add_last (filename.item j);
- };
+ };
);
-
+
//
// Default value.
//
@@ -193,21 +193,21 @@ Section Public
+ default_value:ITM_CODE;
- set_default_value v:ITM_CODE <-
- (
+ (
default_value := v; //default_value v to_slot name in Self;
);
-
+
//
// Creation.
//
-
+
- create f:STRING_CONSTANT name n:STRING_CONSTANT generic_count c:INTEGER :SELF <-
( + result:SELF;
result := clone;
result.make f name n generic_count c;
result
);
-
+
- make f:STRING_CONSTANT name n:STRING_CONSTANT generic_count c:INTEGER <-
( //+ file:FILE;
//+ entry:ENTRY;
@@ -215,9 +215,9 @@ Section Public
+ sz,idx:INTEGER;
? {! prototype_dico.fast_has n};
? {n != NULL};
-
+
filename := f;
- name := n;
+ name := n;
idx := n.fast_last_index_of '.';
(idx != 0).if {
string_tmp.copy n;
@@ -228,27 +228,27 @@ Section Public
};
generic_count := c;
idf_generic_list := FAST_ARRAY(ITM_TYPE_PARAMETER).create_with_capacity c;
-
- // Collection.
+
+ // Collection.
index := prototype_list.count;
prototype_list.add_last Self;
- prototype_dico.fast_put Self to f;
-
- // Read file.
- //entry := FILE_SYSTEM.get f;
+ prototype_dico.fast_put Self to f;
+
+ // Read file.
+ //entry := FILE_SYSTEM.get f;
//file ?= entry.open_read_only;
//source := STRING.create (file.size);
//file.read source size (file.size);
//file.close;
-
+
file := FS_MIN.open_read f;
sz := FS_MIN.file_size file;
source := STRING.create (sz+1);
FS_MIN.read file in source size sz;
FS_MIN.close file;
-
- // Init.
- slot_list := HASHED_DICTIONARY(ITM_SLOT,STRING_CONSTANT).create;
+
+ // Init.
+ slot_list := HASHED_DICTIONARY(ITM_SLOT,STRING_CONSTANT).create;
position := POSITION.create Self line 1 column 0;
//
);
@@ -256,7 +256,7 @@ Section Public
//
// Execute.
//
-
+
- depend <-
( + slot_main:SLOT;
+ self_main:EXPR;
@@ -266,23 +266,23 @@ Section Public
+ i:INSTR;
+ cmd:STRING_CONSTANT;
+ exec:{};
-
+
+ buf:STRING;
//
// Creation list execution.
- //
+ //
list_main := list_current := LIST.create position;
(debug_level_option != 0).if {
// Debug mode : Add context local.
- context_main := TYPE_CONTEXT.default.new_local position
+ context_main := TYPE_CONTEXT.default.new_local position
name (ALIAS_STR.variable_context) style '+';
- context_main.set_ensure_count 1;
+ context_main.set_ensure_count 1;
list_current.add_last (PUSH.create position context context_main first TRUE);
};
-
+
// Command argument.
- (is_ansi).if {
+ (is_ansi).if {
(is_java).if {
cmd := "arg = parg";
} else {
@@ -297,7 +297,7 @@ Section Public
\ pthread_key_create(¤t_thread, NULL);\n\
\ pthread_attr_init(&thread_attr);\n\
\ /*pthread_attr_setdetachstate(&thread_attr,PTHREAD_CREATE_DETACHED);*/\n\
- \#endif\n ";
+ \#endif\n ";
cmd := ALIAS_STR.get string_tmp;
};
i := EXTERNAL_C.create position text cmd
@@ -307,19 +307,19 @@ Section Public
// Main Call.
slot_main := get_slot_main;
self_main := PROTOTYPE_CST.create position type (type_input.default);
- base := NODE.new_read (slot_main.position) slot slot_main
- receiver self_main self self_main intern TRUE;
+ base := NODE.new_read (slot_main.position) slot slot_main
+ receiver self_main self self_main intern TRUE;
list_current.add_last base;
-
- // Result.
- list_current.add_last (INTEGER_CST.create position value 0 type (type_integer.default));
-
+
+ // Result.
+ list_current.add_last (INTEGER_CST.create position value 0 type (type_integer.default));
+
//
// Detect life code.
- //
+ //
pass_count := 1;
(is_quiet).if_false {
- STD_ERROR.put_string "Depending pass: .";
+ STD_ERROR.put_string "Depending pass: .";
};
{modify_count != 0}.while_do {
modify_count := 0;
@@ -329,93 +329,93 @@ Section Public
pass_count := pass_count + 1;
NODE.extend_pass;
};
-
+
(is_quiet).if_false {
STD_ERROR.put_string " (";
STD_ERROR.put_integer pass_count;
STD_ERROR.put_string ")\n";
};
-
+
buf := STRING.create 2000;
-
+
(is_verbose).if {
PROFIL_LIST.display;
};
-
+
//
// Evaluation.
//
- VARIABLE.check_variable_block;
+ VARIABLE.check_variable_block;
(is_quiet).if_false {
STD_ERROR.put_string "Executing pass: ";
};
pass_count_depend := pass_count;
exec := {
- {
+ {
modify_count := 0;
null_counter := 0;
(is_quiet).if_false {
- STD_ERROR.put_string ".";
+ STD_ERROR.put_string ".";
};
- pass_count := pass_count + 1;
-
+ pass_count := pass_count + 1;
+
SWITCH.reset_switch_new_pass;
-
- PROFIL_LIST.execute_pass;
-
+
+ PROFIL_LIST.execute_pass;
+
(SWITCH.switch_new_pass).if {
- new_execute_pass;
- };
- (modify_count != 0).if {
- pass_recur := TRUE;
+ new_execute_pass;
+ };
+ (modify_count != 0).if {
+ pass_recur := TRUE;
};
- }.do_while {modify_count != 0};
+ }.do_while {modify_count != 0};
};
- // First pass (recursive)
- is_executing_pass := TRUE;
+ // First pass (recursive)
+ is_executing_pass := TRUE;
{
(is_quiet).if_false {
STD_ERROR.put_string "*";
- };
+ };
pass_count := pass_count + 1;
- PROFIL_LIST.execute_pass_recursive;
+ PROFIL_LIST.execute_pass_recursive;
pass_recur := FALSE;
- // End first pass.
- exec.value;
- (pass_recur).if_false {
+ // End first pass.
+ exec.value;
+ (pass_recur).if_false {
exec.value;
- };
+ };
}.do_while {pass_recur};
(is_quiet).if_false {
STD_ERROR.put_string " (";
STD_ERROR.put_integer (pass_count - pass_count_depend);
- STD_ERROR.put_string ")\n";
+ STD_ERROR.put_string ")\n";
};
- //
+ //
(is_verbose).if {
list_main.debug_display;
PROFIL_LIST.display;
- };
+ };
);
-
+
//
// Type C
//
-
+
+ type_c :STRING_CONSTANT;
- set_c_type n:STRING_CONSTANT <-
(
- type_c := n;
+ type_c := n;
);
-
+
//
// Shorter.
//
-
+
+ comment_slot:STRING_CONSTANT;
+ comment_header:STRING_CONSTANT;
-
+
- set_comment_slot t:STRING_CONSTANT <-
(
comment_slot := t;
@@ -425,97 +425,97 @@ Section Public
(
comment_header := t;
);
-
+
- shorter_out buf:STRING <-
( + title:STRING_CONSTANT;
+ s:ITM_SLOT;
put name to buf like (ALIAS_STR.short_title);
-
+
(comment_slot != NULL).if {
put comment_slot to buf like (ALIAS_STR.short_prototype_comment_light);
};
(comment_header != NULL).if {
put comment_header to buf like (ALIAS_STR.short_prototype_comment);
};
-
+
list_tmp.clear;
shorter_get_all_slot_in list_tmp;
-
+
// Table.
- shorter_table list_tmp select { sl:ITM_SLOT;
+ shorter_table list_tmp select { sl:ITM_SLOT;
sl.id_section.is_inherit_or_insert
} title "Inherit/Insert Summary" in buf;
-
- shorter_table list_tmp select { sl:ITM_SLOT;
+
+ shorter_table list_tmp select { sl:ITM_SLOT;
sl.name.has_prefix "create"
- } title "Constructor Summary" in buf;
-
+ } title "Constructor Summary" in buf;
+
(list_tmp.lower).to (list_tmp.upper) do { j:INTEGER;
s := list_tmp.item j;
(s.stat_shorter = 0).if {
- title := s.comment_chapter;
- shorter_table list_tmp select { sl:ITM_SLOT;
+ title := s.comment_chapter;
+ shorter_table list_tmp select { sl:ITM_SLOT;
sl.comment_chapter = title
- } title title in buf;
+ } title title in buf;
};
};
-
+
// Detail.
- shorter_detail list_tmp select { sl:ITM_SLOT;
+ shorter_detail list_tmp select { sl:ITM_SLOT;
sl.id_section.is_inherit_or_insert
- } title "Inherit/Insert Detail" in buf;
-
- shorter_detail list_tmp select { sl:ITM_SLOT;
+ } title "Inherit/Insert Detail" in buf;
+
+ shorter_detail list_tmp select { sl:ITM_SLOT;
sl.name.has_prefix "create"
- } title "Constructor Detail" in buf;
-
+ } title "Constructor Detail" in buf;
+
(list_tmp.lower).to (list_tmp.upper) do { j:INTEGER;
s := list_tmp.item j;
(s.stat_shorter = 1).if {
- title := s.comment_chapter;
- shorter_detail list_tmp select { sl:ITM_SLOT;
+ title := s.comment_chapter;
+ shorter_detail list_tmp select { sl:ITM_SLOT;
sl.comment_chapter = title
- } title title in buf;
+ } title title in buf;
};
};
-
+
(list_tmp.lower).to (list_tmp.upper) do { j:INTEGER;
list_tmp.item j.set_stat_shorter 0;
};
);
-
+
Section PROTOTYPE
-
+
- get_slot_main:SLOT <-
- ( + result:SLOT;
- + s:ITM_SLOT;
-
- s := first_slot;
- {
- ((s.id_section.is_public) && {s.name = ALIAS_STR.slot_main}).if {
+ ( + result:SLOT;
+ + s:ITM_SLOT;
+
+ s := first_slot;
+ {
+ ((s.id_section.is_public) && {s.name = ALIAS_STR.slot_main}).if {
(s.result_type != ITM_TYPE_SIMPLE.type_void).if {
semantic_error (s.position,"Unix mode: Not value return.");
};
(s.argument_count != 1).if {
semantic_error (s.position,"Unix mode: Not argument list.");
- };
+ };
result := type_input.get_slot (s.name);
};
s := s.next;
}.do_while {(s != NULL) && {result = NULL}};
-
+
(result = NULL).if {
semantic_error (position,"Entry point not found (slot `main' in `Section Public').");
- };
- result
+ };
+ result
);
-
+
- shorter_get_all_slot_in lst:FAST_ARRAY(ITM_SLOT) <-
- ( + s:ITM_SLOT;
+ ( + s:ITM_SLOT;
+ ps:ITM_TYPE_SIMPLE;
+ p:PROTOTYPE;
+ i:INTEGER;
-
+
s := first_slot;
{s != NULL}.while_do {
(is_short_private || {! s.id_section.is_private}).if {
@@ -529,10 +529,10 @@ Section PROTOTYPE
};
s := s.next;
};
-
+
// Parent.
s := first_slot;
- {(s != NULL) && {s.id_section.is_inherit_or_insert}}.while_do {
+ {(s != NULL) && {s.id_section.is_inherit_or_insert}}.while_do {
ps ?= s.result_type;
((ps != NULL) && {
({s.style = '+'} && {ps.style = ALIAS_STR.keyword_expanded}) ||
@@ -546,20 +546,20 @@ Section PROTOTYPE
};
i := i + 1;
};
- (p != NULL).if {
+ (p != NULL).if {
p.shorter_get_all_slot_in lst;
};
- };
+ };
s := s.next;
- };
+ };
);
-
+
- shorter_table lst:FAST_ARRAY(ITM_SLOT) select sel:{ITM_SLOT; BOOLEAN}
title t:STRING_CONSTANT in buf:STRING <-
( + is_first_cur:BOOLEAN;
- + s:ITM_SLOT;
-
- is_first_cur := TRUE;
+ + s:ITM_SLOT;
+
+ is_first_cur := TRUE;
(lst.lower).to (lst.upper) do { i:INTEGER;
s := lst.item i;
((sel.value s) && {s.stat_shorter = 0}).if {
@@ -577,7 +577,7 @@ Section PROTOTYPE
s.pretty_name_in string_tmp2;
put string_tmp2 to string_tmp like (ALIAS_STR.short_table_slot_name);
(
- (s.id_section.is_inherit_or_insert) &&
+ (s.id_section.is_inherit_or_insert) &&
{
(
(s.style != '+') || {
@@ -585,31 +585,31 @@ Section PROTOTYPE
ts ?= s.result_type;
(ts = NULL) || {ts.style != ALIAS_STR.keyword_expanded}
}
- ) &&
- {! s.name.has_prefix "inherit"} &&
+ ) &&
+ {! s.name.has_prefix "inherit"} &&
{! s.name.has_prefix "insert"}
}
).if {
put " No developed." to string_tmp like (ALIAS_STR.short_warning);
};
- string_tmp2.clear;
+ string_tmp2.clear;
get_all_comment_slot (s.name) in string_tmp2;
string_tmp3.clear;
- shorter_comment string_tmp2 in string_tmp3 light TRUE;
+ shorter_comment string_tmp2 in string_tmp3 light TRUE;
put string_tmp3 to string_tmp like (ALIAS_STR.short_table_slot_comment);
put string_tmp to buf like (ALIAS_STR.short_table_item);
- };
- };
+ };
+ };
(is_first_cur).if_false {
put NULL to buf like (ALIAS_STR.short_table_end);
- };
+ };
);
-
+
- shorter_detail lst:FAST_ARRAY(ITM_SLOT) select sel:{ITM_SLOT; BOOLEAN}
title t:STRING_CONSTANT in buf:STRING <-
( + is_first:BOOLEAN;
+ s:ITM_SLOT;
-
+
is_first := TRUE;
(lst.lower).to (lst.upper) do { i:INTEGER;
s := lst.item i;
@@ -628,10 +628,10 @@ Section PROTOTYPE
s.pretty_name_in string_tmp2;
put string_tmp2 to buf like (ALIAS_STR.short_slot_title);
string_tmp.clear;
- s.position.prototype.append_filename string_tmp;
+ s.position.prototype.append_filename string_tmp;
string_tmp.append " line #";
s.position.line.append_in string_tmp;
- put string_tmp to buf like (ALIAS_STR.short_prototype_path);
+ put string_tmp to buf like (ALIAS_STR.short_prototype_path);
//
put "Section:" to buf like (ALIAS_STR.short_subsub_title);
string_tmp.clear;
@@ -640,51 +640,51 @@ Section PROTOTYPE
//
put "Profile:" to buf like (ALIAS_STR.short_subsub_title);
s.shorter_profile_in buf;
- //
+ //
string_tmp.clear;
- get_all_comment_slot (s.name) in string_tmp;
- shorter_comment string_tmp in buf light FALSE;
- };
+ get_all_comment_slot (s.name) in string_tmp;
+ shorter_comment string_tmp in buf light FALSE;
+ };
};
);
-
+
- get_all_comment_slot n:STRING_CONSTANT in buf:STRING <-
- ( + s:ITM_SLOT;
+ ( + s:ITM_SLOT;
+ ps:ITM_TYPE_SIMPLE;
+ p:PROTOTYPE;
+ i:INTEGER;
-
+
s := slot_list.fast_reference_at n;
((s != NULL) && {s.comment != NULL}).if {
buf.append (s.comment);
};
// Parent.
s := first_slot;
- {(s != NULL) && {s.id_section.is_inherit_or_insert}}.while_do {
+ {(s != NULL) && {s.id_section.is_inherit_or_insert}}.while_do {
ps ?= s.result_type;
- (ps != NULL).if {
+ (ps != NULL).if {
p := NULL;
i := prototype_list.lower;
- {(i <= prototype_list.upper) && {p = NULL}}.while_do {
+ {(i <= prototype_list.upper) && {p = NULL}}.while_do {
(prototype_list.item i.name = ps.name).if {
p := prototype_list.item i;
};
i := i + 1;
};
- (p != NULL).if {
+ (p != NULL).if {
p.get_all_comment_slot n in buf;
};
- };
+ };
s := s.next;
};
);
-
+
- list_tmp:FAST_ARRAY(ITM_SLOT) := FAST_ARRAY(ITM_SLOT).create_with_capacity 256;
-
+
- str_tmp:STRING := STRING.create 512;
- str_tmp2:STRING := STRING.create 64;
- str_tmp3:STRING := STRING.create 64;
-
+
- shorter_comment str:STRING in buf:STRING light is_light:BOOLEAN <-
( + cur:INTEGER;
+ stat,old_stat:INTEGER;
@@ -692,21 +692,21 @@ Section PROTOTYPE
+ i:INTEGER;
+ lst:LINKED_LIST(STRING_CONSTANT);
+ code_balise:STRING_CONSTANT;
-
+
cur := str.lower;
str_tmp.clear;
code_balise := ALIAS_STR.short_comment_slot_line;
- {cur <= str.upper}.while_do {
+ {cur <= str.upper}.while_do {
car := str.item cur;
(stat)
- .when 0 then {
+ .when 0 then {
// Begin.
- (car = '*').if {
+ (car = '*').if {
(str_tmp.count > 1).if {
(is_light).if {
buf.append str_tmp;
cur := str.upper + 1;
- } else {
+ } else {
put "Description:" to buf like (ALIAS_STR.short_subsub_title);
put str_tmp to buf like code_balise;
};
@@ -715,7 +715,7 @@ Section PROTOTYPE
stat := 1;
}.elseif {car = '`'} then {
old_stat := stat;
- stat := 2;
+ stat := 2;
str_tmp2.clear;
} else {
str_tmp.add_last car;
@@ -723,15 +723,15 @@ Section PROTOTYPE
}
.when 1 then {
// Begin slot.
- (car.to_lower.in_range 'a' to 'z').if {
+ (car.to_lower.in_range 'a' to 'z').if {
str_tmp.add_last (car.to_lower);
}.elseif {(car = ' ') && {!str_tmp.is_empty}} then {
- str_tmp.add_last '_';
+ str_tmp.add_last '_';
}.elseif {car = ':'} then {
- (str_tmp.count != 0).if {
- code_balise := ALIAS_STR.get str_tmp;
+ (str_tmp.count != 0).if {
+ code_balise := ALIAS_STR.get str_tmp;
lst := PARSER.short_dico.fast_reference_at code_balise;
- (lst = NULL).if {
+ (lst = NULL).if {
code_balise := NULL;
} else {
str_tmp.replace_all '_' with ' ';
@@ -763,7 +763,7 @@ Section PROTOTYPE
} else {
put str_tmp2 to str_tmp like (ALIAS_STR.short_identifier);
};
- };
+ };
stat := old_stat;
} else {
str_tmp2.add_last car;
@@ -772,22 +772,22 @@ Section PROTOTYPE
.when 3 then {
// Read slot.
(car = '*').if {
- (str_tmp.count > 1).if {
+ (str_tmp.count > 1).if {
put str_tmp to buf like code_balise;
};
str_tmp.clear;
- stat := 1;
+ stat := 1;
}.elseif {car = '`'} then {
old_stat := stat;
- stat := 2;
+ stat := 2;
str_tmp2.clear;
} else {
str_tmp.add_last car;
- };
+ };
};
cur := cur + 1;
};
- (str_tmp.count > 1).if {
+ (str_tmp.count > 1).if {
(is_light).if {
buf.append str_tmp;
} else {
diff --git a/src/type/type.li b/src/type/type.li
index 986a830..6a6e268 100644
--- a/src/type/type.li
+++ b/src/type/type.li
@@ -128,9 +128,9 @@ Section Public
(styl = NULL).if {
result := base.default;
} else {
- (styl = ALIAS_STR.keyword_expanded).if {
- result := base.default + TYPE_FULL.expanded_bit;
- } else {
+ (styl = ALIAS_STR.keyword_expanded).if {
+ result := base.default + TYPE_FULL.expanded_bit;
+ } else {
result := base.default + TYPE_FULL.strict_bit;
};
};
@@ -155,7 +155,7 @@ Section Public
{
(j <= slot_run.upper) &&
{slot_run.item j.id_section.is_inherit_or_insert} &&
- {result = NULL}
+ {result = NULL}
}.while_do {
ts ?= slot_run.item j.result_type;
typ := ts.to_run_for Self.raw;
@@ -189,7 +189,7 @@ Section Public
{
(j <= slot_run.upper) &&
{slot_run.item j.id_section.is_inherit_or_insert} &&
- {result = NULL}
+ {result = NULL}
}.while_do {
ts ?= slot_run.item j.result_type;
typ := ts.to_run_for Self.raw;
@@ -240,7 +240,7 @@ Section Public
{
(j <= slot_run.upper) &&
{slot_run.item j.id_section.is_inherit_or_insert} &&
- {result = NULL}
+ {result = NULL}
}.while_do {
it ?= slot_run.item j.result_type;
result := it.to_run_for Self.get_slot n;
@@ -270,10 +270,10 @@ Section Public
};
*/
itm_slot := prototype.slot_list.fast_reference_at n;
- (itm_slot != NULL).if {
+ (itm_slot != NULL).if {
verify_itm_slot_parent itm_slot;
result := SLOT.create itm_slot type Self;
- slot_run.add_last result;
+ slot_run.add_last result;
};
};
result
@@ -335,11 +335,11 @@ Section Private
j := lst.lower;
{(j <= lst.upper) && {lst.item j.to_run_for profil_slot != t}}.while_do {
j := j + 1;
- };
+ };
(j <= lst.upper).if {
result := TRUE;
last_cast_name.copy msg;
- lst.item j.append_cast_name_in last_cast_name;
+ lst.item j.append_cast_name_in last_cast_name;
};
};
result
@@ -499,7 +499,7 @@ Section Public
(s.type.raw.is_block) ||
{is_far_expanded (s.type)}
}
- ).if {
+ ).if {
s.type.raw.genere_struct;
};
};
@@ -513,7 +513,7 @@ Section Public
};
// Sort slot.
(slot_run.lower).to (slot_run.upper) do { j:INTEGER;
- slot := slot_run.item j;
+ slot := slot_run.item j;
(slot.style = '+').if {
// In struct.
(slot.lower_style = 0).if {
@@ -552,7 +552,7 @@ Section Public
// BSBS: A tester sont utilité !
(! tab.is_empty).if {
semantic_error (tab.first.position,"Slot is not possible with a type C");
- };
+ };
};
(is_java).if_false {
@@ -565,12 +565,12 @@ Section Public
output_decl.add_last '\n';
} else {
genere_typedef_type_c;
- (is_late_binding).if {
+ (is_late_binding).if {
semantic_error (tab.first.position,"Late binding is not possible with a type C");
};
};
};
- } else {
+ } else {
output_decl.append "/* ";
output_decl.append intern_name;
output_decl.append " */\n";
@@ -584,24 +584,24 @@ Section Public
output_decl.append "__ ";
};
string_tmp.clear;
- (is_late_binding).if {
- id_counter_with_type.append_in output_decl;
+ (is_late_binding).if {
+ id_counter_with_type.append_in output_decl;
id_counter_with_type := id_counter_with_type + 1;
(prototype.style != '-').if {
string_tmp.append " unsigned int __id;\n";
};
- (prototype.is_mapping).if {
- semantic_error (prototype.position,
+ (prototype.is_mapping).if {
+ semantic_error (prototype.position,
"Late binding is not possible with `mapping' object.");
};
- } else {
- id_counter_without_type.append_in output_decl;
- id_counter_without_type := id_counter_without_type + 1;
+ } else {
+ id_counter_without_type.append_in output_decl;
+ id_counter_without_type := id_counter_without_type + 1;
};
(is_java).if {
output_decl.add_last ';';
};
- output_decl.add_last '\n';
+ output_decl.add_last '\n';
(prototype.style = '-').if {
string_tmp.append " lith_object thread;\n";
(param_count != 0).if {
@@ -615,21 +615,21 @@ Section Public
4.downto 0 do { j:INTEGER;
tab := slot_size.item j;
(tab.lower).to (tab.upper) do { i:INTEGER;
- slot_data := tab.item i;
+ slot_data := tab.item i;
((prototype.is_mapping) && {slot_data.type.is_expanded_c}).if {
string_tmp.append " volatile ";
} else {
- string_tmp.append " ";
+ string_tmp.append " ";
};
slot_data.genere string_tmp;
};
tab.clear;
};
-
+
(Self = type_block).if {
string_tmp.append " void *self;\n";
};
-
+
(string_tmp.is_empty).if {
string_tmp.append " void *Nothing;\n";
};
@@ -700,7 +700,7 @@ Section Public
} else {
output_decl.append "};\n";
};
- };
+ };
// Prototype declaration.
(is_java).if {
output_glob.append "private static __";
@@ -727,12 +727,12 @@ Section Public
output_glob.append intern_name;
output_glob.append "__}";
};
- output_glob.append ";\n";
+ output_glob.append ";\n";
output_glob.append "#define ";
output_glob.append intern_name;
output_glob.append "__ (&";
output_glob.append intern_name;
- output_glob.append "_)\n\n";
+ output_glob.append "_)\n\n";
};
};
};
@@ -754,7 +754,7 @@ Section Public
output_decl.append "typedef ";
output_decl.append type_c;
output_decl.append " __";
- output_decl.append intern_name;
+ output_decl.append intern_name;
output_decl.add_last ';';
output_decl.add_last '\n';
};
@@ -780,7 +780,7 @@ Section Public
output_decl.append (t.intern_name);
output_decl.append "_struct";
output_decl.append " __";
- output_decl.append intern_name;
+ output_decl.append intern_name;
output_decl.add_last ';';
(alias_slot != NULL).if {
output_decl.append " /* ALIAS with ";
@@ -948,7 +948,7 @@ Section Public
}.while_do {
(slot_run.item idx.id_section.is_inherit).if {
ts ?= slot_run.item idx.result_type;
- type_parent := ts.to_run_for Self.raw;
+ type_parent := ts.to_run_for Self.raw;
result := type_parent.is_sub_type_with_name n;
};
idx := idx + 1;
@@ -1220,7 +1220,7 @@ Section TYPE,PROTOTYPE
{slot_run.item idx.id_section.is_inherit_or_insert}
}.while_do {
ts ?= slot_run.item idx.result_type;
- type_parent := ts.to_run_for Self.raw;
+ type_parent := ts.to_run_for Self.raw;
other := type_parent.prototype.slot_list.fast_reference_at (ref.name);
(other != NULL).if {
ref.is_equal_profil other;
@@ -1243,7 +1243,7 @@ Section TYPE,PROTOTYPE
}.while_do {
s := slot_run.item idx;
ts ?= s.result_type;
- type_parent := ts.to_run_for Self.raw;
+ type_parent := ts.to_run_for Self.raw;
(type_parent = ref).if {
semantic_error (s.position,"Static cyclic inheritance.");
};
diff --git a/src/type/type_block.li b/src/type/type_block.li
index 17b707e..93e4c20 100644
--- a/src/type/type_block.li
+++ b/src/type/type_block.li
@@ -19,25 +19,25 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_BLOCK;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Virtual type for BLOCK manager";
-
+
Section Inherit
-
+
+ parent_type:Expanded TYPE;
-
-Section Private
-
+
+Section Private
+
- dico:FAST_ARRAY(TYPE_BLOCK) := FAST_ARRAY(TYPE_BLOCK).create_with_capacity 2048;
-
+
Section TYPE_BLOCK //,PROFIL_BLOCK
-
+
//
// Creation.
//
@@ -48,51 +48,51 @@ Section TYPE_BLOCK //,PROFIL_BLOCK
result.make a_list and_result r_list;
result
);
-
+
- make a_list:FAST_ARRAY(TYPE_FULL) and_result r_list:FAST_ARRAY(TYPE_FULL) <-
- (
+ (
argument_list := a_list;
result_list := r_list;
- default := TYPE_FULL.create Self with 0;
+ default := TYPE_FULL.create Self with 0;
);
-
+
Section Public
- set_late_binding <-
- (
+ (
type_block.set_late_binding;
);
-
+
- intern_name:STRING_CONSTANT <- type_block.intern_name;
-
+
- is_block:BOOLEAN := TRUE;
+ argument_list:FAST_ARRAY(TYPE_FULL);
- + result_list:FAST_ARRAY(TYPE_FULL);
-
- - get_expr_for p:POSITION :EXPR <-
+ + result_list:FAST_ARRAY(TYPE_FULL);
+
+ - get_expr_for p:POSITION :EXPR <-
( + result:EXPR;
+ lst:FAST_ARRAY(EXPR);
-
+
(result_list.count > 1).if {
lst := FAST_ARRAY(EXPR).create_with_capacity (result_list.count);
(result_list.lower).to (result_list.upper) do { j:INTEGER;
lst.add_last (result_list.item j.get_temporary_expr p);
};
result := EXPR_MULTIPLE.create lst;
- }.elseif {result_list.count = 1} then {
+ }.elseif {result_list.count = 1} then {
result := result_list.first.get_temporary_expr p;
} else {
result := PROTOTYPE_CST.create p type (TYPE_VOID.default);
};
result
- );
-
+ );
+
- get t:ITM_TYPE_BLOCK with p:PARAMETER_TO_TYPE :TYPE_FULL <-
( + a_list:FAST_ARRAY(TYPE_FULL);
+ r_list:FAST_ARRAY(TYPE_FULL);
-
- // Argument.
+
+ // Argument.
a_list := ALIAS_ARRAY(TYPE_FULL).new;
(t.type_argument != NULL).if {
t.type_argument.to_run_in a_list for p;
@@ -100,18 +100,18 @@ Section Public
a_list := ALIAS_ARRAY(TYPE_FULL).alias a_list;
// Result.
r_list := ALIAS_ARRAY(TYPE_FULL).new;
- (t.type_result != NULL).if {
+ (t.type_result != NULL).if {
t.type_result.to_run_in r_list for p;
- };
+ };
r_list := ALIAS_ARRAY(TYPE_FULL).alias r_list;
- //
+ //
get_direct a_list and_result r_list.default
);
-
+
- get_direct a_list:FAST_ARRAY(TYPE_FULL) and_result r_list:FAST_ARRAY(TYPE_FULL) :TYPE_BLOCK <-
( + idx:INTEGER;
+ result:TYPE_BLOCK;
-
+
idx := dico.lower;
{
(idx <= dico.upper) && {
@@ -120,7 +120,7 @@ Section Public
}
}.while_do {
idx := idx + 1;
- };
+ };
(idx <= dico.upper).if {
result := dico.item idx;
} else {
@@ -129,61 +129,61 @@ Section Public
};
result
);
-
+
- prototype:PROTOTYPE <- type_block.prototype;
-
+
- get_slot n:STRING_CONSTANT :SLOT <-
(
type_block.get_slot n
);
-
+
- get_local_slot n:STRING_CONSTANT :SLOT <-
(
type_block.get_local_slot n
);
-
+
- get_path_slot n:STRING_CONSTANT :SLOT <-
(
type_block.get_path_slot n
);
-
+
- genere_struct <- type_block.genere_struct;
-
+
//
// Code source generation.
//
-
+
- put_id buffer:STRING <- index.append_in buffer;
-
- - put_access_id e:EXPR in buffer:STRING <-
+
+ - put_access_id e:EXPR in buffer:STRING <-
(
buffer.append "(int)";
e.genere buffer;
);
-
- - put_value buffer:STRING <-
+
+ - put_value buffer:STRING <-
(
buffer.append "(void *)";
index.append_in buffer;
);
-
+
- is_sub_type other:TYPE :BOOLEAN <-
( + me:TYPE_BLOCK;
-
+
me ?= other;
- (me != NULL) &&
- {me.argument_list = argument_list} &&
+ (me != NULL) &&
+ {me.argument_list = argument_list} &&
{me.result_list = result_list}
);
-
+
- is_sub_type_result other:TYPE_BLOCK :BOOLEAN <-
( + result:BOOLEAN;
+ j:INTEGER;
(result_list = other.result_list) ||
{
- (result_list != NULL) &&
- {other.result_list != NULL} &&
- {result_list.count = other.result_list.count} &&
+ (result_list != NULL) &&
+ {other.result_list != NULL} &&
+ {result_list.count = other.result_list.count} &&
{
result := TRUE;
j := result_list.lower;
@@ -195,21 +195,21 @@ Section Public
}
}
);
-
+
//
// Display.
//
-
+
- append_name_in buf:STRING <-
(
- buf.add_last '{';
+ buf.add_last '{';
(argument_list.is_empty).if_false {
(argument_list.count > 1).if {
buf.add_last '(';
(argument_list.lower).to (argument_list.upper-1) do { j:INTEGER;
argument_list.item j.display buf;
buf.add_last ',';
- };
+ };
argument_list.last.display buf;
buf.add_last ')';
} else {
@@ -217,15 +217,15 @@ Section Public
};
buf.add_last ';';
buf.add_last ' ';
- };
+ };
(result_list.is_empty).if_false {
(result_list.lower).to (result_list.upper-1) do { j:INTEGER;
result_list.item j.display buf;
buf.add_last ',';
- };
- result_list.last.display buf;
+ };
+ result_list.last.display buf;
};
- buf.add_last '}';
+ buf.add_last '}';
// Debug
buf.append "(TYPE_BLOCK)";
);
diff --git a/src/type/type_context.li b/src/type/type_context.li
index e09bcc1..67ce839 100644
--- a/src/type/type_context.li
+++ b/src/type/type_context.li
@@ -19,34 +19,34 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_CONTEXT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type Context for debug mode";
-
+
Section Inherit
-
+
+ parent_type:Expanded TYPE;
-
+
Section Public
-
+
- name:STRING_CONSTANT <- ALIAS_STR.prototype_context;
-
+
- intern_name:STRING_CONSTANT <- name;
-
+
- type_c:STRING_CONSTANT <- "_____CONTEXT";
-
+
//
// Creation.
//
-
+
- make_context <-
- (
- dico_type.fast_put Self to name;
+ (
+ dico_type.fast_put Self to name;
//slot_run := FAST_ARRAY(SLOT).create_with_capacity 1; // BSBS: Plus utile !
default := TYPE_FULL.create Self with (TYPE_FULL.expanded_bit);
);
@@ -55,10 +55,10 @@ Section Public
(
// Nothing.
);
-
+
- genere_struct <-
- (
- output_decl.append
+ (
+ output_decl.append
"/* ___CONTEXT */\n\
\typedef struct ___CONTEXT_struct _____CONTEXT; \n\
\struct ___CONTEXT_struct {\n\
@@ -67,4 +67,3 @@ Section Public
\};\n\
\_____CONTEXT *top_context; \n\n";
);
-
\ No newline at end of file
diff --git a/src/type/type_full.li b/src/type/type_full.li
index 24d0c04..8a64f61 100644
--- a/src/type/type_full.li
+++ b/src/type/type_full.li
@@ -19,44 +19,44 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_FULL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type with attribute flags.";
-
-Section Inherit
-
+
+Section Inherit
+
- parent_any:ANY := ANY;
-
-Section TYPE, TYPE_FULL // Private after fuck bug
-
+
+Section TYPE, TYPE_FULL // Private after fuck bug
+
+ the_parent_type:TYPE; // BSBS: Passer en héritage + Insert mode.
-
+
Section TYPE, TYPE_FULL
-
+
- get_with flg:UINTEGER_8 :TYPE_FULL <- the_parent_type.get_with flg;
-
-Section Public
-
+
+Section Public
+
- get_slot n:STRING_CONSTANT :SLOT <- the_parent_type.get_slot n;
-
+
- hash_code:INTEGER <- raw.name.hash_code;
-
+
- size:INTEGER <- the_parent_type.size;
-
+
- prototype:PROTOTYPE <- the_parent_type.prototype;
-
+
- is_sub_type other:TYPE_FULL :BOOLEAN <- the_parent_type.is_sub_type (other.raw);
-
+
- slot_run:FAST_ARRAY(SLOT) <- the_parent_type.slot_run;
-
+
- is_late_binding:BOOLEAN <- the_parent_type.is_late_binding;
Section TYPE
-
+
+ flag:UINTEGER_8;
// 7 6 5 4 3 2 1 0
// | | | | | +- 0:Reference / 1:Expanded
@@ -69,63 +69,63 @@ Section TYPE
//
// Creation.
//
-
+
- create typ:TYPE with code:UINTEGER_8 :SELF <-
- [
- -? {typ != NULL};
+ [
+ -? {typ != NULL};
]
( + result:SELF;
-
+
result := clone;
result.make typ with code;
- result
+ result
);
-
+
- make typ:TYPE with code:UINTEGER_8 <-
(
the_parent_type := typ;
- flag := code;
+ flag := code;
? {is_expanded -> (! is_strict)};
);
-
+
Section Public
-
+
- is_parameter_type:BOOLEAN <- FALSE;
-
+
- raw:TYPE <- the_parent_type;
-
+
//
// Set.
//
-
- - expanded_bit :UINTEGER_8 := 000001b;
- - default_expanded_bit:UINTEGER_8 := 000010b;
+
+ - expanded_bit :UINTEGER_8 := 000001b;
+ - default_expanded_bit:UINTEGER_8 := 000010b;
- strict_bit :UINTEGER_8 := 000100b;
- default_strict_bit :UINTEGER_8 := 001000b;
- expanded_ref_bit :UINTEGER_8 := 010000b;
- generic_bit :UINTEGER_8 := 100000b;
-
+
//
// Access.
//
-
+
- is_expanded :BOOLEAN <- (flag & expanded_bit ) != 0;
- is_default_expanded :BOOLEAN <- (flag & default_expanded_bit) != 0;
- is_strict :BOOLEAN <- (flag & strict_bit ) != 0;
- is_default_strict :BOOLEAN <- (flag & default_strict_bit ) != 0;
- is_expanded_ref :BOOLEAN <- (flag & expanded_ref_bit ) != 0;
- is_generic :BOOLEAN <- (flag & generic_bit ) != 0;
-
+
- is_expanded_c:BOOLEAN <- (is_expanded) && {raw.type_c != NULL};
-
- - Self:SELF '==' Right 60 other:E :BOOLEAN <-
+
+ - Self:SELF '==' Right 60 other:E :BOOLEAN <-
( + same:SELF;
- same ?= other;
+ same ?= other;
(same != NULL) && {
(Self = same) || {(raw = same.raw) && {(flag & 01111b) = (same.flag & 01111b)}}
}
);
-
+
- append_name_in buffer:STRING <-
(
(is_strict).if {
@@ -133,41 +133,41 @@ Section Public
};
(is_expanded).if {
buffer.append "Expanded ";
- };
+ };
raw.append_name_in buffer;
// buffer.append (raw.name);
);
-
+
//
// Operation.
//
-
+
- Self:SELF '+' other:UINTEGER_8 :TYPE_FULL <- get_with (flag | other);
-
+
- Self:SELF '-' other:UINTEGER_8 :TYPE_FULL <- get_with (flag & ~other);
-
+
- to_strict:TYPE_FULL <-
( + result:TYPE_FULL;
-
+
(is_expanded).if {
result := Self;
- } else {
- result := get_with (flag | strict_bit);
+ } else {
+ result := get_with (flag | strict_bit);
};
result
);
- to_no_strict:TYPE_FULL <-
( + result:TYPE_FULL;
-
+
(is_expanded).if {
result := Self;
- } else {
- result := get_with (flag & ~strict_bit);
+ } else {
+ result := get_with (flag & ~strict_bit);
};
result
);
-
+
//
// Variable product.
//
@@ -184,10 +184,10 @@ Section Public
(
LOCAL.create p name n style s type Self
);
-
+
- get_temporary_expr p:POSITION :EXPR <-
- ( + result:EXPR;
-
+ ( + result:EXPR;
+
(raw = TYPE_VOID).if {
result := PROTOTYPE_CST.create p type (TYPE_VOID.default); //BSBS: Alias.
} else {
@@ -195,11 +195,11 @@ Section Public
};
result
);
-
+
- get_temporary p:POSITION :LOCAL <-
- (
+ (
new_local p name (ALIAS_STR.variable_tmp) style '+'
- );
+ );
- get p:POSITION result n:INTEGER :LOCAL <-
( + intern:STRING_CONSTANT;
@@ -208,14 +208,14 @@ Section Public
string_tmp.add_last '_';
n.append_in string_tmp;
};
- intern := ALIAS_STR.get string_tmp;
+ intern := ALIAS_STR.get string_tmp;
new_local p name intern style '+'
- );
-
+ );
+
//
// Type Control.
//
-
+
//+----------+----------+----------+----------+
//| A := B-->| Reference| Expanded | Strict |
//| V | TYPE | TYPE | TYPE |
@@ -231,120 +231,120 @@ Section Public
//+----------+----------+----------+----------+
- affect_with other:TYPE_FULL :BOOLEAN <-
( + result:BOOLEAN;
-
+
(other == Self).if {
result := TRUE;
- } else {
+ } else {
(is_strict).if {
// A: Strict.
result := other.raw = TYPE_NULL;
}.elseif {is_expanded} then {
// A: Expanded.
- result :=
+ result :=
((other.is_strict) && {raw ~= other.raw }) ||
{(raw = type_boolean) && {other.is_sub_type Self}} ||
- {(raw = type_pointer) && {other.raw = TYPE_NULL }};
+ {(raw = type_pointer) && {other.raw = TYPE_NULL }};
} else {
// A: Reference.
- result :=
+ result :=
(
- (! other.is_expanded) ||
+ (! other.is_expanded) ||
{ + tb:TYPE_BLOCK;
- tb ?= raw;
+ tb ?= raw;
(tb != NULL)
}
- ) && {other.is_sub_type Self};
- };
+ ) && {other.is_sub_type Self};
+ };
};
result
);
-
+
//
// Import / Export manager.
//
-
+
- is_export_to t:TYPE_FULL :BOOLEAN <- raw.is_export_to t;
-
+
- is_import_to t:TYPE_FULL :BOOLEAN <- raw.is_import_to t;
-
+
//
// Default value.
//
+ recursivity_test:BOOLEAN;
- - default_value p:POSITION :EXPR <-
+ - default_value p:POSITION :EXPR <-
( + result:EXPR;
-
+
((prototype != NULL) && {prototype.default_value != NULL}).if {
- // Prototype User definition.
+ // Prototype User definition.
(recursivity_test).if {
crash;
- POSITION.put_error semantic text
+ POSITION.put_error semantic text
"Recursivity without end (default used default, ...).";
list_current.position.put_position;
prototype.default_value.position.put_position;
- POSITION.send_error;
+ POSITION.send_error;
} else {
recursivity_test := TRUE;
result := prototype.default_value.to_run_expr;
recursivity_test := FALSE;
};
} else {
- (is_expanded).if {
+ (is_expanded).if {
// Copy of model prototype.
result := PROTOTYPE_CST.create p type Self;
} else {
result := PROTOTYPE_CST.create p type (TYPE_NULL.default);
- };
+ };
};
-
+
result
);
-
+
//
// Declaration generation.
//
-
+
- genere_declaration buffer:STRING <-
- (
- (is_expanded).if {
+ (
+ (is_expanded).if {
raw.put_expanded_declaration buffer;
}.elseif {is_strict} then {
raw.put_reference_declaration buffer;
- } else {
- raw.put_generic_declaration buffer;
+ } else {
+ raw.put_generic_declaration buffer;
};
);
-
+
- genere_star_declaration buffer:STRING <-
- (
- ((! is_expanded) || {is_expanded_ref}).if {
- raw.put_reference_star_declaration buffer;
+ (
+ ((! is_expanded) || {is_expanded_ref}).if {
+ raw.put_reference_star_declaration buffer;
};
);
-
+
//
// Generation code.
//
-
+
- genere_value buffer:STRING <-
( + tb:PROFIL_BLOCK;
(
- (is_expanded) && {! is_expanded_ref} &&
+ (is_expanded) && {! is_expanded_ref} &&
{raw != type_true} && {raw != type_false} &&
{tb ?= raw; tb = NULL}
).if {
buffer.append "(*";
raw.put_value buffer;
- buffer.add_last ')';
+ buffer.add_last ')';
} else {
raw.put_value buffer;
};
);
-
+
//
// Display.
//
-
+
- display buf:STRING <-
(
(is_generic).if {
@@ -352,14 +352,14 @@ Section Public
};
append_name_in buf;
);
-
+
- print <-
(
string_tmp.clear;
display string_tmp;
string_tmp.print;
);
-
+
- print_full <-
(
string_tmp.clear;
@@ -388,4 +388,4 @@ Section Public
//
string_tmp.print;
);
-
+
diff --git a/src/type/type_generic.li b/src/type/type_generic.li
index 41d503c..3ae0508 100644
--- a/src/type/type_generic.li
+++ b/src/type/type_generic.li
@@ -19,40 +19,40 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_GENERIC;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Type generic";
-
+
Section Inherit
-
+
+ parent_type:Expanded TYPE;
-
-Section Private
-
+
+Section Private
+
// BSBS: Vu que les ITM_TYPE sont aliaser, il n'est pas necessary d'aliaser les TYPE !
// Mais attention au pb des TYPE_GENERIC et de leur alias de slot_run...
-
- - dicog_type:HASHED_DICTIONARY(TYPE_GENERIC,STRING_CONSTANT) :=
+
+ - dicog_type:HASHED_DICTIONARY(TYPE_GENERIC,STRING_CONSTANT) :=
HASHED_DICTIONARY(TYPE_GENERIC,STRING_CONSTANT).create;
-
+
Section Public
-
+
+ name:STRING_CONSTANT;
-
+
+ key:STRING_CONSTANT;
-
- + generic_list:FAST_ARRAY(TYPE_FULL);
-
+
+ + generic_list:FAST_ARRAY(TYPE_FULL);
+
- parameter_to_type p:ITM_TYPE_PARAMETER :TYPE_FULL <-
( + idx:INTEGER;
+ tab:FAST_ARRAY(ITM_TYPE_PARAMETER);
+ result:TYPE_FULL;
-
+
tab := prototype.idf_generic_list;
idx := tab.fast_first_index_of p;
(idx <= tab.upper).if {
@@ -60,75 +60,75 @@ Section Public
};
result
);
-
+
//
// Detect Alias.
- //
-
+ //
+
- detect_alias <-
(
(dicog_type.lower).to (dicog_type.upper) do { j:INTEGER;
dicog_type.item j.detect_alias_struct;
- };
+ };
);
-
+
//
// Import / Export
//
-
+
- is_export_to t:TYPE_FULL :BOOLEAN <-
- (
+ (
is_cast t with (ALIAS_STR.slot_to) on export_list and (prototype.import_list)
);
- is_import_to t:TYPE_FULL :BOOLEAN <-
- (
+ (
is_cast t with (ALIAS_STR.slot_from) on import_list and (prototype.import_list)
);
-
+
Section Private
-
+
+ export_list:FAST_ARRAY(TYPE_FULL);
+ import_list:FAST_ARRAY(TYPE_FULL);
-
- - is_cast t:TYPE_FULL with msg:STRING_CONSTANT
- on lst:FAST_ARRAY(TYPE_FULL)
+
+ - is_cast t:TYPE_FULL with msg:STRING_CONSTANT
+ on lst:FAST_ARRAY(TYPE_FULL)
and lstp:FAST_ARRAY(ITM_TYPE_MONO) :BOOLEAN <-
- ( + result:BOOLEAN;
+ ( + result:BOOLEAN;
+ j:INTEGER;
-
+
(lst != NULL).if {
- j := lst.fast_first_index_of t;
+ j := lst.fast_first_index_of t;
(j <= lst.upper).if {
result := TRUE;
last_cast_name.copy msg;
- lstp.item j.append_cast_name_in last_cast_name;
- };
+ lstp.item j.append_cast_name_in last_cast_name;
+ };
};
- result
+ result
);
-
+
Section Public
-
+
//
// Get
//
-
- - get itm_typ:ITM_TYPE_SIMPLE :TYPE_FULL <-
+
+ - get itm_typ:ITM_TYPE_SIMPLE :TYPE_FULL <-
(
crash_with_message "`get' in TYPE_GENERIC !";
NULL
);
-
+
- get (path:STRING_CONSTANT,itm_typ:ITM_TYPE_SIMPLE) with gen:FAST_ARRAY(TYPE_FULL) :TYPE_FULL <-
- ( + base:TYPE_GENERIC;
+ ( + base:TYPE_GENERIC;
+ result,t:TYPE_FULL;
+ styl,k:STRING_CONSTANT;
+ proto:PROTOTYPE;
-
- proto := load_prototype (path,itm_typ.name) generic_count (gen.count);
- string_tmp.copy (proto.filename);
+
+ proto := load_prototype (path,itm_typ.name) generic_count (gen.count);
+ string_tmp.copy (proto.filename);
(gen.lower).to (gen.upper) do { j:INTEGER;
string_tmp.add_last ' ';
t := gen.item j;
@@ -139,22 +139,22 @@ Section Public
k := ALIAS_STR.get string_tmp;
//
base := dicog_type.fast_reference_at k;
- (base = NULL).if {
+ (base = NULL).if {
base := TYPE_GENERIC.clone;
dicog_type.fast_put base to k;
base.make itm_typ with proto generic gen key k;
};
- //
+ //
styl := itm_typ.style;
- (styl = NULL).if {
+ (styl = NULL).if {
result := base.default;
} else {
- (styl = ALIAS_STR.keyword_expanded).if {
- result := base.default + TYPE_FULL.expanded_bit;
- } else {
+ (styl = ALIAS_STR.keyword_expanded).if {
+ result := base.default + TYPE_FULL.expanded_bit;
+ } else {
result := base.default + TYPE_FULL.strict_bit;
};
- };
+ };
result
);
@@ -163,44 +163,44 @@ Section Public
// BSBS: A revoir : il n'y a que NATIVE_ARRAY qui a besoin de ca,
// il faudrai plutot stocker ca ailleurs... ou? chépa!
//
-
+
+ put_to_list:FAST_ARRAY(PUT_TO);
-
+
- add_put_to n:PUT_TO <-
- (
+ (
(put_to_list = NULL).if {
put_to_list := FAST_ARRAY(PUT_TO).create_with_capacity 16;
};
put_to_list.add_last n;
);
-
+
- remove_put_to n:PUT_TO <-
( + idx:INTEGER;
-
- idx := put_to_list.fast_first_index_of n;
+
+ idx := put_to_list.fast_first_index_of n;
put_to_list.swap idx with (put_to_list.upper);
put_to_list.remove_last;
);
-
+
+ recursive_test:BOOLEAN;
-
+
+ old_type:TYPES;
-
+
- get_type t:TYPES_TMP <-
( + typ:TYPE_FULL;
+ tmp_type:TYPES_TMP;
-
+
typ := generic_list.first;
- (typ.is_expanded && {typ.raw != type_boolean}).if {
+ (typ.is_expanded && {typ.raw != type_boolean}).if {
t.add (typ.raw);
- } else {
+ } else {
(put_to_list != NULL).if {
- (! recursive_test).if {
+ (! recursive_test).if {
recursive_test := TRUE;
tmp_type := TYPES_TMP.new;
(put_to_list.lower).to (put_to_list.upper) do { j:INTEGER;
put_to_list.item j.value.get_type tmp_type;
- };
+ };
old_type := tmp_type.update old_type;
recursive_test := FALSE;
};
@@ -208,14 +208,14 @@ Section Public
};
};
);
-
+
//
// Declaration generation.
//
-
+
- put_reference_declaration buffer:STRING <-
- (
- (prototype.name = ALIAS_STR.prototype_native_array).if {
+ (
+ (prototype.name = ALIAS_STR.prototype_native_array).if {
generic_list.first.genere_declaration buffer;
}.elseif {prototype.name = ALIAS_STR.prototype_native_array_volatile} then {
buffer.append "volatile ";
@@ -224,13 +224,13 @@ Section Public
parent_type.put_reference_declaration buffer;
};
);
-
+
- put_reference_star_declaration buffer:STRING <-
- (
+ (
(
(prototype.name = ALIAS_STR.prototype_native_array) ||
{prototype.name = ALIAS_STR.prototype_native_array_volatile}
- ).if {
+ ).if {
(is_java).if {
buffer.append "[]";
} else {
@@ -241,29 +241,29 @@ Section Public
parent_type.put_reference_star_declaration buffer;
};
);
-
-Section Public
-
+
+Section Public
+
- make itm_typ:ITM_TYPE_SIMPLE <-
(
crash_with_message "TYPE_GENERIC.make";
);
- - make itm_typ:ITM_TYPE_SIMPLE with proto:PROTOTYPE
+ - make itm_typ:ITM_TYPE_SIMPLE with proto:PROTOTYPE
generic gen:FAST_ARRAY(TYPE_FULL) key k:STRING_CONSTANT <-
- ( + mask_bit:UINTEGER_8;
-
+ ( + mask_bit:UINTEGER_8;
+
index := index_count;
index_count := index_count + 1;
//
string_tmp.copy (itm_typ.name);
- string_tmp.add_last '(';
- (gen.lower).to (gen.upper - 1) do { j:INTEGER;
+ string_tmp.add_last '(';
+ (gen.lower).to (gen.upper - 1) do { j:INTEGER;
gen.item j.append_name_in string_tmp;
string_tmp.add_last ',';
- };
+ };
gen.last.append_name_in string_tmp;
- string_tmp.add_last ')';
+ string_tmp.add_last ')';
name := ALIAS_STR.get string_tmp;
key := k;
generic_list := gen;
@@ -276,8 +276,8 @@ Section Public
intern_name := ALIAS_STR.get_intern string_tmp;
//
prototype := proto;
- itm_type := itm_typ;
- slot_run := FAST_ARRAY(SLOT).create_with_capacity 10; // BSBS: A voir.
+ itm_type := itm_typ;
+ slot_run := FAST_ARRAY(SLOT).create_with_capacity 10; // BSBS: A voir.
(prototype.type_style = ALIAS_STR.keyword_expanded).if {
// Expanded.
mask_bit := TYPE_FULL.expanded_bit | TYPE_FULL.default_expanded_bit;
@@ -286,13 +286,13 @@ Section Public
mask_bit := TYPE_FULL.strict_bit | TYPE_FULL.default_strict_bit;
};
default := TYPE_FULL.create Self with mask_bit;
- prototype.init_slot_for Self;
+ prototype.init_slot_for Self;
//
subtype_list := HASHED_SET(TYPE).create;
subtype_list.fast_add TYPE_NULL;
add_subtype Self;
// BSBS: Size ???
-
+
// Import / Export.
(prototype.export_list != NULL).if {
export_list := FAST_ARRAY(TYPE_FULL).create_with_capacity (prototype.export_list.count);
@@ -308,4 +308,3 @@ Section Public
};
);
-
\ No newline at end of file
diff --git a/src/type/type_id.li b/src/type/type_id.li
index ef7835b..11ebede 100644
--- a/src/type/type_id.li
+++ b/src/type/type_id.li
@@ -19,86 +19,86 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_ID;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Virtual type style slot segregation";
-
+
Section Inherit
-
+
+ parent_type:Expanded TYPE;
-
-Section Private
-
+
+Section Private
+
- list_id:FAST_ARRAY(TYPE_ID);
-
+
- create i:INTEGER :SELF <-
( + result:SELF;
-
+
result := clone;
result.make i;
result
);
-
+
- make i:INTEGER <-
(
index := i;
default := TYPE_FULL.create Self with 0;
);
-
-Section Public
-
+
+Section Public
+
- name:STRING_CONSTANT <- ALIAS_STR.prototype_type_id;
-
+
- intern_name:STRING_CONSTANT <- name;
-
+
- get_index idx:INTEGER :TYPE_ID <-
( + result:TYPE_ID;
-
+
(idx > list_id.upper).if {
result := TYPE_ID.create idx;
list_id.add_last result;
? {list_id.upper = idx};
} else {
result := list_id.item idx;
- };
+ };
result
);
- - make_type_id <-
- (
+ - make_type_id <-
+ (
list_id := FAST_ARRAY(TYPE_ID).create_with_capacity 3;
list_id.add_last (create 0);
list_id.add_last (create 1);
);
-
+
- add_genere_list; // Nothing.
-
+
- genere_struct; // Nothing.
- - is_sub_type other:TYPE :BOOLEAN <-
- (
+ - is_sub_type other:TYPE :BOOLEAN <-
+ (
other.name = name
);
-
+
//
// Declaration generation.
//
-
+
- put_generic_declaration buffer:STRING <- buffer.append "int";
-
+
- put_reference_star_declaration buffer:STRING; // Nothing.
-
+
//
// Code source generation.
//
-
+
- put_id buffer:STRING <- index.append_in buffer;
-
+
- put_access_id e:EXPR in buffer:STRING <- e.genere buffer;
-
+
- put_value buffer:STRING <- index.append_in buffer;
\ No newline at end of file
diff --git a/src/type/type_null.li b/src/type/type_null.li
index 4a511ab..f290378 100644
--- a/src/type/type_null.li
+++ b/src/type/type_null.li
@@ -19,106 +19,105 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_NULL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Special type NULL";
-
+
Section Inherit
-
+
+ parent_type:Expanded TYPE;
-
+
Section Public
-
+
- name:STRING_CONSTANT <- ALIAS_STR.variable_null;
-
+
- intern_name:STRING_CONSTANT <- name;
-
+
//
// Creation.
//
- make_null <-
- (
+ (
index := index_count;
index_count := index_count + 1;
- dico_type.fast_put Self to name;
+ dico_type.fast_put Self to name;
slot_run := FAST_ARRAY(SLOT).create_with_capacity 1; // BSBS: Plus utile !
default := TYPE_FULL.create Self with 0;
);
-
- - get_local_slot n:STRING_CONSTANT :SLOT <- NULL;
-
+
+ - get_local_slot n:STRING_CONSTANT :SLOT <- NULL;
+
- get_path_slot n:STRING_CONSTANT :SLOT <- NULL;
-
+
//
// Error.
//
-
+
//- bug:INTEGER;
-
+
- product_error p:POSITION in lst:LIST with ctext:LOCAL <-
- (
- (debug_level_option != 0).if {
+ (
+ (debug_level_option != 0).if {
lst.add_last (
PUSH.create p context ctext first FALSE
- );
- };
- lst.add_last CALL_NULL;
+ );
+ };
+ lst.add_last CALL_NULL;
);
-
+
Section Public
-
+
//
// Import / Export
//
-
+
- is_export_to t:TYPE_FULL :BOOLEAN <- FALSE;
- is_import_to t:TYPE_FULL :BOOLEAN <- FALSE;
-
+
//
//
//
-
- - is_sub_type other:TYPE :BOOLEAN <- TRUE;
-
+
+ - is_sub_type other:TYPE :BOOLEAN <- TRUE;
+
- genere_typedef <-
(
);
-
+
- genere_struct <-
(
(is_java).if_false {
- output_decl.append
+ output_decl.append
"/* NULL */\n\
\#ifndef NULL\n\
\#define NULL ((void *)0)\n\
\#endif\n\n";
};
);
-
+
//
// Code source generation.
//
-
- - put_id buffer:STRING <-
+
+ - put_id buffer:STRING <-
(
put_value buffer;
);
-
- - put_access_id e:EXPR in buffer:STRING <- e.genere buffer;
-
- - put_value buffer:STRING <-
- (
+
+ - put_access_id e:EXPR in buffer:STRING <- e.genere buffer;
+
+ - put_value buffer:STRING <-
+ (
(is_java).if {
buffer.append "null";
} else {
buffer.append name;
};
);
-
\ No newline at end of file
diff --git a/src/type/type_void.li b/src/type/type_void.li
index 556a828..1202e3f 100644
--- a/src/type/type_void.li
+++ b/src/type/type_void.li
@@ -19,43 +19,43 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := TYPE_VOID;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Special virtual Void type";
-
+
Section Inherit
-
+
+ parent_type:Expanded TYPE;
-
+
Section Public
-
+
- name:STRING_CONSTANT <- ALIAS_STR.variable_void;
-
- - intern_name:STRING_CONSTANT <- name;
-
+
+ - intern_name:STRING_CONSTANT <- name;
+
//
// Creation.
//
-
+
- make_void <-
- (
- dico_type.fast_put Self to name;
+ (
+ dico_type.fast_put Self to name;
default := TYPE_FULL.create Self with 0;
);
-
+
//
// Import / Export
//
-
+
- is_export_to t:TYPE_FULL :BOOLEAN <- FALSE;
- is_import_to t:TYPE_FULL :BOOLEAN <- FALSE;
-
+
//
// Genere.
//
@@ -64,13 +64,13 @@ Section Public
(
// Nothing.
);
-
+
- genere_struct <-
(
// Nothing.
);
-
+
Section Public
-
- - is_sub_type other:TYPE :BOOLEAN <- FALSE;
+
+ - is_sub_type other:TYPE :BOOLEAN <- FALSE;
diff --git a/src/variable/argument.li b/src/variable/argument.li
index e054ab3..08af734 100644
--- a/src/variable/argument.li
+++ b/src/variable/argument.li
@@ -19,64 +19,63 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := ARGUMENT;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Argument runnable";
-
+
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
-
+
Section Public
-
+
+ name:STRING_CONSTANT;
-
+
+ type:TYPE_FULL;
-
+
//
// Creation.
//
-
+
- create p:POSITION name n:STRING_CONSTANT type t:TYPE_FULL :SELF <-
( + result:SELF;
-
+
result := clone;
result.make p name n type t;
result
);
-
+
- make p:POSITION name n:STRING_CONSTANT type t:TYPE_FULL <-
(
position := p;
name := n;
type := t;
);
-
+
//
// To profil
//
-
+
- to_local:LOCAL <-
(
LOCAL.create position name name style ' ' type (type.fix)
);
-
+
//
// Display.
//
-
+
- print <-
- (
+ (
string_tmp.clear;
string_tmp.append name;
string_tmp.add_last ':';
type.append_name_in string_tmp;
string_tmp.print;
);
-
-
\ No newline at end of file
+
diff --git a/src/variable/local.li b/src/variable/local.li
index c45b623..ae088f4 100644
--- a/src/variable/local.li
+++ b/src/variable/local.li
@@ -19,41 +19,41 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LOCAL;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Local slot";
-
+
Section Inherit
-
+
+ parent_variable:Expanded VARIABLE;
-
-Section Public
-
+
+Section Public
+
// BSBS: Doit pas etre utile.
-
+
+ is_result :BOOLEAN := FALSE;
- - set_result r:BOOLEAN <-
+ - set_result r:BOOLEAN <-
(
is_result := r;
);
-
+
//
// Copy alias manager.
//
-
+
- is_alias:BOOLEAN;
-
- - alias_on <-
+
+ - alias_on <-
(
is_alias := TRUE;
);
-
+
- alias_off <-
(
(list_alias.lower).to (list_alias.upper) do { j:INTEGER;
@@ -62,37 +62,37 @@ Section Public
list_alias.clear;
is_alias := FALSE;
);
-
+
- list_alias:FAST_ARRAY(LOCAL) := FAST_ARRAY(LOCAL).create_with_capacity 64;
-
+
- get_alias:LOCAL <-
(
(my_alias = NULL).if {
my_alias := my_copy;
my_alias.set_type_list type_list;
- list_alias.add_last Self;
+ list_alias.add_last Self;
};
my_alias
);
-
+
+ my_alias:LOCAL;
-
+
- set_my_alias new_loc:LOCAL <-
(
my_alias := new_loc;
);
-
+
+ list_level:INTEGER;
-
+
- set_list_level lev:INTEGER <-
(
list_level := lev;
);
-
+
- write p:POSITION with r:EXPR value val:EXPR :WRITE <-
( + result:WRITE;
-
- (my_alias != NULL).if {
+
+ (my_alias != NULL).if {
result := my_alias.write_direct p with NULL value val;
}.elseif {is_alias} then {
result := get_alias.write_direct p with NULL value val;
@@ -101,42 +101,42 @@ Section Public
};
result
);
-
+
- read p:POSITION with r:EXPR :READ <-
( + result:READ;
-
- (my_alias != NULL).if {
+
+ (my_alias != NULL).if {
result := my_alias.read_direct p with NULL;
- }.elseif {is_alias} then {
+ }.elseif {is_alias} then {
// Case : Argument function (see CALL_SLOT)
- result := get_alias.read_direct p with NULL;
+ result := get_alias.read_direct p with NULL;
} else {
//? {! is_alias};
result := read_direct p with NULL;
- };
+ };
result
);
-
+
//
// Sequence optimizer
//
-
+
+ last_seq:LOCAL_SEQ;
-
+
- reset_last_write w:WRITE <-
- (
+ (
((last_seq != NULL) && {last_seq.last_write = w}).if {
last_seq.set_last_write NULL;
};
);
-
+
- set_last_seq s:LOCAL_SEQ <-
(
last_seq := s;
);
-
+
- set_write w:WRITE <-
- (
+ (
(last_seq = NULL).if {
LOCAL_SEQ.new Self;
//"LOCAL:".print;
@@ -145,30 +145,30 @@ Section Public
(
(! PROFIL.mode_recursive) &&
{loop_invariant = NULL} &&
- {last_seq.last_write != NULL} &&
+ {last_seq.last_write != NULL} &&
{last_seq.last_index != -1} &&
{last_seq.last_list_current = list_current} &&
{last_seq.last_index < list_current.index} &&
{last_seq.last_seq_call_local_and_loop = seq_call_local_and_loop} &&
{list_current.item (last_seq.last_index) = last_seq.last_write} // BSBS: Voir pourquoi pas tjrs le cas
- ).if {
+ ).if {
list_current.put (last_seq.last_write.value) to (last_seq.last_index);
- unwrite (last_seq.last_write);
+ unwrite (last_seq.last_write);
new_execute_pass;
- };
+ };
// Save context
last_seq.set_seq w;
);
-
+
- set_read <-
(
(last_seq != NULL).if {
last_seq.set_last_index (-1);
};
);
-
+
- get_last_index:INTEGER <- last_seq.last_index;
-
+
- is_invariant:BOOLEAN <-
(
(loop_seq_call_local_and_loop = seq_call_local_and_loop) &&
@@ -179,7 +179,7 @@ Section Public
) || {style = ' '}
}
);
-
+
- get_last_value rec:EXPR :EXPR <-
[
? {rec = NULL};
@@ -191,7 +191,7 @@ Section Public
+ g:SLOT_DATA;
/*
+ bug:BOOLEAN;
-
+
(intern_name == "__tmp__TC").if {
bug:=TRUE;
"0\n".print;
@@ -204,13 +204,13 @@ Section Public
};
};
};
- */
-
-
+ */
+
+
(
- (! PROFIL.mode_recursive) && {loop_invariant = NULL} &&
+ (! PROFIL.mode_recursive) && {loop_invariant = NULL} &&
{last_seq != NULL} && {last_seq.last_write != NULL}
- ).if {
+ ).if {
/*
(bug).if {
"1\n".print;
@@ -231,77 +231,77 @@ Section Public
};
(
( // Constant propagation.
- val.is_constant
- ) ||
+ val.is_constant
+ ) ||
{ // Local propagation.
(l != NULL) && {
(
- (l.last_seq != NULL) && {l.last_seq.last_write != NULL} &&
- {l.last_seq.last_seq_index < last_seq.last_seq_index} &&
- {last_seq.last_seq_call_local_and_loop = seq_call_local_and_loop}
+ (l.last_seq != NULL) && {l.last_seq.last_write != NULL} &&
+ {l.last_seq.last_seq_index < last_seq.last_seq_index} &&
+ {last_seq.last_seq_call_local_and_loop = seq_call_local_and_loop}
) || {l.require_count <= 1} || {l.style = ' '}
}
} ||
{ // Global propagation.
(g != NULL) && {g.style = '-'} && {
- (
- (g.last_write != NULL) && {g.last_seq_index < last_seq.last_seq_index} &&
- {last_seq.last_seq_call_and_loop = seq_call_and_loop} &&
+ (
+ (g.last_write != NULL) && {g.last_seq_index < last_seq.last_seq_index} &&
+ {last_seq.last_seq_call_and_loop = seq_call_and_loop} &&
{is_seq_list (g.last_list_current)}
) || {g.require_count = 1}
}
}
- ).if {
+ ).if {
result := val.my_copy;
}.elseif {
// Propagation step by step.
(last_seq.last_seq_or_and = seq_or_and) &&
{ensure_count = 1} &&
- {list_current.index > list_current.lower} &&
- {list_current.item (list_current.index - 1) = last_seq.last_write}
- } then {
+ {list_current.index > list_current.lower} &&
+ {list_current.item (list_current.index - 1) = last_seq.last_write}
+ } then {
unwrite (last_seq.last_write);
last_seq.set_last_write NULL;
- list_current.put NOP to (list_current.index - 1);
+ list_current.put NOP to (list_current.index - 1);
result := val;
};
- };
+ };
};
result
);
-
+
- set_type_list t:TYPES <-
(
type_list := t;
);
-
+
//
//
//
-
+
- is_local:BOOLEAN <- TRUE;
-
+
//
// Creation.
//
-
- - create p:POSITION name n:STRING_CONSTANT
+
+ - create p:POSITION name n:STRING_CONSTANT
style c:CHARACTER type t:TYPE_FULL result r:BOOLEAN :SELF<-
( + result:SELF;
- result := clone;
+ result := clone;
result.make p name n style c type t result r;
result
);
-
- - create p:POSITION name n:STRING_CONSTANT
+
+ - create p:POSITION name n:STRING_CONSTANT
style c:CHARACTER type t:TYPE_FULL :SELF<-
( + result:SELF;
- result := clone;
+ result := clone;
result.make p name n style c type t result FALSE;
result
);
-
- - make p:POSITION name n:STRING_CONSTANT
+
+ - make p:POSITION name n:STRING_CONSTANT
style c:CHARACTER type t:TYPE_FULL result r:BOOLEAN <-
( + tmp:TYPES_TMP;
? {p.code != 0};
@@ -310,75 +310,75 @@ Section Public
position := p;
name := n;
is_result := r;
- intern_name := ALIAS_STR.get_intern n;
-
+ intern_name := ALIAS_STR.get_intern n;
+
((t.is_expanded) && {! t.is_expanded_c}).if {
type := t + TYPE_FULL.expanded_ref_bit;
} else {
type := t;
};
style := c;
-
- (is_static).if {
- tmp := TYPES_TMP.new;
- tmp.add (t.raw);
- type_list := tmp.to_types;
+
+ (is_static).if {
+ tmp := TYPES_TMP.new;
+ tmp.add (t.raw);
+ type_list := tmp.to_types;
} else {
type_list := TYPES_TMP.types_empty;
- };
+ };
);
-
+
- my_copy:LOCAL <-
( + result:LOCAL;
-
+
result := LOCAL.create position name name style style type type;
result
);
-
+
//
// Value.
//
- init <-
( + val:EXPR;
- + i:INSTR;
- + int:INTEGER_CST;
-
- val := type.default_value position;
- (ALIAS_STR.is_integer (type.raw.name)).if {
+ + i:INSTR;
+ + int:INTEGER_CST;
+
+ val := type.default_value position;
+ (ALIAS_STR.is_integer (type.raw.name)).if {
int ?= val;
- (int != NULL).if {
+ (int != NULL).if {
int.cast_type type;
- };
+ };
} else {
val := val.check_type type with position;
};
i := write position value val;
- list_current.add_last i;
+ list_current.add_last i;
);
-
+
- set_intern_name n:STRING_CONSTANT <-
(
intern_name := n;
);
-
+
Section VARIABLE
-
- - new_read p:POSITION with r:EXPR :READ <-
+
+ - new_read p:POSITION with r:EXPR :READ <-
[ -? {r = NULL}; ]
- (
+ (
READ_LOCAL.create p with Self
);
-
+
- new_write p:POSITION with r:EXPR value v:EXPR :WRITE <-
[ -? {r = NULL}; ]
( + result:WRITE;
- result := WRITE_LOCAL.create p with v in Self;
- result
+ result := WRITE_LOCAL.create p with v in Self;
+ result
);
-
+
/*
- - new_access r:EXPR :ACCESS <-
+ - new_access r:EXPR :ACCESS <-
(
ACCESS_LOCAL.create Self
);
diff --git a/src/variable/local_seq.li b/src/variable/local_seq.li
index 5901e36..2f0cfa1 100644
--- a/src/variable/local_seq.li
+++ b/src/variable/local_seq.li
@@ -19,54 +19,54 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := LOCAL_SEQ;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Local slot";
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Private
-
+
- list_busy:FAST_ARRAY(LOCAL) := FAST_ARRAY(LOCAL).create_with_capacity 512;
-
+
- list_free:FAST_ARRAY(LOCAL_SEQ) := FAST_ARRAY(LOCAL_SEQ).create_with_capacity 512;
-
+
- clean <-
(
last_write := NULL;
);
-
-Section Public
-
+
+Section Public
+
+ last_write:WRITE;
+ last_seq_index:UINTEGER_32;
+ last_seq_or_and:UINTEGER_32;
- + last_seq_call_and_loop:UINTEGER_32;
+ + last_seq_call_and_loop:UINTEGER_32;
+ last_seq_call_local_and_loop:UINTEGER_32;
-
+
+ last_list_current:LIST;
+ last_index:INTEGER;
-
+
- set_last_write w:WRITE <-
(
last_write := w;
);
-
+
- set_last_index i:INTEGER <-
(
last_index := i;
);
-
+
- new l:LOCAL <-
( + result:LOCAL_SEQ;
-
+
(list_free.is_empty).if {
result := clone;
} else {
@@ -77,7 +77,7 @@ Section Public
list_busy.add_last l;
l.set_last_seq result;
);
-
+
- set_seq w:WRITE <-
(
// Save context
@@ -85,18 +85,18 @@ Section Public
last_seq_index := seq_index;
last_seq_or_and := seq_or_and;
last_seq_call_and_loop := seq_call_and_loop;
- last_seq_call_local_and_loop:= seq_call_local_and_loop;
+ last_seq_call_local_and_loop:= seq_call_local_and_loop;
//
last_list_current := list_current;
- last_index := list_current.index;
+ last_index := list_current.index;
);
-
+
- clear <-
( + l:LOCAL;
-
+
(list_busy.upper).downto (list_busy.lower) do { j:INTEGER;
l := list_busy.item j;
- list_free.add_last (l.last_seq);
+ list_free.add_last (l.last_seq);
l.set_last_seq NULL;
};
list_busy.clear;
diff --git a/src/variable/named.li b/src/variable/named.li
index b6653a4..b7d2127 100644
--- a/src/variable/named.li
+++ b/src/variable/named.li
@@ -19,42 +19,42 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := NAMED;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Parent for all slot";
-
+
Section Inherit
-
+
+ parent_itm_object:Expanded ITM_OBJECT;
-
+
Section Public
//
// Data.
//
- + style:CHARACTER; // '+': Clonable,
+ + style:CHARACTER; // '+': Clonable,
// '-': Shared.
// ' ': Argument
// 'T': Temporary
// 'C': Cast
-
+
+ name:STRING_CONSTANT;
- set_style s:CHARACTER <-
(
style := s;
);
-
+
//
// Hashable.
//
-
+
- hash_code: INTEGER <- name.hash_code;
diff --git a/src/variable/section_.li b/src/variable/section_.li
index 4d79f5d..53158f4 100644
--- a/src/variable/section_.li
+++ b/src/variable/section_.li
@@ -19,32 +19,32 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SECTION_;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Test Section protection";
-
+
Section Inherit
-
+
- parent_any:ANY := ANY;
-
+
Section Public
+ name:STRING_CONSTANT;
-
+
+ type_list:FAST_ARRAY(ITM_TYPE_MONO);
-
+
//
// Creation.
- //
+ //
- get_name n:STRING_CONSTANT :SECTION_ <-
( + result:SECTION_;
-
+
result := bucket_name.fast_reference_at n;
(result = NULL).if {
result := clone;
@@ -53,101 +53,101 @@ Section Public
};
result
);
-
+
- get_type_list l:FAST_ARRAY(ITM_TYPE_MONO) :SECTION_ <-
( + result:SECTION_;
-
+
result := bucket_list.fast_reference_at l;
(result = NULL).if {
result := clone;
result.make NULL list l;
bucket_list.fast_put result to l;
};
- result
+ result
);
-
+
//
// Consultation
//
-
+
- is_mapping:BOOLEAN <- name = ALIAS_STR.section_mapping;
-
+
- is_private:BOOLEAN <- name = ALIAS_STR.section_private;
-
+
- is_public:BOOLEAN <- name = ALIAS_STR.section_public;
-
+
- is_header:BOOLEAN <- name = ALIAS_STR.section_header;
-
+
- is_inherit:BOOLEAN <- name = ALIAS_STR.section_inherit;
-
+
- is_insert:BOOLEAN <- name = ALIAS_STR.section_insert;
-
+
- is_inherit_or_insert:BOOLEAN <- (is_inherit) || {is_insert};
-
+
- is_interrupt:BOOLEAN <- name = ALIAS_STR.section_interrupt;
- is_directory:BOOLEAN <- name = ALIAS_STR.section_directory;
-
+
- is_external:BOOLEAN <- name = ALIAS_STR.section_external;
-
+
- is_private_style:BOOLEAN <-
(
? {! is_header};
(! is_public) && {type_list = NULL}
);
-
+
//
// Display.
//
-
+
- append_in buf:STRING <-
- (
+ (
(name != NULL).if {
buf.append name;
} else {
(type_list.lower).to (type_list.upper - 1) do { j:INTEGER;
type_list.item j.append_in buf;
buf.add_last ',';
- buf.add_last ' ';
- };
+ buf.add_last ' ';
+ };
type_list.last.append_in buf;
};
);
-
+
//
// Access test.
//
-
+
- access me:TYPE with client:TYPE :BOOLEAN <-
( + result:BOOLEAN;
+ j:INTEGER;
+ ts:ITM_TYPE_SIMPLE;
? {! is_header};
-
+
((me = client) || {is_public} || {is_external}).if {
result := TRUE;
}.elseif {is_directory} then {
string_tmp.copy (me.prototype.filename);
j := string_tmp.last_index_of '/';
- string_tmp.keep_head j;
+ string_tmp.keep_head j;
result := client.prototype.filename.has_prefix string_tmp;
}.elseif {type_list != NULL} then {
j := type_list.lower;
{(j <= type_list.upper) && {! result}}.while_do {
ts ?= type_list.item j;
- result := client.is_sub_type_with_name (ts.name);
+ result := client.is_sub_type_with_name (ts.name);
j := j + 1;
};
};
result
);
-
+
Section Public
-
+
- hash_code:INTEGER <-
( + result:INTEGER;
-
- (name != NULL).if {
+
+ (name != NULL).if {
result := name.hash_code;
} else {
result := type_list.hash_code;
@@ -156,18 +156,17 @@ Section Public
);
Section SECTION_
-
+
// BSBS: Tu devrais créer deux sous-proto section_name, section_list.
-
- - bucket_name:HASHED_DICTIONARY(SECTION_,STRING_CONSTANT) :=
+
+ - bucket_name:HASHED_DICTIONARY(SECTION_,STRING_CONSTANT) :=
HASHED_DICTIONARY(SECTION_,STRING_CONSTANT).create;
-
- - bucket_list:HASHED_DICTIONARY(SECTION_,FAST_ARRAY(ITM_TYPE_MONO)) :=
+
+ - bucket_list:HASHED_DICTIONARY(SECTION_,FAST_ARRAY(ITM_TYPE_MONO)) :=
HASHED_DICTIONARY(SECTION_,FAST_ARRAY(ITM_TYPE_MONO)).create;
-
+
- make n:STRING_CONSTANT list t:FAST_ARRAY(ITM_TYPE_MONO) <-
(
name := n;
type_list := t;
);
-
\ No newline at end of file
diff --git a/src/variable/slot.li b/src/variable/slot.li
index cdcb201..5421852 100644
--- a/src/variable/slot.li
+++ b/src/variable/slot.li
@@ -167,7 +167,7 @@ Section Public
tm ?= result_type;
(tm != NULL).if {
slot_data_list := FAST_ARRAY(SLOT_DATA).create_with_capacity (tm.count-1);
- (tm.lower).to (tm.upper-1) do { k:INTEGER;
+ (tm.lower).to (tm.upper-1) do { k:INTEGER;
typ := tm.item k.to_run_for receiver_type;
slot_data_list.add_last (
SLOT_DATA.create common_slot type_full typ
diff --git a/src/variable/slot_code.li b/src/variable/slot_code.li
index adaee60..9c5b9be 100644
--- a/src/variable/slot_code.li
+++ b/src/variable/slot_code.li
@@ -19,42 +19,42 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SLOT_CODE;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Slot with method";
-
+
Section Inherit
-
+
+ parent_slot:SLOT := SLOT;
-
+
Section Public
-
+
- common_slot:SLOT <- parent_slot;
+ index:INTEGER;
-
+
//
// Static and Dynamic profil.
//
-
+
+ value:ITM_CODE;
-
+
//
// Dynamic profil.
//
+ profil:FAST_ARRAY(PROFIL_SLOT);
-
+
- get_profil args:FAST_ARRAY(EXPR) self type_self:TYPE_FULL :(PROFIL, FAST_ARRAY(WRITE)) <-
[
-? {type_self != NULL};
]
- ( + result:PROFIL_SLOT;
+ ( + result:PROFIL_SLOT;
+ res_lst:FAST_ARRAY(WRITE);
+ pro:PROFIL_SLOT;
+ j,i:INTEGER;
@@ -64,10 +64,10 @@ Section Public
+ typ_list:TYPES_TMP;
+ pro_list:FAST_ARRAY(PROFIL_SLOT);
+ is_new:BOOLEAN;
-
+
(args = NULL).if {
// For auto-load external section.
- result := PROFIL_SLOT.clone;
+ result := PROFIL_SLOT.clone;
profil.add_last result;
is_new := TRUE;
} else {
@@ -91,7 +91,7 @@ Section Public
};
j := j + 1;
};
-
+
(typ_block != NULL).if {
pro_list := typ_block.profil_list;
i := pro_list.lower;
@@ -106,41 +106,41 @@ Section Public
};
i := i + 1;
};
-
+
(result = NULL).if {
- result := PROFIL_SLOT.clone;
+ result := PROFIL_SLOT.clone;
result.set_context_sensitive;
typ_block.profil_list.add_last result;
- is_new := TRUE;
+ is_new := TRUE;
};
- } else {
+ } else {
// Select classic Profil (no block).
(id_section.is_external).if {
result := profil.first;
} else {
- j := profil.lower;
+ j := profil.lower;
{(j <= profil.upper) && {result = NULL}}.while_do {
- pro := profil.item j;
+ pro := profil.item j;
((pro.type_self = NULL) || {pro.type_self == type_self}).if {
- result := pro;
- i := args.lower + 1;
+ result := pro;
+ i := args.lower + 1;
{(i <= args.upper) && {result != NULL}}.while_do {
- loc := pro.argument_list.item i;
+ loc := pro.argument_list.item i;
(
- (loc != NULL) && {loc.require_first != NULL} &&
+ (loc != NULL) && {loc.require_first != NULL} &&
{args.item i.static_type != loc.require_first.value.static_type} &&
{loc.type.raw != type_boolean}
- ).if {
- result := NULL;
+ ).if {
+ result := NULL;
};
- i := i + 1;
- };
+ i := i + 1;
+ };
};
j := j + 1;
};
};
- (result = NULL).if {
- result := PROFIL_SLOT.clone;
+ (result = NULL).if {
+ result := PROFIL_SLOT.clone;
profil.add_last result;
((id_section.is_external) && {profil.count > 1}).if {
semantic_error (position,"Polymorphic External slot is not possible.");
@@ -149,8 +149,8 @@ Section Public
};
};
};
- (is_new).if {
- res_lst := result.make Self with (type_self, args) verify (profil.count = 1);
+ (is_new).if {
+ res_lst := result.make Self with (type_self, args) verify (profil.count = 1);
} else {
res_lst := result.write_argument args;
};
@@ -160,32 +160,32 @@ Section Public
//
// Constructeur.
//
-
+
- create base:SLOT with val:ITM_CODE :SLOT_CODE <-
( + result:SELF;
result := clone;
result.make base with val;
result
);
-
+
- make base:SLOT with val:ITM_CODE <-
- (
+ (
parent_slot := base;
value := val;
- profil := FAST_ARRAY(PROFIL_SLOT).create_with_capacity 1;
+ profil := FAST_ARRAY(PROFIL_SLOT).create_with_capacity 1;
);
-
+
//
// Execute.
//
-
- + last_type_contract:TYPE;
+
+ + last_type_contract:TYPE;
+ is_require:BOOLEAN;
-
+
- previous_contract:ITM_LIST <-
( + slot:ITM_SLOT;
+ contract:ITM_LIST;
-
+
(is_require).if {
slot := last_type_contract.search_require name;
} else {
@@ -198,17 +198,17 @@ Section Public
contract := slot.ensure;
};
last_type_contract := last_type_contract.last_type_contract;
- };
+ };
contract
);
-
+
- create_code is_first:BOOLEAN <-
( + contract:ITM_LIST;
- + slot:ITM_SLOT;
+ + slot:ITM_SLOT;
+ result:EXPR;
+ mul:EXPR_MULTIPLE;
+ nb_result_list:INTEGER;
-
+
verify := is_first;
// Require
is_require := TRUE;
@@ -222,15 +222,15 @@ Section Public
};
contract := slot.require;
last_type_contract := receiver_type.last_type_contract;
- };
+ };
};
- (contract != NULL).if {
+ (contract != NULL).if {
contract.to_run_expr;
};
-
+
// Body.
result := value.to_run_expr;
- (result.static_type.raw != TYPE_VOID).if {
+ (result.static_type.raw != TYPE_VOID).if {
mul ?= result;
(mul != NULL).if {
nb_result_list := mul.count;
@@ -253,9 +253,9 @@ Section Public
}.elseif {nb_result_list > 1} then {
(mul.lower).to (mul.upper) do { j:INTEGER;
put_result (mul.item j) in (profil_slot.result_list.item j);
- };
+ };
};
-
+
// Ensure
is_require := FALSE;
contract := ensure;
@@ -268,9 +268,9 @@ Section Public
};
contract := slot.ensure;
last_type_contract := receiver_type.last_type_contract;
- };
+ };
};
- (contract != NULL).if {
+ (contract != NULL).if {
contract.to_run_expr;
};
// Result.
@@ -283,38 +283,38 @@ Section Public
EXTERNAL_C.create position text "__END_INTERRUPT__" access NULL
persistant TRUE type (TYPE_VOID.default)
);
- };
+ };
);
-
+
- remove_profil prof:PROFIL_SLOT <-
( + idx:INTEGER;
-
+
idx := profil.fast_first_index_of prof;
- (idx <= profil.upper).if { // Else, This profil is in BLOCK
+ (idx <= profil.upper).if { // Else, This profil is in BLOCK
profil.remove idx;
};
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
buffer.append name;
- (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
+ (argument_list.lower).to (argument_list.upper) do { j:INTEGER;
buffer.add_last ' ';
argument_list.item j.display buffer;
- };
+ };
buffer.add_last ' ';
buffer.add_last ':';
- type.display buffer;
- );
-
+ type.display buffer;
+ );
+
- display_all <-
( + prof:PROFIL;
-
- string_tmp.clear;
+
+ string_tmp.clear;
(profil != NULL).if {
(profil.upper).downto (profil.lower) do { k:INTEGER;
prof := profil.item k;
@@ -323,14 +323,13 @@ Section Public
};
string_tmp.print;
);
-
+
Section Private
-
+
- put_result e:EXPR in v:LOCAL <-
( + val:EXPR;
+ wrt:WRITE;
val := e.check_type (v.type) with (v.position);
wrt := v.write position value val;
- list_current.add_last wrt;
+ list_current.add_last wrt;
);
-
\ No newline at end of file
diff --git a/src/variable/slot_data.li b/src/variable/slot_data.li
index 9416d66..14ee2c4 100644
--- a/src/variable/slot_data.li
+++ b/src/variable/slot_data.li
@@ -19,28 +19,28 @@
// http://isaacproject.u-strasbg.fr/ //
///////////////////////////////////////////////////////////////////////////////
Section Header
-
+
+ name := SLOT_DATA;
- copyright := "2003-2007 Benoit Sonntag";
-
+
- author := "Sonntag Benoit (bsonntag at loria.fr)";
- comment := "Slot with data style";
-
+
Section Inherit
-
+
+ parent_variable:Expanded VARIABLE;
- + parent_slot:SLOT := SLOT;
-
+ + parent_slot:SLOT := SLOT;
+
Section Public
-
+
// BUG COMPILO 0.11
-
- - id_section:SECTION_ <-
+
+ - id_section:SECTION_ <-
( + result:SECTION_;
-
+
(parent_slot != NULL).if {
result := parent_slot.id_section;
} else {
@@ -51,7 +51,7 @@ Section Public
- receiver_type:TYPE <-
( + result:TYPE;
-
+
(parent_slot != NULL).if {
result := parent_slot.receiver_type;
} else {
@@ -59,21 +59,21 @@ Section Public
};
result
);
-
+
//
-
+
- common_slot:SLOT <- parent_slot;
-
+
//
// Sequence optimizer
//
-
+
+ last_write:WRITE;
+ last_seq_index:UINTEGER_32;
- + last_seq_or_and:UINTEGER_32;
+ + last_seq_or_and:UINTEGER_32;
+ last_seq_call_and_loop:UINTEGER_32;
+ last_seq_call_local_and_loop:UINTEGER_32;
-
+
+ last_list_current:LIST;
+ last_index:INTEGER;
@@ -84,47 +84,47 @@ Section Public
{loop_seq_call_and_loop = seq_call_and_loop} &&
{last_seq_index <= loop_seq_index}
);
-
+
- reset_last_write w:WRITE <-
- (
+ (
(last_write = w).if {
last_write := NULL;
};
);
-
+
- set_read <-
(
last_index := -1;
);
-
+
- get_last_index:INTEGER <- last_index;
-
+
- set_write w:WRITE <-
- (
+ (
/* A FAIRE
(
(! PROFIL.mode_recursive) &&
{style = '-'} &&
- {last_write != NULL} &&
+ {last_write != NULL} &&
{last_index < list_current.index} &&
- {last_sequence = sequence_global}
- ).if {
+ {last_sequence = sequence_global}
+ ).if {
? {list_current.item last_index = last_write};
list_current.put (last_write.value) to last_index;
- unwrite last_write;
+ unwrite last_write;
new_execute_pass;
- };
+ };
*/
last_write := w;
last_seq_index := seq_index;
- last_seq_or_and := seq_or_and;
+ last_seq_or_and := seq_or_and;
last_seq_call_and_loop := seq_call_and_loop;
last_seq_call_local_and_loop:= seq_call_local_and_loop;
//
last_list_current := list_current;
last_index := list_current.index;
);
-
+
- get_last_value rec:EXPR :EXPR <-
( + result:EXPR;
+ val:EXPR;
@@ -137,9 +137,9 @@ Section Public
+ my_require_count:INTEGER;
+ pb:PROFIL_BLOCK;
+ i:INSTR;
-
+
((! PROFIL.mode_recursive) && {loop_invariant = NULL} && {last_write != NULL}).if {
-
+
my_require_count := require_count;
(rec != NULL).if {
// Block exception.
@@ -149,7 +149,7 @@ Section Public
l := rd_loc.local;
wrt_slot ?= require_first;
rd_loc ?= wrt_slot.receiver;
- (rd_loc.local = l).if {
+ (rd_loc.local = l).if {
my_require_count := 1;
} else {
my_require_count := 0;
@@ -157,23 +157,23 @@ Section Public
(require_list.lower).to (require_list.upper) do { j:INTEGER;
wrt_slot ?= require_list.item j;
rd_loc ?= wrt_slot.receiver;
- (rd_loc.local = l).if {
+ (rd_loc.local = l).if {
my_require_count := my_require_count + 1;
};
};
};
};
-
+
(
(
- (last_seq_call_and_loop = seq_call_and_loop) &&
+ (last_seq_call_and_loop = seq_call_and_loop) &&
{is_seq_list last_list_current}
) || {my_require_count = 1}
).if {
// Receiver test.
(rec = NULL).if {
- is_rec_ok := TRUE;
- }.elseif {rec.is_constant} then {
+ is_rec_ok := TRUE;
+ }.elseif {rec.is_constant} then {
wrt_slot ?= last_write;
is_rec_ok := rec ~= wrt_slot.receiver;
} else {
@@ -184,25 +184,25 @@ Section Public
wrt_slot ?= last_write;
rd ?= wrt_slot.receiver;
is_rec_ok := (rd != NULL) && {
- (
+ (
{l = rd.variable} && {is_seq_list last_list_current} && {
(
- (l.last_seq != NULL) && {l.last_seq.last_write != NULL} &&
+ (l.last_seq != NULL) && {l.last_seq.last_write != NULL} &&
{l.last_seq.last_seq_index < last_seq_index} &&
{last_seq_call_local_and_loop = seq_call_local_and_loop}
) || {l.require_count <= 1} || {l.style = ' '}
}
- ) ||
+ ) ||
{
{g = rd.variable} && {g.style = '-'} && {
(
(g.last_write != NULL) && {g.last_seq_index < last_seq_index} &&
- {last_seq_call_and_loop = seq_call_and_loop} &&
+ {last_seq_call_and_loop = seq_call_and_loop} &&
{is_seq_list (g.last_list_current)}
) || {g.require_count = 1}
}
}
- };
+ };
};
};
(is_rec_ok).if {
@@ -210,7 +210,7 @@ Section Public
rd ?= val;
(rd = NULL).if {
l := NULL;
- g := NULL;
+ g := NULL;
} else {
l ?= rd.variable;
g ?= rd.variable;
@@ -218,11 +218,11 @@ Section Public
(
( // Constant propagation.
val.is_constant
- ) ||
- { // Local propagation.
- (l != NULL) && {is_seq_list last_list_current} && {
+ ) ||
+ { // Local propagation.
+ (l != NULL) && {is_seq_list last_list_current} && {
(
- (l.last_seq != NULL) && {l.last_seq.last_write != NULL} &&
+ (l.last_seq != NULL) && {l.last_seq.last_write != NULL} &&
{l.last_seq.last_seq_index < last_seq_index} &&
{last_seq_call_local_and_loop = seq_call_local_and_loop}
) || {l.require_count <= 1} || {l.style = ' '}
@@ -231,24 +231,24 @@ Section Public
{ // Global propagation.
(g != NULL) && {g.style = '-'} && {
(
- (g.last_write != NULL) && {g.last_seq_index < last_seq_index} &&
+ (g.last_write != NULL) && {g.last_seq_index < last_seq_index} &&
{last_seq_call_and_loop = seq_call_and_loop} &&
{is_seq_list (g.last_list_current)}
) || {g.require_count = 1}
}
}
- ).if {
+ ).if {
(rec != NULL).if {
rec.remove;
- };
+ };
result := val.my_copy;
}.elseif {
// Propagation step by step.
(last_seq_or_and = seq_or_and) &&
{ensure_count = 1} &&
- {list_current.index > list_current.lower} &&
- {list_current.item (list_current.index - 1) = last_write}
- } then {
+ {list_current.index > list_current.lower} &&
+ {list_current.item (list_current.index - 1) = last_write}
+ } then {
(rec != NULL).if {
rec.remove;
wrt_slot ?= last_write;
@@ -258,38 +258,38 @@ Section Public
list_current.put NOP to (list_current.index - 1);
result := val;
}.elseif {
- (rec != NULL) && {is_seq_list last_list_current} &&
+ (rec != NULL) && {is_seq_list last_list_current} &&
{my_require_count = 1} && {ensure_count = 1} &&
{last_index.in_range (last_list_current.lower) to (last_list_current.upper)} &&
- {last_list_current.item last_index = last_write}
+ {last_list_current.item last_index = last_write}
} then {
- // Local conversion.
+ // Local conversion.
l := type.get_temporary position;
i := l.write (last_write.position) value val;
last_list_current.put i to last_index;
result := l.read (rec.position);
- //
+ //
rec.remove;
wrt_slot ?= last_write;
wrt_slot.receiver.remove;
- unwrite last_write;
+ unwrite last_write;
};
};
- };
+ };
};
result
);
-
+
//
// Constructeur.
//
-
+
- create b:SLOT type_full t:TYPE_FULL :SELF <-
- (
+ (
create (b.position) name (b.name) style (b.style) base b type t
);
-
- - create pos:POSITION name n:STRING_CONSTANT
+
+ - create pos:POSITION name n:STRING_CONSTANT
style s:CHARACTER base b:SLOT type t:TYPE_FULL :SELF <-
// BSBS: N'est plus utilise' !!!
( + result:SELF;
@@ -305,52 +305,52 @@ Section Public
position := pos;
name := n;
style := s;
- intern_name := ALIAS_STR.get_intern name;
- //
- type := t;
+ intern_name := ALIAS_STR.get_intern name;
+ //
+ type := t;
(is_static).if {
- tmp := TYPES_TMP.new;
+ tmp := TYPES_TMP.new;
tmp.add (type.raw);
type_list := tmp.to_types;
} else {
type_list := TYPES_TMP.types_empty;
};
- ((type.raw.is_block) && {name != ALIAS_STR.slot_id} && {name != ALIAS_STR.slot_self}).if {
+ ((type.raw.is_block) && {name != ALIAS_STR.slot_id} && {name != ALIAS_STR.slot_self}).if {
list_variable_block.add_last Self;
};
- ? {type != NULL};
+ ? {type != NULL};
);
-
+
//
// Context
- //
-
+ //
+
+ value_init:LIST;
-
+
- init <-
( + val,rec:EXPR;
- + wrt:WRITE;
+ + wrt:WRITE;
+ old_list:LIST;
+ rd:ITM_READ_ARG1;
+ old_profil_current:PROFIL;
+ old_profil_slot:PROFIL_SLOT;
- /*
+ /*
string_tmp.copy "init : ";
- string_tmp.append name;
+ string_tmp.append name;
warning_error (position,string_tmp);
- */
+ */
((value_init = NULL) && {(affect != '<') || {Self = slot_id}}).if {
- // Context.
+ // Context.
old_list := list_current;
old_profil_current := profil_current;
old_profil_slot := profil_slot;
profil_current := profil_slot := NULL;
- value_init := list_current := LIST.create position;
-
+ value_init := list_current := LIST.create position;
+
(Self = slot_id).if {
val := PROTOTYPE_CST.create position type type;
- } else {
- // Code.
+ } else {
+ // Code.
(value != NULL).if {
rd ?= value;
((rd != NULL) && {rd.arg = NULL}).if {
@@ -362,37 +362,37 @@ Section Public
} else {
val := type.default_value position;
};
- val := val.check_type type with position;
- };
+ val := val.check_type type with position;
+ };
(style = '+').if {
rec := PROTOTYPE_CST.create position type (receiver_type.default);
} else {
rec := NULL;
};
-
+
(debug_level_option != 0).if {
list_current.add_last (
- PUSH.create position context context_main first FALSE
+ PUSH.create position context context_main first FALSE
);
};
-
+
wrt := write position with rec value val;
(is_zero val).if {
wrt.set_quiet_generation;
- };
- list_current.add_last wrt;
+ };
+ list_current.add_last wrt;
list_current.add_last (PROTOTYPE_CST.create position type (TYPE_VOID.default)); // BSBS:Alias
-
+
list_current := old_list;
profil_current := old_profil_current;
profil_slot := old_profil_slot;
};
);
-
+
//
// Execute.
//
-
+
- execute <-
( + lst:FAST_ARRAY(SLOT);
+ slot:SLOT_DATA;
@@ -401,20 +401,20 @@ Section Public
+ old_list_current:LIST;
//+ old_profil_current:PROFIL_SLOT;
+ insert_index:INTEGER;
-
+
(value_init != NULL).if {
val := value_init;
- value_init := NULL;
+ value_init := NULL;
insert_index := list_main.index;
list_main.add val to insert_index;
-
- (type.is_expanded).if {
+
+ (type.is_expanded).if {
lst := type.slot_run;
(lst != NULL).if {
(lst.lower).to (lst.upper) do { j:INTEGER;
s := lst.item j;
(s.style = '+').if {
- slot := s.slot_data_intern;
+ slot := s.slot_data_intern;
(slot != NULL).if {
slot.execute;
};
@@ -424,57 +424,57 @@ Section Public
};
};
};
- };
+ };
};
-
+
old_list_current := list_current;
//old_profil_current := profil_current;
list_current := NULL;
//profil_current := NULL;
-
+
val.execute;
list_main.inc_index;
-
+
list_current := old_list_current;
- //profil_current := old_profil_current;
+ //profil_current := old_profil_current;
};
- );
+ );
//
// Genere
//
-
+
- genere buffer:STRING <-
- (
+ (
type.genere_declaration buffer;
buffer.add_last ' ';
type.genere_star_declaration buffer;
- buffer.append intern_name;
+ buffer.append intern_name;
buffer.append ";\n";
);
-
+
//
// Display.
//
-
+
- display buffer:STRING <-
(
- buffer.append intern_name;
+ buffer.append intern_name;
buffer.add_last ' ';
buffer.add_last ':';
- type.display buffer;
- );
-
+ type.display buffer;
+ );
+
- display_all <-
- (
+ (
string_tmp.clear;
display string_tmp;
string_tmp.print;
);
-
+
Section VARIABLE
-
- - new_read p:POSITION with r:EXPR :READ <-
+
+ - new_read p:POSITION with r:EXPR :READ <-
( + result:READ;
(style = '-').if {
? {r = NULL};
@@ -485,7 +485,7 @@ Section VARIABLE
};
result
);
-
+
- new_write p:POSITION with r:EXPR value v:EXPR :WRITE <-
( + result:WRITE;
(style = '-').if {
@@ -497,11 +497,11 @@ Section VARIABLE
};
result
);
-
+
/*
- - new_access r:EXPR :ACCESS <-
+ - new_access r:EXPR :ACCESS <-
( + result:ACCESS;
-
+
(style = '-').if {
result := ACCESS_GLOBAL.create Self;
} else {
diff --git a/src/variable/variable.li b/src/variable/variable.li
index 41f05d4..3acc94b 100644
--- a/src/variable/variable.li
+++ b/src/variable/variable.li
@@ -124,18 +124,18 @@ Section Public
((typ.subtype_list = NULL) || {typ.subtype_list.count > type_list.count}) ||
{typ = type_block}
}*/
- }).if {
+ }).if {
level_type := level_pass;
tmp_type := TYPES_TMP.new;
- (require_first != NULL).if {
+ (require_first != NULL).if {
- require_first.get_type tmp_type;
+ require_first.get_type tmp_type;
(require_list != NULL).if {
- (require_list.lower).to (require_list.upper) do { j:INTEGER;
+ (require_list.lower).to (require_list.upper) do { j:INTEGER;
require_list.item j.get_type tmp_type;
};
};
- };
+ };
type_list := tmp_type.update type_list;
};
};
@@ -204,9 +204,9 @@ Section Public
tmp_type := TYPES_TMP.new;
(type_list != NULL).if {
tmp_type.union type_list;
- };
+ };
e.value.get_type tmp_type;
- type_list := tmp_type.update type_list;
+ type_list := tmp_type.update type_list;
};
e.set_create;
@@ -253,7 +253,7 @@ Section Public
intern_name.print; '\n'.print;
/*
e.to_pointer.print; ' '.print;
-
+
e.debug_display;
"\n--------\n".print;
require_first.debug_display;
--
Lisaac compiler
More information about the Lisaac-commits
mailing list