Merge branch 'main' into mj-run-param
This commit is contained in:
commit
3b6aaf2303
7
.gitignore
vendored
7
.gitignore
vendored
|
@ -5,3 +5,10 @@ build
|
||||||
log.html
|
log.html
|
||||||
package-lock.json
|
package-lock.json
|
||||||
target
|
target
|
||||||
|
/*.a
|
||||||
|
/*.dylib
|
||||||
|
/*.so*
|
||||||
|
*.o
|
||||||
|
/bindings/c/*.h
|
||||||
|
/bindings/c/tree-sitter-*.pc
|
||||||
|
/.build
|
||||||
|
|
114
Makefile
Normal file
114
Makefile
Normal file
|
@ -0,0 +1,114 @@
|
||||||
|
VERSION := 0.1.2
|
||||||
|
|
||||||
|
# Repository
|
||||||
|
SRC_DIR := src
|
||||||
|
|
||||||
|
PARSER_REPO_URL := $(shell git -C $(SRC_DIR) remote get-url origin )
|
||||||
|
|
||||||
|
ifeq (, $(PARSER_NAME))
|
||||||
|
PARSER_NAME := $(shell basename $(PARSER_REPO_URL))
|
||||||
|
PARSER_NAME := $(subst tree-sitter-,,$(PARSER_NAME))
|
||||||
|
PARSER_NAME := $(subst .git,,$(PARSER_NAME))
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq (, $(PARSER_URL))
|
||||||
|
PARSER_URL := $(subst :,/,$(PARSER_REPO_URL))
|
||||||
|
PARSER_URL := $(subst git@,https://,$(PARSER_URL))
|
||||||
|
PARSER_URL := $(subst .git,,$(PARSER_URL))
|
||||||
|
endif
|
||||||
|
|
||||||
|
UPPER_PARSER_NAME := $(shell echo $(PARSER_NAME) | tr a-z A-Z )
|
||||||
|
|
||||||
|
# install directory layout
|
||||||
|
PREFIX ?= /usr/local
|
||||||
|
INCLUDEDIR ?= $(PREFIX)/include
|
||||||
|
LIBDIR ?= $(PREFIX)/lib
|
||||||
|
PCLIBDIR ?= $(LIBDIR)/pkgconfig
|
||||||
|
|
||||||
|
# collect C++ sources, and link if necessary
|
||||||
|
CPPSRC := $(wildcard $(SRC_DIR)/*.cc)
|
||||||
|
|
||||||
|
ifeq (, $(CPPSRC))
|
||||||
|
ADDITIONALLIBS :=
|
||||||
|
else
|
||||||
|
ADDITIONALLIBS := -lc++
|
||||||
|
endif
|
||||||
|
|
||||||
|
# collect sources
|
||||||
|
SRC := $(wildcard $(SRC_DIR)/*.c)
|
||||||
|
SRC += $(CPPSRC)
|
||||||
|
OBJ := $(addsuffix .o,$(basename $(SRC)))
|
||||||
|
|
||||||
|
# ABI versioning
|
||||||
|
SONAME_MAJOR := 0
|
||||||
|
SONAME_MINOR := 0
|
||||||
|
|
||||||
|
CFLAGS ?= -O3 -Wall -Wextra -I$(SRC_DIR)
|
||||||
|
CXXFLAGS ?= -O3 -Wall -Wextra -I$(SRC_DIR)
|
||||||
|
override CFLAGS += -std=gnu99 -fPIC
|
||||||
|
override CXXFLAGS += -fPIC
|
||||||
|
|
||||||
|
# OS-specific bits
|
||||||
|
ifeq ($(shell uname),Darwin)
|
||||||
|
SOEXT = dylib
|
||||||
|
SOEXTVER_MAJOR = $(SONAME_MAJOR).dylib
|
||||||
|
SOEXTVER = $(SONAME_MAJOR).$(SONAME_MINOR).dylib
|
||||||
|
LINKSHARED := $(LINKSHARED)-dynamiclib -Wl,
|
||||||
|
ifneq ($(ADDITIONALLIBS),)
|
||||||
|
LINKSHARED := $(LINKSHARED)$(ADDITIONALLIBS),
|
||||||
|
endif
|
||||||
|
LINKSHARED := $(LINKSHARED)-install_name,$(LIBDIR)/libtree-sitter-$(PARSER_NAME).$(SONAME_MAJOR).dylib,-rpath,@executable_path/../Frameworks
|
||||||
|
else
|
||||||
|
SOEXT = so
|
||||||
|
SOEXTVER_MAJOR = so.$(SONAME_MAJOR)
|
||||||
|
SOEXTVER = so.$(SONAME_MAJOR).$(SONAME_MINOR)
|
||||||
|
LINKSHARED := $(LINKSHARED)-shared -Wl,
|
||||||
|
ifneq ($(ADDITIONALLIBS),)
|
||||||
|
LINKSHARED := $(LINKSHARED)$(ADDITIONALLIBS),
|
||||||
|
endif
|
||||||
|
LINKSHARED := $(LINKSHARED)-soname,libtree-sitter-$(PARSER_NAME).so.$(SONAME_MAJOR)
|
||||||
|
endif
|
||||||
|
ifneq (,$(filter $(shell uname),FreeBSD NetBSD DragonFly))
|
||||||
|
PCLIBDIR := $(PREFIX)/libdata/pkgconfig
|
||||||
|
endif
|
||||||
|
|
||||||
|
all: libtree-sitter-$(PARSER_NAME).a libtree-sitter-$(PARSER_NAME).$(SOEXTVER) bindings/c/$(PARSER_NAME).h bindings/c/tree-sitter-$(PARSER_NAME).pc
|
||||||
|
|
||||||
|
libtree-sitter-$(PARSER_NAME).a: $(OBJ)
|
||||||
|
$(AR) rcs $@ $^
|
||||||
|
|
||||||
|
libtree-sitter-$(PARSER_NAME).$(SOEXTVER): $(OBJ)
|
||||||
|
$(CC) $(LDFLAGS) $(LINKSHARED) $^ $(LDLIBS) -o $@
|
||||||
|
ln -sf $@ libtree-sitter-$(PARSER_NAME).$(SOEXT)
|
||||||
|
ln -sf $@ libtree-sitter-$(PARSER_NAME).$(SOEXTVER_MAJOR)
|
||||||
|
|
||||||
|
bindings/c/$(PARSER_NAME).h:
|
||||||
|
sed -e 's|@UPPER_PARSERNAME@|$(UPPER_PARSER_NAME)|' \
|
||||||
|
-e 's|@PARSERNAME@|$(PARSER_NAME)|' \
|
||||||
|
bindings/c/tree-sitter.h.in > $@
|
||||||
|
|
||||||
|
bindings/c/tree-sitter-$(PARSER_NAME).pc:
|
||||||
|
sed -e 's|@LIBDIR@|$(LIBDIR)|;s|@INCLUDEDIR@|$(INCLUDEDIR)|;s|@VERSION@|$(VERSION)|' \
|
||||||
|
-e 's|=$(PREFIX)|=$${prefix}|' \
|
||||||
|
-e 's|@PREFIX@|$(PREFIX)|' \
|
||||||
|
-e 's|@ADDITIONALLIBS@|$(ADDITIONALLIBS)|' \
|
||||||
|
-e 's|@PARSERNAME@|$(PARSER_NAME)|' \
|
||||||
|
-e 's|@PARSERURL@|$(PARSER_URL)|' \
|
||||||
|
bindings/c/tree-sitter.pc.in > $@
|
||||||
|
|
||||||
|
install: all
|
||||||
|
install -d '$(DESTDIR)$(LIBDIR)'
|
||||||
|
install -m755 libtree-sitter-$(PARSER_NAME).a '$(DESTDIR)$(LIBDIR)'/libtree-sitter-$(PARSER_NAME).a
|
||||||
|
install -m755 libtree-sitter-$(PARSER_NAME).$(SOEXTVER) '$(DESTDIR)$(LIBDIR)'/libtree-sitter-$(PARSER_NAME).$(SOEXTVER)
|
||||||
|
ln -sf libtree-sitter-$(PARSER_NAME).$(SOEXTVER) '$(DESTDIR)$(LIBDIR)'/libtree-sitter-$(PARSER_NAME).$(SOEXTVER_MAJOR)
|
||||||
|
ln -sf libtree-sitter-$(PARSER_NAME).$(SOEXTVER) '$(DESTDIR)$(LIBDIR)'/libtree-sitter-$(PARSER_NAME).$(SOEXT)
|
||||||
|
install -d '$(DESTDIR)$(INCLUDEDIR)'/tree_sitter
|
||||||
|
install -m644 bindings/c/$(PARSER_NAME).h '$(DESTDIR)$(INCLUDEDIR)'/tree_sitter/
|
||||||
|
install -d '$(DESTDIR)$(PCLIBDIR)'
|
||||||
|
install -m644 bindings/c/tree-sitter-$(PARSER_NAME).pc '$(DESTDIR)$(PCLIBDIR)'/
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f $(OBJ) libtree-sitter-$(PARSER_NAME).a libtree-sitter-$(PARSER_NAME).$(SOEXT) libtree-sitter-$(PARSER_NAME).$(SOEXTVER_MAJOR) libtree-sitter-$(PARSER_NAME).$(SOEXTVER)
|
||||||
|
rm -f bindings/c/$(PARSER_NAME).h bindings/c/tree-sitter-$(PARSER_NAME).pc
|
||||||
|
|
||||||
|
.PHONY: all install clean
|
38
Package.swift
Normal file
38
Package.swift
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
// swift-tools-version:5.3
|
||||||
|
|
||||||
|
import PackageDescription
|
||||||
|
|
||||||
|
let package = Package(
|
||||||
|
name: "TreeSitterDockerfile",
|
||||||
|
platforms: [.macOS(.v10_13), .iOS(.v11)],
|
||||||
|
products: [
|
||||||
|
.library(name: "TreeSitterDockerfile", targets: ["TreeSitterDockerfile"]),
|
||||||
|
],
|
||||||
|
dependencies: [],
|
||||||
|
targets: [
|
||||||
|
.target(name: "TreeSitterDockerfile",
|
||||||
|
path: ".",
|
||||||
|
exclude: [
|
||||||
|
"binding.gyp",
|
||||||
|
"bindings",
|
||||||
|
"Cargo.toml",
|
||||||
|
"corpus",
|
||||||
|
"examples",
|
||||||
|
"grammar.js",
|
||||||
|
"LICENSE",
|
||||||
|
"Makefile",
|
||||||
|
"package.json",
|
||||||
|
"README.md",
|
||||||
|
"src/grammar.json",
|
||||||
|
"src/node-types.json",
|
||||||
|
],
|
||||||
|
sources: [
|
||||||
|
"src/parser.c",
|
||||||
|
],
|
||||||
|
resources: [
|
||||||
|
.copy("queries")
|
||||||
|
],
|
||||||
|
publicHeadersPath: "bindings/swift",
|
||||||
|
cSettings: [.headerSearchPath("src")])
|
||||||
|
]
|
||||||
|
)
|
16
bindings/c/tree-sitter.h.in
Normal file
16
bindings/c/tree-sitter.h.in
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#ifndef TREE_SITTER_@UPPER_PARSERNAME@_H_
|
||||||
|
#define TREE_SITTER_@UPPER_PARSERNAME@_H_
|
||||||
|
|
||||||
|
#include <tree_sitter/parser.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern TSLanguage *tree_sitter_@PARSERNAME@();
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // TREE_SITTER_@UPPER_PARSERNAME@_H_
|
11
bindings/c/tree-sitter.pc.in
Normal file
11
bindings/c/tree-sitter.pc.in
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
prefix=@PREFIX@
|
||||||
|
libdir=@LIBDIR@
|
||||||
|
includedir=@INCLUDEDIR@
|
||||||
|
additionallibs=@ADDITIONALLIBS@
|
||||||
|
|
||||||
|
Name: tree-sitter-@PARSERNAME@
|
||||||
|
Description: A tree-sitter grammar for @PARSERNAME@ files.
|
||||||
|
URL: @PARSERURL@
|
||||||
|
Version: @VERSION@
|
||||||
|
Libs: -L${libdir} ${additionallibs} -ltree-sitter-@PARSERNAME@
|
||||||
|
Cflags: -I${includedir}
|
16
bindings/swift/TreeSitterDockerfile/dockerfile.h
Normal file
16
bindings/swift/TreeSitterDockerfile/dockerfile.h
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#ifndef TREE_SITTER_DOCKERFILE_H_
|
||||||
|
#define TREE_SITTER_DOCKERFILE_H_
|
||||||
|
|
||||||
|
typedef struct TSLanguage TSLanguage;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern TSLanguage *tree_sitter_dockerfile();
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // TREE_SITTER_DOCKERFILE_H_
|
|
@ -40,6 +40,23 @@ ENV X=42
|
||||||
(unquoted_string)
|
(unquoted_string)
|
||||||
(unquoted_string))))
|
(unquoted_string))))
|
||||||
|
|
||||||
|
================================================================================
|
||||||
|
keys can begin or end with underscores
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
ENV _TEST="foo" TEST__=bar
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
(source_file
|
||||||
|
(env_instruction
|
||||||
|
(env_pair
|
||||||
|
name: (unquoted_string)
|
||||||
|
value: (double_quoted_string))
|
||||||
|
(env_pair
|
||||||
|
name: (unquoted_string)
|
||||||
|
value: (unquoted_string))))
|
||||||
|
|
||||||
================================================================================
|
================================================================================
|
||||||
Multiple
|
Multiple
|
||||||
================================================================================
|
================================================================================
|
||||||
|
|
|
@ -86,6 +86,24 @@ ENV TEST="foo$BAR" \
|
||||||
(expansion
|
(expansion
|
||||||
(variable))))))
|
(variable))))))
|
||||||
|
|
||||||
|
================================================================================
|
||||||
|
Variables can begin or end with underscores
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
ENV TEST="$_foo${bar_}"
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
(source_file
|
||||||
|
(env_instruction
|
||||||
|
(env_pair
|
||||||
|
(unquoted_string)
|
||||||
|
(double_quoted_string
|
||||||
|
(expansion
|
||||||
|
(variable))
|
||||||
|
(expansion
|
||||||
|
(variable))))))
|
||||||
|
|
||||||
================================================================================
|
================================================================================
|
||||||
Empty Env
|
Empty Env
|
||||||
================================================================================
|
================================================================================
|
||||||
|
|
|
@ -215,7 +215,7 @@ module.exports = grammar({
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|
||||||
variable: ($) => token.immediate(/[a-zA-Z][a-zA-Z0-9_]*/),
|
variable: ($) => token.immediate(/[a-zA-Z_][a-zA-Z0-9_]*/),
|
||||||
|
|
||||||
env_pair: ($) =>
|
env_pair: ($) =>
|
||||||
seq(
|
seq(
|
||||||
|
@ -234,7 +234,7 @@ module.exports = grammar({
|
||||||
),
|
),
|
||||||
|
|
||||||
_env_key: ($) =>
|
_env_key: ($) =>
|
||||||
alias(/[a-zA-Z]([a-zA-Z0-9_]*[a-zA-Z0-9])?/, $.unquoted_string),
|
alias(/[a-zA-Z_][a-zA-Z0-9_]*/, $.unquoted_string),
|
||||||
|
|
||||||
expose_port: ($) => seq(/\d+/, optional(choice("/tcp", "/udp"))),
|
expose_port: ($) => seq(/\d+/, optional(choice("/tcp", "/udp"))),
|
||||||
|
|
||||||
|
|
|
@ -949,7 +949,7 @@
|
||||||
"type": "IMMEDIATE_TOKEN",
|
"type": "IMMEDIATE_TOKEN",
|
||||||
"content": {
|
"content": {
|
||||||
"type": "PATTERN",
|
"type": "PATTERN",
|
||||||
"value": "[a-zA-Z][a-zA-Z0-9_]*"
|
"value": "[a-zA-Z_][a-zA-Z0-9_]*"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"env_pair": {
|
"env_pair": {
|
||||||
|
@ -1038,7 +1038,7 @@
|
||||||
"type": "ALIAS",
|
"type": "ALIAS",
|
||||||
"content": {
|
"content": {
|
||||||
"type": "PATTERN",
|
"type": "PATTERN",
|
||||||
"value": "[a-zA-Z]([a-zA-Z0-9_]*[a-zA-Z0-9])?"
|
"value": "[a-zA-Z_][a-zA-Z0-9_]*"
|
||||||
},
|
},
|
||||||
"named": true,
|
"named": true,
|
||||||
"value": "unquoted_string"
|
"value": "unquoted_string"
|
||||||
|
|
1524
src/parser.c
1524
src/parser.c
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue