commit
54e35e2b89
@ -0,0 +1,149 @@
|
|||||||
|
.DS_Store
|
||||||
|
__pycache__
|
||||||
|
target
|
||||||
|
|
||||||
|
# Created by https://www.gitignore.io/api/java,eclipse,intellij,emacs,vim
|
||||||
|
|
||||||
|
### Java ###
|
||||||
|
*.class
|
||||||
|
|
||||||
|
# Mobile Tools for Java (J2ME)
|
||||||
|
.mtj.tmp/
|
||||||
|
|
||||||
|
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
|
||||||
|
hs_err_pid*
|
||||||
|
|
||||||
|
|
||||||
|
### Eclipse ###
|
||||||
|
*.pydevproject
|
||||||
|
.metadata
|
||||||
|
.gradle
|
||||||
|
bin/
|
||||||
|
tmp/
|
||||||
|
*.tmp
|
||||||
|
*.bak
|
||||||
|
*.swp
|
||||||
|
*~.nib
|
||||||
|
local.properties
|
||||||
|
.settings/
|
||||||
|
.loadpath
|
||||||
|
|
||||||
|
# Eclipse Core
|
||||||
|
.project
|
||||||
|
|
||||||
|
# External tool builders
|
||||||
|
.externalToolBuilders/
|
||||||
|
|
||||||
|
# Locally stored "Eclipse launch configurations"
|
||||||
|
*.launch
|
||||||
|
|
||||||
|
# CDT-specific
|
||||||
|
.cproject
|
||||||
|
|
||||||
|
# JDT-specific (Eclipse Java Development Tools)
|
||||||
|
.classpath
|
||||||
|
|
||||||
|
# Java annotation processor (APT)
|
||||||
|
.factorypath
|
||||||
|
|
||||||
|
# PDT-specific
|
||||||
|
.buildpath
|
||||||
|
|
||||||
|
# sbteclipse plugin
|
||||||
|
.target
|
||||||
|
|
||||||
|
# TeXlipse plugin
|
||||||
|
.texlipse
|
||||||
|
|
||||||
|
|
||||||
|
### Intellij ###
|
||||||
|
# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio
|
||||||
|
|
||||||
|
*.iml
|
||||||
|
|
||||||
|
## Directory-based project format:
|
||||||
|
.idea/
|
||||||
|
# if you remove the above rule, at least ignore the following:
|
||||||
|
|
||||||
|
# User-specific stuff:
|
||||||
|
# .idea/workspace.xml
|
||||||
|
# .idea/tasks.xml
|
||||||
|
# .idea/dictionaries
|
||||||
|
|
||||||
|
# Sensitive or high-churn files:
|
||||||
|
# .idea/dataSources.ids
|
||||||
|
# .idea/dataSources.xml
|
||||||
|
# .idea/sqlDataSources.xml
|
||||||
|
# .idea/dynamic.xml
|
||||||
|
# .idea/uiDesigner.xml
|
||||||
|
|
||||||
|
# Gradle:
|
||||||
|
# .idea/gradle.xml
|
||||||
|
# .idea/libraries
|
||||||
|
|
||||||
|
# Mongo Explorer plugin:
|
||||||
|
# .idea/mongoSettings.xml
|
||||||
|
|
||||||
|
## File-based project format:
|
||||||
|
*.ipr
|
||||||
|
*.iws
|
||||||
|
|
||||||
|
## Plugin-specific files:
|
||||||
|
|
||||||
|
# IntelliJ
|
||||||
|
/out/
|
||||||
|
|
||||||
|
# mpeltonen/sbt-idea plugin
|
||||||
|
.idea_modules/
|
||||||
|
|
||||||
|
# JIRA plugin
|
||||||
|
atlassian-ide-plugin.xml
|
||||||
|
|
||||||
|
# Crashlytics plugin (for Android Studio and IntelliJ)
|
||||||
|
com_crashlytics_export_strings.xml
|
||||||
|
crashlytics.properties
|
||||||
|
crashlytics-build.properties
|
||||||
|
|
||||||
|
|
||||||
|
### Emacs ###
|
||||||
|
# -*- mode: gitignore; -*-
|
||||||
|
*~
|
||||||
|
\#*\#
|
||||||
|
/.emacs.desktop
|
||||||
|
/.emacs.desktop.lock
|
||||||
|
*.elc
|
||||||
|
auto-save-list
|
||||||
|
tramp
|
||||||
|
.\#*
|
||||||
|
|
||||||
|
# Org-mode
|
||||||
|
.org-id-locations
|
||||||
|
*_archive
|
||||||
|
|
||||||
|
# flymake-mode
|
||||||
|
*_flymake.*
|
||||||
|
|
||||||
|
# eshell files
|
||||||
|
/eshell/history
|
||||||
|
/eshell/lastdir
|
||||||
|
|
||||||
|
# elpa packages
|
||||||
|
/elpa/
|
||||||
|
|
||||||
|
# reftex files
|
||||||
|
*.rel
|
||||||
|
|
||||||
|
# AUCTeX auto folder
|
||||||
|
/auto/
|
||||||
|
|
||||||
|
# cask packages
|
||||||
|
.cask/
|
||||||
|
|
||||||
|
|
||||||
|
### Vim ###
|
||||||
|
[._]*.s[a-w][a-z]
|
||||||
|
[._]s[a-w][a-z]
|
||||||
|
*.un~
|
||||||
|
Session.vim
|
||||||
|
.netrwhist
|
||||||
|
*~
|
@ -0,0 +1,26 @@
|
|||||||
|
Copyright (c) 2017-2018 The Regents of the University of California
|
||||||
|
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are
|
||||||
|
met:
|
||||||
|
|
||||||
|
1. Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
@ -0,0 +1,24 @@
|
|||||||
|
# NYU Compiler Construction CSCI-GA.2130/Spring 2021: Programming Assignment 1
|
||||||
|
|
||||||
|
This assignment is adapted from https://github.com/cs164berkeley/pa1-chocopy-parser/ with the authors' permission.
|
||||||
|
|
||||||
|
See the PA1 document on Piazza for a detailed specification.
|
||||||
|
|
||||||
|
## Quickstart
|
||||||
|
|
||||||
|
Run the following commands to generate and compile your parser and run the tests:
|
||||||
|
```
|
||||||
|
mvn clean package
|
||||||
|
java -cp "chocopy-ref.jar:target/assignment.jar" chocopy.ChocoPy \
|
||||||
|
--pass=s --test --dir src/test/data/pa1/sample/
|
||||||
|
```
|
||||||
|
|
||||||
|
`--pass=s` uses your parser (`s` for `student`), and with the starter code, only one test should pass.
|
||||||
|
`--pass=r` uses the reference parser (`r` for `reference`), which should pass all tests.
|
||||||
|
|
||||||
|
In addition to running in test mode with `--test`, you can also observe the actual output
|
||||||
|
of your (or reference) parser with:
|
||||||
|
```
|
||||||
|
java -cp "chocopy-ref.jar:target/assignment.jar" chocopy.ChocoPy \
|
||||||
|
--pass=s src/test/data/pa1/sample/expr_plus.py
|
||||||
|
```
|
Binary file not shown.
@ -0,0 +1,330 @@
|
|||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<groupId>chocopy</groupId>
|
||||||
|
<artifactId>chocopy</artifactId>
|
||||||
|
<packaging>jar</packaging>
|
||||||
|
<version>2.2-SNAPSHOT</version>
|
||||||
|
<name>chocopy</name>
|
||||||
|
<url>http://maven.apache.org</url>
|
||||||
|
|
||||||
|
<!-- Set this property to true on the command-line for very verbose output -->
|
||||||
|
<properties>
|
||||||
|
<chocopy.debug>false</chocopy.debug>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<!-- Specify JFlex and CUP plugins here; execute in profiles -->
|
||||||
|
<pluginManagement>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>de.jflex</groupId>
|
||||||
|
<artifactId>jflex-maven-plugin</artifactId>
|
||||||
|
<version>1.6.1</version>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>com.github.vbmacher</groupId>
|
||||||
|
<artifactId>cup-maven-plugin</artifactId>
|
||||||
|
<version>11b-20160615</version>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-assembly-plugin</artifactId>
|
||||||
|
<version>3.1.0</version>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-jar-plugin</artifactId>
|
||||||
|
<version>3.1.0</version>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-site-plugin</artifactId>
|
||||||
|
<version>3.7.1</version>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</pluginManagement>
|
||||||
|
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-assembly-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<descriptorRefs>
|
||||||
|
<descriptorRef>jar-with-dependencies</descriptorRef>
|
||||||
|
</descriptorRefs>
|
||||||
|
<finalName>assignment</finalName>
|
||||||
|
<appendAssemblyId>false</appendAssemblyId>
|
||||||
|
</configuration>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<id>make-assembly</id>
|
||||||
|
<phase>package</phase> <!-- bind to the packaging phase -->
|
||||||
|
<goals>
|
||||||
|
<goal>single</goal>
|
||||||
|
</goals>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>3.8.0</version>
|
||||||
|
<configuration>
|
||||||
|
<encoding>UTF-8</encoding>
|
||||||
|
<source>1.8</source>
|
||||||
|
<target>1.8</target>
|
||||||
|
<parameters>true</parameters>
|
||||||
|
<debug>true</debug>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
|
||||||
|
<resources>
|
||||||
|
<resource>
|
||||||
|
<directory>src/main/asm</directory>
|
||||||
|
<includes>
|
||||||
|
<include>**/*.s</include>
|
||||||
|
<include>**/*.os</include>
|
||||||
|
</includes>
|
||||||
|
<excludes>
|
||||||
|
<exclude>**/reference/*.s</exclude>
|
||||||
|
</excludes>
|
||||||
|
</resource>
|
||||||
|
</resources>
|
||||||
|
</build>
|
||||||
|
|
||||||
|
<profiles>
|
||||||
|
<profile>
|
||||||
|
<id>reference</id>
|
||||||
|
<activation>
|
||||||
|
<!-- This profile is activated whenever we have the reference sources available -->
|
||||||
|
<file>
|
||||||
|
<exists>src/main/java/chocopy/reference/</exists>
|
||||||
|
</file>
|
||||||
|
</activation>
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<!-- Do not include student skeletons in the reference JAR -->
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-jar-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<excludes>
|
||||||
|
<exclude>**/pa1/*</exclude>
|
||||||
|
<exclude>**/pa2/*</exclude>
|
||||||
|
<exclude>**/pa3/*</exclude>
|
||||||
|
</excludes>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<!-- Name the generated JAR differently so that it is different from the student version -->
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-assembly-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<descriptorRefs>
|
||||||
|
<descriptorRef>jar-with-dependencies</descriptorRef>
|
||||||
|
</descriptorRefs>
|
||||||
|
<finalName>chocopy-ref</finalName>
|
||||||
|
<appendAssemblyId>false</appendAssemblyId>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<!-- Run JFlex to generate reference lexer -->
|
||||||
|
<plugin>
|
||||||
|
<groupId>de.jflex</groupId>
|
||||||
|
<artifactId>jflex-maven-plugin</artifactId>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<id>jflex-reference</id>
|
||||||
|
<goals>
|
||||||
|
<goal>generate</goal>
|
||||||
|
</goals>
|
||||||
|
<configuration>
|
||||||
|
<lexDefinitions>
|
||||||
|
<lexDefinition>src/main/jflex/chocopy/reference/ChocoPy.jflex</lexDefinition>
|
||||||
|
</lexDefinitions>
|
||||||
|
<dump>${chocopy.debug}</dump>
|
||||||
|
<verbose>true</verbose>
|
||||||
|
</configuration>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
<!-- Run CUP to generate reference parser -->
|
||||||
|
<plugin>
|
||||||
|
<groupId>com.github.vbmacher</groupId>
|
||||||
|
<artifactId>cup-maven-plugin</artifactId>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<id>cup-reference</id>
|
||||||
|
<goals>
|
||||||
|
<goal>generate</goal>
|
||||||
|
</goals>
|
||||||
|
<configuration>
|
||||||
|
<cupDefinition>src/main/cup/chocopy/reference/ChocoPy.cup</cupDefinition>
|
||||||
|
<packageName>chocopy.reference</packageName>
|
||||||
|
<className>ChocoPyParser</className>
|
||||||
|
<symbolsName>ChocoPyTokens</symbolsName>
|
||||||
|
<dumpTables>${chocopy.debug}</dumpTables>
|
||||||
|
<dumpStates>${chocopy.debug}</dumpStates>
|
||||||
|
<dumpGrammar>${chocopy.debug}</dumpGrammar>
|
||||||
|
<locations>true</locations>
|
||||||
|
</configuration>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
<!-- No debug -->
|
||||||
|
<plugin>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<debug>true</debug>
|
||||||
|
<debuglevel>none</debuglevel>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<!-- Copy dependencies to target/ -->
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-dependency-plugin</artifactId>
|
||||||
|
<version>3.1.1</version>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<id>copy-dependencies</id>
|
||||||
|
<phase>package</phase>
|
||||||
|
<goals>
|
||||||
|
<goal>copy-dependencies</goal>
|
||||||
|
</goals>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
</profile>
|
||||||
|
|
||||||
|
<profile>
|
||||||
|
<id>pa1</id>
|
||||||
|
<activation>
|
||||||
|
<!-- This profile is activated whenever we are in a PA1 distribution -->
|
||||||
|
<file>
|
||||||
|
<exists>src/main/java/chocopy/pa1</exists>
|
||||||
|
</file>
|
||||||
|
</activation>
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<!-- Run JFlex on the student version -->
|
||||||
|
<plugin>
|
||||||
|
<groupId>de.jflex</groupId>
|
||||||
|
<artifactId>jflex-maven-plugin</artifactId>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<id>jflex-pa1</id>
|
||||||
|
<goals>
|
||||||
|
<goal>generate</goal>
|
||||||
|
</goals>
|
||||||
|
<configuration>
|
||||||
|
<lexDefinitions>
|
||||||
|
<lexDefinition>src/main/jflex/chocopy/pa1/ChocoPy.jflex</lexDefinition>
|
||||||
|
</lexDefinitions>
|
||||||
|
<dump>${chocopy.debug}</dump>
|
||||||
|
<verbose>true</verbose>
|
||||||
|
</configuration>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
<!-- Run CUP on the student version -->
|
||||||
|
<plugin>
|
||||||
|
<groupId>com.github.vbmacher</groupId>
|
||||||
|
<artifactId>cup-maven-plugin</artifactId>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<id>cup-pa1</id>
|
||||||
|
<goals>
|
||||||
|
<goal>generate</goal>
|
||||||
|
</goals>
|
||||||
|
<configuration>
|
||||||
|
<cupDefinition>src/main/cup/chocopy/pa1/ChocoPy.cup</cupDefinition>
|
||||||
|
<packageName>chocopy.pa1</packageName>
|
||||||
|
<className>ChocoPyParser</className>
|
||||||
|
<symbolsName>ChocoPyTokens</symbolsName>
|
||||||
|
<dumpTables>${chocopy.debug}</dumpTables>
|
||||||
|
<dumpStates>${chocopy.debug}</dumpStates>
|
||||||
|
<dumpGrammar>${chocopy.debug}</dumpGrammar>
|
||||||
|
<locations>true</locations>
|
||||||
|
</configuration>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
</profile>
|
||||||
|
<profile>
|
||||||
|
<id>pa2</id>
|
||||||
|
<activation>
|
||||||
|
<!-- This profile is activated whenever we are in a PA2 distribution -->
|
||||||
|
<file>
|
||||||
|
<exists>src/main/java/chocopy/pa2</exists>
|
||||||
|
</file>
|
||||||
|
</activation>
|
||||||
|
</profile>
|
||||||
|
<profile>
|
||||||
|
<id>pa3</id>
|
||||||
|
<activation>
|
||||||
|
<!-- This profile is activated whenever we are in a PA3 distribution -->
|
||||||
|
<file>
|
||||||
|
<exists>src/main/java/chocopy/pa3</exists>
|
||||||
|
</file>
|
||||||
|
</activation>
|
||||||
|
</profile>
|
||||||
|
</profiles>
|
||||||
|
|
||||||
|
|
||||||
|
<repositories>
|
||||||
|
<repository>
|
||||||
|
<id>venus164-repo</id>
|
||||||
|
<name>Repository for Venus164</name>
|
||||||
|
<url>https://raw.githubusercontent.com/chocopy/venus/maven-repository/</url>
|
||||||
|
</repository>
|
||||||
|
</repositories>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>net.sourceforge.argparse4j</groupId>
|
||||||
|
<artifactId>argparse4j</artifactId>
|
||||||
|
<version>0.8.1</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.fasterxml.jackson.core</groupId>
|
||||||
|
<artifactId>jackson-databind</artifactId>
|
||||||
|
<version>[2.9.10.1,)</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.fasterxml.jackson.module</groupId>
|
||||||
|
<artifactId>jackson-module-parameter-names</artifactId>
|
||||||
|
<version>2.9.10</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.github.vbmacher</groupId>
|
||||||
|
<artifactId>java-cup-runtime</artifactId>
|
||||||
|
<version>11b-20160615</version>
|
||||||
|
</dependency>
|
||||||
|
<!-- https://mvnrepository.com/artifact/de.jflex/jflex -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>de.jflex</groupId>
|
||||||
|
<artifactId>jflex</artifactId>
|
||||||
|
<version>1.6.1</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.jetbrains.kotlin</groupId>
|
||||||
|
<artifactId>kotlin-stdlib</artifactId>
|
||||||
|
<version>1.2.71</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>edu.berkeley.eecs.venus164</groupId>
|
||||||
|
<artifactId>venus164</artifactId>
|
||||||
|
<version>0.2.4</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
<version>4.12</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>net.sf.proguard</groupId>
|
||||||
|
<artifactId>proguard-base</artifactId>
|
||||||
|
<version>6.0.3</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</project>
|
@ -0,0 +1,214 @@
|
|||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import java_cup.runtime.*;
|
||||||
|
import chocopy.common.astnodes.*;
|
||||||
|
|
||||||
|
/* The following code section is copied verbatim to the generated
|
||||||
|
* parser class. */
|
||||||
|
parser code {:
|
||||||
|
|
||||||
|
/* The following fields and methods deal with error reporting
|
||||||
|
* Avoid changing these unless you know what you are doing. */
|
||||||
|
|
||||||
|
/** Node that accumulates error messages to be added to the Program
|
||||||
|
* node produced as a result. */
|
||||||
|
public final Errors errors = new Errors(new ArrayList<>());
|
||||||
|
|
||||||
|
/** Return the Program node that results from parsing the stream of
|
||||||
|
* tokens produced by lexical analysis. In the case of syntax errors,
|
||||||
|
* the program may be empty, but will have error messages. */
|
||||||
|
public Program parseProgram(boolean debug) {
|
||||||
|
try {
|
||||||
|
Symbol result = debug ? debug_parse() : parse();
|
||||||
|
if (result == null || !(result.value instanceof Program)) {
|
||||||
|
return new Program(new Location(0, 0), new Location(0, 0),
|
||||||
|
new ArrayList<Declaration>(),
|
||||||
|
new ArrayList<Stmt>(),
|
||||||
|
errors);
|
||||||
|
} else {
|
||||||
|
return (Program) result.value;
|
||||||
|
}
|
||||||
|
} catch (RuntimeException excp) {
|
||||||
|
throw excp;
|
||||||
|
} catch (Exception excp) {
|
||||||
|
String msg =
|
||||||
|
String.format("Internal parser error detected: %s%n", excp);
|
||||||
|
throw new AssertionError(msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SymbolFactory getSymbolFactory() {
|
||||||
|
return ((ChocoPyLexer) getScanner()).symbolFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void syntax_error(Symbol cur_token) {
|
||||||
|
String token = symbl_name_from_id(cur_token.sym);
|
||||||
|
String text = ((ChocoPyLexer) getScanner()).yytext();
|
||||||
|
errors.syntaxError(
|
||||||
|
((ComplexSymbolFactory.ComplexSymbol) cur_token).xleft,
|
||||||
|
((ComplexSymbolFactory.ComplexSymbol) cur_token).xright,
|
||||||
|
"Parse error near token %s: %s", token, text);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void unrecovered_syntax_error(Symbol cur_token) {
|
||||||
|
/* Do not die */
|
||||||
|
}
|
||||||
|
:}
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
* FEEL FREE TO MODIFY ANYTHING BELOW THIS LINE
|
||||||
|
*
|
||||||
|
* The rules provided below parse expressions of the form <INT> + <INT> + ...
|
||||||
|
* You can re-use these rules or edit them as you wish. The start rule
|
||||||
|
* should return a node of type Program.
|
||||||
|
*
|
||||||
|
* Tips: Production rules are usually followed by action code that will be
|
||||||
|
* copied to the generated parser to be executed immediately after a reduce
|
||||||
|
* operation; that is, when a production rule has been matched. You can name
|
||||||
|
* a nonterminal or terminal symbol in a production rule using the colon
|
||||||
|
* notation, e.g. expr_stmt ::= expr:e, to get the AST node for the matched
|
||||||
|
* expression. In the action code, `e` will be a variable of whatever type
|
||||||
|
* has been declared for the corresponding nonterminal, such as `Expr`.
|
||||||
|
* Therefore, you can construct an AST Node of type `ExprStmt` with `e` in the
|
||||||
|
* constructor: `new ExprStmt(exleft, exright, e)`
|
||||||
|
*
|
||||||
|
* The variables `exleft` and `exright` are automatically generated by CUP
|
||||||
|
* and contain Location objects for the start and end of the expression `e`.
|
||||||
|
* You can collect start and line number info for AST nodes by taking the
|
||||||
|
* location of the left end of the leftmost symbol in a rule and the
|
||||||
|
* location of the right end of the rightmost symbol. The auto-generated
|
||||||
|
* variables have names `<sym>xleft` and `<sym>xright`, where <sym> is the
|
||||||
|
* name given to the symbol using the colon notation.
|
||||||
|
*
|
||||||
|
* When you have nonterminals that are lists of things, e.g. List<Stmt> or
|
||||||
|
* List<Declaration>, it is helpful to get the leftmost and rightmost
|
||||||
|
* source location from within this list; we have provided some utility
|
||||||
|
* functions below to do just that.
|
||||||
|
**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
/* The following code section is copied verbatim to the class that performs
|
||||||
|
* production-rule actions. */
|
||||||
|
action code {:
|
||||||
|
|
||||||
|
/** Return a mutable list initially containing the single value ITEM. */
|
||||||
|
<T> List<T> single(T item) {
|
||||||
|
List<T> list = new ArrayList<>();
|
||||||
|
if (item != null) {
|
||||||
|
list.add(item);
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** If ITEM is non-null, appends it to the end of LIST. Then returns
|
||||||
|
* LIST. */
|
||||||
|
<T> List<T> combine(List<T> list, T item) {
|
||||||
|
if (item != null) {
|
||||||
|
list.add(item);
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Return a mutable empty list. */
|
||||||
|
<T> List<T> empty() {
|
||||||
|
return new ArrayList<T>();
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Return the leftmost non-whitespace location in NODES, or null if NODES
|
||||||
|
* is empty. Assumes that the nodes of NODES are ordered in increasing
|
||||||
|
* order of location, from left to right. */
|
||||||
|
ComplexSymbolFactory.Location getLeft(List<? extends Node> nodes) {
|
||||||
|
if (nodes.isEmpty()) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
Node first = nodes.get(0);
|
||||||
|
return new ComplexSymbolFactory.Location(first.getLocation()[0],
|
||||||
|
first.getLocation()[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
:}
|
||||||
|
|
||||||
|
/* Terminal symbols (tokens returned by the lexer). The declaration
|
||||||
|
* terminal <identifier1>, <identifier2>, ...;
|
||||||
|
* declares each <identifieri> as the denotation of a distinct type terminal
|
||||||
|
* symbol for use in the grammar. The declaration
|
||||||
|
* terminal <type> <identifier1>, ...;
|
||||||
|
* does the same, and in addition indicates that the lexer supplies a
|
||||||
|
* semantic value of type <type> for these symbols that may be referenced
|
||||||
|
* in actions ( {: ... :} ).
|
||||||
|
*/
|
||||||
|
terminal NEWLINE;
|
||||||
|
terminal String PLUS;
|
||||||
|
terminal Integer NUMBER;
|
||||||
|
/* Returned by the lexer for erroneous tokens. Since it does not appear in
|
||||||
|
* the grammar, it indicates a syntax error. */
|
||||||
|
terminal UNRECOGNIZED;
|
||||||
|
|
||||||
|
/* Nonterminal symbols (defined in production rules below).
|
||||||
|
* As for terminal symbols,
|
||||||
|
* non terminal <type> <identifier1>, ..., <identifiern>;
|
||||||
|
* defines the listed nonterminal identifier symbols to have semantic values
|
||||||
|
* of type <type>. */
|
||||||
|
non terminal Program program;
|
||||||
|
non terminal List<Declaration> program_head;
|
||||||
|
non terminal List<Stmt> stmt_list, opt_stmt_list;
|
||||||
|
non terminal Stmt stmt, expr_stmt;
|
||||||
|
non terminal Expr expr, binary_expr;
|
||||||
|
|
||||||
|
/* Precedences (lowest to highest) for resolving what would otherwise be
|
||||||
|
* ambiguities in the form of shift/reduce conflicts.. */
|
||||||
|
precedence left PLUS;
|
||||||
|
|
||||||
|
/* The start symbol. */
|
||||||
|
start with program;
|
||||||
|
|
||||||
|
|
||||||
|
/***** GRAMMAR RULES *****/
|
||||||
|
|
||||||
|
program ::= program_head:d opt_stmt_list:s
|
||||||
|
{: RESULT = new Program(d.isEmpty() ? getLeft(s) : getLeft(d),
|
||||||
|
sxright, d, s, errors);
|
||||||
|
:}
|
||||||
|
;
|
||||||
|
|
||||||
|
/* Initial list of declarations. */
|
||||||
|
program_head ::= /* not implemented; currently matches empty string */
|
||||||
|
{: RESULT = empty(); :}
|
||||||
|
;
|
||||||
|
|
||||||
|
opt_stmt_list ::= {: RESULT = empty(); :}
|
||||||
|
| stmt_list:s {: RESULT = s; :}
|
||||||
|
;
|
||||||
|
|
||||||
|
stmt_list ::= stmt:s {: RESULT = single(s); :}
|
||||||
|
| stmt_list:l stmt:s {: RESULT = combine(l, s); :}
|
||||||
|
| stmt_list:l error {: RESULT = l; :}
|
||||||
|
/* If there is a syntax error in the source, this says to discard
|
||||||
|
* symbols from the parsing stack and perform reductions until
|
||||||
|
* there is a stmt_list on top of the stack, and then to discard
|
||||||
|
* input symbols until it is possible to shift again, reporting
|
||||||
|
* a syntax error. */
|
||||||
|
;
|
||||||
|
|
||||||
|
stmt ::= expr_stmt:s NEWLINE {: RESULT = s; :}
|
||||||
|
;
|
||||||
|
|
||||||
|
expr_stmt ::= expr:e {: RESULT = new ExprStmt(exleft, exright, e); :}
|
||||||
|
;
|
||||||
|
|
||||||
|
expr ::= binary_expr:e {: RESULT = e; :}
|
||||||
|
| NUMBER:n {: RESULT = new IntegerLiteral(nxleft, nxright, n); :}
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
/* A binary expression, illustrating how to find the left and right
|
||||||
|
* source position of a phrase. */
|
||||||
|
binary_expr ::= expr:e1 PLUS:op expr:e2
|
||||||
|
{: RESULT = new BinaryExpr(e1xleft, e2xright,
|
||||||
|
e1, op, e2); :}
|
||||||
|
;
|
@ -0,0 +1,64 @@
|
|||||||
|
package chocopy.common;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Utility functions for general use.
|
||||||
|
*/
|
||||||
|
public class Utils {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return resource file FILENAME's contents as a string. FILENAME
|
||||||
|
* can refer to a file within the class hierarchy, so that a text
|
||||||
|
* resource in file resource.txt in the chocopy.common.codegen
|
||||||
|
* package, for example, could be referred to with FILENAME
|
||||||
|
* chocopy/common/codegen/resource.txt.
|
||||||
|
* <p>
|
||||||
|
* Credit: Lucio Paiva.
|
||||||
|
*/
|
||||||
|
public static String getResourceFileAsString(String fileName) {
|
||||||
|
InputStream is =
|
||||||
|
Utils.class.getClassLoader().getResourceAsStream(fileName);
|
||||||
|
if (is != null) {
|
||||||
|
BufferedReader reader =
|
||||||
|
new BufferedReader
|
||||||
|
(new InputStreamReader(is, StandardCharsets.UTF_8));
|
||||||
|
return reader.lines().collect
|
||||||
|
(Collectors.joining(System.lineSeparator()));
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return an exception signalling a fatal error having a message
|
||||||
|
* formed from MSGFORMAT and ARGS, as for String.format.
|
||||||
|
*/
|
||||||
|
public static Error fatal(String msgFormat, Object... args) {
|
||||||
|
return new Error(String.format(msgFormat, args));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the string S padded with FILL to TOLEN characters. Padding
|
||||||
|
* is on the left if PADONLEFT, and otherwise on the right. If S is
|
||||||
|
* already at least TOLEN characters, returns S.
|
||||||
|
*/
|
||||||
|
public static String pad(String s, Character fill, int toLen,
|
||||||
|
boolean padOnLeft) {
|
||||||
|
StringBuilder result = new StringBuilder(toLen);
|
||||||
|
if (!padOnLeft) {
|
||||||
|
result.append(s);
|
||||||
|
}
|
||||||
|
for (int n = s.length(); n < toLen; n += 1) {
|
||||||
|
result.append(fill);
|
||||||
|
}
|
||||||
|
if (padOnLeft) {
|
||||||
|
result.append(s);
|
||||||
|
}
|
||||||
|
return result.toString();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,100 @@
|
|||||||
|
package chocopy.common.analysis;
|
||||||
|
|
||||||
|
import chocopy.common.astnodes.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This interface can be used to separate logic for various concrete
|
||||||
|
* classes in the AST class hierarchy.
|
||||||
|
* <p>
|
||||||
|
* The idea is that a phase of the analysis is encapsulated in a class
|
||||||
|
* that implements this interface, and contains an overriding of the
|
||||||
|
* analyze method for each concrete Node class that needs something
|
||||||
|
* other than default processing. Each concrete node class, C, implements
|
||||||
|
* a generic dispatch method that takes a NodeAnalyzer<T> argument and
|
||||||
|
* calls the overloading of analyze that takes an argument of type C.
|
||||||
|
* The effect is that anode.dispatch(anAnalyzer) executes the method
|
||||||
|
* anAnalyzer.analyze that is appropriate to aNode's dynamic type.
|
||||||
|
* As a result each NodeAnalyzer subtype encapsulates all
|
||||||
|
* implementations of a particular action on Nodes. Thus, it inverts
|
||||||
|
* the usual OO pattern in which the implementations of analysis A for
|
||||||
|
* each different class are scattered among the class bodies
|
||||||
|
* themselves as overridings of a method A on the Node class.
|
||||||
|
* <p>
|
||||||
|
* The class AbstractNodeAnalyzer provides empty default
|
||||||
|
* implementations for these methods.
|
||||||
|
* <p>
|
||||||
|
* The type T is the type of result returned by the encapsulated analysis.
|
||||||
|
*/
|
||||||
|
public interface NodeAnalyzer<T> {
|
||||||
|
|
||||||
|
T analyze(AssignStmt node);
|
||||||
|
|
||||||
|
T analyze(BinaryExpr node);
|
||||||
|
|
||||||
|
T analyze(BooleanLiteral node);
|
||||||
|
|
||||||
|
T analyze(CallExpr node);
|
||||||
|
|
||||||
|
T analyze(ClassDef node);
|
||||||
|
|
||||||
|
T analyze(ClassType node);
|
||||||
|
|
||||||
|
T analyze(CompilerError node);
|
||||||
|
|
||||||
|
T analyze(Errors node);
|
||||||
|
|
||||||
|
T analyze(ExprStmt node);
|
||||||
|
|
||||||
|
T analyze(ForStmt node);
|
||||||
|
|
||||||
|
T analyze(FuncDef node);
|
||||||
|
|
||||||
|
T analyze(GlobalDecl node);
|
||||||
|
|
||||||
|
T analyze(Identifier node);
|
||||||
|
|
||||||
|
T analyze(IfExpr node);
|
||||||
|
|
||||||
|
T analyze(IfStmt node);
|
||||||
|
|
||||||
|
T analyze(IndexExpr node);
|
||||||
|
|
||||||
|
T analyze(IntegerLiteral node);
|
||||||
|
|
||||||
|
T analyze(ListExpr node);
|
||||||
|
|
||||||
|
T analyze(ListType node);
|
||||||
|
|
||||||
|
T analyze(MemberExpr node);
|
||||||
|
|
||||||
|
T analyze(MethodCallExpr node);
|
||||||
|
|
||||||
|
T analyze(NoneLiteral node);
|
||||||
|
|
||||||
|
T analyze(NonLocalDecl node);
|
||||||
|
|
||||||
|
T analyze(Program node);
|
||||||
|
|
||||||
|
T analyze(ReturnStmt node);
|
||||||
|
|
||||||
|
T analyze(StringLiteral node);
|
||||||
|
|
||||||
|
T analyze(TypedVar node);
|
||||||
|
|
||||||
|
T analyze(UnaryExpr node);
|
||||||
|
|
||||||
|
T analyze(VarDef node);
|
||||||
|
|
||||||
|
T analyze(WhileStmt node);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the default value returned by calls to analyze that are not
|
||||||
|
* overridden to VALUE. By default, this is null.
|
||||||
|
*/
|
||||||
|
void setDefault(T value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default value for non-overridden methods.
|
||||||
|
*/
|
||||||
|
T defaultAction(Node node);
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Single and multiple assignments.
|
||||||
|
*/
|
||||||
|
public class AssignStmt extends Stmt {
|
||||||
|
/**
|
||||||
|
* List of left-hand sides.
|
||||||
|
*/
|
||||||
|
public final List<Expr> targets;
|
||||||
|
/**
|
||||||
|
* Right-hand-side value to be assigned.
|
||||||
|
*/
|
||||||
|
public final Expr value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* AST for TARGETS[0] = TARGETS[1] = ... = VALUE spanning source locations
|
||||||
|
* [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public AssignStmt(Location left, Location right,
|
||||||
|
List<Expr> targets, Expr value) {
|
||||||
|
super(left, right);
|
||||||
|
this.targets = targets;
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,40 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <operand> <operator> <operand>.
|
||||||
|
*/
|
||||||
|
public class BinaryExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Left operand.
|
||||||
|
*/
|
||||||
|
public final Expr left;
|
||||||
|
/**
|
||||||
|
* Operator name.
|
||||||
|
*/
|
||||||
|
public final String operator;
|
||||||
|
/**
|
||||||
|
* Right operand.
|
||||||
|
*/
|
||||||
|
public final Expr right;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An AST for expressions of the form LEFTEXPR OP RIGHTEXPR
|
||||||
|
* from text in range [LEFTLOC..RIGHTLOC].
|
||||||
|
*/
|
||||||
|
public BinaryExpr(Location leftLoc, Location rightLoc, Expr leftExpr,
|
||||||
|
String op, Expr rightExpr) {
|
||||||
|
super(leftLoc, rightLoc);
|
||||||
|
left = leftExpr;
|
||||||
|
operator = op;
|
||||||
|
right = rightExpr;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,29 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Literals True or False.
|
||||||
|
*/
|
||||||
|
public final class BooleanLiteral extends Literal {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True iff I represent True.
|
||||||
|
*/
|
||||||
|
public final boolean value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An AST for the token True or False at [LEFT..RIGHT], depending on
|
||||||
|
* VALUE.
|
||||||
|
*/
|
||||||
|
public BooleanLiteral(Location left, Location right, boolean value) {
|
||||||
|
super(left, right);
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A function call.
|
||||||
|
*/
|
||||||
|
public class CallExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The called function.
|
||||||
|
*/
|
||||||
|
public final Identifier function;
|
||||||
|
/**
|
||||||
|
* The actual parameter expressions.
|
||||||
|
*/
|
||||||
|
public final List<Expr> args;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* AST for FUNCTION(ARGS) at [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public CallExpr(Location left, Location right, Identifier function,
|
||||||
|
List<Expr> args) {
|
||||||
|
super(left, right);
|
||||||
|
this.function = function;
|
||||||
|
this.args = args;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,50 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A class definition.
|
||||||
|
*/
|
||||||
|
public class ClassDef extends Declaration {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Name of the declared class.
|
||||||
|
*/
|
||||||
|
public final Identifier name;
|
||||||
|
/**
|
||||||
|
* Name of the parent class.
|
||||||
|
*/
|
||||||
|
public final Identifier superClass;
|
||||||
|
/**
|
||||||
|
* Body of the class.
|
||||||
|
*/
|
||||||
|
public final List<Declaration> declarations;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An AST for class
|
||||||
|
* NAME(SUPERCLASS):
|
||||||
|
* DECLARATIONS.
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public ClassDef(Location left, Location right,
|
||||||
|
Identifier name, Identifier superClass,
|
||||||
|
List<Declaration> declarations) {
|
||||||
|
super(left, right);
|
||||||
|
this.name = name;
|
||||||
|
this.superClass = superClass;
|
||||||
|
this.declarations = declarations;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Identifier getIdentifier() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A simple class type name.
|
||||||
|
*/
|
||||||
|
public final class ClassType extends TypeAnnotation {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The denotation of the class in source.
|
||||||
|
*/
|
||||||
|
public final String className;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An AST denoting a type named CLASSNAME0 at [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public ClassType(Location left, Location right, String className0) {
|
||||||
|
super(left, right);
|
||||||
|
className = className0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,64 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a single error. Does not correspond to any Python source
|
||||||
|
* construct.
|
||||||
|
*/
|
||||||
|
public class CompilerError extends Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents an error with message MESSAGE. Iff SYNTAX, it is a
|
||||||
|
* syntactic error. The error applies to source text at [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public CompilerError(Location left, Location right, String message,
|
||||||
|
boolean syntax) {
|
||||||
|
super(left, right);
|
||||||
|
this.message = message;
|
||||||
|
this.syntax = syntax;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonInclude(JsonInclude.Include.NON_DEFAULT)
|
||||||
|
public boolean isSyntax() {
|
||||||
|
return syntax;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (o == null || getClass() != o.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
CompilerError that = (CompilerError) o;
|
||||||
|
return Objects.equals(message, that.message)
|
||||||
|
&& Arrays.equals(getLocation(), that.getLocation());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
int result = Objects.hash(message);
|
||||||
|
result = 31 * result + Arrays.hashCode(getLocation());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The error message.
|
||||||
|
*/
|
||||||
|
public final String message;
|
||||||
|
/**
|
||||||
|
* True if this is a syntax error.
|
||||||
|
*/
|
||||||
|
private final boolean syntax;
|
||||||
|
}
|
@ -0,0 +1,23 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base of all AST nodes representing definitions or declarations.
|
||||||
|
*/
|
||||||
|
public abstract class Declaration extends Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A definition or declaration spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public Declaration(Location left, Location right) {
|
||||||
|
super(left, right);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the identifier defined by this Declaration.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public abstract Identifier getIdentifier();
|
||||||
|
}
|
@ -0,0 +1,90 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Collects the error messages in a Program. There is exactly one per
|
||||||
|
* Program node.
|
||||||
|
*/
|
||||||
|
public class Errors extends Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The accumulated error messages in the order added.
|
||||||
|
*/
|
||||||
|
public final List<CompilerError> errors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True iff multiple semantic errors allowed on a node.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
private boolean allowMultipleErrors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An Errors whose list of CompilerErrors is ERRORS. The list should be
|
||||||
|
* modified using this.add.
|
||||||
|
*/
|
||||||
|
@JsonCreator
|
||||||
|
public Errors(List<CompilerError> errors) {
|
||||||
|
super(null, null);
|
||||||
|
this.errors = errors;
|
||||||
|
allowMultipleErrors = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return true iff there are any errors.
|
||||||
|
*/
|
||||||
|
public boolean hasErrors() {
|
||||||
|
return !this.errors.isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prevent multiple semantic errors on the same node.
|
||||||
|
*/
|
||||||
|
public void suppressMultipleErrors() {
|
||||||
|
allowMultipleErrors = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a new semantic error message attributed to NODE, with message
|
||||||
|
* String.format(MESSAGEFORM, ARGS).
|
||||||
|
*/
|
||||||
|
public void semError(Node node, String messageForm, Object... args) {
|
||||||
|
if (allowMultipleErrors || !node.hasError()) {
|
||||||
|
String msg = String.format(messageForm, args);
|
||||||
|
CompilerError err = new CompilerError(null, null, msg, false);
|
||||||
|
err.setLocation(node.getLocation());
|
||||||
|
add(err);
|
||||||
|
if (!node.hasError()) {
|
||||||
|
node.setErrorMsg(msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a new syntax error message attributed to the source text
|
||||||
|
* between LEFT and RIGHT, and with message
|
||||||
|
* String.format(MESSAGEFORM, ARGS).
|
||||||
|
*/
|
||||||
|
public void syntaxError(Location left, Location right,
|
||||||
|
String messageForm, Object... args) {
|
||||||
|
add(new CompilerError(left, right, String.format(messageForm, args),
|
||||||
|
true));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add ERR to the list of errors.
|
||||||
|
*/
|
||||||
|
public void add(CompilerError err) {
|
||||||
|
errors.add(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,22 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base of all AST nodes representing expressions.
|
||||||
|
* <p>
|
||||||
|
* There is nothing in this class, but there will be many AST
|
||||||
|
* node types that have fields that are *any expression*. For those
|
||||||
|
* cases, having a field of this type will encompass all types of
|
||||||
|
* expressions such as binary expressions and literals that subclass
|
||||||
|
* this class.
|
||||||
|
*/
|
||||||
|
public abstract class Expr extends Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A Python expression spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public Expr(Location left, Location right) {
|
||||||
|
super(left, right);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,29 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Statements consisting of expressions.
|
||||||
|
*/
|
||||||
|
public final class ExprStmt extends Stmt {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The expression I evaluate.
|
||||||
|
*/
|
||||||
|
public final Expr expr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for EXPR spanning source locations [LEFT..RIGHT]
|
||||||
|
* in a statement context.
|
||||||
|
*/
|
||||||
|
public ExprStmt(Location left, Location right, Expr expr) {
|
||||||
|
super(left, right);
|
||||||
|
this.expr = expr;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,43 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* For statements.
|
||||||
|
*/
|
||||||
|
public class ForStmt extends Stmt {
|
||||||
|
/**
|
||||||
|
* Control variable.
|
||||||
|
*/
|
||||||
|
public final Identifier identifier;
|
||||||
|
/**
|
||||||
|
* Source of values of control statement.
|
||||||
|
*/
|
||||||
|
public final Expr iterable;
|
||||||
|
/**
|
||||||
|
* Repeated statements.
|
||||||
|
*/
|
||||||
|
public final List<Stmt> body;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* for IDENTIFIER in ITERABLE:
|
||||||
|
* BODY
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public ForStmt(Location left, Location right,
|
||||||
|
Identifier identifier, Expr iterable, List<Stmt> body) {
|
||||||
|
super(left, right);
|
||||||
|
this.identifier = identifier;
|
||||||
|
this.iterable = iterable;
|
||||||
|
this.body = body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,61 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Def statements.
|
||||||
|
*/
|
||||||
|
public class FuncDef extends Declaration {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Defined name.
|
||||||
|
*/
|
||||||
|
public final Identifier name;
|
||||||
|
/**
|
||||||
|
* Formal parameters.
|
||||||
|
*/
|
||||||
|
public final List<TypedVar> params;
|
||||||
|
/**
|
||||||
|
* Return type annotation.
|
||||||
|
*/
|
||||||
|
public final TypeAnnotation returnType;
|
||||||
|
/**
|
||||||
|
* Local-variable,inner-function, global, and nonlocal declarations.
|
||||||
|
*/
|
||||||
|
public final List<Declaration> declarations;
|
||||||
|
/**
|
||||||
|
* Other statements.
|
||||||
|
*/
|
||||||
|
public final List<Stmt> statements;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* def NAME(PARAMS) -> RETURNTYPE:
|
||||||
|
* DECLARATIONS
|
||||||
|
* STATEMENTS
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public FuncDef(Location left, Location right,
|
||||||
|
Identifier name, List<TypedVar> params,
|
||||||
|
TypeAnnotation returnType,
|
||||||
|
List<Declaration> declarations, List<Stmt> statements) {
|
||||||
|
super(left, right);
|
||||||
|
this.name = name;
|
||||||
|
this.params = params;
|
||||||
|
this.returnType = returnType;
|
||||||
|
this.declarations = declarations;
|
||||||
|
this.statements = statements;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Identifier getIdentifier() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,34 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Declaration of global variable.
|
||||||
|
*/
|
||||||
|
public class GlobalDecl extends Declaration {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The declared variable.
|
||||||
|
*/
|
||||||
|
public final Identifier variable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for the declaration
|
||||||
|
* global VARIABLE
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public GlobalDecl(Location left, Location right, Identifier variable) {
|
||||||
|
super(left, right);
|
||||||
|
this.variable = variable;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Identifier getIdentifier() {
|
||||||
|
return this.variable;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,29 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A simple identifier.
|
||||||
|
*/
|
||||||
|
public class Identifier extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Text of the identifier.
|
||||||
|
*/
|
||||||
|
public final String name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An AST for the variable, method, or parameter named NAME, spanning
|
||||||
|
* source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public Identifier(Location left, Location right, String name) {
|
||||||
|
super(left, right);
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,40 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Conditional expressions.
|
||||||
|
*/
|
||||||
|
public class IfExpr extends Expr {
|
||||||
|
/**
|
||||||
|
* Boolean condition.
|
||||||
|
*/
|
||||||
|
public final Expr condition;
|
||||||
|
/**
|
||||||
|
* True branch.
|
||||||
|
*/
|
||||||
|
public final Expr thenExpr;
|
||||||
|
/**
|
||||||
|
* False branch.
|
||||||
|
*/
|
||||||
|
public final Expr elseExpr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* THENEXPR if CONDITION else ELSEEXPR
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public IfExpr(Location left, Location right,
|
||||||
|
Expr condition, Expr thenExpr, Expr elseExpr) {
|
||||||
|
super(left, right);
|
||||||
|
this.condition = condition;
|
||||||
|
this.thenExpr = thenExpr;
|
||||||
|
this.elseExpr = elseExpr;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Conditional statement.
|
||||||
|
*/
|
||||||
|
public class IfStmt extends Stmt {
|
||||||
|
/**
|
||||||
|
* Test condition.
|
||||||
|
*/
|
||||||
|
public final Expr condition;
|
||||||
|
/**
|
||||||
|
* "True" branch.
|
||||||
|
*/
|
||||||
|
public final List<Stmt> thenBody;
|
||||||
|
/**
|
||||||
|
* "False" branch.
|
||||||
|
*/
|
||||||
|
public final List<Stmt> elseBody;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* if CONDITION:
|
||||||
|
* THENBODY
|
||||||
|
* else:
|
||||||
|
* ELSEBODY
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public IfStmt(Location left, Location right,
|
||||||
|
Expr condition, List<Stmt> thenBody, List<Stmt> elseBody) {
|
||||||
|
super(left, right);
|
||||||
|
this.condition = condition;
|
||||||
|
this.thenBody = thenBody;
|
||||||
|
this.elseBody = elseBody;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,35 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List-indexing expression.
|
||||||
|
*/
|
||||||
|
public class IndexExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indexed list.
|
||||||
|
*/
|
||||||
|
public final Expr list;
|
||||||
|
/**
|
||||||
|
* Expression for index value.
|
||||||
|
*/
|
||||||
|
public final Expr index;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* LIST[INDEX].
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public IndexExpr(Location left, Location right, Expr list, Expr index) {
|
||||||
|
super(left, right);
|
||||||
|
this.list = list;
|
||||||
|
this.index = index;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,29 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Integer numerals.
|
||||||
|
*/
|
||||||
|
public final class IntegerLiteral extends Literal {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Value denoted.
|
||||||
|
*/
|
||||||
|
public final int value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for the literal VALUE, spanning source
|
||||||
|
* locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public IntegerLiteral(Location left, Location right, int value) {
|
||||||
|
super(left, right);
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,32 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List displays.
|
||||||
|
*/
|
||||||
|
public final class ListExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of element expressions.
|
||||||
|
*/
|
||||||
|
public final List<Expr> elements;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* [ ELEMENTS ].
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public ListExpr(Location left, Location right, List<Expr> elements) {
|
||||||
|
super(left, right);
|
||||||
|
this.elements = elements;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Type denotation for a list type.
|
||||||
|
*/
|
||||||
|
public final class ListType extends TypeAnnotation {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The element of list element.
|
||||||
|
*/
|
||||||
|
public final TypeAnnotation elementType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for the type annotation
|
||||||
|
* [ ELEMENTTYPE ].
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public ListType(Location left, Location right, TypeAnnotation elementType) {
|
||||||
|
super(left, right);
|
||||||
|
this.elementType = elementType;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base of all the literal nodes.
|
||||||
|
* <p>
|
||||||
|
* There is nothing in this class, but it is useful to isolate
|
||||||
|
* expressions that are constant literals.
|
||||||
|
*/
|
||||||
|
public abstract class Literal extends Expr {
|
||||||
|
/**
|
||||||
|
* A literal spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public Literal(Location left, Location right) {
|
||||||
|
super(left, right);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attribute accessor.
|
||||||
|
*/
|
||||||
|
public class MemberExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Object selected from.
|
||||||
|
*/
|
||||||
|
public final Expr object;
|
||||||
|
/**
|
||||||
|
* Name of attribute (instance variable or method).
|
||||||
|
*/
|
||||||
|
public final Identifier member;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* OBJECT.MEMBER.
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public MemberExpr(Location left, Location right,
|
||||||
|
Expr object, Identifier member) {
|
||||||
|
super(left, right);
|
||||||
|
this.object = object;
|
||||||
|
this.member = member;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,38 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method calls.
|
||||||
|
*/
|
||||||
|
public class MethodCallExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Expression for the bound method to be called.
|
||||||
|
*/
|
||||||
|
public final MemberExpr method;
|
||||||
|
/**
|
||||||
|
* Actual parameters.
|
||||||
|
*/
|
||||||
|
public final List<Expr> args;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* METHOD(ARGS).
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public MethodCallExpr(Location left, Location right,
|
||||||
|
MemberExpr method, List<Expr> args) {
|
||||||
|
super(left, right);
|
||||||
|
this.method = method;
|
||||||
|
this.args = args;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,204 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonSubTypes;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonTypeInfo;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
import com.fasterxml.jackson.databind.SerializationFeature;
|
||||||
|
import com.fasterxml.jackson.module.paramnames.ParameterNamesModule;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Root of the AST class hierarchy. Every node has a left and right
|
||||||
|
* location, indicating the start and end of the represented construct
|
||||||
|
* in the source text.
|
||||||
|
* <p>
|
||||||
|
* Every node can be marked with an error message, which serves two purposes:
|
||||||
|
* 1. It indicates that an error message has been issued for this
|
||||||
|
* Node, allowing tne program to reduce cascades of error
|
||||||
|
* messages.
|
||||||
|
* 2. It aids in debugging by making it convenient to see which
|
||||||
|
* Nodes have caused an error.
|
||||||
|
*/
|
||||||
|
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME,
|
||||||
|
include = JsonTypeInfo.As.EXISTING_PROPERTY,
|
||||||
|
property = "kind")
|
||||||
|
/* List of all concrete subclasses of Node. */
|
||||||
|
@JsonSubTypes({
|
||||||
|
@JsonSubTypes.Type(AssignStmt.class),
|
||||||
|
@JsonSubTypes.Type(BinaryExpr.class),
|
||||||
|
@JsonSubTypes.Type(BooleanLiteral.class),
|
||||||
|
@JsonSubTypes.Type(CallExpr.class),
|
||||||
|
@JsonSubTypes.Type(ClassDef.class),
|
||||||
|
@JsonSubTypes.Type(ClassType.class),
|
||||||
|
@JsonSubTypes.Type(CompilerError.class),
|
||||||
|
@JsonSubTypes.Type(Errors.class),
|
||||||
|
@JsonSubTypes.Type(ExprStmt.class),
|
||||||
|
@JsonSubTypes.Type(ForStmt.class),
|
||||||
|
@JsonSubTypes.Type(FuncDef.class),
|
||||||
|
@JsonSubTypes.Type(GlobalDecl.class),
|
||||||
|
@JsonSubTypes.Type(Identifier.class),
|
||||||
|
@JsonSubTypes.Type(IfExpr.class),
|
||||||
|
@JsonSubTypes.Type(IfStmt.class),
|
||||||
|
@JsonSubTypes.Type(IndexExpr.class),
|
||||||
|
@JsonSubTypes.Type(IntegerLiteral.class),
|
||||||
|
@JsonSubTypes.Type(ListExpr.class),
|
||||||
|
@JsonSubTypes.Type(ListType.class),
|
||||||
|
@JsonSubTypes.Type(MemberExpr.class),
|
||||||
|
@JsonSubTypes.Type(MethodCallExpr.class),
|
||||||
|
@JsonSubTypes.Type(NoneLiteral.class),
|
||||||
|
@JsonSubTypes.Type(NonLocalDecl.class),
|
||||||
|
@JsonSubTypes.Type(Program.class),
|
||||||
|
@JsonSubTypes.Type(ReturnStmt.class),
|
||||||
|
@JsonSubTypes.Type(StringLiteral.class),
|
||||||
|
@JsonSubTypes.Type(TypedVar.class),
|
||||||
|
@JsonSubTypes.Type(UnaryExpr.class),
|
||||||
|
@JsonSubTypes.Type(VarDef.class),
|
||||||
|
@JsonSubTypes.Type(WhileStmt.class),
|
||||||
|
})
|
||||||
|
public abstract class Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Node-type indicator for JSON form.
|
||||||
|
*/
|
||||||
|
public final String kind;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Source position information: 0: line number of start, 1: column number
|
||||||
|
* of start, 2: line number of end, 3: column number of end.
|
||||||
|
*/
|
||||||
|
private final int[] location = new int[4];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* First error message "blamed" on this Node. When non-null, indicates
|
||||||
|
* that an error has been found in this Node.
|
||||||
|
*/
|
||||||
|
@JsonInclude(JsonInclude.Include.NON_EMPTY)
|
||||||
|
private String errorMsg;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A Node corresponding to source text between LEFT and RIGHT.
|
||||||
|
*/
|
||||||
|
public Node(Location left, Location right) {
|
||||||
|
if (left != null) {
|
||||||
|
location[0] = left.getLine();
|
||||||
|
location[1] = left.getColumn();
|
||||||
|
}
|
||||||
|
if (right != null) {
|
||||||
|
location[2] = right.getLine();
|
||||||
|
location[3] = right.getColumn();
|
||||||
|
}
|
||||||
|
this.kind = getClass().getSimpleName();
|
||||||
|
this.errorMsg = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return my source location as
|
||||||
|
* { <first line>, <first column>, <last line>, <last column> }.
|
||||||
|
* Result should not be modified, and contents will change after
|
||||||
|
* setLocation().
|
||||||
|
*/
|
||||||
|
public int[] getLocation() {
|
||||||
|
return location;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy LOCATION as getLocation().
|
||||||
|
*/
|
||||||
|
public void setLocation(final int[] location) {
|
||||||
|
System.arraycopy(location, 0, this.location, 0, 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getErrorMsg() {
|
||||||
|
return errorMsg;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setErrorMsg(String msg) {
|
||||||
|
this.errorMsg = msg;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return true iff I have been marked with an error message.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public boolean hasError() {
|
||||||
|
return this.errorMsg != null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Invoke ANALYZER on me as a node of static type T. See the comment
|
||||||
|
* on NodeAnalyzer. Returns modified Node.
|
||||||
|
*/
|
||||||
|
public abstract <T> T dispatch(NodeAnalyzer<T> analyzer);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Print out the AST in JSON format.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
try {
|
||||||
|
return toJSON();
|
||||||
|
} catch (JsonProcessingException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return a serialization of this node in JSON format.
|
||||||
|
*/
|
||||||
|
public String toJSON() throws JsonProcessingException {
|
||||||
|
return mapper.writeValueAsString(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mapper to-and-from serialized JSON.
|
||||||
|
*/
|
||||||
|
private static final ObjectMapper mapper = new ObjectMapper();
|
||||||
|
|
||||||
|
static {
|
||||||
|
mapper.enable(SerializationFeature.INDENT_OUTPUT);
|
||||||
|
mapper.registerModule(new ParameterNamesModule());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a T from JSON, a JSON-serialized T value with class
|
||||||
|
* CLAS.
|
||||||
|
*/
|
||||||
|
public static <T> T fromJSON(String json, Class<T> clas)
|
||||||
|
throws IOException {
|
||||||
|
return mapper.readValue(json, clas);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the result of converting JSON, a JSon-serialization of
|
||||||
|
* a Node value, into the value it serializes.
|
||||||
|
*/
|
||||||
|
public static Node fromJSON(String json)
|
||||||
|
throws IOException {
|
||||||
|
return fromJSON(json, Node.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the result of converting TREE to the value of type T
|
||||||
|
* that it represents, where CLAS reflects T.
|
||||||
|
*/
|
||||||
|
public static <T> T fromJSON(JsonNode tree, Class<T> clas)
|
||||||
|
throws IOException {
|
||||||
|
return mapper.treeToValue(tree, clas);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the translation of serialized value SRC into the
|
||||||
|
* corresponding JSON tree.
|
||||||
|
*/
|
||||||
|
public static JsonNode readTree(String src) throws IOException {
|
||||||
|
return mapper.readTree(src);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,34 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Nonlocal declaration.
|
||||||
|
*/
|
||||||
|
public class NonLocalDecl extends Declaration {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Name of identifier being declared.
|
||||||
|
*/
|
||||||
|
public final Identifier variable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* nonlocal VARIABLE
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public NonLocalDecl(Location left, Location right, Identifier variable) {
|
||||||
|
super(left, right);
|
||||||
|
this.variable = variable;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Identifier getIdentifier() {
|
||||||
|
return this.variable;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The expression 'None'.
|
||||||
|
*/
|
||||||
|
public final class NoneLiteral extends Literal {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for None, spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public NoneLiteral(Location left, Location right) {
|
||||||
|
super(left, right);
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,70 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An entire ChocoPy program.
|
||||||
|
*/
|
||||||
|
public class Program extends Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initial variable, class, and function declarations.
|
||||||
|
*/
|
||||||
|
public final List<Declaration> declarations;
|
||||||
|
/**
|
||||||
|
* Trailing statements.
|
||||||
|
*/
|
||||||
|
public final List<Stmt> statements;
|
||||||
|
/**
|
||||||
|
* Accumulated errors.
|
||||||
|
*/
|
||||||
|
public final Errors errors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for the program
|
||||||
|
* DECLARATIONS
|
||||||
|
* STATEMENTS
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
* <p>
|
||||||
|
* ERRORS is the container for all error messages applying to the
|
||||||
|
* program.
|
||||||
|
*/
|
||||||
|
public Program(Location left, Location right,
|
||||||
|
List<Declaration> declarations, List<Stmt> statements,
|
||||||
|
Errors errors) {
|
||||||
|
super(left, right);
|
||||||
|
this.declarations = declarations;
|
||||||
|
this.statements = statements;
|
||||||
|
if (errors == null) {
|
||||||
|
this.errors = new Errors(new ArrayList<>());
|
||||||
|
} else {
|
||||||
|
this.errors = errors;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true iff there is at least one error in the program.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public boolean hasErrors() {
|
||||||
|
return errors.hasErrors();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A convenience method returning the list of all CompilerErrors for
|
||||||
|
* this program.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public List<CompilerError> getErrorList() {
|
||||||
|
return errors.errors;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return from function.
|
||||||
|
*/
|
||||||
|
public class ReturnStmt extends Stmt {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returned value.
|
||||||
|
*/
|
||||||
|
public final Expr value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* return VALUE
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public ReturnStmt(Location left, Location right, Expr value) {
|
||||||
|
super(left, right);
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base of all AST nodes representing statements.
|
||||||
|
* <p>
|
||||||
|
* There is nothing in this class, but there will be some AST
|
||||||
|
* node types that have fields that are *any statement* or a
|
||||||
|
* list of statements. For those cases, having a field of this type will
|
||||||
|
* encompass all types of statements such as expression statements,
|
||||||
|
* if statements, while statements, etc.
|
||||||
|
*/
|
||||||
|
public abstract class Stmt extends Node {
|
||||||
|
/**
|
||||||
|
* A statement spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public Stmt(Location left, Location right) {
|
||||||
|
super(left, right);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,29 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* String constants.
|
||||||
|
*/
|
||||||
|
public final class StringLiteral extends Literal {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Contents of the literal, not including quotation marks.
|
||||||
|
*/
|
||||||
|
public final String value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for a string literal containing VALUE, spanning source
|
||||||
|
* locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public StringLiteral(Location left, Location right, String value) {
|
||||||
|
super(left, right);
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,16 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base of all AST nodes representing type annotations (list or class
|
||||||
|
* types.
|
||||||
|
*/
|
||||||
|
public abstract class TypeAnnotation extends Node {
|
||||||
|
/**
|
||||||
|
* An annotation spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public TypeAnnotation(Location left, Location right) {
|
||||||
|
super(left, right);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An identifier with attached type annotation.
|
||||||
|
*/
|
||||||
|
public class TypedVar extends Node {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The typed identifier.
|
||||||
|
*/
|
||||||
|
public final Identifier identifier;
|
||||||
|
/**
|
||||||
|
* The declared type.
|
||||||
|
*/
|
||||||
|
public final TypeAnnotation type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* IDENTIFIER : TYPE.
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public TypedVar(Location left, Location right,
|
||||||
|
Identifier identifier, TypeAnnotation type) {
|
||||||
|
super(left, right);
|
||||||
|
this.identifier = identifier;
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An expression applying a unary operator.
|
||||||
|
*/
|
||||||
|
public class UnaryExpr extends Expr {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The text representation of the operator.
|
||||||
|
*/
|
||||||
|
public final String operator;
|
||||||
|
/**
|
||||||
|
* The operand to which it is applied.
|
||||||
|
*/
|
||||||
|
public final Expr operand;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* OPERATOR OPERAND
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public UnaryExpr(Location left, Location right,
|
||||||
|
String operator, Expr operand) {
|
||||||
|
super(left, right);
|
||||||
|
this.operator = operator;
|
||||||
|
this.operand = operand;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,42 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A declaration of a variable (i.e., with type annotation).
|
||||||
|
*/
|
||||||
|
public class VarDef extends Declaration {
|
||||||
|
/**
|
||||||
|
* The variable and its assigned type.
|
||||||
|
*/
|
||||||
|
public final TypedVar var;
|
||||||
|
/**
|
||||||
|
* The initial value assigned.
|
||||||
|
*/
|
||||||
|
public final Literal value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* VAR = VALUE
|
||||||
|
* where VAR has a type annotation, and spanning source
|
||||||
|
* locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public VarDef(Location left, Location right, TypedVar var, Literal value) {
|
||||||
|
super(left, right);
|
||||||
|
this.var = var;
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The identifier defined by this declaration.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Identifier getIdentifier() {
|
||||||
|
return this.var.identifier;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,39 @@
|
|||||||
|
package chocopy.common.astnodes;
|
||||||
|
|
||||||
|
import chocopy.common.analysis.NodeAnalyzer;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory.Location;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indefinite repetition construct.
|
||||||
|
*/
|
||||||
|
public class WhileStmt extends Stmt {
|
||||||
|
/**
|
||||||
|
* Test for whether to continue.
|
||||||
|
*/
|
||||||
|
public final Expr condition;
|
||||||
|
/**
|
||||||
|
* Loop body.
|
||||||
|
*/
|
||||||
|
public final List<Stmt> body;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The AST for
|
||||||
|
* while CONDITION:
|
||||||
|
* BODY
|
||||||
|
* spanning source locations [LEFT..RIGHT].
|
||||||
|
*/
|
||||||
|
public WhileStmt(Location left, Location right,
|
||||||
|
Expr condition, List<Stmt> body) {
|
||||||
|
super(left, right);
|
||||||
|
this.condition = condition;
|
||||||
|
this.body = body;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public <T> T dispatch(NodeAnalyzer<T> analyzer) {
|
||||||
|
return analyzer.analyze(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,25 @@
|
|||||||
|
package chocopy.pa1;
|
||||||
|
|
||||||
|
import chocopy.common.astnodes.Program;
|
||||||
|
import java_cup.runtime.ComplexSymbolFactory;
|
||||||
|
|
||||||
|
import java.io.StringReader;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface between driver and parser.
|
||||||
|
*/
|
||||||
|
public class StudentParser {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the Program AST resulting from parsing INPUT. Turn on
|
||||||
|
* parser debugging iff DEBUG.
|
||||||
|
*/
|
||||||
|
public static Program process(String input, boolean debug) {
|
||||||
|
ChocoPyLexer lexer = new ChocoPyLexer(new StringReader(input));
|
||||||
|
ChocoPyParser parser =
|
||||||
|
new ChocoPyParser(lexer, new ComplexSymbolFactory());
|
||||||
|
return parser.parseProgram(debug);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,82 @@
|
|||||||
|
package chocopy.pa1;
|
||||||
|
import java_cup.runtime.*;
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
/*** Do not change the flags below unless you know what you are doing. ***/
|
||||||
|
|
||||||
|
%unicode
|
||||||
|
%line
|
||||||
|
%column
|
||||||
|
|
||||||
|
%class ChocoPyLexer
|
||||||
|
%public
|
||||||
|
|
||||||
|
%cupsym ChocoPyTokens
|
||||||
|
%cup
|
||||||
|
%cupdebug
|
||||||
|
|
||||||
|
%eofclose false
|
||||||
|
|
||||||
|
/*** Do not change the flags above unless you know what you are doing. ***/
|
||||||
|
|
||||||
|
/* The following code section is copied verbatim to the
|
||||||
|
* generated lexer class. */
|
||||||
|
%{
|
||||||
|
/* The code below includes some convenience methods to create tokens
|
||||||
|
* of a given type and optionally a value that the CUP parser can
|
||||||
|
* understand. Specifically, a lot of the logic below deals with
|
||||||
|
* embedded information about where in the source code a given token
|
||||||
|
* was recognized, so that the parser can report errors accurately.
|
||||||
|
* (It need not be modified for this project.) */
|
||||||
|
|
||||||
|
/** Producer of token-related values for the parser. */
|
||||||
|
final ComplexSymbolFactory symbolFactory = new ComplexSymbolFactory();
|
||||||
|
|
||||||
|
/** Return a terminal symbol of syntactic category TYPE and no
|
||||||
|
* semantic value at the current source location. */
|
||||||
|
private Symbol symbol(int type) {
|
||||||
|
return symbol(type, yytext());
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Return a terminal symbol of syntactic category TYPE and semantic
|
||||||
|
* value VALUE at the current source location. */
|
||||||
|
private Symbol symbol(int type, Object value) {
|
||||||
|
return symbolFactory.newSymbol(ChocoPyTokens.terminalNames[type], type,
|
||||||
|
new ComplexSymbolFactory.Location(yyline + 1, yycolumn + 1),
|
||||||
|
new ComplexSymbolFactory.Location(yyline + 1,yycolumn + yylength()),
|
||||||
|
value);
|
||||||
|
}
|
||||||
|
|
||||||
|
%}
|
||||||
|
|
||||||
|
/* Macros (regexes used in rules below) */
|
||||||
|
|
||||||
|
WhiteSpace = [ \t]
|
||||||
|
LineBreak = \r|\n|\r\n
|
||||||
|
|
||||||
|
IntegerLiteral = 0 | [1-9][0-9]*
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
|
||||||
|
<YYINITIAL> {
|
||||||
|
|
||||||
|
/* Delimiters. */
|
||||||
|
{LineBreak} { return symbol(ChocoPyTokens.NEWLINE); }
|
||||||
|
|
||||||
|
/* Literals. */
|
||||||
|
{IntegerLiteral} { return symbol(ChocoPyTokens.NUMBER,
|
||||||
|
Integer.parseInt(yytext())); }
|
||||||
|
|
||||||
|
/* Operators. */
|
||||||
|
"+" { return symbol(ChocoPyTokens.PLUS, yytext()); }
|
||||||
|
|
||||||
|
/* Whitespace. */
|
||||||
|
{WhiteSpace} { /* ignore */ }
|
||||||
|
}
|
||||||
|
|
||||||
|
<<EOF>> { return symbol(ChocoPyTokens.EOF); }
|
||||||
|
|
||||||
|
/* Error fallback. */
|
||||||
|
[^] { return symbol(ChocoPyTokens.UNRECOGNIZED); }
|
@ -0,0 +1 @@
|
|||||||
|
x = (y = 2)
|
@ -0,0 +1,16 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 6, 1, 6 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 1, 8, 1, 8 ],
|
||||||
|
"message" : "Parse error near token EQ: =",
|
||||||
|
"syntax" : true
|
||||||
|
} ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
print(x = 1)
|
@ -0,0 +1,16 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 7, 1, 7 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"message" : "Parse error near token EQ: =",
|
||||||
|
"syntax" : true
|
||||||
|
} ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,6 @@
|
|||||||
|
def foo(a, b) -> 1:
|
||||||
|
x:int = a
|
||||||
|
return 1
|
||||||
|
|
||||||
|
print(1)
|
||||||
|
print(3**6)
|
@ -0,0 +1,64 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 2, 13, 6, 8 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"name" : "a"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 3, 5, 3, 12 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 12, 3, 12 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 5, 1, 5, 8 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 5, 1, 5, 8 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 1, 5, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 5, 7, 5, 7 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 1, 10, 1, 10 ],
|
||||||
|
"message" : "Parse error near token COMMA: ,",
|
||||||
|
"syntax" : true
|
||||||
|
}, {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"message" : "Parse error near token IDENTIFIER: a",
|
||||||
|
"syntax" : true
|
||||||
|
}, {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 5, 1, 5, 0 ],
|
||||||
|
"message" : "Parse error near token DEDENT: ",
|
||||||
|
"syntax" : true
|
||||||
|
}, {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 6, 9, 6, 9 ],
|
||||||
|
"message" : "Parse error near token TIMES: *",
|
||||||
|
"syntax" : true
|
||||||
|
} ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,3 @@
|
|||||||
|
x = 1
|
||||||
|
y = 2
|
||||||
|
z = 3
|
@ -0,0 +1,47 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 2, 3, 3, 6 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 2, 3, 2, 7 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 3, 2, 3 ],
|
||||||
|
"name" : "y"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 7, 2, 7 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 3, 1, 3, 5 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 1, 3, 1 ],
|
||||||
|
"name" : "z"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 5, 3, 5 ],
|
||||||
|
"value" : 3
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 2, 1, 2, 2 ],
|
||||||
|
"message" : "Parse error near token INDENT: ",
|
||||||
|
"syntax" : true
|
||||||
|
}, {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 3, 1, 3, 0 ],
|
||||||
|
"message" : "Parse error near token DEDENT: ",
|
||||||
|
"syntax" : true
|
||||||
|
} ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
1 + 2
|
||||||
|
3 == 4 or (not False && True)
|
||||||
|
5 + 6
|
||||||
|
7 << 8
|
@ -0,0 +1,65 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 4, 7 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"value" : 1
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 5, 1, 5 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 3, 1, 3, 5 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 3, 1, 3, 5 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 1, 3, 1 ],
|
||||||
|
"value" : 5
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 5, 3, 5 ],
|
||||||
|
"value" : 6
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 4, 6, 4, 6 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 4, 6, 4, 6 ],
|
||||||
|
"value" : 8
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 2, 22, 2, 22 ],
|
||||||
|
"message" : "Parse error near token UNRECOGNIZED: &",
|
||||||
|
"syntax" : true
|
||||||
|
}, {
|
||||||
|
"kind" : "CompilerError",
|
||||||
|
"location" : [ 4, 4, 4, 4 ],
|
||||||
|
"message" : "Parse error near token LT: <",
|
||||||
|
"syntax" : true
|
||||||
|
} ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,2 @@
|
|||||||
|
x[0] = y = z.f = 1
|
||||||
|
z.g = y = x[0]
|
@ -0,0 +1,85 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 2, 15 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 1, 1, 1, 18 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 1, 1, 1, 4 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 3, 1, 3 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 8, 1, 8 ],
|
||||||
|
"name" : "y"
|
||||||
|
}, {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 1, 12, 1, 14 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 12, 1, 12 ],
|
||||||
|
"name" : "z"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 14, 1, 14 ],
|
||||||
|
"name" : "f"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 18, 1, 18 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 2, 1, 2, 14 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 2, 1, 2, 3 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 1, 2, 1 ],
|
||||||
|
"name" : "z"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 3, 2, 3 ],
|
||||||
|
"name" : "g"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 7, 2, 7 ],
|
||||||
|
"name" : "y"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 2, 11, 2, 14 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 11, 2, 11 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
x = y = z = 1
|
@ -0,0 +1,32 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 14 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 1, 1, 1, 13 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"name" : "x"
|
||||||
|
}, {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 5, 1, 5 ],
|
||||||
|
"name" : "y"
|
||||||
|
}, {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"name" : "z"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 13, 1, 13 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
class Foo(object):
|
||||||
|
x:int = 1
|
||||||
|
|
||||||
|
f = Foo()
|
@ -0,0 +1,65 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 4, 10 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "ClassDef",
|
||||||
|
"location" : [ 1, 1, 2, 14 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 7, 1, 9 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"superClass" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 11, 1, 16 ],
|
||||||
|
"name" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 2, 5, 2, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 5, 2, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 5 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 7, 2, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 4, 1, 4, 9 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 1, 4, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 4, 5, 4, 9 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 5, 4, 7 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"args" : [ ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
class Foo(object):
|
||||||
|
x:int = 1
|
||||||
|
|
||||||
|
f = Foo()
|
||||||
|
print(f.x)
|
@ -0,0 +1,91 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 5, 11 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "ClassDef",
|
||||||
|
"location" : [ 1, 1, 2, 14 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 7, 1, 9 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"superClass" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 11, 1, 16 ],
|
||||||
|
"name" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 2, 5, 2, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 5, 2, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 5 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 7, 2, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 4, 1, 4, 9 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 1, 4, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 4, 5, 4, 9 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 5, 4, 7 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"args" : [ ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 5, 1, 5, 10 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 5, 1, 5, 10 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 1, 5, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 5, 7, 5, 9 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 7, 5, 7 ],
|
||||||
|
"name" : "f"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 9, 5, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
class Foo(object):
|
||||||
|
x:int = 1
|
||||||
|
|
||||||
|
f = Foo()
|
||||||
|
f.x = 2
|
@ -0,0 +1,87 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 5, 8 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "ClassDef",
|
||||||
|
"location" : [ 1, 1, 2, 14 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 7, 1, 9 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"superClass" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 11, 1, 16 ],
|
||||||
|
"name" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 2, 5, 2, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 5, 2, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 5 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 7, 2, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 4, 1, 4, 9 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 1, 4, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 4, 5, 4, 9 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 5, 4, 7 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"args" : [ ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 5, 1, 5, 7 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 5, 1, 5, 3 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 1, 5, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 3, 5, 3 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 5, 7, 5, 7 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,8 @@
|
|||||||
|
class Foo(object):
|
||||||
|
x:int = 0
|
||||||
|
|
||||||
|
def __init__(self:"Foo", x:int):
|
||||||
|
self.x = x
|
||||||
|
|
||||||
|
f = Foo(1)
|
||||||
|
print(f.x)
|
@ -0,0 +1,159 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 8, 11 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "ClassDef",
|
||||||
|
"location" : [ 1, 1, 7, 0 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 7, 1, 9 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"superClass" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 11, 1, 16 ],
|
||||||
|
"name" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 2, 5, 2, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 5, 2, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 5 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 7, 2, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 4, 5, 5, 19 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 9, 4, 16 ],
|
||||||
|
"name" : "__init__"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 4, 18, 4, 27 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 18, 4, 21 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 23, 4, 27 ],
|
||||||
|
"className" : "Foo"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 4, 30, 4, 34 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 30, 4, 30 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 32, 4, 34 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 36, 4, 36 ],
|
||||||
|
"className" : "<None>"
|
||||||
|
},
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 5, 9, 5, 18 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 5, 9, 5, 14 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 9, 5, 12 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 14, 5, 14 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 18, 5, 18 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 7, 1, 7, 10 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 1, 7, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 7, 5, 7, 10 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 5, 7, 7 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 7, 9, 7, 9 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 8, 1, 8, 10 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 8, 1, 8, 10 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 1, 8, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 8, 7, 8, 9 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 7, 8, 7 ],
|
||||||
|
"name" : "f"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 9, 8, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,9 @@
|
|||||||
|
class Foo(object):
|
||||||
|
x:int = 0
|
||||||
|
|
||||||
|
def set(self:"Foo", x:int) -> object:
|
||||||
|
self.x = x
|
||||||
|
|
||||||
|
f = Foo()
|
||||||
|
f.set(1)
|
||||||
|
print(f.x)
|
@ -0,0 +1,181 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 9, 11 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "ClassDef",
|
||||||
|
"location" : [ 1, 1, 7, 0 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 7, 1, 9 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"superClass" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 11, 1, 16 ],
|
||||||
|
"name" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 2, 5, 2, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 5, 2, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 5 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 7, 2, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 13, 2, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 4, 5, 5, 19 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 9, 4, 11 ],
|
||||||
|
"name" : "set"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 4, 13, 4, 22 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 13, 4, 16 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 18, 4, 22 ],
|
||||||
|
"className" : "Foo"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 4, 25, 4, 29 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 25, 4, 25 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 27, 4, 29 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 35, 4, 40 ],
|
||||||
|
"className" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 5, 9, 5, 18 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 5, 9, 5, 14 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 9, 5, 12 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 14, 5, 14 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 18, 5, 18 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 7, 1, 7, 9 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 1, 7, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 7, 5, 7, 9 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 5, 7, 7 ],
|
||||||
|
"name" : "Foo"
|
||||||
|
},
|
||||||
|
"args" : [ ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 8, 1, 8, 8 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "MethodCallExpr",
|
||||||
|
"location" : [ 8, 1, 8, 8 ],
|
||||||
|
"method" : {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 8, 1, 8, 5 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 1, 8, 1 ],
|
||||||
|
"name" : "f"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 3, 8, 5 ],
|
||||||
|
"name" : "set"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 8, 7, 8, 7 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 9, 1, 9, 10 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 9, 1, 9, 10 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 1, 9, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 9, 7, 9, 9 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 7, 9, 7 ],
|
||||||
|
"name" : "f"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 9, 9, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,38 @@
|
|||||||
|
count:int = 0
|
||||||
|
|
||||||
|
def foo(s: str) -> int:
|
||||||
|
return len(s)
|
||||||
|
|
||||||
|
class bar(object):
|
||||||
|
p: bool = True
|
||||||
|
|
||||||
|
def baz(self:"bar", xx: [int]) -> str:
|
||||||
|
global count
|
||||||
|
x:int = 0
|
||||||
|
y:int = 1
|
||||||
|
|
||||||
|
def qux(y: int) -> object:
|
||||||
|
nonlocal x
|
||||||
|
if x > y:
|
||||||
|
x = -1
|
||||||
|
|
||||||
|
for x in xx:
|
||||||
|
self.p = x == 2
|
||||||
|
|
||||||
|
qux(0) # Yay! ChocoPy
|
||||||
|
|
||||||
|
count = count + 1
|
||||||
|
|
||||||
|
while x <= 0:
|
||||||
|
if self.p:
|
||||||
|
xx[0] = xx[1]
|
||||||
|
self.p = not self.p
|
||||||
|
x = x + 1
|
||||||
|
elif foo("Long"[0]) == 1:
|
||||||
|
return self is None
|
||||||
|
|
||||||
|
return "Nope"
|
||||||
|
|
||||||
|
print(bar().baz([1,2]))
|
||||||
|
|
||||||
|
|
@ -0,0 +1,613 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 36, 24 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 1, 1, 1, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"name" : "count"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 7, 1, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 13, 1, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 3, 1, 4, 18 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 5, 3, 7 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 3, 9, 3, 14 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 9, 3, 9 ],
|
||||||
|
"name" : "s"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 3, 12, 3, 14 ],
|
||||||
|
"className" : "str"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 3, 20, 3, 22 ],
|
||||||
|
"className" : "int"
|
||||||
|
},
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 4, 5, 4, 17 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 4, 12, 4, 17 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 12, 4, 14 ],
|
||||||
|
"name" : "len"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 16, 4, 16 ],
|
||||||
|
"name" : "s"
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
}, {
|
||||||
|
"kind" : "ClassDef",
|
||||||
|
"location" : [ 6, 1, 36, 0 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 6, 7, 6, 9 ],
|
||||||
|
"name" : "bar"
|
||||||
|
},
|
||||||
|
"superClass" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 6, 11, 6, 16 ],
|
||||||
|
"name" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 7, 5, 7, 18 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 7, 5, 7, 11 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 5, 7, 5 ],
|
||||||
|
"name" : "p"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 7, 8, 7, 11 ],
|
||||||
|
"className" : "bool"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BooleanLiteral",
|
||||||
|
"location" : [ 7, 15, 7, 18 ],
|
||||||
|
"value" : true
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 9, 5, 34, 22 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 9, 9, 11 ],
|
||||||
|
"name" : "baz"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 9, 13, 9, 22 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 13, 9, 16 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 9, 18, 9, 22 ],
|
||||||
|
"className" : "bar"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 9, 25, 9, 33 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 25, 9, 26 ],
|
||||||
|
"name" : "xx"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ListType",
|
||||||
|
"location" : [ 9, 29, 9, 33 ],
|
||||||
|
"elementType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 9, 30, 9, 32 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 9, 39, 9, 41 ],
|
||||||
|
"className" : "str"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "GlobalDecl",
|
||||||
|
"location" : [ 10, 9, 10, 20 ],
|
||||||
|
"variable" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 10, 16, 10, 20 ],
|
||||||
|
"name" : "count"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 11, 9, 11, 17 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 11, 9, 11, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 11, 9, 11, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 11, 11, 11, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 11, 17, 11, 17 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 12, 9, 12, 17 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 12, 9, 12, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 12, 9, 12, 9 ],
|
||||||
|
"name" : "y"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 12, 11, 12, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 12, 17, 12, 17 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 14, 9, 19, 8 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 14, 13, 14, 15 ],
|
||||||
|
"name" : "qux"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 14, 17, 14, 22 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 14, 17, 14, 17 ],
|
||||||
|
"name" : "y"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 14, 20, 14, 22 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 14, 28, 14, 33 ],
|
||||||
|
"className" : "object"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "NonLocalDecl",
|
||||||
|
"location" : [ 15, 13, 15, 22 ],
|
||||||
|
"variable" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 15, 22, 15, 22 ],
|
||||||
|
"name" : "x"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "IfStmt",
|
||||||
|
"location" : [ 16, 13, 19, 8 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 16, 16, 16, 20 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 16, 16, 16, 16 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 16, 20, 16, 20 ],
|
||||||
|
"name" : "y"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"thenBody" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 17, 17, 17, 22 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 17, 17, 17, 17 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "UnaryExpr",
|
||||||
|
"location" : [ 17, 21, 17, 22 ],
|
||||||
|
"operator" : "-",
|
||||||
|
"operand" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 17, 22, 17, 22 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"elseBody" : [ ]
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ForStmt",
|
||||||
|
"location" : [ 19, 9, 22, 8 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 19, 13, 19, 13 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"iterable" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 19, 18, 19, 19 ],
|
||||||
|
"name" : "xx"
|
||||||
|
},
|
||||||
|
"body" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 20, 13, 20, 27 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 20, 13, 20, 18 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 20, 13, 20, 16 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 20, 18, 20, 18 ],
|
||||||
|
"name" : "p"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 20, 22, 20, 27 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 20, 22, 20, 22 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"operator" : "==",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 20, 27, 20, 27 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 22, 9, 22, 14 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 22, 9, 22, 14 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 22, 9, 22, 11 ],
|
||||||
|
"name" : "qux"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 22, 13, 22, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 24, 9, 24, 25 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 24, 9, 24, 13 ],
|
||||||
|
"name" : "count"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 24, 17, 24, 25 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 24, 17, 24, 21 ],
|
||||||
|
"name" : "count"
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 24, 25, 24, 25 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "WhileStmt",
|
||||||
|
"location" : [ 26, 9, 34, 8 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 26, 15, 26, 20 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 26, 15, 26, 15 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"operator" : "<=",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 26, 20, 26, 20 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"body" : [ {
|
||||||
|
"kind" : "IfStmt",
|
||||||
|
"location" : [ 27, 13, 34, 8 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 27, 16, 27, 21 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 27, 16, 27, 19 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 27, 21, 27, 21 ],
|
||||||
|
"name" : "p"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"thenBody" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 28, 17, 28, 29 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 28, 17, 28, 21 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 28, 17, 28, 18 ],
|
||||||
|
"name" : "xx"
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 28, 20, 28, 20 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 28, 25, 28, 29 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 28, 25, 28, 26 ],
|
||||||
|
"name" : "xx"
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 28, 28, 28, 28 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 29, 17, 29, 35 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 29, 17, 29, 22 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 29, 17, 29, 20 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 29, 22, 29, 22 ],
|
||||||
|
"name" : "p"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "UnaryExpr",
|
||||||
|
"location" : [ 29, 26, 29, 35 ],
|
||||||
|
"operator" : "not",
|
||||||
|
"operand" : {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 29, 30, 29, 35 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 29, 30, 29, 33 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 29, 35, 29, 35 ],
|
||||||
|
"name" : "p"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 30, 17, 30, 25 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 30, 17, 30, 17 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 30, 21, 30, 25 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 30, 21, 30, 21 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 30, 25, 30, 25 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"elseBody" : [ {
|
||||||
|
"kind" : "IfStmt",
|
||||||
|
"location" : [ 31, 13, 34, 8 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 31, 18, 31, 36 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 31, 18, 31, 31 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 31, 18, 31, 20 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 31, 22, 31, 30 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "StringLiteral",
|
||||||
|
"location" : [ 31, 22, 31, 27 ],
|
||||||
|
"value" : "Long"
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 31, 29, 31, 29 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
},
|
||||||
|
"operator" : "==",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 31, 36, 31, 36 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"thenBody" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 32, 17, 32, 35 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 32, 24, 32, 35 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 32, 24, 32, 27 ],
|
||||||
|
"name" : "self"
|
||||||
|
},
|
||||||
|
"operator" : "is",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "NoneLiteral",
|
||||||
|
"location" : [ 32, 32, 32, 35 ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"elseBody" : [ ]
|
||||||
|
} ]
|
||||||
|
} ]
|
||||||
|
}, {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 34, 9, 34, 21 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "StringLiteral",
|
||||||
|
"location" : [ 34, 16, 34, 21 ],
|
||||||
|
"value" : "Nope"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 36, 1, 36, 23 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 36, 1, 36, 23 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 36, 1, 36, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "MethodCallExpr",
|
||||||
|
"location" : [ 36, 7, 36, 22 ],
|
||||||
|
"method" : {
|
||||||
|
"kind" : "MemberExpr",
|
||||||
|
"location" : [ 36, 7, 36, 15 ],
|
||||||
|
"object" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 36, 7, 36, 11 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 36, 7, 36, 9 ],
|
||||||
|
"name" : "bar"
|
||||||
|
},
|
||||||
|
"args" : [ ]
|
||||||
|
},
|
||||||
|
"member" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 36, 13, 36, 15 ],
|
||||||
|
"name" : "baz"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "ListExpr",
|
||||||
|
"location" : [ 36, 17, 36, 21 ],
|
||||||
|
"elements" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 36, 18, 36, 18 ],
|
||||||
|
"value" : 1
|
||||||
|
}, {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 36, 20, 36, 20 ],
|
||||||
|
"value" : 2
|
||||||
|
} ]
|
||||||
|
} ]
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
def foo() -> int:
|
||||||
|
return 1
|
||||||
|
|
||||||
|
foo()
|
@ -0,0 +1,48 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 4, 6 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 1, 1, 2, 13 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 5, 1, 7 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"params" : [ ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 14, 1, 16 ],
|
||||||
|
"className" : "int"
|
||||||
|
},
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 2, 5, 2, 12 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 12, 2, 12 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 4, 1, 4, 5 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 4, 1, 4, 5 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 1, 4, 3 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"args" : [ ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
def foo(x:int, y:int) -> bool:
|
||||||
|
return x > y
|
||||||
|
|
||||||
|
foo(1,2)
|
@ -0,0 +1,92 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 4, 9 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 1, 1, 2, 17 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 5, 1, 7 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 1, 9, 1, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 11, 1, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 1, 16, 1, 20 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 16, 1, 16 ],
|
||||||
|
"name" : "y"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 18, 1, 20 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 26, 1, 29 ],
|
||||||
|
"className" : "bool"
|
||||||
|
},
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 2, 5, 2, 16 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 2, 12, 2, 16 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 12, 2, 12 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 16, 2, 16 ],
|
||||||
|
"name" : "y"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 4, 1, 4, 8 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 4, 1, 4, 8 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 1, 4, 3 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 4, 5, 4, 5 ],
|
||||||
|
"value" : 1
|
||||||
|
}, {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 4, 7, 4, 7 ],
|
||||||
|
"value" : 2
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,7 @@
|
|||||||
|
z:int = 0
|
||||||
|
|
||||||
|
def foo(x:int) -> bool:
|
||||||
|
global z
|
||||||
|
return x > z
|
||||||
|
|
||||||
|
foo(1)
|
@ -0,0 +1,105 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 7, 7 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"name" : "z"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 3, 1, 5 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 3, 1, 5, 17 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 5, 3, 7 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 3, 9, 3, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 9, 3, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 3, 11, 3, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 3, 19, 3, 22 ],
|
||||||
|
"className" : "bool"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "GlobalDecl",
|
||||||
|
"location" : [ 4, 5, 4, 12 ],
|
||||||
|
"variable" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 12, 4, 12 ],
|
||||||
|
"name" : "z"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 5, 5, 5, 16 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 5, 12, 5, 16 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 12, 5, 12 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 16, 5, 16 ],
|
||||||
|
"name" : "z"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 7, 1, 7, 6 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 7, 1, 7, 6 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 1, 7, 3 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 7, 5, 7, 5 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
|
||||||
|
def foo(x:int) -> bool:
|
||||||
|
a:int = 0
|
||||||
|
b:int = 1
|
||||||
|
def bar(y: int) -> int:
|
||||||
|
a:int = 2
|
||||||
|
return y
|
||||||
|
return bar(x) > a
|
||||||
|
|
||||||
|
foo(1)
|
@ -0,0 +1,187 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 2, 1, 10, 7 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 2, 1, 8, 22 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 7 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 9, 2, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 9, 2, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 11, 2, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 19, 2, 22 ],
|
||||||
|
"className" : "bool"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 3, 5, 3, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 3, 5, 3, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 5, 3, 5 ],
|
||||||
|
"name" : "a"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 3, 7, 3, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 13, 3, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 4, 5, 4, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 4, 5, 4, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 5, 4, 5 ],
|
||||||
|
"name" : "b"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 7, 4, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 4, 13, 4, 13 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 5, 5, 7, 17 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 9, 5, 11 ],
|
||||||
|
"name" : "bar"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 5, 13, 5, 18 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 13, 5, 13 ],
|
||||||
|
"name" : "y"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 5, 16, 5, 18 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 5, 24, 5, 26 ],
|
||||||
|
"className" : "int"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 6, 9, 6, 17 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 6, 9, 6, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 6, 9, 6, 9 ],
|
||||||
|
"name" : "a"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 6, 11, 6, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 6, 17, 6, 17 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 7, 9, 7, 16 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 16, 7, 16 ],
|
||||||
|
"name" : "y"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 8, 5, 8, 21 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 8, 12, 8, 21 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 8, 12, 8, 17 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 12, 8, 14 ],
|
||||||
|
"name" : "bar"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 16, 8, 16 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ]
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 21, 8, 21 ],
|
||||||
|
"name" : "a"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 10, 1, 10, 6 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 10, 1, 10, 6 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 10, 1, 10, 3 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 10, 5, 10, 5 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,11 @@
|
|||||||
|
|
||||||
|
def foo(x:int) -> bool:
|
||||||
|
a:int = 0
|
||||||
|
b:int = 1
|
||||||
|
def bar(y: int) -> int:
|
||||||
|
nonlocal a
|
||||||
|
a = 2
|
||||||
|
return y
|
||||||
|
return bar(x) > a
|
||||||
|
|
||||||
|
foo(1)
|
@ -0,0 +1,186 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 2, 1, 11, 7 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 2, 1, 9, 22 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 7 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 2, 9, 2, 13 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 9, 2, 9 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 11, 2, 13 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 2, 19, 2, 22 ],
|
||||||
|
"className" : "bool"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 3, 5, 3, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 3, 5, 3, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 5, 3, 5 ],
|
||||||
|
"name" : "a"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 3, 7, 3, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 13, 3, 13 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 4, 5, 4, 13 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 4, 5, 4, 9 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 4, 5, 4, 5 ],
|
||||||
|
"name" : "b"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 4, 7, 4, 9 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 4, 13, 4, 13 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "FuncDef",
|
||||||
|
"location" : [ 5, 5, 8, 17 ],
|
||||||
|
"name" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 9, 5, 11 ],
|
||||||
|
"name" : "bar"
|
||||||
|
},
|
||||||
|
"params" : [ {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 5, 13, 5, 18 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 13, 5, 13 ],
|
||||||
|
"name" : "y"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 5, 16, 5, 18 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"returnType" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 5, 24, 5, 26 ],
|
||||||
|
"className" : "int"
|
||||||
|
},
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "NonLocalDecl",
|
||||||
|
"location" : [ 6, 9, 6, 18 ],
|
||||||
|
"variable" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 6, 18, 6, 18 ],
|
||||||
|
"name" : "a"
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 7, 9, 7, 13 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 7, 9, 7, 9 ],
|
||||||
|
"name" : "a"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 7, 13, 7, 13 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 8, 9, 8, 16 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 8, 16, 8, 16 ],
|
||||||
|
"name" : "y"
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ReturnStmt",
|
||||||
|
"location" : [ 9, 5, 9, 21 ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 9, 12, 9, 21 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 9, 12, 9, 17 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 12, 9, 14 ],
|
||||||
|
"name" : "bar"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 16, 9, 16 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ]
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 9, 21, 9, 21 ],
|
||||||
|
"name" : "a"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 11, 1, 11, 6 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 11, 1, 11, 6 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 11, 1, 11, 3 ],
|
||||||
|
"name" : "foo"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 11, 5, 11, 5 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
3 if 1 > 2 else 4
|
@ -0,0 +1,43 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 18 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 17 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "IfExpr",
|
||||||
|
"location" : [ 1, 1, 1, 17 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 6, 1, 10 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 6, 1, 6 ],
|
||||||
|
"value" : 1
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 10, 1, 10 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"thenExpr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"value" : 3
|
||||||
|
},
|
||||||
|
"elseExpr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 17, 1, 17 ],
|
||||||
|
"value" : 4
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
3 if 1 > 2 else 4 if 1 < 0 else 5
|
@ -0,0 +1,67 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 34 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 33 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "IfExpr",
|
||||||
|
"location" : [ 1, 1, 1, 33 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 6, 1, 10 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 6, 1, 6 ],
|
||||||
|
"value" : 1
|
||||||
|
},
|
||||||
|
"operator" : ">",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 10, 1, 10 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"thenExpr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"value" : 3
|
||||||
|
},
|
||||||
|
"elseExpr" : {
|
||||||
|
"kind" : "IfExpr",
|
||||||
|
"location" : [ 1, 17, 1, 33 ],
|
||||||
|
"condition" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 22, 1, 26 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 22, 1, 22 ],
|
||||||
|
"value" : 1
|
||||||
|
},
|
||||||
|
"operator" : "<",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 26, 1, 26 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"thenExpr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 17, 1, 17 ],
|
||||||
|
"value" : 4
|
||||||
|
},
|
||||||
|
"elseExpr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 33, 1, 33 ],
|
||||||
|
"value" : 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
a + b[i][j]
|
@ -0,0 +1,47 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 12 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 11 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 1, 1, 11 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"name" : "a"
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 1, 5, 1, 11 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "IndexExpr",
|
||||||
|
"location" : [ 1, 5, 1, 8 ],
|
||||||
|
"list" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 5, 1, 5 ],
|
||||||
|
"name" : "b"
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 7, 1, 7 ],
|
||||||
|
"name" : "i"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"index" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 10, 1, 10 ],
|
||||||
|
"name" : "j"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
1 + 2 + 3
|
@ -0,0 +1,39 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 10 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "BinaryExpr",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"left" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"value" : 1
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 5, 1, 5 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"operator" : "+",
|
||||||
|
"right" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"value" : 3
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
-1
|
@ -0,0 +1,24 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 3 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 2 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "UnaryExpr",
|
||||||
|
"location" : [ 1, 1, 1, 2 ],
|
||||||
|
"operator" : "-",
|
||||||
|
"operand" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 2, 1, 2 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
x:int = 1
|
||||||
|
|
||||||
|
x = 2
|
||||||
|
|
||||||
|
print(x)
|
@ -0,0 +1,63 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 5, 9 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 3, 1, 5 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "AssignStmt",
|
||||||
|
"location" : [ 3, 1, 3, 5 ],
|
||||||
|
"targets" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 1, 3, 1 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ],
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 5, 3, 5 ],
|
||||||
|
"value" : 2
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 5, 1, 5, 8 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 5, 1, 5, 8 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 1, 5, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 5, 7, 5, 7 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,7 @@
|
|||||||
|
True
|
||||||
|
False
|
||||||
|
1
|
||||||
|
None
|
||||||
|
"This is a string"
|
||||||
|
[1, 2, 3]
|
||||||
|
|
@ -0,0 +1,70 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 6, 10 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 4 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "BooleanLiteral",
|
||||||
|
"location" : [ 1, 1, 1, 4 ],
|
||||||
|
"value" : true
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 2, 1, 2, 5 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "BooleanLiteral",
|
||||||
|
"location" : [ 2, 1, 2, 5 ],
|
||||||
|
"value" : false
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 3, 1, 3, 1 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 3, 1, 3, 1 ],
|
||||||
|
"value" : 1
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 4, 1, 4, 4 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "NoneLiteral",
|
||||||
|
"location" : [ 4, 1, 4, 4 ]
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 5, 1, 5, 18 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "StringLiteral",
|
||||||
|
"location" : [ 5, 1, 5, 18 ],
|
||||||
|
"value" : "This is a string"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 6, 1, 6, 9 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "ListExpr",
|
||||||
|
"location" : [ 6, 1, 6, 9 ],
|
||||||
|
"elements" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 6, 2, 6, 2 ],
|
||||||
|
"value" : 1
|
||||||
|
}, {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 6, 5, 6, 5 ],
|
||||||
|
"value" : 2
|
||||||
|
}, {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 6, 8, 6, 8 ],
|
||||||
|
"value" : 3
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
print(1)
|
@ -0,0 +1,28 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"declarations" : [ ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 1, 1, 1, 8 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 1, 1, 1, 8 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 7, 1, 7 ],
|
||||||
|
"value" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
x:int = 0
|
||||||
|
for x in [1, 2, 3]:
|
||||||
|
print(x)
|
||||||
|
|
@ -0,0 +1,76 @@
|
|||||||
|
{
|
||||||
|
"kind" : "Program",
|
||||||
|
"location" : [ 1, 1, 5, 1 ],
|
||||||
|
"declarations" : [ {
|
||||||
|
"kind" : "VarDef",
|
||||||
|
"location" : [ 1, 1, 1, 9 ],
|
||||||
|
"var" : {
|
||||||
|
"kind" : "TypedVar",
|
||||||
|
"location" : [ 1, 1, 1, 5 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 1, 1, 1, 1 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"type" : {
|
||||||
|
"kind" : "ClassType",
|
||||||
|
"location" : [ 1, 3, 1, 5 ],
|
||||||
|
"className" : "int"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value" : {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 1, 9, 1, 9 ],
|
||||||
|
"value" : 0
|
||||||
|
}
|
||||||
|
} ],
|
||||||
|
"statements" : [ {
|
||||||
|
"kind" : "ForStmt",
|
||||||
|
"location" : [ 2, 1, 5, 1 ],
|
||||||
|
"identifier" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 2, 5, 2, 5 ],
|
||||||
|
"name" : "x"
|
||||||
|
},
|
||||||
|
"iterable" : {
|
||||||
|
"kind" : "ListExpr",
|
||||||
|
"location" : [ 2, 10, 2, 18 ],
|
||||||
|
"elements" : [ {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 11, 2, 11 ],
|
||||||
|
"value" : 1
|
||||||
|
}, {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 14, 2, 14 ],
|
||||||
|
"value" : 2
|
||||||
|
}, {
|
||||||
|
"kind" : "IntegerLiteral",
|
||||||
|
"location" : [ 2, 17, 2, 17 ],
|
||||||
|
"value" : 3
|
||||||
|
} ]
|
||||||
|
},
|
||||||
|
"body" : [ {
|
||||||
|
"kind" : "ExprStmt",
|
||||||
|
"location" : [ 3, 5, 3, 12 ],
|
||||||
|
"expr" : {
|
||||||
|
"kind" : "CallExpr",
|
||||||
|
"location" : [ 3, 5, 3, 12 ],
|
||||||
|
"function" : {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 5, 3, 9 ],
|
||||||
|
"name" : "print"
|
||||||
|
},
|
||||||
|
"args" : [ {
|
||||||
|
"kind" : "Identifier",
|
||||||
|
"location" : [ 3, 11, 3, 11 ],
|
||||||
|
"name" : "x"
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
} ]
|
||||||
|
} ],
|
||||||
|
"errors" : {
|
||||||
|
"errors" : [ ],
|
||||||
|
"kind" : "Errors",
|
||||||
|
"location" : [ 0, 0, 0, 0 ]
|
||||||
|
}
|
||||||
|
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue