Compare commits

...

3 Commits

Author SHA1 Message Date
c6bed88d37
Add test for basic custom struct 2023-08-28 22:15:10 +08:00
3640da1cf2
format main.cpp 2023-08-28 22:11:02 +08:00
3148127319
update code format configure 2023-08-28 21:58:23 +08:00
3 changed files with 870 additions and 846 deletions

View File

@ -1,5 +1,5 @@
Language: Cpp
AccessModifierOffset: -4
AccessModifierOffset: -8
AlignAfterOpenBracket: Align
AlignArrayOfStructures: Left
AlignConsecutiveMacros: None
@ -56,8 +56,8 @@ BreakStringLiterals: true
ColumnLimit: 99
QualifierAlignment: Left
CompactNamespaces: false
ConstructorInitializerIndentWidth: 4
ContinuationIndentWidth: 4
ConstructorInitializerIndentWidth: 8
ContinuationIndentWidth: 8
Cpp11BracedListStyle: true
DeriveLineEnding: true
DerivePointerAlignment: false
@ -79,7 +79,7 @@ IndentGotoLabels: false
IndentPPDirectives: None
IndentExternBlock: AfterExternBlock
IndentRequires: false
IndentWidth: 4
IndentWidth: 8
IndentWrappedFunctionNames: false
InsertTrailingCommas: Wrapped
InsertBraces: true
@ -141,7 +141,7 @@ SpacesInSquareBrackets: false
SpaceBeforeSquareBrackets: false
BitFieldColonSpacing: Both
Standard: Cpp11
TabWidth: 4
TabWidth: 8
UseCRLF: false
UseTab: Always

View File

@ -1,16 +1,16 @@
#include <bits/stdc++.h>
#include <argparse/argparse.hpp>
#include <bits/stdc++.h>
using namespace std;
enum class TokenType {
COMMA, // ,
SEMI, // ;
LB,
RB,
LP,
RP,
LT,
RT, // { } ( ) < >
LB, // {
RB, // }
LP, // (
RP, // )
LT, // <
RT, // >
ASSIGN, // =
DOT, // .
COLON, // :
@ -21,7 +21,8 @@ enum class TokenType {
RETURN, // return
TYPEOF, // typeof
PUBLIC, // public
ID
ID, // identifier
EXCEED
};
struct Token {
@ -55,7 +56,8 @@ void printTokens() {
"public",
"ID"};
for (auto u : tokens) {
cout << mp[static_cast<int>(u.type)] << " " << u.line << " " << cvt.to_bytes(u.s) << endl;
cout << mp[static_cast<int>(u.type)] << " " << u.line << " " << cvt.to_bytes(u.s)
<< endl;
}
cout << endl;
}
@ -191,7 +193,8 @@ bool sameType(shared_ptr<ValType> a, shared_ptr<ValType> b) {
return false;
}
if (a->type() == 0) {
auto aa = static_pointer_cast<TemplateType>(a), bb = static_pointer_cast<TemplateType>(b);
auto aa = static_pointer_cast<TemplateType>(a),
bb = static_pointer_cast<TemplateType>(b);
return aa == bb || eq.find({aa, bb}) != eq.end();
}
if (a->type() == 1) {
@ -201,7 +204,8 @@ bool sameType(shared_ptr<ValType> a, shared_ptr<ValType> b) {
return false;
}
assert(aa->mp.size() == bb->mp.size());
for (auto ia = aa->mp.begin(), ib = bb->mp.begin(); ia != aa->mp.end(); ia++, ib++) {
for (auto ia = aa->mp.begin(), ib = bb->mp.begin(); ia != aa->mp.end();
ia++, ib++) {
assert(ia->first == ib->first);
if (!sameType(ia->second, ib->second)) {
return false;
@ -323,7 +327,8 @@ shared_ptr<ValType> struct_replace(shared_ptr<ValType> vt, shared_ptr<StructType
for (auto u = vtt->str; u.get() != nullptr; u = u->fa.lock()) {
vis.insert(u);
}
for (auto u = ut->str; u.get() != nullptr && vis.find(u) == vis.end(); u = u->fa.lock()) {
for (auto u = ut->str; u.get() != nullptr && vis.find(u) == vis.end();
u = u->fa.lock()) {
for (auto tem : u->c1) {
tt->mp.erase(tem);
}
@ -507,7 +512,8 @@ shared_ptr<ValType> createVal() {
bool legal = vals.size() == tt->str->c2.size();
if (legal) {
for (size_t i = 0; i < vals.size(); i++) {
if (!sameType(vals[i], struct_replace(tt->str->c2[i], tt))) {
if (!sameType(vals[i],
struct_replace(tt->str->c2[i], tt))) {
legal = 0;
break;
}
@ -818,8 +824,10 @@ void work() {
}
int main(int argc, char* argv[]) {
argparse::ArgumentParser program("acpa", APP_VERSION
, argparse::default_arguments::help, false);
argparse::ArgumentParser program("acpa",
APP_VERSION,
argparse::default_arguments::help,
false);
program.add_argument("input_file")
.help("Source proof file")
.action([](const std::string& value) { return value; });

16
tests/ok/custom-struct.ac Normal file
View File

@ -0,0 +1,16 @@
struct {
struct And<P, Q>(p: P, q: Q) {
left = Fn<>() -> P {
return p;
};
right = Fn<>() -> Q {
return q;
};
};
AndLeft = Fn<P, Q>(h: And<P, Q>) -> P {
return h.p;
};
} main;