X-Git-Url: http://git.phpeclipse.com diff --git a/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/ui/preferences/MembersOrderPreferenceCache.java b/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/ui/preferences/MembersOrderPreferenceCache.java index af66a6f..cf34946 100644 --- a/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/ui/preferences/MembersOrderPreferenceCache.java +++ b/net.sourceforge.phpeclipse/src/net/sourceforge/phpdt/internal/ui/preferences/MembersOrderPreferenceCache.java @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 2000, 2003 IBM Corporation and others. + * Copyright (c) 2000, 2004 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Common Public License v1.0 * which accompanies this distribution, and is available at @@ -12,79 +12,185 @@ package net.sourceforge.phpdt.internal.ui.preferences; import java.util.StringTokenizer; +import net.sourceforge.phpdt.core.Flags; import net.sourceforge.phpdt.ui.PreferenceConstants; import org.eclipse.jface.preference.IPreferenceStore; import org.eclipse.jface.util.IPropertyChangeListener; import org.eclipse.jface.util.PropertyChangeEvent; - /** - */ + */ public class MembersOrderPreferenceCache implements IPropertyChangeListener { - - public static final int TYPE_INDEX= 0; - public static final int CONSTRUCTORS_INDEX= 1; - public static final int METHOD_INDEX= 2; - public static final int FIELDS_INDEX= 3; - public static final int INIT_INDEX= 4; - public static final int STATIC_FIELDS_INDEX= 5; - public static final int STATIC_INIT_INDEX= 6; - public static final int STATIC_METHODS_INDEX= 7; - public static final int N_ENTRIES= STATIC_METHODS_INDEX + 1; - - private int[] fOffsets= null; + + public static final int TYPE_INDEX = 0; + + public static final int CONSTRUCTORS_INDEX = 1; + + public static final int METHOD_INDEX = 2; + + public static final int FIELDS_INDEX = 3; + + public static final int INIT_INDEX = 4; + + public static final int STATIC_FIELDS_INDEX = 5; + + public static final int STATIC_INIT_INDEX = 6; + + public static final int STATIC_METHODS_INDEX = 7; + + public static final int N_CATEGORIES = STATIC_METHODS_INDEX + 1; + + private static final int PUBLIC_INDEX = 0; + + private static final int PRIVATE_INDEX = 1; + + private static final int PROTECTED_INDEX = 2; + + private static final int DEFAULT_INDEX = 3; + + private static final int N_VISIBILITIES = DEFAULT_INDEX + 1; + + private int[] fCategoryOffsets = null; + + private boolean fSortByVisibility; + + private int[] fVisibilityOffsets = null; + + public MembersOrderPreferenceCache() { + fCategoryOffsets = null; + fSortByVisibility = PreferenceConstants + .getPreferenceStore() + .getBoolean( + PreferenceConstants.APPEARANCE_ENABLE_VISIBILITY_SORT_ORDER); + fVisibilityOffsets = null; + } + + public static boolean isMemberOrderProperty(String property) { + return PreferenceConstants.APPEARANCE_MEMBER_SORT_ORDER + .equals(property) + || PreferenceConstants.APPEARANCE_VISIBILITY_SORT_ORDER + .equals(property) + || PreferenceConstants.APPEARANCE_ENABLE_VISIBILITY_SORT_ORDER + .equals(property); + } public void propertyChange(PropertyChangeEvent event) { - if (PreferenceConstants.APPEARANCE_MEMBER_SORT_ORDER.equals(event.getProperty())) { - fOffsets= null; + String property = event.getProperty(); + + if (PreferenceConstants.APPEARANCE_MEMBER_SORT_ORDER.equals(property)) { + fCategoryOffsets = null; + } else if (PreferenceConstants.APPEARANCE_VISIBILITY_SORT_ORDER + .equals(property)) { + fVisibilityOffsets = null; + } else if (PreferenceConstants.APPEARANCE_ENABLE_VISIBILITY_SORT_ORDER + .equals(property)) { + fSortByVisibility = PreferenceConstants + .getPreferenceStore() + .getBoolean( + PreferenceConstants.APPEARANCE_ENABLE_VISIBILITY_SORT_ORDER); } } - public int getIndex(int kind) { - if (fOffsets == null) { - fOffsets= getOffsets(); + public int getCategoryIndex(int kind) { + if (fCategoryOffsets == null) { + fCategoryOffsets = getCategoryOffsets(); } - return fOffsets[kind]; + return fCategoryOffsets[kind]; } - - private int[] getOffsets() { - int[] offsets= new int[N_ENTRIES]; - IPreferenceStore store= PreferenceConstants.getPreferenceStore(); - String key= PreferenceConstants.APPEARANCE_MEMBER_SORT_ORDER; - boolean success= fillOffsetsFromPreferenceString(store.getString(key), offsets); + + private int[] getCategoryOffsets() { + int[] offsets = new int[N_CATEGORIES]; + IPreferenceStore store = PreferenceConstants.getPreferenceStore(); + String key = PreferenceConstants.APPEARANCE_MEMBER_SORT_ORDER; + boolean success = fillCategoryOffsetsFromPreferenceString(store + .getString(key), offsets); if (!success) { store.setToDefault(key); - fillOffsetsFromPreferenceString(store.getDefaultString(key), offsets); + fillCategoryOffsetsFromPreferenceString( + store.getDefaultString(key), offsets); } return offsets; - } - - private boolean fillOffsetsFromPreferenceString(String str, int[] offsets) { - StringTokenizer tokenizer= new StringTokenizer(str, ","); //$NON-NLS-1$ - int i= 0; + } + + private boolean fillCategoryOffsetsFromPreferenceString(String str, + int[] offsets) { + StringTokenizer tokenizer = new StringTokenizer(str, ","); //$NON-NLS-1$ + int i = 0; while (tokenizer.hasMoreTokens()) { - String token= tokenizer.nextToken().trim(); + String token = tokenizer.nextToken().trim(); if ("T".equals(token)) { //$NON-NLS-1$ - offsets[TYPE_INDEX]= i++; + offsets[TYPE_INDEX] = i++; } else if ("M".equals(token)) { //$NON-NLS-1$ - offsets[METHOD_INDEX]= i++; + offsets[METHOD_INDEX] = i++; } else if ("F".equals(token)) { //$NON-NLS-1$ - offsets[FIELDS_INDEX]= i++; + offsets[FIELDS_INDEX] = i++; } else if ("I".equals(token)) { //$NON-NLS-1$ - offsets[INIT_INDEX]= i++; + offsets[INIT_INDEX] = i++; } else if ("SF".equals(token)) { //$NON-NLS-1$ - offsets[STATIC_FIELDS_INDEX]= i++; + offsets[STATIC_FIELDS_INDEX] = i++; } else if ("SI".equals(token)) { //$NON-NLS-1$ - offsets[STATIC_INIT_INDEX]= i++; + offsets[STATIC_INIT_INDEX] = i++; } else if ("SM".equals(token)) { //$NON-NLS-1$ - offsets[STATIC_METHODS_INDEX]= i++; + offsets[STATIC_METHODS_INDEX] = i++; } else if ("C".equals(token)) { //$NON-NLS-1$ - offsets[CONSTRUCTORS_INDEX]= i++; + offsets[CONSTRUCTORS_INDEX] = i++; + } + } + return i == N_CATEGORIES; + } + + public boolean isSortByVisibility() { + return fSortByVisibility; + } + + public int getVisibilityIndex(int modifierFlags) { + if (fVisibilityOffsets == null) { + fVisibilityOffsets = getVisibilityOffsets(); + } + int kind = DEFAULT_INDEX; + if (Flags.isPublic(modifierFlags)) { + kind = PUBLIC_INDEX; + } else if (Flags.isProtected(modifierFlags)) { + kind = PROTECTED_INDEX; + } else if (Flags.isPrivate(modifierFlags)) { + kind = PRIVATE_INDEX; + } + + return fVisibilityOffsets[kind]; + } + + private int[] getVisibilityOffsets() { + int[] offsets = new int[N_VISIBILITIES]; + IPreferenceStore store = PreferenceConstants.getPreferenceStore(); + String key = PreferenceConstants.APPEARANCE_VISIBILITY_SORT_ORDER; + boolean success = fillVisibilityOffsetsFromPreferenceString(store + .getString(key), offsets); + if (!success) { + store.setToDefault(key); + fillVisibilityOffsetsFromPreferenceString(store + .getDefaultString(key), offsets); + } + return offsets; + } + + private boolean fillVisibilityOffsetsFromPreferenceString(String str, + int[] offsets) { + StringTokenizer tokenizer = new StringTokenizer(str, ","); //$NON-NLS-1$ + int i = 0; + while (tokenizer.hasMoreTokens()) { + String token = tokenizer.nextToken().trim(); + if ("B".equals(token)) { //$NON-NLS-1$ + offsets[PUBLIC_INDEX] = i++; + } else if ("V".equals(token)) { //$NON-NLS-1$ + offsets[PRIVATE_INDEX] = i++; + } else if ("R".equals(token)) { //$NON-NLS-1$ + offsets[PROTECTED_INDEX] = i++; + } else if ("D".equals(token)) { //$NON-NLS-1$ + offsets[DEFAULT_INDEX] = i++; } } - return i == N_ENTRIES; + return i == N_VISIBILITIES; } - }