- v13.1.1
- v13.1.0
- v13.0.0
- v12.2.1
- v12.2.0
- v12.1.0
- v12.0.1
- v12.0.0
- v11.13.0
- v11.12.0
- v11.11.0
- v11.10.0
- v11.9.2
- v11.9.1
- v11.9.0
- v11.8.1
- v11.8.0
- v11.7.0
- v11.6.1
- v11.6.0
- v11.5.0
- v11.4.0
- v11.3.0
- v11.2.0
- v11.1.0
- v11.0.1
- v11.0.0
- v10.6.0
- v10.5.1
- v10.5.0
- v10.4.0
- v10.3.0
- v10.2.0
- v10.1.0
- v10.0.1
- v10.0.0
- v9.0.0
- v8.1.0
- v8.0.0
- v7.5.0
- v7.4.0
- v7.3.0
- v7.2.1
- v7.2.0
- v7.1.0
- v7.0.0
- Incompatible Changes
- v6.7.0
- v6.6.0
- v6.5.1
- v6.5.0
- v6.4.0
- v6.3.0
- v6.2.0
- v6.1.1
- v6.1.0
- v6.0.0
- v5.1.0
- v5.0.0
- v4.7.0
- v4.6.0
- v4.5.0
- v4.4.0
- v4.3.0
- v4.2.0
- v4.1.0
- v4.0.0
- v3.0.1
- v3.0.0
- v2.2.0
- v2.1.0
- v2.0.0
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.0
- v0.3.5
- v0.3.4
- v0.3.3
- v0.3.2
- v0.3.1
- v0.3.0
- v0.2.1
- v0.2.0
- v0.1.4
- v0.1.3
- v0.1.2
- v0.1.1
- v0.1.0
- v0.0.3
- v0.0.2
- #2673 - @KronicDeth
- Fix Project Initialization Failed from New > Project > Elixir
- Catch and log
IOException
s swallowed by Project Initialization Failed. - Recursively delete project directory before running
mix new
. Previously, the directory was only deleted if empty, but whether the.idea
directory is written whensetupProject
is called differs between IDE versions, so to be safe, recursively delete.
- Catch and log
- Fix Project Initialization Failed from New > Project > Elixir
- #2705 - @KronicDeth
- Fix Go To Definition for function in compiled modules.
When switching over to delayed decompilation,
ModuleImpl
did not haveprocessDeclaration
overloadded, so thePsiScopeProcessor
was never called on it and so theCallDefinitionClause
scope processor did not check theModuleImpl#callDefinitons
. - Implement Deprecated metadata handling for docs from BEAM files.
- Fix Go To Definition for function in compiled modules.
When switching over to delayed decompilation,
- #2709 - @KronicDeth
- Don't assume Elixir
SDK
sdkAdditionalData
is non-null
.
- Don't assume Elixir
- #2711 - @KronicDeth
- Don't restrict Run Configurations to Run in Modules to Elixir modules.
The docs for
ModuleType
say the concept is meant to be deprecated, so don't enforce it and trying to loadElixirModuleType
in RubyMine breaks as it tries to loadElixirModuleBuilder
and thereforeJavaModuleBuilder
, which only works in IntelliJ.
- Don't restrict Run Configurations to Run in Modules to Elixir modules.
The docs for
- #2712 - @KronicDeth
- Add the facet in a write action in addition to setting the SDK.
- #2717 - @KronicDeth
- Increase
SUSPECT_NAME_SET_SIZE
to20
. Increased to cover the15
impl
s ofString.Chars
in thegeo
hex package.
- Increase
- #2719 - @KronicDeth
- Log if
erl
binary is not found when trying to runmix format
. Log instead of letting it throw up the stack and cause an error report since the SDK not being set will be very common.
- Log if
- #2673 - @KronicDeth
- Improved error reporting
- Include 5 lines of context around error elements
- Use
originalFile
when calculating path, so that.beam
file path is used for decompiled files that don't have aVirtualFile
. - Compact line references
- Only including ending line if it is different than starting line.
- Add ending line as a range after starting line instead of a completely separate path and line.
- Put stacktrace in
<details>
with<summary>
- Improved error reporting
- #2687 - @KronicDeth
- Update dependencies
gradle
to7.4.2
gradle-intellij-plugin
to1.6.0
- Set
-Xjvm-default=all
for Kotlin to allow@JvmDefault
interfaces- Needed for
LanguageNewProjectWizard
subclasses and associated implementations
- Needed for
- New Project > Language > Elixir includes all mix options
--app
--module
--sup
--umbrella
- Update dependencies
- #2578 - @yordis
- Add
mix format
external formatter. Requires project or module SDK be set in order to run. If the SDK is not available, only the internal formatter will be used. The internal formatter is still used for file subsection formatting and new line indenting asmix format
works at the file-level.-
Allow
mix format
external formatter to be disabled.- Preferences
- Editor > Code Style > Elixir
- Click the
mix format
tab - Expand the General group
- Uncheck "Format files with
mix format
".
-
- Add
- #2697 - @KronicDeth
- Support Elixir 1.13.0 in debugger.
- #2637 - @KronicDeth
- Protect from
null
containingFile
when fetching docs.
- Protect from
- #2639 - @KronicDeth
- Show notification if $HOME_PATH/lib does not exist. Instead of logging an error show a notification since it can and does happen and is not a bug to be fixed in the plugin, but a configuration change the user needs to do.
- #2640 - @KronicDeth
- Ignore tuples as type restrictions that occur during typing.
- #2641 - @KronicDeth
- Catch
AlreadyDisposedException
when trying to find module for PsiElement inmostSpecificSdk
.- Check if the project
is disposed before using it to get module for
PsiElement`.
- Check if the project
- Catch
- #2645 - @KronicDeth
- Look above
CallDefinitionImpl
forType
scope processing It should go up to theModuleImpl
to find theTypeDefinitionImpl
.
- Look above
- #2671 - @KronicDeth
- Have Credo Global Inspection use standard
Mix.commandLine
used for Run Configurations.- Allow environment variables to be set similar to Run Configurations for projects that require environment variables to be set for Mix tasks due to checks in their config.
- No longer support Include Explanations as it takes too long to run.
- Remove annotator until it can be re-implemented in performant manner using corrected environment and SDK from Global Inspection.
- Have Credo Global Inspection use standard
- #2672 - @KronicDeth
- Look above
<variable>.<tuple>
forancestorTypeSpec
.- Look above
<tuple>
after<variable>.
forancestorTypeSpec
.
- Look above
- Look above
- #2673 - @KronicDeth
- Fix Find Usages that resolve to compiled types.
- Add element description for
TypeDefinitionImpl
- Node Text is
@<module_attribte> <name>(<parameters>) :: ...
- Long Name and Short Name are just the
name
- Type is
type
- Node Text is
- Mirror
TypeDefinitionImpls
to types in decompiled source. AllowTypeDefinitionImpl.getNavigation
to go to decompiled types.
- Add element description for
- Allow types with atom keyword names to be highlight even though they are invalid names.
- Fix Find Usages that resolve to compiled types.
- #2674 - @KronicDeth
- Catch
RuntimeException
ifrootProvider
is already disposed. CatchingAssertionError
used to be enough in #1359, but not anymore as of #2623.
- Catch
- #2675 - @KronicDeth
- Ignore invalid format that occur while user is typing when highlighting types
@type name :: String.()
@type String.()
@type S
- Ignore invalid format that occur while user is typing when highlighting types
- #2676 - @KronicDeth
- Restore Project configuration for Small IDEs.
I dropped an
!
when converting fromequals
to==
when fixing the deprecation warnings, which made the Project SDK selection only be HIDDEN where it needed to be SHOWN.
- Restore Project configuration for Small IDEs.
I dropped an
- #2679 - @KronicDeth
- Catch
StackOverflowError
infind_usages.Provider.getType()
. - Element descriptions for
CallDefinitionImpl
- Catch
- #2680 - @KronicDeth
- Highlight
CallDefinitionImpl
references as predefined if resolvedCallDefinitionImpl
is inKernel
orKernel.SpecialForms
. Fixes highlightingdef
and other defined when using SDKs without source like Homebrew after the delayed-decompilation fixes from 12.2.1. Now source-less (Homebrew) and SDKs with sources (ASDF) will both be able to highlight predefineds.
- Highlight
- #2681 - @KronicDeth
- No longer record the SDK name as an attribute of the Facet configuration, as it didn't write back changes.
- Instead detect the Elixir SDK by finding any of the libraries that have an Elixir SDK name in the module. (The Elixir SDK was already being added as a library to allow indexing the SDK.)
- Clear out any existing Elixir SDKs listed as module libraries before setting a new SDK. This eliminates the duplicates that happened before. (It turns out the JetBrains API doesn't prevent duplicates. Oopsie.) It also ensures that no SDK is recorded if the SDK is deselected in the UI, which wouldn't happen before.
- No longer record the SDK name as an attribute of the Facet configuration, as it didn't write back changes.
- #2687 - @KronicDeth
- Handle disposed
Sdk.rootProvider
by reloading theSdk
when loadingebinDirectories
- In IntelliJ 2022, the New Project dialog changed and it no longer automatically listed
ModuleType.getBuilder
ModuleBuilder
s as potential project builders, so it looked like Elixir New Project support disappeared. Fix this by implementing thenewProjectWizard.language
extension that was added to control the Language switching in the new New Project dialog.
- Handle disposed
- [#2688]](#2688) - @KronicDeth
- Remove references to
ElementClassHint
in BeamFileImpl that only work in IntelliJ.ElementClassHint
is part of theprocessDeclaration
system used in Java and so was in the code becauseBeamFileImpl
was original based onClassFileImpl
, but since the Elixir resolvers don't use the hint system at all, it can just be removed.
- Remove references to
- #2578 - @yordis
- Remove
CodeStyleSettingsProvider
because it is redundant withLanguageCodeStyleSettingsProvider
- Remove
- #2695 - @KronicDeth
- Restrict
UsageTargetProvider
toElixirFile
s Without this restriction, it tries to run when developing the plugin itself and breaks Kotlin syntax highlighting.
- Restrict
- #2697 - @KronicDeth
- Fix environment not being passed to debug runs of ESpec and ExUnit Run Configurations.
The
env
from theConfiguration
was dropped because a localenv
was created to setMIX_ENV
true
.
- Fix environment not being passed to debug runs of ESpec and ExUnit Run Configurations.
The
- #2594 - @KronicDeth
- Drop support for IDEEs before 2022.1.
- #2594 - @KronicDeth
- Support 2022.1 IDEs
- Update IntelliJ Plugin Gradle to 1.5.3.
- Set untilBuild explicitly
- Target JVM Version 11
- Support 2022.1 IDEs
- #2633 - @KronicDeth
- Expand
untilBuild
to cover PATCH releases of 2022.1.
- Expand
- #2594 - @KronicDeth
- Fix (some) plugin verifier warnings
- Fix (some) deprecation warnings.
- Use fewer Internal APIs.
- Fix (some) plugin verifier warnings
- #2633 - @KronicDeth
- Don't use ElixirModuleType to check if it is available.
It will not load in IDEs that lack
JavaModuleBuilder
, which is why I was hard coding the ran previously. - Don't use
XmlSerializer
as equivalent ofDefaultJDOMExternalizer
TheDefaultJDOMExternalizer
method calls weren't writing anything and the explicit attribute value accesses were, so it is more correct to just remove the original deprecated calls.
- Don't use ElixirModuleType to check if it is available.
It will not load in IDEs that lack
- #2579 - @KronicDeth
-
Don't call
.navigationElement
to prevent unnecessary decompilation when resolving references or showing completions.- Don't call
navigationElement
inChooseByNameContributor
- Don't decompile Protocols to get their specific
t
type - Don't call
.navigationElement
when resolving built-in types in:erlang
- Don't use
navigationElement
inCallDefinitionClause.implicitImports
forKernel
andKernelSpecial.Forms
. - Don't call
.navigationElement
inreference.resolver.Module.multiResolveProject
Prevents decompiling modules when doing completion.
Handle
PsiCompiledElement
in places that previously only handled source and decompiledCall
sgetElementDescription
for ModuleImpl- Complete call definition under binary modules
- Don't look for variables in compiled elements
- Don't assume elements have a non-null node Decompiled elements don't
- Index
TypeDefinition
s in .beam files Only supported built-in types faked in:erlang
for now - Walk
ModuleImpl
forscope.Type
- Don't call
-
- #2461 - @KronicDeth
- Test against support IDEA versions in CI to prevent another Find Usage regression
- 2021.2.3 FindUsageTests differ from manual testings, so don't test 2021.2.3
- Make FindUsagesTest UsageViewTreeText work for both 2021.1.3 and other versions
- Add kernel.ex to all Find Usage Tests to ensure it doesn't work because it can't resolve primary element
- Add find usages for def test
- Test against support IDEA versions in CI to prevent another Find Usage regression
- #2461 - @KronicDeth
- Work-around Find Usage bug due to temporary change in JetBrains API only in versions that have that change.
- Restore old find_usages.handler.Call
- Determine whether to resolve
FindUsageHandler
primary element based on application build number Assume that are 213.* builds have the already resolved call. This excludes 2021.3, but not 2021.3.1, which includes the fix to restore the 2021.1.3 behaviour.
- Work-around Find Usage bug due to temporary change in JetBrains API only in versions that have that change.
- #2466 - @KronicDeth
- Fix HTML errors in
description.html
. - Add card one-liner.
- Fix HTML errors in
- #2405 - @osbre
- Add MacPorts SDK locations to README.
- #2404 - @KronicDeth
- Update build to elixir 1.13.0
- Add support for
**
operator to lexer and parser. Port elixir-lang/elixir#11241
- #2436 - @KronicDeth
- Color settings for each sigil name. Both the interpolating (lower case) and literal (upper case) name use the same settings.
- #2202 - @KronicDeth
- Add support for stepped ranges Port elixir-lang/elixir#10810
- Regression test for #2200
- Update CI
- Update to Elixir 1.12.3
- Update to Erlang 24.1.6
- Add support for stepped ranges Port elixir-lang/elixir#10810
- #2447 - @KronicDeth
- Use
getUsageViewTreeTextRepresentation
to check find usages. - Regression test for #2374.
- Use
- #2448 - @KronicDeth
- Regression test for #2386 Issue #2386 had the same root cause (OtpExternalFun not being decompiled correctly) as
Issue #2410, so Issue #2386 was fixed by Pull Request #2441, but since @alexxero was nice enough to upload
the
.beam
file for Issue #2386, I might as well add it as a regression test too.
- Regression test for #2386 Issue #2386 had the same root cause (OtpExternalFun not being decompiled correctly) as
Issue #2410, so Issue #2386 was fixed by Pull Request #2441, but since @alexxero was nice enough to upload
the
- #2453 - @KronicDeth
- Regression test for #2446
- #2642 - @KronicDeth
- Ignore
()
as a type parameter as it occurs during typing.
- Ignore
- #2643 - @KronicDeth
- Default the variable color if the specific type foreground is
null
.
- Default the variable color if the specific type foreground is
- #2644 - @KronicDeth
- Log unknown element for fetching docs from BEAM file.
- #2397 - @KronicDeth
-
Restore tests that weren't being run after 2021.3 upgrade. Upgrading to 2021.3 dropped the number of run tests from 3741 to 1452. This was due to a change in the packaging in 2021.3 that triggered a gradle bug.
- Fix test broken by missing
markdown
in plugins list Like the need for thejava
plugin to handle thecom.intellij.modules.java
depends
inplugin.xml
, theorg.intellij.plugins.markdown
depends
neededmarkdown
added to the list to make some of the tests work. The failed tests weren't being run before after the 2021.3 upgrade. - Manually include tests instead of scanning. Work-around gradle/gradle#18486 as described
in https://jetbrains-platform.slack.com/archives/C5U8BM1MK/p1637955960051600?thread_ts=1637923961.040000&cid=C5U8BM1MK
that affects running tests with ideaVersion 2021.3.
- Rename ParsingTestCases with improper capitalization
- Fix test broken by missing
-
- #2404 - @KronicDeth
- Decompile
{:|, ..., ...}
as cons operator in Elixir Dbgi. - Fix missing guards when decompiling Elixr DbgI clauses using special decompiler Guards where missing because
only
decompiler.appendSignature
was used. - Fix module.Reference.calculateDefaultRangeInElement
element.textOffset
instead ofelement.textLength
was used for end of range.
- Decompile
- #2436 - @KronicDeth
- Restore colors for char lists and strings lost with the PSI changes in e71b247.
- #2441 - @KronicDeth
- Render
OtpErlangExternalFun
correctly as remote captures (&Mod.fun/arity
). Fixes decompilingEcto.Changeset.validate_number
.
- Render
- #2445 - @KronicDeth
- Protect ExUnit configuration
Producer
fromElixirFile
withoutVirtualFile
.
- Protect ExUnit configuration
- #2447 - @KronicDeth
Unquote.treeWalkUp
no longer assumes that the final argument tounquote
is aCall
.- Fix Find Usages for call definitions
- Don't resolve primary Find Usages element. The primary element passed to
FindUsageHandler
is now already resolved, so resolving it again for call definitions finds usages ofdef
,defmacro
, etc. - Since the element passed to
FindUsagesProvider#canFindUsageFor
, definers can no longer be excluded, so remove that check.
- Don't resolve primary Find Usages element. The primary element passed to
- #2449 - @KronicDeth
- Don't highlight
Quote
orSigil
as normal text if part of documentation. Since the annotators will run in arbitrary order, theTextual
annotator has to avoid annotating the same nodes as theModuleAttribute
annotator or the colors can get interleaved.
- Don't highlight
- #2450 - @KronicDeth
- Put
ENTRANCE
and Initial Visited Element in__module__.Resolver
.
- Put
- #2452 - @KronicDeth
- Keep searching when resolving type parameters if bitstring is encountered.
- #2453 - @KronicDeth
- Fix
UnaliasedName.unaliasedName
for atoms. - Restore
ElixirAtom#getName
Lost when parser was regenerated when Elixir <= 1.6 support was dropped in 679a9689cfe097018b9baa4e894d4550a84d7aac .
- Fix
- #2345 - @KronicDeth
- Override
Override org.elixir_lang.*.configuration.Factory.getId
to fix deprecation warning about the default implementation being accidentally localizable when it shouldn't be. The Elixir plugin didn't localize these name using message bundles, so this wasn't an actual risk, but overriding is the only way to silence the error.
- Override
- #2346 - @KronicDeth
- Stop look for qualifier at curly braces for
%{Alias}
.
- Stop look for qualifier at curly braces for
- #2179 - @KronicDeth
- Drop support for Elixir <= 1.6. Continuing support for Elixir <= 1.6 required special handling of the language level
to support differences in precedence and operators. Removing the language level tracking allows dropping the
Level
andFilePropertyPusher
classes and all their usages, including in the parser grammar and the specialifVersion
external rule. It also eliminates the need for tests to setup the SDK since it was only needed to get the appropriate Level. This makes the tests run in 45 seconds instead of 7 minutes.
- Drop support for Elixir <= 1.6. Continuing support for Elixir <= 1.6 required special handling of the language level
to support differences in precedence and operators. Removing the language level tracking allows dropping the
- #2339 - @KronicDeth
- Remove code dependent on the Erlang plugin Erlang plugin is not 2021.3 compatible yet
- #2179 - @KronicDeth
-
Resolve more calls and bindings in
Ecto.Query
calls-
Resolve bindings in
Ecto.Query.lock/3
-
Resolve bindings in
Ecto.Query.windows/3
-
Walk
preload
binding and expression -
Resolve in
update
for Ecto.Query -
Resolve
fragment
inwith_cte
-
Resolve
binding
andexpr
inEcto.Query.dynamic/1-2
-
Resolve
field
injoin(..., on: field(..., ...) ...)
Forjoin/5
, descend into the options to look foron: value
and then walkvalue
the same as the value tohaving
orwhere
in selects since they're all boolean conditions. -
Extract
ecto.query.Nested
-
Resolve
Ecto.Query.WindowAPI
functions -
Resolve reference variable src in
join(query, ..., [{src, counter}], ..., ...)
Tuple lists in join have two forms:{^assoc, a}
{src, counter}
The pinned association form was already handled because the second element was checked for a declaration, but the first element was not, so
src
in (2) could not be resolved. -
from([..] in ...)
-
Treat
or_having
the same ashaving
-
Treat
or_where
the same aswhere
-
Treat
having:
the same aswhere:
infrom
-
Treat
select_merge
the same asselect
for resolvingEcto.Query.API
. -
from(..., [elements])
-
Resolve Ecto reference variables in
left in ...
-
-
ModuleWalker
andNameArityRangeWalker
Reduce code by abstracting common pattern for walking library APIs. -
ExUnit
- Find modules declared in
test
s. - Resolve call definitions inside
describe
blocks. - Resolve variables in
assert_receive
andassert_received
. - Resolve
alias
to modules defined inside the enclosingdescribe
block. - Walk
assert
expression for variable declarations- Check for earlier bindings of variables in right operand of
=
inassert
.
- Check for earlier bindings of variables in right operand of
- Find modules declared in
-
Resolve
require
as:
arguments as Aliases -
Decompiler
- Erlang
- Decompile private Erlang functions
- Decompile specs from Erlang DbgI
- Decompile function bodies from Erlang DbgI
- Escape "in" when an Erlang Var in type
- Decompile types from Erlang DbgI Fixes #2017
- Decompile Elixir function bodies using DbgI
- :erlang./(a, b) -> a / b
- :erlang.*(a, b) -> a * b
- Convert :erlang.==(a,b) to a == b
- Rewrite case to
and
when there is a badbool error too - Decompile %{struct: name, ...} as %name{...}
- Rewrite more :erlang functions to Elixir
- Rewrite case to ||
- Rewrite
case expr1 do pat1 -> true; _ -> false; end
tomatch?(pat1, expr1)
- Rewrite
if var do false else true
to!var
- Rewrite case to or
- Rewrite case to and
- Rewrite :erlang.error(E.exception(M)) to raise E, M
- Rewrite case statements to if
- Rewrite case statements to &&
- Indent all lines of spec macro string in case it is multiple @spec
- Erlang
-
Resolve module attributes defined outside the immediate modular lexical scope
- Resolve module attributes registered in
elixir_module.erl
to decompiled source- after_compile
- before_compile
- behaviour
- compile
- derive
- dialyzer
- external_resource
- Resolve module attributes registered in
-
on_definition
- Index module attributes Use the index to resolve module attributes when it can't be found directly by tree walking.
-
Defined with
Module.put_attribute/3
-
Defined with
Module.register_attribute/3
-
Defined in
quote
blocks
-
- Resolve variables to variables in any
quote
blocks If a variable can't be resolved in the scope, try resolving it to any variable declared at the top-level of aquote
block. This helps with certain patterns ofquote
blocks used in Ecto where a variable's declaration and usage are not in the samequote
block. - Simplify CallDefinitionClause resolver for modulars Due to the addition of skipping if the entrance is a child call,
the check for only following siblings is no longer needed. Additionally, that check caused a bug because
the
ElixirStabBody
skipped call definitions because they were new scopes. - Resolve functions declared with
Mix.Generator.embed_template
andembed_text
. Also, new system for tracking resolves paths -import
s,defdelegate
, anduse
calls are added to the resolve results after the preferred elements are chosen for source in the same module. This prevents only theimport
showing because the actual declaration is in another module or the SDK. - Record a call as visited in its
treeWalkUp
instead of requiring the caller to do it in the passResolveState
- Record
quoteCall
as visited inQuoteMacro.treeWalkUp
- Record
unquoteCall
as visited inUnquote.treeWalkUp
- Record
unlessCall
as visited inUnless.treeWalkUp
- Record
ifCall
as visited inIf.treeWalkUp
- Record
importCall
as visited inImport.treeWalkUp
- Record
useCall
as visited inUse.treeWalkUp
- Record
- More macro specialized in Structure View
test
describe
- Resolve
Qualifer.unquote(variable)(...)
to any definition with correct arity inQualifier
. - Only calculate
element.resolvedFinalArity
once inresolvedQualified
- Implementations and Protocols
- Redo icons
- Implementations Go To Protocol line markers
- Go to Super for calls to
defimpl
function/macro Goes to corresponding name/arity in thedefprotocol
that thedefimpl
implements. - Go to implementations line marker from defprotocol def
- Go to implementations line marker from defprotocol
- Go To Implementation from individual functions in defimpl
- Go To Implementation from defimpl Alias
- Resolve protocol function to
def
in defprotocol - Resolve defp inside of defimpl Process declarations inside of implementation the same as modules.
- Stop
prependQualifiers
at top of file - Walk the false and true (else) branch of unless in Modules or Quote
- Walk the true and false (else) branch of if in Modules or Quote
- Port
preferred
andexpand
system fromCallables
toModules
. - Update CI build dependencies
- #2199 - @KronicDeth
- Regression test for #2198.
- #2201 - @KronicDeth
- Use callbacks as completions for calls.
- #2223 - @KronicDeth
- Decompiler
- Don't require
MacroNameArity
foraccept
, but useNameArity
only because no decompiler cares about the macro.
- Don't require
- Tests for Code.Identifier and String.Tokenizer
- Decompiler
- #2226 - @KronicDeth
- Structure View for
EEx.function_from_(file|string)
- Variants (completion) for functions declared by special macros.
- Functions defined by
EEx.function_from_(file|string)
exception/1
andmessage/1
defined bydefexception
*_text/0
and*_template(assigns)
functions defined byMix.Generator.embed_text
andMix.Generator.embed_template
.
- Functions defined by
- Structure View for
- #2334 - @KronicDeth
- Internal Tool for BEAM Bulk Decompilation Decompile all .beam files in the project, modules and SDKs to check for errors in the generated Elixir code
- Decompiler
- Erlang Abst
- Log decompilation errors
- Erlang Abst
- Error Reports
- Include system information in error reports Instead of just including the plugin version, also include the Application name, edition, and version; and the Operation System name and version as these are common follow-up questions I have.
- Remove tab at start of location for title of issues
- Don't include "java.lang.Throwable: " in title of issues The
Throwable
is necessary to get a stacktrace, but not a real error.
- #2339 - @KronicDeth
- Build against
2021.3
runPluginVerifier
in GitHub Actions- Update IDEA version range supports and verified
- Fix reported compatibility warnings
- Inline deprecated bundle messages
- Don't bundle built-in markdown plugin, depend on it instead
- Build against
- #2074 - @Thau
- Alternative function clause for
put_event
withsuite_finished
- Alternative function clause for
- #2179 - @KronicDeth
- StackOverflow fixes
-
getElementDescription(ElixirAtom, ElementDescriptionLocation) Override getElementDescription for atoms to prevent StackOverflow while looking for a provider.
-
Don't descend into either branch of
if
orunless
if entrance in either branch when resolving calls. If the definition were in one of the branch, it would already have been found on processing previous siblings in theElixirStabBody
. -
Treat child of modulars as being at the same level if nested in
if
orunless
Preventstest
inif
insupervisor_test.exs
inecto
from stack overflowing. -
Fix StackOverflow when looking for earlier bindings in parameters.
-
Don't check following siblings of modulars if entrance is a direct child
Prevent StackOverflow when trying to resolve embed_template when more than one appears in the same module.
In general, if the entrance is a child of modular then it can only be defined by a previous sibling, usually an
import
oruse
, but if the entrance is descendant of a child, then it child then it may be a call to a function or macro defined in the modular to following siblings of the entrance ancestor child needs to be checked if the entrance is a forward-call to a later declared function or macro. -
Fix StackOverflowError in ifErlangRewriteTo Don't rewriter :erlang.* to a different :erlang.*
-
- Adjust nameArityInterval in nameArityInAnyModule Ensures that
fragment/1..
used in aquote
can resolve to one inEcto.Query.API
. - Resolve variable that are the only child of
quote
Ecto loves doingquote do: query
or other variable names in the code and tests, so record those as declarations to resolve as invalid results. - Find enclosing macro call when keyword
do:
is surrounded by parentheses Previously, onlyquote do: variable
would work, but nowquote(do: variable)
also works to find thequote
call. - Don't mark fields and keys that are not expected to be resolvable yet as unresolvable in Elixir References
inspection.
QualifiedBracketOperation
qualifierStructOperation
qualifier- Expect qualified
unquote
to only have invalid results. - Don't mark invalid only results for first chained function call. Don't
report
unquote(schema).__schema__(:source)
- Don't mark invalid only results for chained function calls. Don't
report
Mix.shell().yes?("Are you sure you want to drop the database for repo #{inspect repo}?")
- Don't mark invalid resolved function of call output
- Don't mark invalid resolved keys or fields of call output
- Don't mark invalid resolved function call on keys or fields
- Don't mark parentheses calls on variables if the call does not resolve. Can't find exact valid resolves on variables yet.
- Don't mark keys or fields on the output of a function call.
- Fix some bugs with
Ecto.Query
calls.- Add missing
state.put(Query.Call, call)
forjoin/3-4
executeOnIn
. - Walk the operands of
|>
inselect
expressions. - Resolve pinned variables as normal instead of as reference variables for Ecto.Query calls.
- Don't walk keywords that cannot declare reference variables.
hints
lock
intersect
intersect_all
except
except_all
union
union_all
prefix
preload
offset
windows
limit
- Don't treat signature for call definition as use of Ecto macro
- Add missing
- Don't generate references to aliases, functions, or types that don't have declarations
assoc/2
injoin: .. in assoc(_, _)
in a no parenthesesfrom
callvar
in type restrictions Related to elixir-ecto/ecto#3756BitString
BitString
is recognized indefimpl ..., for: BitString
to define protocol implementations for<<..>>
, but theBitString
module itself does not exist, so can't be resolved.
- Error reporting
- Ignore
at com.intellij.openapi.diagnostic.Logger
when calculating location for error report titles - Improve error report format sent to GitHub
- Fix the
event
message
not being included, which meant that the excerpt wasn't included, so no reproducibility or element class was available. - Filter stacktrace to stop at last line from the plugin to limit their size and improve chance of URL being short enough for GitHub.
- Don't include "What I was doing" section unless user actually fills in the additional information in the UI form. I'm sick of seeing the issue tracker full of "I don't know what I was doing", which is the default text when no additional info is given in the UI form.
- Set title to the message at start of exception and first
at
that isn't from theerrorreport.Logger
instead of[auto-generated]
as this is the pattern I follow when renaming manually.
- Ignore
- Handle
alias __MODULE__.{...}
in prependQualifier Fixes #2153 - Log error, but don't fail with TODO() for unknown strippedQualifier or null qualifier Fixes #2153
- Go To Declaration for captures
-
Don't allow name to be acceptable named parent in
&name/arity
. Resolves #488 Allows Go To Declaration onname
and not just on/arity
. -
Don't allow
Mod.name
to be acceptable named parent in&Mod.name/arity
. Resolves #488 Fixes #2101Allows Go To Declaration on
name
and not just on/arity
. -
Resolve
&name/arity
and&Mod.name/arity
using same code as callables. Fixes resolving &Mod.name.arity and ensures that special handling for weird definitions for callables also apply to captures.
-
- Resolve
__MODULE__
inquote
todefmacro __MODULE__
inKernel.SpecialForms
- Performance
-
Fix String.Unicode decompiled being PlainText instead of Elixir
String.Unicode
when decompiled using all information fromDbgI
was 161,171 lines long, which made the JetBrains API treat it as plain text instead of Elixir. Being that long also made it freeze the UI while being decompiled.Now, don't even attempt to use the
DbgI
if the function has more than 10 clauses. -
Don't decompile private macros and functions if > 500 definitions in one module.
-
If body cannot be decompiled, decompile as one-liner with
...
body -
Don't decompile Abst clause bodies that exceed 1024 bytes.
-
Decompile Erlang one clauses as Elixir one-liners
-
- Fix resolving type specs
-
Find
ancestorTypeSpec
for qualified type used in parentheses in anonymous function type in an alternation
* Resolve type parameters used in inline anonymous function types * Resolve callback heads to themselves when they have type restrictions using when * Ignore literal parameters * Decimals * Aliases * Check left operand of `\\` for type parameters as they could appear when copying def with defaults.
-
- putInitialVisitedElement in variable.Variants Fixes #2002
- Walk
defdelegate
s when walkingimport
s Fixes resolvingconfig
fromuse Mix.Config
as it delegates toConfig
- Resolve variables used in
match?
guards to pattern declaration Resolveson_delete
inmatch?(%{on_delete: on_delete} when on_delete != :nothing, reflection)
- Implementations and Protocols
- Fix calculating definition for stubs of defimpl with
for:
There was no clause for defimpl being arity 3, which is the case when there is the (1) protocol (2)for:
and (3)do
block. Not having a definition meant that thedefimpl protocol, for: struct do
would be in AllName index, but not ModularName. - Get name of enclosing modular for defimpl without
for:
- Fix calculating definition for stubs of defimpl with
- Store if stubs are guards
- Decompiler
- Surround
case
statements with parentheses when used incond
clause conditions - Convert OtpErlangString to OtpErlangList for tuple and call argument lists
- Escape ESC character as \e
- Handle Clause arguments being OtpErlangString
- Handle tuple elements being an OtpErlangString
- Add missing
.
after callee when it is a module or fn - Protect from
Macro.toString(macro)
StackOverflowError when decompiling body of function clauses - Don't print function names as atoms in captures
- Escape
\x
to\\x
in OtpErlangStr - Fix rewrite of :erlang calls
- Surround type unions with parentheses Prevents parsing problems with unions in guard (when) clauses
- Don't use
prependIndent
because it indents blank lines too. This doesn't matchmix format
or the IntelliJ Elixir formatting. - Erlang
- Escape fn Erlang variable
- Escape Erlang char \ as \
- Don't append lines for clauses or
after
in Erlangreceive
when decompiling if empty. - Use
Infix
,Prefix
, andUnquote
decompolers for Erlang Abst chunk in addition to DbgI chunk- functions
- typesepcs
- Use
function.macroNameArityMacro.macro
when decompiling Erlang Abst clauses. Don't usedef
anymore when unexported and therefore private; usedefp
instead. - Remove space after
...
in decompiled private types.
- Surround
- Process imports for calls Imports were previously only processed inside of Modules and not in general, which means
that imports in the file were not processed, which is needed for
association.ex
in Ecto. - Classify ..// as OTHER instead of NOT_CALLABLE, so that it is escaped as a key.
- Fix Macro.ifCaptureModuleNameArity
- Resolve variable to parameter in
%parameter{}
patterns for struct names Unquote.treeWalkUpUnquoted
through tuplesQuote.treeWalkUp
throughcase
- Stop searching on numerical index in binding
- Stop searching if atom in wrong place in binding Stops invalid binding test from erroring when resolving it.
- Turn off
tailrec
because it doesn't work correctly forElixirAccessExpression
- Stop searching for qualifier when
ElixirUnqualifiedNoParenthesesManyArgumentsCall
.
- StackOverflow fixes
- #2199 - @KronicDeth
- Stop highlighting types when
unquote_splicing/1
is reached.unquote_splicing
is being used to splat arguments or fields of a struct into the type. The arguments tounquote_splicing
are normal calls or variables, not types.
- Stop highlighting types when
- #2201 - @KronicDeth
- Implement
call_definition_clause.Variants#executeOnCallback
- Implement
- #2204 - @KronicDeth
CallDefinitionClause.time/1
- Mark guards as runtime.
- Mark anything unknown as runtime too.
- Log unknown calls.
- #2207 - @KronicDeth
- Check if
Call
isValid
before usingcontainingFile
forlocationString
.
- Check if
- #2208 - @KronicDeth
- Check if
project
is not dumb innameArityInAnyModule
.
- Check if
- #2209 - @KronicDeth
- Take
resolveInScope
only if at least one valid Checking only for an empty collection allowed any prefixes in the scope to override exact matches in anywhere indexed, which meant thatEcto
indefmodule Ecto.Adapter do
resolved to itself instead of the exactdefmodule Ecto do
.
- Take
- #2214 - @KronicDeth
- When regenerating the parser,
ElixirVisitor
is also regenerated. When it was regenerated it lost the bug fix for#visitLiteralSigileLine
calling itself. Added a regression test, so that this can't happen again.
- When regenerating the parser,
- #2223 - @KronicDeth
- Ecto
- Walk keyword keys as right operand of
in
infrom
- Walk keyword keys as right operand of
- Resolving type references
- Walk struct operations for type parameters
- Check keyword values for type parameters
- Check operands of two operations for type parameters
- Stop looking for type parameters on qualified or unqualified alias
- Decompiler
- Only unquote
in
when an Erlang function, otherwise, use operators the same as Elixir for defs and calls. - Fix apply Erlang arguments, so that they are inside
[]
. - Quote keyword keys containing
-
Fixes decompiling ofElixir.Phoenix.HTML.Tag.beam
- Use apply with escaped atom when Erlang function call is an Elixir operator
- Only unquote
- Port String.Tokenizer.tokenize for use in Identifier.inspectAsKey I was putting off porting all
of
Identifer.inspectAsKey
by adding special cases as needed, but the decompiler kept having bugs, so port all of it includingString.Tokenizer.tokenize
. It will also work for unicode characters now too. - Resolve calls that are unquoted values to search for quote blocks in those functions.
- Stop looking for qualifiers to prepend when reaching
=>
- The parent argument to AccumulatorContinue.childExpressionsFoldWhile should be this and not parent When converting
to an extension function I left
parent
in place because the argument is calledparent
, but since it is an extension function that value becausethis.parent
when it really should have beenthis
. Usingthis.parent
meant it would ask for the parent's children and keep looping back tothis
. - Don't use
tailrec
in function with any body-recursion. It causes issues withElixirAccessExpression
recursion sometimes.
- Ecto
- #2226 - @KronicDeth
- Implement completion for functions declared with
defdelegate
. - Fix
LookupElementPresentation.putItemPresentation
addTailText
. Only append suffix ofpresentableText
if it is prefixed byitemText
.
- Implement completion for functions declared with
- #2334 - @KronicDeth
- Decompiler
- Elixir
- Decompile local function calls in Elixir DbgI using inspectAsFunction While remote calls
used
inspectAsFunction
, local calls just used theatomValue
, which meant names that needed to be unquoted weren't and caused parsing errors.
- Decompile local function calls in Elixir DbgI using inspectAsFunction While remote calls
used
- Erlang Abst
- Decompile Erlang Abst string with OtpErlangList as strings with non-ASCII codepoints Fixes unknown string format
in
idna.beam
- Always group for comprehensions in sequence even if there is only 1 element Some forms of
for
comprehensions cannot be used as the sole argument of a call unless surrounded by parentheses, so always add those parentheses. - Decompile Erlang Abst record empty record fields as
[]
for updates - Decompile Erlang Abst
left xor right
as:erlang.xor(left, right)
Elixir does not have a logical xor infix operator, so have to decompile as normal function call - Decompile Erlang Abst named anonymous function as a macro Named anonymous functions are support in Erlang, but not Elixir, so fake it as a macro when decompiling.
- Add builtin-types for Erlang Abst
bitstring
float
nonempty_improper_list
nonempty_maybe_improper_list
- Decompile tagged atoms and other complex expression as function name in Abst capture
- Decompile Erlang Abst
float
- Decompile Erlang Abst
begin
blocks as parenthesized groups separated by ; - Decompile empty OtpErlangList as "" in Erlang Abst
string
- Track if decompiled Erlang Abst contains do blocks so that they can be surrounded by parentheses when necessary
- Fix decompiling Erlang Abst
record_index
when record name needs to be unquoted - Decompile
map
updates in Erlang Abst - Erlang Abst Function capture names are OtpErlangAtom and not tagged Atoms
- Inspect local function names as atoms instead of as functions when apply/3 is used for operations and unquoted
in Erlang Abst Stops
:unquote(:"NAME")
from happening - Surround anonymous function definitions that are called immediately with parentheses and call arguments with .( in Erlang Abst
- Decompile
field_type
in Erlang Abst Fixes decompilinghipe_icode_call_elim.beam
- Inspect type name usages as local functions to ensure invalid names are unquoted
- Inspect type names as local functions to ensure invalid names are unquoted
- Decompile Erlang Abst string with OtpErlangList as strings with non-ASCII codepoints Fixes unknown string format
in
- Elixir
- References
- Stop looking for qualifiers to prepend when exiting interpolation
- Don't safeMultiResolve null call.reference in resolvesToModularName
- Types
- Fix highlighting types declared with unquote and no secondary parentheses
- Performance
- Don't error if a private function mirror cannot be found Private functions are not decompiled if there are too many public functions.
- Fix CallDefinitionImpl.isExported Used to be hard-coded to return
true
, but this pre-dated decompiling private functions. Now with decompiling private functions, isExported needs to defer to theDefinition
and count as unexported if a private function, macro, or guard.
- Decompiler
- #2337 - @KronicDeth
- Walk map constructin arguments, associatons, and variables when resolving type parameters.
- #2339 - @KronicDeth
- Don't use
PluginId.findId
that doesn't exist in 2021.1.X
- Don't use
- #2035 - @theqp
- Update build to IntelliJ IDEA 2021.2.
- Upgrade to Gradle 7.1.1.
- #2036 - @KronicDeth
- Expand compatibility range to 2021.1.2-2021.2.
- #1988 - @KronicDeth
- Only descend into modular children of modular for Module scope. Prevents recursion loops on use calls.
- Don't search for unquoted variable value variable is value for
do:
. - Protect from
IndexNotReady
inresolver.Module.multiResolveProject
. - Stop walking unquoted variable that resolves to a parameter.
- Walk case in
__using__
to find quote in any clause. Fixes resolving test macro fromuse PowerAssert
- Resolve functions declared in
quote
's scope whenblock
injected withunquote(block)
. Fixes resolvingfield
,timestamps
, andindex
inschema
foruse Yacto.Schema
as it makes theblock
see theimport Yacto.Schema
aboveunquote(block)
in thequote
inschema(..., do: block)
.
- #1990 - @KronicDeth
- Convert MissingSDK errors for Dialyzer into Notifications.
- #1993 - @KronicDeth
- Log element in psi.scope.Type instead of using
TODO()
Error will still be reported, but there will be enough information to triage and sincetrue
is returned now it won't stop the type resolving from working.
- Log element in psi.scope.Type instead of using
- #1994 - @KronicDeth
- Add missing mix deps options to non-path influencing list:
- env
- manager
- repo
- sparse
- submodules
- system_env
- Add missing mix deps options to non-path influencing list:
- #1995 - @hurricup]
- Fix incorrect
OuterElementType
ineex.lexer.TemplateData
. TheEEX
IElementType
needs to useOuterLanguageElementType
instead of the directeex.psi.TokenType
.
- Fix incorrect
- #1996 - @KronicDeth
- Run
QualifiedAlias#text
inrunReadAction
forQualifiedAlias#name
- Run
- #1997 - @KronicDeth
- Return
null
Chunk
instead of throwingIOException
when read incomplete. Incomplete reads happen often due to incomplete writes to the file system being read in. As such, they shouldn't generate error reports and instead should be silently ignored.
- Return
- #1999 - @KronicDeth
- Implement
beam.FileEditor#getFile
to fixDeprecatedMethodException
as the default implementation is now deprecated and requires an explicit implementation. - Use
TabbedPaneWrapper.AsJBTabs
instead ofJBTabbedPane
for "BEAM Chunks" tabs. I'm not sure whyJBTabbedPane
stopped showing its labels sometime in the 2020.X IDE version series, but by debugging when "BEAM Chunks" name was retrieved I found that the bottom tabs usedTabbedPaneWrapper.asJBTabs
. Using that, the labels reappeared.
- Implement
- #2000 - @KronicDeth
- Don't require Alias qualifier to be a
PsiNamedElement
. It can be anElixirAtom
and getting the reference will still work.
- Don't require Alias qualifier to be a
- #2001 - @KronicDeth
Any.isDecompiled
forCallDefinitionHead
.
- #1988 - @KronicDeth
-
Find
Dep
s in function calls in thedeps()
list. -
Dep.putPath
from a variable. -
Treat
Memoize
defmemo
asdef
anddefmemop
asdefp
. -
Resolve
exception/1
andmessage/1
todefexception
. -
Resolve to callbacks when searching in any module.
-
Support arity intervals for unquote_splicing in parameters
Functions defined with unquote_splicing, such as
Ecto.Schema.__schema/2
:
Need to have their arity not be the number of PsiElements in the parentheses. Any call to `unquote_splicing(...)` can end up have 0 to infinite parameters, so it means when one is saw, the range of `minimum...maximum` should change to an open interval of `minimum...`. This required changing `IntRange resolvedFinalArityChange()` to `ArityInterval resolvedFinalArityInterval()` on all `Call`s, which was a large change. It also meant changing a lot of ArityRange types to ArityInterval, and NameArityRange to NameArityInterval, which influenced the variable names. Since all Calls support ArityIntervals now and not just special forms and Ecto DSLs, exportArity is changed to always state the ResolveState, so that the special form changes can be integrated for all callers. The actual implementation of CallImpl.resolvedFinalArityRange is changes to fold over the ArityInterval: * Normal arguments increase the minimum and maximum. * Default arguments increase only the maximum. * unquote_splicing changes the maximum to null to indicate the interval is half open.
-
- #1948 - @KronicDeth
-
Reference Resolution
-
Allow any Alias in a chain to have references. This allows going to the declaration of
Phoenix
,Phoenix.LiveView
, orPhoenix.LiveView.Socket
depending on whether you're on thePhoenix
,LiveView
, orSocket
Alias, respectively, in the chain.-
Allow any Alias in Qualified Alias to be resolved This allows going to the declaration of Phoenix, Phoenix.LiveView, or Phoenix.LiveView.Socket depending on whether you're on the Phoenix, LiveView, or Socket Alias, respectively, in the chain.
-
Update DocumentationProvider to work with improved Alias resolution
Without these changes the DocumentationProvider double-resolves and so ends up showing the docs for
def
anddefmodule
, instead of the call definition clause or module, respectively.
-
-
Reimplement Module references Instead of references for only the outermost QualifiableAlias, there is a reference for each right-most Alias at a given position, so instead of there only be a reference to
App.Context.Schema
inApp.Context.Schema
, there is now a reference toApp
in theApp
prefix, a reference toApp.Context
inContext
inApp.Context
, and a reference toApp.Context.Schema
inSchema
inApp.Context.Schema
. Not only is this more useful, being able to jump to parent namespaces, but it fixed some of the capability issues with Go To Definition in the 2020 line of IDEs. This approach of usinggetRangeInElement
to target the range of the right-most Alias, while the element was still the parent that contained, but did not go beyond the Alias, was tried after having references only onAlias
es and notQualifiedAlias
es did not fix completion issues. It was the while debugging Go To Declaration actions and noticing they were sensitive to the range in element AND the docs for PsiReference#getRangeInElement that I realized that the Go To Declaration and Completion has a hidden requirement that References for things that behave like namespaces have to work this way.- Use
ModularName
index for Module Variants Have a smaller index to iterate and remove need for theisAlias
check.
- Use
-
Limit Elixir Module resolution to same JetBrains Project Module
- Change the
GlobalSearchScope
fromallProject
tomoduleWithDependenciesAndLibrariesScope
for faster searching on multi-module projects.- Set
includeTests
based whether the referring element is in a test directory.
- Set
- Use
StubIndex#processElements
instead of home grownforEachNavigationElement
asprocessElements
is more efficient.
- Change the
-
Favor Module
ResolveResults
under sameModule
content roots This should favor deps sources in the same module. -
Iterate
function
body inunquote(function())
when iterating call definition clauses inquote
Treats itfunction
body the same as a__using__
body. -
Standardized preferred
ResolveResult
filters between Callables and Modules- Prefer valid results as long as it doesn't leave no results.
- Prefer results in the same module as long as it doesn't leave no results.
In Go To Declaration also:
- Prefer results in source (that aren't decompiled) as long as it doesn't leave no results.
-
Use the second argument to
use
to determine which function is called with apply/3This pattern is used in Phoenix
__using__
, so this lets to differentiate whetherPlug.Conn.assign/3
orPhoenix.LiveSocket.assign/3
is resolved in a Controller, LiveComponent, or LiveView. -
In LEEx Templates
- Resolve function calls in
*.html.leex
templates to functions defined in the corresponding LiveComponent/View module. - Assigns
- Resolve assigns in LEEx templates to the keyword key in
assign/3
calls inupdate/2
in the LiveComponent or LiveView Had to add back in aTargetElementEvaluator
, so that theUnqualifiedNoArgumentCall
(name
) that is the identifier in an assign (@name
) was not counted as valid target for Find Usages / Go To Declaration by itself. - Search for assigns in all call definitions in view module Expand from just
update
to any call definition to cover helper functions and other callbacks. Don't stop on the first valid match because with helper functions and multiple callbacks, the last write isn't obvious. - Resolve assigns set with
assign/3
- Look for
assign
calls in|>
pipelines - Resolve assigns set with
assign_new/3
- Resolve @live_action to where it is assigned Phoenix.LiveView.Channel.assign_action/2
- Find assigns in maps for assign/2 Since assign/2 accepts either a keyword list or a map, check in both types.
- Resolve @myself to where it is set in
render_pending_components
- Resolve assigns in macros with do blocks like
case
andif
- Find assigns in
live_component
calls If an assign can't be found in the body of a LiveComponent module, then it maybe passed through from thelive_component
call itself, so look for any references to the view module ( the LiveComponent) and if it is alive_component
call, then look at those assigns to try to resolve the assign name. - Resolve assigns to
live_modal
callslive_modal
is not built intophoenix_live_view
, but it is generated byphx.gen.live
, so most projects will have it. This allowsreturn_to
, which is used use inlive_modal
, to be resolved. - Resolve
@socket
to last socket variable or call in view module. - Resolve
@flash
toput_flash/3
calls. - Resolve
@inner_content
toPhoenix.LiveView.Utils.to_rendered/2
setting the assign withput_in
- Resolve assigns in LEEx templates to the keyword key in
- Resolve aliases in
.leex
templates Generalize the.leex
anduse
walking from call definition clauses to any scope processor lambda, so it can be used to resolve uses ofRoutes
in.leex
templates.
- Resolve function calls in
-
Resolve Types
- Have separate references specifically for Types.
- Resolve to both types declared with
@type
,@typep
, or@opaque
; and named type parameters. - Process declarations for
@type
,@typep
, and@opaque
. - Count
@callback
as declaring a Type - Resolve type
t
fordefprotocol
to where it is defined inProtocol.__protocol__
Unfortunately, this ties all protocol'st
to the same element, so Find Usage finds all protocol's types instead of just a specific module's type, but this works for projects that have source, but not yet compiled.- Favor protocol-specific decompiled
@type t
when available.
- Favor protocol-specific decompiled
- Resolve type variable to the keyword key in guards.
__MODULE__
-
Favor source over decompiled per name instead of overall for
ResolveResultOrderedSet
This allows theRoutes
alias to be resolved to the both theMyAppWeb.Router.Helpers
inalias MyAppWeb.Router.Helpers, as: Routes
in the source ofMyAppWeb
, but also the decompiledMyAppWeb.Router.Helpers
, which is necessary asMyAppWeb.Router.Helpers
is produced on compile fromrouter.ex
. -
Resolve references through
defdelegate
calls. -
Resolve
code_reloading?
in MyApp.EndpointThe generated
MyApp.Endpoint
formix phx.new
has a section to enable code-reloading at compile time:
if code_reloading? do socket("/phoenix/live_reload/socket", Phoenix.LiveReloader.Socket) plug(Phoenix.LiveReloader) plug(Phoenix.CodeReloader) end
Previously, `code_reloading?` variable would not resolve because psi.scope.Variable ignored `use` calls, not `use` calls are entered and the `var!(code_reloading?)` is found in `Phoenix.Endpoint.config/1` by way of the `unquote(config(opts))` call in the `quote` block in `__using__(opts)`. * Resolve qualified calls with unknown resolvable qualifier using only relative identifier and arity. * `@spec` * Resolve `@spec` to `defdelegate` calls. * Resolve @specs to the definitions if the definitions are in a for comprehension * `Ecto` * `Query` * Resolve reference variables in `Ecto.Query` * Reference variables are introduced in as the left operand of `in` passed to `from/2` and the `join:` keyword in `from/2`. * `join/3-5` * Resolve bindings in `select/2-3`. * Resolve reference variables in `where/2,3` binding. Also add support for resolving `a` in `[{^assoc, a}]` binding. * Resolve `bindings` in `group_by/2-3`. * Resolve `bindings` and `expressions` in `order_by/2-3`. * Resolve `bindings` in `having/2-3`. * Add `select_merge` to declaring `Ecto.Query` macros. * Add `distinct/2-3` as a declaring `Ecto.Query` macro. * Resolve `field` calls in Ecto `schema` blocks How `field` works in `schema` for `Ecto.Schema` 1. `use Ecto.Schema` 2. `Ecto.Schema.__using__` 3. `import Ecto.Schema, only: [schema: 2, embedded_schema: 1]`` Note that only the outer DSLs, schema and embedded_schema are available even though field/2 is defined in Ecto.Schema. So when you call `schema ... do` 1. `defmacro schema(source, [do: block])` 2. `schema(__CALLER__, source, true, :id, block)` 3. `defp schema(caller, source, meta?, type, block)` 4. There's a big `prelude = quote do` quote block At the end of prelude there is ```elixir try do import Ecto.Schema unquote(block) after :ok end ``` Hey! An `import Ecto.Schema`, but `prelude` is just floating as a variable. At the end of `defp schema(caller, source, meta?, type, block)` is ```elixir quote do unquote(prelude) unquote(postlude) end ``` So to statically analyze an `Ecto.Schema` module. 1. Resolve `schema/2` to `defmacro schema` by walking the `use`, `__using__`, `quote`, and `import`. 2. Inside the `schema/2` (or macros in general if you want to get fancy 💅 and support more DSLs), 3. Go into the body of the macro. If there's a call, resolve it 4. Go into the called function 5. Look for a `quote` block at the end (the same as my current `__using__` support) 6. If there's a `Call` inside an `unquote` see if you can resolve it to a variable in addition to a call definition (which is already supported for Phoenix). 7. If it's a variable, check it's value. If it's a `quote`, use the quote block handling 8. In the quote block handling add support for `try` 9. Walk the `try` and see the `import`, walk the `import` to find `Ecto.Schema.field/2` * `API` * Resolve `Ecto.Query.API` functions in `Ecto.Query` * `from(order_by: ...)` * `from(select: ...)` * `from(select: tuple())` * `from(where: ...)` * `group_by/2-3` * `having/2-3` * `select/2-3` `expr` argument * `where` * Resolve `Ecto.Query.API.fragment` to arity interval `0..`. * Resolve `fragment` nested in other `Ecto.Query.API` call like `type`. * Walk `rightOperand` of `join(..., ... in ..., ...)` for `Ecto.Query.API` usages like `fragment`. * Resolve module attributes defined in `use` `__using__` `quote` block * Change `org.elixir_lang.reference.resolver.ModuleAttribute` to use `PsiScopeProcessor` for non-`@for` and non-`@protocol` instead of custom logic. * Don't descend into a `use` if the `ENTRANCE` is an ancestor since that means the `Alias` on the `use` is probably being resolved. * `AtUnqualifiedNoParenthesesCall.processDeclarations` will call `processor.execute` when it isn't a type spec. * The `UseScopeSelector` for `AtUnqualifiedNoParenthesesCallImpl` has been changed to `SELF_AND_FOLLOWING_SIBLINGS` since the module attribute is used that way. The previous `SELF` value was when the `UseScopeSelector` only applied to variables.
-
-
"Elixir References" inspection for finding unresolved or invalid references.
visitAtNonNumericOperation
Helps "Elixir References" find unresolved assigns.
-
Strip
AccessExpression
s fromQualified
qualifiers automatically -
Documentation
- Show
deprecated
,impl
, andspec
, and actual heads in documentation for source functions - Merge
Documentation
across multiple arities when arity of lookup is ambiguous.
- Show
-
Find variables defined in EEx element Finds variables defined in EEx PsiElement by creating them the same as a StabBody, which means that the siblings are checked backwards from the last parent. This fixes resolving the
f
fromf = form_for ...
in*input f ...
in LiveView FormComponent templates. -
Highlight named parameters in types.
-
Decompilation
- Fake built-in types by decompiling in
:erlang.beam
For type reference resolution of built-in types to work, they need to be defined somewhere. IntelliJ Erlang does this by looping usages back on themselves, but this leads to Find Usages not working for built-in types since each usage is a distinct declaration. By instead defining the types in decompiled:erlang.beam
(even though they aren't actually defined there), there is a shared location for all reference to point to and then check for Find Usages. - Decompile types from EEP-48 documentation.
- Fake built-in types by decompiling in
-
Descend into body of
unless
inquote
fortreeWalkUp
. -
Descend into
for
when looking for call definition clauses. -
QuoteMacro.treeWalkUp
intoif
unless
was already walked, but notif
. Fixes resolvingRepo.preload/2
, which is defined inside anif
inuse Ecto.Repo
's__using__
. -
Add
defguard
anddefguardp
to CallDefinitionClause.is
. -
Don't generate a reference for
Elixir
Elixir
is not declared anywhere. It is the namespace of all Aliases. -
Refactor how sibling sequences are walked Port filtering out comments, white space and end of expressions from
siblingExpression
. -
Reimplement
fullyQualifiedName
Eliminate the specialization for
ElixirAlias
ANDQualifiableAlias
as which was picked as based on the static casted type.fullyQualifiedName
will include the following:- Convert
__MODULE__
to the enclosing modular canonical name - Combine an ElixirAlias with its qualifier
- If in a
ElixirMultipleAliases
will combine the qualifier (qualifier.{...}
) outside the{}
with the relative name inside...{relative, ...}
.
- If in a
- Convert
-
EEx
viewFile
for.eex
files used in same directory as.ex
usingEEx.function_from_file
.- Resolve function calls to those defined by
EEx.function_from_file/3-5
. - Find view modules for templates under the
templates
directory.
-
Walk
quote
macros for sibling call definitions -
Always fallback to name/arity in any module if callable not resolved in scope
-
Resolve uses of aliased name produced by
alias __MODULE__
-
- #1967 - @KronicDeth
- Updates
- IntelliJ IDEA build version to 2021.1.2
- Update
ParsingTestCase
to latest APIs.
- Update
- Gradle plugins
- intellij 1.0
- kotlin.jvm 1.5.10
- IntelliJ IDEA build version to 2021.1.2
- Configure
runPluginVerifier
- Updates
- #1948 - @KronicDeth
-
Fix Ctrl+Click/Cmd+B/Go To Declaration for Aliases.
-
Don't index non-canonical names. The non-canonical name for a nested
defmodule
is the Alias given to thatdefmodule
call. While that name should be resolvable within the parent modular, it should not be indexed because the index is for the global scope.Prevents
defmodule Enum
in
from being indexed as `Enum`, which hides the decompiled version from the standard library because source references are favored over decompiled versions when resolving references. * Reference Resolution * Only favor same file Module resolutions if they are valid Invalid same file results can occur for prefix matches, but if only prefix matches are available, then a whole project search should occur instead of only when there are no same file `ResolveResult` of either validity. * Include library sources in `Module#multiResolveProject` `GlobalSearchScope` Ensures that library sources can be returned, which are favored over decompiled libraries, so that `__using__` macros can be followed. * Protect from `Module` reference element not having a `VirtualFile` when checking if a test file. * Fix `QualifiableAliasImpl#fullyQualifiedName` * Include qualifier of `MultipleAliases` In an `alias` line like `alias Myapp.MyContext.{Schema1, Schema2}`, `Schema1` would think its `fullyQualifiedName` was only `Schema1`, when it should included the `fullyQualifiedName` of the qualifier, `MyApp.MyContext` too. This leads to the correct `Schema1` fully-qualified name of `MyApp.MyContext.Schema1`. This fix makes references to `Schema1` resolve to both the `alias` and the `defmodule`. * Include qualifier of `MultipleAliases` for deep aliases In an `alias` line like `alias Myapp.MyContext.{NestedContext1.Schema1, NestedContext2.Schema2}`, `Schema1` would think its `fullyQualifiedName` was only `NestedContext1.Schema1`, when it should included the `fullyQualifiedName` of the qualifier, `MyApp.MyContext` too. This leads to the correct `Schema1` fully-qualified name of `MyApp.MyContext.NestedContext.Schema1`. This fix makes references to `Schema1` resolve to both the `alias` and the `defmodule`. * In LEEx Templates * Don't check for implicit imports at top of template file if there is a view file The implicit imports should come last, after the view file has been processed. * Ignore call definition clauses expressions that can't contain an assign * Atom keywords (`false`, `true`, `nil`) * Maps * Structs * Keyword lists * Strings and charlists * Don't follow variables for assigns For now, don't follow variables to look for assigns. * Fix finding assigns in `|> case do ... end` `None` calls were ignored, but when `case` is used in a pipeline it is a `None` since it has no literal arguments and only resolved arguments, so it was being ignored. * Ignore Lists and Aliases when resolving assigns * Fix resolve assigns in `if`s Only looked in `stab` of the `doBlock`, but the `else` is in the `blockList`. * Don't use the same path for actual aliases and defmodules when resolving aliases Prevents a case of an exact match and its namespace both being marked as valid (exact matches). * Types * Don't generate references for map key optionality (`required/1` and `optional/1`) * Don't create a reference to `...` in lists in type specs. * Look above `ElixirStabBody` for `ancestorTypeSpec`. * Generate `Callable` reference for `unquote` in typespec instead of `Type` reference. * Allow modular names to resolve to multiple modulars Fix `:systemd.ready()` not resolving because `:systemd` only exists as a decompiled file from source because it is Erlang and there is no preference given to different MIX_ENVs. All MIX_ENV `defmodule :systemd` are returned for the `:systemd` and all of them are checked for `ready/0`. * Fix resolving qualified calls that are defined through use Resolving qualified calls only used `Modular.callDefinitionClauseCallFoldWhile`, which ignores all non call definition, which means it ignored the `use`, but switching to use `org.elixir_lang.psi.scope.call_definition_clause.MultiResolve` `PsiScopeProcessor` used for unqualified calls, but starting on the modular call of the qualifier, all the `use` handling that works for unqualified calls also works for qualified calls now. This fixes resolving `MyAppWeb.Endpoint.config_change(changed, removed)` in `MyApp.Application.config_change/3` because `use Phoenix.Endpoint, otp_app: :my_app` in `MyAppWeb.Endpoint` is now walked for qualified calls. * Fix resolving variables to parameters that are both pattern matched and defaulted In functions like ```elixir def f(%Struct{} = s \\ %Struct{}) do s end ``` `s` in the body would not resolve to the `s` parameter because the default parameter had to be `PsiNamedElement`, that is a variable directly. Instead, recurse on any operand before the `\\` to support pattern matching too. * Use `keepProcessing()` in `MultiResolve.addToResolveResults` instead of specific return values Fixes `def` in `def default_host_flag, do: "--host` resolving as an invalid match to `default_host_flag` instead of search the implicit imports for `defmacro def`. * The `nameIdentifier` for a `defdelegate` is the first argument, not the `as:` The `as:` is the name in the `to:` module only. * Fix `defdelegate` `MultiResolve` 1. I had flipped the head name and `as` name for checking for a name match 2. I only counted the `defdelegate` as matching if the `as` name as found in `to` module, but if the head alone is prefixed by the name then the head should be a ResolveResult element even if the `to` or `as` can't be found 3. Inside the `to`, I only checked if the children were call definition clauses, but this meant that all the `for` handling was ignored, so start a new `resolveResults()` for each modular. * Fix `toModulars` not returning all modulars `fullyResolve` only touched the first modular. * Favor complete valid results over incomplete invalid earlier bindings for variables. * Ecto * Don't generate reference for `assoc/2` pseudo-function in `join(..., _ in assoc(_, _))` * Fix unaliasing multiple aliases `UnaliasName` still assumed that `fullyQualifiedName` included the qualifier, but it is just the lexical qualifier now. * Check for `MULTIPLE_ALIASES_QUALIFIER` in `ResolveState` for prefix matches. Fixes resolving `SSH.Key` to `Foo.SSH.Key` when the alias is `alias Foo.{SSH, ...}`. * Ignore type variables in type restrictions when resolving normal variables. * Fix `withSelf` for `childExpressions` `siblingExpressions` call While refactoring the walk, I copied the call for siblings, which shouldn't included self. Children should include self, or the first expression is missed which showed up as `Repo.transaction` not being found because `transaction` is the first `def` inside an `if` in `Ecto.Repo.__using__`'s `quote` block. * Don't try to resolve keys/fields of a capture. * Don't generate reference for `assoc` in `*join*: .. in assoc(..., ...)`. Already worked for `join/3` calls, extend to keyword syntax too. * Fix resolving references to `Modulars` when resolved is in BEAM file The check to see if the resolved was a modular only worked for source elements because it checked if it was a `Call`, but decompiled modules in BEAM files are `ModuleImpls`. * Fix logic error when ignored pinned variables as declaration sites The logic was supposed to be that * If it is pinned, keep searching * If it is not pinned, check the operation as a Call ... but, the code was `operatorText != "^" && execute(match as Call, state)` which meant that if the `operatorText` was `"^"`, then the whole expression was `false`, which meant `keepProcessing` was `false`, so any pin stopped the processing for other unpinned parameters after the pin in addition to processing in the outer scope of the pin. * Prefer source only for target candidates for Go To Declaration and not all ResolveResults. Ensures that functions only defined in decompiled Modules can be found because the Module's ResolveResults include the decompiled Module in addition to the source ones. * Don't prefer source over decompiled in `ResolveResultOrderedSet` Preference is now handled in `Resolver`, so that source preference only happens on Go To Declaration and not for `multiResolve` because that needs decompiled Modulars for compile-time `for` loops that are too complex to infer. * Use primary arity instead of final for resolving Callables Fixes `unquote` in `def unquote(...)() do` not resolving. * Filter out decompiled private functions from completions If they are only available as decompiled functions, it is unlikely we have the source available to make them public, which was the reasoning to allow private functions at all. * Decompiling * Include module name for "No decompiled source function" errors * Unquote `and` when not and/2 Fixes decompiling `:hipe_arm_encode`. * `unquote` `false` when decompiling. Fixes decompiling `:thrift_json_parser`. Add `true` to the `Unquote` list too since it would have the same issue. * Unquote `in` when not `in/2` Fix decompiling `:digraph_utils` * Use `containingFile.originalFile` for `resolve.Module.multiResolveProject` Ensures `VirtualFile` is available for decompiled files. * Performance * Don't use `.navigationElement` for `Variants` Using `navigationElement` forces parsing of the decompiled source, which isn't necessary whe only showing the lookup string. * Remove `ModuleOwner` interface * `BeamFileImpl` is known to have only 1 module in it, so it makes the code more complicated to make it act like source files. * Don't use `getChildrenByType`, as it causes the decompiled source to be parsed, which is slow and unnecessary since all the metadata for modules is available from the binary format. * Get project from parent in decompiled Module and CallDefinition Not doing this causes an unnecessary parsing of the decompiled source. * Fix infinite recursion in `ElixirVisitor#visitLiteralSigilLine` * Show more scope for keyword key Go To Definition * Always show the keyword pair, instead of just the keyword key, so that the value being assigned to the key can be seen before Go To. * Show the location at the path relative to the content root and the line number as `live_modal` may be used more than once in the same file. * Put `entrance` as initial visited in `module.Variants`. * Check if `PsiElement` has been visited before walking `quote` and `__using__` * Don't mark qualified calls as unresolved in "Elixir References" inspection I don't have a good approach for resolving struct fields or map keys for now, don't mark them as unresolved as it clutters finding unresolved calls I expect to work. * Don't assume `PsiFile#virtualFile` is `NotNull` in `PsiElement.moduleWithDependentsScope`. * Don't assume `PsiFile#virtualFile` is `NotNull` in `AtNonNumericOperation.computeReference()`. * `putInitialVisitedElement` in `variable.MultiResolve` Fixes resolving variables through `use` statements for variables in the body of `defmodule` blocks. * Log when `VISITED_ELEMENT_SET` is `null` instead of erroring. * Fix `resolvePrimaryArity` for `|> case do` `resolvedPrimaryArity` did not add both the doBlock's arity and the arity from the `|>` at the same time. If the pipe was there, the `do` was ignored because the pre-existing `resolvePrimaryArity` was not used if the normal primary arity of the call was zero, which is the case for `|> case do`. * Find module for elements in libraries Elements in libraries don't have a `Module` from `ModuleUtil.findModuleForPsiElement`, so scan the element's project's module's content roots for the closest `Module` for libraries. * `prependQualifiers` when typing an alias on a new line in the body of a function. * Don't descend into `quote` blocks if the call being resolved is given to an `unquote` in the `quote` block.
-
- #1967 - @KronicDeth
updateSinceUntilBuild
to prevent breaking in future IDEs.- Check if modules loaded before using
findModuleForPsiElement
. - Use
BasePlatformTestCase
instead ofLightCodeInsightTestCase
becauseLightCodeInsightTestCase
is deprecated.
- #1893 - @KronicDeth
- Simplify
onlyTemplateDateFileType
- Simplify
- #1897 - @KronicDeth
- Add missing opcodes to
Code
disassembler- OTP 23 opcode
bs_start_match4
- Current (in-development) OTP 24 opcodes
make_fun3
init_yregs
recv_marker_bind
recv_marker_clear
recv_marker_clear
recv_marker_user
- OTP 23 opcode
- Add missing opcodes to
- #1899 - @KronicDeth
- Log
PsiElement
ifCall#finalArguments
contain anull
.
- Log
- #1902 - @KronicDeth
- Suggest ASDF directories as
homepath
s for both Elixir and Erlang for Elixir SDKs.
- Suggest ASDF directories as
- #1821 - @jacekgajek
- Run 'Dialyzer based inspections (Elixir)' using Elixir SDK running
mix dialyzer
or any customizedmix
command.
- Run 'Dialyzer based inspections (Elixir)' using Elixir SDK running
- #1893 - @KronicDeth
- Use
VirtualFile#fileType
instead of EEx Type::INSTANCE when looking up extensions. Since LEEx fileType
is a subclass of EEx's fileType
, it callstemplateDataFileTypeSet
in EEx'sType
, buttemplateDataFileTypeSet
usesINSTANCE
from EEx. By using theVirtualFile#fileType
instead, it will properly be EEx or LEEx based on the actual file extension and then it can be used to strip that off and find the DataTemplateLanguage, such asHTMLLanguage
for.html.leex
.
- Use
- #1897 - @KronicDeth
- Compare max opcode in to file to max opcode number, not ordinal. Opcodes are 1-based, but the ordinal of the
Kotlin
Enum
s are 0-based, so the comparison was off-by-1 when a file had the max opcode and would be incorrectly marked as too new.
- Compare max opcode in to file to max opcode number, not ordinal. Opcodes are 1-based, but the ordinal of the
Kotlin
- #1899 - @KronicDeth
- Don't return null left or right infix operands in
primaryArguments
operation.infix.Normalized.leftOperand
and.rightOperand
ensures thatPsiErrorElement
is not returned: they can returnnull
when there is no left or right operand.Infix.primaryArguments
was not taking this into account and so could return anull
as one of theprimaryArguments
, which brokeCall.finalArguments
.
- Don't return null left or right infix operands in
- #1902 - @KronicDeth
- Don't attempt to execute
elixir -e "System.version |> IO.puts"
to get the version number as it requires too much of a full SDK to be built and from the Erlang paths to be correct too, which was rarely the case for ASDF. Since for Homebrew and ASDF, the directory name is the version name, this shouldn't be a loss in naming ability. If the directory name is not a parseable version it will be of the formatElixir at <path>
. This is probably more correct for installs directories that aren't versioned as SDK versions aren't updated if the version installed at the path changes, such as/usr/local/elixir
or/opt/elixir
, etc.
- Don't attempt to execute
- #1887 - @KronicDeth
- Protect from nested heredocs in documentation from stopping documentation's heredoc as happens in
Module
andEcto.Query
.- Use
~S
for@moduledoc
too, in addition to@doc
. - Check if the documentation contains
"""
or'''
and use the opposite one as the promoter/terminator.- If neither is used, use
"""
. - If both are used, use
"""
, but then escape"""
as\"\"\"
.
- If neither is used, use
- Trim trailing whitespace from documentation lines to match formatter output.
- Use
- Protect from nested heredocs in documentation from stopping documentation's heredoc as happens in
- #1890 - @KronicDeth
- Set
runIde
maxHeapSize
to7g
- Set to the same I run my own IDE at, so the debugged instance isn't any slower than the normal IDE when I need to do extended all day testing to trigger bugs.
- Test that all
FormattingTest
files can be parsed. YYINITIAL
is special - wrappers of the lexer assume that if inYYINITIAL
, it is safe to shift the lexer over when there is an error, having{OPENING_CURLY}
pushAndBegin(YYINITIAL)
when it was either inYYINITIAL
orINTERPOLATION
( ) means that the lexer looked like it was restartable when it really wasn't. This code has been in the lexer for 6 years (https://github.com/KronicDeth/intellij-elixir/blame/36b53331967950453906c3bde9c7f79dc3f9cd2f/src/org/elixir_lang/Elixir.flex#L812) .- When in
YYINITIAL
,{
no longer recurses intoYYINITIAL
as}
does not need to be counted to determine if it is closing an interpolation. - When in
INTERPOLATION
,{
entersINTERPOLATION_CURLY
to allow counting and matching of}
until it can exit and go back toINTERPOLATION
, where}
will exit the interpolation. - When in
INTERPOLATION_CURLY
,{
enters another level ofINTERPOLATION_CURLY
to allow counting and matching of}
until it can exit and go up a level.
- When in
- The
}
inYYINITIAL
didyybegin(ADDITION_OR_SUBTRACTION_MAYBE)
, but it should have beenpushAndBegin(ADDITION_OR_SUBTRACTION)
asADDITION_OR_SUBTRACTION_MAYBE
or its following states all exit withhandleInLastState()
orpopAndBegin()
. This was not caught in #1859 because the extraYYINITIAL
frompushAndBegin(YYINTIAL)
hid the bug. - Prevent nested
YYINITIAL
bugs in the future by erroring- If trying to
pushAndBegin(YYINITIAL)
. - If trying to
push(YYINITIAL)
and the state stack is not empty
- If trying to
- Clear the state Stack when
ElixirFlexLexer#reset
is called, as at the level of typing and pasting, theElixirFlexLexer
is wrapped in many layers of lexers includingLexerEditorHighlighter
where theElixirFlexLexer
is no longer re-instantiated when there is no text, but instead,ElixirFlexLexer#reset
is only called. This has always been an invariant violation since the stack state was added 7 years ago in https://github.com/KronicDeth/intellij-elixir/commit/52cb2fbf6368ba551a4784bd1de49e1fc21c969a. It likely only became more apparent with the changes to +/- parsing in #1859 that made return-to-YYINITIAL less likely.- Since this
stack.clear()
has to be manually added toElixirFlexLexer.java
, which is generated fromElixir.flex
,ResetTest
is added to check that the code is still there.
- Since this
- For a reason I haven't been able to explain, the
LexerEditorHighlighter
stops working after:
is typed at the start of an atom in certain situations, such as before)
inside a function call, like when adding an argument. In this case, the old version of the lexer would mark)
as aBAD_CHARACTER
and continue to do so until an expected atom start of [a-zA-Z_],'
,"
, or an operator occurred. Now, if an invalid atom start is matched, theATOM_START
state ends and the previous state handles the text, which in the function case mean)
is parsed asCLOSING_PARENTHESIS
. This change allows the highlighting to continue. I do not know if returningBAD_CHARACTER
will always break theLexerEditorHighlighter
, but I don't think, so since theGroovyLexer
inintellij-community
returns it , but it may be the case that it isn't actually returned ever when users are typing and only handled by the lexer for completeness.
- Set
- #1877 - @KronicDeth
-
Fix syntax highlighting stopping due to decompiling of
Kernel
failing caused by bugs introduced in #1834. Syntax highlighting could fail part way through a file whenKernel
needed to be decompiled to resolve parts of the syntax. This would lead to the file to be colored above a certain point, but then the default gray after that point.- Connect compiled stubs to decompiled source by name/arity. Previously, when the decompiler didn't use the
Docs
, it was guaranteed that thePsiCompiled
stubs would correlate, in-order, with the decompiled source call definitions, and so mirrors could be set by matching up the list of them in order. Since theDocs
doesn't have to correspond to and doesn't correspond to the binary precisely for some BEAMs, most importantly,Elixir.Kernel.beam
, the PsiCompiled stub and decompiled source is now matched by name and arity. This means some mirrors are missed, but no errors are produced. - Allow decompile source to map to entire arity range Since the decompile source from
Docs
can have default arguments the call definition clauses can have an arity range and not just a fixed arity, so all arities in the range need to be mappable toPsiCompiled
functions. - Use correct macro for signature from
Docs
. Ensures that defmacro is used for macros instead of hard-codingdef
as in #1834. - Use
~S"""
for docs fromDocs
chunk. The docs from theDocs
chunk may contain interpolation in the code samples or#{
in regex examples, but these should not be treated as an interpolation start as theDocs
format does not support interpolation. Anything that looks like interpolation in the docs text was actually escaped in the original docs, so also escape it here by usingS"""
, which turns off interpolation. - Log an error if
Code
function can't be matched to decompiled source. Unlike the oldInvalidMirrorException
, this won't be an exception and the binary <-> decompile will still work for the other functions/macros in the file, so it will be a more graceful degradation.
- Connect compiled stubs to decompiled source by name/arity. Previously, when the decompiler didn't use the
-
- 1878 - @KronicDeth
- Fix missed references to
DepsWatcher
as project componentDepsWatcher
was converted to a Project Listener in #1844 to support installing the plugin from the Marketplace without reloading, but some references toDepsWatcher
were still trying to get its instance for project usingproject.getComponent()
, which would now returnnull
.
- Fix missed references to
- #1879 - @KronicDeth
- Target Java 1.8 for JPS compatibility. JPS (JetBrains Project System) is the API used to allow External Builders,
like
mix
to build projects.
- Target Java 1.8 for JPS compatibility. JPS (JetBrains Project System) is the API used to allow External Builders,
like
- #1880 - @KronicDeth
- Fix matching
unquote(ATOM)
call definitions to compiled function by using the argument tounquote
when calculating the name of the call definition clause if possible. Needed to match anonymous function names that areunquote
d because they contain/
to separate the outer function name from the anonymous function naming convention. - Don't use
Docs
signature forMacroNameArity
that is an operator orunquote
d The signatures for operators andunquote
d don't produce valid code that can be parsed. - Don't use signatures for
__struct__
functions. The signatures for the__struct__
functions are like%Module{}
, but that's not parseable, so bypass the signatures with a specializedSignatureOverride
decompiler that matches the actual code indefstruct
. - Don't indent empty lines from
Docs
for@moduledoc
and@doc
to match the formatter output.
- Fix matching
- #1881 - @KronicDeth
- Fix capitalization of
Docs
@moduledoc
@moduleDoc
->@moduledoc
- Fix capitalization of
- #1844 - @KronicDeth
- Make plugin updatable without a restart when installing from the JetBrains Marketplace. (If installing from file on
GitHub you still need to restart due to a limitation in the JetBrains API.). JetBrains refers to this as
a Dynamic Plugin.
- Convert
DepsWatcher
from project component to project listener - Convert
Watcher
from module component to project listener - Make org.elixir_lang.packageManager extension point dynamic
- Convert
- Remove unnecessary
assert
. - Replace
if
withwhen
- Include
asd
tool version Prevent me screwing up the quoter cache using the wrong elixir version again. - Update gradle project
gradlew
6.7.1
org.jetbrains.intellij
0.6.3
org.jetbrains.kotlin.jvm
1.3.70
de.undercouch.download
to4.4.1
- Update to GitHub Environment Files
- Make plugin updatable without a restart when installing from the JetBrains Marketplace. (If installing from file on
GitHub you still need to restart due to a limitation in the JetBrains API.). JetBrains refers to this as
a Dynamic Plugin.
- #1859 - @KronicDeth
- Update CI to Elixir 1.11.2 and Erlang 23.1
- Quoting (for verification of correspondences between plugin and Elixir native lexer and parser.)
- Port elixir-lang/elixir#9725
- Indentations for sigil binaries with complex content. Makes sure the indentation metadata is added to sigils that have content with metadata already.
- Quote charlist the same as string when used for a quoted atom
- Port elixir-lang/elixir@e89e9d874bf803379d729a3bae185052a5323a85
- Add sigil delimiter to metadata Ports elixir-lang/elixir#9671
- Have 3 character delimiter for heredocs
- Add
no_parens: true
metadata Port elixir-lang/elixir@8e7befb1087bd37d5acb883e21925b1c0eb0a55f
- Port elixir-lang/elixir#9725
- Remove elixir-lang parsing tests for files that don't exist in Elixir 1.11
- Add missing
@Deprecated
to match overridden method - Format expected and actual quoted Makes the diff not be a one-liner. so easier to spot the difference.
- Convert
Quoter
to Kotlin - Regenerate Parser for newer GrammarParser version.
- Port elixir-lang/elixir@1e4e05ef78b3105065f0a313bd0e1e78b2aa973e
- Quoting (for verification of correspondences between plugin and Elixir native lexer and parser.)
- Update CI to Elixir 1.11.2 and Erlang 23.1
- #1834
- @marcindawidziuk
- Rewrote the
DocumentationProvider
so it no longer relies on invokingmix
(which I admit was more like a hack than a real solution). This now works so quickly that it actually makes sense to show docs on mouse hover.- It can get the documentation from both the source code and decompiled .beam files.
- Decompilation of documentation was implemented according to EEP-48.
- The experience on navigating through decompiled file has also been improved a bit
- See the
@moduledoc
and@doc
s - See if a function has been deprecated
- See the original signature of the function (instead of just
p0
,p1
, ...).
- See the
- Rewrote the
- @marcindawidziuk
- #1844 - @KronicDeth
- Fix deprecation warnings for IntelliJ IDEA 2020.2
- Replace
fileTypeFactory
extensions withfileType
- Convert
fileType
s to Kotlin - Replace uses of deprecated
Project#baseDir
- Replace uses of deprecated
ContainerUtil.newHashMap
- Replace
defaultLiveTemplatesProvider
withdefaultLiveTemplates
spaceExistanceTypeBetweenTokens
replaced withspaceExistenceTypeBetweenTokens
- Replace
ListCellRendererWrapper
withSimpleListCellRenderer
- Replace
StdFileTypes.PLAIN_TEXT
withFileTypes.PLAIN_TEXT
- Replace
LanguageSubstitutors.INSTANCE
withgetInstance()
- Replace
ReportMessages.ERROR_REPORT
withReportMessages.getErrorReport()
- Replace
DefaultProgramRunner
withGenericProgramRunner
- Have only one runner for all configurations in plugin since body of runner was all the same for non-debug.
- Don't override deprecated
flushBufferBeforeTerminating()
- Don't override deprecated
acceptsFile
- Override
initExtra(Project)
instead ofinitExtra(Project, MessageBus, Engine)
- Replace
NamedFoldingDescriptor
withFoldingDescriptor
- Convert
folding.Builder
to Kotlin
- Convert
- Replace
file
withvalue
for@Storage
annotation - Replace
checkBox(fieldName, title)
withcheckBox(title, getter, setter)
- Replace
com.intellij.util.contains.Predicate
withjava.util.function.Predicate
- Replace
CodeStyleSettingsManager
withCodeStyle
- Replace
Comparing.equal
withObjects.equals
- Replace
UsageType(String)
withUsageType(Supplier)
- Replace
PluginManager
withPluginManagerCore
- Replace
WakValueHashMap
withcreateWakeValueMap
- Don't pass
Pass
toLineMarkerInfo
- Replace
newArrayListWithCapacity
withArrayList
- Replace
newIdentityHashMap
withIdentityHashMap
- Replace
RefElement#element
with#psiElement
- Pass
columnMargin
tosetupCheckboxColumn
Extensions.getExtensions(name)
->name.extensionList
Extensions.findExtension
->ExtensionPointName.findExtensionOrFail
Object
->Any
- Replace
choseAndSetSdk
withSdkPopupFactory
- Replace
- Fix error reporting formatting
- Fix new lines around excerpts so that code blocks quote correctly
- Use FILE:LINE format for excerpt location, so it can be used in editors for rapid lookup.
- Separate title from message
- Remove use of
ErrorBean
- Pass project for LevelPropertyPusher DumbModeTask
- Don't use constructor injection for
SetupSDKNotificationProvider
- Don't use
AnnotationHolder::create*
APIs and useAnnotationBuilder
instead.- Convert
Annotator
s to Kotlin
- Convert
- Use
logger.error
directly instead ofLogMessageEx
- Fix Atom annotator to only annotator within current element. Annotation keyword pair's key and colon instead of annotating the keyword key and the colon outside of it.
- Fix
Macro
parsing inDbgI
ifAccessToString
I missed taking the 3rd element of the tuple to get[Access, :get]
and was checking the outer tuple directly.- Convert
beam.assembly.ParserDefinition
to Kotlin
- Convert
ifWhenToString
whereas
should beas?
- Suppress unused variables for
TODO()
s - Remove unnecessary
Line
chunk dependency onAtom
chunk - Switch unused
unsignedInt
values to_
as Kotlin doesn't support_name
- Use
key
instead of environment forcomputeIfAbsent
- Replace lambda with constructor reference
- Remove unnecessary
!!
s - Replace
mapIndexed
withmap
becauseindex
is unused - Remove
open
that has no effect inobject
- Fix
is
overrides by converting to Kotlin - Remove unused
Call
fromImplementation.
andCallDefinitionClause
.elementDescription(Call, ElementDescriptionLocation)
. - Don't shadow
resolveResultList
inaddToResolveResultList
- Remove useless
?:
- Remove unnecessary
!= null
- Fix named argument calling by using super argument name
- Change
Float.from(ByteArray, Int)
toTODO()
as implementation is invalid. - Remove unused
ModuleChooserDialog
- Setup
EncodingManager
forParsingTestCase
- Remove redundant
internal
- Don't highlight resolved callables along with referrers Newest annotation API asserts that the annotator only annotates the PsiElement being visited, so can't highlight the resolved call definitions at the same time anymore.
- Fix deprecation warnings for IntelliJ IDEA 2020.2
- #1859 - @KronicDeth
- Differentiate signs, unary +/-, and addition/subtraction in lexer. Fix parsing of
-1
forcase
clauses (#1316) by more strictly parsing decimal exponent signs differently than addition/subtraction and differently from unary+
and-
. No longer have a "dual" operation emitted from the lexer like the Elixir native lexer and instead use specific tokens for each use case so that the parser doesn't need to decide on the operation. - Heredoc with escapable newlines (#1843) Heredocs allow the final newline to be escaped so you can write a heredoc in the code, but have no newlines in the string term at runtime.
- Fix terminators docs to show closing version and not opening version
- Differentiate signs, unary +/-, and addition/subtraction in lexer. Fix parsing of
- #1866 - @KronicDeth
- Protect against
IndexOutOfBounds
fromhighlighterIterator
inQuoteHandler
.
- Protect against
- #1822 - @KronicDeth
- Vendor JInterface 1.11 to support
BIG_CREATION
when debugging. The JInterface on Maven Central has stopped being updated because the OTP Team didn't actually maintain it , that was Basho, and Basho is gone now. This version of JInterface, 1.11, is from Erlang 23.0.4 from Homebrew, but with the formula edited (brew edit erlang
) to add--with-java
and then built withbrew install erlang --build-from-source
.
- Vendor JInterface 1.11 to support
- #1823 - @KronicDeth
- On Windows, the
file.path
to the debugger server files has\
, but they aren't escaped. Therefore, replace them with escaped version,\\
to fix debugging on Windows, but leave Linux and macOS unaffected.
- On Windows, the
- #1792
- @marcindawidziuk
- Quick documentation (F1/Ctrl+Q)
- @marcindawidziuk
- #1807 - @niknetniko
- Run Icons in gutter next to ExUnit tests. The icon changes to the state of the test: green for passing and red for failing.
- #1788 - @KronicDeth
-
Fix Unchecking Show Method Separator still showing on
@doc
and@spec
.Previously, unchecking Show Method Separator would still show the method separator if it was the module attributes ( such as
@doc
and@spec
) associated with the call definition (def
,defp
,defmacro
, ordefmacrop
) and only disabled the ones directly above the call definition. This is fixed by checking if method separators are enabled ingetLineMarkerInfo(PsiElement)
instead of the specializedgetLineMarkerInfo(Call)
, so that the check happens for both module attributes and call definitions.
-
- #1786 - @odk211
- Remove "Unresolved module attribute" error annotation because module attributes cannot be resolved through
use
yet, so current annotation is a false positive in those cases.
- Remove "Unresolved module attribute" error annotation because module attributes cannot be resolved through
- #1801 - @niknetniko
- Use
SimpleTemplateLanguageFormattingModelBuilder
for EEx files, so that theTemplateDataLanguage
(i.e.html
when the extension is.html.eex
) formatter is used instead of the Elixir formatter.
- Use
- #1781 - @KronicDeth
- Convert
annotator.ModuleAttribute
to Kotlin- Apply optional Kotlin transformations.
- Convert
- #1781 - @KronicDeth
-
Check if at least one resolution for module attribute references is valid
Previously, it was checked if module attributes resolved to exactly one declaration, but this is no longer true with the looser reference resolution that allows invalid results for PisPolyVariantReference.
resolve()
will returnnull
when there is more than one result frommultiResolve
even if some are invalid, so we need to explicitly check if thePsiReference
is aPsiPolyVariantReference
and if so check if any are valid. -
Fix deprecation warnings for
annotator.ModuleAttribute
. -
Quick fixes for inlinables in
annotator.ModuleAttribute
.
-
- #1774 - @odk211
- Fix
iex
anderl
arguments not being saved for IEx Mix Run Configurations.
- Fix
- #1762 - @KronicDeth
- Support diffs in pattern matching added in Elixir
1.10.0
in the ExUnit formatter. Ports elixir-lang/elixir@98c6bba436cc4833363295e5fedd3f819504d79d .
- Support diffs in pattern matching added in Elixir
- #1773 - @KronicDeth
- Only require at least the number of children to safely get a specific child instead of exact number to allow getting prefix children when there are grammatical errors.
- #1691 - @KronicDeth
- Treat
.leex
files as.eex
files, so same features apply to both.
- Treat
- #1735 - @KronciDeth
- Switch build to GitHub Actions.
- #1738 - @Koziolek
- Update build to IntelliJ IDEA 2020.1
-
- Swap improperly sized
General.QuestionDialog
icon forRunConfigurations.TestUnknown
icon for Unknown icon in Structure View.
- Swap improperly sized
-
- Fix
MODULENAME
variable indefm
live template, so that the file name is camel-cased before being capitalized.
- Fix
-
- Update
README.md
about information for Goland IDE since has been released for awhile and no longer only an EAP.
- Update
-
- Restore canary builds being published to JetBrains Marketplace .
-
- JetBrains IDEs 2020.1 compatibility
- Change obsolete references to
AllocIcons
inIcons
to new ones inAlllIcons
that are recommended in documentation. - Update to
@NotNull
annotation onPsiElementVisitor
DepGatherer
QuotableImpl.quote
- Change obsolete references to
- JetBrains IDEs 2020.1 compatibility
-
- Fix tests for IDEA 2020.1.
-
-
Get
ProjectImportProvider
builder indoGetBuilder
instead of constructor.Fixes use of deprecated constructor dependency injection that is incompatible with dynamic, injectable plugins in 2020.1.
com.intellij.diagnostic.PluginException: getComponentAdapterOfType is used to get org.elixir_lang.mix.project._ import.Builder( requestorClass=org.elixir_lang.mix.project._import.Provider, requestorConstructor=protected org.elixir_lang.mix.project._import.Provider(org.elixir_lang.mix.project._import.Builder) ).
Probably constructor should be marked as NonInjectable. [Plugin: org.elixir_lang]
-
-
- Allow underscores in binary (
0b
), octal (0o
) , and hexadecimal (0x
) numbers.
- Allow underscores in binary (
- #1630 - @KronicDeth
-
Ignore the
incompleteCode
flag and instead always use the criteria used whenincompleteCode
was set.name prefix exact name ResolveResult valid ❌ N/A ❌ N/A ✅ ❌ ✅ ❌ ✅ ✅ ✅ ✅ This extends #1617 to more cases.
- Qualified calls (
Process.flag(...)
, etc) - Type specs (
@spec foo(...)
) - Aliases (
alias Foo...
) - Module Attributes (
@attribute
) - Variables (
foo
) Protocol
reserved module attributes (@protocol
and@for
)
- Qualified calls (
-
- #1650 - @KronicDeth
- Fix debugger evaluator for Elixir >= 1.9.2. Ports elixir-lang/elixir@7002554 .
-
- Previously, the arity of a function or macro could only disagree with the definition and resolve if
- The arity of the call was in the arity range of the defintion and the
ResolveResult
was marked as avalidResult
. - The code is marked as
incomplete
(because the IDE detects typing, etc) and the arity mismatches and theResolveResult
is marked as an invalid result.
By marking all arity mismatches, regardless of incompleteness of the code as an invalid result, Go To Definition and Show Parameters works when the the arity is incorrect. This males Show Parameters work while typing out a call without the correct number of commas and allows jumping to the definition while typing out the call too.
- #1600 - @KronicDeth
- Show Parameter Info (⌘+P/Ctrl+P)
- #1607 - @hoodaly
- Fix must specify non-empty 'commandLine' parameter
- #1608 - @KronicDeth
-
GeneralCommandLine
's escaping for Windows can't handle the parentheses in a way that both works for the Windows shell and Elixir running the code the shell hands off. Removing the parentheses leaves runnable code even if it is no longer formatted.Fixes "Unknown Version" naming for Elixir SDKs and the "Probably SDK installed in ... is corrupt" dialog from appearing.
-
- #1592 - @alex-dukhno
- Add
ExUnit
describe
block template.
- Add
- #1589 - @KronicDeth
- Don't error on
runtume
in mix deps.guardian
is too common of a dependency and too many users have the version with the typo installed.
- Don't error on
- #1569 - @chitacan
- Fix IEx Mix Run/Debug Configuration for
asdf
by using absolute path tomix
.
- Fix IEx Mix Run/Debug Configuration for
- #1595 - @KronicDeth
- Add OTP 22 and 23 opcodes to Code BEAM Chunk Viewer
put_tuple/2
bs_get_tail/3
bs_start_match3/4
bs_get_position/3
bs_set_position/2
swap/2
- Add OTP 22 and 23 opcodes to Code BEAM Chunk Viewer
- #1587 - @KronicDeth
- Update gradle plugins
gradle-intellij-plugin
(org.jetbrains.intellij
) to0.4.10
org.jetbrains.kotlin.jvm
to1.3.50
de.undercrouch.download
to4.0.0
- Update IDEA version in builds
2019.2
->2019.2.2
- Update gradle plugins
- #1582 - @KronicDeth
- Don't log if partial or no header typeID is read. It happens too often due to
.beam
files being written partially to disk during the build process. They will be re-indexed when they are complete.
- Don't log if partial or no header typeID is read. It happens too often due to
- #1587 - @KronicDeth
- Update gradle intellij plugin to fix
runIde
on newer macOS.
- Update gradle intellij plugin to fix
- #1588 - @KronicDeth
-
Fix
ConcurrentModificationException
in Structure ViewJava 9 fixed a bug (https://bugs.openjdk.java.net/browse/JDK-8071667) in
HashMap
wherecomputeIfAbsent
did not check for concurrent modifications, and it turns out thatTreeElementList
was using concurrent modifications, so it was now broke.Fixed by use
get
orput
if it is absent, so thatputNew
can ensure that theCallDefinition
is in theTreeElementList
before it is added to theMutableList<TreeElement>
, which was the original reason why there was aput
inside ofcomputeIfAbsent
, which would haveput
when the function returned anyway.
-
- #1548 - @KronicDeth
- The java plugin dependency needs to be declared so that it shows up for compiling the JPS builder system and the project importer in IntelliJ and Android Studio, but it needs to be optional, so that the plugin is still compatible with Rubymine and the other small IDEs.
- #1545 - @KronicDeth
- Simplifications due to only supporting IntelliJ 2019.2
- Don't use reflection for error report Submitter
- Don't use deprecated WeakHashMap. It was needed for backwards compatibility, but since this build is for 2019.2 only, no compatibility is necessary and it clears up the long warnings from the logs for end users.
- Remove reflection from OutputToGeneralTestEventsConverters. Only 2019.2 is now supported, so no need for complicated backwards compatibility.
- Only support IntelliJ 2019.2 in Travis CI
- Remove Elixir 1.5 and 1.6 builds as they are both > 1 year since the last release approximately.
- Simplifications due to only supporting IntelliJ 2019.2
- #1545 - @KronicDeth
- IntelliJ 2019.2 compatibility
-
Explicitly depend on java plugin. 2019.2 extracted the Java functionality to a plugin (as outlined here), which includes the JPS builder used for Project Build functionality.
-
Remove project converterts. Project converters are broken in 2019.2 because the
DialogWrapper
they try to launch isn't being launched in the Event Dispatch Thread ( EDT) (https://youtrack.jetbrains.com/issue/IDEA-218071).As this is bug in code wholey controlled by upstream, the only option is to remove the project converters. The work-around is for users to re-import projects when a project layout update is necessary.
-
Fix nullability of
override
arguments inChooseByNameModel
-
Don't use dependency injection for OpenProcessor builder. JetBrains has removed dependency injection for Extensions in 2019.2.
-
Don't pass a null name ot findSdk
-
- IntelliJ 2019.2 compatibility
- #1545 - @KronicDeth
- Changes needed for 2019.2 compatibility make this build incompatible with earlier releases.
- #1492 - Add Linux Mint Erlang and Elixir home paths to SDK
home path suggestions. Linux Mint installs to
/usr/lib/erlang
and/usr/lib/elixir
instead of/usr/local/lib/erlang
and/usr/local/lib/elixir
. - @KronicDeth
- #1491 - @KronicDeth
- Elixir 1.8 made
:elixir.quoted_to_erl/3
private, so in Elixir 1.8+, the debugger needs to inline the private version to maintain < 1.8 and >= 1.8 compatibility. - Reformat debugger for Elixir 1.8
- Elixir 1.8 made
- #1483 - @KronicDeth
- Numerous users have reported that annotation can encounter a
StackOverflowError
. A reproduction case shows that they are called by PhoenixWeb
modules where one function containingquote
blockuse
s the same module again, such as anadmin_view
depending on the baseview
throughuse App.Web, :view
. When theuse App.Web, :view
is resolving, thedefmacro __using__
is re-entered as is theadmin_view
because there was no tracking of already visitedPsiElement
s. The fix is to track the visited elements and not re-enter the visited elements so thatadmin_view
is skipped and the other call definition clauses can be checked to findview
.
- Numerous users have reported that annotation can encounter a
- #1445 - @KronicDeth
- Replace comparator with Comparator.reverseOrder()
- The correct home path for
kiex
is~/.kiex/elixirs/elixir-VERSION/lib/elixir
as that contains the truelib
andbin
directory, but users may select other directories by mistake, so doing the following adjustments:- Adjust
bin
home path tolib/elixir
. - Adjust
elixirs/elixir-VERSION
home path toelixirs/elixir-VERSION/lib/elixir
.
- Adjust
- #1462 - Use reflections to allow saving settings when creating the projects before in 2018.3 and 2019.1 even though the API changed.
- #1443 - @KronicDeth
-
In RubyMine, attach OTP applications as separate projects with Elixir facets instead of directly creating
ELIXIR_MODULE
modules inDirectoryConfigurator
. This matches the manual steps of opening the OTP apps as separate directories after opening the root of the project.- Mark directories when adding facet
- Sync libraries when adding facet or attaching to root project. Ensures External Libraries show up for all OTP applications.
-
Convert Small IDE projects with
ELIXIR_MODULE
s:- Remove
ELIXIR_MODULE
*.iml
files - Remove
ELIXIR_MODULE
entries root project'smodules.xml
file. - Lack of modules in project in
doOpenProject
will triggerDirectoryProjectConfigurator
s to be run , which will setup the project and runDirectoryConfigurator
to attach theapps
OTP apps and Elixir facets.
- Only support automatic attaching multiple OTP apps as separate projects in Rubymine. In IntelliJ normal support for multiple Modules in one Project still works.
- Remove
-
- #1444 - Increase suspect
nameSet
size to15
to supportgeo
.geo
has 13String.Chars
implementations. - #1445 - @KronicDeth
- Remove obsolete
SdkType
. I keep confusing it with its replacementorg.elixir_lang.sdk.elixir.Type
! - Check that HomePath has
ebin
paths when validation. Prevents selecting false HomePaths forkiex
.
- Remove obsolete
- #1446 - Adding missing ESpec template. When reviewing #1410
I missed that the template wasn't in
resources
. 🤦♂️ - @KronicDeth - #1447 - Ignore
targets
when calculatingDep
path. - #1448 - Ignore
organization
when calculatingDep
path. - #1449 - Get view provider document in read action.
- #1450 - Support
rebar.config
deps that are name only. - #1456 - Always use
containingFile
forQualifiableAlias
maxScope
forgetReference
. Prevents cache capturingmaxScope
, which can vary based on invocation. - @KronicDeth - #1462 - @KronicDeth
-
Create new project before attaching it in Small IDEs. When attaching a directory to a project during startup, saving is disallowed, so the attached directory only has a
workspace.xml
in its.idea
when the attach is attempted. Attaching requires the.idea/*.iml
Module file, so the attaching fails, saying the directory is an unsupported format.Experimentation showed that manually attaching the directory also did not work, but opening the directory in a separate window, then opening and attaching it again would make the directory have the full project files. To mimic this manual process:
- The internals of
doOpenProject
are copied - A save of the project files is forced, bypassing the normal "startup" save blocker
- The project is attached to the root project.
Tested to work when upgrading from 10.4.0 to 10.5.0-pre in Rubymine when no project was already open.
- The internals of
-
Check if project can be attached instead of if RubyMine Although GoLand supports attaching projects, it doesn't work for non-Go projects, so it is also excluded. How the support appears in each non-IntelliJ IDEA is shown below:
IDE Works? Android Studio YES Android Studio is built on top of IntelliJ, so it has full multi-Module support. It is not Small IDE. CLion NO No Attach to Project support to multiple module support. DataGrip No DataGrip doesn't have a Project View and doesn't support Attach to Project. You can still run tests if you directly open the file. GoLand NO Modules show up, but independent projects are not attached as in other Small IDEs, so disabled. In general, the Go settings, like Test Runners always win, so it is recommended to not use GoLand at all for Elixir development. PHPStorm YES The projects are listed in Directories. The Languages & Frameworks > Elixir shows all 3 projects. Right-clicking on the marked Test directory will not show the Elixir Run Configuration, Python ones win, but subdirectories and *_test.exs
will show up in the context menu.PyCharm YES The root project is listed in Project. app/*
projects are listed listed as Project Dependencies of the root Project. The Languages & Frameworks > Elixir shows all 3 projects. Right-clicking on the marked Test directory will not show the Elixir Run Configuration, Python ones win, but subdirectories and*_test.exs
will show up in the context menu.Rider No Solution system is separate from Project system. Rubymine YES The projects are listed in Project Structure. The Languages & Frameworks > Elixir shows all 3 projects. Right-clicking on the marked Test directory will not show the Elixir Run Configuration, Python ones win, but subdirectories and *_test.exs
will show up in the context menu.WebStorm NO No Attach to Project support or multiple module support. -
Don't count Android Studio as a Small IDE. It includes Project Structure menu with multiple-language, multiple-Module per Project support from IntelliJ.
-
- #1410
- ESpec Test Runner - alex-dukhno
- ESpec Graphical Test Results - @KronicDeth
- #1410 - @KronicDeth
- Only show Run/Debug ExUnit when
*_test.exs
files exist. - Only show Run/Debug ESpec when
*_spec.exs
files exist.
- Only show Run/Debug ExUnit when
- #1415 -
Wrap
UnqualifiedNoArgumentCall.quote
identifier.text
inrunReadAction
. - #1419 - Fix typos in
CONTRIBUTING.md
- #1420 - Prevent the module attribute annotator from running in EEx files. - @nschulzke
- #1404 - Add Type Specifications to Dbgi tab for :elixir_erl backend. - @KronicDeth
- #1407 - Bug Report issue template.
- #1408 - @KronicDeth
- Cache all computed Elixir levels at the file, module, project, and SDK levels. The computed Elixir level is used to
determine how to emulate the various grammar changes made for the different Elixir versions. This bug was
potentially introduced as earlier asv7.0.0 (2017-12-15) and as late
as v7.5.0 (2018-06-03) as
that's the history for
LevelPropertyPusher.java
and has affected all later versions. If you ever experienced the 6.X series as faster than the 7.X series and later, this bug may be why and you should upgrade/reinstall immediately.
- Cache all computed Elixir levels at the file, module, project, and SDK levels. The computed Elixir level is used to
determine how to emulate the various grammar changes made for the different Elixir versions. This bug was
potentially introduced as earlier asv7.0.0 (2017-12-15) and as late
as v7.5.0 (2018-06-03) as
that's the history for
- #1353 - @KronicDeth
- Improve support for umbrella projects in Small IDEs like Rubymine by creating a separate module for each
mix.exs
when opening a directory (DirectoryConfigurator
). This matches the pre-existing support in Rich IDEs (IntelliJ Community & Ultimate Edition) when using Import From External Model and Quick Import when opening a directory. - Ignore
assets
directory when looking formix.exs
files for Import From External Model, Quick Import and Directory Configurator.
- Improve support for umbrella projects in Small IDEs like Rubymine by creating a separate module for each
- #1355 - @KronicDeth
- Update Build Matrix
- Add
2018.3
.- Update
gradlew
to5.0
. - Update
org.jetbrains.intellij
to0.3.12
. - Update
org.jetbrains.kotlin.kvm
to1.3.10
.- Update Kotlin
apiVerision
to1.3
.
- Update Kotlin
- Update
de.undercouch.download
to3.4.3
. - Don't configure Kotlin in projects that don't use it.
- Update
- Remove
2017.3
to keep version count at3
.
- Add
- Update Build Matrix
- #1355 - Prevent
ConcurrentModificationException
s when updatinggradle
by usingallprojects
less. - @KronicDeth - #1359 - @KronicDeth
- Remove unused variables in Elixir debugger server.
- Protect from
AssertionError
whenVirtualFileCache
is disposed.
- #1360 - Protect from
AssertionError
whenVirtualFilePointerContainer
is disposed. - @KronicDeth - #1364 - Use
:path
for deps for paths external to project. Unfortunately, even though they show up in the Project Structure, onlyebin
directories are shown as it is restricted to those marked asCLASSES
and the:path
lib
is aSOURCES
. - #1367 - Ignore
:tag
when finding path to dep. - #1368 - No longer use the forked version
of
TerminalExecutionConsole
as2018.3
's version doesn't have the text echoing behavior that was being bypassed before. - @KronicDeth - #1372 - Ignore
:ref
when finding path to dep.
- #1330 - @KronicDeth
- #1334 - @KronicDeth
- Allow creating
ExUnit.Case
modules from template. Template containsuse ExUnit.Case
alias
of the source module@moduletag :capture_log
doctest
test
that checks that the source module exists.
- Convert
CreateElixirModuleAction
to Kotlin. - Drop "Elixir" prefix from templates name in Elixir File dialog since you already know you're creating an Elixir File.
- Allow creating
- #1327 - Fix deadlinks to Run Configurations, which broke when section was renamed Run/Debug Configurations and auto-anchor changed name.
- #1328 - Fix image links in
README
. - #1331 - Ensure
defmodule
one-liner isn't mistaken for call definition head in Go To Symbol. - @KronicDeth - #1336 - Wrap
packagePisToDepSet
in read action because checking the validity of the dependencies requires a read action. - @KronicDeth
- #1322 - @KronicDeth
- Eliminate freezes when calculating Module and Library dependencies during project import and dependency updates.
- Run library syncing in tasks: When importing projects, run sync as a modal task while when
VirtualFileSystem
events occur, run sync as background tasks. Either style of task is cancellable and importantly, it allows to show what is happening during the syncing. This converts the unresponsive UI beachball on macOS during import to an updating progress bar. - Calculate dep sets iteratively with a work queue instead of recursively to limit the calculation of dep set for a root to 1 time. Then use normal transitive walk to get complete dep set for module. Vastly speeds up project import.
- Cache dep set on package
PsiFile
to allow faster refreshes when indirect dependencies don't change.
- Run library syncing in tasks: When importing projects, run sync as a modal task while when
- Eliminate freezes when calculating Module and Library dependencies during project import and dependency updates.
- #1323 - @KronicDeth
- Log
nameSet
when it reaches suspect size (10
) to allow triaging if it is a real bug or just something with a lot of valid names. - Fix inverted condition around when to warn and when to error and use
readAheadLength
.
- Log
- #1272 - @KronicDeth
- Go To Symbol and completion will only resolve in project source unless non-project sources are turned on.
deps
are properly marked as Libraries and no longer count as being in the project scope for the Go To tools.- In umbrella projects, when
in_umbrella
is used, the Project Module for eachapps/#{APP_NAME}
will be marked a dependency, - Library and Modules are properly connected as dependencies, so that only declared dependencies will resolve, lessening false completions and declarations when different OTP app share common Module or function names.
deps
and the_build/#{MIX_ENV}/lib/#{DEP_NAME}
will be marked as Excluded, so that Libraries appear in External Libraries at the bottom of the Project Pane.
- Go To Symbol and completion will only resolve in project source unless non-project sources are turned on.
- #1275 - @KronicDeth
- Go To Class action (Cmd+O) to go to modules separately from all functions as would happen with Go To Symbols (
Alt+Cmd+O).
-
New ModuleName index keeps track of only the names of modulars:
- defmodule
- defimpl
- defprotocol
It is used to power gotoClassContributor for Go To Class action.
-
- Go To Class action (Cmd+O) to go to modules separately from all functions as would happen with Go To Symbols (
Alt+Cmd+O).
- #1280 - Handle
commit
andoverride
forMix.Dep
. - #1283 - Add
.eex
to.ex
and.exs
for accepted file extensions used to hyperlink files in stacktraces. - @KronicDeth - #1285 - @KronicDeth
- Resolve unaliased name when using
alias __MODULE__, as: Mod
- Resolve usage of
Mod
inalias __MODULE__, as Mod
Mod
__MODULE__
inalias __MODULE__
defmodule MyModule
that is enclosing__MODULE__
.
- Disable
ProcessCanceledException
forrunIde
gradle task, to allow for easier manual testing of completion and Go To actions during development. - Completion of functions in current module when using
Mod.
afteralias __MODULE__, as: Mod
. - Show more context for
alias
calls in presentations, like "Choose Declaration" pop up for Go To Declaration.- Show resolved
__MODULE__
name (alias MyModule
) when usingalias __MODULE__
. - Show full
alias MyModule, as: Mod
when listingMod
inalias __MODULE__, as Mod
.
- Show resolved
- Resolve unaliased name when using
- #1293 - @KronicDeth
- Exclude common directories when importing projects
cover
for test coveragedoc
forex_doc
logs
for log filesassets/node_modules/phoenix
forphoenix
assets/node_modules/phoenix_html
forphoenix_html
- Setup Libraries and Module dependencies when importing projects from Mix.
- Exclude common directories when importing projects
- #1299 - Regression test for #1270. - @KronicDeth
- #1313 - @KronicDeth
- Update gradle wrapper to 3.5 to allow for environment variable overrides
- Setup datetime based pre-release versioning to ensure that correct version of pre-release plugin is used when testing Install Plugin From Disk.
- #1318 - @KronicDeth
- Canary, pre-release builds (
vMAJOR.MINOR.PATCH-pre+YYYYMMDDHHMMSS
) frommaster
branch- GitHub pre-release releases
- Release on the canary channel in the JetBrains Plugin Repository
- Canary, pre-release builds (
- #1277 - Don't include
null
useCall
as__MODULE__
dependency. - @KronicDeth - #1279 - @KronicDeth
- Wrap
LibraryTable#removeLibrary
in write action. - Wrap
Library#modifiableModule#commit
in write action.
- Wrap
- #1282 - Check if
Mix.Dep
has already been seen to prevent recursive loops. - @KronicDeth - #1287 - @KronicDeth
- More closely
match ExUnit.CliFormatter
output in Test Runner.
- Don't
inspect
ExUnit failurereason
as##teamcity
message
. - Add captured logs to failure
- Colorize test failures - including diff colorization
- Don't
.formatter.exs
input globs would not match file paths because it was default that neededlib
on top and not version-dependent paths used inresources/exunit
.
- More closely
match ExUnit.CliFormatter
output in Test Runner.
- #1291 - @KronicDeth
- Ignore branch and hex options when finding path of Mix.Dep
- Map Elixir 1.7
:excluded
and:skipped
(added in elixir-lang/elixir#7245) totestIgnored
teamcity message, thereby restoring ignored test counts and markers from Elixir 1.6.
- #1293 - @KronicDeth
- When the entire deps directory has updated sync the children deps directories and then sync all modules instead of syncing them after each dep.
- For an unknown reason, when sync occurs at
initComponent
time inDepsWatcher
ormix.Watcher
, the child directories of the projectbasedDir
aren't shown in the Project Pane until a change is applied in Project Structure. - Use
invokeAndWait
instead ofinvokeLater
to ensure order of syncs.
- #1299 - When finding a
defmodule
, check that it is an ancestor of the entrance of theResolveState
, so that nested sibling modules are not scanned for potential call definition clauses, but only the outer module of the entrance. - @KronicDeth - #1300 - Improve error message
for
org.elixir_lang.debugger.settings.stepping.module_filter.editor.table.Model.getValueAt
, so we can detect if there is an off-by-1 error. - @KronicDeth - #1304 - Remove
@2x
and@3x
SVG icons that render wrong size in 2018.3 EAP. - @KronicDeth - #1305 - @KronicDeth
- Fix unused variables in
TeamCityExUnitFormatting
reason
was completely unused.details
should have been used.
- Fix unused variables in
- #1306 - @KronicDeth
flushBufferBeforeTerminating
was deprecated and in newer IntelliJ the call toprocessStatuses
does not occur unlessflushBufferOnProcessTermination
is also overridden.- Treat
== Compilation error
inSTDOUT
asERROR
for ExUnit reporter - Convert
(CompileError)
of a test file to test failure. The "Test framework quit unexpectedly" is converted to a failed run with a single test with the compilation error as the failure message.
- #1308 - @KronicDeth
- Don't treat redefinition of
defmodule
macro as module definition (as occurs in @bitwalker's distillery' sMix.Tasks.Release.Init.MixMock
- Bump
AllName
VERSION
to re-index and drop bad call definition head from #1301.
- Bump
- Don't treat redefinition of
- #1310 - Don't log compilation errors as test failures
unless a test has started. Test name being called
mix test
does not work, so log those compilation errors as normal build messages instead. - @KronicDeth - #1311 - Don't interpret
:crypto
by default::crypto
includes NIFs that can't be reloaded and so kills the debugger. - @KronicDeth - #1312 - Protect from
null
containingFile
for modular names during completion. - @KronicDeth - #1313 - Wrap
syncPublisher(JDK_TABLE_TOPIC)
ininvokeLater
runWriteAction
. - @KronicDeth
- #1272 - @KronicDeth
- Dependencies are now counted as external to the project, so the Go To tools, like Go To Symbol will no longer
include matches for both project sources and dependencies sources together, instead they will follow the more
JetBrains native behavior
- Project sources will be shown by default
- If there are no project matches, dependencies will be shown instead.
- If you want to include dependency (non-project) matches, you can check the box or hit Cmd+O.
- Dependencies are now counted as external to the project, so the Go To tools, like Go To Symbol will no longer
include matches for both project sources and dependencies sources together, instead they will follow the more
JetBrains native behavior
- #1293 - Modules and Libraries won't be automatically setup
when a project or module is opened, but instead only when
apps
ordeps
directories or subdirectories change.
- #1255 - @KronicDeth
-
Resolve calls through
use AnAlias
callsAnAlias
will be resolved to its modular (module, implementation, or protocol)- The
__using__
macro in the modular is found - The last call in
__using__
is checked
-
If it is a
quote
block, check for call definitions recursively inside the block -
If it is an
apply/3
call- Resolve the first argument as a modular
- Scan for each function in
modular
- In each function Goto Step 3 above
This handling is what specifically makes
use MyAppWeb, :controller
in Phoenix apps now work. -
If it is a general call
- Resolve the call to its definition
- Goto Step 3 above
-
- #1259 - @KronicDeth
- Go To Related (
Ctrl+Cmd+Up
) can be used to Go To the decompiled Module or call definitions when on a source modular (defimpl
,defmodule
, ordefprotocol
) or callable (def
,defp
,defmacro
,defmacrop
). This somewhat restores the ability to go to both source and decompiled module and calls before 9.0.0, but now the source is preferred for Go To Declaration and the decompiled will only be available if there is no source and if you definitely want decompiled, you'll need to use Go To Related.
- Go To Related (
- #1245 - Specify that Kotlin Plugin is needed
in
CONTRIBUTING.md
, so IntelliJ plays nice. - @sfat - #1246 - @KronicDeth
- Resolve unqualified bracket operation identifiers (
var
invar[key]
) to variables or0
-arity calls.- Fixes renames of variables not renaming usage of variables for Access lookups (i.e.
var[key]
).
- Fixes renames of variables not renaming usage of variables for Access lookups (i.e.
- Resolve unqualified bracket operation identifiers (
- #1248 - @KronicDeth
- Go To Symbol will no longer show redundant entries
- Call Definitions (
name/arity
) is no longer shown if the Call Definition Clause is also included. This isn't a large loss because the/arity
was not searchable and only part of the presentation. - If there is a decompiled and a source version of a symbol, only the source version will be shown.
- The source Implementation will be shown and not the decompiled Module with the same fully-qualified
name (
<protocol>.<for>
).
- The source Implementation will be shown and not the decompiled Module with the same fully-qualified
name (
- Items will be deduped if they point to the same element, such as function clauses with default arguments because
when presented they look the same even if internally one is representing
/1
and/2
, for example.
- Call Definitions (
- Go To Symbol will no longer show redundant entries
- #1249 - Ensure that Go To Declaration for qualified calls
such as
Module.function(...)
whereModule
is an alias does not return the decompiled version ofModule
when the source is available. - @KronicDeth - #1256 - @KronicDeth
- Fix completion not working for unqualified functions from
import
s.- When I switched to using
?.let
I accidentally hid theif
from running when there was noENTRANCE_CALL_DEFINITION_CLAUSE
, so the correct form is add if there is no entrance or if there is a non-equivalent entrance. - I just straight up forgot an ! on a contains check. I moved to computeIfAbsent, so it is more obvious what the intent is.
- When I switched to using
- Fix completion not working for unqualified functions from
- #1248 Go To Symbol and Go To Declaration will no longer suggest decompiled modules or functions if source modules or functions of the same name or module/name/arity exists.
- #1226 - Flat icons to match IntelliJ IDEA 2018.2 design rules . Thanks to @nk8 for consulting on the design and showing me how to use Figma.
- #1233 - Regression test for #1228 - @KronicDeth
- #1239 - Use icon provided by Lidiya
Chernigovskaya (@LChernigovskaya) and created by JetBrains UX (Alina Mishina)
for
pluginIcon
compatibility with IntelliJ IDEA 2018.3. - @KronicDeth
- #1233 - Look above
Enum.reduce
for enclosing macro call. - #1234 - @KronicDeth
- Add Facet SDK as External Library to re-enable indexing. When the External Library was removed
in 4297287 in favor
of a real SDK, completion for SDK
.beam
modules was lost because Small IDEs don't index SDKs, but only External Libraries, so add Application-wide External Libraries for SDKs when they are created (and update, remove on edit or delete), which are then added as a Dependency for the facet's module when the SDK is set for the Small IDE project.- Convert old modules with Elixir facets to also have External Library, so that users don't need to remove and add the SDKs to get the External Library.
- Add Facet SDK as External Library to re-enable indexing. When the External Library was removed
in 4297287 in favor
of a real SDK, completion for SDK
- #1237 - @KronicDeth
-
Use #AEB9C0 for JetBrains Default/Light Gray. Use #87939A for JetBrains Darcula Gray. Colors based on IntelliJ's color picker picking its own colors.
Icon matching testing done under both themes in 2018.2.1. Weirdly, the colors are different in the SVGs in my intellij-community@master. Hopefully, this doesn't mean the colors change again in 2018.3.
-
- #1244 - @KronicDeth
- Run
createLibrary
insiderunWriteAction
. - Remove test that leaks threads and so causes builds to fail.
- Run
- #1175 - @KronicDeth
- New and improved Run/Debug Configurations
- Distillery Release CLIs for running
console
,foreground
, etc Options for configuring each part of the command line- Path to Release CLI
- Release CLI arguments (like a command
console
) - Settings that are normally hidden in environment variables
erl
arguments (ERL_OPTS
)elixir -extra
arguments (EXTRA_OPTS
)- Code Loading Mode (
CODE_LOADING_MODE
) - Log Directory (
RUNNER_LOG_DIR
) - Replace OS Vars (
REPLACE_OS_VARS
) sys.config
file (SYS_CONFIG_PATH
)- Release Config Directory (
RELEASE_CONFIG_DIR
) - Pipe directory (
PIPE_DIR
)
- Use Pseudo-Terminal (PTY) to allow overriding console type when it can't be inferred from the Release CLI
arguments, such as using PTY for
console
because it uses aniex
-like shell. - Working Directory
- Environment Variables
iex
console with proper PTY support (colors, tab completion, history) Options for configuring each part of the command lineiex
argumentserl
arguments- Working Directory
- Environment Variables
elixir
with colors Options for configuring each part of the command lineelixir
argumentserl
arguments- Working Directory
- Environment Variables
mix
tasks getting expanded options to match the new configurationsmix
arguments, which used to be called "Program Arguments" (I figured out how to customize that name. 😉)elixir
argumentserl
arguments- Working Directory
- Environment Variables
iex -S mix
Options for configuring each part of the command linemix
argumentsiex
argumentserl
arguments- Working Directory
- Environment Variables
mix test
mix test
arguments, which used to be called "Program Arguments"elixir
argumentserl
arguments- Working Directory
- Environment Variables
- Distillery Release CLIs for running
- Debugger enhancements
- All the above configurations can be debugged using the debugger. It is no longer restricted to only working
with
mix
-based configurations. - Filter more common dependency modules from being interpreted by default.
credo
inch_ex
earmark
ex_doc
- More ways to filter interpreted modules
- Run Configurations now have an Interpreted Modules tab, next to Configuration, which by default imports the
Application-wide settings, but allows
- Disabling inherited filters
- Adding configuration-specific filters
- Remove configuration-specific filters
- Allow interpreted modules to be uninterpreted when the debugger is running, using the "Interpreted Modules" tab.
- Run Configurations now have an Interpreted Modules tab, next to Configuration, which by default imports the
Application-wide settings, but allows
- Improved Variables pane by showing the Elixir name of variables instead of Erlang names
- Evaluate can evaluate an Elixir expression in any stack frame.
- All the above configurations can be debugged using the debugger. It is no longer restricted to only working
with
- New and improved Run/Debug Configurations
- #1192 - @KronicDeth
-
Add all OTP 21 opcodes to disassembler. Previous opcode set was frozen prior to OTP 21 release and missed some later additions.
number name Added 160
build_stacktrace
Before OTP 21 release 161
raw_raise
Now 162
get_hd
Now 163
get_tl
Now
-
- #1196 - @KronicDeth
- Spell checking for identifiers, aliases, comments, and literals (charlists, strings, and sigils).
- Dictionaries for common dependencies
- Elixir
- Ecto
- Dictionaries for common dependencies
- Spell checking for identifiers, aliases, comments, and literals (charlists, strings, and sigils).
- #1203 - @KronicDeth
- Elixir 1.7 debugger Variables and Evaluate compatibility
- Elixir 1.7 names Erlang variables like
_<elixirVariableName>@<counter>
while Elixir 1.6 usedV<elixirVariableName>@<counter>
- Elixir 1.7 changed
elixir_erl
record and%Macro.Env{}
, which changed how:elixir.quoted_to_erl
needed to be called.
- Elixir 1.7 names Erlang variables like
- Elixir 1.7 debugger Variables and Evaluate compatibility
- #1208 - Update
2018.2
to2018.2.1
in build matrix. - #1210 - Regression test for #1141 - @KronicDeth
- #1212 - Improve Cannot Create SDK error message (additions in bold): "You need to configure an Erlang SDK for Elixir SDK. Click OK to be take through the Erlang SDK configuration. Click Cancel to stop configuring this SDK AND the Erlang SDK."
- #1223 - Convert mix and mix test run configurations to new format. - @KronicDeth
- #1188 - Show
...
for module name whenDbgi
has no module name as happens for instrumented modules fromIEx.break/4
. - @KronicDeth - #1189 - Don't assume
callDefinitionClause
is non-null
. - #1190 - Don't assume parent of list access expression
is
QuotableKeywordPair
- @KronicDeth - #1191 - Don't assume parent of keywords is a list.
- #1208 -
TerminalExecutionConsole
itself echos input in2018.2
and2018.2.1
, which was introduced in https://github.com/JetBrains/intellij-community/commit/fd7bbd0cb7f3c2a5add8872e0e6c5172be5f074a#diff-5acc2eb2e78fe52d7458d4a48b0eac9f , but it was reverted in JetBrains/intellij-community@5f4465b, so this uses that version to maintain compatibility across supported versions. - @KronicDeth - #1210 - In
Phoenix.Router.Helpers
, aquote
block appears as the head of[head | tail]
list, so add support for search for enclosing macro call above|
. - #1213 - Treat EEx tag the same as
StabBody
for use scope. - #1214 - Use
ATOM
for keyword keys instead ofIDENTIFIER_TOKEN
asATOM
allows for@
, which is needed for correctness. - #1215 - In
eachEbinPath
, the ebin directories were found by iterating<SDK_HOME_PATH>/lib
and then iterating grandchild of that, so that all paths matching<SDK_HOME_PATH>/lib/<APP>/ebin
would be added, but for some installs from source, like SDK, there are non-OTP-app files in<SDK_HOME_PATH>/lib
, so filter<SDK_HOME_PATH>/lib/<APP>
to only directories. - #1216
org.elixir.lang.psi.scope.Module.aliasedName(QualifiedAlias)
was already converted to useorg.elixir_lang.psi.operation.Normalized
andorg.elixir_lang.psi.infix.Normalized
, which makes it work with errors in the PSI tree, so there's no need protect with an assert and that assert would be wrong in times of errors handled byNormalized
. - @KronicDeth
- #1217
org.elixir_lang.reference.module.UnaliasedName.down(PsiElement)
only expectsElixirAccessExpression
orQualifiableAlias
, but for unexpected classes of elements, it was a simple KotlinTODO()
, which didn't log anything useful for enhancements. Replace theTODO()
with anorg.elixir_lang.errorreport.Logger.error
, so that the element's class and content can be reported when this happens again.
- #1164 - Use
/
in paths passed to Erlang, even on Windows
- #1175 - Drop support for IntelliJ IDEA before 2017.3 as
they lack the
TerminalExecutionConsole
used to runiex
in a PTY. - @KronicDeth
- #1055 - Refactor
ElixirPsiImplUtil
into separate files tied to specific classes or interfaces to shrink its size. - @KronicDeth - #1073 - Complete
#{
with}
. - #1109 - @KronicDeth
- Read Write Accessor Detector
- Variable/Parameter declarations/rebindings are highlighted as writes while other usages are highlighted as reads.
- Improved Find & Show Usages
- Added Find & Show Usages for Functions at declaration and usage site
- Multi-clause functions use all clauses as targets and find usages of all clauses.
- Improved Find & Show Usages for Modules/Aliases
- Added Find & Show Usages for Functions at declaration and usage site
- Improved Element Descriptions
- It is easier to distinguish
alias
es and thedefmodule
that is being aliased because element description now includealias
ordefmodule
before the Alias name based on how the Alias is defined in the scope. - Call definitions use the same presentation for Structure View and Find Usages, so that Compile/Runtime time icons, and visibility are the same in both.
- It is easier to distinguish
- Read Write Accessor Detector
- #1111 - Regression test for #1091 - @KronicDeth
- #1120 - Add regression tests for #1116 that test that parameter and variables can be renamed. - @KronicDeth
- #1124 - Update IntelliJ versions in build matrix to
include
2018.1
and latest patch version of other versions. - @KronicDeth - #1126 - @KronicDeth
- Add Elixir 1.6.X to build matrix
- Update grammar and quoter to match native 1.6 behavior when SDK is >= 1.6.
- New default SDK level is 1.7 to handle builds from
master
.
- #1127 - Regression test for #1105 - @KronicDeth
- #1056 - Certain
.beam
files in the OTP source are purposely invalid, so ignore them when trying to parse and don't log the expected error. - #1060 - Log available bytes and total size when header is
not
FOR1
. - @KronicDeth - #1071 -
erl_abstract_code
formatDbgi
chunks can now be navigated similar to howelixir_erl
format Dbgi chunks can be navigated. Instead of converting the Erlang Abstract Code back to Erlang, which would not be highlighted if intellij-erlang and requires the user to know Erlang, the Erlang Abstract Code is translated back to Elixir source, so you can use the Dbgi chunk view to translate Erlang to Elixir. - @KronicDeth - #1111 - Allow zero or more new lines after the struct name
before the opening curly brace (
{
). - @KronicDeth - #1112 - @KronicDeth
-
In order to prevent
Access is allowed from event dispatch thread only
errors when creating read-only code editor in subtabs of the BEAM Chunks editor, only create those editors when their parent tab is selected.Affected tabs:
- Code (Elixir & Erlang)
- ExDc
- Dbgi (Elixir & Erlang)
-
- #1114 - Check for suffix instead of full match to detect predefined macros when annotating. Location strings have become more complex, such as including the file path for root level modules, so the old exact matching on the module name no longer works.
- #1120 - Restore parameter and variable rename. It broke
because the changes to make Find Usages work and have Go To Declaration default to Find Usage when there is only one
target disabled the default selected element code that the
VariableInplaceRenameHandler
used. - #1121 - @KronicDeth
- Allow module attribute declaration to resolve to itself, so that unused module attributes don't say they can't find the declaration.
- Restore rename module attributes.
- #1127 - Allow
true
andfalse
to be keyword keys.
- #1036 - @KronicDeth
- Clean up debugger
mix format
debugger- Restructure debugger.
- Convert IDE-side to Kotlin
- Allow files to skip interpreting in the debugger to be configured in Preferences > Build, Execution, Deployment >
Debugger > Stepping. It is recommended to customize these settings instead of
using
INTELLIJ_ELIXIR_DEBUG_BLACKLIST
environment variable.INTELLIJ_ELIXIR_DEBUG_BLACKLIST
should be reserved to additional modules that need to not be interpreted only for specific runs.- Ship a set of patterns that excludes Elixir standard library by default and most
mix phx.new
dependencies, so that debugger boots faster for most users.
- Ship a set of patterns that excludes Elixir standard library by default and most
- Support debugging
.eex
templates- Detect MFAs that refer to template functions in Phoenix view modules derived from
.eex
template files, to allow stepping through Elixir tags in those templates. - Allow setting breakpoints in
.eex
files when a.beam
file using the template's relative can be found. ** This means that the Phoenix view module.beam
file must exist in_build
prior to setting a breakpoint. Run the Run Configuration once, before debugging to complete the build if setting a breakpoint does not work.**.beam
files are now indexed by theirLine
chunkfilenames
subsection to power this feature.
- Detect MFAs that refer to template functions in Phoenix view modules derived from
- Cache
.beam
Beam
Cache
onVirtualFile
. Cache is invalidated and refreshed on modification of theVirtualFile
. Cache is used for both BEAM Chunks read-only editors andLine
chunk file name index.
- Clean up debugger
- #1037 - Each package manager uses a different root path and which directory to pick above the ebins varies by package manager, so document package manager install paths.
- #1041 - @KronicDeth
- Restructure JPS code to remove prefixes and suffixes in class names that redundant with package names.
- Show warnings-as-errors checkbox
as original blocker has been fixed for
awhile and
ProcessAdapter
turns warning text into errors that IDE understands.
- #1045 - @KronicDeth
- When importing Mix projects, don't exclude compiler output from indexing because it is needed to resolve Elixir Line
Breakpoints in EEx files.
- For pre-existing Elixir modules, they will be converted to not exclude compiler output.
- When importing Mix projects, don't exclude compiler output from indexing because it is needed to resolve Elixir Line
Breakpoints in EEx files.
- #1047 - @KronicDeth
- Exclude known uninterpretable modules
Bcrypt.Base
:erocksdb
:lz4
:re2
- Exclude known uninterpretable modules
- #1036 - @KronicDeth
- Turn off
dbeug
flag when startingIntelliJElixir.DebugServer
, which removes the*DBG*
statements that kept printing in the ExUnit output when using the debugger. - Fix conversion of Elixir module names to Erlang module names for
INTELLIJ_ELIXIR_DEBUG_BLACKLIST
environment variable. - Cache
null
SDKRelease
, so that when Elixir is configured, but the Erlang path is broken (such as after abrew unlink erlang
, theRelease
calculating usingelixir
- Implement
Macro.atomToString
- Properly render improper lists
- Show improper list with explicit
|
for presenation - Children of improper lists show
head
andtail
instead of index.
- Show improper list with explicit
- Show Elixir indices (
0
-based) instead of Erlang indices (1
-based`) for lists and tuples.
- Turn off
- #1037 - Loosen check on the path suffix by looking for
only
lib
and notlib/erlang/lib
, so that it works for both Homebrew'sebin
paths and ASDF'sebin
paths. - #1041 - @KronicDeth
- Remove unused
MixBuilder
because building withmix
is just an option inElixirBuilder
. - Harmonize JPS compile server's invoking of
mix
to pattern used in Run Configuration runners.- Use
mix
path from SDK
- Use
- No longer say the build succeeded when there are obvious
mix
errors- Parse
mix compile
output for compilation errors and warnings- When "warnings-as-errors" is enabled in "Elixir compiler" settings, IDE also shows warnings as errors.
- IDE will know build failed if there are errors (or warnings treated as errors) and properly allow rebuild.
- Parse
- Remove unused
- #1045 - @KronicDeth
- Group alternatives in
erlang_module_name_patterns_to_regex
before pinning: I always forget that the|
swallows the^
and$
in regexes. - Reject vs filter accumulation got flipped when switching to
Enum.reduce
to track rejections.
- Group alternatives in
- #1047 - @KronicDeth
- Some modules, like NIF modules, can't be loaded into the debugger. Individual modules not being debuggable shouldn't kill the debugger task, so rescue the known error and record it for later debugging of the debugger.
- Add
:
to start of Erlang module names for included debugger excludes
- #988 - @KronicDeth
- Update build matrix
- Update IntelliJ IDEA version
2017.3
to2017.3.2
- Update Elixir version
1.5.2
to1.5.3
- Update IntelliJ IDEA version
- Update build matrix
- #1015 - @KronicDeth
- Add supplemental file editor for
.beam
files: "BEAM Chunks". The decompiled binary file will continue to be shown on the default "Text" editor tab. The BEAM Chunks editor is subdivided into further tabs, one for each chunk in the.beam
file. The tabs are listed in the order that the chunks occur in the.beam
file.-
The
Atom
chunk holdsLATIN-1
atoms whileAtU8
holdsUTF8
atoms. There will only be one of these atom-related chunks in any given.beam
file.AtU8
is used in newer versions of OTP that support UTF8 atoms.The
Atom
/AtU8
tab shows a table with the columnsColumn Description Source Index Which is 1-based to match Erlang convention. In the Code
chunk,atom(0)
is reserved to always translate tonil
Derived Byte Count The byte count for the atom's bytes Raw Characters From encoding the bytes as LATIN-1 for Atom
chunk or UTF-8 forAtU8
chunkDerived Index 1 is always the module name for the
.beam
file. Since.beam
is originally an Erlang format, for Elixir modules, you'll see the full atom name of with theElixir.
prefix instead of the Alias name used in Elixir source. -
The
Attr
chunk holds the module attributes, but only those that are persisted.The
Attr
tab shows a table with the columnsColumn Description Source Key Attribute name Raw Value Attribute value. **Note: The value always appears as a list as read from the binary format. I don't know why.** Raw All modules will have a
:vsn
attribute that is either set explicitly or defaults to the MD5 of the module. -
The
CInf
chunk is the Compilation Information for the Erlang or Erlang Core compiler. Even Elixir modules have it because Elixir code passes through this part of the Erlang Core compiler.The
CInf
tab shows a table with the columnsColumn Description Source Key Option name Raw Value Inspected value Raw -
The
Code
chunk contains the byte code for the module. It is encoded in BEAM Compact Term Encoding , which differs from the binary format produced byterm_to_binary
.The
Code
tab shows a read-only editor with one byte code operation on each line. For ease of reading, operations are grouped by function and then label block with indentation indicating scope.By default as many references to other chunks and references to other parts of
Code
chunk are inlined to ease understanding. If you want to see the raw byte code operations, you can turn off the various inliners. -
The
Dbgi
chunk contains Debug Info. It was introduced in OTP 20 as a replacement for theAbst
chunk. While theAbst
chunk was required to contain the Erlang AST, theDbgi
format can contain the debug info for other languages, such as Elixirquoted
form AST.Because the format is language neutral, the format is a set of nested, versioned formats. The outer most layer is
For `:debug_info_v1`, Elixir's `backend` is `:elixir_erl`. The `metadata` for `:elixir_erl` is further versioned: `{:elixir_v1, map, specs}`. `map` contains the bulk of the data. | Key | Value | |:----------------|:---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | `:attributes` | Attributes similar to the `Attr` chunk, but at the Elixir, instead of Core Erlang level. Usually they match with the exception that `attributes` doesn't contain `vsn` when `Attr` contains the `MD5` version | | `:compile_opts` | Compilation options similar to `CInf` chunk's `options` key, but at for Elixir, instead of Core Erlang level. | | `:definitions` | The Elixir `quoted` AST for reach function clause. | | `:file` | The name of the file the module was generated from. | | `:line` | The line in `:file` where the module was defined, such as the line `defmodule` occurred. | | `:module` | The name of the module as an `atom` | | `:unreachable` | Unreachable functions | The `Dbgi` tag show the single value map entries: `:file`, `:line`, and `:module` ![screen shot 2018-02-02 at 5 26 04 pm](https://user-images.githubusercontent.com/298259/35759265-33c33742-083e-11e8-9a4f-97cfd52bbe8e.png) For the multi-value keys: `:attributes`, `:compile_opts`, and `:definitions`, there are individual tabs. ![screen shot 2018-02-02 at 5 27 29 pm](https://user-images.githubusercontent.com/298259/35759293-6117c83e-083e-11e8-8327-ec7c66cade69.png) The Attributes tab has the same format as the `Attr`s chunk ![screen shot 2018-02-02 at 6 47 49 pm](https://user-images.githubusercontent.com/298259/35760967-9c7e0914-0849-11e8-8d53-e402653b70fa.png) The Compile Options tab is usually empty, much like the `CInf` `options` key for Erlang. ![screen shot 2018-02-02 at 6 48 34 pm](https://user-images.githubusercontent.com/298259/35760988-c3ef0f52-0849-11e8-9ca6-2cbeba8eda23.png) The Definitions tab is split between a tree of Module, Function/Arity and clauses. ![screen shot 2018-02-02 at 6 50 14 pm](https://user-images.githubusercontent.com/298259/35761058-3710d04c-084a-11e8-99e3-0f2aa4f8837d.png) Clicking on a clause will show only that clause, but clicking on a higher level in the tree will show all clauses in the function or the entire Module. ![screen shot 2018-02-02 at 6 53 17 pm](https://user-images.githubusercontent.com/298259/35761087-7a6e0b8e-084a-11e8-9f86-6e4840eab25d.png) ![screen shot 2018-02-02 at 8 47 05 pm](https://user-images.githubusercontent.com/298259/35762314-55fb0dd2-085a-11e8-8381-faacc880d29e.png) ![screen shot 2018-02-02 at 8 47 20 pm](https://user-images.githubusercontent.com/298259/35762317-5b9f9136-085a-11e8-8b53-03be16b7a06c.png) The AST stored in the `definitions` tab and the process of converting it back to code is not format preserves, so it will not look precisely like the source code as the AST has undergone some macro expansion before its put in the Dbgi chunk. *As common idioms are understood, reversals will be add to the renderer.* * The `ExDc` chunk stores ExDoc. Not the rendered HTML from the `ex_doc` package, but the the `@doc` , `@moduledoc`, and `@typedoc` attribute values that work even without `ex_doc` installed. This chunk is what is consulted when the `h` helper is used in `iex`. The `ExDc` binary format is from `term_to_binary`, so it can be reversed with `binary_to_term`. The term format is a versioned as `{version, versioned_format}`. The current `version` tag is `:elixir_docs_v1` and the `versioned_format` is a [Keyword.t](https://hexdocs.pm/elixir/Keyword.html#t:t/0) with `:callback_docs` , `:docs`, `:moduledoc`, and `:type_docs` keys. Like `Dbgi`, the `ExDc` tab is split between a tree to navigate and an editor to show the decompiled value. ![screen shot 2018-02-02 at 8 58 38 pm](https://user-images.githubusercontent.com/298259/35762423-024913d0-085c-11e8-88ee-c794474a5da5.png) ![screen shot 2018-02-02 at 9 07 03 pm](https://user-images.githubusercontent.com/298259/35762502-139d2b8e-085d-11e8-97a6-4b16d19dfccb.png) | Node | Description | |:-------------------------|:-----------------------------------| | *Root* | All docs | | Module | `@moduledoc` | | Types | All `@typedoc`s | | Types *child* | A specific `@typedoc` | | Callbacks | All `@callback` `@doc`s | | Callbacks *child* | A specific `@callback`'s `@doc` | | Functions/Macros | All `@doc`s for functions/macros | | Functions/Macros *child* | A specific function/macro's `@doc` | * The `ExpT` chunk is the Export Table. The name "Export" derives from the `Erlang` module attribute `-export`, which is used to "export" functions from a module. It is the equivalent of making a function or macro public with `def` and `defmacro` as opposed to making it private with `defp` and `defmacrop` in Elixir. The `ExpT` tab shows a table with the columns | Column | Description | Source | |:-----------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:--------| | Atom Index | Index into the `Atom` or `AtU8` chunk for the function's name | Raw | | Name | The atom referenced by "Atom Index" | Derived | | Arity | The arity (argument count) of the function | Raw | | Label | Label index in the `Code` chunk where the function is defined. This label is usually immediately after the `func_info` operation and before the first pattern match or guard operation. | Raw | ![screen shot 2018-02-01 at 8 21 13 pm](https://user-images.githubusercontent.com/298259/35713581-b36f17ba-078d-11e8-87e3-0c50b2624676.png) You'll notice the first entry starts with `MACRO-`. This is because the BEAM, being made for Erlang has no concept of macros. It only understands functions, so Elixir macros, like `__using__/1` called by `use` are compiled to plain Erlang functions with `MACRO-` prefixed to their name and an extra argument ( the `__CALLER__` environment) as the first argument, which increases the arity, yielding a full MFA of `MACRO-__using__/2` as seen above. * The `ImpT` chunk is the Import Table. It **DOES NOT** encode just the Erlang `-import` attributes or Elixir `import` macro calls: it tracks any external function or macro called from another module. `call_ext_*` operations in the `Code` chunk don't store the Module and Function (MF) of the function they will call directly in the bytecode, instead, one of the arguments is an index into the `ImpT` chunk. This way, all external calls are normalized into the `ImpT` chunk instead of being denormalized to the call site. The arity still appears at the call site to help with checking the argument count. The `ImpT` tab shows a table with the columns | Column | Description | Source | |:--------------------|:-------------------------------------------------------------|:--------| | Index | 0-based index used by references in the `Code` chunk. | Derived | | Module Atom Index | Index into the `Atom` or `AtU8` chunk for the Module's name | Raw | | Module Atom | The atom referenced by "Module Atom Index". | Derived | | Function Atom Index | Index into the `Atom` or `AtU8` chunk for the functon's name | Raw | | Function Atom | The atom referened by "Function Atom Index". | Derived | ![screen shot 2018-02-01 at 8 07 15 pm](https://user-images.githubusercontent.com/298259/35713189-93432ff0-078b-11e8-8856-df067459adf9.png) You may notice that `erlang.byte_size/1` is included in the table. This is because even bifs are referenced by MFA and not a pre-assigned number as would be the case for system calls in operating systems like Linux. BEAM is like an Operation System, but not in all ways. * The `LitT` chunk contains literals loaded as arguments in `Code` chunk. Confusingly, in the `Code` chunk sometimes the `literal(N)` term is used to encode integer `N`, an index into another chunk, or an actual `index` into the `LitT`. How `literal` terms are handled is completely dependent on the specific operation, so without having outside knowledge about the bytecode operation arguments for BEAM, the best way to figure out if `literal` terms are an integer or an index is to toggle the various controls in the `Code` tab to see if `literal` with no inlining turns into a `LitT` literal, `FunT` function reference, `ImpT` function reference, or integer. The `LitT` tab shows a table with the columns | Column | Description | Source | |:-------|:---------------------------------------------------------|:--------| | # | 0-based index used by references in the `Code` chunk. | Derived | | Term | The equivalent of `raw |> binary_to_term() |> inspect()` | Raw | ![screen shot 2018-02-01 at 9 25 07 pm](https://user-images.githubusercontent.com/298259/35715153-674f088c-0796-11e8-89e8-fd3c6c083a45.png) * The `LocT` chunk is the dual to the `ExpT` chunk: it contains all private functions and macros. The `LocT` tab shows a table with the columns | Column | Description | Source | |:-----------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:--------| | Atom Index | Index into the `Atom` or `AtU8` chunk for the function's name | Raw | | Name | The atom referenced by "Atom Index" | Derived | | Arity | The arity (argument count) of the function | Raw | | Label | Label index in the `Code` chunk where the function is defined. This label is usually immediately after the `func_info` operation and before the first pattern match or guard operation. | Raw | ![screen shot 2018-02-01 at 9 27 49 pm](https://user-images.githubusercontent.com/298259/35715229-ca135b1c-0796-11e8-80a4-971470f1c6d2.png) You'll notice the first entry `-__struct__/1-fun-0-`, starts with `-` and have a `/` suffix with `fun` in it. This naming scheme is used for anonymous functions such as those defined with `fn` or the capture operator (`&`) in Elixir. Much like how macros don't really exist and use a `MACRO-` suffix, anonymous functions/lambdas don't exist, and instead use a distinct naming scheme `-<PARENT_FUNCTION>/*fun*`. Unlike `MACRO-`, which is an Elixir invention, anonymous functions/lambdas really being local named functions with derived names is also done in pure Erlang modules. Erlang's anonymous functions are defined with `fun`, which is where the `fun` part of the naming scheme comes from. * The `StrT` chunk contains a single contiguous pool of all Erlang strings (that is, Elixir charlists) used in the `Code` chunk. These strings are used for byte code operations like `bs_put_string`. Not all strings appear in `StrT`. Some strings, including most Elixir strings (Erlang binaries) appear in the `LitT` chunk that holds literals. ![screen shot 2018-02-01 at 7 56 15 pm](https://user-images.githubusercontent.com/298259/35712876-040796d8-078a-11e8-8eb6-6b7f203bbd4a.png) The `StrT` is contiguous with no separation of strings. Instead of encoding the start and length of each string in the chunk itself, the start and length for any given string is passed as arguments to the byte code operations in the `Code` chunk. By doing this, shared substrings can be efficiently encoded in `StrT`.
-
- Add supplemental file editor for
- #1021 - @KronicDeth
-
Support for https://github.com/elixir-lang/elixir/commit/23c7542d95683a497a7b93071b9ccbbeb9e45d2f
Version Struct Started Event Finished Event %ExUnit.Test{}
field< 1.6.0 %ExUnit.TestCase{}
:case_started
:case_finished
case
> = 1.6.0 %ExUnit.TestCase{}
:module_started
:module_finished
module
Because Elixir 1.6.0 could not introduce a breaking change, the
< 1.6.0
event are fired, butresources/exunit/1.6.0/team_city_ex_unit_formatting.ex
will ignore them and only convert the>= 1.6.0
event to TeamCity event used in the JetBrains Test Runner UI.
-
- #1018 - Expose Declarations > Functions and Declarations > Macros in Color Settings - @dimcha
- #1019 - Don't use
StreamEx
because support is inconsistent across IDEs - @KronicDeth - #999 - @ronanboiteau
- Jetbrains' Gogland is now named GoLand, updated README accordingly
- In donors list, Garrett Hart had his GitHub URL (
@https://github.com/thirdshift
) shown instead of his GitHub username (@thirdshift
)
- #980 - Use
documentionRootType
to indirectly get the documentationOrderRootType
in the Erlang SDK Type, so that it works in Small IDEs that have more thanCLASSES
andSOURCES
root types installed. - @KronicDeth - #981 - @KronicDeth
-
The
credo
annotator is disabled by default as numerous users find runningmix credo
in the background has a negative impact on their system performance. If you like to try enabling the annotation, you can turn it on using the configuration.- Preferences > Editor > Inspections > Elixir
- Check "Credo"
- Click OK to save and close Preferences
If you notice a degradation the in the responsiveness of the editor, it is recommended you disable the annotator again.
- Preferences > Editor > Inspections > Elixir
- Uncheck "Credo"
- Click OK to save and close Preferences
-
- #982 - Protect from
PsiFile
beingnull
inLocal
credo inspector - @KronicDeth - #983 - Run
Qualified#moduleName
getText
in Read Action. - #985 - Scratch Files have a
Project
, but not aModule
, so change flow to useProject
whenModule
isnull
in credo annotator. - #986 - Don't add
.bat
tomix
on Windows.mix
is never run as an executable. It is either run as a script toelixir.bat
OR as an argument toerl.exe
whenerl.exe
is runningelixir
. - @KronicDeth
- #963 -
mix
runs will be faster as they will no longer check to see if the SDK is updated. - @KronicDeth
- #963 - Avoid problems with read and write locks when updating Elixir SDK on-demand by instead updating them when any project is open using a project converter.
- #964
- JetBrains/intellij-community@9adbba0
added
@NotNull
toOrderRootType.getOrderRootType
, whichJavaDocRootType.getInstance
calls, which means any Small IDE usingintellij-community
since 4 months ago, including the newest CLion cannot haveJavadocOrderRootType.getInstance
safely called. - @KronicDeth
- JetBrains/intellij-community@9adbba0
added
- #966 - Path changes were not being written back to disk
because the
projectSdksModel.apply()
was being called before theeditor.apply()
, which would have copied to theeditor'
s path changes to theprojectSdksModel
. - @KronicDeth
- #955 - @KronicDeth
- Start using Kotlin for new development.
- Elixir Facet in Small IDEs
- Preferences > Languages & Frameworks > Elixir can set the Elixir Facet SDK for the Project Module used in Small IDEs as a per-project settings.
- Preferences > Languages & Frameworks > Elixir> SDKs can add, delete, and configure Elixir SDKs as per-application settings.
- Preferences > Languages * Frameworks > Elixir > Internal SDKs can add, delete, and configure Erlang SDK for Elixir SDKs as per-application settings.
- Configure SDK before running
mix
when importing mix projects, so that themix
path does not need to be configured separately from the SDK path.- The
mix
path no longer needs to be setup independently from the Elixir SDK.
- The
- #957 - Add Local shared
credo
inspection, so the thecredo
inspection works for Code > Code Cleanup. - @KronicDeth - #958 - @KronicDeth
-
Show Mix ExUnit in context menu in Elixir Facets, so that
- Run 'Mix ExUnit ...'
- Debug 'Mix ExUnit ...'
- "Create "Mix ExUnit ...'"
appear in Rubymine when you right-click the
test
directory and it is Marked as a Test Sources Root. It will appear green in Rubymine if already marked. To mark it, do the following:- Right-Click
test
directory - Select "Mark Directory as > Test Sources Root"
-
- #955 - @KronicDeth
- Protect access to
JavadocOrderRootType.getInstance()
so that it doesn't cause an error in Small IDEs where its Extension Point is not defined. - If the explanation tooltip is empty, fallback to the message for the credo annotator instead.
- Protect access to
- #956 - Check if
SdkAdditionalData
isnull
before gettingErlangSDK
as it can benull
in certain scenarios in Rubymine. - #958 - @KronicDeth
Fix
isConfigurationFromContext
, so that it works on Mix ExUnit Run Configurations generated from directories. Check if theprogramParameters
andworkingDirectory
match by just generating another configuration from the context as this ensures the logic matches and includes support forPsiDirectory
.
- #944 - @KronicDeth
- Eliminate the majority of the
eolStar
parser rules around operators where they do not matter leaving only theeolStar
afterCOMMA
and the the ones that help differentiate unary and binary+
/-
. This simplifies the parser and under certain conditions should prevent reparsing when onlyWHITE_SPACE
changes in size.- Look-ahead in the lexer, where it's cheaper than the parser to see if the next token does not care if there's
an
EOL
or normalWHITE_SPACE
. - After operators that don't care if they are followed by
EOL
, try to match all followingWHITE_SPACE
,ESCAPED_EOL
andEOL
.
- Look-ahead in the lexer, where it's cheaper than the parser to see if the next token does not care if there's
an
- Eliminate the majority of the
- #950 - @KronicDeth
-
If you want to limit the performance impact of the credo annotator because
mix credo
spikes your CPU, you can limit the number ofmix credo
runs to 1 per open file by disabling the Explanation tooltip- Preferences > Editor > Inspections > Credo
- Uncheck "Include Explanation"
If you don't want the annotator to run at all on open editors, then you can disable the paired inspection
- Preferences > Editor > Inspections
- Uncheck Elixir > Credo
If you've unchecked the inspection, it disables both the annotation and the pair inspection when Analyze > Inspect Code... is run. You can still run the Credo inspection by name.
- Analyze > Run Inspection By Name... (⌥⇧⌘I)
- Type "Credo"
- Select "Credo" from the shortened list
- Hit Enter.
You'll be presented with a "Run 'Credo'" dialog
- Change the "Inspection scope" from "Whole project", which would include the
deps
to "Custom scope" - Select "Project Production Files" from the "Custom scope" dropdown
- Click "OK"
-
- #951 - @KronicDeth
- Setup
VirtualFilePointerManager
duringParsingTestCase
- Put
LineMarkerInfo
on leaf elements for Method (Call Definition) Separators for a performance improvement. - Add IntelliJ IDEA 2017.3 to the build matrix
- Setup
- #947 - When the SDK changes, record what
Release
of Elixir is used indirectly, using aLevel
enum
that only cares about the major and minor version. Changing theLevel
, will mark the open files and .beam files as invalidated, so that if the SDK is changed, the stubs and codeLevel
will agree, so there isn't a stub incompatibility with the PSI. - @KronicDeth - #950 - Allow credo section to be empty when processing credo explanations - @KronicDeth
- #951 - @KronicDeth
- Prevent negative indent, not supported in 2017.3
- Cleanup SDKs from MixProjectImportBuilderTest
- #951 - Drop support for IntelliJ IDEA before 2016.3
- #943 - @KronicDeth
- Regression test for #580
{EOL}|.
->{ANY}
inElixir.flex
- Convert (some) unimportant newlines from
EOL
toWHITE_SPACE
token, as GrammarKit is smarter about reparsing when onlyWHITE_SPACE
changes in size.- After
fn
do
->
- block identifier (
after
,catch
,else
, andrescue
) - keyword pair colon
(
- Before
- Comments
- After
- #943 - @KronicDeth
-
Remove
!stabOperationPrefix
beforeexpression
, sincestabOperationPrefix
itself starts withexpression
and instead put a negative look-ahead,!(infixComma | stabInfixOperator)
afterexpression
. This now works when it previously didn't becauseCOMMA
was added toexpressionRecoverUntil
, which means bothCOMMA
andSTAB_OPERATOR
are now in both not eaten byexpression
's error recovery.This drops Fn1 through Fn8 to ~176ms instead of the previous time of the last optimization of 13 seconds for Fn8. It started at 26 seconds and now it appears that the time no longer grows with the number of
fn
. It also eliminates the pause when hitting entering inside thefn
nesting.
-
- #923 - @KronicDeth
- EEx support
- Lexer for EEx format
- Parser for EEx format
- EEx as a Template Language
- Any file with
.eex
as the final extension will be treated as EEx. To determine the Template Data Language, the.eex
extension will be stripped and any remaining extension will be looked up to get the File Type and its associated Language. For example,*.txt.eex
will be EEx with Plain Text (.txt
) as the Data Template Language. Likewise,*.html.eex
will be EEx with HTML as the Data Template Language. There's no need to register*.txt.eex
or*.html.eex
or any other*.DATA_TEMPLATE_LANGUAGE_EXTENSION.eex
pattern explicitly: the nested extension will be looked up using the normal extension setup.
- Any file with
- Update Build Matrix
- IDEA
2016.2
is dropped because it's over a year old. It is still supported, but not actively tested.
- IDEA
- EEx support
- #931 - Decompile
LocT
chunk for private macros and functions and the derived names of anonymous functions. - @KronicDeth
- #910 -
mix hex.local --force
->mix local.hex --force
inREADME
- @bryanhuntesl-lowpriv - #930 - @KronicDeth
- Parse
HEAD-<SHA1>
as0.0.<SHA1>
for sorting versions from homebrew homepath. It will almost always be last unless there is an unknown version, which uses0.0.0
. - Ensure any unparsable version sorts as
0.0.0
(UKNOWN_VERSION
).
- Parse
- #932 - @KronicDeth
- Look at parent of
eexTag
to resolvefn
parameters - Ensure functions
fn
ineex
tags don't error by looking ateex
element parent. - Search above
eexTag
andeex
to determine if variable.
- Look at parent of
- #904 - Don't do
project instanceOf MockProjectEx
because not all IDEs, such as Rider, ship withMockProjectEx
; instead, do aClass#getCanonicalName()
check.
- #898 - @KronicDeth
- Update Build Matrix
- Only include IDEA versions within the last year. Prior versions are supported, but not tested. It is up to users
stuck on older versions to report incompatibilities and then I'm specifically fix those bugs.
- Add
2017.2
- Drop
2016.1.4
- Add
- Only include Elixir versions within the last year. Prior versions are supported, but not tested. It is up to users
stuck on older versions to report incompatibilities and then I'm specifically fix those bugs.
- Add
1.5.2
- Drop
1.3.4
- Add
- Only include OTP versions within the last year. Prior versions are supported, but not tested. It is up to users
stuck on older versions to report incompatibilities and then I'm specifically fix those bugs.
- Add
20.1
- Drop
18.3
- Add
- Only include IDEA versions within the last year. Prior versions are supported, but not tested. It is up to users
stuck on older versions to report incompatibilities and then I'm specifically fix those bugs.
- Support
not in
grammar added by elixir-lang/elixir#5620 shipped with Elixir 1.5. - Don't treat numeric operands to
@
and unary operators as separate operations from non-numeric operands to port elixir-lang/elixir@9747e58db773c716c01c210642ec1d91475e0c83 that shipped with Elixir 1.5.0. This only kicks in if the Elixir SDK is version >= 1.5.0 or not set. With an earlier SDK, you'll get the earlier behavior.
- Update Build Matrix
- #898 - Make binary infix vs unary prefix
+
/-
handling more robust to supportone(two, - three)
used in Elixir 1.5enum.ex
. - #901 - Call
withCharSet(Charsets.UTF_8)
on allGeneralCommandLines
to prevent encoding errors on Windows. - @KronicDeth
- #861 - Regression test for #860 - @KronicDeth
- #862 - Regression test for #859 - @KronicDeth
- #863 - Convert ANSI escape codes to colored output in
mix
Run and Debug output - @KronicDeth - #886 - Regression test for #883 - @KronicDeth
- #887 - Regression test for #878 - @KronicDeth
- #861 - @KronicDeth.
- Quote
-
in addition to#
inUnquoted
MacroNameArity
decompiler. - Quote
-
in decompiled module names.
- Quote
- #862 - Wrap call definitions with name
nil
asunquote(:nil)
in the decompiler. - @KronicDeth - #884 -
Application#runWriteAction
MUST be run from EventDispatch thread. This is true when run from a Run Configuration runner, but when the Credo annotator runsrunWriteAction
, it's not in an EventDispatch thread, so followed IntelliJ Platform SDK DevGuide - General Threading Rules and wrapped therunWriteAction
inApplication#invokeAndWait
. - @KronicDeth - #885 - Wrap
sdkModificator::commitChanges
ininvokeAndWait
runWriteAction
inMixRunningStateUtil#updateRoots
. - #886 - @KronicDeth
-
Generalize what needs to be double quoted for
Unquoted
decompiler- Aliases and special forms are bare atoms
- Anything that is NEITHER an identifier NOR a prefix operator is a double quoted atom.
Normal identifiers and prefix operators then fall through to the
Default
decompiler.
-
- #887 - Add
end
toUnquoted
decompiler bare atoms. - #888 - Replace
assert
s inCredo
external annotator with extended log messages that record the unexpected line. - @KronicDeth
- #854 - @KronicDeth
credo
external annotator- Once modifications have settled on a file and all internal annotators have run,
mix credo
will be run on any modified file.- Each check failure reported by
mix credo
will be turned into a warning annotation (yellow highlight) of the line or line and column credo identified. - If you hover over the annotation (either in the source or on right gutter), the
mix credo PATH:LINE(:COLUMN)
explanation will be shown. Links in the tooltip are clickable and allow you to jump to the specific line or line and column of the failure.
- Each check failure reported by
- Once modifications have settled on a file and all internal annotators have run,
- #856 - @KronicDeth
- Explain Rich vs Small IDEs more
- Add feature support table for Rich vs Small IDEs with links to alternatives for Rich IDEs features not in Small IDEs.
- Reorder Project subsections based on usage.
- #854 - Rename package with typo
org.elixir_lang.annonator
->org.elixir_lang.annotator
. - @KronicDeth - #855 - @KronicDeth
- Change error to say mix, elixir, or erlang path is not set instead of just mix path.
- Rewrite of
MixRunningStateUtil#setElixir
to support callingerl
directly in IntelliJ IDEA added a check that sdk type was the Elixir SDK Type, but there was noelse
clauses to handle that there IS an SDK, but its NOT Elixir, which is the common case on all Small IDEs (like Rubymine). To fill this gap, if the SDK is not Elixir and a Small IDE is detected, then the SDK Home from Preferences > Other Settings > Elixir External Tools > Elixir SDK > Path will be used to get the absolute path to theelixir
(orelixir.bat
executable and set it in theGeneralCommandLine
.
- #856 - @KronicDeth
- Add missing
**
for bold. - Document alternative setup in Small IDEs
- Put Import from external model first in Project subsections, so that people are more likely to import as a mix project correctly.
- Add missing
- #817 - * Add note to README that atom module names should be
prefixed with
:
- @merqlove - #827 - @KronicDeth
-
Elixir SDK will now have an Internal Erlang SDK, which can be supplied one of two ways:
- If
intellij-erlang
is installed: its Erlang SDK can be used - Otherwise: the Erlang SDK for Elixir SDK from this plugin can be used
Either Internal Erlang SDK's home path is used to locate the
erl
(orerl.exe
on Windows) executable and it is used to run Elixir; bypassing theelixir
(orelixir.bat
on Windows) script. Instead, as was done in #789, the ebin directories for the Elixir SDK are passed as-pa
options toerl
.The Elixir SDK's configuration becomes more important: the classpath entries are now the list of
ebin
directories to pass toerl
using-pa
instead of scanning for ebins in the homepath, so additional code paths can be added to the Classpaths configuration and they will be used when runningmix
andmix test
. The classpaths will be initialized to the ebin directories under the home path.- To support migrating from earlier version of the plugin, an SDK will be updated when it is used for Mix ExUnit Run
Configurations
- The default Internal Erlang SDK will be set, which uses the latest version of Erlang that can be found on the
system. When
intellij-erlang
is installed,intellij-elixir
's Erlang version suggestion is still used becauseintellij-elixir
favors the latest version whileintellij-erlang
favors the first found, which is usually the oldest version. - Update roots (class path, source paths, documentation paths):
- Class path of
HOMEPATH/lib
is replaced withHOMEPATH/lib/APP/ebin
. - Source path of
HOMEPATH/lib
is replaced withHOMEPATH/lib/APP/lib
IF it exists (so only for source SDKs) - Documentation of
http://elixir-lang.org/docs/stable/elixir/
will be replaced withhttps://hexdoc.pm/APP/VERSION
for everyAPP
inHOMEPATH/lib
.
- Class path of
- The default Internal Erlang SDK will be set, which uses the latest version of Erlang that can be found on the
system. When
- If
-
- #839 - @KronicDeth
- All
ebin
paths in the Internal Erlang SDK will be copied to the Elixir SDK, so that they are indexed, which makes the Internal Erlang SDK modules show up in Symbol search. - Erlang SDK modules can be completed and then functions in those modules can be completed after typing
.
.- Atoms have References.
- Indexed atoms (from decompiled Erlang
.beams
from the Internal Erlang SDK) will be used for completing atoms as soon the atom is parseable: either after the first letter:
or inside the quotes when making a quoted atom. - Atoms will resolve to modules if the atom is a module name. If the atom is quoted and contains interpolation, it
will treat each interpolation as
.*
and look for regex matches to this derived potential atom name.
- Indexed atoms (from decompiled Erlang
- Atoms have References.
- Completions for functions after
.
will now work at the end of file. Previously, completions only worked in the middle of a file, where the.
could parse the next work an existing call, now if that parse doesn't work and the only thing after is a new line, it will still complete.
- All
- #830 - Auto test for mix test case runner will automatically run tests after a change is detected in the project files, which normally happens on save, which happens when losing focus on a changed editor tab by default. - @nivanson
- #840 - Regression test for #821 - @KronicDeth
- #841 - Regression test for #803 - @KronicDeth
- #842 - Regression test for #833 - @KronicDeth
- #843 -
Port elixir-lang/elixir#2774: Allow
A-Z
as sigil modifiers in addition toa-z
to supportU
ungreedy modifier that replacedr
ungreedy modifier for regexes.
- #816 - Add notice for debug blacklist that it uses atoms,
not Aliases, so you need to qualifier module aliases with
Elixir.
- @merqlove - #817 - Support atoms (prefixed with
:
) andElixir.
and plain Aliases for debugger blacklist. - @merqlove - #832 - Add space to import window text
- #840 - Add
END
to allowedkeywordKey
tokens - #841 - @KronicDeth
- Only use "Macros" as first header in decompiled
.beam
files ifmacro
isdefmacro
. "Macros" header was being printed when there was only functions because the check when there was nolastMacroNameArity
didn't care what the currentmacroNameArity.macro
was. - When an
.erl
file has-compile([compressed])
, it will be compiled normally, and then gzipped, so that the.beam
will not contain the BEAM magic numberFOR1
, but instead the gzip magic number0x1f
0x8b
. So, to properly handle normal and compressed, the decompiler needs to look-ahead 2-bytes and check the gzip magic number. If the gzip magic number is detected, the InputStream will be passed throughGZIPInputStream
before the the normal decoding process.
- Only use "Macros" as first header in decompiled
- #842 - When decompiling function and macro names from Erlang
module, its possible for the name to contain
#
and they would be interpreted as comments. Accepting those names inUnquoted
wouldn't escape the#
from being treated as a comment, so in addition tounquote
ing the name, surround it in double quotes. - @KronicDeth - #848 - @KronicDeth
AdditionalDataConfigurable
only copied the the Internal Erlang SDK Code Paths when the selection in theComboBox
was changed, which meant if the there was only one Erlang SDK or the user never changed the selection, the Code Paths were never copied. To get the Code Paths copied when the Elixir SDK is first created andsetupSdkPaths
interface method is called- All paths are set directly on the Elixir SDK as before
- The default Erlang SDK, which should be the one that was last created, is configured in
SdkAdditionalaData
- The Code paths from the Erlang SDK are copied to the Elixir SDK
- If the the Erlang SDK is from intellij-elixir and does not have
ebin
directories for its Class Paths, then the Class Paths is expanded to Code Paths.
- #851 - The Code Paths from the Internal Erlang SDK were not
being copied from the default Erlang SDK to the Elixir SDK when the default Erlang SDK was set during
mix test
runs, which meant that the Elixir SDK would not upgrade correctly from 6.1.1 to 6.2.0 without the user deleting the Elixir SDK and recreating it. - @KronicDeth
- #795 -
When #754 made
intellij-erlang
a soft-dependency, it broke the debugger's icons that referencedErlangIcons
, but it turns out all the icon constants were aliases toAllIcons.Debugger
constants, so by using theAllIcons.Debugger
icons directly, the dependency onErlangIcons
can be removed without the need to copy the image files intointellij-elixir
. - #796 - When
do ... end
template is inserted, it did not have a previous child whose attributes to use, so it used the default, which left the cursor unindented. To get the cursor indented by default, When theElementType
isDO
, apply thestabChildrenIndent
rules: indent normal and determine whether to indent relative to direct parent using code style setting. - #797 - Include
VirtualFile
path in Beam read errors
- #792 - @KronicDeth
- Since the process of requiring resource files is the same,
org.elixir_lang.ElixirModules
has static methods for copying resources out to a temporary directory and adding the-r <temporary_path>
for one or more resource files to a new or existing ParametersList. These are now shared for the Mix ExUnit and Debugger code paths. - Format class
ElixirXDebugProcess
MixExUnitRunningState
MIxRunningState
- Since the process of requiring resource files is the same,
- #792 - The compiled
.beam
files were removed in 58e7d4a, which was before v5.1.0, but not all users had problems with using the debugger. #739 persisted ( as reported by @erikreedstrom) when 6.0.0 was released; I retried reproducing on a clean VM and I got it. I'm not sure why it worked for some people in prior releases since the.beam
don't exist that were being copied, but now the debugger uses the same system of copying.ex
files and requiring them with-r
instead of copying.beam
and using-pa
to add theebin
directory. Fix was verified local under macOS and in Windows VM that reproduced #739.
- #724 - @KronicDeth
- Code Formatter
do
block lines are indenteddo
blocksend
as the last argument of a no parentheses call unindents to the start of the call- If one clause of a multi-clause anonymous function wraps, all clauses wrap.
- Indent after
else
- Indent map and struct keys
- All keys wrap if any key wraps
- No spaces around...
.
- Spaces around...
and
in
or
when
- Configure spaces around...
=
<-
and\\
!=
,==
,=~
,!==
, and===
<
,<=
,>=
, and>
+
and-
*
and/
- Unary
+
,-
,!
,^
, and~~~
->
::
|
||
and|||
&&
and&&&
<~
,|>
,~>
,<<<
,<<~
,<|>
,<~>
,>>>
, and~>>
..
^^^
++
,--
,..
,<>
=>
- Configure spaces before...
,
- No space after...
@
- Spaces after...
not
fn
after
catch
rescue
key:
- Configure space after...
&
,
- Configure spaces within...
{ }
<< >>
[ ]
( )
- No space around
/
in&NAME/ARITY
and&QUALIFIER.NAME/ARITY
when
wraps when its right operand wraps, so that guards start withwhen
on a newline when they are too long.- Align
|>
at start of indented line for pipelines - Align
end
with start of call instead of start of line fordo
blocks in pipelines - Indent list elements when wrapped
- Indent tuple elements when wrapped
- Align type definition to right of
::
- Align guard to right of
when
when guards span multiple lines - Align two operator (
++
,--
,..
,<>
) operands, so that<>
binaries are multiple lines align their starts instead of using continuation indent and being indented relative to first operand. - Align pipe
|
operands, so that alternates in types and specs are aligned instead of continuation indented relative to the first operand. - Comments in
spec
(that is above operands to|
align with the operands - Remove newlines from pipelines, so that all pipelines start with an initial value or call and each
|>
is the start of a successive line. - Key exclusivity: if an association operation or keyword key is already on a line, the container value automatically has it's elements wrapped if there is nested associations or keyword pairs, so that two levels of keys are not on the same line.
- Indent bit string (
<< >>
) elements when wrapped
- Code Formatter
- #732 - @KronicDeth
- Update IntelliJ IDEA version to latest in each MINOR version:
2017.1.1
->2017.1.5
2016.3.5
->2016.3.7
- Update Elixir version
1.4.2
->1.4.5
- Update IntelliJ IDEA version to latest in each MINOR version:
- #738 - @KronicDeth
TeamCityExUnitFormatting.put_event
- Always match on
%__MODULE__{}
for state in clauses to prevent state update errors - Match on
:suite_finished
and:suite_started
event, so that only event added to the interface will be unknown andIO.warn
can be used tell anyone spotting the new event to file an issue.
- #741 - Instead of pinning position (
1
for lines or3
for heredocs),pin
*_PROMOTER
token, so it's more obvious the pattern is that the promoter is pinned. - #747 - Regression test for #659 - @KronicDeth
- #629 - Search for Elixir SDKs in
/nix/store
on Mac if homebrew path does not exist - @KronicDeth - #749 - Regression test for #672 - @KronicDeth
- #750 - Regression test for #674 - @KronicDeth
- #751 - @KronicDeth
- Regression test for #683
- Store expected decompilation in files to shrink
DecompilerTest
length
- #754 - Update to
org.jetbrains.intellij
0.2.15
- #755 - Regression test for #687 - @KronicDeth
- #756 - Regression test for #692 - @KronicDeth
- #758 - Regression test for #694 - @KronicDeth
- #759 - Regression test for #699 - @KronicDeth
- #760 - Use
Elixir.LDAPEx.ELDAPv3.beam
as regression test for #703 - @KronicDeth - #764 - Show
quote
s in list in macros in Structure View - #768 - References will be cached until the file containing
the PSI element changes, so that results from
Callable#multiResolve
,CallDefinitionClause#multiResolve
,Module#multiResolve
, andModuleAttribute#multiResolve
, which are all the extant references, can be cached and invalidated correctly. - @KronicDeth - #769 - Use
ParameterLists
to support Path Variables in program parameters. - @KronicDeth - #774 - @KronicDeth
- Adjust SDK home path when
bin
,lib,
orsrc
to parent directory. - Format
ElixirSdkType
.
- Adjust SDK home path when
- #775 - Regression test for #354 - @KronicDeth
- #777 - @KronicDeth
- Include specific message for each decompilation error reason.
- Regression test for #772
AtU8
UTF8 atoms chunk decompilation to support OTP 20 compiled.beam
files.- Regression test for Elixir 1.5.0 announcement to ensure that unicode from
AtU8
chunk can be read from beam file produced by following Elixir code::こんにちは世界 saudação = "Bom dia!" saudação end end ```
- #771 - Guard against read/write mismatch in stubs
- #782 - Always install
IdeaVIM
in the gradle sandbox because it got annoying having to reinstall it when the sandbox reset. - @KronicDeth - #786 - @KronicDeth
- Merge both homebrew and nix store on Mac
- Merge default and nix store on Linux
- #789 - Format
MixRunningStateUtil
and fix warnings.
- #726 - @KronicDeth
- Treat
::
the same as:
inkey:
afterwhen
in type specifications as it's a realistic error. - Change
.
to#
when referring to constants in javadocs - Remove
@param
without descriptions - Remove explicit type from generics when the type can be inferred.
- Check if
atNonNumericOperation
reference is non-null
before resolving - Swap empty branches to inverted conditions for final
else
. - Check if
Type
leftOperand
isnull
before using it. - Remove empty
highlightTypesAndTypeParameterUsages(When...)
- Remove unused
highlightTypesAndSpecificationTypeParameterDeclarations
- Flip
equals
to eliminate need fornull
check - Remove redundant type arguments (
<...>
) - Change
Collections.EMPTY_SET
toCollections.emptySet()
to prevent uncheck cast warnings. - Inline constant argument for errors.
- Check if
when
rightOperand
is non-null
before scanning it for parameter names. - Fix typos
- Treat
- #732 - @KronicDeth
- When compilation error is detected during
mix test
, it will be turned into a test failure.- Compilation errors are any stacktraces to
stderr
that end in(elixir) lib/kernel/parallel_require.ex:
. - The test failure for the compilation will be attributed to either
mix test
or the inferred module name of test file.- If the first line of the stacktrace contains
test/.*_test.exs:\d+: \(module\)
- The file and line from that line will be used as the location of failure
- The
test/
and.exs
will be stripped from the file and it will be camelized to produce the derived test module name of the failure
- Otherwise,
mix test
is used
- If the first line of the stacktrace contains
- Compilation errors are any stacktraces to
- Rearrange doc test names to emphasize the function being tested:
"test doc at MODULE.FUNCTION/ARITY (COUNT)"
becomes"MODULE.FUNCTION/ARITY doc (COUNT)"
- If
MODULE
is the same as the test case without theTest
suffix, thenMODULE.
is stripped too and the test name becomes onlyFUNCTION/ARITY doc (COUNT)
- If
- Fix parallel test cases nesting under each other due to asynchronous reporting from
formatter.
##teamCity
testSuiteStarted
messages automatically nest, so switched to usingnodeId
andparentNodeId
system, so that nesting is explicit. This will allow multiple parallel tests to show up in GUI too. Elixir.
prefix is stripped from test case names.
- When compilation error is detected during
- #728 - Handle Elixir versions with non-numeric parts
- #734 - Use a separate formatter, one GenEvent-based and one GenServer-based, depending on whether the SDK is >= 1.4.0 as that's when GenEvent was deprecated and GenServer was preferred. - @KronicDeth
- #736 - @KronicDeth
- Merge
Callable
andKernel
annotators - Use
PsiElementVisitor
instead ofPsiRecursiveElementVisitor
, so that macros indefmodule
block don't get double annotated. - Instead of erasing and then applying multiple
TextAttributeKey
, erase as before, but then merge theTextAttributeKey
'sTextAttributes
and apply as singlesetEnforcedTextAttributes
. For some reason, this fixes the inconsistency of whetherPREDEFINED_CALL
orMACRO_CALL
is applied first. - In case of multiple
resolved
s, make those that needPREDEFINED_CALL
to win.
- Merge
- #738 - @KronicDeth
TeamCityExUnitFormatting.new
should return struct only because none of the formatters expects an:ok
tuple.- Fix order of
TeamCityExUnitFormatting.put_Event
catchall parameters. FileReferenceFilter
- Add
.exs
to pattern for stacktrace linking. - Highlight only stacktrace path and line umber instead of entire line
- Better path match in stacktraces
- Only accept VirtualFile if it has a suffix matching the stacktrace's path instead of accepting the first index file with a matching basename.
- Allow multiple VirtualFiles to be linked if it turns out there is a true file path collision between two OTP apps in the Project or Libraries.
- Format and fix warnings
- Add
- #741 - @KronicDeth
- Pin promoter for all quotes, including the previously missing
stringLine
andcharListLine
. - Only insert closing quote if previous token was an opening quote.
- Pin promoter for all quotes, including the previously missing
- #742 - @KronicDeth
- On
unquote
, include argument in name of call definition clause - Look outside tuple containing
quote
forenclosingMacroCall
, which allows going to Phoenix.Template.compile's quote's defp - Treat
Module.create
as `Modular Or
interface to unifyMatched
andUnmatched
Or
s.- Look at both side of
Or
operation for nested child calls for Structure view. - Make
unquote(ARG1)
name forgetName
and indexing
- On
- #744 - @KronicDeth
ElementDescription
forElixirVariable
- Mark
UnqualifiedParenthesesCall
s ascall
instead ofvariable
.
- #745 - @KronicDeth
mix local.hex --force
beforemix deps.get
during project import to prevent prompt for hex update when local hex is earlier than that required bymix
.- Fix warnings and format
MixProjectRootStep
- #746 - @KronicDeth
- Mark
ElixirDecimalFloat
as error in types.- If in a Range: "Floats aren't allowed in Ranges"
- Otherwise: "Float literals are not allowed in types. Use float() instead".
- Mark
- #747 - @KronicDeth
- Ignore
jps-*/out
directories. - Look at parent for
isParameter
forAtUnqualifiedBracketOperation
. - Treat
AtUnqualifiedBracketOperation
the same asUnqualifiedBracketOperation
forisVariable
.
- Ignore
- #748 - Include path in error messages from
buildFileStub
- #749 - Erlang allows
do
as a function name, but it's a keyword in Elixir, so wrap it asunquote(:do)
. TheSpecialForm
decompiler already did thisunquote(...)
wrapping, butdo
is a keyword and not a special form, so rename the decompiler toUnquoted
. - #750 - @KronicDeth
- Move {3} inside
|
forSIGIL
PROMOTER
andTERMINATOR
:
SIGIL_HEREDOC_PROMOTER = ({SIGIL_DOUBLE_QUOTES_PROMOTER}|> {SIGIL_SINGLE_QUOTES_PROMOTER}){3} SIGIL_HEREDOC_TERMINATOR = ({SIGIL_DOUBLE_QUOTES_TERMINATOR}|> {SIGIL_SINGLE_QUOTES_TERMINATOR}){3}
> -- https://github.com/KronicDeth/intellij-elixir/blob/v5.1.0/src/org/elixir_lang/Elixir.flex?utf8=%E2%9C%93#L524-L525 The `|` is inside group that is then `{3}`'d, so it allows either `'` or `"` in groups of three. This is only applies to the sigils. It's correct for normal string and charlist heredocs: > ```
CHAR_LIST_HEREDOC_PROMOTER = {CHAR_LIST_PROMOTER}{3} CHAR_LIST_HEREDOC_TERMINATOR = {CHAR_LIST_TERMINATOR}{3}
STRING_HEREDOC_PROMOTER = {STRING_PROMOTER}{3} STRING_HEREDOC_TERMINATOR = {STRING_TERMINATOR}{3}
QUOTE_HEREDOC_PROMOTER = {CHAR_LIST_HEREDOC_PROMOTER} | {STRING_HEREDOC_PROMOTER} QUOTE_HEREDOC_TERMINATOR = {CHAR_LIST_HEREDOC_TERMINATOR} | {STRING_HEREDOC_TERMINATOR}
> -- https://github.com/KronicDeth/intellij-elixir/blob/v5.1.0/src/org/elixir_lang/Elixir.flex?utf8=%E2%9C%93#L441-L448
- Move {3} inside
- #751 - Unquote function names that start with an uppercase codepoint, so that they aren't parsed as Aliases. These function names occur in the CORBA modules in OTP.
- #754 - @KronicDeth
- Using intellij.plugins will prevent packaging intellij-erlang as a runtime dependency, which leads to duplicate templates.
- Don't use the
JPS
type
forjps-*
projects because their deps become incompatible with other projects.
- #755 - Add missing
break
s tocase
statement inprocessDeclarations(Match, ...)
that caused the logic of whether to check left, right, or both operand based on the whether the treeWalkUp came from always fell through to theRIGHT
case, so it was only, always checking the right operand of the match and never the left operand. - @KronicDeth - #756 - Skip
processDeclarationsInPreviousSibling
whenlastParent
isElixirFile
- @KronicDeth - #757 - Remove background color from sigils because it stands out really badly in the Default theme where it's black on white and while it doesn't in Darcula, it's unnecessary there because it's so close to the editor background color in Darcula. - @KronicDeth
- #758 - Treat
Alias
as miscapitalized type parameter. @KronicDeth - #759 - Ignore call definition clauses after
when
in type specifications as it is a common occurrence when typing a specification above a pre-existing call definition clause. - #761 - Use
THashSet
instead of the more specificSmartHashSet
becauseTHashSet
allowsnull
keys, which are expected for thecanonicalNameSet
. - #764 - @KronicDeth
- Look above
List
for enclosing modular macro. - Look above
ElixirNoParenthesesManyStrictNoParenthesesExpression
for enclosing modular macro.
- Look above
- #765 - Remove background color from Sigil Color Scheme Design to match changes in #757.
- #769 - @KronicDeth
- Check if program parameters is blank before splitting into mix args.
- Use
ParametersList
to properly parse quote program parameters.
- #773 - @KronicDeth
- Move
Quoter
intotest
directory, so it and its dependency onJUnit
is only used for test compilation and runtime and not the shipped runtime. - Fix
Quoter
warnings and format.
- Move
- #774 - @KronicDeth
- #775 - Always check if resolution result is right operand of match. - @KronicDeth
- #776 -
CallDefinitionClause
InsertHandler
always assumed there was a character after the insert location, but when inserting at the very end of the file, there isn't, which caused anIndexOutOfBoundsException
. Only check if the following character is not a space,(
, or[
when the document is longer than the tail offset to prevent theIndexOutOfBoundsException
. If the insertion is at the end of the file, then the()
will always be inserted. - @KronicDeth - #777 -
Decompilated
->Decompilation
- #771 - The
lower-level
Data(Output|IntputStream
(write|read)Int
don't work correctly with sizes, so use the JetBrains(write|read)VarInt
ones instead. - @KronicDeth - #782 - Delegate
ChildAttributes
to previous child when available:Block.getChildAttributes
is used when Enter is pressed to determine the indentation and alignment. Using the default implementation, newlines in stabs look overly indented, but there is a constant,DELEGATE_TO_PREV_CHILD
that can be used to just use the last child's indent as long as there is one, which appears to work well for stabs (do block bodies, etc). - @KronicDeth - #783 - @KronicDeth
- Increase suspect
nameSetSize
from4
to10
because aPoison.Encoder
has animpl
module for 4 types, and so has 4 canonical names. - Only read-ahead if guard length is non-zero; otherwise, only warn the nameSetSize may be suspect and don't read-ahead as this can mess up OK namesets.
- Increase suspect
- #784 - @KronicDeth
- Override
Kernel.SpecialFroms
arity intervalsalias
overridden from2
to1-2
to support without:as
option.import
overridden from2
to1-2
to support without:except
or:only
options.quote
overridden from2
to1-2
to support block without options.require
overridden from2
to1-2
to support without:as
option.super
overridden from1
to0-
to support calling any super method.
- Override
- #789 -
elixir.bat
in at least Elixir 1.5.1, will not properly parse a mix path with spaces in it on Windows even when the path has outer quotes (see elixir-lang/elixir#6455). It is not possible to use inner quotes, as you can do in cmd.exe, using the JetBrains and Java libraries hat auto-matically quote, so instead bypass the bad quoting inelixir.bat
by doing whatelixir.bat
does: callerl.exe
with all the SDK ebin paths added with-pa
, then-noshell -s elixir start_cli
to run Elixir and-extra
to run requires (-r
), mix and its tasks. - @KronicDeth
- #732 - @KronicDeth
- Drop
14.1.X
support because it does not have support for nodeId test output, so it's not possible to handle the ExUnit test output in a safe manner while still allowing concurrent output for asynchronous tests.
- Drop
- #669 -
Replace
assert scope.isEquivalentTo(lastParent.getParent())
with anif
and log whatlastParent
was when condition isfalse
, so root cause can be traced. - @KronicDeth
- #574 - @KronicDeth
- Decompile
.beam
files- Structure view for decompiled
.beam
files - Index modules, functions, and macros exported by
.beam
files - Go To Symbol for Modules defined in
.beam
files (both SDK and deps)- Erlang using atoms (like
:idna
) - Elixir using Alias (like
Enum
)
- Erlang using atoms (like
- Completion for Modules defined in
.beam
files (both SDK and deps)- Elixir using Alias (like
Enum
)
- Elixir using Alias (like
- Completion for functions and macros exported by
.beam
files - Syntax highlighting
- Structure view for decompiled
- Decompile
- #579 - Regression test for #575 - @KronicDeth
- #583 - @KronicDeth
- Macros appear before functions in decompiled
.beam
files- Header for macro and function sections
- Macros appear before functions in decompiled
- #585 - @KronicDeth
- Update
ELIXIR_VERSION
for1.2.*
from1.2.3
to1.2.6
- Add
ELIXIR_VERSION
1.3.4
- Add
ELIXIR_VERSION
1.4.0
- Update
IDEA
for2016.*
to2016.3.1
- Show
OtpErlangBitStr
(and thereforeOtpErlangBinary
contents when tests fail - Quote binaries as
to_charlist
instead ofto_char_list
for Elixir>= 1.3
. Depends on Elixir version of project SDK. - Use
elixir
instead ofjava
VM, so now Erlang and Elixir don't need to be built on travis-ci, butant
and thejdk
need to be installed, but unlike Erlang and Elixir, there are tarballs for that, so this way is faster than the old method without depending on travis-ci cache.
- Update
- #609 - @KronicDeth
- If
multiResolve
causes aStackOverflow
fororg.elixir_lang.annotator.Callable.visitCall
, thencatch
it and useerrorreport
logger to log the element. - Include file path in
errorreport
excerpt - Log element for
StackOverflow
related toimport
s - Regression test for #605.
- Log
LookupElement#getObject
whenLookupElement#getPsiElement
isnull
to track down how it wasnull
in #563.
- If
- #614 - Regression test for #559 - @KronicDeth
- #504 - @JakeBecker
- Switch to Gradle for builds.
./gradlew runIde
(or therunIde (VERSION)
Run Configurations) will run IDEA in a sandbox with the development version of the plugin../gradlew test
(or thetest (VERSION)
Run Configurations) will run the main plugin and jps-builder tests.- The plugin can now be published with
./gradlew publishPlugin
, BUT you'll need to fill inpublish*
properties ingradle.properties
. This will eventually allow for automated "nightlies" from successful Travis-CI builds onmaster
.
- Switch to Gradle for builds.
- #638 - The
Callable
annotator is meant for variables, parameters, and macro and function calls and declarations. TheModuleAttribute
annotator handles module attribute declaration and usage, so we can save reference resolution time by skipping module attributes inCallable
. - #640 - Allow module attribute folding to be configured.
- #662 - @KronicDeth
- Allow call definition heads to resolves to themselves for consistency with Aliases of
defmodule
. - Generalize
Callable.callDefinitionClauseDefiner(Call)
: in addition to the currentCallDefinitionClause
, make it work forImplementation
,Module
, andProtocol
.
- Allow call definition heads to resolves to themselves for consistency with Aliases of
- #574 - Fix copy-paste errors
in
MatchOperatorInsteadOfTypeOperator
- @KronicDeth - #579 - @KronicDeth
- Subtract 1 from arity in
.beam
file when decompiling todefmacro
calls because the Erlang function for Elixir macros has one addition argument: the first argument is theCaller
of the macro. - If the name of the decompiled macro/function is an infix operator, then decompile the head as a binary operation instead of a normal prefix name as infix operators aren't valid prefix names and led to parsing errors, which was the root cause of #575.
- Fix IntelliJ warnings in
BeamFileImpl
- Remove unused
VirtualFile
argument toBeamFileImpl#buildFileStub
.
- Subtract 1 from arity in
- #583 - @KronicDeth
- Add
++
,=~
, andin
toINFIX_OPERATOR_SET
. - Only render infix operators if arity is
2
. - Prefix operator decompilation:
+
and-
are both binary and unary operators. When a unary operator they need to be wrapped in parentheses, so that the call definition clause is parsed correctly.
- Add
- #585 - @KronicDeth
- Ignore
JFLex
jar - Don't check for
elixir-lang/elixr
files remove in1.3
- Allow
nil
as a keyword key.nil
was being lexed as a potential keyword key, but NIL was missing from the token list in the keywordKey grammar rule.
- Ignore
- #599 - Some SpecialForms don't work as literals as they
would be interpreted as metaprogramming, so their name needs to be wrapped as an atom to
unquote
. - #600 - @KronicDeth
- Check children of
MultipleAliases
for variable declarations. - Treat any variable declared in a
MultipleAliases
as invalid.
- Check children of
- #609 - @KronicDeth
- Skip
import Kernel
inkernel.ex
to prevent stack overflow due to recursiveimport
- Strip all outer parentheses for left type operand, so that
(+value)
can be see as+
operator type spec. - Use advice from
IndexNotReadyException
documentation and checkDumbService.isDumb(Project)
before callingStubIndex.getElements
inModule
andmodule.MultiResolve.indexNameElements
. - Don't
assert
thatLookupElement#getPsiElement
is notnull
inCallDefinitionCluase.renderElement
- Update to
ant
1.10.1
because1.10.0
is no longer hosted.
- Skip
- #612 - Yeah, it sounds weird, but an
ElixirVariable
isn't necessarily a variable if it doesn't occur in a declaration context. It could just be a no-parentheses function call in the wrong spot, so check the parentPsiElement
to determine ifElixirVariable
is a variable. - #614 - Highlight parameterized type head (
maybe(t)
in@type maybe(t)
) the same as a full type definition (maybe(t)
in@type maybe(t) :: t | nil
) - #616 - Only show Mix ExUnit Run in context when the module, or when the module is not a available, the project SDK is Elixir. If there is no SDK configured, show "Mix ExUnit Run" in the menu. - @KronicDeth
- #617 - Mark
do:
as atom in demo text - #627 - Annotations can only be applied to the single, active
file, which belongs to the
referrer
Callable
. Theresolved
may be outside the file if it is a cross-file function or macro usage, in which case it'sTextRange
should not be highlighted because it is referring to offsets in a different file. - @KronicDeth - #634 - @KronicDeth
Variable
scope forQualifiedMultipleAliases
, which occurs when qualified call occurs over a line with assignment to a tuple, such asQualifier.\n{:ok, value} = call()
- Remove call definition clauses (function or macro) completion for bare words as it had a detrimental impact on
typing feedback (the editor still took input, but it wasn't rendered until the completion returned OR
ESC
was hit to cancel the completion, which became excessive once the index of call definition clauses was expanded by the decompilation of the Elixir standard library.beam
s, so disable it. If bare-words completion is restored. It will either (1) need to not use theReference#getVariants()
API because it generates too many objects that need to be thrown away or (2) need to only complete call definition clauses that are provably in-scope from imports or other macros.
- #636 - @KronicDeth
- Both intellij-erlang and intellij-community are Apache 2.0 licensed and its the default license for Elixir projects,
so seems like a good choice for
LICENSE.md
- Add
CODE_OF_CONDUCT.md
- Both intellij-erlang and intellij-community are Apache 2.0 licensed and its the default license for Elixir projects,
so seems like a good choice for
- #638 - @KronicDeth
- The run configurations I put together in #504 didn't allow for the debugger to work properly: neither pause nor breakpoints had any effect, so regenerate them from the Gradle pane.
- Check parent of
when
operation in case it's a guarded function head inorg.elixir_lang.annonator.Parameter.putParameterized(Parameter, PsiElement)
- Instead of highlighting call definition clauses when they are referred to, which only works if it is in the same
file, highlight all function and macro declarations when the
def*
call is encountered. - Only increment arity for right pipe operand instead of all operands, so that left operands resolve to correct arity or as variable/parameter.
- #662 - @KronicDeth
- Override
ModuleImpl#getProject()
to preventStackOverflowError
. Without overriding#getProject()
,IdentifierHighlighterPass
gets stuck in a loop betweengetManager
andgetProject
on the target ( theModuleImpl
) when clicking on the space betweendef
s ordefmacro
s in the decompiled.beam
files. - Fix source formatting
- Skip looking for variables unless 0-arity AND no arguments
- Highlight unresolved macros as macro calls. Anything with a do keyword or a do block will be treated like a macro call even if it can't be resolved. No resolved is either no resolve results or an empty list
- Implicit imports at top of file in addition to top of Module.
- Override
- #663 - @KronicDeth
CallDefinitionClause
completion provider is unexpectedly invoked both when.
is typed, but continues to be invoked after a letter is typed after the.
; however, once the letter is typed, the letter becomes the default prefix instead, so the prefix should only be reset to""
when it ends in.
.- Disable
Callable#getVariants
unlessUnqualified
to prevents local functions and macros being shown as completions for qualified names.
- #651 - @StabbyMcDuck
- Among many other tweaks, the String color is now green, so that Atom and String are no longer close to one another,
which was the original issue in #569
Alias
now hasunderscored
effectBrackets
are now greenish instead of brownishCallbacks
are now a lighter blue and hasunderscored
effectCharList
is little lighterCharToken
is dark yellow now instead of dark purpleDot
is now purple instead of dark redExpression Substitution Mark
is a little lighterInterpolation
is now lime greenKernel Macros
are a burnt orangeMap
is now a dark blue instead of a dark yellowOperation Sign
is a little lighterParameters
are a little darkerParentheses
are redderPredefined
is orange instead of blueSpecification
is now red instead of purpleStruct
is now purple instead of yellowType
is now green instead of dark purpleVariable
is more tealish
- Among many other tweaks, the String color is now green, so that Atom and String are no longer close to one another,
which was the original issue in #569
- #650 - @StabbyMcDuck
- Fix indentation to fix sub-lists in
CONTRIBUTING.md
- Fix pluralization in
CONTRIBUTING.md
- Fix indentation to fix sub-lists in
- #664 - @KronicDeth
- Check if resolve results are
null
forFor.resolveResultList
- Check if
Protocol.resolveResultList
isnull
- Check if resolve results are
- #665 - Check
match
Call
is anUnqualifiedNoArgumentCall
, in addition to being 0 resolved final arity, before checking if the name matches.
- #585 - Move
^^^
to its own three-operator precedence level to match1.2
. This does mean the parsing will be wrong for Elixir1.1
, but is simpler than maintaining two grammars for those that are still using Elixir1.1
- @KronicDeth - #504 - The
ant
build files have been removed. To build the build plugin (for Install From Disk), use the./gradlew buildPlugin
. - @JakeBecker - #640 - Change to module attribute folding to off by default.
- #523 - Use the
CommonProgramParametersPanel
to get the working directory and environment variables the same way the JUnit form does. Replace the custom "Command" input with the "Program arguments" input built into theCommonProgramParametersPanel
.CommonProgramParametersPanel
expects to store the "Program Arguments" in a "ProgramParameters" field, so old run configurations will lose their "Command" option value and it will be migrated to the new "ProgramParameters". - @KronicDeth - #482 - @JakeBecker
, @KronicDeth
- Create / Run Mix ExUnit Run Configurations
- Run Configuration from Directory
- Run Configuration from File
- Run Configuration from LIne
- Run Configurations support Common Program Parameters
- Program Arguments
- Working directory
- Environment variables
- Create / Run Mix ExUnit Run Configurations
- #531 - @KronicDeth
enclosingMacroCall
returns enclosing macro call when parent isElixirDoBlock
, so thatend
element goes to the macro call.Navigate > Test
will go to the Module that has the same canonical name as the currentdefimpl
,defmodule
,defprotocol
, orquote
with aTest
suffix addedNavigate > Test Subject
will go to thedefimpl
,defmodule
,defprotocol
, orquote
that has the same canonical name as the current Module with theTest
suffix removed.
- #533 - Regression test for #500
- #545 - Regression test for #517
- #548 - Regression test for #521
- #549 - @KronicDeth
- Regression test for #525
- If
:
is used instead of::
for a type specification, mark it as an error with a Quick Fix to convert:
to::
. - Highlight
=
operands the same as::
operands in type specifications. - If
=
is used instead of::
in a type specification, mark it as an error with a Quick Fix to convert=
to::
.
- #523 - Fix typo:
myRunInModuleChekcBox
=>myRunInModuleCheckBox
- @KronicDeth - #532 - Don't log error when name length exceeds presentable text length because it appears to be common for normal users and not a development environment artifact.
- #533 - Check parent of
ElixirMultipleAliases
forisVariable
becauseElixirMultipleAliases
can be hit inisVariable
whenMyAlias.
is added on a line above a pre-existing tuple, such as when typing a new qualified call. - @KronicDeth - #534 - Add space between variable and match in lookup element presentation - @KronicDeth
- #535 - Check
VirtualFile
is not null before creating attachment becausePsiFile
can lack aVirtualFile
if thePsiFile
only exists in memory. - #537 - Convert
CallDefinitionClause(Call)
toCallDefinitionClause.fromCall(Call)
, so thatnull
can be returned whenCallDefinitionClause.enclosingModular(Call)
returnsnull
. - @KronicDeth - #539 - @KronicDeth
- Use
functionName
instead ofgetName
when multiresolving unqualified functions becausegetName
will return the Alias when called ondefmodule
. maybeQualifiedCallToModular
returnednull
BOTH (1) if the call was unqualified OR (2) if the call was qualified, but its modular could not be resolved, so qualified calls to.beam
-only modules, likeFile.read!
returnednull
becauseFile
could not be resolved to a modular. RemovemaybeqQualifiedToModular
and callqualifiedToModular
whenmyElement
is qualified. If the modular isnull
, then return an emptyResolveResult[]
instead of looking for unqualified matches.- Pass
maxScope
toModule
reference.maxScope
is generally the containing file for the element, but when usingModule
to resolveimport
s, it is theimport
call's parent element, so that the resolve doesn't ricochet between thedefmodule
and its child, theimport
call untilStackOverflowError
.
- Use
- #545 - A variable cannot be declared in update arguments, so
return
LocalSearchScope.EMPTY
, the same as interpolation. - @KronicDeth - #548 -
ElixirSystemUtil.getProcessOutput
already allowed for an empty, invalidProcessOutput
when theworkDir
wasn't a directory, so allow it to also benull
and return the emptyProcessOutput
. - @KronicDeth - #549 - @KronicDeth
- If a single keyword pair is used for a type spec, treat
:
as a type for::
- Limit variable use scope for variables "declared" in module attributes to the module attribute because the variable can't be declared there and it is really a variable usage without declaration.
- If a single keyword pair is used for a type spec, treat
- #454 - Regression test for #453 - @KronicDeth
- #455 - Regression test for #446 - @KronicDeth
- #464 - Show element class in all error reports
- #465 - Regression test for #456 - @KronicDeth
- #466 - Regression test for #458 - @KronicDeth
- #467 - Regression tests for #443 - @KronicDeth
- #474 - Regression test for #462 - @KronicDeth
- #476 - Regression test for #468 - @KronicDeth
- #477 - @KronicDeth
- Regression test for #469
- Highlight Strings and String Heredocs as errors in types.
- #479 - Regression tests for #470 - @KronicDeth
- #483 - @KronicDeth
- Add
Qualified#qualifier
by extracting it fromCallDefinitionClause
CompletionProvider
. - Add
Modular
class with#forEachCallDefinitionClauseNameIdentifier
to enumerate all the identifiers that could be linked to in a modular. - Add
ElixirPsiImplUtil#maybeQualifiedCallToModular
by extractingresolveFully
fromCallDefinitionClause
CompletionProvider
- Add regression tests for #463.
- Add
- #484 - Regression test for #471 - @KronicDeth
- #485 - Regression test for #472 - @KronicDeth
- #486 - @KronicDeth
- Extract
Arrow
interface for*ArrowOperation
s. - Regression tests for #480
- Extract
- #454 - Return
emptySet
whenlookupElementByPsiElement
isnull
. - @KronicDeth - #455 - @KronicDeth
-
Don't do a naked
assert
that there are 2 children because this can fail during error recovery on the operand, instead use theprefix.Normalized.operand()
throughprefix.operand()
.WARNING: This changes the
@NotNull
array so that its sole element changes from@NotNull
to@Nullable
. It may trigger new bugs.
-
- #461 - Use shipped
GeneratedParserUtilBase.DUMMY_BLOCK
because theDUMMY_BLOCK
MUST match theGeneratedParserUtilBase
to detect dummy blocks inserted for error handling. - @KronicDeth - #465 - Skip over
ElixirNoParenthesesStrict
forisVariable
- @KronicDeth - #466 - Allow newlines before
do
indoBlock
- #467 - Don't match
do
orfn
toend
when used as a keyword key. - @KronicDeth - #474 - @KronicDeth
- Check if
iterator.atEnd()
before callingiterator.getTokenType()
to avoidIndexOutOfBounds
exception. - Don't add current call definition clause being written to completion
- Check if
- #476 -
When#leftOperand
will returnnull
(because it's normalized) if there are left-hand error elements, but when stripping guards we want best-effort to match human expectations, so don't use normalizednull
, but use left, non-error element if it is unique. - #477 - Highlight types in
QualifiedNoParenthesesCall
- #478 - Still not obvious why
name
for aCallDefinitionClause
lookup renderer can be longer thanpresentableText
, so still log an error, but withLogger.error
, so we getname
,presentableText
, and the originalelement
. - #479 - @KronicDeth
- Skip
Arguments
elements inpreviousParentExpresion
to eliminate an unnecessary level of processing declarations since calls will enter their arguments. - Only put new
ENTRANCE
inResolveState
invariable.MultiResolve.resolveResultList
, so that caller can override the default value. - Set
ENTRANCE
tomatchAncestor
instead of previous expression to eliminate the looping that occurred when a variable was unbound (or a function) because the check forwith
(andfor
) was expecting theENTRANCE
to be the previous child expression instead of thewith
clause as a whole (or theArguments
element as had been the case before 6fcc19b).
- Skip
- #483 - @KronicDeth
- Resolves functions qualified by Aliases that are either direct Module references or one-step aliases.
- Remove
Call#resolvedFunctionName
becauseimport
can't rename functions.
- #484 - Don't type-highlight
BracketOperation
s as they occur when putting maps or structs in front of lists. - @KronicDeth - #485 - Treat
Enum.each
the same asEnum.map
arounddef
- #486 - Increase
resolvedFinalArity
by1
for piping. - #498 - @KronicDeth
- Go To Declaration resolves through
import
- for
import MyModule
- the
import
statement - the call definition clause in the imported Module.
- the
- for
import MyModule, only: [name: arity]
- the
import
statement - the call definition clause in the imported Module.
- the
- for
import MyModule, except: [name: arity]
if reference is notname/arity
.- the
import
statement - the call definition clause in the imported Module.
- the
- for
- Go To Declaration resolves through
- #452 - @KronicDeth
- Go To Declaration for functions and macros (only those defined in parseable-Elixir source. References to Erlang
functions or only those available in
.beam
file, such as the standard library will not resolve.) - Completion for functions and macros (only those defined in parseable-Elixir source. Erlang functions and Elixir
function only in compiled
.beam
file, such as the standard library will not complete.)- Completion uses the same presentation as Structure View, so the you can tell whether the name is a function/macro, whether it is public/private, and the Module where it is defined.
- Completed functions/macro insert
()
after the name in preparation for Elixir 1.4 where it is an error to have bare function calls. It also makes it more obvious that you inserted a function and not a variable. - Completion works for all functions when a bare identifier is used. For a qualified identifier, only functions/macros under than Module are shown.
- Go To Declaration for functions and macros (only those defined in parseable-Elixir source. References to Erlang
functions or only those available in
- #419 - Regression test using
typespec_test.exs
that triggered #413 - #425 - Regression test that checks the correct
import
is used forGeneratedParserUtilBase
inElixirParser
- @KronicDeth - #432 - @KronicDeth
- Completion of multiple aliases inside curly braces
- Override
ElixirMultipleAliases#processDeclarations
, so thattreeWalkUp
can stop atElixirMultipleAliases
when determining how to do Alias completion. If a multiple alias is encountered, then de-prefixed names should be returned.
- Override
- Completion of multiple aliases inside curly braces
- #434 - Regression test for #429 - @KronicDeth
- #435 - Regression test for #422 - @KronicDeth
- #439 - Regression test for #438 - @KronicDeth
- #440 - Regression test for #431 - @KronicDeth
- #441 - Regression test for #436 - @KronicDeth
- #419 - @KronicDeth
- Return empty
Set
instead ofnull
fromcanonicalNameSet
- Highlight types in
ElixirMapUpdateArguments
even though they are an invalid typespec example from elixir-lang/elixir tests
- Return empty
- #424 - Check if
rightOperand
isnull
when highlighting types forType
, which can occur when typing:
for an atom after the::
for aType
- #425 - Use
GeneratedParserUtilBase
synced to GrammarKit version as was done originally in #406 - #426 - Check parent of
BracketArguments
forisParameter
andisVariable
- @KronicDeth - #428 - Instead of asserting that a
QualifiableAlias
has 3 children, which may not be true on error recovery, use theNormalized
static methods that are used elsewhere to handle error recovery around Infix operations as the.
inQualifiableAlias
es is a pseudo-Infix - #432 - Add missing
@Nullable
to@NotNull
change when parser wasn't regenerated whencanonicalNameSet
was changed to@NotNull
in the interface. - #434 - Search above block items and block lists for calls to check use scope - @KronicDeth
- #435 - Check parent
isVariable
forElixirNoParenthesesManyStrictNoParenthesesExpression
- @KronicDeth - #439 - Highlight
@type
without::
- #440
ElixirNoParenthesesManyStrictNoParenthesesExpression
indicates an ambiguous no parentheses nesting, but the highlighting should not error and do a best effort instead. - @KronicDeth
- #441 -
isParameter(Call)
calledisParameter
on its parent if it wasn't a call definition clause, delegation or macro, butisParameter(PsiElement)
immediately callsgetParent()
and does all theinstanceof
tests on the parent. So, instead ofisParameter(Call)
callingisParameter(PsiElement)
on its parent, it should just call it on itself, this way the check forElixirInterpolation
will not be skipped and there's no need to handleElixirInterpolatedString
.
- #387 - Resolve aliased modules to their
alias
call, from the alias call, you can Go To Declaration for the module itself. - @KronicDeth- Code structure
- Module resolution uses the OpenAPI convention of
treeWalkUp
now instead of custom code. - Resolvable names has been extracted to its own class
- Module resolution uses the OpenAPI convention of
- Resolution use cases
Suffix
resolves toalias Prefix.Suffix
Suffix.Nested
resolves toalias Prefix.Suffix
As
resolvesto
alias Prefix.Suffix, as: As`NestedSuffix
resolves toalias __MODULE__.NestedSuffix
- Code structure
- #389 - Completion for module aliases
- @KronicDeth
- From in-file aliases
__MODULE__
- In project modules (using index already used for Go To Declaration)
- @KronicDeth
- #393 - In addition to
StubBased#canonicalName
, there now alsoStubBased#canonicalNames
, for when a call defines multiple canonical names, as is the case fordefimpl <PROTOCOL>, for: [<TYPE>, ...]
. - @KronicDeth - #397 - When a aliased name is added to the module list for
completion, it's unaliased name is searched for in the
AllName
index, if any nested modules are found for the unaliased name, then those nested names are aliased and also shown for completion. - #399 -
resolvableName
allows nested modules under multiple aliases to be completed. - @KronicDeth - #403 - By user request, the folding will be off-by-default
now, but can be re-enabled, like the old behavior by checking the checkbox in Preferences > Editor > General > Code
Folding > Elixir Module directive (
alias
,import
,require
oruse
) groups. - #405 - @KronicDeth
- Resolve
as:
aliased name to bothalias
anddefmodule
- Complete modules nested under
as:
aliased name.
- Resolve
- #409 - @KronicDeth
- Completion and reference tests for aliases:
alias Prefix.Suffix
alias Prefix.Suffix, as: As
alias Prefix.{MultipleAliasA, MultipleAliasB}
- Completion and reference tests for aliases:
- #393 - @KronicDeth
defimpl <PROTOCOL>, for: [<TYPE>, ...]
generates multiple canonical names, which are stored in the stub index.- When retrieved from the
AllName
index, thedefimpl
's Implementation will render as if only thedefimpl <PROTOCOL>, for: <TYPE>
was used for the<TYPE>
matching the lookup name in the Goto Symbol dialog. For example, if you search forTuple
,JSX.Encoder.Tuple
will match fordefimpl JSX.Encoder, for: for: [Tuple, PID, Port, Reference, Function, Any]
.
- When retrieved from the
- #400 - @KronicDeth
- Look outside Enum.map for enclosing macro call because
Ecto
defines the clauses of__schema__(:type, ...)
usingEnum.map
, butenclosingMacroCall
only knews to jump over enclosing macros likefor
, so a special case was added for anonymous function given toEnum.map
. - Fix if-else-ordering bug where
Call
appeared before operations (which are usuallyCall
s) likeMatch
.
- Look outside Enum.map for enclosing macro call because
- #401 - In
@type unquote({name, nil, []}) :: foo
,name
will be highlighted as a type parameter even though it is not strictly the name that will appear as a type parameter. - #405 - @KronicDeth
- Resolve alias nested under aliased modules to both the
alias
anddefmodule
, as resolving to only thealias
loses the nested name, so it wasn't possible to jump to the nested name'sdefmodule
. - Resolve aliased name to both the
alias
and thedefmodule
, so you can skip jumping to thealias
before jumping to thedefmodule
.
- Resolve alias nested under aliased modules to both the
- #406 - @KronicDeth
- The generated
ElixirParser
uses theGeneratedParserUtilBase
fromcom.intellij.lang.parser
, but since that version is a synced copy, it is a snapshot ofGeneratedParserUtilBase
from the version of GrammarKit that was current when the IDE was released. To ensure the generated parser works on all the IDEs, I copyGeneratedParserUtilBase
fromorg.intellij.grammar.parser
intoorg.elixir_lang.grammar.parser
and then use that version inElixirParser
. This ensures neither the IDE's version nor the version in any installed GrammarKit plugin is used.
- The generated
- #409 - @KronicDeth
- Check that index name maps to an actual project element before returning it for completion as the names
from
StubIndex.getInstance.getAllKeys(...)
is a superset of actual keys in the actual project according to Peter Gromov of JetBrains . - Don't index
canonicalName
if it matches the literal name, as the duplicate name leads to duplicate entries in the completion lookup.canonicalNameCollection
was renamed tocanonicalNameSet
(with type changing fromCollection<String>
toSet<String>
to match) to emphasize that the canonical names should be unique, butcanonicalNameSet
itself should still include duplicates of name for those places where only canonical names are used.
- Use
resolvableName
for theunaliasedName
forMultipleAliases
Aliases, so that they complete correctly for nested modules. - Completion for nested modules will no longer complete with string suffixes (i.e.
SSHView
) and only complete nested Aliases (i.e.SSH.Key
).
- Check that index name maps to an actual project element before returning it for completion as the names
from
- #371 - @KronicDeth
BraceMatcher
- Matches the following pairs:
do
toend
fn
toend
"""
to"""
'''
to'''
<<
to>>
<
to>
[
to]
{
to}
(
to)
- Completes the following pairs:
[
with]
{
with}
(
with)
- Matches the following pairs:
QuoteHandler
completes standard quotes (that start with"
or'
)'
with'
"
with"
'''
with'''
"""
with"""
TypedHandler
completes the non-standard quotes and bracesdo
withend
fn
withend
with
>>`<
with>
(for promoters)/
with/
(for promoters)|
with|
(for promoters)
- #372 - Check parent
for
isVariable(ElixirMapUpdateArguments)
- @KronicDeth - #374 - @KronicDeth
- IntelliJ 15.0.4 is no longer available from JetBrains, so if the cache is not available, the builds don't work, so use 15.0.6, which is available in 15.0.4's place as the test version for 15.X.
- IntelliJ 2016.2 is no longer available from JetBrains, so if the cache is not available, the builds don't work, so use 2016.2, which is available in 2016.1's places at the test version for 2016.X.
- #378 -
enclosingMacroCall
could climb out the stab after ado
, but not theelse
in anif
, which is used for defined functions conditionally inPhoenix.Endpoint.server/0
- #380 - A lot of ppl use the doc template after already
typing
@
, but the doc template starts with@
, so it ends up inserting@@doc ...
. The@doc
template is the same code, but since the name starts with@
, it doesn't insert a second@
. Unfortunately, the template search code doesn't prompt when just typing@
, so you end up having to type@doc
before only one template is selected. The@doc
template will show in the lookup as soon as@d
is typed, but you have to select it from the list then before tabbing to accept. - @KronicDeth - #381 - Look at end of
do
instead of start forend
completion to stop ignoring the:
indo:
, whencaret - 3
would land on theo
, now all tests are meant to land on theo
, sodo:
won't complete withend
incorrectly anymore. - @KronicDeth - #382 - Ignore
ElixirVariable
inhighlightTypesAndTypeParameterUsages
- @KronicDeth
- #331 - @KronicDeth
- Allow
do end
blocks to fold todo: ...
- Allow
->
operator and the right operand to fold to-> ...
- Allow
@doc
,@moduledoc
and@typedoc
value to fold to"..."
. - Fold runs of adjacent
alias
,import
,require
, oruse
to be followed to a singlealias
,import
,require
, oruse
followed by...
.
- Allow
- #334 - Function separators
- @KronicDeth
- Show a function separator (Preferences > Editor > General > Appearance > Show method separators) above the group
of
@doc
,@spec
anddef
,defp
,defmacro
, anddefmacrop
(call definition clauses) of the same name and arity range. Arity range will be used if one of the call definition clauses uses default arguments.
- Show a function separator (Preferences > Editor > General > Appearance > Show method separators) above the group
of
- @KronicDeth
- #337 - @KronicDeth
@for
folds to the resolved module name indefimpl
@protocol
folds to the protocol name indefimpl
- #343 - Share code between
mix
andelixir
version parsing. - @KronicDeth - #344 - @KronicDeth
- Allow Unknown modulars in the Structure pane, in addition to Go To Symbol. Their icon is a big ? to indicate their correct usage is unknown.
- #348 - @KronicDeth
- Regenerate
gen
folder using Grammar Kit 1.4.1 and fix some bugs ( including JetBrains/Grammar-Kit#126) manually.
- Regenerate
- #349 - Have both
QualifiedBracketOperation
andUnqualifiedBracketOperation
extendBracketOperation
, so thatBracketOperation
can be used to match both when the qualification does not matter. - @KronicDeth - #364 - @KronicDeth
-
Regenerate parser with GrammarKit 1.4.2
-
ElixirSdkRelease
is nowComparable
, so version checks can be done for tests to restrict them to Elixir 1.2+ for multiple alias support. -
Resolve Multiple Aliases with unqualified Alias in tuples.
-
canonicalName
borrows from the idea ofPsiReference#canonicalText
: an element can have both a Name ( fromgetName
), which is the literal name in the code, which can be renamed, and a Canonical Name, which is the name to refer to the element without need for imports or aliases. For this change,defimpl
,defmodule
, anddefprotocol
will show their full module Alias for their Canonical Name.This change addresses the use case of Go To Declaration that should resolved to a nested
defmodule
.
-
- #330 - Check if
parameter
isnull
beforeVariable#execute
call inVariable#execute(PsiElement[], ResolveState)
. - #336 - Fix
isVariable
andvariableUseScope
forvar!(name)[...]
- @KronicDeth - #337 - @KronicDeth
@for
is no longer marked as unresolved indefimpl
and instead resolve to the either the<name>
infor: <name>
or the module name for the enclosing module whenfor:
is not given.@protocol
is no longer marked as unresolved indefimpl
and instead resolve to the<name>
indefimpl <name>
.
- #342 - @KronicDeth
- Instead of
assert checkRight || checkLeft
inMatch#processDeclaraions
, do the normal code ifcheckRight || checkLeft
and log an error report otherwise, so that the exact code that trigger this error can be reported and the method fixed to handle that form ofMatch
later.
- Instead of
- #343 - Be able to parse mix version from 1.3.0+
- @KronicDeth
- Check all lines of output for mix version as Elixir 1.3.0 changed the format of
mix --version
, so that it includes the Erlang header (Erlang/OTP ... [erts-...] [source] [64-bit] [smp:..:..] [async-threads:..] [hipe] [kernel-poll:false] [dtrace]
) on the first line andMix <version>
on the 3rd line. Previously the parsing expectedMix <version>
to be the first line.
- Check all lines of output for mix version as Elixir 1.3.0 changed the format of
- @KronicDeth
- #344 - @KronicDeth
- If no known modular (Module, Implementation, Protocol, Quote, or Use) matches the call, then use Unknown, which
accepts any macro with a
do
block or keyword. This allows Go To Symbol to no error in projects using Dogma asdefrule
is now treated as Unknown instead of causing an error that the enclosing modular could not be found.
- If no known modular (Module, Implementation, Protocol, Quote, or Use) matches the call, then use Unknown, which
accepts any macro with a
- #349 -
BracketOperations
are neither parameters nor variables. - @KronicDeth - #353 - Fix stacktrace linking picking wrong file with same
basename - @KronicDeth
- Strip spaces from front of file path in
mix
output, which allows file looks to work correctly. - Ensure file reference highlight doesn't include the leading and trailing characters by fix off-by-one errors.
- Strip spaces from front of file path in
- #358 - Determine whether to check left, right, or both by
doing isAncestor checks for all operands, not just the normalized operand. The normalized operand is still used
for
PsiScopeProcessor#execute
since#execute
is not expected to handle error elements. - #364 - @KronicDeth
- Add
A.{B, C}
to grammar with quoting to check consistence with Elixir 1.2. Ports elixir-lang/elixir#3666. - Use
fullyQualifiedName
instead ofgetName
forresolvableName
becausefullyQualifiedName
is needed so that qualified aliases inside of the{ }
of a multiple alias will not have a name asgetName
isnull
for those qualified aliases because the name fromgetName
has to be a literal name that can be renamed and qualified names can't be renamed.
- Add
- #365 - The
Module
icon got the same icon asUnknown
when creatingUnknown
somehow, I assume due to find-replace. - @KronicDeth
- #314 - Call references for unqualified no argument calls
that work as variables or parameters - @KronicDeth
- Resolve and highlight parameter references
- Resolve call definition clause (
def(macro)?p?
) parameters to themselves - Resolve call definition parameter with default to itself
- Add Parameter ot Color Settings Page
- Parameters in any macro with do block or keyword pair
- Resolve call definition clause (
- Resolve and highlight variable references
- Properly identifier variable declared in
for
comprehension as variable - Add Variable to Color Settings Page
- Highlight bind quoted keyword key as Variable
- Resolve references to earlier
&&
operands, which handles code that matches a variable and only uses the variable on success like((cwd = cwd()) && write_tmp_dir(cwd))
- Resolve variables from
destructure
- Properly identifier variable declared in
- Detect bitstring segment options and don't treat them as variables.
- Highlight bitstring segment type options as Type, the same highlight as used for
@type
names. - Don't generate (unresolved) references for bitstring segment options
- Highlight bitstring segment type options as Type, the same highlight as used for
- Resolve
_
to only itself, no matter how many are used to reflect that it is non-binding, while_<name>
will resolve to_<name>
as it does bind.- Add Ignored Variable to Color Settings Page
- Reimplement module attribute renaming so that variable renaming can be implemented using a different validator for
renaming (since module attribute names include the
@
). Non-inplace renaming should also be supported, but inplace is preferred. (There's a setting to turn off in-place renaming in JetBrains IDEs.) operation.infix.Normalized
- Normalizes leftOperand, operator, and rightOperand for an Infix operation that may have errors (in either operand)
. If there is an error in the operand then its normalized value is
null
.
- Normalizes leftOperand, operator, and rightOperand for an Infix operation that may have errors (in either operand)
. If there is an error in the operand then its normalized value is
- Keyword key type descriptions
- Default to
"keyword key"
. - Detect
bind_quoted:
usage and call those"quote bound variable"
.
- Default to
- Add interfaces to unify matching of
Matched
andUnmatched
form of operations when the code cares about the operatorAnd
UnaryNonNumericOperation
- Add
processDeclarations
to support variable and parameter resolution usingPsiTreeUtil.treeWalkUp
andPsiScopeProcessors
ElixirStabBody
- StabOperations
- Treat variables and parameters as
NamedElements
, so they can be Rename Refactored. - Move reused Module and Function names to
org.elixir_lang.psi.name.{Module,Function}
constants. - Parameter and Variable completion
- Resolve and highlight parameter references
- #318 - Highlight keyword keys (
key:
inkey: value
) that aren't quotes ("key": value
or'key': value
) as Atom. - @KronicDeth - #320 - @KronicDeth
- Show annotator applied highlights in the Preferences > Editor > Colors & Fonts > Elixir.
- Errors
Alias
Braces and Operators
Bit
(<<
and>>
)Braces
({
and}
)Brackets
([
and]
)Char Tokens
(?
)Comma
(,
)Dot
(.
)Interpolation
(#{
and}
)Maps and Structs
Maps
(%{
and}
)Structs
(%{
and}
when used for struct. The Alias is still highlighted usingAlias
)
Operation Sign
Parentheses
((
and)
)Semicolon
(;
)
Calls
Function
(currently only combined withPredefined
to highlightKernel
functions. Will be used later for all function calls once function references are implemented.)Macro
(curently only combined withPredefined
to highlightKernel
andKernel.SpecialForms
macros. Will be used later for all macro calls once macro references are implemented.)Predefined
(Combined withFunction
to highlightKernel
functions. Combined withMacro
to highlightKernel
andKernel.SpecialForms
macros.)
Escape Sequence
Module Attributes
Documentation
(PreviouslyDocumentation Module Attributes
)Text
(PreviouslyDocumentation Text
)
Types
Callback
(my_callback
in@callback my_callback() :: :ok
ormy_macro_callback
in@macrocallback my_macro_callback
)Specification
(my_function
in@spec my_function() :: :ok
)Type
typ
andinteger
in@type typ :: integer
parameterized
in@type parameterized(type_parameter) :: type_parameter
typtyp
in@opaque typtyp :: 1..10
typ
andtyptyp
in@callback func(typ, typtyp) :: :ok | :fail
binary
andutf8
in<< "hello" :: binary, c :: utf8, x = 4 * 2 >> = "hello™1"
Type Parameters
(type_parameter
in@type parameterized(type_parameter) :: type_parameter
)
Numbers
Binary, Decimal, Hexadecimal, and Octal Digits
(Previously at top-level.)Decimal Exponent, Mark and Separator
(Previously at top-level)Invalid Binary, Decimal, Hexadecimal, and Octal Digits
(Previously at top-level.)Non-Decimal Base Prefix
(Previously at top-level.)Obsolete Non-Decimal Base Prefix
Variables
Ignored
Parameter
Variable
- Recover in expression until close of subexpression
\n
\r\n
>>
]
}
)
;
->
end
after
catch
else
rescue
- Update Preferences > Editor > Colors & Fonts > Elixir example text's bitstring syntax to Elixir post-1.0.0 (
Use
-
to separate segment options instead of a list.) - Use same algorithm for
ElixirStabBody
andElixirFile
because they are sequences of expressions. - Highlight atom keywords (
false
,nil
, andtrue
) as merge ofAtom
andKeyword
text attributes. If both only use foreground color,Keyword
wins. - Annotate
QualifiableAlias
asAlias
. - Highlight keyword list and map keywords (
<key>:
) asAtom
. - Add
with
to highlighted special forms
- Show annotator applied highlights in the Preferences > Editor > Colors & Fonts > Elixir.
- #322 - Additional Text Attributes
- @KronicDeth
- Default text attributes for "Darcula" and "Default" themes: almost every Text Attribute Key has a unique hue for the Foreground color.
- Explain how to add
additionalTextAttributes
toplugin.xml
inCONTRIBUTING.md
- Group Textual Text Attribute Keys Together: Next "Textual" group is created and "Character List", "Escape Sequence", "Sigil", and "String" are moved under the group.
- Describe relations between different text attributes in
COLOR_SCHEMA_DESIGN.xml
, so they can be applied to different base schemes, such as applying the current Darcula additonalTextAttributes to Default.
- @KronicDeth
- #314 - @KronicDeth
- Don't generate module attribute references for control attributes: Module attributes that control compilation or are
predefined by the standard library:
@behaviour
,@callback
,@macrocallback
,@doc
,@moduledoc
,@typedoc
,@spec
,@opaque
,@type
, and@typep
, should not have references because their uses are unrelated. - Drop requirement that there are 2 children and only require there be 1 and assume that is the Operator.
- Don't count @(...) as a module attribute usage: Module attribute declarations are defined as
defmacro @(...)
in Kernel and that@
should count as a function name, not a prefix for a module attribute name. - Allow
null
Module for Scratch File use scope - Default to
"call"
for Call type - Fix typo that had
*Two
operations usingType
interface - Don't process
AccessExpression
declarations
- Don't generate module attribute references for control attributes: Module attributes that control compilation or are
predefined by the standard library:
- #316 - @KronicDeth
- Highlight
foo
in@spec foo
as a type, which occurs while typing a new@spec
before::
can be typed. - Check if
leftOperand
isnull
even whencheckLeft
istrue
becausecheckLeft
can betrue
andleftOperand
isnull
when thelastParent
is the operand or operation as a whole, but there is an error in the unnormalizedleftOperand
leading to the normalizedleftOperand
beingnull
. - Check if reference is
null
before checking if it resolves tonull
when replacing module attribute usages with their value becauseAtNonNumericOperation
s can have anull
reference when they are non-referencing, like@spec
.
- Highlight
- #317 - Leave normal highlighting for char tokens when highlighting types - @KronicDeth
- #320 - @KronicDeth
- Stab operation parameter Use Scope is the stab operation.
- Skip over
PsiLeafElement
when looking for variables because thePsiLeafElement
is an error. - In a script file where the parent of a
Match
is aPsiFile
, theMatch
Use Scope is the rest of the file. - Add
=
toOperator Signs
- Skip
NoParenthesesKeywords
when highlighting types, which occurs when the::
has no proper right operand and the following one-liner function clause withdo:
is parsed as the right operand. - Skip
DUMMY_BLOCK
when looking for Variable, which prevents walking through errors. - Use
Normalized
pattern forPrefix
, so that the operand isnull
when only the operator matches or the operand has errors. - Work-around Phoenix .ex templates that contain EEX: if
<%=
from EEX is detected, don't throw error whenModular
can't be found. - Fix capitalization error in example text
- #323 - Build
jps-builder
using only Java 1.6 compatible.class
es - @KronicDeth-
In IntelliJ 14.1, all of
openapi.jar
targets Java 1.6 (withMAJOR.MINOR
50.0
), but in IntelliJ 2016.1, some ofopenapi.jar
targets only Java 1.8 (withMAJOR.MINOR
52.0
), sincejps-builders
require parts ofopenapi.jar
and must target Java 1.6 even for IntelliJ 2016.1, the52.0
.class
es needed to be ported intoorg.elixir_lang.jps.builder
, so that the52.0
version inopenapi.jar
wouldn't be attempted to be loaded.This ended up being 5 classes:
ExecutionException
GeneralCommandLine
ParametersList
ParamsGroup
ProcessNotCreatedException
Only
GeneralCommandLine
was used directly, all others are dependencies of it.
-
- #320 - @KronicDeth
- Preferences > Editor > Colors & Fonts > Elixir restructured to group together related highlights and to match
grouping used for Colors & Fonts > Language Defaults and Colors & Fonts > Java.
Documentation Module Attributes
renamed toModule Attributes
>Documentation
Documentation Text
renamed toModule Attributes > Documentation > Text
Expression Substitution Mark
renamed toBraces and Operators > Interpolation
.- The following are now nested under
Numbers
instead of being at the top-level:Binary, Decimal, Hexadecimal, and Octal Digits
Decimal Exponent, Mark and Separator
Invalid Binary, Decimal, Hexadecimal, and Octal Digits
Non-Decimal Base Prefix
Obsolete Non-Decimal Base Prefix
- Preferences > Editor > Colors & Fonts > Elixir restructured to group together related highlights and to match
grouping used for Colors & Fonts > Language Defaults and Colors & Fonts > Java.
- #322 - "Character List", "Escape Sequence", "Sigil", and " String" are moved under the new "Textual" group. - @KronicDeth
- #324 - Group Numbers subcategories and lower display name
verbosity - @KronicDeth
- "Numbers > Binary, Decimal, Hexadecimal, and Octal Digits" renamed to "Numbers > Digits > Valid"
- "Numbers > Invalid Binary, Decimal, Hexadecimal, and Octal Digits" renamed to "Numbers > Digits > Invalid"
- "Numbers > Non-Decimal Base Prefix" renamed to "Numbers > Base Prefix > Non-Decimal"
- "Numbers > Obsolete Non-Decimal Base" renamed to "Numbers > Base Prefix > Obsolete > Non-Decimal"
- #287 - Use the error reporter logger instead of
plain
assert
inPrefix#operator
. NOTE: This does not address error recovery recovery since I don't have a regression test case. - @KronicDeth - #283 - All function name elements act as
PsiNameIdentifier
s now even if they don't resolve, but that means they all need to supportFindUsagesProvider#getType
, which they don't, so use a placeholder of "unknown call type" for anyCall
that can't be matched and "unknown element" for anything else. - @KronicDeth - #284 - Enumerate all Kernel Functions, Macros, and Special Forms in the Syntax Highlighting section of the README, so that users searching for which category controls highlighting a given call can find it. - @KronicDeth
- #257 - @KronicDeth
- Go To Symbol (⌥⌘O)
- Call definition clauses (
def
,defp
,defmacro
, anddefmacrop
) - Callbacks (
@callback
and@macrocallback
) - Call definition specifications (
@spec
) - Call definition heads (
foo(bar)
) for delegation (defdelegate foo(bar), to: BAZ
) - Implementations (
defimpl
) - Protocols (
defprotocol
)
- Call definition clauses (
- Go To Declaration for Aliases now uses the same
isModular
checks as the stubbing for the index uses for Go To Symbol.
- Go To Symbol (⌥⌘O)
- #263 - Build against 14.0, 14.1, 15.0, and 2016.1 on travis-ci to ensure continued compatibility. - @KronicDeth
- #273 - Error reporting for type highlighter gives the Class, Excerpt and Full Text when an unknown element type is encountered as the Excerpt alone is not enough sometimes.
- #275 - @KronicDeth
- Custom error handling that will open an issue against https://github.com/KronicDeth/intellij-elixir with the exception messsage and stacktrace filled in.
- Changed
NotImplementedExceptions
and (some)assert
s to logging custom error message that include thePsiElement
text and the containing file as an attachment. The files make the URL too big for the error handler to put the file contents in when opening the browser with the error handler, so the issue body instead explains how to get the attachment text out of IntelliJ's "IDE Fatal Errors"
- #276 - Update to Grammar Kit 1.3.0.
- #256 - Fix Elixir Mix Run configuration not persisting past restart - @zyuyou
- #259 - Allow
Infix#operator
to work on operations with errors, which eliminates theAssertionError
reported when typing infix operation and they are incomplete - #259 - Add Keywords to the Preferences > Editor > Colors & Fonts > Elixir settings page, so it can be customized for just Elixir instead of having to change Preferences > Editor > Colors & Fonts > General > Keyword - @KronicDeth
- #263 - Ensure compatibility from 14.0 to 2016.1
- @KronicDeth
-
Use
TextAttributesKey
s that aren't deprecated in 2016.1 and work back to 14.1All of
CodeInsightColors
is deprecated, so all constants from there had to be replaced. Unfortunately, the recommended replacements don't have the same color as the original, so I used differentDefaultLanguageHighlighterColors
constants for some."Module Attribute" is now based on
DefaultLanguageHighlighterColors.CONSTANT
(which is purplish in Darcula) instead of the recommendedMETADATA
, which is yellow. Although module attributes don't have to be constant since they can be set to accumulate, often they are used as constants and not really as metadata, since they are just data then. All themetadata
uses of module attributes have a separate color."Specification" is now based on
DefaultLanguageHighlighterColors.FUNCTION_DECLARATION
, which maintains the golden color thatCodeInsightColors.METHOD_DECLARATION_ATTRIBUTES
had."Type" is now based on
DefaultLanguageHighlighterColors.METADATA
, which is bright yellow unlikeCodeInsightColors.ANNOTATION_ATTRIBUTE_NAME_ATTRIBUTES
, which was a bright white."Type Parameter" is now based on
DefaultLanguageHighlighterColors.PARAMETER
, which unfortunately has no attributes associated with it, but the constant name was too good a fit not to use, so if you want the old color, you'll need to customize it yourself. -
Restore compatibility with the IntelliJ IDEA 14.0 release line
- By using reflection to call
FileTemplateManager#getInstance
ifFileTemplateManager#getDefaultInstance
is not available - By calling
FileChooserDescriptorFactory#createSingleLocalFileDescriptor
(which works in 14.0 through 2016.1) instead ofFileChooserDescriptorFactory#createSingleFileDescriptor
(which only works in 14.1 through 2016.1)
- By using reflection to call
-
- @KronicDeth
- #264 - Use more human-readable error message for Elixir File
action - @KronicDeth
- Instead of showing the regular expression pattern, which may be confusing to new developers, explain in English the expected pattern. I also included the description, which explains how nesting is mapped to directories, of the action since it doesn't actually show up in the dialog otherwise.
- #265 - Check if a file exists before allowing Elixir Module to be created. If it exists, show an error with the conflicting path. - @KronicDeth
- #272 - Fix (one cause) of
AssertionError
inGoToSymbolContributor
when theModular
(defimpl
,demodule
,defprotocol
, andquote
) could not be resolved due adef
being surrounded by afor
comprehension, which is common in Elixir libraries as was the case forPostgrex
: any enclosingfor
comprehension(s) will now be ignored and the next enclosing macro will be checked to see if it is aModular
. - @KronicDeth - #273 - While typing, before
:
in keyword pairs, after thewhen
, such as in@spec foo(id) :: id when id
before finishing typing@spec foo(id) :: id when id: String.t
, the keyword key will be properly highlighted as a Type Parameter - @KronicDeth - #276 - @KronicDeth
- Properly handle the
Infix#rightOperand
beingnull
due to the Pratt Parser matching up through the operator and then ignoring the mismatched right operand, which leads to theInfix
having only 2 elements: the left operand and the operator. @doc
and other module attributes appearing as the right operand of@type name ::
will be ignored as it is common when adding a new type above pre-existing, documented functions.- Only error in
Infix#leftOperand
if there are not 2-3 children forInfix
instead of a strict 3.
- Properly handle the
- #276 - Drop support for IntelliJ 14.0 because the parser generated by Grammar Kit 1.3.0 is not compatible with the OpenAPI libraries shipped in IntelliJ 14.0. Still compatible with 14.1 through 2016.1. - @KronicDeth
- #240 - Code Commenter
- #243
, #248 - Structure View
- KronicDeth
- Controls
- Scroll to Source and Scroll From Source
- Sorting
- Runtime (functions) vs Compile (macros)
- Visibility (public [
def
,macro
, etc] vs private [defp
,macrop
and@typep
]) - Alphabetical
- Show Used - injects structure from
use Alias
call's__using__
'squote
into the call site Structure
- Elements
- Callbacks (
@callback
) show their name/arity and then a nest spec - CallDefinition groups together CallDefinitionClause of the same name/arity
- CallDefinitionClause (
def
,defp
,macro
, andmacrop
) shows the head of each definition under the CallDefinition. - CallDefinitionSpecification (
@spec
) show the type specification for a CallDefinition - CallReference
name: arity
shows the name/arity for adefoverridable
. - Delegation shows all the
:append_first
and:to
options with the implied Function Delegation nested underneath - Exception (
defexception
) show the implicit struct and nest any callback functions, such asexception/1
ormessage/1
. - Overridable
defoverridable
tracks overridable functions and is used to mark CallDefinitions are overrides. - Quote
quote do end
models quote blocks so they can be injecteduse Alias
sites. - Use
use Alias
showuse
calls.
- Callbacks (
- Controls
- KronicDeth
- #241 - Live Templates - pfitz
- #220 - Added clarification to "Import Project from External
Model" that
mix.bat
should be used instead ofmix
- f-lombardo - #244 - Get the Elixir version directly
from
System.build_info[:version]
instead of processing the formatted output ofelixir --version
as the build info version is more stable - KronicDeth
- #244 - Elixir version parsing handles both pre and build
numbers if present by using the same regular expression as Elixir itself uses for the
Version
module - #245 - Better error handling in Structure View
- #236 -
\u
in strings and char lists for unicode mapping - #237 - Test against Elixir 1.1.1 and 1.2.0
- #233 - More flexible
elixir --version
parsing: works withelixir
1.2.0 and earlier - bitgamma
- #207 - KronicDeth
- Highlighters for
- Kernel Functions
- Kernel Macros
- Kernel.SpecialForms Macros
- Highlighters for
- #219 - Test against Elixir v1.1.1
- #221 - Highlight
after
,catch
,do
,else
,end
,fn
, andrescue
as keywords - KronicDeth - #223
, #227 - Annotate Module Attributes
- KronicDeth
- Documentation module attributes (
@doc
,@moduledoc
, and@typedoc
) are annotated as "Documentation Module Attributes" while all other module attributes are annotated as "Module Attributes". - The string or heredoc argument to a documentation module attribute (
@doc
,@moduledoc
, and@typedoc
) is annotated as "Documentation Text" - Function names passed to
@callback
,@macrocallback
or@spec
are annotated as "Specification". - Variables/calls in the parameters and return of
@callback
,@macrocallback
,@spec
are annotated as "Type" . - Parameters of
@opaque
,@type
,@typep
names are annotated as "Type Parameter" - Keyword keys from the
when
clause of@callback
,@macrocallback
or@spec
definitions and their usage are annotated as "Type Parameters" @doc false
,@moduledoc false
, and@typedoc false
will annotate thefalse
with a weak warning: "Will make documented invisible to the documentation extraction tools like ExDoc.".
- Documentation module attributes (
- KronicDeth
- #228 - Module attributes resolution and refactoring
- KronicDeth
- Go To Definition for module attributes.
- Module attribute completion (NOTE: works after typing first character after
@
. To see all module attributes, type a character after@
, then delete the character to get the full list.) - Module attributes that can't be resolved will have "Unresolved module attribute" error annotation (i.e. red squiggly underline).
- Find Usages of module attributes from their declarations.
- Rename module attributes inline (editing the name in the declaration will change the name at the usage site at the same time without a dialog).
- The module attribute value (from the declaration site) will be folded into the usage site. It can be reverted to
the literal
@module_name
text by clicking the + to unfold.
- KronicDeth
- #206 - Change "edition" to "addition" in README.
- #225 - Sped up reparsing when [ENTER] is hit in the middle of comment by removing the custom error handling element, adjacentExpression, and going with the default error handling provided by JetBrains' OpenAPI. - KronicDeth
- #226 - Fix
mix
version detection on Windows
- #225 - KronicDeth
- Removed "Add Newline" Quick Fix as it depended on
adjacentExpression
elements, which have now been removed to speed up error handling when comments become code. - Removed "Add Semicolon" Quick Fix as it depended on
adjacentExpression
elements, which have now been removed to speed up error handling when comments become code.
- Removed "Add Newline" Quick Fix as it depended on
- #204 - Keywords not at the end of no parentheses calls will be properly marked as errors. - KronicDeth
- #200 - Fix
IllegalStateException
for file delete and rename by givingElixirFile
s descriptive names for safe-refactoring displaying file usage. - #201 - KronicDeth
- README states explicitly that the plugin works with both IntelliJ Community and Ultimate.
- README states that the plugin is free.
- #202 - Prevent match error when typing
~
to start a sigil that is followed later by a\n
by matchingEOL
in theNAMED_SIGIL
state as aBAD_CHARACTER
- #204 - Keywords at the end of a no parentheses call that is surrounded by parentheses will not be marked as an error when that parenthetical group appears in the middle of an outer call. - KronicDeth
- #184 - If (1) you have intellij-erlang installed and (2) you
have an atom in Erlang that starts with
Elixir.
, such as'Elixir.Test'
, then intellij-elixir will annotate whether it can resolve the name to adefmodule
call in Elixir files. - KronicDeth - #188 - Default SDK path for Linux and Windows
- #198 - KronicDeth
- Go To Declaration (
Cmd+Click
,Cmd+B
,Navigate > Declaration
) from Alias todefmodule
where Alias is declared. - Index
defmodule
s for fast Go To Declaration in elixir-lang/elixir and other large projects. - Find Usage for Alias in
defmodule
- Go To Declaration (
- #167 - zyuyou
Build
Compile
an individual fileMake Project
to build the entire project
New
Elixir File
has new templatesEmpty module
Elixir Application
Elixir Supervisor
Elixir GenServer
Elixir GenEvent
Project > Elixir
creates a new Elixir project with an emptylib
directory marked as source directory.Project from Existing Sources...
Create project from existing sources
sets up the project with SDK using a pre-existing directory.Import project from external model > Mix
- Fetches the the dependencies with the local version of
mix
- Marks
lib
directory as source - Marks
test
directory as test sources
- Fetches the the dependencies with the local version of
Run > Elixir Mix
to setup Run Configurations to runmix
tasks.
- #168 - Update ant build on travis-ci.org to use IDEA 14.1.4 (from 14.0.2) - KronicDeth
- #174 - Parser is verified to quote the same as native Elixir
- #154 - Fix parsing of unary vs binary +/- with leading and trailing spaces and newlines - KronicDeth
- #155 - Allow EOL between list arguments and
]
- #156 - KronicDeth
- Relative identifiers after
.
that start withand
,or
, andnot
will be lexed as a single identifier instead ofand
,or
, ornot
followed by another identifier. end
is allowed as a relative identifier after.
- Relative identifiers after
- #157 - Fix
(...)
as part of matched expression in no parentheses stab signature - KronicDeth - #158 - Allow multiple newlines to mark the end of an
expression, but only one
;
- KronicDeth - #159 - Allow operators in function
references (
<op>/<arity>
) for function captures (&<op>/<arity>
) - KronicDeth - #160 -
unquote_splicing
is properly wrapped in__block__
when in stab bodies - KronicDeth - #163 - Check for matching terminator in heredocs when determining white space type at beginning of line - KronicDeth
- #170 - Allow + to count as addition
- #171 - Unary expressions inside parentheses are no longer
marked
ambiguous_op: nil
- KronicDeth - #173 - Differentiate between
Qualifier.'relative'()
vsQualifier.'relative' ()
andQualifier."relative"()
vsQualifier."relative" ()
- #176 - Fix link to Elixir website in README
- #178 - All tokens have human-readable names and/or expected characters for better error messages - KronicDeth
- #162 - New Elixir File has moved to the last item in the New
File menu to preserve
CTRL+N ENTER
keyboard shortcut forNew > File
- jaketrent
- #135 -
do
blocks (`do end) - #152 - Unmatched expressions (operations involving
do
block calls and normal matched expressions) - Kronicdeth
- #137 - Lex full atom instead of just identifier-like
operator prefix (
:in<nospace>dex
before vs:index
after) - @KronicDeth - #138 -
!
andnot
are properly wrapped in__block__
s when in stab bodies - @KronicDeth
- #126 - Bracket at expression (
@foo[key]
) - #127 - Anonymous functions (
fn end
), stab clauses (->
), and parentheticals ((1 + 2)
) - @KronicDeth - #128 - Maps (
%{}
) and structs (%User{}
) - #129 - Tuples (
{}
) - #130 - Bit strings (
<<>>
)
- #122 - @KronicDeth
- Remote function calls (
Alias.function
,:atom.function
, etc) and local function calls (function
) with...- No Parentheses with...
- No Arguments (
Alias.function
) - Keywords (
Alias.function key: value
) - Nested No Parentheses Call (
Alias.function Inner.function positional, key: value
) - Positional and Keyword arguments (
Alias.function positional, key: value
) - Matched Expression (
Alias.function 1 + 2
)
- No Arguments (
- Parentheses with...
- No arguments (
Alias.function()
) - No Parentheses Call (
Alias.function(Inner.function positional, key: value
) - Keywords (
Alias.function(key: value)
) - Positional and Keyword arguments (
Alias.function(positional, key: value)
) - Trailing parentheses for quoting (
def unquote(variable)(positional)
)
- No arguments (
- No Parentheses with...
- Remote function calls (
- #125 - Bracket expression (
foo[key]
)
- #121 - Fix
NoSuchElementException
when no suggested SDK home paths are available. Thanks to @zyuyou for reporting
- #112 - File > New > Project From Existing Sources can be
used in IntelliJ to setup the excludes, sources, tests, SDK and libraries for an Elixir project that has already been
created with
mix new
. - @KronicDeth - #114 - Operators can be qualified function names
- #118 - @KronicDeth
- Anonymous function calls (
.(...)
) - Inspection that marks errors when keywords aren't at end of list.
- Anonymous function calls (
- #108 -
\x
is marked as an error in CharLists, CharList Heredocs, Strings, and String Heredocs, but not in any sigils. - @KronicDeth - #111 - New Elixir File will automatically underscore the
camel case module name when creating the file name and will convert qualifying aliases before the last
.
to directories - @KronicDeth
- #111 - New Elixir File validates that the name is a valid
Alias, so each
.
separated part must start with a capital letter. Previous New Elixir File validated that the name was a valid path, and so forced the name to be lowercase. - @KronicDeth
- #105 - No parentheses function calls can occur as the right operand in binary infix operations or the sole operand of unary prefix operation.
- #74 - @KronicDeth
- Function calls with neither parentheses nor
do
blocks that have at least 2 arguments: a positional argument and keyword arguments or 2 or more positional argument(s) followed by optional keyword arguments. - Inspection that marks errors for ambiguous commas
- Inspection that marks errors for ambiguous parentheses
- Quick Fix for the ambiguous parentheses to remove the space between the function name and the opening parentheses.
- Function calls with neither parentheses nor
- #75 - @KronicDeth
- Inspection that marks errors for missing end-of-expressions (
;
and newlines) between expressions. - Quick Fix to insert
;
for missing end-of-expression. - Quick Fix to insert newline for missing end-of-expression.
- Inspection that marks errors for missing end-of-expressions (
- #74 - Right hand-side of
dot_alias
anddot_identifier
was translated incorrectly. Only Aliases and Identifiers are allowed now. @KronicDeth
- #73 - @KronicDeth
- New attributes for parts of numbers on Color Settings Page
- Binary, Decimal, Hexadecimal, and Octal Digits
- Decimal Exponent, Mark, and Separator
- Invalid Binary, Decimal, Hexadecimal, and Octal Digits
- 2-9, A-Z, and a-z will be parsed as invalid binary digits
- 8-9, A-Z, and a-z will be parsed as invalid octal digits
- G-Z and g-z will be parsed as invalid hexadecimal digits
- Non-Decimal Base Prefix
- Any letter other than b, o, or x, in either case, will be recognized as an invalid whole number base
- Obsolete Non-Decimal Base Prefix (
B
for binary andX
for hexadecimal)
- Any digit, 0-9, A-Z, or a-z will be parsed as invalid for invalid whole number based numbers
- Recovery for non-decimal whole numbers if the prefix is given, but no digits are given
- #73: Number attribute has been removed from Color Settings page - @KronicDeth
- #17: All valid escape sequences (
\<character>
,\x<hexadecimal>
,\x{<hexadecimal>}
are recognized. - @KronicDeth - #18: Support for creation of Elixir modules
- #21: Use pygments' elixir_example.ex supplied by @alco for Color Settings Page - @KronicDeth
- #25:
?
before any character or valid escape sequence will be recognized as a character token. - @KronicDeth - #35:
;
is recognized as EOL.\r\n
and\n
style EOL can be escaped with\
and will be treated as whitespace. - @KronicDeth - #38: Operator arity, associativity, and precedence
- #39: Decimal integers and floats
- #40: Identifiers (variable, function, and macro names)
- #41:
...
identifier - #42: Aliases (module names)
- #45: Keyword identifiers
- #49: Empty Parentheses
- #52: In Operator
- #54: Dot Operator
- #56: Keyword Lists
- #70: Matched Expressions
- #72: Regular Keywords (
end
,false
,fn
,nil
, andtrue
) - @KronicDeth
- #17: Sigil terminator escapes are recognized, so that sigils are no longer prematurely terminated. - @KronicDeth
- #24: Comments do not consume EOL, so trailing comments don't cause error parsing expression on following line. - @KronicDeth
- #36: Sigil modifiers now work on groups in addition to heredocs. - @KronicDeth
- #47:
;
is separate fromEOL
and either or both can separate expressions, but onlyEOL
can separate operators and operands for operations
- #10: Blank lines are properly parsed as whitespace instead of bad characters. - @KronicDeth
- #13: EOL is parsed as bad character in sigil name (after
~
) instead of causing the lexer to fail to match, which raised exceptions in Event Log.
- Atoms with highlighting
- Atom with double or single quotes to allow interpolation. Double quotes are highlighted as 'String' while single quotes are highlighted as 'Char List'. This may be changed in the future.
- Literal atoms highlighted as 'Atom'.
- Operator atoms highlighted as 'Atom'.
- Build using JDK 6 instead of 7 so that plugin will work by default on OSX Mavericks.
- #3: Literal and interpolated sigils with highlighting
- @KronicDeth
- CharList Sigils (
~c
and~C
) highlighted as 'Char List' in Settings. - Regex Sigils (
~r
and~R
) highlighted as 'Sigil' in Settings. NOTE: Regex syntax is not internally highlighted yet - String Sigils (
~s
and~S
) highlighted as 'String' in Settings. - Word Sigils (
~w
and~W
) highlighted as 'Sigil' in Settings. - Custom Sigils highlighted as 'Sigil' in Settings.
- Modifiers are highlighted on Regex, Word, and Custom while modifiers aren't allowed on CharList and String Sigils.
- CharList Sigils (
- @KronicDeth
- Single-quoted strings are correctly referred to as 'Character List' now instead of 'String' in Settings.
- Double-quoted strings are correctly referred to as 'String' now instead of 'Interpolated String' in Settings.
- Non-Heredoc CharLists and Strings can be multiline.
- CharLists and Strings support interpolation and escape sequences.
- Single quoted strings with highlighting. ('String' in Color Settings.)
- Double quoted strings with highlighting. ('Interpolated String' in Color Settings.)
- Interpolation (
#{
and}
) with highlighting. ('Expression Substitution Mark' in Color Settings.) - Escape sequences for
"
and#
with highlighting. ('Escape Sequence' in Color Settings.)
- Interpolation (
- Binary, Hexadecimal, and Octal numbers (including deprecated syntax) are recognized as numbers.
- Syntax Highlighting for numbers.
- Color Settings page for changing the color of comments and numbers for Elixir (Preferences > Editor > Colors & Fonts > Elixir).
- Parser no longer freezes IDE on tokens it doesn't understand.
- White space at beginning of lines no longer leads to annotation errors.
- White space and EOLs at beginning of file no longer lead to annotation errors.