1
0
Fork 0
mirror of https://github.com/eclipse-cdt/cdt synced 2025-04-29 19:45:01 +02:00

Cleanup and unify CElementLabelProviders

This commit is contained in:
Anton Leherbauer 2006-12-07 12:49:25 +00:00
parent e18fdc081c
commit 554b3fa756
6 changed files with 109 additions and 248 deletions

View file

@ -620,6 +620,7 @@ public class ASTStringUtil {
final IASTExpression expression= (IASTExpression)argument; final IASTExpression expression= (IASTExpression)argument;
appendExpressionString(buffer, expression); appendExpressionString(buffer, expression);
} }
trimRight(buffer);
} }
buffer.append(Keywords.cpGT); buffer.append(Keywords.cpGT);
} else if (name != null) { } else if (name != null) {

View file

@ -16,12 +16,12 @@ import org.eclipse.jface.util.IPropertyChangeListener;
import org.eclipse.jface.util.PropertyChangeEvent; import org.eclipse.jface.util.PropertyChangeEvent;
/** /**
* JavaUILabelProvider that respects settings from the Appearance preference page. * CUILabelProvider that respects settings from the Appearance preference page.
* Triggers a viewer update when a preference changes. * Triggers a viewer update when a preference changes.
*/ */
public class AppearanceAwareLabelProvider extends CUILabelProvider implements IPropertyChangeListener { public class AppearanceAwareLabelProvider extends CUILabelProvider implements IPropertyChangeListener {
public final static int DEFAULT_TEXTFLAGS= CElementLabels.ROOT_VARIABLE | CElementLabels.M_PARAMETER_TYPES | CElementLabels.REFERENCED_ROOT_POST_QUALIFIED; public final static int DEFAULT_TEXTFLAGS= CElementLabels.M_PARAMETER_TYPES | CElementLabels.PROJECT_POST_QUALIFIED;
public final static int DEFAULT_IMAGEFLAGS= CElementImageProvider.OVERLAY_ICONS; public final static int DEFAULT_IMAGEFLAGS= CElementImageProvider.OVERLAY_ICONS;
private int fTextFlagMask; private int fTextFlagMask;

View file

@ -27,6 +27,7 @@ import org.eclipse.cdt.core.model.IField;
import org.eclipse.cdt.core.model.IFunctionDeclaration; import org.eclipse.cdt.core.model.IFunctionDeclaration;
import org.eclipse.cdt.core.model.IMethodDeclaration; import org.eclipse.cdt.core.model.IMethodDeclaration;
import org.eclipse.cdt.core.model.ISourceRoot; import org.eclipse.cdt.core.model.ISourceRoot;
import org.eclipse.cdt.core.model.ITemplate;
import org.eclipse.cdt.core.model.ITranslationUnit; import org.eclipse.cdt.core.model.ITranslationUnit;
import org.eclipse.cdt.core.model.IVariableDeclaration; import org.eclipse.cdt.core.model.IVariableDeclaration;
import org.eclipse.cdt.ui.CUIPlugin; import org.eclipse.cdt.ui.CUIPlugin;
@ -38,8 +39,6 @@ import org.eclipse.cdt.internal.ui.CUIMessages;
/** /**
* @author aniefer * @author aniefer
* *
* To change the template for this generated type comment go to
* Window>Preferences>Java>Code Generation>Code and Comments
*/ */
public class CElementLabels { public class CElementLabels {
@ -49,12 +48,6 @@ public class CElementLabels {
*/ */
public final static int M_PARAMETER_TYPES= 1 << 0; public final static int M_PARAMETER_TYPES= 1 << 0;
/**
* Method names contain parameter names.
* e.g. <code>foo(index)</code>
*/
public final static int M_PARAMETER_NAMES= 1 << 1;
/** /**
* Method names contain thrown exceptions. * Method names contain thrown exceptions.
* e.g. <code>foo throw( IOException )</code> * e.g. <code>foo throw( IOException )</code>
@ -75,27 +68,21 @@ public class CElementLabels {
/** /**
* Method names are fully qualified. * Method names are fully qualified.
* e.g. <code>java.util.Vector.size</code> * e.g. <code>ClassName::size</code>
*/ */
public final static int M_FULLY_QUALIFIED= 1 << 5; public final static int M_FULLY_QUALIFIED= 1 << 5;
/** /**
* Method names are post qualified. * Method names are post qualified.
* e.g. <code>size - java.util.Vector</code> * e.g. <code>size - ClassName</code>
*/ */
public final static int M_POST_QUALIFIED= 1 << 6; public final static int M_POST_QUALIFIED= 1 << 6;
/** /**
* Initializer names are fully qualified. * Templates are qualified with template parameters.
* e.g. <code>java.util.Vector.{ ... }</code> * e.g. <code>ClassName<T></code>
*/ */
public final static int I_FULLY_QUALIFIED= 1 << 7; public final static int TEMPLATE_PARAMETERS= 1 << 7;
/**
* Type names are post qualified.
* e.g. <code>{ ... } - java.util.Map</code>
*/
public final static int I_POST_QUALIFIED= 1 << 8;
/** /**
* Field names contain the declared type (appended) * Field names contain the declared type (appended)
@ -127,12 +114,6 @@ public class CElementLabels {
*/ */
public final static int T_FULLY_QUALIFIED= 1 << 13; public final static int T_FULLY_QUALIFIED= 1 << 13;
/**
* Type names are type container qualified.
* e.g. <code>OuterClass::InnerClass</code>
*/
public final static int T_CONTAINER_QUALIFIED= 1 << 14;
/** /**
* Type names are post qualified. * Type names are post qualified.
* e.g. <code>InnerClass - OuterClass</code> * e.g. <code>InnerClass - OuterClass</code>
@ -140,113 +121,64 @@ public class CElementLabels {
public final static int T_POST_QUALIFIED= 1 << 15; public final static int T_POST_QUALIFIED= 1 << 15;
/** /**
* Declarations (import container / declarartion, package declarartion) are qualified. * Translation unit names contain the full path.
* e.g. <code>java.util.Vector.class/import container</code> * e.g. <code>/MyProject/src/ClassName.cpp</code>
*/ */
public final static int D_QUALIFIED= 1 << 16; public final static int TU_QUALIFIED= 1 << 20;
/** /**
* Declarations (import container / declarartion, package declarartion) are post qualified. * Translation unit names are post qualified with their path.
* e.g. <code>import container - java.util.Vector.class</code> * e.g. <code>ClassName.cpp - /MyProject/src</code>
*/ */
public final static int D_POST_QUALIFIED= 1 << 17; public final static int TU_POST_QUALIFIED= 1 << 21;
/** /**
* Class file names are fully qualified. * Source roots contain the project name (prepended).
* e.g. <code>java.util.Vector.class</code>
*/
public final static int CF_QUALIFIED= 1 << 18;
/**
* Class file names are post qualified.
* e.g. <code>Vector.class - java.util</code>
*/
public final static int CF_POST_QUALIFIED= 1 << 19;
/**
* Compilation unit names are fully qualified.
* e.g. <code>java.util.Vector.java</code>
*/
public final static int CU_QUALIFIED= 1 << 20;
/**
* Compilation unit names are post qualified.
* e.g. <code>Vector.java - java.util</code>
*/
public final static int CU_POST_QUALIFIED= 1 << 21;
/**
* Package names are qualified.
* e.g. <code>MyProject/src/java.util</code>
*/
public final static int P_QUALIFIED= 1 << 22;
/**
* Package names are post qualified.
* e.g. <code>java.util - MyProject/src</code>
*/
public final static int P_POST_QUALIFIED= 1 << 23;
/**
* Package Fragment Roots contain variable name if from a variable.
* e.g. <code>JRE_LIB - c:\java\lib\rt.jar</code>
*/
public final static int ROOT_VARIABLE= 1 << 24;
/**
* Package Fragment Roots contain the project name if not an archive (prepended).
* e.g. <code>MyProject/src</code> * e.g. <code>MyProject/src</code>
*/ */
public final static int ROOT_QUALIFIED= 1 << 25; public final static int ROOT_QUALIFIED= 1 << 25;
/** /**
* Package Fragment Roots contain the project name if not an archive (appended). * Source roots contain the project name (appended).
* e.g. <code>src - MyProject</code> * e.g. <code>src - MyProject</code>
*/ */
public final static int ROOT_POST_QUALIFIED= 1 << 26; public final static int ROOT_POST_QUALIFIED= 1 << 26;
/** /**
* Add root path to all elements except Package Fragment Roots and Java projects. * Add source root path.
* e.g. <code>java.lang.Vector - c:\java\lib\rt.jar</code> * e.g. <code>func() - MyProject/src</code>
* Option only applies to getElementLabel * Option only applies to getElementLabel
*/ */
public final static int APPEND_ROOT_PATH= 1 << 27; public final static int APPEND_ROOT_PATH= 1 << 27;
/** /**
* Add root path to all elements except Package Fragment Roots and Java projects. * Prepend source root path.
* e.g. <code>java.lang.Vector - c:\java\lib\rt.jar</code> * e.g. <code>MyProject/src - func()</code>
* Option only applies to getElementLabel * Option only applies to getElementLabel
*/ */
public final static int PREPEND_ROOT_PATH= 1 << 28; public final static int PREPEND_ROOT_PATH= 1 << 28;
/** /**
* Package names are compressed. * Post qualify container project. For example
* e.g. <code>o*.e*.search</code> * <code>folder - MyProject</code> if the folder is in project MyProject.
*/ */
public final static int P_COMPRESSED= 1 << 29; public final static int PROJECT_POST_QUALIFIED= 1 << 30;
/**
* Post qualify referenced package fragement roots. For example
* <code>jdt.jar - org.eclipse.jdt.ui</code> if the jar is referenced
* from another project.
*/
public final static int REFERENCED_ROOT_POST_QUALIFIED= 1 << 30;
/** /**
* Post qualify symbols with file. * Post qualify symbols with file.
* e.g. func() - /proj/foder/file.cpp * e.g. func() - /proj/folder/file.cpp
*/ */
public final static int MF_POST_FILE_QUALIFIED= 1 << 31; public final static int MF_POST_FILE_QUALIFIED= 1 << 31;
/** /**
* Qualify all elements * Qualify all elements
*/ */
public final static int ALL_FULLY_QUALIFIED= F_FULLY_QUALIFIED | M_FULLY_QUALIFIED | I_FULLY_QUALIFIED | T_FULLY_QUALIFIED | D_QUALIFIED | CF_QUALIFIED | CU_QUALIFIED | P_QUALIFIED | ROOT_QUALIFIED; public final static int ALL_FULLY_QUALIFIED= F_FULLY_QUALIFIED | M_FULLY_QUALIFIED | T_FULLY_QUALIFIED | TU_QUALIFIED | ROOT_QUALIFIED;
/** /**
* Post qualify all elements * Post qualify all elements
*/ */
public final static int ALL_POST_QUALIFIED= F_POST_QUALIFIED | M_POST_QUALIFIED | I_POST_QUALIFIED | T_POST_QUALIFIED | D_POST_QUALIFIED | CF_POST_QUALIFIED | CU_POST_QUALIFIED | P_POST_QUALIFIED | ROOT_POST_QUALIFIED; public final static int ALL_POST_QUALIFIED= F_POST_QUALIFIED | M_POST_QUALIFIED | T_POST_QUALIFIED | TU_POST_QUALIFIED | ROOT_POST_QUALIFIED;
/** /**
* Default options (M_PARAMETER_TYPES enabled) * Default options (M_PARAMETER_TYPES enabled)
@ -254,14 +186,14 @@ public class CElementLabels {
public final static int ALL_DEFAULT= M_PARAMETER_TYPES; public final static int ALL_DEFAULT= M_PARAMETER_TYPES;
/** /**
* Default qualify options (All except Root and Package) * Default qualify options (All except Root)
*/ */
public final static int DEFAULT_QUALIFIED= F_FULLY_QUALIFIED | M_FULLY_QUALIFIED | I_FULLY_QUALIFIED | T_FULLY_QUALIFIED | D_QUALIFIED | CF_QUALIFIED | CU_QUALIFIED; public final static int DEFAULT_QUALIFIED= F_FULLY_QUALIFIED | M_FULLY_QUALIFIED | T_FULLY_QUALIFIED | TU_QUALIFIED;
/** /**
* Default post qualify options (All except Root and Package) * Default post qualify options (All except Root)
*/ */
public final static int DEFAULT_POST_QUALIFIED= F_POST_QUALIFIED | M_POST_QUALIFIED | I_POST_QUALIFIED | T_POST_QUALIFIED | D_POST_QUALIFIED | CF_POST_QUALIFIED | CU_POST_QUALIFIED; public final static int DEFAULT_POST_QUALIFIED= F_POST_QUALIFIED | M_POST_QUALIFIED | T_POST_QUALIFIED | TU_POST_QUALIFIED;
public final static String CONCAT_STRING= CUIMessages.getString("CElementLabels.concat_string"); // " - "; //$NON-NLS-1$ public final static String CONCAT_STRING= CUIMessages.getString("CElementLabels.concat_string"); // " - "; //$NON-NLS-1$
@ -299,10 +231,14 @@ public class CElementLabels {
switch (type) { switch (type) {
case ICElement.C_METHOD : case ICElement.C_METHOD :
case ICElement.C_METHOD_DECLARATION: case ICElement.C_METHOD_DECLARATION:
case ICElement.C_TEMPLATE_METHOD:
case ICElement.C_TEMPLATE_METHOD_DECLARATION:
getMethodLabel( (IMethodDeclaration) element, flags, buf ); getMethodLabel( (IMethodDeclaration) element, flags, buf );
break; break;
case ICElement.C_FUNCTION: case ICElement.C_FUNCTION:
case ICElement.C_FUNCTION_DECLARATION: case ICElement.C_FUNCTION_DECLARATION:
case ICElement.C_TEMPLATE_FUNCTION:
case ICElement.C_TEMPLATE_FUNCTION_DECLARATION:
getFunctionLabel( (IFunctionDeclaration) element, flags, buf); getFunctionLabel( (IFunctionDeclaration) element, flags, buf);
break; break;
case ICElement.C_FIELD : case ICElement.C_FIELD :
@ -316,6 +252,12 @@ public class CElementLabels {
case ICElement.C_STRUCT: case ICElement.C_STRUCT:
case ICElement.C_UNION: case ICElement.C_UNION:
case ICElement.C_ENUMERATION: case ICElement.C_ENUMERATION:
case ICElement.C_TEMPLATE_CLASS:
case ICElement.C_TEMPLATE_STRUCT:
case ICElement.C_TEMPLATE_UNION:
case ICElement.C_TEMPLATE_CLASS_DECLARATION:
case ICElement.C_TEMPLATE_STRUCT_DECLARATION:
case ICElement.C_TEMPLATE_UNION_DECLARATION:
getTypeLabel( element, flags, buf ); getTypeLabel( element, flags, buf );
break; break;
case ICElement.C_UNIT: case ICElement.C_UNIT:
@ -360,23 +302,25 @@ public class CElementLabels {
if( getFlag( flags, M_FULLY_QUALIFIED ) ){ if( getFlag( flags, M_FULLY_QUALIFIED ) ){
ICElement parent = method.getParent(); ICElement parent = method.getParent();
if (parent != null && parent.exists() && !(parent instanceof ITranslationUnit)) { if (parent != null && parent.exists() && !(parent instanceof ITranslationUnit)) {
getTypeLabel( parent, T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( parent, T_FULLY_QUALIFIED, buf );
buf.append( "::" ); //$NON-NLS-1$ buf.append( "::" ); //$NON-NLS-1$
} }
} }
buf.append( method.getElementName() ); buf.append( method.getElementName() );
//template parameters
if (method instanceof ITemplate) {
getTemplateParameters((ITemplate)method, flags, buf);
}
//parameters //parameters
if( getFlag( flags, M_PARAMETER_TYPES | M_PARAMETER_NAMES ) ) { if( getFlag( flags, M_PARAMETER_TYPES ) ) {
buf.append('('); buf.append('(');
String[] types = getFlag(flags, M_PARAMETER_TYPES) ? method.getParameterTypes() : null; String[] types = method.getParameterTypes();
String[] names = null;//(getFlag(flags, M_PARAMETER_NAMES) && method.exists()) ? method.getParameterNames() : null;
int nParams = ( types != null ) ? types.length : names.length; for (int i= 0; i < types.length; i++) {
for (int i= 0; i < nParams; i++) {
if (i > 0) { if (i > 0) {
buf.append( COMMA_STRING ); buf.append( COMMA_STRING );
} }
@ -384,13 +328,6 @@ public class CElementLabels {
if (types != null) { if (types != null) {
buf.append( types[i] ); buf.append( types[i] );
} }
if (names != null) {
if (types != null) {
buf.append(' ');
}
buf.append( names[i] );
}
} }
buf.append(')'); buf.append(')');
} }
@ -418,7 +355,7 @@ public class CElementLabels {
// post qualification // post qualification
if( getFlag(flags, M_POST_QUALIFIED)) { if( getFlag(flags, M_POST_QUALIFIED)) {
buf.append( CONCAT_STRING ); buf.append( CONCAT_STRING );
getTypeLabel( method.getParent(), T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( method.getParent(), T_FULLY_QUALIFIED, buf );
} }
if( getFlag(flags, MF_POST_FILE_QUALIFIED)) { if( getFlag(flags, MF_POST_FILE_QUALIFIED)) {
IPath path= method.getPath(); IPath path= method.getPath();
@ -432,6 +369,22 @@ public class CElementLabels {
} }
} }
private static void getTemplateParameters(ITemplate template, int flags, StringBuffer buf) {
if (getFlag(flags, TEMPLATE_PARAMETERS)) {
String[] types = template.getTemplateParameterTypes();
buf.append('<');
if (types != null) {
for (int i= 0; i < types.length; i++) {
if (i > 0) {
buf.append( ',' );
}
buf.append( types[i] );
}
}
buf.append('>');
}
}
public static void getFieldLabel(IField field, int flags, StringBuffer buf ) { public static void getFieldLabel(IField field, int flags, StringBuffer buf ) {
try { try {
//return type //return type
@ -444,7 +397,7 @@ public class CElementLabels {
if( getFlag( flags, F_FULLY_QUALIFIED ) ){ if( getFlag( flags, F_FULLY_QUALIFIED ) ){
ICElement parent = field.getParent(); ICElement parent = field.getParent();
if (parent != null && parent.exists()) { if (parent != null && parent.exists()) {
getTypeLabel( parent, T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( parent, T_FULLY_QUALIFIED, buf );
buf.append( "::" ); //$NON-NLS-1$ buf.append( "::" ); //$NON-NLS-1$
} }
} }
@ -459,7 +412,7 @@ public class CElementLabels {
// post qualification // post qualification
if( getFlag(flags, F_POST_QUALIFIED)) { if( getFlag(flags, F_POST_QUALIFIED)) {
buf.append( CONCAT_STRING ); buf.append( CONCAT_STRING );
getTypeLabel( field.getParent(), T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( field.getParent(), T_FULLY_QUALIFIED, buf );
} }
if( getFlag(flags, MF_POST_FILE_QUALIFIED)) { if( getFlag(flags, MF_POST_FILE_QUALIFIED)) {
IPath path= field.getPath(); IPath path= field.getPath();
@ -485,7 +438,7 @@ public class CElementLabels {
if( getFlag( flags, F_FULLY_QUALIFIED ) ){ if( getFlag( flags, F_FULLY_QUALIFIED ) ){
ICElement parent = var.getParent(); ICElement parent = var.getParent();
if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) { if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) {
getTypeLabel( parent, T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( parent, T_FULLY_QUALIFIED, buf );
buf.append( "::" ); //$NON-NLS-1$ buf.append( "::" ); //$NON-NLS-1$
} }
} }
@ -502,7 +455,7 @@ public class CElementLabels {
ICElement parent = var.getParent(); ICElement parent = var.getParent();
if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) { if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) {
buf.append( CONCAT_STRING ); buf.append( CONCAT_STRING );
getTypeLabel( var.getParent(), T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( var.getParent(), T_FULLY_QUALIFIED, buf );
} }
} }
if( getFlag(flags, MF_POST_FILE_QUALIFIED)) { if( getFlag(flags, MF_POST_FILE_QUALIFIED)) {
@ -528,23 +481,25 @@ public class CElementLabels {
if( getFlag( flags, M_FULLY_QUALIFIED ) ){ if( getFlag( flags, M_FULLY_QUALIFIED ) ){
ICElement parent = func.getParent(); ICElement parent = func.getParent();
if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) { if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) {
getTypeLabel( parent, T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( parent, T_FULLY_QUALIFIED, buf );
buf.append( "::" ); //$NON-NLS-1$ buf.append( "::" ); //$NON-NLS-1$
} }
} }
buf.append( func.getElementName() ); buf.append( func.getElementName() );
//template parameters
if (func instanceof ITemplate) {
getTemplateParameters((ITemplate)func, flags, buf);
}
//parameters //parameters
if( getFlag( flags, M_PARAMETER_TYPES | M_PARAMETER_NAMES ) ) { if( getFlag( flags, M_PARAMETER_TYPES ) ) {
buf.append('('); buf.append('(');
String[] types = getFlag(flags, M_PARAMETER_TYPES) ? func.getParameterTypes() : null; String[] types = func.getParameterTypes();
String[] names = null;//(getFlag(flags, M_PARAMETER_NAMES) && method.exists()) ? method.getParameterNames() : null;
int nParams = ( types != null ) ? types.length : names.length; for (int i= 0; i < types.length; i++) {
for (int i= 0; i < nParams; i++) {
if (i > 0) { if (i > 0) {
buf.append( COMMA_STRING ); buf.append( COMMA_STRING );
} }
@ -552,13 +507,6 @@ public class CElementLabels {
if (types != null) { if (types != null) {
buf.append( types[i] ); buf.append( types[i] );
} }
if (names != null) {
if (types != null) {
buf.append(' ');
}
buf.append( names[i] );
}
} }
buf.append(')'); buf.append(')');
} }
@ -588,7 +536,7 @@ public class CElementLabels {
ICElement parent = func.getParent(); ICElement parent = func.getParent();
if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) { if (parent != null && parent.exists() && parent.getElementType() == ICElement.C_NAMESPACE) {
buf.append( CONCAT_STRING ); buf.append( CONCAT_STRING );
getTypeLabel( func.getParent(), T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf ); getTypeLabel( func.getParent(), T_FULLY_QUALIFIED, buf );
} }
} }
if( getFlag(flags, MF_POST_FILE_QUALIFIED)) { if( getFlag(flags, MF_POST_FILE_QUALIFIED)) {
@ -604,9 +552,6 @@ public class CElementLabels {
* Appends the label for a source root to a StringBuffer. Considers the ROOT_* flags. * Appends the label for a source root to a StringBuffer. Considers the ROOT_* flags.
*/ */
public static void getSourceRootLabel(ISourceRoot root, int flags, StringBuffer buf) { public static void getSourceRootLabel(ISourceRoot root, int flags, StringBuffer buf) {
// if (root.isArchive())
// getArchiveLabel(root, flags, buf);
// else
getFolderLabel(root, flags, buf); getFolderLabel(root, flags, buf);
} }
@ -620,7 +565,7 @@ public class CElementLabels {
private static void getFolderLabel(ICContainer container, int flags, StringBuffer buf) { private static void getFolderLabel(ICContainer container, int flags, StringBuffer buf) {
IResource resource= container.getResource(); IResource resource= container.getResource();
boolean rootQualified= getFlag(flags, ROOT_QUALIFIED); boolean rootQualified= getFlag(flags, ROOT_QUALIFIED);
boolean referencedQualified= getFlag(flags, REFERENCED_ROOT_POST_QUALIFIED) boolean referencedQualified= getFlag(flags, PROJECT_POST_QUALIFIED)
&& (container instanceof ISourceRoot && CModelUtil.isReferenced((ISourceRoot)container)) && (container instanceof ISourceRoot && CModelUtil.isReferenced((ISourceRoot)container))
&& resource != null; && resource != null;
if (rootQualified) { if (rootQualified) {
@ -654,10 +599,10 @@ public class CElementLabels {
buf.append(tu.getElementName()); buf.append(tu.getElementName());
} }
else { else {
if (getFlag(flags, CU_QUALIFIED)) { if (getFlag(flags, TU_QUALIFIED)) {
buf.append(path.toString()); buf.append(path.toString());
} }
else if (getFlag(flags, CU_POST_QUALIFIED)) { else if (getFlag(flags, TU_POST_QUALIFIED)) {
buf.append(path.lastSegment()); buf.append(path.lastSegment());
buf.append(CONCAT_STRING); buf.append(CONCAT_STRING);
buf.append(path.removeLastSegments(1)); buf.append(path.removeLastSegments(1));
@ -700,21 +645,10 @@ public class CElementLabels {
} }
buf.append(typeName); buf.append(typeName);
// // post qualification //template parameters
// if (getFlag(flags, T_POST_QUALIFIED)) { if (elem instanceof ITemplate) {
// buf.append(CONCAT_STRING); getTemplateParameters((ITemplate)elem, flags, buf);
// IType declaringType= type.getDeclaringType(); }
// if (declaringType != null) {
// getTypeLabel(declaringType, T_FULLY_QUALIFIED | (flags & P_COMPRESSED), buf);
// int parentType= type.getParent().getElementType();
// if (parentType == ICElement.METHOD || parentType == ICElement.FIELD || parentType == ICElement.INITIALIZER) { // anonymous or local
// buf.append('.');
// getElementLabel(type.getParent(), 0, buf);
// }
// } else {
// getPackageFragmentLabel(type.getPackageFragment(), (flags & P_COMPRESSED), buf);
// }
// }
} }
private static boolean getFlag(int flags, int flag) { private static boolean getFlag(int flags, int flag) {

View file

@ -28,7 +28,7 @@ import org.eclipse.jface.viewers.SelectionChangedEvent;
public class StatusBarUpdater implements ISelectionChangedListener { public class StatusBarUpdater implements ISelectionChangedListener {
private final int LABEL_FLAGS= CElementLabels.DEFAULT_QUALIFIED | CElementLabels.ROOT_POST_QUALIFIED | CElementLabels.APPEND_ROOT_PATH | private final int LABEL_FLAGS= CElementLabels.DEFAULT_QUALIFIED | CElementLabels.ROOT_POST_QUALIFIED | CElementLabels.APPEND_ROOT_PATH |
CElementLabels.M_PARAMETER_TYPES | CElementLabels.M_PARAMETER_NAMES | CElementLabels.M_APP_RETURNTYPE | CElementLabels.M_EXCEPTIONS | CElementLabels.M_PARAMETER_TYPES | CElementLabels.M_APP_RETURNTYPE | CElementLabels.M_EXCEPTIONS |
CElementLabels.F_APP_TYPE_SIGNATURE; CElementLabels.F_APP_TYPE_SIGNATURE;
private IStatusLineManager fStatusLineManager; private IStatusLineManager fStatusLineManager;

View file

@ -56,7 +56,6 @@ import org.eclipse.cdt.internal.ui.CPluginImages;
import org.eclipse.cdt.internal.ui.actions.SelectionConverter; import org.eclipse.cdt.internal.ui.actions.SelectionConverter;
import org.eclipse.cdt.internal.ui.viewsupport.AppearanceAwareLabelProvider; import org.eclipse.cdt.internal.ui.viewsupport.AppearanceAwareLabelProvider;
import org.eclipse.cdt.internal.ui.viewsupport.CElementImageProvider; import org.eclipse.cdt.internal.ui.viewsupport.CElementImageProvider;
import org.eclipse.cdt.internal.ui.viewsupport.CElementLabels;
import org.eclipse.cdt.internal.ui.viewsupport.DecoratingCLabelProvider; import org.eclipse.cdt.internal.ui.viewsupport.DecoratingCLabelProvider;
/** /**
@ -133,7 +132,7 @@ public class CElementWorkingSetPage extends WizardPage implements IWorkingSetPag
AppearanceAwareLabelProvider cElementLabelProvider= AppearanceAwareLabelProvider cElementLabelProvider=
new AppearanceAwareLabelProvider( new AppearanceAwareLabelProvider(
AppearanceAwareLabelProvider.DEFAULT_TEXTFLAGS | CElementLabels.P_COMPRESSED, AppearanceAwareLabelProvider.DEFAULT_TEXTFLAGS,
AppearanceAwareLabelProvider.DEFAULT_IMAGEFLAGS | CElementImageProvider.SMALL_ICONS AppearanceAwareLabelProvider.DEFAULT_IMAGEFLAGS | CElementImageProvider.SMALL_ICONS
); );

View file

@ -1,5 +1,5 @@
/******************************************************************************* /*******************************************************************************
* Copyright (c) 2000 2005 IBM Corporation and others. * Copyright (c) 2000, 2006 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials * All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0 * are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at * which accompanies this distribution, and is available at
@ -8,23 +8,20 @@
* Contributors: * Contributors:
* IBM Corporation - initial API and implementation * IBM Corporation - initial API and implementation
* QNX Software System * QNX Software System
* Anton Leherbauer (Wind River Systems)
*******************************************************************************/ *******************************************************************************/
package org.eclipse.cdt.ui; package org.eclipse.cdt.ui;
import org.eclipse.cdt.core.model.CModelException;
import org.eclipse.cdt.core.model.IBinary;
import org.eclipse.cdt.core.model.ICElement;
import org.eclipse.cdt.core.model.IFunctionDeclaration;
import org.eclipse.cdt.core.model.INamespace;
import org.eclipse.cdt.core.model.ITemplate;
import org.eclipse.cdt.core.model.ITypeDef;
import org.eclipse.cdt.core.model.IVariableDeclaration;
import org.eclipse.cdt.internal.ui.viewsupport.CElementImageProvider;
import org.eclipse.cdt.internal.ui.viewsupport.CElementLabels;
import org.eclipse.jface.viewers.LabelProvider; import org.eclipse.jface.viewers.LabelProvider;
import org.eclipse.swt.graphics.Image; import org.eclipse.swt.graphics.Image;
import org.eclipse.ui.model.WorkbenchLabelProvider; import org.eclipse.ui.model.WorkbenchLabelProvider;
import org.eclipse.cdt.core.model.ICElement;
import org.eclipse.cdt.internal.ui.viewsupport.CElementImageProvider;
import org.eclipse.cdt.internal.ui.viewsupport.CElementLabels;
import org.eclipse.cdt.internal.ui.viewsupport.CUILabelProvider;
/** /**
* The label provider for the c model elements. * The label provider for the c model elements.
*/ */
@ -87,6 +84,7 @@ public class CElementLabelProvider extends LabelProvider {
private WorkbenchLabelProvider fWorkbenchLabelProvider; private WorkbenchLabelProvider fWorkbenchLabelProvider;
protected CElementImageProvider fImageLabelProvider; protected CElementImageProvider fImageLabelProvider;
private CUILabelProvider fCElementLabelProvider;
private int fFlags; private int fFlags;
private int fImageFlags; private int fImageFlags;
@ -98,90 +96,15 @@ public class CElementLabelProvider extends LabelProvider {
public CElementLabelProvider(int flags) { public CElementLabelProvider(int flags) {
fWorkbenchLabelProvider= new WorkbenchLabelProvider(); fWorkbenchLabelProvider= new WorkbenchLabelProvider();
fImageLabelProvider= new CElementImageProvider(); fImageLabelProvider= new CElementImageProvider();
fFlags = flags; fFlags = flags;
fCElementLabelProvider= new CUILabelProvider(getTextFlags() | CElementLabels.TEMPLATE_PARAMETERS, getImageFlags());
} }
public String getText(Object element) { public String getText(Object element) {
if (element instanceof ICElement) { if (element instanceof ICElement) {
try { return fCElementLabelProvider.getText(element);
ICElement celem= (ICElement)element;
StringBuffer name = new StringBuffer();
switch(celem.getElementType()){
case ICElement.C_FIELD:
case ICElement.C_VARIABLE:
case ICElement.C_VARIABLE_DECLARATION:
IVariableDeclaration vDecl = (IVariableDeclaration) celem;
name.append(vDecl.getElementName());
if((vDecl.getTypeName() != null) &&(vDecl.getTypeName().length() > 0)){
name.append(" : "); //$NON-NLS-1$
name.append(vDecl.getTypeName());
}
break;
case ICElement.C_FUNCTION:
case ICElement.C_FUNCTION_DECLARATION:
case ICElement.C_METHOD:
case ICElement.C_METHOD_DECLARATION:
IFunctionDeclaration fDecl = (IFunctionDeclaration) celem;
name.append(fDecl.getSignature());
if((fDecl.getReturnType() != null) &&(fDecl.getReturnType().length() > 0)){
name.append(" : "); //$NON-NLS-1$
name.append(fDecl.getReturnType());
}
break;
case ICElement.C_STRUCT:
case ICElement.C_UNION:
case ICElement.C_ENUMERATION:
if((celem.getElementName() != null) && (celem.getElementName().length() > 0)){
name.append(celem.getElementName());
} else if (celem instanceof IVariableDeclaration) {
IVariableDeclaration varDecl = (IVariableDeclaration) celem;
name.append(varDecl.getTypeName());
}
break;
case ICElement.C_TYPEDEF:
ITypeDef tDecl = (ITypeDef) celem;
name.append(tDecl.getElementName());
if((tDecl.getTypeName() != null) &&(tDecl.getTypeName().length() > 0)){
name.append(" : "); //$NON-NLS-1$
name.append(tDecl.getTypeName());
}
break;
case ICElement.C_NAMESPACE:
if((celem.getElementName() != null) && (celem.getElementName().length() > 0)){
name.append(celem.getElementName());
} else if (celem instanceof INamespace) {
INamespace nDecl = (INamespace) celem;
name.append(nDecl.getTypeName());
}
break;
case ICElement.C_TEMPLATE_CLASS:
case ICElement.C_TEMPLATE_FUNCTION:
case ICElement.C_TEMPLATE_METHOD:
case ICElement.C_TEMPLATE_STRUCT:
case ICElement.C_TEMPLATE_UNION:
case ICElement.C_TEMPLATE_VARIABLE:
ITemplate template = (ITemplate) celem;
String signature = template.getTemplateSignature();
name.append(signature);
break;
default:
name.append(celem.getElementName());
break;
}
if (celem instanceof IBinary) {
IBinary bin = (IBinary)celem;
name.append(" - [" + bin.getCPU() + (bin.isLittleEndian() ? "le" : "be") + "]"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
}
return name.toString();
} catch (CModelException e) {
CUIPlugin.getDefault().log(e);
}
} }
return fWorkbenchLabelProvider.getText(element); return fWorkbenchLabelProvider.getText(element);
} }
@ -191,6 +114,10 @@ public class CElementLabelProvider extends LabelProvider {
} }
public void dispose() { public void dispose() {
if (fCElementLabelProvider != null) {
fCElementLabelProvider.dispose();
fCElementLabelProvider= null;
}
if (fWorkbenchLabelProvider != null) { if (fWorkbenchLabelProvider != null) {
fWorkbenchLabelProvider.dispose(); fWorkbenchLabelProvider.dispose();
fWorkbenchLabelProvider= null; fWorkbenchLabelProvider= null;