use of org.eclipse.xtext.ui.editor.contentassist.ConfigurableCompletionProposal.IReplacementTextApplier in project xtext-eclipse by eclipse.
the class XbaseProposalProvider method proposeFavoriteStaticFeatures.
/**
* @since 2.17
*/
protected void proposeFavoriteStaticFeatures(EObject context, ContentAssistContext contentAssistContext, ICompletionProposalAcceptor acceptor, IScope scopedFeatures) {
Function<IEObjectDescription, ICompletionProposal> proposalFactory = getProposalFactory(getFeatureCallRuleName(), contentAssistContext);
IReplacementTextApplier textApplier = new FQNImporter(contentAssistContext.getResource(), contentAssistContext.getViewer(), scopedFeatures, qualifiedNameConverter, qualifiedNameValueConverter, importSectionFactory, replaceConverter);
Function<IEObjectDescription, ICompletionProposal> importAddingProposalFactory = input -> {
ICompletionProposal proposal = proposalFactory.apply(input);
if (proposal instanceof ConfigurableCompletionProposal) {
ConfigurableCompletionProposal castedProposal = (ConfigurableCompletionProposal) proposal;
// Add textApplier to introduce imports if necessary
((ConfigurableCompletionProposal) proposal).setTextApplier(textApplier);
return castedProposal;
}
return proposal;
};
getCrossReferenceProposalCreator().lookupCrossReference(scopedFeatures, context, XbasePackage.Literals.XABSTRACT_FEATURE_CALL__FEATURE, acceptor, getFeatureDescriptionPredicate(contentAssistContext), importAddingProposalFactory);
}
use of org.eclipse.xtext.ui.editor.contentassist.ConfigurableCompletionProposal.IReplacementTextApplier in project xtext-eclipse by eclipse.
the class JdtTypesProposalProvider method searchAndCreateProposals.
protected void searchAndCreateProposals(IJavaSearchScope scope, final ICompletionProposalFactory proposalFactory, ContentAssistContext context, EReference typeReference, final Filter filter, final IValueConverter<String> valueConverter, final ICompletionProposalAcceptor acceptor) throws JavaModelException {
String prefix = context.getPrefix();
List<String> split = Strings.split(prefix, '.');
char[] typeName = null;
char[] packageName = null;
if (prefix.length() > 0 && !split.isEmpty()) {
CharMatcher dotMatcher = CharMatcher.is('.');
if (Character.isUpperCase(split.get(split.size() - 1).charAt(0))) {
typeName = split.get(split.size() - 1).toCharArray();
if (split.size() > 1)
packageName = ("*" + dotMatcher.replaceFrom(prefix.substring(0, prefix.length() - (typeName.length + 1)), "*.") + "*").toCharArray();
} else {
if (prefix.endsWith("."))
prefix = prefix.substring(0, prefix.length() - 1);
packageName = ("*" + dotMatcher.replaceFrom(prefix, "*.") + "*").toCharArray();
}
}
IScope typeScope = null;
if (context.getCurrentModel() != null) {
typeScope = scopeProvider.getScope(context.getCurrentModel(), typeReference);
}
final IReplacementTextApplier textApplier = createTextApplier(context, typeScope, qualifiedNameConverter, valueConverter);
final ICompletionProposalAcceptor scopeAware = textApplier != null ? new ICompletionProposalAcceptor.Delegate(acceptor) {
@Override
public void accept(ICompletionProposal proposal) {
if (proposal instanceof ConfigurableCompletionProposal) {
((ConfigurableCompletionProposal) proposal).setTextApplier(textApplier);
}
super.accept(proposal);
}
} : acceptor;
Builder contextBuilder = context.copy();
final PrefixMatcher original = context.getMatcher();
contextBuilder.setMatcher(new PrefixMatcher() {
@Override
public boolean isCandidateMatchingPrefix(String name, String prefix) {
if (original.isCandidateMatchingPrefix(name, prefix))
return true;
String nameWithoutDollars = name.replace('$', '.');
String prefixWithoutDollars = prefix.replace('$', '.');
final boolean nameOrPrefixHasDollars = (nameWithoutDollars != name) || (prefixWithoutDollars != prefix);
if (nameOrPrefixHasDollars && original.isCandidateMatchingPrefix(nameWithoutDollars, prefixWithoutDollars))
return true;
String sub = nameWithoutDollars;
int delimiter = sub.indexOf('.');
while (delimiter != -1) {
sub = sub.substring(delimiter + 1);
delimiter = sub.indexOf('.');
if (delimiter == -1 || prefixWithoutDollars.length() > 0 && Character.isLowerCase(prefixWithoutDollars.charAt(0))) {
if (original.isCandidateMatchingPrefix(sub, prefixWithoutDollars))
return true;
}
}
return false;
}
});
final ContentAssistContext myContext = contextBuilder.toContext();
final IJvmTypeProvider jvmTypeProvider = jdtTypeProviderFactory.findOrCreateTypeProvider(context.getResource().getResourceSet());
final Set<String> filteredTypeNames = getDirtyTypeNames();
final Filter dirtyTypenameFilter = new ITypesProposalProvider.Filter() {
@Override
public boolean accept(int modifiers, char[] packageName, char[] simpleTypeName, char[][] enclosingTypeNames, String path) {
if (path == null || path.endsWith(".class") || path.endsWith(".java")) {
// Java index match
String identifier = getIdentifier(packageName, simpleTypeName, enclosingTypeNames);
if (filteredTypeNames.contains(identifier)) {
return false;
}
}
return true;
}
@Override
public int getSearchFor() {
return filter.getSearchFor();
}
};
BasicSearchEngine searchEngine = new BasicSearchEngine();
searchEngine.searchAllTypeNames(packageName, SearchPattern.R_PATTERN_MATCH, typeName, SearchPattern.R_PREFIX_MATCH | SearchPattern.R_CAMELCASE_MATCH, filter.getSearchFor(), scope, new IRestrictedAccessTypeRequestor() {
@Override
public void acceptType(int modifiers, char[] packageName, char[] simpleTypeName, char[][] enclosingTypeNames, String path, AccessRestriction access) {
if (dirtyTypenameFilter.accept(modifiers, packageName, simpleTypeName, enclosingTypeNames, path) && filter.accept(modifiers, packageName, simpleTypeName, enclosingTypeNames, path) && (!checkAccessRestriction() || (access == null || access.getProblemId() != IProblem.ForbiddenReference && !access.ignoreIfBetter()))) {
StringBuilder fqName = new StringBuilder(packageName.length + simpleTypeName.length + 1);
if (packageName.length != 0) {
fqName.append(packageName);
fqName.append('.');
}
for (char[] enclosingType : enclosingTypeNames) {
/*
* the JDT index sometimes yields enclosingTypeNames in the form
* char[][] { { Outer$Middle } }
* rather than
* char[][] { { Outer }, { Middle } }
* thus we create the fqName as the binary name and post process the proposal later on
*/
fqName.append(enclosingType);
fqName.append('$');
}
fqName.append(simpleTypeName);
String fqNameAsString = fqName.toString();
createTypeProposal(fqNameAsString, modifiers, enclosingTypeNames.length > 0, proposalFactory, myContext, scopeAware, jvmTypeProvider, valueConverter);
}
}
}, IJavaSearchConstants.WAIT_UNTIL_READY_TO_SEARCH, new NullProgressMonitor() {
@Override
public boolean isCanceled() {
return !acceptor.canAcceptMoreProposals();
}
});
if (acceptor.canAcceptMoreProposals()) {
Iterable<IEObjectDescription> allDirtyTypes = dirtyStateManager.getExportedObjectsByType(TypesPackage.Literals.JVM_TYPE);
for (IEObjectDescription description : allDirtyTypes) {
QualifiedName qualifiedName = description.getQualifiedName();
final int modifiers = getDirtyStateModifiers(context, description);
if (filter.accept(modifiers, qualifiedName.skipLast(1).toString().toCharArray(), qualifiedName.getLastSegment().toCharArray(), new char[0][0], description.getEObjectURI().toPlatformString(true))) {
String fqName = description.getQualifiedName().toString();
createTypeProposal(fqName, modifiers, fqName.indexOf('$') > 0, proposalFactory, myContext, scopeAware, jvmTypeProvider, valueConverter);
}
}
}
}
Aggregations