yacc

    0

    1답변

    의 값이 I bison 사양에 다음과 같은 제품이 있습니다 op : '+' { printf("%d %d %c\n", $1, '+', '+'); } 때 나는 입력 나는 다음과 같은 출력을 얻을 + : 0 43 + 을 누군가 $1의 값이 0 인 이유를 설명 할 수 있습니까? 43이 아니어야합니까? 내가 뭘 놓치고 있니? 편집 아무 플렉스 파일이 없지만,

    1

    1답변

    저는 독자적으로 컴파일러를 연구하려고합니다. 나는 책을 읽는 중이며 이것은 운동 중 하나입니다 (나는 이것이 숙제가 아니라는 것을 강조하고 싶습니다., 나는 이것을 스스로하고 있습니다). |>수 - 다음 문법 LISP와 같은 접두어 표기법 lexp에서 간단한 산술 식을 나타냅니다 (op lexp-seq) op -> + | * | + lexp-seq -> l

    2

    1답변

    yacc에 내 첫 번째 파서를 쓰고 있습니다. 성명 모드 표 머리글 모드 내 파서 싶습니다 표 행 모드 문에서 시작 : 나는 3 "모드"가있는 파일을 구문 분석하고 싶습니다 모드에서 마이너스 기호로 구성된 행을 볼 때 테이블 표제어 모드로 전환하십시오. 그것은 마이너스 기호의 또 다른 라인을 볼 때, 테이블 행 모드로 전환하고,이보고 마지막 때 마이너스 기

    0

    1답변

    에서 변수를 저장하는 방법, 파이썬의 작은 부분 집합에 대한 컴파일러를 작성해야 : 이 언어는 하나의 방법 이 기능이 아니므로했다 I 하나의 어휘 범위만을 다루고 있습니다. 이 파이썬 서브 세트는 자바 바이트 코드로 변환 될 것입니다. 나는 이미 렉시 컬 분석과 파싱 트리 (lex 및 yacc 사용)를 수행했습니다. 코드 생성과 관련되어 있습니다. 우리는

    0

    1답변

    그래서 나는 Bison을 처음 접했고 간단한 계산기를 만들려고 노력하고 있습니다. 필자가 bison -d 명령을 실행하면 7 줄이기/줄이기 충돌이 발생하며 실제로이 이유가 확실하지 않다는 것을 알았습니다. 문법에 나쁜 논리가 있기 때문에 필자는 그것을 찾을 수 없습니다. 그래서 여기에 .Y 파일의 코드는 다음과 같습니다는 %{ #include <stdio

    3

    1답변

    계산기 온라인에서 찾은 예제를 실행하려고합니다. 하지만 gcc 명령을 실행할 때마다이 오류가 표시됩니다. 여기에 내가 실행하는 명령은 다음과 같습니다 flex -l calc3.l yacc -vd calc3.y gcc y.tab.c -lm -ll -> 나는이 오류 메시지가있어이 시점에서 다음은 /tmp/ccPOq58f.o : In function 'y

    0

    1답변

    내 대학에서 컴파일러 디자인 과정을 마친 후 간단한 프로그래밍 언어로 컴파일러를 만들었지 만 파서에 문제가 있습니다. 나는 컴파일러를 mosml로 만들고 내장 파서 mosmlyac을 사용하여 파서를 구성했다. 다음은 문법과 연관성 + 우선 순위를 보여주는 파서의 발췌 부분입니다. ... %right ASSIGN %left OR %left AND %n

    1

    3답변

    간체화 된 Java 언어로 자체 제작 된 컴파일러를 실행하려고하는데, 항상 세그먼트 화 오류로 끝납니다. 목표는 추상 구문 트리를 작성하는 것입니다. 또한 valgrind를 사용하여 디버깅을 시도했지만 tool이 내 PC에서 bison과 flex에 문제가있는 것 같습니다. 도와주세요. Lexfile : %{ #include <stdio.h> #inclu

    0

    1답변

    Yacc/Bison에서 부모 규칙을 어떻게 알 수 있습니까 그에 따라 조치를 취할 수 있습니까? 예를 들어 : Module :ModuleName "=" Functions Functions :Functions Function | Function Function : DEF ID ARGS BODY {

    0

    1답변

    PLY를 사용하여 간단한 파서를 작성하려고하지만 아래 파서는 모든 NEWLINE 이후 첫 번째 문자열을 잃게됩니다. 입력 내용은 "a b c \ nb d e \ nc f"입니다. 파서는 상태 (0, (('a', 'b'), 'c'), 0)로 구문 분석하지만 다음 토큰 'b'는 손실됩니다. 두 번째 라인 문은 state (0, ((''d ','e '), 0)입