Skip to content

Go로 컴파일되는 한글 프로그래밍 언어

Notifications You must be signed in to change notification settings

abiriadev/hango

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

한고

Go로 컴파일되는 한글 프로그래밍 언어

개요

한고는 Go에 기반한 한글 프로그래밍 언어로, 다음 개념의 증명을 위해 만들어졌습니다.

  1. 라틴 문자에 불필요하게 의존하는 식별자 공개 원칙에 대한 신선한 비판1
  2. 외부 라이브러리나 직접 짠 렉서 혹은 파서 없이 내장 text/scanner만으로 구현이 가능함의 증명

예시

묶음 main

사용 "fmt"

함수 main() {
	fmt.Println("안녕, 세상!")
}

한고 키워드

한고는 주어진 키워드를 Go의 키워드로 1:1 변환시키는 방법으로 컴파일됩니다.

한고 키워드 Go 키워드 한고 키워드 Go 키워드
정지 break 묶음 package
기본 default 비교 switch
함수 func 상수 const
특성 interface 이어서 fallthrough
선택 select 만약 if
경우 case 범위 range
지연 defer type
출발 go 계속 continue
사전 map 반복 for
구조체 struct 사용 import
통로 chan 반환 return
아니라면 else 선언 var
이동 goto

빌드 및 사용법

먼저 본 저장소를 복제합니다.

$ git clone https://github.com/abiriadev/hango && cd hango

다음 명령을 통해 hango 컴파일러를 설치합니다.

$ go install ./cmd/hango

컴파일하고자 하는 한고 파일을 인자로 제공합니다. 이때 확장자는 반드시 .hgo여야 합니다.

예를 들어, 본 저장소의 examples 폴더 내의 모든 파일을 컴파일하려면 다음 명령을 사용합니다.

$ hango ./examples/*

아무 인자도 주어지지 않는다면 표준 입력에서 한고 소스를 읽어 컴파일된 결과를 표준 출력으로 내보냅니다.

$ hango < ./examples/hello.hgo

고민중인 기능

본 프로젝트의 원 목적은 표준 라이브러리만 사용하여 100줄 이내의 짧은 코드만으로 Go와 1:1 변환 가능한 언어를 구현하는 것이었습니다.

당초 목적한 구현이 표준 라이브러리 없이 가능함이 증명되었으므로 앞으로는 다음과 같은 기능을 차차 추가할 예정입니다:

  • 공개 키워드
  • Context-sensitive transformations: 자체 파서 구현 필요
  • Syntax highlighting support
  • 더 적은 키워드
  • 기본 타입(int, string), 빌트인 함수(len, make) 지원: name resolution needed

Footnotes

  1. 사실 한고 자체는 식별자가 아닌 키워드만 한글화하므로 본 문제와 무관합니다. 단, 100% 한글만으로 이루어진 식별자를 공개하는 것이 애시당초 불가능함을 일깨워 줄 수 있습니다.

About

Go로 컴파일되는 한글 프로그래밍 언어

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages