diff --git a/pkg/service/expr.go b/pkg/service/expr.go index 4c1aa23..dee0b64 100644 --- a/pkg/service/expr.go +++ b/pkg/service/expr.go @@ -32,10 +32,17 @@ func handleBasicLit(bl *ast.BasicLit) string { return bl.Value } -func handleUnaryExpr(expr *ast.UnaryExpr) string { - code := expr.Op.String() - code += handleExpr(expr.X) - return code +func handleUnaryExpr(expr *ast.UnaryExpr) (code string) { + cl, ok := expr.X.(*ast.CompositeLit) + if ok { + code += "new " + code += handleIdentExpr(cl.Type) + code += "()" + } else { + code += expr.Op.String() + code += handleExpr(expr.X) + } + return } func handleBinaryExpr(expr ast.Expr) string { diff --git a/pkg/service/features/app.feature b/pkg/service/features/app.feature index 2f9cbc5..02c61ce 100644 --- a/pkg/service/features/app.feature +++ b/pkg/service/features/app.feature @@ -196,7 +196,7 @@ this->x=dev2->x; } ``` - Сценарий: Структура с объявлением переменных-указателей + Сценарий: Структура с объявлением переменных-указателей и их созданием * Исходник: ``` package test @@ -206,11 +206,19 @@ var ( ) type device struct {} + +func main() { + dev1 = &device{} +} ``` * Результат: ``` class device { public: }; +void main(); device *dev1,*dev2; -``` \ No newline at end of file +void main() { +dev1=new device(); +} +```