Bash++
Bash++ compiler internal documentation
bpp.h
Go to the documentation of this file.
1
7#pragma once
8
9#include <string>
10#include <sstream>
11#include <vector>
12#include <unordered_map>
13#include <list>
14#include <memory>
15
16#include "replace_all.h"
17
18#include <include/EntityMap.h>
19#include <include/BashVersion.h>
20#include <AST/Nodes/Program.h>
21
22namespace bpp {
23
30
36
43
51struct diagnostic {
53 std::string message;
54 uint32_t start_line;
55 uint32_t start_column;
56 uint32_t end_line;
57 uint32_t end_column;
58};
59
60// Forward declarations
61
62class bpp_entity;
63class bpp_code_entity;
64class bpp_string;
65class bpp_method;
67class bpp_class;
68class bpp_object;
69class bpp_datamember;
70class bpp_program;
71
72// Statement types
75class bash_if;
76class bash_if_branch;
77class bash_case;
80class bash_function;
83class bpp_pointer_dereference;
87class bpp_object_address;
88
93inline const std::shared_ptr<bpp_entity> inaccessible_entity = std::make_shared<bpp_entity>();
94
99inline const std::shared_ptr<bpp_datamember> inaccessible_datamember = std::make_shared<bpp_datamember>();
100
105inline const std::shared_ptr<bpp_method> inaccessible_method = std::make_shared<bpp_method>();
106
111static const char bpp_nullptr[] = "0";
112
117inline constexpr const char* protected_keywords[] = {
118 "class", "constructor", "delete", "destructor",
119 "dynamic_cast", "include", "include_once", "local", "method",
120 "new", "nullptr", "primitive", "private",
121 "protected", "public", "super", "this",
122 "typeof", "virtual"
123 };
124
129inline bool is_protected_keyword(const std::string& keyword) {
130 for (const char* protected_keyword : protected_keywords) {
131 if (keyword == protected_keyword) {
132 return true;
133 }
134 }
135 return false;
136}
137
143inline bool is_valid_identifier(const std::string& identifier) {
144 // Verify it's not empty, and not a reserved keyword
145 if (identifier.empty() || is_protected_keyword(identifier)) {
146 return false;
147 }
148
149 // Verify it doesn't contain two consecutive underscores
150 if (identifier.find("__") != std::string::npos) {
151 return false;
152 }
153
154 // Verify it starts with a letter or underscore, and contains only letters, digits, and underscores
155 if (!isalpha(identifier[0]) && identifier[0] != '_') {
156 return false;
157 }
158
159 for (char c : identifier) {
160 if (!isalnum(c) && c != '_') {
161 return false;
162 }
163 }
164
165 // If all checks passed, it's a valid identifier
166 return true;
167}
168
170 std::string file;
171 uint64_t line;
172 uint64_t column;
173
175 SymbolPosition(const std::string& file, uint64_t line, uint64_t column)
176 : file(file), line(line), column(column) {}
177};
178
187 protected:
188 std::string name = "";
193 std::unordered_map<std::string, std::weak_ptr<bpp_class>> classes;
194
199 std::unordered_map<std::string, std::weak_ptr<bpp_object>> objects;
200
207 std::unordered_map<std::string, std::shared_ptr<bpp_object>> local_objects;
208 std::weak_ptr<bpp_class> type;
209 std::weak_ptr<bpp_class> containing_class;
210 std::weak_ptr<bpp_program> containing_program;
211 std::vector<std::weak_ptr<bpp_class>> parents;
212 std::weak_ptr<bpp_method> overridden_method;
214 std::list<bpp::SymbolPosition> references;
215 public:
216 virtual ~bpp_entity() = default;
217 virtual bool add_class(std::shared_ptr<bpp_class> class_);
218 virtual bool add_object(std::shared_ptr<bpp_object> object, bool make_local = false);
219
220 virtual std::shared_ptr<bpp_class> get_class();
221 virtual std::string get_address() const;
222 virtual void set_name(const std::string& name);
223 virtual std::string get_name() const;
224 virtual std::weak_ptr<bpp::bpp_class> get_containing_class();
225 virtual std::weak_ptr<bpp_program> get_containing_program();
226 virtual bool set_containing_class(std::weak_ptr<bpp::bpp_class> containing_class);
227
228 void inherit(std::shared_ptr<bpp_entity> parent);
229 void inherit(std::shared_ptr<bpp_program> program);
230 virtual void inherit(std::shared_ptr<bpp_class> parent);
231
232 void set_definition_position(const std::string& file, uint64_t line, uint64_t column);
233 void add_reference(const std::string& file, uint64_t line, uint64_t column);
234
236 std::list<bpp::SymbolPosition> get_references() const;
237
238 std::unordered_map<std::string, std::shared_ptr<bpp_class>> get_classes() const;
239 std::unordered_map<std::string, std::shared_ptr<bpp_object>> get_objects() const;
240 std::shared_ptr<bpp_class> get_class(const std::string& name);
241 std::shared_ptr<bpp_object> get_object(const std::string& name);
242
243 std::shared_ptr<bpp_class> get_parent() const;
244};
245
264 protected:
265 std::shared_ptr<std::ostream> code = std::make_shared<std::ostringstream>();
266 std::string nextline_buffer = "";
267 std::string postline_buffer = "";
268 bool buffers_flushed = false;
269
276 public:
278
279 virtual void add_code(const std::string& code, bool add_newline = true);
280 virtual void add_code_to_previous_line(const std::string& code);
281 virtual void add_code_to_next_line(const std::string& code);
282
283 bool add_object(std::shared_ptr<bpp_object> object, bool make_local = false) override;
284
285 virtual void flush_nextline_buffer();
286 virtual void flush_postline_buffer();
287 virtual void flush_code_buffers();
288
289 virtual void clear_all_buffers();
290
291 virtual std::string get_code() const;
292 virtual std::string get_pre_code() const;
293 virtual std::string get_post_code() const;
294
295 void set_requires_perfect_forwarding(bool require);
297};
298
361 public:
362 bpp_string();
363
364 void add_code(const std::string& code, bool add_newline = true) override;
365 void add_code_to_previous_line(const std::string& code) override;
366 void add_code_to_next_line(const std::string& code) override;
367
368 std::string get_code() const override;
369 std::string get_pre_code() const override;
370 std::string get_post_code() const override;
371};
372
393 protected:
394 std::string joined_code = "";
396
397 bool perfect_forwarding = false;
398
399 void join();
400 public:
402
403 void add_connective(bool is_and);
404
405 void add_code(const std::string& code, bool add_newline = true) override;
406
407 std::string get_code() const override;
408 std::string get_pre_code() const override;
409 std::string get_post_code() const override;
410
411 void set_perfect_forwarding(bool enable);
412};
413
420 private:
421 std::vector<std::shared_ptr<bpp_method_parameter>> parameters;
423 bool m_is_virtual = false;
424 bool m_is_overridable = false;
425 bool inherited = false;
426 bool add_object_as_parameter(std::shared_ptr<bpp_object> object);
427 std::string last_override; // Name of the latest class to override this virtual method
428 public:
429 bpp_method();
430 explicit bpp_method(const std::string& name);
431 bpp_method(const std::string& name, bool is_virtual);
432
433 virtual bool add_parameter(std::shared_ptr<bpp_method_parameter> parameter);
435 void set_virtual(bool is_virtual);
437 void set_inherited(bool is_inherited);
438 void set_last_override(const std::string& class_name);
439 void set_overridden_method(std::weak_ptr<bpp_method> method);
440 bool add_object(std::shared_ptr<bpp_object> object, bool make_local) override;
441
442 std::vector<std::shared_ptr<bpp_method_parameter>> get_parameters() const;
443 bpp_scope get_scope() const;
444 bool is_virtual() const;
445 bool is_overridable() const;
446 bool is_inherited() const;
447 std::string get_last_override() const;
448
449 void destruct_local_objects(std::shared_ptr<bpp_program> program);
450};
451
458 public:
459 explicit bpp_method_parameter(const std::string& name);
460
461 void set_class(std::shared_ptr<bpp_class>);
462};
463
469class bpp_class : public bpp_entity, public std::enable_shared_from_this<bpp_class> {
470 private:
471 std::vector<std::shared_ptr<bpp_method>> methods;
472 std::vector<std::shared_ptr<bpp_datamember>> datamembers;
474
477 public:
478 bpp_class();
479
480 std::weak_ptr<bpp_class> get_containing_class() override;
481 bool set_containing_class(std::weak_ptr<bpp::bpp_class> containing_class) override;
482
483 std::shared_ptr<bpp_class> get_class() override;
484
485 void set_name(const std::string& name) override;
486 bool add_method(std::shared_ptr<bpp_method> method);
487 bool add_datamember(std::shared_ptr<bpp_datamember> datamember);
488
489 std::vector<std::shared_ptr<bpp_method>> get_methods() const;
490 std::vector<std::shared_ptr<bpp_datamember>> get_datamembers() const;
491
492 std::shared_ptr<bpp_method> get_method(const std::string& name, std::shared_ptr<bpp_entity> context);
493 std::shared_ptr<bpp_method> get_method_UNSAFE(const std::string& name);
494 std::shared_ptr<bpp_datamember> get_datamember(const std::string& name, std::shared_ptr<bpp_entity> context);
495 std::shared_ptr<bpp_datamember> get_datamember_UNSAFE(const std::string& name);
496
498 void inherit(std::shared_ptr<bpp_class> parent) override;
499 std::shared_ptr<bpp::bpp_class> get_parent();
500};
501
507class bpp_object : public bpp_entity {
508 protected:
509 std::string address = "";
510 std::string assignment_value = "";
511 std::string pre_access_code = "";
512 std::string post_access_code = "";
513 bool m_is_pointer = false;
514 std::shared_ptr<bpp::bpp_object> copy_from = nullptr;
515 public:
516 bpp_object();
517 explicit bpp_object(const std::string& name);
518 bpp_object(const std::string& name, bool is_pointer);
519
520 void set_class(std::shared_ptr<bpp_class> object_class);
521 void set_pointer(bool is_pointer);
522 void set_address(const std::string& address);
523 void set_assignment_value(const std::string& assignment_value);
524 void set_pre_access_code(const std::string& pre_access_code);
525 void set_post_access_code(const std::string& post_access_code);
526 void set_nullptr();
527
528 std::string get_address() const override;
529 std::string get_assignment_value() const;
530 std::string get_pre_access_code() const;
531 std::string get_post_access_code() const;
532 std::shared_ptr<bpp::bpp_object> get_copy_from() const;
533
534 bool is_pointer() const;
535};
536
543 private:
544 std::string default_value = "";
546 bool array = false;
547 public:
549
550 void set_default_value(const std::string& default_value);
552 void set_array(bool is_array);
553
554 std::string get_address() const override;
555 std::string get_default_value() const;
556 bpp_scope get_scope() const;
557 bool is_array() const;
558};
559
565class bpp_program : public bpp_code_entity, public std::enable_shared_from_this<bpp_program> {
566 private:
567 std::shared_ptr<bpp_class> primitive_class;
568 uint64_t supershell_counter = 0;
569 uint64_t assignment_counter = 0;
570 uint64_t function_counter = 0;
572 uint64_t typeof_counter = 0;
573 uint64_t object_counter = 0;
574
576
577 std::string main_source_file;
578
579 // To ensure that the bpp_program **owns** its classes
580 // I.e., that those classes don't get destroyed before we're done with them
581 std::unordered_map<std::string, std::shared_ptr<bpp::bpp_class>> owned_classes;
582
583 // Source file -> AST
584 // Used for advanced analysis, e.g. LSP features
585 std::unordered_map<std::string, std::shared_ptr<AST::Program>> source_file_asts;
586
587 // Source file -> EntityMap
588 std::unordered_map<std::string, EntityMap> entity_maps;
589 // s.t. requesting entity_maps["/path/to/file1.bpp"] returns an EntityMap
590 // which outlines for us which container entities are active at each point in the file
591
592 // Source file -> Diagnostics
593 std::unordered_map<std::string, std::vector<bpp::diagnostic>> diagnostics;
594 // Each 'diagnostic' contains a type (error, warning, etc), message, and position in the source file
595
596 // For debug info:
597 std::shared_ptr<std::vector<std::string>> include_paths;
598 public:
599 bpp_program();
600
601 bool set_containing_class(std::weak_ptr<bpp_class> containing_class) override;
602 void set_output_stream(std::shared_ptr<std::ostream> output_stream);
603
604 bool prepare_class(std::shared_ptr<bpp_class> class_);
605 bool add_class(std::shared_ptr<bpp_class> class_) override;
606
607 std::shared_ptr<bpp_class> get_primitive_class() const;
608
609 std::weak_ptr<bpp_program> get_containing_program() override;
610
611 void set_include_paths(std::shared_ptr<std::vector<std::string>> paths);
612 std::shared_ptr<std::vector<std::string>> get_include_paths() const;
613
615 uint64_t get_supershell_counter() const;
616
618 uint64_t get_assignment_counter() const;
619
621 uint64_t get_function_counter() const;
622
624 uint64_t get_dynamic_cast_counter() const;
625
627 uint64_t get_typeof_counter() const;
628
630 uint64_t get_object_counter() const;
631
634
635 void mark_entity(
636 const std::string& file,
637 uint32_t start_line, uint32_t start_column,
638 uint32_t end_line, uint32_t end_column,
639 std::shared_ptr<bpp::bpp_entity> entity
640 );
641
642 std::shared_ptr<bpp::bpp_entity> get_active_entity(
643 const std::string& file,
644 uint32_t line, uint32_t column
645 );
646
647 std::vector<std::string> get_source_files() const;
648 std::string get_main_source_file() const;
649 void set_main_source_file(const std::string& file);
650 void add_source_file(const std::string& file);
651
652 void set_source_file_ast(const std::string& file, std::shared_ptr<AST::Program> ast);
653 std::shared_ptr<AST::Program> get_source_file_ast(const std::string& file) const;
654
655 void add_diagnostic(
656 const std::string& file,
658 const std::string& message,
659 uint32_t start_line, uint32_t start_column,
660 uint32_t end_line, uint32_t end_column
661 );
662
663 std::vector<bpp::diagnostic> get_diagnostics(const std::string& file) const;
664 void clear_diagnostics(const std::string& file);
665};
666
682 private:
683 std::shared_ptr<bpp::bash_while_or_until_condition> condition;
684 public:
686
687 void set_condition(std::shared_ptr<bpp::bash_while_or_until_condition> condition);
688 std::shared_ptr<bpp::bash_while_or_until_condition> get_condition() const;
689
690 std::string get_code() const override;
691 std::string get_pre_code() const override;
692 std::string get_post_code() const override;
693};
694
703 public:
705};
706
725class bash_if : public bpp_string {
726 private:
727 std::vector<std::pair<std::string, std::string>> conditional_branches = {};
728 public:
729 bash_if();
730
731 void new_branch();
732 void add_condition_code(const std::string& condition_code);
733 void add_branch_code(const std::string& branch_code);
734 const std::vector<std::pair<std::string, std::string>>& get_conditional_branches() const;
735};
736
748 private:
749 std::shared_ptr<bpp::bash_if> if_statement;
750 public:
752
753 void set_if_statement(std::shared_ptr<bpp::bash_if> if_statement);
754 std::shared_ptr<bpp::bash_if> get_if_statement() const;
755
756 std::string get_code() const override;
757 std::string get_pre_code() const override;
758 std::string get_post_code() const override;
759};
760
770class bash_case : public bpp_string {
771 private:
772 std::string cases = "";
773 public:
774 bash_case();
775
776 void add_case(const std::string& case_);
777
778 const std::string& get_cases() const;
779};
780
791 private:
792 std::string pattern = "";
793 std::shared_ptr<bpp::bash_case> containing_case;
794 public:
796
797 void set_pattern(const std::string& pattern);
798 void set_containing_case(std::shared_ptr<bpp::bash_case> containing_case);
799
800 const std::string& get_pattern() const;
801 std::shared_ptr<bpp::bash_case> get_containing_case() const;
802};
803
814 private:
815 std::string header_pre_code = "";
816 std::string header_post_code = "";
817 std::string header_code = "";
818 public:
820
821 void set_header_pre_code(const std::string& pre_code);
822 void set_header_post_code(const std::string& post_code);
823 void set_header_code(const std::string& code);
824
825 const std::string& get_header_pre_code() const;
826 const std::string& get_header_post_code() const;
827 const std::string& get_header_code() const;
828};
829
840 public:
842};
843
856 private:
857 std::shared_ptr<bpp::bpp_object> object_to_delete;
858 public:
860
861 void set_object_to_delete(std::shared_ptr<bpp::bpp_object> object);
862 std::shared_ptr<bpp::bpp_object> get_object_to_delete() const;
863};
864
877 private:
878 std::string cast_to;
879 public:
881
882 void set_cast_to(const std::string& cast_to);
883 std::string get_cast_to() const;
884};
885
899 public:
901};
902
911 private:
913 std::shared_ptr<bpp_entity> nonprimitive_object;
915 bool array_assignment = false;
916 bool adding = false;
917 public:
919
920 void set_nonprimitive_assignment(bool is_nonprimitive);
921 void set_nonprimitive_object(std::shared_ptr<bpp_entity> object);
922 void set_lvalue_nonprimitive(bool is_nonprimitive);
923 void set_array_assignment(bool is_array);
924 void set_adding(bool is_adding);
925
926 bool is_nonprimitive_assignment() const;
927 std::shared_ptr<bpp_entity> get_nonprimitive_object() const;
928 bool lvalue_is_nonprimitive() const;
929 bool is_array_assignment() const;
930 bool is_adding() const;
931};
932
941 private:
942 std::string lvalue = "";
943 std::string rvalue = "";
946 std::shared_ptr<bpp_entity> lvalue_object;
947 std::shared_ptr<bpp_entity> rvalue_object;
948 bool adding = false;
949 bool rvalue_array = false;
950 public:
952
953 void set_lvalue(const std::string& lvalue);
954 void set_rvalue(const std::string& rvalue);
955 void set_lvalue_nonprimitive(bool is_nonprimitive);
956 void set_rvalue_nonprimitive(bool is_nonprimitive);
957 void set_lvalue_object(std::shared_ptr<bpp_entity> object);
958 void set_rvalue_object(std::shared_ptr<bpp_entity> object);
959 void set_adding(bool is_adding);
960 void set_rvalue_array(bool is_array);
961
962 std::string get_lvalue() const;
963 std::string get_rvalue() const;
964 bool lvalue_is_nonprimitive() const;
965 bool rvalue_is_nonprimitive() const;
966 std::shared_ptr<bpp_entity> get_lvalue_object() const;
967 std::shared_ptr<bpp_entity> get_rvalue_object() const;
968 bool is_adding() const;
969 bool rvalue_is_array() const;
970};
971
980 private:
982 std::string array_index = "";
983 public:
985
987 void set_array_index(const std::string& array_index);
989 std::string get_array_index() const;
990 bool has_array_index() const;
991};
992
993} // namespace bpp
A pattern for a case statement in Bash++.
Definition bpp.h:790
std::string pattern
Definition bpp.h:792
void set_containing_case(std::shared_ptr< bpp::bash_case > containing_case)
Definition bash_case_pattern.cpp:17
const std::string & get_pattern() const
Definition bash_case_pattern.cpp:21
void set_pattern(const std::string &pattern)
Definition bash_case_pattern.cpp:13
bash_case_pattern()
Definition bash_case_pattern.cpp:11
std::shared_ptr< bpp::bash_case > containing_case
Definition bpp.h:793
std::shared_ptr< bpp::bash_case > get_containing_case() const
Definition bash_case_pattern.cpp:25
A case statement in Bash++.
Definition bpp.h:770
std::string cases
Definition bpp.h:772
bash_case()
Definition bash_case.cpp:11
const std::string & get_cases() const
Definition bash_case.cpp:17
void add_case(const std::string &case_)
Definition bash_case.cpp:13
A sequence of bash commands connected by '&&' and '||'.
Definition bpp.h:392
std::string joined_code
Definition bpp.h:394
std::string get_code() const override
Return the contents of the main code buffer as a string.
Definition bash_command_sequence.cpp:105
void set_perfect_forwarding(bool enable)
Definition bash_command_sequence.cpp:109
bool perfect_forwarding
Definition bpp.h:397
void add_connective(bool is_and)
Add a connective to the command sequence, finalizing the previously-received pipeline....
Definition bash_command_sequence.cpp:73
void join()
Definition bash_command_sequence.cpp:11
void add_code(const std::string &code, bool add_newline=true) override
Add code to the code entity.
Definition bash_command_sequence.cpp:86
std::string get_post_code() const override
Return the contents of the post-code buffer as a string.
Definition bash_command_sequence.cpp:101
bool contains_multiple_commands
Definition bpp.h:395
std::string get_pre_code() const override
Return the contents of the pre-code buffer as a string.
Definition bash_command_sequence.cpp:97
A for loop or select statement in Bash++.
Definition bpp.h:813
const std::string & get_header_post_code() const
Definition bash_for_or_select.cpp:29
void set_header_post_code(const std::string &post_code)
Definition bash_for_or_select.cpp:17
const std::string & get_header_code() const
Definition bash_for_or_select.cpp:33
std::string header_pre_code
Definition bpp.h:815
bash_for_or_select()
Definition bash_for_or_select.cpp:11
std::string header_post_code
Definition bpp.h:816
std::string header_code
Definition bpp.h:817
const std::string & get_header_pre_code() const
Definition bash_for_or_select.cpp:25
void set_header_pre_code(const std::string &pre_code)
Definition bash_for_or_select.cpp:13
void set_header_code(const std::string &code)
Definition bash_for_or_select.cpp:21
A normal Bash function.
Definition bpp.h:839
bash_function()
Definition bash_function.cpp:11
A branch of an if statement in Bash++.
Definition bpp.h:747
void set_if_statement(std::shared_ptr< bpp::bash_if > if_statement)
Definition bash_if_branch.cpp:13
std::shared_ptr< bpp::bash_if > get_if_statement() const
Definition bash_if_branch.cpp:17
bash_if_branch()
Definition bash_if_branch.cpp:11
std::string get_pre_code() const override
Return the contents of the pre-code buffer as a string.
Definition bash_if_branch.cpp:25
std::string get_post_code() const override
Return the contents of the post-code buffer as a string.
Definition bash_if_branch.cpp:33
std::string get_code() const override
Return the contents of the main code buffer as a string.
Definition bash_if_branch.cpp:21
std::shared_ptr< bpp::bash_if > if_statement
Definition bpp.h:749
An if statement in Bash++.
Definition bpp.h:725
std::vector< std::pair< std::string, std::string > > conditional_branches
Definition bpp.h:727
void new_branch()
Definition bash_if.cpp:13
void add_branch_code(const std::string &branch_code)
Definition bash_if.cpp:21
void add_condition_code(const std::string &condition_code)
Definition bash_if.cpp:17
bash_if()
Definition bash_if.cpp:11
const std::vector< std::pair< std::string, std::string > > & get_conditional_branches() const
Definition bash_if.cpp:25
The condition for a while/until loop in Bash++.
Definition bpp.h:702
A while/until loop in Bash++.
Definition bpp.h:681
std::string get_code() const override
Return the contents of the main code buffer as a string.
Definition bash_while_or_until_loop.cpp:21
std::string get_pre_code() const override
Return the contents of the pre-code buffer as a string.
Definition bash_while_or_until_loop.cpp:25
std::string get_post_code() const override
Return the contents of the post-code buffer as a string.
Definition bash_while_or_until_loop.cpp:33
std::shared_ptr< bpp::bash_while_or_until_condition > condition
Definition bpp.h:683
void set_condition(std::shared_ptr< bpp::bash_while_or_until_condition > condition)
Definition bash_while_or_until_loop.cpp:13
bash_while_or_until_loop()
Definition bash_while_or_until_loop.cpp:11
std::shared_ptr< bpp::bash_while_or_until_condition > get_condition() const
Definition bash_while_or_until_loop.cpp:17
A class in Bash++.
Definition bpp.h:469
void set_name(const std::string &name) override
Definition bpp_class.cpp:64
bool set_containing_class(std::weak_ptr< bpp::bpp_class > containing_class) override
Definition bpp_class.cpp:60
bpp_class()
Definition bpp_class.cpp:12
std::shared_ptr< bpp_class > get_class() override
Definition bpp_class.cpp:56
void inherit(std::shared_ptr< bpp_class > parent) override
Inherit from a parent class.
Definition bpp_class.cpp:267
bool add_method(std::shared_ptr< bpp_method > method)
Add a method to the class.
Definition bpp_class.cpp:72
std::vector< std::shared_ptr< bpp_datamember > > get_datamembers() const
Definition bpp_class.cpp:156
void add_default_toPrimitive()
Add the default toPrimitive method.
Definition bpp_class.cpp:38
std::vector< std::shared_ptr< bpp_datamember > > datamembers
Definition bpp.h:472
std::shared_ptr< bpp_datamember > get_datamember(const std::string &name, std::shared_ptr< bpp_entity > context)
Get a datamember by name.
Definition bpp_class.cpp:228
bool has_custom_toPrimitive
Definition bpp.h:473
void remove_default_toPrimitive()
Remove the default toPrimitive method.
Definition bpp_class.cpp:20
std::shared_ptr< bpp::bpp_class > get_parent()
Definition bpp_class.cpp:299
std::shared_ptr< bpp_method > get_method(const std::string &name, std::shared_ptr< bpp_entity > context)
Get a method by name.
Definition bpp_class.cpp:173
std::shared_ptr< bpp_method > get_method_UNSAFE(const std::string &name)
Get a method by name without checking the context.
Definition bpp_class.cpp:206
std::shared_ptr< bpp_datamember > get_datamember_UNSAFE(const std::string &name)
Definition bpp_class.cpp:251
std::vector< std::shared_ptr< bpp_method > > get_methods() const
Definition bpp_class.cpp:152
std::weak_ptr< bpp_class > get_containing_class() override
Get the class which contains this entity.
Definition bpp_class.cpp:52
bool add_datamember(std::shared_ptr< bpp_datamember > datamember)
Add a datamember to the class.
Definition bpp_class.cpp:131
std::vector< std::shared_ptr< bpp_method > > methods
Definition bpp.h:471
An entity which can contain code.
Definition bpp.h:263
void set_requires_perfect_forwarding(bool require)
Definition bpp_code_entity.cpp:184
virtual void add_code_to_next_line(const std::string &code)
Add code to the code entity's post-code buffer.
Definition bpp_code_entity.cpp:59
bpp_code_entity()
Definition bpp_code_entity.cpp:12
std::shared_ptr< std::ostream > code
Definition bpp.h:265
std::string postline_buffer
Definition bpp.h:267
virtual void flush_code_buffers()
Definition bpp_code_entity.cpp:84
virtual void add_code_to_previous_line(const std::string &code)
Add code to the code entity's pre-code buffer.
Definition bpp_code_entity.cpp:51
virtual void flush_postline_buffer()
Definition bpp_code_entity.cpp:74
virtual std::string get_post_code() const
Return the contents of the post-code buffer as a string.
Definition bpp_code_entity.cpp:180
virtual std::string get_pre_code() const
Return the contents of the pre-code buffer as a string.
Definition bpp_code_entity.cpp:173
virtual void flush_nextline_buffer()
Definition bpp_code_entity.cpp:64
virtual void clear_all_buffers()
Definition bpp_code_entity.cpp:90
bool requires_perfect_forwarding
Signals to bash_command_sequence entities whether they should operate in perfect forwarding mode I....
Definition bpp.h:275
bool add_object(std::shared_ptr< bpp_object > object, bool make_local=false) override
Add an object to the code entity.
Definition bpp_code_entity.cpp:110
bool get_requires_perfect_forwarding() const
Definition bpp_code_entity.cpp:188
virtual void add_code(const std::string &code, bool add_newline=true)
Add code to the code entity.
Definition bpp_code_entity.cpp:24
virtual std::string get_code() const
Return the contents of the main code buffer as a string.
Definition bpp_code_entity.cpp:162
std::string nextline_buffer
Definition bpp.h:266
bool buffers_flushed
Definition bpp.h:268
A data member in a class.
Definition bpp.h:542
bool is_array() const
Definition bpp_datamember.cpp:37
bool array
Definition bpp.h:546
void set_scope(bpp_scope scope)
Definition bpp_datamember.cpp:17
std::string get_default_value() const
Definition bpp_datamember.cpp:29
void set_default_value(const std::string &default_value)
Definition bpp_datamember.cpp:13
std::string get_address() const override
Definition bpp_datamember.cpp:25
bpp_scope scope
Definition bpp.h:545
std::string default_value
Definition bpp.h:544
bpp_scope get_scope() const
Definition bpp_datamember.cpp:33
bpp_datamember()
Definition bpp_datamember.cpp:11
void set_array(bool is_array)
Definition bpp_datamember.cpp:21
A delete statement in Bash++.
Definition bpp.h:855
std::shared_ptr< bpp::bpp_object > get_object_to_delete() const
Definition bpp_delete_statement.cpp:15
void set_object_to_delete(std::shared_ptr< bpp::bpp_object > object)
Definition bpp_delete_statement.cpp:11
std::shared_ptr< bpp::bpp_object > object_to_delete
Definition bpp.h:857
A dynamic_cast statement in Bash++.
Definition bpp.h:876
void set_cast_to(const std::string &cast_to)
Definition bpp_dynamic_cast_statement.cpp:13
std::string get_cast_to() const
Definition bpp_dynamic_cast_statement.cpp:17
bpp_dynamic_cast_statement()
Definition bpp_dynamic_cast_statement.cpp:11
std::string cast_to
Definition bpp.h:878
The target of a dynamic_cast in Bash++.
Definition bpp.h:898
The base class for all entities in the Bash++ compiler.
Definition bpp.h:186
std::shared_ptr< bpp_class > get_parent() const
Definition bpp_entity.cpp:176
std::unordered_map< std::string, std::shared_ptr< bpp_object > > get_objects() const
Definition bpp_entity.cpp:143
std::weak_ptr< bpp_class > type
Definition bpp.h:208
std::unordered_map< std::string, std::weak_ptr< bpp_class > > classes
A map of class names to class objects within this entity.
Definition bpp.h:193
virtual void set_name(const std::string &name)
Definition bpp_entity.cpp:54
std::unordered_map< std::string, std::shared_ptr< bpp_object > > local_objects
Like objects, but only for objects whose scope is local to this entity.
Definition bpp.h:207
virtual std::weak_ptr< bpp::bpp_class > get_containing_class()
Get the class which contains this entity.
Definition bpp_entity.cpp:67
std::string name
Definition bpp.h:188
virtual bool add_object(std::shared_ptr< bpp_object > object, bool make_local=false)
Add an object to this entity's list of objects.
Definition bpp_entity.cpp:30
virtual ~bpp_entity()=default
std::unordered_map< std::string, std::shared_ptr< bpp_class > > get_classes() const
Definition bpp_entity.cpp:134
std::vector< std::weak_ptr< bpp_class > > parents
Definition bpp.h:211
void add_reference(const std::string &file, uint64_t line, uint64_t column)
Definition bpp_entity.cpp:89
bpp::SymbolPosition get_initial_definition() const
Definition bpp_entity.cpp:85
std::weak_ptr< bpp_program > containing_program
Definition bpp.h:210
virtual std::weak_ptr< bpp_program > get_containing_program()
Definition bpp_entity.cpp:71
std::weak_ptr< bpp_method > overridden_method
Definition bpp.h:212
std::shared_ptr< bpp_object > get_object(const std::string &name)
Definition bpp_entity.cpp:164
virtual std::string get_address() const
Definition bpp_entity.cpp:50
std::list< bpp::SymbolPosition > references
Definition bpp.h:214
std::unordered_map< std::string, std::weak_ptr< bpp_object > > objects
A map of object names to bpp_objects within this entity.
Definition bpp.h:199
std::weak_ptr< bpp_class > containing_class
Definition bpp.h:209
virtual bool set_containing_class(std::weak_ptr< bpp::bpp_class > containing_class)
Definition bpp_entity.cpp:75
virtual std::string get_name() const
Definition bpp_entity.cpp:58
std::list< bpp::SymbolPosition > get_references() const
Definition bpp_entity.cpp:100
void inherit(std::shared_ptr< bpp_entity > parent)
Inherit from a parent entity.
Definition bpp_entity.cpp:111
virtual bool add_class(std::shared_ptr< bpp_class > class_)
Add a class to this entity's list of classes.
Definition bpp_entity.cpp:16
void set_definition_position(const std::string &file, uint64_t line, uint64_t column)
Definition bpp_entity.cpp:80
virtual std::shared_ptr< bpp_class > get_class()
Definition bpp_entity.cpp:46
bpp::SymbolPosition initial_definition
Definition bpp.h:213
A parameter in a method.
Definition bpp.h:457
void set_class(std::shared_ptr< bpp_class >)
Definition bpp_method_parameter.cpp:15
A method in a class.
Definition bpp.h:419
bool inherited
Definition bpp.h:425
void set_last_override(const std::string &class_name)
Definition bpp_method.cpp:100
bool add_object(std::shared_ptr< bpp_object > object, bool make_local) override
Add an object to the code entity.
Definition bpp_method.cpp:152
bool add_object_as_parameter(std::shared_ptr< bpp_object > object)
Add a pointer to a non-primitive object as a parameter to the method.
Definition bpp_method.cpp:24
bpp_method(const std::string &name, bool is_virtual)
virtual bool add_parameter(std::shared_ptr< bpp_method_parameter > parameter)
Add a parameter to the method.
Definition bpp_method.cpp:55
bool is_virtual() const
Definition bpp_method.cpp:116
void set_scope(bpp_scope scope)
Definition bpp_method.cpp:83
bpp_scope scope
Definition bpp.h:422
void set_overridden_method(std::weak_ptr< bpp_method > method)
Definition bpp_method.cpp:104
bool m_is_overridable
Definition bpp.h:424
std::vector< std::shared_ptr< bpp_method_parameter > > get_parameters() const
Definition bpp_method.cpp:108
std::string last_override
Definition bpp.h:427
bpp_method()
Definition bpp_method.cpp:12
std::string get_last_override() const
Definition bpp_method.cpp:128
void set_virtual(bool is_virtual)
Definition bpp_method.cpp:87
bpp_scope get_scope() const
Definition bpp_method.cpp:112
void set_inherited(bool is_inherited)
Definition bpp_method.cpp:96
void destruct_local_objects(std::shared_ptr< bpp_program > program)
Destruct all local objects.
Definition bpp_method.cpp:139
std::vector< std::shared_ptr< bpp_method_parameter > > parameters
Definition bpp.h:421
void set_overridable(bool is_overridable)
Definition bpp_method.cpp:92
bool is_inherited() const
Definition bpp_method.cpp:124
bool m_is_virtual
Definition bpp.h:423
bool is_overridable() const
Definition bpp_method.cpp:120
An object assignment statement in Bash++.
Definition bpp.h:940
void set_rvalue_array(bool is_array)
Definition bpp_object_assignment.cpp:41
bool rvalue_array
Definition bpp.h:949
bool rvalue_is_array() const
Definition bpp_object_assignment.cpp:73
void set_adding(bool is_adding)
Definition bpp_object_assignment.cpp:37
bool adding
Definition bpp.h:948
std::shared_ptr< bpp_entity > lvalue_object
Definition bpp.h:946
void set_rvalue_nonprimitive(bool is_nonprimitive)
Definition bpp_object_assignment.cpp:25
bool rvalue_nonprimitive
Definition bpp.h:945
bpp_object_assignment()
Definition bpp_object_assignment.cpp:11
std::shared_ptr< bpp_entity > get_lvalue_object() const
Definition bpp_object_assignment.cpp:61
void set_lvalue(const std::string &lvalue)
Definition bpp_object_assignment.cpp:13
bool rvalue_is_nonprimitive() const
Definition bpp_object_assignment.cpp:57
void set_lvalue_object(std::shared_ptr< bpp_entity > object)
Definition bpp_object_assignment.cpp:29
std::string get_rvalue() const
Definition bpp_object_assignment.cpp:49
std::string get_lvalue() const
Definition bpp_object_assignment.cpp:45
void set_lvalue_nonprimitive(bool is_nonprimitive)
Definition bpp_object_assignment.cpp:21
void set_rvalue(const std::string &rvalue)
Definition bpp_object_assignment.cpp:17
std::shared_ptr< bpp_entity > rvalue_object
Definition bpp.h:947
std::string lvalue
Definition bpp.h:942
bool lvalue_is_nonprimitive() const
Definition bpp_object_assignment.cpp:53
std::string rvalue
Definition bpp.h:943
bool lvalue_nonprimitive
Definition bpp.h:944
bool is_adding() const
Definition bpp_object_assignment.cpp:69
std::shared_ptr< bpp_entity > get_rvalue_object() const
Definition bpp_object_assignment.cpp:65
void set_rvalue_object(std::shared_ptr< bpp_entity > object)
Definition bpp_object_assignment.cpp:33
An object reference in Bash++.
Definition bpp.h:979
void set_array_index(const std::string &array_index)
Definition bpp_object_reference.cpp:17
bool has_array_index() const
Definition bpp_object_reference.cpp:29
bpp::reference_type get_reference_type() const
Definition bpp_object_reference.cpp:21
bpp::reference_type reference_type
Definition bpp.h:981
bpp_object_reference()
Definition bpp_object_reference.cpp:11
std::string array_index
Definition bpp.h:982
std::string get_array_index() const
Definition bpp_object_reference.cpp:25
void set_reference_type(bpp::reference_type reference_type)
Definition bpp_object_reference.cpp:13
An object in Bash++.
Definition bpp.h:507
std::string get_pre_access_code() const
Definition bpp_object.cpp:58
bool is_pointer() const
Definition bpp_object.cpp:66
void set_pre_access_code(const std::string &pre_access_code)
Definition bpp_object.cpp:36
void set_pointer(bool is_pointer)
Definition bpp_object.cpp:24
void set_address(const std::string &address)
Definition bpp_object.cpp:28
std::string address
Definition bpp.h:509
void set_post_access_code(const std::string &post_access_code)
Definition bpp_object.cpp:40
std::string get_post_access_code() const
Definition bpp_object.cpp:62
std::string get_assignment_value() const
Definition bpp_object.cpp:54
void set_assignment_value(const std::string &assignment_value)
Definition bpp_object.cpp:32
std::string pre_access_code
Definition bpp.h:511
void set_nullptr()
Definition bpp_object.cpp:44
std::string post_access_code
Definition bpp.h:512
bpp_object()
Definition bpp_object.cpp:11
bool m_is_pointer
Definition bpp.h:513
std::string assignment_value
Definition bpp.h:510
std::shared_ptr< bpp::bpp_object > get_copy_from() const
Definition bpp_object.cpp:70
std::string get_address() const override
Definition bpp_object.cpp:50
void set_class(std::shared_ptr< bpp_class > object_class)
Definition bpp_object.cpp:20
std::shared_ptr< bpp::bpp_object > copy_from
Definition bpp.h:514
The main program.
Definition bpp.h:565
uint64_t get_dynamic_cast_counter() const
Definition bpp_program.cpp:181
std::vector< std::string > get_source_files() const
Definition bpp_program.cpp:244
void add_diagnostic(const std::string &file, diagnostic_type type, const std::string &message, uint32_t start_line, uint32_t start_column, uint32_t end_line, uint32_t end_column)
Definition bpp_program.cpp:283
uint64_t assignment_counter
Definition bpp.h:569
std::shared_ptr< bpp_class > primitive_class
Definition bpp.h:567
uint64_t dynamic_cast_counter
Definition bpp.h:571
void set_main_source_file(const std::string &file)
Definition bpp_program.cpp:256
std::unordered_map< std::string, std::shared_ptr< bpp::bpp_class > > owned_classes
Definition bpp.h:581
std::weak_ptr< bpp_program > get_containing_program() override
Definition bpp_program.cpp:37
bool set_containing_class(std::weak_ptr< bpp_class > containing_class) override
Definition bpp_program.cpp:25
uint64_t get_supershell_counter() const
Definition bpp_program.cpp:145
std::string get_main_source_file() const
Definition bpp_program.cpp:252
void increment_typeof_counter()
Definition bpp_program.cpp:185
std::shared_ptr< AST::Program > get_source_file_ast(const std::string &file) const
Definition bpp_program.cpp:275
void increment_function_counter()
Definition bpp_program.cpp:157
std::unordered_map< std::string, EntityMap > entity_maps
Definition bpp.h:588
std::string main_source_file
Definition bpp.h:577
uint64_t get_typeof_counter() const
Definition bpp_program.cpp:195
uint64_t get_assignment_counter() const
Definition bpp_program.cpp:153
uint64_t object_counter
Definition bpp.h:573
std::shared_ptr< bpp_class > get_primitive_class() const
Definition bpp_program.cpp:33
std::shared_ptr< bpp::bpp_entity > get_active_entity(const std::string &file, uint32_t line, uint32_t column)
Definition bpp_program.cpp:226
uint64_t supershell_counter
Definition bpp.h:568
std::vector< bpp::diagnostic > get_diagnostics(const std::string &file) const
Definition bpp_program.cpp:300
std::shared_ptr< std::vector< std::string > > get_include_paths() const
Definition bpp_program.cpp:128
uint64_t get_function_counter() const
Definition bpp_program.cpp:167
std::unordered_map< std::string, std::vector< bpp::diagnostic > > diagnostics
Definition bpp.h:593
uint64_t typeof_counter
Definition bpp.h:572
uint64_t function_counter
Definition bpp.h:570
bool add_class(std::shared_ptr< bpp_class > class_) override
Add a class to the program.
Definition bpp_program.cpp:66
void set_target_bash_version(BashVersion target_bash_version)
Definition bpp_program.cpp:207
uint64_t get_object_counter() const
Definition bpp_program.cpp:203
void increment_dynamic_cast_counter()
Definition bpp_program.cpp:171
bpp_program()
Definition bpp_program.cpp:13
BashVersion get_target_bash_version() const
Definition bpp_program.cpp:211
bool prepare_class(std::shared_ptr< bpp_class > class_)
Prepare a class for addition to the program by adding it to the classes map.
Definition bpp_program.cpp:51
void add_source_file(const std::string &file)
Definition bpp_program.cpp:264
void increment_supershell_counter()
Definition bpp_program.cpp:132
std::shared_ptr< std::vector< std::string > > include_paths
Definition bpp.h:597
void increment_assignment_counter()
Definition bpp_program.cpp:149
void mark_entity(const std::string &file, uint32_t start_line, uint32_t start_column, uint32_t end_line, uint32_t end_column, std::shared_ptr< bpp::bpp_entity > entity)
Definition bpp_program.cpp:215
void set_source_file_ast(const std::string &file, std::shared_ptr< AST::Program > ast)
Definition bpp_program.cpp:271
BashVersion target_bash_version
Definition bpp.h:575
void set_output_stream(std::shared_ptr< std::ostream > output_stream)
Definition bpp_program.cpp:29
void increment_object_counter()
Definition bpp_program.cpp:199
void clear_diagnostics(const std::string &file)
Definition bpp_program.cpp:308
void set_include_paths(std::shared_ptr< std::vector< std::string > > paths)
Definition bpp_program.cpp:124
std::unordered_map< std::string, std::shared_ptr< AST::Program > > source_file_asts
Definition bpp.h:585
The practical difference between bpp_code_entity and bpp_string is how we handle the code buffers.
Definition bpp.h:360
std::string get_pre_code() const override
Return the contents of the pre-code buffer as a string.
Definition bpp_string.cpp:41
void add_code(const std::string &code, bool add_newline=true) override
Add code to the primary buffer.
Definition bpp_string.cpp:19
void add_code_to_previous_line(const std::string &code) override
Add code to the pre-code buffer.
Definition bpp_string.cpp:26
void add_code_to_next_line(const std::string &code) override
Add code to the post-code buffer.
Definition bpp_string.cpp:33
bpp_string()
Definition bpp_string.cpp:11
std::string get_code() const override
Return the contents of the main code buffer as a string.
Definition bpp_string.cpp:37
std::string get_post_code() const override
Return the contents of the post-code buffer as a string.
Definition bpp_string.cpp:49
A value assignment statement in Bash++.
Definition bpp.h:910
bool is_array_assignment() const
Definition bpp_value_assignment.cpp:45
std::shared_ptr< bpp_entity > nonprimitive_object
Definition bpp.h:913
bool nonprimitive_assignment
Definition bpp.h:912
bool is_nonprimitive_assignment() const
Definition bpp_value_assignment.cpp:33
bpp_value_assignment()
Definition bpp_value_assignment.cpp:11
bool array_assignment
Definition bpp.h:915
std::shared_ptr< bpp_entity > get_nonprimitive_object() const
Definition bpp_value_assignment.cpp:37
bool lvalue_nonprimitive
Definition bpp.h:914
void set_adding(bool is_adding)
Definition bpp_value_assignment.cpp:29
void set_lvalue_nonprimitive(bool is_nonprimitive)
Definition bpp_value_assignment.cpp:21
void set_array_assignment(bool is_array)
Definition bpp_value_assignment.cpp:25
void set_nonprimitive_assignment(bool is_nonprimitive)
Definition bpp_value_assignment.cpp:13
bool lvalue_is_nonprimitive() const
Definition bpp_value_assignment.cpp:41
bool is_adding() const
Definition bpp_value_assignment.cpp:49
void set_nonprimitive_object(std::shared_ptr< bpp_entity > object)
Definition bpp_value_assignment.cpp:17
bool adding
Definition bpp.h:916
Definition bash_case.cpp:9
const std::shared_ptr< bpp_method > inaccessible_method
A placeholder for an inaccessible method of a class (scope handling)
Definition bpp.h:105
const std::shared_ptr< bpp_datamember > inaccessible_datamember
A placeholder for an inaccessible data member of a class (scope handling)
Definition bpp.h:99
static const char bpp_nullptr[]
The secret internal value of '@nullptr' in Bash++.
Definition bpp.h:111
const std::shared_ptr< bpp_entity > inaccessible_entity
A placeholder for an inaccessible entity (scope handling)
Definition bpp.h:93
bool is_valid_identifier(const std::string &identifier)
Check if a string is a valid identifier in Bash++.
Definition bpp.h:143
constexpr const char * protected_keywords[]
A list of keywords that are reserved and cannot be used as identifiers in Bash++.
Definition bpp.h:117
diagnostic_type
Definition bpp.h:37
@ DIAGNOSTIC_INFO
Definition bpp.h:40
@ DIAGNOSTIC_ERROR
Definition bpp.h:38
@ DIAGNOSTIC_WARNING
Definition bpp.h:39
@ DIAGNOSTIC_HINT
Definition bpp.h:41
bool is_protected_keyword(const std::string &keyword)
Check if a string matches any of our protected keywords.
Definition bpp.h:129
bpp_scope
Definition bpp.h:24
@ SCOPE_PUBLIC
Definition bpp.h:25
@ SCOPE_INACCESSIBLE
Definition bpp.h:28
@ SCOPE_PRIVATE
Definition bpp.h:27
@ SCOPE_PROTECTED
Definition bpp.h:26
reference_type
Definition bpp.h:31
@ ref_method
Definition bpp.h:33
@ ref_object
Definition bpp.h:34
@ ref_primitive
Definition bpp.h:32
Represents a Bash version to target for code generation.
Definition BashVersion.h:21
Definition bpp.h:169
std::string file
Definition bpp.h:170
SymbolPosition()
Definition bpp.h:174
uint64_t column
Definition bpp.h:172
SymbolPosition(const std::string &file, uint64_t line, uint64_t column)
Definition bpp.h:175
uint64_t line
Definition bpp.h:171
Represents a diagnostic message (error, warning, info, hint)
Definition bpp.h:51
uint32_t start_line
Definition bpp.h:54
uint32_t end_line
Definition bpp.h:56
diagnostic_type type
Definition bpp.h:52
std::string message
Definition bpp.h:53
uint32_t end_column
Definition bpp.h:57
uint32_t start_column
Definition bpp.h:55