mirror of
https://github.com/ton-blockchain/ton
synced 2025-02-12 19:22:37 +00:00
- split stdlib.tolk into multiple files (tolk-stdlib/ folder) (the "core" common.tolk is auto-imported, the rest are needed to be explicitly imported like "@stdlib/tvm-dicts.tolk") - all functions were renamed to long and clear names - new naming is camelCase
81 lines
3 KiB
C++
81 lines
3 KiB
C++
/*
|
|
This file is part of TON Blockchain source code.
|
|
|
|
TON Blockchain is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
TON Blockchain is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with TON Blockchain. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
In addition, as a special exception, the copyright holders give permission
|
|
to link the code of portions of this program with the OpenSSL library.
|
|
You must obey the GNU General Public License in all respects for all
|
|
of the code used other than OpenSSL. If you modify file(s) with this
|
|
exception, you may extend this exception to your version of the file(s),
|
|
but you are not obligated to do so. If you do not wish to do so, delete this
|
|
exception statement from your version. If you delete this exception statement
|
|
from all source files in the program, then also delete it here.
|
|
*/
|
|
#include "tolk.h"
|
|
#include "pipeline.h"
|
|
#include "compiler-state.h"
|
|
#include "lexer.h"
|
|
#include "ast.h"
|
|
|
|
namespace tolk {
|
|
|
|
|
|
void on_assertion_failed(const char *description, const char *file_name, int line_number) {
|
|
std::string message = static_cast<std::string>("Assertion failed at ") + file_name + ":" + std::to_string(line_number) + ": " + description;
|
|
#ifdef TOLK_DEBUG
|
|
#ifdef __arm64__
|
|
// when developing, it's handy when the debugger stops on assertion failure (stacktraces and watches are available)
|
|
std::cerr << message << std::endl;
|
|
__builtin_debugtrap();
|
|
#endif
|
|
#endif
|
|
throw Fatal(std::move(message));
|
|
}
|
|
|
|
int tolk_proceed(const std::string &entrypoint_filename) {
|
|
define_builtins();
|
|
lexer_init();
|
|
|
|
// on any error, an exception is thrown, and the message is printed out below
|
|
// (currently, only a single error can be printed)
|
|
try {
|
|
AllSrcFiles all_files = pipeline_discover_and_parse_sources("@stdlib/common.tolk", entrypoint_filename);
|
|
|
|
pipeline_register_global_symbols(all_files);
|
|
pipeline_convert_ast_to_legacy_Expr_Op(all_files);
|
|
|
|
pipeline_find_unused_symbols();
|
|
pipeline_generate_fif_output_to_std_cout(all_files);
|
|
|
|
return 0;
|
|
} catch (Fatal& fatal) {
|
|
std::cerr << "fatal: " << fatal << std::endl;
|
|
return 2;
|
|
} catch (ParseError& error) {
|
|
std::cerr << error << std::endl;
|
|
return 2;
|
|
} catch (UnifyError& unif_err) {
|
|
std::cerr << "fatal: ";
|
|
unif_err.print_message(std::cerr);
|
|
std::cerr << std::endl;
|
|
return 2;
|
|
} catch (UnexpectedASTNodeType& error) {
|
|
std::cerr << "fatal: " << error.what() << std::endl;
|
|
std::cerr << "It's a compiler bug, please report to developers" << std::endl;
|
|
return 2;
|
|
}
|
|
}
|
|
|
|
} // namespace tolk
|