use of com.redhat.qute.parser.template.Expression in project quarkus-ls by redhat-developer.
the class JavaDataModelCache method resolveJavaType.
private CompletableFuture<ResolvedJavaTypeInfo> resolveJavaType(ObjectPart objectPart, String projectUri, boolean nullIfDontMatchWithIterable) {
CompletableFuture<ResolvedJavaTypeInfo> future = null;
JavaTypeInfoProvider javaTypeInfo = objectPart.resolveJavaType();
if (javaTypeInfo == null) {
return RESOLVED_JAVA_TYPE_INFO_NULL_FUTURE;
}
String javaType = javaTypeInfo.getJavaType();
if (StringUtils.isEmpty(javaType)) {
Expression expression = javaTypeInfo.getJavaTypeExpression();
if (expression != null) {
String literalJavaType = expression.getLiteralJavaType();
if (literalJavaType != null) {
future = resolveJavaType(literalJavaType, projectUri);
} else {
Part lastPart = expression.getLastPart();
if (lastPart == null) {
return RESOLVED_JAVA_TYPE_INFO_NULL_FUTURE;
}
future = resolveJavaType(lastPart, projectUri);
}
}
}
if (future == null) {
future = resolveJavaType(javaType, projectUri);
}
Node node = javaTypeInfo.getJavaTypeOwnerNode();
Section section = getOwnerSection(node);
if (section != null) {
if (section.isIterable()) {
future = //
future.thenCompose(resolvedType -> {
if (resolvedType == null) {
return RESOLVED_JAVA_TYPE_INFO_NULL_FUTURE;
}
if (!resolvedType.isIterable()) {
if (resolvedType.isInteger()) {
// {/for}
return resolveJavaType(resolvedType.getName(), projectUri);
}
if (nullIfDontMatchWithIterable) {
// {item.|}
return RESOLVED_JAVA_TYPE_INFO_NULL_FUTURE;
}
}
// valid case
// Ex:
// {@java.util.List<org.acme.Item> items}
// {#for item in items}
// {item.|}
// Here
// - resolvedType = java.util.List<org.acme.Item>
// - iterTypeName = org.acme.Item
// Resolve org.acme.Item
String iterTypeName = resolvedType.getIterableOf();
return resolveJavaType(iterTypeName, projectUri);
});
}
}
return future;
}
use of com.redhat.qute.parser.template.Expression in project quarkus-ls by redhat-developer.
the class QuteCodeActions method doCodeActionsForUndefinedObject.
private static void doCodeActionsForUndefinedObject(Template template, Diagnostic diagnostic, QuteErrorCode errorCode, List<CodeAction> codeActions) {
try {
String varName = null;
boolean isIterable = false;
JsonObject data = (JsonObject) diagnostic.getData();
if (data != null) {
varName = data.get(DIAGNOSTIC_DATA_NAME).getAsString();
isIterable = data.get(DIAGNOSTIC_DATA_ITERABLE).getAsBoolean();
} else {
int offset = template.offsetAt(diagnostic.getRange().getStart());
Node node = template.findNodeAt(offset);
node = QutePositionUtility.findBestNode(offset, node);
if (node.getKind() == NodeKind.Expression) {
Expression expression = (Expression) node;
ObjectPart part = expression.getObjectPart();
if (part != null) {
varName = part.getPartName();
}
}
}
if (varName != null) {
TextDocument document = template.getTextDocument();
String lineDelimiter = document.lineDelimiter(0);
String title = MessageFormat.format(UNDEFINED_OBJECT_CODEACTION_TITLE, varName);
Position position = new Position(0, 0);
StringBuilder insertText = new StringBuilder("{@");
if (isIterable) {
insertText.append("java.util.List");
} else {
insertText.append("java.lang.String");
}
insertText.append(" ");
insertText.append(varName);
insertText.append("}");
insertText.append(lineDelimiter);
CodeAction insertParameterDeclarationQuickFix = CodeActionFactory.insert(title, position, insertText.toString(), document, diagnostic);
codeActions.add(insertParameterDeclarationQuickFix);
// CodeAction to set validation severity to ignore
doCodeActionToSetIgnoreSeverity(template, Collections.singletonList(diagnostic), errorCode, codeActions, UNDEFINED_OBJECT_SEVERITY_SETTING);
}
} catch (BadLocationException e) {
}
}
use of com.redhat.qute.parser.template.Expression in project quarkus-ls by redhat-developer.
the class QutePositionUtility method findBestNode.
/**
* Find the best node from the given expression at the given offset.
*
* @param expression the expression node.
* @param offset the offset.
*
* @return the best node from the given expression at the given offset.
*/
private static Node findBestNode(Expression expression, int offset) {
Node expressionNode = expression.findNodeExpressionAt(offset);
if (expressionNode != null) {
if (expressionNode instanceof MethodPart) {
MethodPart method = (MethodPart) expressionNode;
Parameter parameter = method.getParameterAtOffset(offset);
if (parameter != null) {
Expression parameterExpression = parameter.getJavaTypeExpression();
if (parameterExpression != null) {
return findBestNode(parameterExpression, offset);
}
return parameter;
}
}
return expressionNode;
}
return expression;
}
use of com.redhat.qute.parser.template.Expression in project quarkus-ls by redhat-developer.
the class QuteSearchUtils method tryToCollectObjectParts.
/**
* Try to collect all object parts from the given expression
* <code>nodeExpr</code> which matches the given part name
* <code>partName</code>.
*
* @param partName the part name.
* @param matcher the matcher strategy.
* @param nodeExpr the Qute node expression
* @param collector the node collector.
*
* @return true if the given nodeExpr reference the part name as object part and
* false otherwise.
*/
private static boolean tryToCollectObjectParts(String partName, PartNameMatcher matcher, Node nodeExpr, BiConsumer<Node, Range> collector) {
switch(nodeExpr.getKind()) {
case Expression:
{
Expression expression = (Expression) nodeExpr;
boolean result = false;
List<Node> nodes = expression.getExpressionContent();
for (Node node : nodes) {
// ex : partName=item
// node expression can be
// 1) a simple expression:
// --> {item_count} --> [ObjectPart=item_count]
// --> {item.name} --> [ObjectPart=item, PropertyPart=name)
// --> {item.getName()} --> [ObjectPart=item, MethodPart=getName())
// In those cases, one object part will be collected =>{|item|_count},
// {|item|.name}, {|item|.getName()}
// 2) an expression with method part which can host another expressions when
// method have parameters
// --> {item.getName(item.name)} --> [ObjectPart=item,
// MethodPart=getName(item.name))
// In this case, two object parts will be collected =>
// {|item|.getName(|item|.name)}
result |= tryToCollectObjectParts(partName, matcher, node, collector);
}
return result;
}
case ExpressionParts:
{
Parts parts = (Parts) nodeExpr;
boolean result = false;
for (Node partNode : parts.getChildren()) {
result |= tryToCollectObjectParts(partName, matcher, partNode, collector);
}
return result;
}
case ExpressionPart:
{
Part part = (Part) nodeExpr;
if (part.getPartKind() == PartKind.Object) {
ObjectPart objectPart = (ObjectPart) part;
if (isMatch(objectPart, partName, matcher)) {
Range range = QutePositionUtility.createRange(objectPart);
collector.accept(objectPart, range);
return true;
}
} else if (part.getPartKind() == PartKind.Method) {
MethodPart methodPart = (MethodPart) part;
List<Parameter> parameters = methodPart.getParameters();
boolean result = false;
for (Parameter parameter : parameters) {
Expression paramExpr = parameter.getJavaTypeExpression();
if (paramExpr != null) {
result |= tryToCollectObjectParts(partName, matcher, paramExpr, collector);
}
}
return result;
}
}
break;
default:
break;
}
return false;
}
use of com.redhat.qute.parser.template.Expression in project quarkus-ls by redhat-developer.
the class QuteHover method doHoverForParameter.
private CompletableFuture<Hover> doHoverForParameter(Parameter parameter, Template template, HoverRequest hoverRequest) {
int offset = hoverRequest.getOffset();
if (parameter.isInName(offset)) {
// A parameter name is hovered
if (parameter.getOwnerSection() != null && (parameter.getOwnerSection().getSectionKind() == SectionKind.FOR || parameter.getOwnerSection().getSectionKind() == SectionKind.EACH)) {
// a parameter from #for section is hovered
LoopSection iterableSection = (LoopSection) parameter.getOwnerSection();
if (iterableSection.isInAlias(offset)) {
Parameter iterableParameter = iterableSection.getIterableParameter();
if (iterableParameter != null) {
boolean hasMarkdown = hoverRequest.canSupportMarkupKind(MarkupKind.MARKDOWN);
String projectUri = template.getProjectUri();
Part iterablePart = iterableParameter.getJavaTypeExpression().getLastPart();
return //
javaCache.resolveJavaType(iterablePart, projectUri).thenCompose(resolvedJavaType -> {
if (resolvedJavaType != null && resolvedJavaType.isIterable()) {
return //
javaCache.resolveJavaType(resolvedJavaType.getIterableOf(), projectUri).thenApply(resolvedIterableOf -> {
MarkupContent content = DocumentationUtils.getDocumentation(resolvedIterableOf, hasMarkdown);
Range range = QutePositionUtility.createRange(parameter);
return new Hover(content, range);
});
}
return NO_HOVER;
});
}
}
} else {
// Other parameter
// Check if part is a literal (ex: true, null, 123, 'abc', etc)
Expression expression = parameter.getJavaTypeExpression();
if (expression != null) {
String projectUri = template.getProjectUri();
String literalJavaType = expression.getLiteralJavaType();
if (literalJavaType != null) {
return //
javaCache.resolveJavaType(literalJavaType, projectUri).thenApply(resolvedJavaType -> {
if (resolvedJavaType != null) {
boolean hasMarkdown = hoverRequest.canSupportMarkupKind(MarkupKind.MARKDOWN);
MarkupContent content = DocumentationUtils.getDocumentation(resolvedJavaType, hasMarkdown);
Range range = QutePositionUtility.createRange(parameter);
return new Hover(content, range);
}
return null;
});
}
return //
javaCache.resolveJavaType(parameter, projectUri).thenApply(resolvedJavaType -> {
if (resolvedJavaType != null) {
boolean hasMarkdown = hoverRequest.canSupportMarkupKind(MarkupKind.MARKDOWN);
MarkupContent content = DocumentationUtils.getDocumentation(resolvedJavaType, hasMarkdown);
Range range = QutePositionUtility.createRange(parameter);
return new Hover(content, range);
}
return null;
});
}
}
}
return NO_HOVER;
}
Aggregations