简单编译到C语言的语义分析

时间:2013-10-06 22:09:29

标签: python c compiler-construction intermediate-language nxc

所以我正在创建一个简单的编译到C语言,其语法类似于Python。 以下是一些示例源代码:

# All comments start with pound signs

# Integer declaration
speed = 4
motor = 69.5
text = "hey +  guys!"
junk =   5    +4

# Move function
def move():
  speed = speed + 1
  print speed

# Main function (program entry)
def main():
  localvar = 43.2
  move()
  if true:
    print localvar

与Python一样,该语言强调缩进策略的可读性。它还有一个非常宽松的类型声明系统。类型由上下文决定。

object = 5            // Creates an integer
object_two = "stuff"  // Creates a string
object_three = 5.23   // Creates a float

我上面的示例源代码在内部表示如下:

[
  [
    "GLOBAL",
    [
      "speed = 4",
      "motor = 69.5",
      "text = \"hey +  guys!\"",
      "junk =   5    +4"
    ],
    [
      "SCOPE",
      [
        "speed",
        "motor",
        "text",
        "junk"
      ],
      [
        "INT",
        "FLOAT",
        "STRING",
        "INT"
      ],
      [
        0,
        1,
        2,
        3
      ]
    ]
  ],
  [
    "def move():",
    [
      "  speed = speed + 1",
      "  print speed"
    ],
    [
      "SCOPE",
      [
        "speed",
        "motor",
        "text",
        "junk"
      ],
      [
        "GLOBAL",
        "GLOBAL",
        "GLOBAL",
        "GLOBAL"
      ],
      [
        0,
        1,
        2,
        3
      ]
    ]
  ],
  [
    "def main():",
    [
      "  localvar = 43.2",
      "  move()",
      "  if true:",
      "    print localvar"
    ],
    [
      "SCOPE",
      [
        "speed",
        "motor",
        "text",
        "junk",
        "localvar"
      ],
      [
        "GLOBAL",
        "GLOBAL",
        "GLOBAL",
        "GLOBAL",
        "FLOAT"
      ],
      [
        0,
        1,
        2,
        3,
        0
      ]
    ]
  ]
]

每个函数都包含在此表示中,以及各自的局部变量及其类型(也是它们在函数中声明的行的索引)。

我正在尝试将此中间表示转换为实际的C代码(实际上它是NXC代码,因此它与C稍有不同)。

我的问题是如何理解变量类型(特别是函数参数中声明的变量)。我可以做到这一点的唯一方法是根据调用函数的上下文进行猜测。

更不用说,我正在以线性方式创建中间表示。如果定义了一个函数但直到稍后才调用会发生什么?在获得所有必要的类型信息之前,我是否必须进行几次运行来修改此中间表示?

0 个答案:

没有答案