Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Kotlin: build extractor with bazel #16117

Merged
merged 111 commits into from
Jun 4, 2024
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
111 commits
Select commit Hold shift + click to select a range
0da4130
Bazel: add LFS rules
redsun82 Apr 3, 2024
341816c
Kotlin: add dependencies as lazy LFS files
redsun82 Apr 3, 2024
c242466
Kotlin: first support for Kotlin extractor build
redsun82 Apr 3, 2024
47ff1c1
Kotlin: working standalone extractor built with bazel
redsun82 Apr 4, 2024
5313288
LFS: do non-matching fetchinclude rather than explicit fetchexclude
redsun82 Apr 4, 2024
55ff710
Kotlin: support embeddable build in bazel
redsun82 Apr 4, 2024
5d6baea
Kotlin: add aliases for default versions
redsun82 Apr 4, 2024
3a0a219
Kotlin: remove obsolete 1.4.32 version
redsun82 Apr 4, 2024
cbdb1eb
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 4, 2024
44f3c02
Kotlin: revert accidental modification of `kotlin_plugin_versions.py`
redsun82 Apr 4, 2024
7aefd22
Kotlin: tweak `BUILD.bazel` file, add documentation
redsun82 Apr 4, 2024
38a7bc0
Bazel: optimize LFS to use symlinks when the file is not an LFS pointer
redsun82 Apr 8, 2024
fd77f1a
Bazel: fix lfs to do checkout rather than smudging
redsun82 Apr 8, 2024
e963b84
Kotlin: fix error in building extractor from internal repo
redsun82 Apr 8, 2024
a970c2d
Kotlin: move empty zip from git to internal bazel repo rule
redsun82 Apr 8, 2024
60febcd
Revert "Bazel: fix lfs to do checkout rather than smudging"
redsun82 Apr 8, 2024
b71ffc6
Bazel: properly fix lfs smudge script
redsun82 Apr 8, 2024
4a4bd16
Java/Kotlin: prepare for internal bazel packaging
redsun82 Apr 9, 2024
11729aa
Kotlin: add licensing links about kotlin dependencies
redsun82 Apr 9, 2024
4b205ff
Apply suggestions from code review
redsun82 Apr 9, 2024
9c73a9a
Bazel: move shared `bazelrc` settings to a `exported.bazelrc` file
redsun82 Apr 9, 2024
662fd5c
Add explanatory comment to `.lfsconfig`
redsun82 Apr 9, 2024
e7c680e
Kotlin: reuse generated dbscheme in embeddable, and tweak comments
redsun82 Apr 9, 2024
3bdab70
Bazel: rename `exported.bazelrc` to `.bazelrc.exported`
redsun82 Apr 10, 2024
aca8d04
Bazel: fix `.bazelrc`
redsun82 Apr 10, 2024
c9565b3
Bazel/Kotlin: fix version comparison logic, add default version printing
redsun82 Apr 10, 2024
5bdd724
Bazel: move patching of `rules_kotlin` to a registry override
redsun82 Apr 9, 2024
a15681a
Bazel: ease update of local registry
redsun82 Apr 10, 2024
35a2ed8
Bazel/Kotlin: patch jdep emission
redsun82 Apr 10, 2024
1a7f25a
Merge pull request #16167 from github/redsun82/kotlin-patched-registry
redsun82 Apr 10, 2024
5df1abc
Bazel/Kotlin: use `"all"` for extension metadata direct dependencies
redsun82 Apr 10, 2024
24ef424
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 10, 2024
fe35902
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 11, 2024
02257ee
Bazel: use triple slash in `--registry`
redsun82 Apr 11, 2024
f0fc811
Bazel/Kotlin: add `2.0.0-RC1`, remove `2.0.0-Beta4`
redsun82 Apr 11, 2024
5415665
Bazel/Kotlin: make `_embeddable_source` more robust
redsun82 Apr 11, 2024
3b75d63
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 11, 2024
c18b556
Kotlin/Bazel: remove `2.0.255-SNAPSHOT` version
redsun82 Apr 11, 2024
7f495b1
Bazel/kotlin: make version detection more robust
redsun82 Apr 11, 2024
59fdbdb
Kotlin/Bazel: move defaults to separate bazel package
redsun82 Apr 11, 2024
3d14654
Bazel/Kotlin: tentatively fix version detection on Windows
redsun82 Apr 11, 2024
fc62ed5
Kotlin/Bazel: port `custom_plugin` test to use bazel
redsun82 Apr 12, 2024
b8c063e
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 12, 2024
4822de3
Kotlin/Bazel: add fail printouts to `_default_version`
redsun82 Apr 12, 2024
a834101
Use `fetchexclude=*` in `.lfsconfig` rather than `fetchinclude`
redsun82 Apr 12, 2024
c64d02d
Undo `.gitattributes` formatting, move `LFS` entry
redsun82 Apr 12, 2024
bc89742
Kotlin: fix space indentation in `OdasaOutput.java`
redsun82 Apr 12, 2024
9c3a615
CI: add non-blocking kotlin extractor build check
redsun82 Apr 12, 2024
2d16192
CI: fix typo in `kotlin-build.yml`
redsun82 Apr 12, 2024
9114131
Bazel: add settings required by internal repo
redsun82 Apr 12, 2024
b8010f2
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 12, 2024
65df2bb
Bazel/Kotlin: add `.exe` to `kotlinc` on windows
redsun82 Apr 12, 2024
0ad8ed3
Kotlin/Bazel: use `kotlinc.bat` instead of `kotlinc.exe` on Windows
redsun82 Apr 12, 2024
24c7ad5
Bazel/Kotlin: use plain `kotlinc` instead of result of `repository_ct…
redsun82 Apr 12, 2024
5c2d9fe
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 12, 2024
a78124b
Bazel/Kotlin: use a wrapper to get the current kotlin version
redsun82 Apr 12, 2024
92a5f3d
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 12, 2024
b36cabb
Anchor `.gitattributes` entries at root where it makes sense
redsun82 Apr 12, 2024
bdc8a7f
Revert "Use `fetchexclude=*` in `.lfsconfig` rather than `fetchinclude`"
redsun82 Apr 15, 2024
9d1901c
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 15, 2024
b07fa70
Kotlin/Bazel: provide wrapper for managing versions of `kotlinc`
redsun82 Apr 15, 2024
e53ef4a
Kotlin/Bazel: fix wrapper on Windows
redsun82 Apr 15, 2024
1b5675e
Kotlin/Bazel: tweak wrapper
redsun82 Apr 15, 2024
6a83bf9
Merge pull request #16208 from github/redsun82/kotlin-wrapper
redsun82 Apr 15, 2024
5bb2cba
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 15, 2024
bd631c5
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 15, 2024
8c705ad
Kotlin/Bazel: fix java release to 8 for java code
redsun82 Apr 15, 2024
735b341
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 16, 2024
aee3c0d
Add license and notice information to patched registry
redsun82 Apr 16, 2024
27ab487
Kotlin: simplify `kotlinc` wrapper
redsun82 Apr 16, 2024
306f0f1
Kotlin: accept `--select default` in kotlinc wrapper to select the de…
redsun82 Apr 16, 2024
a741170
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 16, 2024
c5f6c65
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 16, 2024
3678e51
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 17, 2024
7952f0e
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 22, 2024
f685843
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 22, 2024
aaa29d8
Remove unneeded slash in `kotlinc.bat`
redsun82 Apr 22, 2024
072e2ed
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 23, 2024
5b143ce
Kotlin: make wrapper install quietly unless `--select` is explicit
redsun82 Apr 23, 2024
c014cd8
Bazel: fix kotlin wrapper version dependency
redsun82 Apr 23, 2024
4aa0a8e
Kotlin: make wrapper more robust for windows
redsun82 Apr 24, 2024
a23327c
Merge branch 'main' into HEAD
redsun82 Apr 24, 2024
1e622e1
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 25, 2024
8e1d77b
Bazel: format file
redsun82 Apr 25, 2024
a841a2b
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 26, 2024
d7ecaae
Kotlin: back off from lazy LFS rules
redsun82 Apr 29, 2024
450f651
Bazel: remove generic lazy lfs files
redsun82 Apr 29, 2024
b834173
Merge branch 'main' into redsun82/kotlin
redsun82 Apr 29, 2024
d4e0a56
Kotlin: update wrapper location
redsun82 Apr 29, 2024
52a015f
Bazel: remove further unneeded files
redsun82 Apr 30, 2024
239b6d8
Merge branch 'main' into redsun82/kotlin
redsun82 May 6, 2024
514e24c
Kotlin: bring back lazy LFS dependencies
redsun82 May 6, 2024
e546560
Kotlin: restore `kotlin-compiler-embeddable-1.7.0.jar` to the maven c…
redsun82 May 6, 2024
75709bf
Merge branch 'main' into redsun82/kotlin
redsun82 May 16, 2024
eab940c
Merge branch 'main' into redsun82/kotlin
redsun82 May 22, 2024
821bd1f
Merge branch 'main' into redsun82/kotlin
redsun82 May 27, 2024
d1a2c0f
Merge branch 'main' into redsun82/kotlin
redsun82 Jun 4, 2024
99f70a6
Kotlin: address review comments
redsun82 Jun 4, 2024
fcd326e
CI: reword comment
redsun82 Jun 4, 2024
6a9cb90
Kotlin: rework header comment
redsun82 Jun 4, 2024
2fe0718
Explain `.lfsconfig` choice in the comment
redsun82 Jun 4, 2024
4c91bdc
Kotlin: `tgt` -> `target`
redsun82 Jun 4, 2024
e7cec01
Kotlin: make `current_kotlin_version.py` executable
redsun82 Jun 4, 2024
e693c27
Kotlin: remove unneeded patch
redsun82 Jun 4, 2024
c6039b3
Kotlin: update default `kotlinc` version
redsun82 Jun 4, 2024
be5c82c
Kotlin: add other tools to dev wrapper
redsun82 Jun 4, 2024
8205f86
Kotlin: use `tools/bazel` in integration test
redsun82 Jun 4, 2024
a48d71b
Merge branch 'main' into redsun82/kotlin
redsun82 Jun 4, 2024
10584b3
Kotlin: improve posix dev wrappers
redsun82 Jun 4, 2024
e4653a8
Kotlin: remove `kapt` wrapper, probably unneeded
redsun82 Jun 4, 2024
b7e16ca
Kotlin: fix `custom_plugin` test
redsun82 Jun 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .bazelrc
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,7 @@ build:linux --cxxopt=-std=c++20
build:macos --cxxopt=-std=c++20 --cpu=darwin_x86_64
build:windows --cxxopt=/std:c++20 --cxxopt=/Zc:preprocessor

# emitting jdeps does not work when building the 2.0.0+ kotlin extractor
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
build --@rules_kotlin//kotlin/settings:jvm_emit_jdeps=false
criemen marked this conversation as resolved.
Show resolved Hide resolved

try-import %workspace%/local.bazelrc
10 changes: 1 addition & 9 deletions .gitattributes
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,8 @@
# git add --renormalize .
# git status [just to show what files were renormalized]
# git commit -m "Normalize line endings"

redsun82 marked this conversation as resolved.
Show resolved Hide resolved
# Anything Git auto-detects as text gets normalized and checked out as LF
* text=auto eol=lf

# Explicitly set a bunch of known extensions to text, in case auto detection gets confused.
*.ql text
*.qll text
Expand Down Expand Up @@ -40,7 +38,6 @@
*.lua text
*.expected text
*.go text

# Explicitly set a bunch of known extensions to binary, because Git < 2.10 will treat
# `* text=auto eol=lf` as `* text eol=lf`
*.png -text
Expand All @@ -49,32 +46,27 @@
*.gif -text
*.dll -text
*.pdb -text

java/ql/test/stubs/**/*.java linguist-generated=true
java/ql/test/experimental/stubs/**/*.java linguist-generated=true

# Force git not to modify line endings for go or html files under the go/ql directory
go/ql/**/*.go -text
go/ql/**/*.html -text
# Force git not to modify line endings for go dbschemes
go/*.dbscheme -text
# Preserve unusual line ending from codeql-go merge
go/extractor/opencsv/CSVReader.java -text

# For some languages, upgrade script testing references really old dbscheme
# files from legacy upgrades that have CRLF line endings. Since upgrade
# resolution relies on object hashes, we must suppress line ending conversion
# for those testing dbscheme files.
*/ql/lib/upgrades/initial/*.dbscheme -text

# Generated test files - these are synced from the standard JavaScript libraries using
# `javascript/ql/experimental/adaptivethreatmodeling/test/update_endpoint_test_files.py`.
javascript/ql/experimental/adaptivethreatmodeling/test/endpoint_large_scale/autogenerated/**/*.js linguist-generated=true -merge
javascript/ql/experimental/adaptivethreatmodeling/test/endpoint_large_scale/autogenerated/**/*.ts linguist-generated=true -merge

# Auto-generated modeling for Python
python/ql/lib/semmle/python/frameworks/data/internal/subclass-capture/*.yml linguist-generated=true

# auto-generated bazel lock file
ruby/extractor/cargo-bazel-lock.json linguist-generated=true
ruby/extractor/cargo-bazel-lock.json -merge
/java/kotlin-extractor/deps/*.jar filter=lfs diff=lfs merge=lfs -text
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
2 changes: 2 additions & 0 deletions .lfsconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
[lfs]
fetchinclude = /nothing
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would fetchexclude = * be equivalent? That would more natural to me.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeah, agreed, will do!

Copy link
Contributor Author

@redsun82 redsun82 Apr 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah, I remembered why I had gone for fetchinclude rather than fetchexclude: the latter has precedence over the former, so if one wants to override these settings in order to fetch some specific files it becomes non trivial.

Say we start having more of such lazy LFS files (I'm planning to use this for Swift as well), and you want to fetch the kotlin files. With fetchinclude=/nothing in .lfsconfig, it suffices for you to git config lfs.fetchinclude=/java/kotlin-extractor/**, which will override the /nothing and give you what you want, while other files will stay excluded.

With fetchexclude=* in .lfsconfig, you would need to (say) do something like git config lfs.fetchexclude=swift/**, or exclude all directories save for /java just to be forward compatible with the exclusion rules...

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ah, OK, that makes sense. Could you add a comment explaining that please?

56 changes: 56 additions & 0 deletions MODULE.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,14 @@ bazel_dep(name = "bazel_skylib", version = "1.5.0")
bazel_dep(name = "abseil-cpp", version = "20240116.0", repo_name = "absl")
bazel_dep(name = "nlohmann_json", version = "3.11.3", repo_name = "json")
bazel_dep(name = "fmt", version = "10.0.0")
bazel_dep(name = "rules_kotlin", version = "1.9.4")

# we patch `rules_kotlin` to allow passing `-language-version` at a jvm_kt_library level
single_version_override(
criemen marked this conversation as resolved.
Show resolved Hide resolved
module_name = "rules_kotlin",
patch_strip = 1,
patches = ["//java/kotlin-extractor:rules_kotlin.patch"],
criemen marked this conversation as resolved.
Show resolved Hide resolved
)

pip = use_extension("@rules_python//python/extensions:pip.bzl", "pip")
pip.parse(
Expand Down Expand Up @@ -48,6 +56,54 @@ node.toolchain(
)
use_repo(node, "nodejs", "nodejs_toolchains")

kotlin_extractor_deps = use_extension("//java/kotlin-extractor:deps.bzl", "kotlin_extractor_deps")

# following list can be kept in sync by running `bazel mod tidy` in `codeql`
criemen marked this conversation as resolved.
Show resolved Hide resolved
use_repo(
kotlin_extractor_deps,
"codeql_kotlin_defaults",
"codeql_kotlin_embeddable",
"kotlin-compiler-1.5.0",
criemen marked this conversation as resolved.
Show resolved Hide resolved
"kotlin-compiler-1.5.10",
"kotlin-compiler-1.5.20",
"kotlin-compiler-1.5.30",
"kotlin-compiler-1.6.0",
"kotlin-compiler-1.6.20",
"kotlin-compiler-1.7.0",
"kotlin-compiler-1.7.20",
"kotlin-compiler-1.8.0",
"kotlin-compiler-1.9.0-Beta",
"kotlin-compiler-1.9.20-Beta",
"kotlin-compiler-2.0.0-Beta4",
"kotlin-compiler-2.0.255-SNAPSHOT",
"kotlin-compiler-embeddable-1.5.0",
"kotlin-compiler-embeddable-1.5.10",
"kotlin-compiler-embeddable-1.5.20",
"kotlin-compiler-embeddable-1.5.30",
"kotlin-compiler-embeddable-1.6.0",
"kotlin-compiler-embeddable-1.6.20",
"kotlin-compiler-embeddable-1.7.0",
"kotlin-compiler-embeddable-1.7.20",
"kotlin-compiler-embeddable-1.8.0",
"kotlin-compiler-embeddable-1.9.0-Beta",
"kotlin-compiler-embeddable-1.9.20-Beta",
"kotlin-compiler-embeddable-2.0.0-Beta4",
"kotlin-compiler-embeddable-2.0.255-SNAPSHOT",
"kotlin-stdlib-1.5.0",
"kotlin-stdlib-1.5.10",
"kotlin-stdlib-1.5.20",
"kotlin-stdlib-1.5.30",
"kotlin-stdlib-1.6.0",
"kotlin-stdlib-1.6.20",
"kotlin-stdlib-1.7.0",
"kotlin-stdlib-1.7.20",
"kotlin-stdlib-1.8.0",
"kotlin-stdlib-1.9.0-Beta",
"kotlin-stdlib-1.9.20-Beta",
"kotlin-stdlib-2.0.0-Beta4",
"kotlin-stdlib-2.0.255-SNAPSHOT",
)

register_toolchains(
"@nodejs_toolchains//:all",
)
12 changes: 12 additions & 0 deletions java/downgrades/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
load("@rules_pkg//:mappings.bzl", "pkg_files", "strip_prefix")

pkg_files(
name = "downgrades",
srcs = glob(
["**"],
exclude = ["BUILD.bazel"],
),
prefix = "downgrades",
strip_prefix = strip_prefix.from_pkg(),
visibility = ["//visibility:public"],
)
190 changes: 190 additions & 0 deletions java/kotlin-extractor/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,190 @@
"""
# Usage overview
Building the extractor can be done via
```
bazel build //java/kotlin-extractor:codeql-extractor-kotlin-<variant>-<version>
```
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It looks like this can't be done from <root>, but can be done from <root>/ql or <root>/ql/java/kotlin-extractor. Is that expected?

Also, I think that this should mention that you needs tools/bazel to be the bazel on your path.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It looks like this can't be done from , but can be done from /ql or /ql/java/kotlin-extractor. Is that expected?

I can add a note about building from the internal repo (bazel build @codeql//java/kotlin-extractor:etc is what works from there)

Also, I think that this should mention that you needs tools/bazel to be the bazel on your path.

Actually, any installed bazel or bazelisk will do (bar http fetching problems 😅). On codeql, if it's bazelisk (which is now the recommended bazel executable to have and is what bazel is on github actions) it will pick up the correct bazel version. If it's a fixed bazel version, it will exit any way with a helpful error on a version mismatch.

Furthermore, on semmle-code, any installed bazel will actually auto-pick tools/bazel.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The helpful error will have the user install bazel, though, and they will have to update their installation when we bump our bazel version. Wouldn't it be better to just tell them to use the tools/bazel they already have?

where `<variant>` is either `standalone` or `embeddable`, and `<version>` is one of the supported versions.

For the moment both variants where tested by replacing them into `target/intree/codeql-java` and running one relevant integration test.
redsun82 marked this conversation as resolved.
Show resolved Hide resolved

```
bazel build //java/kotlin-extractor
```
will build a default variant:
* standalone, unless `CODEQL_KOTLIN_SINGLE_VERSION_EMBEDDABLE` is set to true, in which case it will go for embeddable
* the version will be taken as the last supported version less than the version of the currently installed `kotlinc`
* if `CODEQL_KOTLIN_SINGLE_VERSION` is set, that will be used instead
* if `kotlinc` is not installed, `1.9.20-Beta` will be used

If `kotlinc` is updated, bazel won't be aware of it and will therefore keep the same default version. Possible workarounds for that:
criemen marked this conversation as resolved.
Show resolved Hide resolved
* `bazel clean`
* `bazel fetch --force @codeql_kotlin_defaults\\:all`
* `CODEQL_KOTLIN_SINGLE_VERSION= bazel build //java/kotlin-extractor`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

does this work repeatedly? Presumably, the env variable needs to change for bazel to run the configuration again, no?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Indeed, this requires CODEQL_KOTLIN_SINGLE_VERSION to appear empty in the environment for bazel to pick up a change. For example setting that in a persistent env won't help at all.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we add a note about this then, and/or drop this workaround?
Or maybe shell out to a source of randomness to set the variable content :D

"""

# notice that this file is used in the `@codeql_koblin_embeddable` external repo, which means we need to
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
# reference explicitly @codeql
load(
"@codeql//java/kotlin-extractor:versions.bzl",
"VERSIONS",
"get_compatilibity_sources",
"get_language_version",
"version_less",
)
load("@rules_kotlin//kotlin:jvm.bzl", "kt_jvm_library")
load("@rules_kotlin//kotlin:core.bzl", "kt_kotlinc_options")
load("@codeql_kotlin_defaults//:defaults.bzl", "kotlin_extractor_defaults")

_for_embeddable = repo_name().endswith("codeql_kotlin_embeddable")

_common_extractor_name_prefix = "codeql-extractor-kotlin"

_extractor_name_prefix = "%s-%s" % (
_common_extractor_name_prefix,
"embeddable" if _for_embeddable else "standalone",
)

py_binary(
name = "generate_dbscheme",
srcs = ["generate_dbscheme.py"],
)

genrule(
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
name = "generated-dbscheme",
srcs = ["@codeql//java:dbscheme"],
outs = ["KotlinExtractorDbScheme.kt"],
cmd = "$(execpath :generate_dbscheme) $< $@",
tools = [":generate_dbscheme"],
)

_resources = [
(
r,
r[len("src/main/resources/"):],
)
for r in glob(["src/main/resources/**"])
]

[
(
kt_kotlinc_options(
name = "kotlinc-options-%s" % v,
include_stdlibs = "none",
jvm_target = "1.8",
criemen marked this conversation as resolved.
Show resolved Hide resolved
language_version = get_language_version(v),
warn = "error",
x_optin = [
"kotlin.RequiresOptIn",
"org.jetbrains.kotlin.ir.symbols.%s" %
("IrSymbolInternals" if version_less(v, "2.0.0") else "UnsafeDuringIrConstructionAPI"),
],
x_suppress_version_warnings = True,
),
# * extractor.name is different for each version, so we need to put it in different output dirs
# * in order to put it in `resources`, we need to define `resource_strip_prefix` to strip this version
# * `resource_strip_prefix` is unique per jar, so we must also put other resources under the same version prefix
genrule(
name = "resources-%s" % v,
srcs = [src for src, _ in _resources],
outs = [
"%s/com/github/codeql/extractor.name" % v,
] + [
"%s/%s" % (v, tgt)
for _, tgt in _resources
],
cmd = "\n".join([
"echo %s-%s > $(RULEDIR)/%s/com/github/codeql/extractor.name" % (_extractor_name_prefix, v, v),
] + [
"cp $(execpath %s) $(RULEDIR)/%s/%s" % (src, v, tgt)
for src, tgt in _resources
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: Can we call this target instead?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit doesn't seem to have been addressed, despite a thumbs-up emoji

]),
),
kt_jvm_library(
name = "%s-%s" % (_extractor_name_prefix, v),
srcs =
[":generated-dbscheme"] +
glob(
[
"src/**/*.kt",
"src/**/*.java",
],
exclude = ["src/main/kotlin/utils/versions/**"],
) + get_compatilibity_sources(v, "src/main/kotlin/utils/versions"),
kotlinc_opts = ":kotlinc-options-%s" % v,
module_name = "codeql-kotlin-extractor",
# resource_strip_prefix is very nit-picky: the following makes it work from
# `codeql`, `@codeql_kotlin_embeddable` and `semmle-code`
resource_strip_prefix = (
("../%s/" % repo_name() if repo_name() else "") +
("%s/" % package_name() if package_name() else "") +
v
),
resources = [
":resources-%s" % v,
],
visibility = ["//visibility:public"],
deps = [
"@kotlin-compiler%s-%s" % (
"-embeddable" if _for_embeddable else "",
v,
),
"@kotlin-stdlib-%s" % v,
],
),
# if in main repository, alias the embeddable versions from the modified @codeql_kotlin_embeddable repo
alias(
name = "%s-embeddable-%s" % (_common_extractor_name_prefix, v),
actual = "@codeql_kotlin_embeddable//:%s-embeddable-%s" % (_common_extractor_name_prefix, v),
visibility = ["//visibility:public"],
) if not _for_embeddable else None,
)
for v in VERSIONS
]

# default aliases, based on the kotlinc version installed on the host
# * default version can be overridden with env variableCODEQL_KOTLIN_SINGLE_VERSION
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
# * setting CODEQL_KOTLIN_SINGLE_VERSION_EMBEDDABLE=true overrides the default variant
redsun82 marked this conversation as resolved.
Show resolved Hide resolved
# * when a new kotlinc version is installed, you'll need to either `bazel clean` or
# `bazel fetch --force @codeql_kotlin_defaults//:all` to refresh the default
(
alias(
name = "%s-standalone" % _common_extractor_name_prefix,
actual = "%s-standalone-%s" % (
_common_extractor_name_prefix,
kotlin_extractor_defaults.version,
),
visibility = ["//visibility:public"],
),
alias(
name = "%s-embeddable" % _common_extractor_name_prefix,
actual = "%s-embeddable-%s" % (
_common_extractor_name_prefix,
kotlin_extractor_defaults.version,
),
visibility = ["//visibility:public"],
),
alias(
name = _common_extractor_name_prefix,
actual = "%s-%s-%s" % (
_common_extractor_name_prefix,
kotlin_extractor_defaults.variant,
kotlin_extractor_defaults.version,
),
visibility = ["//visibility:public"],
),
alias(
name = "kotlin-extractor",
actual = _common_extractor_name_prefix,
visibility = ["//visibility:public"],
),
filegroup(
name = "many",
srcs = ["%s-%s-%s" % (
_common_extractor_name_prefix,
variant,
version,
) for variant in ("standalone", "embeddable") for version in VERSIONS],
visibility = ["//visibility:public"],
),
) if not _for_embeddable else None
Loading
Loading