From bee5ed3c6202277c69a937a65f0abe3f268777ed Mon Sep 17 00:00:00 2001
From: Davide Steduto
Date: Mon, 5 Jun 2017 19:33:43 +0200
Subject: [PATCH] Resolved #381 - Better Log system
---
.../samples/flexibleadapter/MainActivity.java | 34 +-
.../eu/davidea/fastscroller/FastScroller.java | 14 +-
.../flexibleadapter/AnimatorAdapter.java | 99 +++--
.../flexibleadapter/FlexibleAdapter.java | 355 ++++++++----------
.../flexibleadapter/SelectableAdapter.java | 50 ++-
.../common/FlexibleItemAnimator.java | 32 +-
.../common/TopSnappedSmoothScroller.java | 3 +-
.../helpers/ActionModeHelper.java | 12 +-
.../helpers/AnimatorHelper.java | 17 +-
.../helpers/ItemTouchHelperCallback.java | 1 -
.../helpers/StickyHeaderHelper.java | 17 +-
.../flexibleadapter/helpers/UndoHelper.java | 2 +-
.../flexibleadapter/items/IFilterable.java | 2 +-
.../eu/davidea/flexibleadapter/utils/Log.java | 266 +++++++++++++
14 files changed, 554 insertions(+), 350 deletions(-)
create mode 100644 flexible-adapter/src/main/java/eu/davidea/flexibleadapter/utils/Log.java
diff --git a/flexible-adapter-app/src/main/java/eu/davidea/samples/flexibleadapter/MainActivity.java b/flexible-adapter-app/src/main/java/eu/davidea/samples/flexibleadapter/MainActivity.java
index 13be3acf..53a6961d 100644
--- a/flexible-adapter-app/src/main/java/eu/davidea/samples/flexibleadapter/MainActivity.java
+++ b/flexible-adapter-app/src/main/java/eu/davidea/samples/flexibleadapter/MainActivity.java
@@ -30,7 +30,6 @@
import android.support.v7.widget.helper.ItemTouchHelper;
import android.text.InputType;
import android.transition.Fade;
-import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
@@ -50,6 +49,8 @@
import eu.davidea.flexibleadapter.helpers.UndoHelper;
import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
import eu.davidea.flexibleadapter.items.IFlexible;
+import eu.davidea.flexibleadapter.utils.Log;
+import eu.davidea.flexibleadapter.utils.Log.Level;
import eu.davidea.samples.flexibleadapter.dialogs.EditItemDialog;
import eu.davidea.samples.flexibleadapter.dialogs.MessageDialog;
import eu.davidea.samples.flexibleadapter.fragments.AbstractFragment;
@@ -112,8 +113,6 @@ public class MainActivity extends AppCompatActivity implements
NavigationView.OnNavigationItemSelectedListener,
OnFragmentInteractionListener {
- public static final String TAG = MainActivity.class.getSimpleName();
-
/**
* Bundle key representing the Active Fragment
*/
@@ -170,8 +169,8 @@ protected void onCreate(Bundle savedInstanceState) {
}
setContentView(R.layout.activity_main);
- Log.d(TAG, "onCreate");
- FlexibleAdapter.enableLogs(true);
+ FlexibleAdapter.enableLogs(Level.DEBUG);
+ Log.v("onCreate");
// Initialize Toolbar, Drawer & FAB
initializeToolbar();
@@ -187,7 +186,7 @@ protected void onCreate(Bundle savedInstanceState) {
@Override
public void onSaveInstanceState(Bundle outState) {
- Log.v(TAG, "onSaveInstanceState!");
+ Log.v("onSaveInstanceState!");
mAdapter.onSaveInstanceState(outState);
getSupportFragmentManager().putFragment(outState, STATE_ACTIVE_FRAGMENT, mFragment);
super.onSaveInstanceState(outState);
@@ -264,7 +263,7 @@ public void onRefresh() {
}
private void initializeToolbar() {
- Log.d(TAG, "initializeToolbar as actionBar");
+ Log.d("initializeToolbar as actionBar");
mToolbar = (Toolbar) findViewById(R.id.toolbar);
mHeaderView = (HeaderView) findViewById(R.id.toolbar_header_view);
mHeaderView.bindTo(getString(R.string.app_name), getString(R.string.overall));
@@ -446,7 +445,7 @@ private void showFab() {
@Override
public void initSearchView(final Menu menu) {
// Associate searchable configuration with the SearchView
- Log.d(TAG, "onCreateOptionsMenu setup SearchView!");
+ Log.d("onCreateOptionsMenu setup SearchView!");
SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
MenuItem searchItem = menu.findItem(R.id.action_search);
if (searchItem != null) {
@@ -482,7 +481,7 @@ public boolean onMenuItemActionCollapse(MenuItem item) {
@Override
public boolean onQueryTextChange(String newText) {
if (mAdapter.hasNewSearchText(newText)) {
- Log.d(TAG, "onQueryTextChange newText: " + newText);
+ Log.d("onQueryTextChange newText: " + newText);
mAdapter.setSearchText(newText);
// Fill and Filter mItems with your custom list and automatically animate the changes
@@ -499,7 +498,7 @@ public boolean onQueryTextChange(String newText) {
@Override
public boolean onQueryTextSubmit(String query) {
- Log.v(TAG, "onQueryTextSubmit called!");
+ Log.v("onQueryTextSubmit called!");
return onQueryTextChange(query);
}
@@ -509,12 +508,12 @@ public boolean onQueryTextSubmit(String query) {
@Override
public boolean onPrepareOptionsMenu(Menu menu) {
- Log.v(TAG, "onPrepareOptionsMenu called!");
+ Log.v("onPrepareOptionsMenu called!");
if (mSearchView != null) {
//Has searchText?
if (!mAdapter.hasSearchText()) {
- Log.d(TAG, "onPrepareOptionsMenu Clearing SearchView!");
+ Log.d("onPrepareOptionsMenu Clearing SearchView!");
mSearchView.setIconified(true);// This also clears the text in SearchView widget
} else {
//Necessary after the restoreInstanceState
@@ -701,7 +700,7 @@ public boolean onItemClick(int position) {
// Action on elements are allowed if Mode is IDLE, otherwise selection has priority
if (mAdapter.getMode() != SelectableAdapter.MODE_IDLE && mActionModeHelper != null) {
boolean activate = mActionModeHelper.onClick(position);
- Log.d(TAG, "Last activated position " + mActionModeHelper.getActivatedPosition());
+ Log.d("Last activated position %s", mActionModeHelper.getActivatedPosition());
return activate;
} else {
// Notify the active callbacks or implement a custom action onClick
@@ -749,8 +748,7 @@ public void onItemMove(int fromPosition, int toPosition) {
@Override
public void onItemSwipe(final int position, int direction) {
- Log.i(TAG, "onItemSwipe position=" + position +
- " direction=" + (direction == ItemTouchHelper.LEFT ? "LEFT" : "RIGHT"));
+ Log.i("onItemSwipe position=%s direction=%s", position, (direction == ItemTouchHelper.LEFT ? "LEFT" : "RIGHT"));
// Option 1 FULL_SWIPE: Direct action no Undo Action
// Do something based on direction when item has been swiped:
@@ -829,7 +827,7 @@ public void onPostAction() {
*/
@Override
public void onUpdateEmptyView(int size) {
- Log.d(TAG, "onUpdateEmptyView size=" + size);
+ Log.d("onUpdateEmptyView size=%s", size);
FastScroller fastScroller = (FastScroller) findViewById(R.id.fast_scroller);
View emptyView = findViewById(R.id.empty_view);
TextView emptyText = (TextView) findViewById(R.id.empty_text);
@@ -891,12 +889,12 @@ public void onDeleteConfirmed(int action) {
case R.layout.recycler_sub_item:
SubItem subItem = (SubItem) adapterItem;
DatabaseService.getInstance().removeSubItem(mAdapter.getExpandableOfDeletedChild(subItem), subItem);
- Log.d(TAG, "Confirm removed " + subItem);
+ Log.d("Confirm removed %s", subItem);
break;
case R.layout.recycler_simple_item:
case R.layout.recycler_expandable_item:
DatabaseService.getInstance().removeItem(adapterItem);
- Log.d(TAG, "Confirm removed " + adapterItem);
+ Log.d("Confirm removed %s", adapterItem);
break;
}
}
diff --git a/flexible-adapter/src/main/java/eu/davidea/fastscroller/FastScroller.java b/flexible-adapter/src/main/java/eu/davidea/fastscroller/FastScroller.java
index 441680fb..743556b0 100644
--- a/flexible-adapter/src/main/java/eu/davidea/fastscroller/FastScroller.java
+++ b/flexible-adapter/src/main/java/eu/davidea/fastscroller/FastScroller.java
@@ -32,7 +32,6 @@
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.util.AttributeSet;
-import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
@@ -47,6 +46,7 @@
import java.util.List;
import eu.davidea.flexibleadapter.R;
+import eu.davidea.flexibleadapter.utils.Log;
import static java.lang.annotation.RetentionPolicy.SOURCE;
@@ -56,9 +56,9 @@
* @see
* github.com/AndroidDeveloperLB/LollipopContactsRecyclerViewFastScroller
* @since Up to the date 23/01/2016
- *
23/01/2016 Added onFastScrollerStateChange in the listener
- *
10/03/2017 Added autoHide, bubblePosition, bubbleEnabled, ignoreTouchesOutsideHandle (thanks to @arpinca)
- *
22/04/2017 Added minimum scroll threshold
+ *
23/01/2016 Added onFastScrollerStateChange in the listener
+ *
10/03/2017 Added autoHide, bubblePosition, bubbleEnabled, ignoreTouchesOutsideHandle (thanks to @arpinca)
+ *
22/04/2017 Added minimum scroll threshold
*/
public class FastScroller extends FrameLayout {
@@ -205,7 +205,7 @@ protected void notifyScrollStateChange(boolean scrolling) {
}
/**
- * Layout customization.
+ * Layout customization.
* Color for Selected State is the bubbleAndHandleColor defined inside the Drawables.
*
* @param layoutResId Main layout of Fast Scroller
@@ -232,7 +232,7 @@ public void setViewsToUse(@LayoutRes int layoutResId, @IdRes int bubbleResId, @I
}
/**
- * Layout customization
+ * Layout customization
* Color for Selected State is also customized by the user.
*
* @param layoutResId Main layout of Fast Scroller
@@ -288,7 +288,7 @@ public void setBubbleAndHandleColor(@ColorInt int color) {
handle.setImageDrawable(stateListDrawable);
} catch (Exception e) {
// This should never happen in theory (Java Reflection Exception)
- Log.e(FastScroller.class.getSimpleName(), "Exception while setting Bubble and Handle Color", e);
+ Log.wtf(e, "Exception while setting Bubble and Handle Color");
}
}
}
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/AnimatorAdapter.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/AnimatorAdapter.java
index 4e0e4dbf..e665bd7d 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/AnimatorAdapter.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/AnimatorAdapter.java
@@ -26,7 +26,6 @@
import android.support.annotation.NonNull;
import android.support.v4.view.ViewCompat;
import android.support.v7.widget.RecyclerView;
-import android.util.Log;
import android.util.SparseArray;
import android.view.View;
import android.view.animation.Interpolator;
@@ -37,6 +36,7 @@
import java.util.List;
import eu.davidea.flexibleadapter.helpers.AnimatorHelper;
+import eu.davidea.flexibleadapter.utils.Log;
import eu.davidea.viewholders.FlexibleViewHolder;
import static eu.davidea.flexibleadapter.utils.FlexibleUtils.getClassName;
@@ -52,14 +52,12 @@
* @see FlexibleAdapter
* @see SelectableAdapter
* @since 10/01/2016 Created
- *
30/01/2016 Class now extends {@link SelectableAdapter}
- *
13/09/2016 {@link #animateView(RecyclerView.ViewHolder, int)} is now automatically called
+ *
30/01/2016 Class now extends {@link SelectableAdapter}
+ *
13/09/2016 {@link #animateView(RecyclerView.ViewHolder, int)} is now automatically called
*/
@SuppressWarnings({"unused", "WeakerAccess"})
public abstract class AnimatorAdapter extends SelectableAdapter {
- private static final String TAG = AnimatorAdapter.class.getSimpleName();
-
private Interpolator mInterpolator = new LinearInterpolator();
private AnimatorAdapterDataObserver mAnimatorNotifierObserver;
private boolean mEntryStep = true;
@@ -108,7 +106,7 @@ private enum AnimatorEnum {
AnimatorAdapter(boolean stableIds) {
super();
setHasStableIds(stableIds);
- if (DEBUG) Log.i("FlexibleAdapter", "Initialized with StableIds=" + stableIds);
+ Log.iTag("FlexibleAdapter", "Initialized with StableIds=" + stableIds);
//Get notified when an item is changed (should skip animation)
mAnimatorNotifierObserver = new AnimatorAdapterDataObserver();
@@ -137,7 +135,7 @@ void setScrollAnimate(boolean animate) {
* @since 5.0.0-b1
*/
public AnimatorAdapter setAnimationInitialDelay(long initialDelay) {
- if (DEBUG) Log.i(TAG, "Set animationInitialDelay=" + initialDelay);
+ Log.i("Set animationInitialDelay=%s", initialDelay);
mInitialDelay = initialDelay;
return this;
}
@@ -152,7 +150,7 @@ public AnimatorAdapter setAnimationInitialDelay(long initialDelay) {
* @since 5.0.0-b1
*/
public AnimatorAdapter setAnimationDelay(@IntRange(from = 0) long delay) {
- if (DEBUG) Log.i(TAG, "Set animationDelay=" + delay);
+ Log.i("Set animationDelay=%s", delay);
mStepDelay = delay;
return this;
}
@@ -168,7 +166,7 @@ public AnimatorAdapter setAnimationDelay(@IntRange(from = 0) long delay) {
* since 5.0.0-b8
*/
public AnimatorAdapter setAnimationEntryStep(boolean entryStep) {
- if (DEBUG) Log.i(TAG, "Set animationEntryStep=" + entryStep);
+ Log.i("Set animationEntryStep=%s", entryStep);
this.mEntryStep = entryStep;
return this;
}
@@ -182,7 +180,7 @@ public AnimatorAdapter setAnimationEntryStep(boolean entryStep) {
* @since 5.0.0-b1
*/
public AnimatorAdapter setAnimationDuration(@IntRange(from = 1) long duration) {
- if (DEBUG) Log.i(TAG, "Set animationDuration=" + duration);
+ Log.i("Set animationDuration=%s", duration);
mDuration = duration;
return this;
}
@@ -195,7 +193,7 @@ public AnimatorAdapter setAnimationDuration(@IntRange(from = 1) long duration) {
* @return this AnimatorAdapter, so the call can be chained
*/
public AnimatorAdapter setAnimationInterpolator(@NonNull Interpolator interpolator) {
- if (DEBUG) Log.i(TAG, "Set animationInterpolator=" + getClassName(interpolator));
+ Log.i("Set animationInterpolator=%s", getClassName(interpolator));
mInterpolator = interpolator;
return this;
}
@@ -210,14 +208,14 @@ public AnimatorAdapter setAnimationInterpolator(@NonNull Interpolator interpolat
*/
@Deprecated
public AnimatorAdapter setAnimationStartPosition(@IntRange(from = 0) int start) {
- if (DEBUG) Log.i(TAG, "Set animationStartPosition=" + start);
+ Log.i("Set animationStartPosition=%s", start);
mLastAnimatedPosition = start;
return this;
}
/**
* Enables/Disables item animation while scrolling and on loading.
- * Enabling scrolling will disable onlyEntryAnimation.
+ *
Enabling scrolling will disable onlyEntryAnimation.
* Disabling scrolling will disable also reverse scrolling.
* Default value is {@code false}.
* Note: Loading animation can only be performed if the Adapter is initialized
@@ -230,7 +228,7 @@ public AnimatorAdapter setAnimationStartPosition(@IntRange(from = 0) int start)
* @since 5.0.0-b1
*/
public AnimatorAdapter setAnimationOnScrolling(boolean enabled) {
- if (DEBUG) Log.i(TAG, "Set animationOnScrolling=" + enabled);
+ Log.i("Set animationOnScrolling=%s", enabled);
if (enabled) this.onlyEntryAnimation = false;
shouldAnimate = enabled;
return this;
@@ -251,7 +249,7 @@ public boolean isAnimationOnScrollingEnabled() {
* @since 5.0.0-b1
*/
public AnimatorAdapter setAnimationOnReverseScrolling(boolean enabled) {
- if (DEBUG) Log.i(TAG, "Set animationOnReverseScrolling=" + enabled);
+ Log.i("Set animationOnReverseScrolling=%s", enabled);
isReverseEnabled = enabled;
return this;
}
@@ -287,7 +285,7 @@ public boolean isAnimationOnReverseScrollingEnabled() {
* @since 5.0.0-b8
*/
public AnimatorAdapter setOnlyEntryAnimation(boolean enabled) {
- if (DEBUG) Log.i(TAG, "Set onlyEntryAnimation=" + enabled);
+ Log.i("Set onlyEntryAnimation=%s", enabled);
if (enabled) this.shouldAnimate = true;
this.onlyEntryAnimation = enabled;
return this;
@@ -307,12 +305,12 @@ public boolean isOnlyEntryAnimation() {
/*--------------*/
/**
- * Build your custom list of {@link Animator} to apply on the ItemView.
+ * Build your custom list of {@link Animator} to apply on the ItemView.
* Write the logic based on the position and/or viewType and/or the item selection.
*
Suggestions:
- *
- You can also use {@link #getItemViewType(int)} to apply different Animation for
+ *
- You can also use {@link #getItemViewType(int)} to apply different Animation for
* each view type.
- *
- If you want to apply same animation for all items, create new list at class level
+ *
- If you want to apply same animation for all items, create new list at class level
* and initialize it in the constructor, not inside this method!
*
* @param itemView the bounded ItemView
@@ -356,7 +354,6 @@ private void cancelExistingAnimation(final int hashCode) {
* @param position the current item position
* @since 5.0.0-b1
*/
- @SuppressWarnings("ConstantConditions")
protected final void animateView(final RecyclerView.ViewHolder holder, final int position) {
if (mRecyclerView == null) return;
@@ -369,16 +366,10 @@ protected final void animateView(final RecyclerView.ViewHolder holder, final int
shouldAnimate = false;
}
int lastVisiblePosition = getFlexibleLayoutManager().findLastVisibleItemPosition();
-// if (DEBUG) {
-// Log.v(TAG, "shouldAnimate=" + shouldAnimate
-// + " isFastScroll=" + isFastScroll
-// + " isNotified=" + mAnimatorNotifierObserver.isPositionNotified()
-// + " isReverseEnabled=" + isReverseEnabled
-// + " mLastAnimatedPosition=" + mLastAnimatedPosition
-// + (!isReverseEnabled ? " Pos>LasVisPos=" + (position > lastVisiblePosition) : "")
-// + " mMaxChildViews=" + mMaxChildViews
-// );
-// }
+// Log.v("shouldAnimate=%s isFastScroll=%s isNotified=%s isReverseEnabled=%s mLastAnimatedPosition=%s %s mMaxChildViews=%s",
+// shouldAnimate, isFastScroll, mAnimatorNotifierObserver.isPositionNotified(), isReverseEnabled, mLastAnimatedPosition,
+// (!isReverseEnabled ? " Pos>LasVisPos=" + (position > lastVisiblePosition) : ""), mMaxChildViews
+// );
if (holder instanceof FlexibleViewHolder && shouldAnimate && !isFastScroll &&
!mAnimatorNotifierObserver.isPositionNotified() &&
(position > lastVisiblePosition || isReverseEnabled || isScrollableHeaderOrFooter(position) || (position == 0 && mMaxChildViews == 0))) {
@@ -403,7 +394,7 @@ protected final void animateView(final RecyclerView.ViewHolder holder, final int
duration = animator.getDuration();
}
}
- //Log.v(TAG, "duration=" + duration);
+ //Log.v("duration=%s", duration);
set.setDuration(duration);
set.addListener(new HelperAnimatorListener(hashCode));
if (mEntryStep) {
@@ -412,7 +403,7 @@ protected final void animateView(final RecyclerView.ViewHolder holder, final int
}
set.start();
mAnimators.put(hashCode, set);
- if (DEBUG) Log.v(TAG, "animateView Scroll animation on position " + position);
+ //Log.v("animateView Scroll animation on position %s", position);
}
mAnimatorNotifierObserver.clearNotified();
// Update last animated position
@@ -449,7 +440,7 @@ public final void animateView(final View itemView, int position) {
//Add Alpha animator
ViewCompat.setAlpha(itemView, 0);
animators.add(ObjectAnimator.ofFloat(itemView, "alpha", 0f, 1f));
- Log.w(TAG, "Started Deprecated Animation on position " + position);
+ Log.w("Started Deprecated Animation on position %s", position);
//Execute the animations
AnimatorSet set = new AnimatorSet();
@@ -516,13 +507,9 @@ private long calculateAnimationDelay(int position) {
delay = mInitialDelay + (position * mStepDelay);
}
-// if (DEBUG) Log.v(TAG, "Delay[" + position + "]=" + delay +
-// " FirstVisible=" + firstVisiblePosition +
-// " LastVisible=" + lastVisiblePosition +
-// " LastAnimated=" + numberOfAnimatedItems +
-// " VisibleItems=" + visibleItems +
-// " ChildCount=" + mRecyclerView.getChildCount() +
-// " MaxChildCount=" + mMaxChildViews);
+// Log.v("Delay[%s]=%s FirstVisible=%s LastVisible=%s LastAnimated=%s VisibleItems=%s ChildCount=%s MaxChildCount=%s",
+// position, delay, firstVisiblePosition, lastVisiblePosition, numberOfAnimatedItems,
+// visibleItems, mRecyclerView.getChildCount(), mMaxChildViews);
return delay;
}
@@ -532,9 +519,9 @@ private long calculateAnimationDelay(int position) {
/*-----------*/
/**
- * This is the default animator.
+ * This is the default animator.
* Alpha animator will be always automatically added.
- * Note: Only 1 animator of the same compatible type can be added.
+ *
Note: Only 1 animator of the same compatible type can be added.
* Incompatible with ALPHA animator.
*
* @param animators user defined list
@@ -552,10 +539,10 @@ private void addAlphaAnimator(
}
/**
- * Item will slide from Left to Right.
+ * Item will slide from Left to Right.
* Ignored if LEFT, RIGHT, TOP or BOTTOM animators were already added.
- * Note: Only 1 animator of the same compatible type can be added per time.
- * Incompatible with LEFT, TOP, BOTTOM animators.
+ *
Note: Only 1 animator of the same compatible type can be added per time.
+ * Incompatible with LEFT, TOP, BOTTOM animators.
*
* @param animators user defined list
* @param view itemView to animate
@@ -575,10 +562,10 @@ public void addSlideInFromLeftAnimator(
}
/**
- * Item will slide from Right to Left.
+ * Item will slide from Right to Left.
* Ignored if LEFT, RIGHT, TOP or BOTTOM animators were already added.
- *
Note: Only 1 animator of the same compatible type can be added per time.
- * Incompatible with RIGHT, TOP, BOTTOM animators.
+ *
Note: Only 1 animator of the same compatible type can be added per time.
+ * Incompatible with RIGHT, TOP, BOTTOM animators.
*
* @param animators user defined list
* @param view ItemView to animate
@@ -598,9 +585,9 @@ public void addSlideInFromRightAnimator(
}
/**
- * Item will slide from Top of the screen to its natural position.
+ * Item will slide from Top of the screen to its natural position.
* Ignored if LEFT, RIGHT, TOP or BOTTOM animators were already added.
- *
Note: Only 1 animator of the same compatible type can be added per time.
+ *
Note: Only 1 animator of the same compatible type can be added per time.
* Incompatible with LEFT, RIGHT, TOP, BOTTOM animators.
*
* @param animators user defined list
@@ -620,9 +607,9 @@ public void addSlideInFromTopAnimator(
}
/**
- * Item will slide from Bottom of the screen to its natural position.
+ * Item will slide from Bottom of the screen to its natural position.
* Ignored if LEFT, RIGHT, TOP or BOTTOM animators were already added.
- * Note: Only 1 animator of the same compatible type can be added per time.
+ *
Note: Only 1 animator of the same compatible type can be added per time.
* Incompatible with LEFT, RIGHT, TOP, BOTTOM animators.
*
* @param animators user defined list
@@ -642,10 +629,10 @@ public void addSlideInFromBottomAnimator(
}
/**
- * Item will scale.
+ * Item will scale.
* Ignored if SCALE animator was already added.
- * Note: Only 1 animator of the same compatible type can be added per time.
- * Incompatible with LEFT, RIGHT, BOTTOM animators.
+ *
Note: Only 1 animator of the same compatible type can be added per time.
+ * Incompatible with LEFT, RIGHT, BOTTOM animators.
*
* @param animators user defined list
* @param view itemView to animate
@@ -675,7 +662,7 @@ private class AnimatorAdapterDataObserver extends RecyclerView.AdapterDataObserv
private boolean notified;
private Handler mAnimatorHandler = new Handler(Looper.getMainLooper(), new Handler.Callback() {
public boolean handleMessage(Message message) {
- if (DEBUG) Log.v(TAG, "Clear notified for scrolling Animations");
+ //Log.v("Clear notified for scrolling Animations");
notified = false;
return true;
}
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/FlexibleAdapter.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/FlexibleAdapter.java
index 3259a3f4..7a75e9e2 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/FlexibleAdapter.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/FlexibleAdapter.java
@@ -29,7 +29,6 @@
import android.support.v7.util.DiffUtil;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.helper.ItemTouchHelper;
-import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
@@ -56,6 +55,7 @@
import eu.davidea.flexibleadapter.items.IHeader;
import eu.davidea.flexibleadapter.items.ISectionable;
import eu.davidea.flexibleadapter.utils.FlexibleUtils;
+import eu.davidea.flexibleadapter.utils.Log;
import eu.davidea.viewholders.ExpandableViewHolder;
import eu.davidea.viewholders.FlexibleViewHolder;
@@ -97,7 +97,7 @@
*
15/04/2017 Starting or resetting the Filter will empty the bin of the deletedItems
*
23/04/2017 Wrapper class for any third type of LayoutManagers
*/
-//@SuppressWarnings({"Range", "unused", "unchecked", "ConstantConditions", "SuspiciousMethodCalls", "WeakerAccess"})
+@SuppressWarnings({"Range", "unused", "unchecked", "ConstantConditions", "SuspiciousMethodCalls", "WeakerAccess"})
public class FlexibleAdapter
extends AnimatorAdapter
implements ItemTouchHelperCallback.AdapterCallback {
@@ -283,35 +283,35 @@ public FlexibleAdapter initializeListeners(@Nullable Object listener) {
*/
@CallSuper
public FlexibleAdapter addListener(@Nullable Object listener) {
- if (DEBUG && listener != null) {
- Log.i(TAG, "Setting listener class " + getClassName(listener) + " as:");
+ if (listener != null) {
+ Log.i("Setting listener class %s as:", getClassName(listener));
}
if (listener instanceof OnItemClickListener) {
- if (DEBUG) Log.i(TAG, "- OnItemClickListener");
+ if (DEBUG) Log.i("- OnItemClickListener");
mItemClickListener = (OnItemClickListener) listener;
}
if (listener instanceof OnItemLongClickListener) {
- if (DEBUG) Log.i(TAG, "- OnItemLongClickListener");
+ if (DEBUG) Log.i("- OnItemLongClickListener");
mItemLongClickListener = (OnItemLongClickListener) listener;
}
if (listener instanceof OnItemMoveListener) {
- if (DEBUG) Log.i(TAG, "- OnItemMoveListener");
+ if (DEBUG) Log.i("- OnItemMoveListener");
mItemMoveListener = (OnItemMoveListener) listener;
}
if (listener instanceof OnItemSwipeListener) {
- if (DEBUG) Log.i(TAG, "- OnItemSwipeListener");
+ if (DEBUG) Log.i("- OnItemSwipeListener");
mItemSwipeListener = (OnItemSwipeListener) listener;
}
if (listener instanceof OnDeleteCompleteListener) {
- if (DEBUG) Log.i(TAG, "- OnDeleteCompleteListener");
+ if (DEBUG) Log.i("- OnDeleteCompleteListener");
mDeleteCompleteListener = (OnDeleteCompleteListener) listener;
}
if (listener instanceof OnStickyHeaderChangeListener) {
- if (DEBUG) Log.i(TAG, "- OnStickyHeaderChangeListener");
+ if (DEBUG) Log.i("- OnStickyHeaderChangeListener");
mStickyHeaderChangeListener = (OnStickyHeaderChangeListener) listener;
}
if (listener instanceof OnUpdateListener) {
- if (DEBUG) Log.i(TAG, "- OnUpdateListener");
+ if (DEBUG) Log.i("- OnUpdateListener");
mUpdateListener = (OnUpdateListener) listener;
mUpdateListener.onUpdateEmptyView(getMainItemCount());
}
@@ -548,7 +548,7 @@ public void updateDataSet(@Nullable List items, boolean animate) {
prepareItemsForUpdate(newItems);
mItems = newItems;
// Execute instant reset on init
- if (DEBUG) Log.w(TAG, "updateDataSet with notifyDataSetChanged!");
+ Log.w("updateDataSet with notifyDataSetChanged!");
notifyDataSetChanged();
onPostUpdate();
}
@@ -756,11 +756,8 @@ public int calculatePositionFor(@NonNull Object item, @Nullable Comparator(mItems);
if (!sortedList.contains(item)) sortedList.add(item);
Collections.sort(sortedList, comparator);
- if (DEBUG)
- Log.v(TAG, "Calculated position " + Math.max(0, sortedList.indexOf(item)) + " for item=" + item);
+ Log.v("Calculated position %s for item=%s", Math.max(0, sortedList.indexOf(item)), item);
return Math.max(0, sortedList.indexOf(item));
}
@@ -838,7 +834,7 @@ public final boolean isScrollableHeaderOrFooter(T item) {
* @since 5.0.0-rc1
*/
public final boolean addScrollableHeader(@NonNull T headerItem) {
- if (DEBUG) Log.d(TAG, "Add scrollable header " + getClassName(headerItem));
+ Log.d("Add scrollable header %s", getClassName(headerItem));
if (!mScrollableHeaders.contains(headerItem)) {
headerItem.setSelectable(false);
headerItem.setDraggable(false);
@@ -849,7 +845,7 @@ public final boolean addScrollableHeader(@NonNull T headerItem) {
setScrollAnimate(false);
return true;
} else {
- Log.w(TAG, "Scrollable header " + getClassName(headerItem) + " already exists");
+ Log.w("Scrollable header %s already exists", getClassName(headerItem));
return false;
}
}
@@ -879,7 +875,7 @@ public final boolean addScrollableHeader(@NonNull T headerItem) {
*/
public final boolean addScrollableFooter(@NonNull T footerItem) {
if (!mScrollableFooters.contains(footerItem)) {
- if (DEBUG) Log.d(TAG, "Add scrollable footer " + getClassName(footerItem));
+ Log.d("Add scrollable footer %s", getClassName(footerItem));
footerItem.setSelectable(false);
footerItem.setDraggable(false);
int progressFix = (footerItem == mProgressItem) ? mScrollableFooters.size() : 0;
@@ -892,7 +888,7 @@ public final boolean addScrollableFooter(@NonNull T footerItem) {
performInsert(getItemCount() - progressFix, Collections.singletonList(footerItem), true);
return true;
} else {
- Log.w(TAG, "Scrollable footer " + getClassName(footerItem) + " already exists");
+ Log.w("Scrollable footer %s already exists", getClassName(footerItem));
return false;
}
}
@@ -907,7 +903,7 @@ public final boolean addScrollableFooter(@NonNull T footerItem) {
*/
public final void removeScrollableHeader(@NonNull T headerItem) {
if (mScrollableHeaders.remove(headerItem)) {
- if (DEBUG) Log.d(TAG, "Remove scrollable header " + getClassName(headerItem));
+ Log.d("Remove scrollable header %s", getClassName(headerItem));
performRemove(headerItem, true);
}
}
@@ -922,7 +918,7 @@ public final void removeScrollableHeader(@NonNull T headerItem) {
*/
public final void removeScrollableFooter(@NonNull T footerItem) {
if (mScrollableFooters.remove(footerItem)) {
- if (DEBUG) Log.d(TAG, "Remove scrollable footer " + getClassName(footerItem));
+ Log.d("Remove scrollable footer %s", getClassName(footerItem));
performRemove(footerItem, true);
}
}
@@ -936,7 +932,7 @@ public final void removeScrollableFooter(@NonNull T footerItem) {
*/
public final void removeAllScrollableHeaders() {
if (mScrollableHeaders.size() > 0) {
- if (DEBUG) Log.d(TAG, "Remove all scrollable headers");
+ Log.d("Remove all scrollable headers");
mItems.removeAll(mScrollableHeaders);
notifyItemRangeRemoved(0, mScrollableHeaders.size());
mScrollableHeaders.clear();
@@ -952,7 +948,7 @@ public final void removeAllScrollableHeaders() {
*/
public final void removeAllScrollableFooters() {
if (mScrollableFooters.size() > 0) {
- if (DEBUG) Log.d(TAG, "Remove all scrollable footers");
+ Log.d("Remove all scrollable footers");
mItems.removeAll(mScrollableFooters);
notifyItemRangeRemoved(getItemCount() - mScrollableFooters.size(), mScrollableFooters.size());
mScrollableFooters.clear();
@@ -971,8 +967,7 @@ public final void removeAllScrollableFooters() {
*/
public final void addScrollableHeaderWithDelay(@NonNull final T headerItem, @IntRange(from = 0) long delay,
final boolean scrollToPosition) {
- if (DEBUG)
- Log.d(TAG, "Enqueued adding scrollable header (" + delay + "ms) " + getClassName(headerItem));
+ Log.d("Enqueued adding scrollable header (%sms) %s", delay, getClassName(headerItem));
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
@@ -994,8 +989,7 @@ public void run() {
*/
public final void addScrollableFooterWithDelay(@NonNull final T footerItem, @IntRange(from = 0) long delay,
final boolean scrollToPosition) {
- if (DEBUG)
- Log.d(TAG, "Enqueued adding scrollable footer (" + delay + "ms) " + getClassName(footerItem));
+ Log.d("Enqueued adding scrollable footer (%sms) %s", delay, getClassName(footerItem));
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
@@ -1015,8 +1009,7 @@ public void run() {
* @since 5.0.0-rc1
*/
public final void removeScrollableHeaderWithDelay(@NonNull final T headerItem, @IntRange(from = 0) long delay) {
- if (DEBUG)
- Log.d(TAG, "Enqueued removing scrollable header (" + delay + "ms) " + getClassName(headerItem));
+ Log.d("Enqueued removing scrollable header (%sms) %s", delay, getClassName(headerItem));
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
@@ -1035,8 +1028,7 @@ public void run() {
* @since 5.0.0-rc1
*/
public final void removeScrollableFooterWithDelay(@NonNull final T footerItem, @IntRange(from = 0) long delay) {
- if (DEBUG)
- Log.d(TAG, "Enqueued removing scrollable footer (" + delay + "ms) " + getClassName(footerItem));
+ Log.d("Enqueued removing scrollable footer (%sms) %s", delay, getClassName(footerItem));
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
@@ -1086,7 +1078,7 @@ public boolean isRemoveOrphanHeaders() {
*/
@Deprecated
public FlexibleAdapter setRemoveOrphanHeaders(boolean removeOrphanHeaders) {
- if (DEBUG) Log.i(TAG, "Set removeOrphanHeaders=" + removeOrphanHeaders);
+ Log.i("Set removeOrphanHeaders=%s", removeOrphanHeaders);
this.removeOrphanHeaders = removeOrphanHeaders;
return this;
}
@@ -1101,7 +1093,7 @@ public FlexibleAdapter setRemoveOrphanHeaders(boolean removeOrphanHeaders) {
* @since 5.0.0-b6
*/
public FlexibleAdapter setUnlinkAllItemsOnRemoveHeaders(boolean unlinkOnRemoveHeader) {
- if (DEBUG) Log.i(TAG, "Set unlinkOnRemoveHeader=" + unlinkOnRemoveHeader);
+ Log.i("Set unlinkOnRemoveHeader=%s", unlinkOnRemoveHeader);
this.unlinkOnRemoveHeader = unlinkOnRemoveHeader;
return this;
}
@@ -1447,8 +1439,7 @@ public FlexibleAdapter setStickyHeaders(boolean sticky) {
* @since 5.0.0-rc1
*/
public FlexibleAdapter setStickyHeaders(final boolean sticky, @Nullable ViewGroup stickyContainer) {
- if (DEBUG) Log.i(TAG, "Set stickyHeaders=" + sticky + " (in Post!)" +
- (stickyContainer != null ? " with user defined Sticky Container" : ""));
+ Log.i("Set stickyHeaders=%s (in Post!)%s", sticky, (stickyContainer != null ? " with user defined Sticky Container" : ""));
// With user defined container
mStickyContainer = stickyContainer;
@@ -1463,12 +1454,12 @@ public void run() {
mStickyHeaderHelper = new StickyHeaderHelper(FlexibleAdapter.this,
mStickyHeaderChangeListener, mStickyContainer);
mStickyHeaderHelper.attachToRecyclerView(mRecyclerView);
- if (DEBUG) Log.i(TAG, "Sticky headers enabled");
+ Log.i("Sticky headers enabled");
}
} else if (areHeadersSticky()) {
mStickyHeaderHelper.detachFromRecyclerView();
mStickyHeaderHelper = null;
- if (DEBUG) Log.i(TAG, "Sticky headers disabled");
+ Log.i("Sticky headers disabled");
}
}
});
@@ -1554,10 +1545,10 @@ public ViewGroup getStickyHeaderContainer() {
@Deprecated
public FlexibleAdapter setStickyHeaderContainer(@Nullable ViewGroup stickyContainer) {
if (areHeadersSticky()) {
- Log.w(TAG, "StickyHeader has been already initialized! Call this method before enabling StickyHeaders");
+ Log.w("StickyHeader has been already initialized! Call this method before enabling StickyHeaders");
}
- if (DEBUG && stickyContainer != null)
- Log.i(TAG, "Set stickyHeaderContainer=" + getClassName(stickyContainer));
+ if (stickyContainer != null)
+ Log.i("Set stickyHeaderContainer=%s", getClassName(stickyContainer));
this.mStickyContainer = stickyContainer;
return this;
}
@@ -1605,18 +1596,18 @@ public FlexibleAdapter showAllHeaders() {
*/
private void showAllHeaders(boolean init) {
if (init) {
- if (DEBUG) Log.i(TAG, "showAllHeaders at startup");
+ Log.i("showAllHeaders at startup");
// No notifyItemInserted!
showAllHeadersWithReset(true);
} else {
- if (DEBUG) Log.i(TAG, "showAllHeaders with insert notification (in Post!)");
+ Log.i("showAllHeaders with insert notification (in Post!)");
// In post, let's notifyItemInserted!
mHandler.post(new Runnable() {
@Override
public void run() {
// #144 - Check if headers are already shown, discard the call to not duplicate headers
if (headersShown) {
- Log.w(TAG, "Double call detected! Headers already shown OR the method showAllHeaders() was already called!");
+ Log.w("Double call detected! Headers already shown OR the method showAllHeaders() was already called!");
return;
}
showAllHeadersWithReset(false);
@@ -1670,7 +1661,7 @@ private boolean showHeaderOf(int position, T item, boolean init) {
// Check header existence
if (header == null || getPendingRemovedItem(item) != null) return false;
if (header.isHidden()) {
- if (DEBUG) Log.v(TAG, "Showing header at position " + position + " header=" + header);
+ Log.v("Showing header position=%s header=%s", position, header);
header.setHidden(false);
// Insert header, but skip notifyItemInserted when init=true!
performInsert(position, Collections.singletonList((T) header), !init);
@@ -1726,7 +1717,7 @@ private boolean hideHeaderOf(T item) {
private boolean hideHeader(int position, IHeader header) {
if (position >= 0) {
- if (DEBUG) Log.v(TAG, "Hiding header at position " + position + " header=" + header);
+ Log.v("Hiding header position=%s header=$s", position, header);
header.setHidden(true);
// Remove and notify removals
mItems.remove(position);
@@ -1758,7 +1749,7 @@ private boolean linkHeaderTo(T item, IHeader header, @Nullable Object payload) {
unlinkHeaderFrom((T) sectionable, Payload.UNLINK);
}
if (sectionable.getHeader() == null && header != null) {
- if (DEBUG) Log.v(TAG, "Link header " + header + " to " + sectionable);
+ Log.v("Link header %s to %s", header, sectionable);
//TODO: try-catch for when sectionable item has a different header class signature, if so, they just can't accept that header!
sectionable.setHeader(header);
linked = true;
@@ -1790,7 +1781,7 @@ private IHeader unlinkHeaderFrom(T item, @Nullable Object payload) {
if (hasHeader(item)) {
ISectionable sectionable = (ISectionable) item;
IHeader header = sectionable.getHeader();
- if (DEBUG) Log.v(TAG, "Unlink header " + header + " from " + sectionable);
+ Log.v("Unlink header %s from %s", header, sectionable);
sectionable.setHeader(null);
addToOrphanListIfNeeded(header, getGlobalPositionOf(item), 1);
// Notify items
@@ -1808,15 +1799,14 @@ private void addToOrphanListIfNeeded(IHeader header, int positionStart, int item
// Check if the header is not already added (happens after un-linkage with un-success linkage)
if (!mOrphanHeaders.contains(header) && !isHeaderShared(header, positionStart, itemCount)) {
mOrphanHeaders.add(header);
- if (DEBUG)
- Log.v(TAG, "Added to orphan list [" + mOrphanHeaders.size() + "] Header " + header);
+ Log.v("Added to orphan list [%s] Header %s", mOrphanHeaders.size(), header);
}
}
@Deprecated
private void removeFromOrphanList(IHeader header) {
if (mOrphanHeaders.remove(header) && DEBUG)
- Log.v(TAG, "Removed from orphan list [" + mOrphanHeaders.size() + "] Header " + header);
+ Log.v("Removed from orphan list [%s] Header %s", mOrphanHeaders.size(), header);
}
@Deprecated
@@ -1879,8 +1869,8 @@ public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType
T item = getViewTypeInstance(viewType);
if (item == null || !autoMap) {
// If everything has been set properly, this should never happen ;-)
- throw new IllegalStateException("ViewType instance not found for viewType " + viewType +
- ". You should implement the AutoMap properly.");
+ throw new IllegalStateException(
+ String.format("ViewType instance not found for viewType %s. You should implement the AutoMap properly.", viewType));
}
if (mInflater == null) {
mInflater = LayoutInflater.from(parent.getContext());
@@ -1914,14 +1904,10 @@ public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
*/
@Override
public void onBindViewHolder(final RecyclerView.ViewHolder holder, int position, List payloads) {
- if (DEBUG) {
- Log.v(TAG, "onViewBound Holder=" + getClassName(holder) + " position=" + position +
- " itemId=" + holder.getItemId() + " layoutPosition=" + holder.getLayoutPosition());
- }
+ Log.v("onViewBound Holder=%s position=%s itemId=%s", getClassName(holder), position, holder.getItemId());
if (!autoMap) {
// If everything has been set properly, this should never happen ;-)
- throw new IllegalStateException("AutoMap is not active, this method cannot be called." +
- " Override this method or implement the AutoMap properly.");
+ throw new IllegalStateException("AutoMap is not active, this method cannot be called. You should implement the AutoMap properly.");
}
// Bind view activation with current selection
super.onBindViewHolder(holder, position, payloads);
@@ -2031,7 +2017,7 @@ public int getEndlessPageSize() {
* @since 5.0.0-rc1
*/
public FlexibleAdapter setEndlessPageSize(@IntRange(from = 0) int endlessPageSize) {
- if (DEBUG) Log.i(TAG, "Set endlessPageSize=" + endlessPageSize);
+ Log.i("Set endlessPageSize=%s", endlessPageSize);
mEndlessPageSize = endlessPageSize;
return this;
}
@@ -2062,7 +2048,7 @@ public int getEndlessTargetCount() {
* @since 5.0.0-rc1
*/
public FlexibleAdapter setEndlessTargetCount(@IntRange(from = 0) int endlessTargetCount) {
- if (DEBUG) Log.i(TAG, "Set endlessTargetCount=" + endlessTargetCount);
+ Log.i("Set endlessTargetCount=%s", endlessTargetCount);
mEndlessTargetCount = endlessTargetCount;
return this;
}
@@ -2076,7 +2062,7 @@ public FlexibleAdapter setEndlessTargetCount(@IntRange(from = 0) int endlessT
* @return this Adapter, so the call can be chained
*/
public FlexibleAdapter setLoadingMoreAtStartUp(boolean enable) {
- if (DEBUG) Log.i(TAG, "Set loadingAtStartup=" + enable);
+ Log.i("Set loadingAtStartup=%s", enable);
if (enable) {
mHandler.post(new Runnable() {
@Override
@@ -2106,12 +2092,10 @@ public FlexibleAdapter setEndlessProgressItem(@Nullable T progressItem) {
if (progressItem != null) {
setEndlessScrollThreshold(mEndlessScrollThreshold);
mProgressItem = progressItem;
- if (DEBUG) {
- Log.i(TAG, "Set progressItem=" + getClassName(progressItem));
- Log.i(TAG, "Enabled EndlessScrolling");
- }
- } else if (DEBUG) {
- Log.i(TAG, "Disabled EndlessScrolling");
+ Log.i("Set progressItem=%s", getClassName(progressItem));
+ Log.i("Enabled EndlessScrolling");
+ } else {
+ Log.i("Disabled EndlessScrolling");
}
return this;
}
@@ -2130,7 +2114,7 @@ public FlexibleAdapter setEndlessProgressItem(@Nullable T progressItem) {
*/
public FlexibleAdapter setEndlessScrollListener(@Nullable EndlessScrollListener endlessScrollListener,
@NonNull T progressItem) {
- if (DEBUG) Log.i(TAG, "Set endlessScrollListener=" + getClassName(endlessScrollListener));
+ Log.i("Set endlessScrollListener=%s", getClassName(endlessScrollListener));
mEndlessScrollListener = endlessScrollListener;
return setEndlessProgressItem(progressItem);
}
@@ -2150,7 +2134,7 @@ public FlexibleAdapter setEndlessScrollThreshold(@IntRange(from = 1) int thre
thresholdItems = thresholdItems * spanCount;
}
mEndlessScrollThreshold = thresholdItems;
- if (DEBUG) Log.i(TAG, "Set endlessScrollThreshold=" + mEndlessScrollThreshold);
+ Log.i("Set endlessScrollThreshold=%s", mEndlessScrollThreshold);
return this;
}
@@ -2173,10 +2157,9 @@ protected void onLoadMore(int position) {
if ((!mTopEndless && (position == getGlobalPositionOf(mProgressItem) || position < threshold)) ||
(mTopEndless && position > 0 && position > threshold)) {
return;
- } else if (DEBUG) {
- Log.v(TAG, "onLoadMore topEndless=" + mTopEndless + ", loading=" + endlessLoading
- + ", position=" + position + ", itemCount=" + getItemCount()
- + ", threshold=" + mEndlessScrollThreshold + ", currentThreshold=" + threshold);
+ } else {
+ Log.v("onLoadMore topEndless=%s, loading=%s, position=%s, itemCount=%s threshold=%s, currentThreshold=%s",
+ mTopEndless, endlessLoading, position, getItemCount(), mEndlessScrollThreshold, threshold);
}
// Load more if not loading and inside the threshold
endlessLoading = true;
@@ -2191,7 +2174,7 @@ public void run() {
boolean added = mTopEndless ? addScrollableHeader(mProgressItem) : addScrollableFooter(mProgressItem);
// When the listener is not set, loading more is called upon a user request
if (added && mEndlessScrollListener != null) {
- if (DEBUG) Log.d(TAG, "onLoadMore invoked!");
+ Log.d("onLoadMore invoked!");
mEndlessScrollListener.onLoadMore(getMainItemCount(), getEndlessCurrentPage());
} else if (!added) {
endlessLoading = false;
@@ -2237,8 +2220,7 @@ public void onLoadMoreComplete(@Nullable List newItems, @IntRange(from = -1)
int totalItemCount = newItemsSize + getMainItemCount();
// Add any new items
if (newItemsSize > 0) {
- if (DEBUG)
- Log.v(TAG, "onLoadMore performing adding " + newItemsSize + " new items on Page=" + getEndlessCurrentPage());
+ Log.v("onLoadMore performing adding %s new items on page=%s", newItemsSize, getEndlessCurrentPage());
int position = mTopEndless ? mScrollableHeaders.size() : getGlobalPositionOf(mProgressItem);
addItems(position, newItems);
}
@@ -2250,8 +2232,7 @@ public void onLoadMoreComplete(@Nullable List newItems, @IntRange(from = -1)
}
// Remove the progressItem if needed
if (delay > 0 && (newItemsSize == 0 || !isEndlessScrollEnabled())) {
- if (DEBUG)
- Log.v(TAG, "onLoadMore enqueued removing progressItem (" + delay + "ms)");
+ Log.v("onLoadMore enqueued removing progressItem (%sms)", delay);
mHandler.sendEmptyMessageDelayed(LOAD_MORE_COMPLETE, delay);
} else {
hideProgressItem();
@@ -2270,7 +2251,7 @@ public void onLoadMoreComplete(@Nullable List newItems, @IntRange(from = -1)
private void hideProgressItem() {
int positionToNotify = getGlobalPositionOf(mProgressItem);
if (positionToNotify >= 0) {
- if (DEBUG) Log.v(TAG, "onLoadMore remove progressItem");
+ Log.v("onLoadMore remove progressItem");
if (mTopEndless) {
removeScrollableHeader(mProgressItem);
} else {
@@ -2283,7 +2264,7 @@ private void hideProgressItem() {
* Called when no more items are loaded.
*/
private void noMoreLoad(int newItemsSize) {
- if (DEBUG) Log.i(TAG, "noMoreLoad!");
+ Log.i("noMoreLoad!");
int positionToNotify = getGlobalPositionOf(mProgressItem);
if (positionToNotify >= 0)
notifyItemChanged(positionToNotify, Payload.NO_MORE_LOAD);
@@ -2313,7 +2294,7 @@ public boolean isAutoCollapseOnExpand() {
* @since 5.0.0-b1
*/
public FlexibleAdapter setAutoCollapseOnExpand(boolean collapseOnExpand) {
- if (DEBUG) Log.i(TAG, "Set autoCollapseOnExpand=" + collapseOnExpand);
+ Log.i("Set autoCollapseOnExpand=%s", collapseOnExpand);
this.collapseOnExpand = collapseOnExpand;
return this;
}
@@ -2337,7 +2318,7 @@ public boolean isAutoScrollOnExpand() {
* @since 5.0.0-b1
*/
public FlexibleAdapter setAutoScrollOnExpand(boolean scrollOnExpand) {
- if (DEBUG) Log.i(TAG, "Set setAutoScrollOnExpand=" + scrollOnExpand);
+ Log.i("Set setAutoScrollOnExpand=%s", scrollOnExpand);
this.scrollOnExpand = scrollOnExpand;
return this;
}
@@ -2388,7 +2369,7 @@ public int getMinCollapsibleLevel() {
* @since 5.0.0-b6
*/
public FlexibleAdapter setMinCollapsibleLevel(int minCollapsibleLevel) {
- if (DEBUG) Log.i(TAG, "Set minCollapsibleLevel=" + minCollapsibleLevel);
+ Log.i("Set minCollapsibleLevel=%s", minCollapsibleLevel);
this.mMinCollapsibleLevel = minCollapsibleLevel;
return this;
}
@@ -2638,15 +2619,12 @@ private int expand(int position, boolean expandAll, boolean init, boolean notify
IExpandable expandable = (IExpandable) item;
if (!hasSubItems(expandable)) {
expandable.setExpanded(false);//clear the expanded flag
- if (DEBUG)
- Log.w(TAG, "No subItems to Expand on position " + position +
- " expanded " + expandable.isExpanded());
+ Log.w("No subItems to Expand on position %s expanded %s", position, expandable.isExpanded());
return 0;
}
- if (DEBUG && !init && !expandAll) {
- Log.v(TAG, "Request to Expand on position=" + position +
- " expanded=" + expandable.isExpanded() +
- " anyParentSelected=" + parentSelected);
+ if (!init && !expandAll) {
+ Log.v("Request to Expand on position=%s expanded=%s anyParentSelected=%s",
+ position, expandable.isExpanded(), parentSelected);
}
int subItemsCount = 0;
if (init || !expandable.isExpanded() &&
@@ -2688,10 +2666,7 @@ private int expand(int position, boolean expandAll, boolean init, boolean notify
if (!expandSHF(mScrollableHeaders, expandable))
expandSHF(mScrollableFooters, expandable);
- if (DEBUG) {
- Log.v(TAG, (init ? "Initially expanded " : "Expanded ") +
- subItemsCount + " subItems on position=" + position);
- }
+ Log.v("%s %s subItems on position=%s", (init ? "Initially expanded" : "Expanded"), subItemsCount, position);
}
return subItemsCount;
}
@@ -2782,11 +2757,8 @@ public int collapse(@IntRange(from = 0) int position, boolean notifyParent) {
List subItems = getExpandableList(expandable);
int subItemsCount = subItems.size(), recursiveCount = 0;
- if (DEBUG) {
- Log.v(TAG, "Request to Collapse on position=" + position +
- " expanded=" + expandable.isExpanded() +
- " hasSubItemsSelected=" + hasSubItemsSelected(position, subItems));
- }
+ Log.v("Request to Collapse on position=%s expanded=%s hasSubItemsSelected=%s",
+ position, expandable.isExpanded(), hasSubItemsSelected(position, subItems));
if (expandable.isExpanded() && subItemsCount > 0 &&
(!hasSubItemsSelected(position, subItems) || getPendingRemovedItem(item) != null)) {
@@ -2813,8 +2785,7 @@ public int collapse(@IntRange(from = 0) int position, boolean notifyParent) {
if (!collapseSHF(mScrollableHeaders, expandable))
collapseSHF(mScrollableFooters, expandable);
- if (DEBUG)
- Log.v(TAG, "Collapsed " + subItemsCount + " subItems on position " + position);
+ Log.v("Collapsed %s subItems on position %s", subItemsCount, position);
}
return subItemsCount + recursiveCount;
}
@@ -2913,16 +2884,16 @@ public void updateItem(@NonNull T item, @Nullable Object payload) {
*/
public void updateItem(@IntRange(from = 0) int position, @NonNull T item, @Nullable Object payload) {
if (item == null) {
- Log.e(TAG, "updateItem No Item to update!");
+ Log.e("updateItem No Item to update!");
return;
}
int itemCount = getItemCount();
if (position < 0 || position >= itemCount) {
- Log.e(TAG, "Cannot updateItem on position out of OutOfBounds!");
+ Log.e("Cannot updateItem on position out of OutOfBounds!");
return;
}
mItems.set(position, item);
- if (DEBUG) Log.d(TAG, "updateItem notifyItemChanged on position " + position);
+ Log.d("updateItem notifyItemChanged on position " + position);
notifyItemChanged(position, payload);
}
@@ -2985,10 +2956,10 @@ public boolean addItem(@NonNull T item) {
*/
public boolean addItem(@IntRange(from = 0) int position, @NonNull T item) {
if (item == null) {
- Log.e(TAG, "addItem No item to add!");
+ Log.e("addItem No item to add!");
return false;
}
- if (DEBUG) Log.v(TAG, "addItem delegates addition to addItems!");
+ Log.v("addItem delegates addition to addItems!");
return addItems(position, Collections.singletonList(item));
}
@@ -3010,12 +2981,12 @@ public boolean addItem(@IntRange(from = 0) int position, @NonNull T item) {
*/
public boolean addItems(@IntRange(from = 0) int position, @NonNull List items) {
if (items == null || items.isEmpty()) {
- Log.e(TAG, "addItems No items to add!");
+ Log.e("addItems No items to add!");
return false;
}
int initialCount = getMainItemCount();//Count only main items!
if (position < 0) {
- Log.w(TAG, "addItems Position is negative! adding items to the end");
+ Log.w("addItems Position is negative! adding items to the end");
position = initialCount;
}
// Insert the item properly
@@ -3044,8 +3015,7 @@ private void performInsert(int position, List items, boolean notify) {
}
// Notify range addition
if (notify) {
- if (DEBUG)
- Log.d(TAG, "addItems on position=" + position + " itemCount=" + items.size());
+ Log.d("addItems on position=%s itemCount=%s", position, items.size());
notifyItemRangeInserted(position, items.size());
}
}
@@ -3084,7 +3054,7 @@ public boolean addSubItem(@IntRange(from = 0) int parentPosition,
@IntRange(from = 0) int subPosition,
@NonNull T item, boolean expandParent, @Nullable Object payload) {
if (item == null) {
- Log.e(TAG, "No items to add!");
+ Log.e("No items to add!");
return false;
}
// Build a new list with 1 item to chain the methods of addSubItems
@@ -3146,7 +3116,7 @@ public boolean addSubItems(@IntRange(from = 0) int parentPosition,
IExpandable expandable = (IExpandable) parent;
return addSubItems(parentPosition, subPosition, expandable, items, expandParent, payload);
}
- Log.e(TAG, "Provided parentPosition doesn't belong to an Expandable item!");
+ Log.e("Provided parentPosition doesn't belong to an Expandable item!");
return false;
}
@@ -3285,7 +3255,7 @@ public int addItemToSection(@NonNull ISectionable sectionable, @Nullable IHeader
*/
public int addItemToSection(@NonNull ISectionable sectionable, @Nullable IHeader header,
@IntRange(from = 0) int index) {
- if (DEBUG) Log.d(TAG, "addItemToSection relativePosition=" + index);
+ Log.d("addItemToSection relativePosition=%s", index);
int headerPosition = getGlobalPositionOf(header);
if (index >= 0) {
sectionable.setHeader(header);
@@ -3311,7 +3281,7 @@ public int addItemToSection(@NonNull ISectionable sectionable, @Nullable IHeader
* @since 5.0.0-rc1
*/
public void clear() {
- if (DEBUG) Log.d(TAG, "clearAll views");
+ Log.d("clearAll views");
removeAllScrollableHeaders();
removeAllScrollableFooters();
removeRange(0, getItemCount(), null);
@@ -3330,7 +3300,7 @@ public void clear() {
*/
public void clearAllBut(Integer... viewTypes) {
List viewTypeList = Arrays.asList(viewTypes);
- if (DEBUG) Log.d(TAG, "clearAll retaining views " + viewTypeList);
+ Log.d("clearAll retaining views %s", viewTypeList);
List positionsToRemove = new ArrayList<>();
int startPosition = Math.max(0, mScrollableHeaders.size());
int endPosition = getItemCount() - mScrollableFooters.size();
@@ -3349,7 +3319,7 @@ public void clearAllBut(Integer... viewTypes) {
@Deprecated
public void removeItemWithDelay(@NonNull final T item, @IntRange(from = 0) long delay,
final boolean permanent, boolean resetLayoutAnimation) {
- Log.w(TAG, "Method removeItemWithDelay() with 'resetLayoutAnimation' has been deprecated, param 'resetLayoutAnimation'. Method will be removed with final release!");
+ Log.w("Method removeItemWithDelay() with 'resetLayoutAnimation' has been deprecated, param 'resetLayoutAnimation'. Method will be removed with final release!");
removeItemWithDelay(item, delay, permanent);
}
@@ -3421,7 +3391,7 @@ public void removeItem(@IntRange(from = 0) int position) {
public void removeItem(@IntRange(from = 0) int position, @Nullable Object payload) {
// Request to collapse after the notification of remove range
collapse(position);
- if (DEBUG) Log.v(TAG, "removeItem delegates removal to removeRange");
+ Log.v("removeItem delegates removal to removeRange");
removeRange(position, 1, payload);
}
@@ -3458,8 +3428,7 @@ public void removeItems(@NonNull List selectedPositions) {
* @since 5.0.0-b1
*/
public void removeItems(@Nullable List selectedPositions, @Nullable Object payload) {
- if (DEBUG)
- Log.v(TAG, "removeItems selectedPositions=" + selectedPositions + " payload=" + payload);
+ Log.v("removeItems selectedPositions=%s payload=%s", selectedPositions, payload);
// Check if list is empty
if (selectedPositions == null || selectedPositions.isEmpty()) return;
// Reverse-sort the list, start from last position for efficiency
@@ -3469,8 +3438,7 @@ public int compare(Integer lhs, Integer rhs) {
return rhs - lhs;
}
});
- if (DEBUG)
- Log.v(TAG, "removeItems after reverse sort selectedPositions=" + selectedPositions);
+ Log.v("removeItems after reverse sort selectedPositions=%s", selectedPositions);
// Split the list in ranges
int positionStart = 0, itemCount = 0;
int lastPosition = selectedPositions.get(0);
@@ -3574,13 +3542,12 @@ public void removeRange(@IntRange(from = 0) int positionStart,
public void removeRange(@IntRange(from = 0) int positionStart,
@IntRange(from = 0) int itemCount, @Nullable Object payload) {
int initialCount = getItemCount();
- if (DEBUG)
- Log.d(TAG, "removeRange positionStart=" + positionStart + " itemCount=" + itemCount);
+ Log.d("removeRange positionStart=%s itemCount=%s", positionStart, itemCount);
if (positionStart < 0 || (positionStart + itemCount) > initialCount) {
- Log.e(TAG, "Cannot removeRange with positionStart out of OutOfBounds!");
+ Log.e("Cannot removeRange with positionStart OutOfBounds!");
return;
} else if (itemCount == 0 || initialCount == 0) {
- Log.w(TAG, "Nothing to delete!");
+ Log.w("Nothing to delete!");
return;
}
@@ -3640,7 +3607,7 @@ public void removeRange(@IntRange(from = 0) int positionStart,
for (IHeader orphanHeader : mOrphanHeaders) {
headerPosition = getGlobalPositionOf(orphanHeader);
if (headerPosition >= 0) {
- if (DEBUG) Log.v(TAG, "Removing orphan header " + orphanHeader);
+ Log.v("Removing orphan header %s", orphanHeader);
if (!permanentDelete)
createRestoreItemInfo(headerPosition, (T) orphanHeader);
mItems.remove(headerPosition);
@@ -3718,7 +3685,7 @@ public boolean isPermanentDelete() {
* @since 5.0.0-b6
*/
public FlexibleAdapter setPermanentDelete(boolean permanentDelete) {
- if (DEBUG) Log.i(TAG, "Set permanentDelete=" + permanentDelete);
+ Log.i("Set permanentDelete=%s", permanentDelete);
this.permanentDelete = permanentDelete;
return this;
}
@@ -3746,7 +3713,7 @@ public boolean isRestoreWithSelection() {
* @since 5.0.0-b1
*/
public FlexibleAdapter setRestoreSelectionOnUndo(boolean restoreSelection) {
- if (DEBUG) Log.i(TAG, "Set restoreSelectionOnUndo=" + restoreSelection);
+ Log.i("Set restoreSelectionOnUndo=%s", restoreSelection);
this.restoreSelection = restoreSelection;
return this;
}
@@ -3772,12 +3739,12 @@ public void restoreDeletedItems() {
if (restoreInfo.relativePosition >= 0) {
// Restore child
- if (DEBUG) Log.d(TAG, "Restore SubItem " + restoreInfo);
+ Log.d("Restore SubItem %s", restoreInfo);
addSubItem(restoreInfo.getRestorePosition(true), restoreInfo.relativePosition,
restoreInfo.item, false, Payload.UNDO);
} else {
// Restore parent or simple item
- if (DEBUG) Log.d(TAG, "Restore Item " + restoreInfo);
+ Log.d("Restore Item %s", restoreInfo);
addItem(restoreInfo.getRestorePosition(false), restoreInfo.item);
}
// Item is again visible
@@ -3808,7 +3775,7 @@ public void restoreDeletedItems() {
addSelection(getGlobalPositionOf(restoreInfo.item));
}
}
- if (DEBUG) Log.d(TAG, "Selected positions after restore " + getSelectedPositions());
+ Log.d("Selected positions after restore %s", getSelectedPositions());
}
// Call listener to update EmptyView
multiRange = false;
@@ -3826,7 +3793,7 @@ public void restoreDeletedItems() {
* @since 3.0.0
*/
public synchronized void emptyBin() {
- if (DEBUG) Log.d(TAG, "emptyBin!");
+ Log.d("emptyBin!");
mRestoreList.clear();
}
@@ -4002,7 +3969,7 @@ public void setSearchText(String searchText) {
* @since 5.0.0-b1
*/
public final FlexibleAdapter setNotifyChangeOfUnfilteredItems(boolean notifyChange) {
- if (DEBUG) Log.i(TAG, "Set notifyChangeOfUnfilteredItems=" + notifyChange);
+ Log.i("Set notifyChangeOfUnfilteredItems=%s", notifyChange);
this.notifyChangeOfUnfilteredItems = notifyChange;
return this;
}
@@ -4022,7 +3989,7 @@ public final FlexibleAdapter setNotifyChangeOfUnfilteredItems(boolean notifyChan
* @since 5.0.0-b8
*/
public final FlexibleAdapter setNotifyMoveOfFilteredItems(boolean notifyMove) {
- if (DEBUG) Log.i(TAG, "Set notifyMoveOfFilteredItems=" + notifyMove);
+ Log.i("Set notifyMoveOfFilteredItems=%s", notifyMove);
this.notifyMoveOfFilteredItems = notifyMove;
return this;
}
@@ -4095,7 +4062,7 @@ public void filterItems(@NonNull List unfilteredItems, @IntRange(from = 0) lo
* the current filter.
* Filter is skipped while endless feature is active (loading).
* Items are animated thanks to {@link #animateTo(List, Payload)} BUT a limit of
- * {@value ANIMATE_TO_LIMIT} (default) items is set. Note: Above this limit,
+ * {@value #ANIMATE_TO_LIMIT} (default) items is set. Note: Above this limit,
* {@link #notifyDataSetChanged()} will be called to improve performance. you can change
* this limit by calling {@link #setAnimateToLimit(int)}.
*
@@ -4118,7 +4085,7 @@ public void filterItems(@NonNull List unfilteredItems) {
}
private synchronized void filterItemsAsync(@NonNull List unfilteredItems) {
- if (DEBUG) Log.i(TAG, "filterItems with searchText=\"" + mSearchText + "\"");
+ Log.d("filterItems with searchText=\"%s\"", mSearchText);
List filteredItems = new ArrayList<>();
filtering = true; //Enable flag
@@ -4300,14 +4267,14 @@ private void resetFilterFlags(List items) {
* Tunes the limit after the which the synchronization animations, occurred during
* updateDataSet and filter operations, are skipped and {@link #notifyDataSetChanged()}
* will be called instead.
- * Default value is {@value ANIMATE_TO_LIMIT} items, number new items.
+ * Default value is {@value #ANIMATE_TO_LIMIT} items, number new items.
*
* @param limit the number of new items that, when reached, will skip synchronization animations
* @return this Adapter, so the call can be chained
* @since 5.0.0-b8
*/
public FlexibleAdapter setAnimateToLimit(int limit) {
- if (DEBUG) Log.i(TAG, "Set animateToLimit=" + limit);
+ Log.i("Set animateToLimit=%s", limit);
mAnimateToLimit = limit;
return this;
}
@@ -4366,7 +4333,7 @@ public FlexibleAdapter setDiffUtilCallback(DiffUtilCallback diffUtilCallback)
@Deprecated //TODO: Call animateTo instead.
private synchronized void animateDiff(@Nullable List newItems, Payload payloadChange) {
if (useDiffUtil) {
- Log.v(TAG, "Animate changes with DiffUtils! oldSize=" + getItemCount() + " newSize=" + newItems.size());
+ Log.d("Animate changes with DiffUtils! oldSize=%s newSize=%s", getItemCount(), newItems.size());
if (diffUtilCallback == null) {
diffUtilCallback = new DiffUtilCallback();
}
@@ -4395,16 +4362,14 @@ private synchronized void animateDiff(@Nullable List newItems, Payload payloa
private synchronized void animateTo(@Nullable List newItems, Payload payloadChange) {
mNotifications = new ArrayList<>();
if (newItems != null && newItems.size() <= mAnimateToLimit) {
- if (DEBUG)
- Log.v(TAG, "Animate changes! oldSize=" + getItemCount() + " newSize=" + newItems.size() + " limit=" + mAnimateToLimit);
+ Log.d("Animate changes! oldSize=%s newSize=%s limit=%s", getItemCount(), newItems.size(), mAnimateToLimit);
mTempItems = new ArrayList<>(mItems);
applyAndAnimateRemovals(mTempItems, newItems);
applyAndAnimateAdditions(mTempItems, newItems);
if (notifyMoveOfFilteredItems)
applyAndAnimateMovedItems(mTempItems, newItems);
} else {
- if (DEBUG)
- Log.v(TAG, "NotifyDataSetChanged! oldSize=" + getItemCount() + " newSize=" + (newItems != null ? newItems.size() : "0") + " limit=" + mAnimateToLimit);
+ Log.d("NotifyDataSetChanged! oldSize=%s newSize=%s limit=%s", getItemCount(), (newItems != null ? newItems.size() : "0"), mAnimateToLimit);
mTempItems = newItems;
mNotifications.add(new Notification(-1, 0));
}
@@ -4451,8 +4416,7 @@ private void applyAndAnimateRemovals(List from, List newItems) {
if (mFilterAsyncTask != null && mFilterAsyncTask.isCancelled()) return;
final T item = from.get(i);
if (!mHashItems.contains(item)) {
- if (DEBUG)
- Log.v(TAG, "calculateRemovals remove position=" + i + " item=" + item + " searchText=" + mSearchText);
+ Log.v("calculateRemovals remove position=%s item=%s searchText=%s", i, item, mSearchText);
from.remove(i);
mNotifications.add(new Notification(i, Notification.REMOVE));
out++;
@@ -4469,10 +4433,8 @@ private void applyAndAnimateRemovals(List from, List newItems) {
}
}
mHashItems = null;
- if (DEBUG) {
- Log.v(TAG, "calculateModifications total mod=" + mod);
- Log.v(TAG, "calculateRemovals total out=" + out);
- }
+ Log.d("calculateModifications total mod=%s", mod);
+ Log.d("calculateRemovals total out=%s", out);
}
/**
@@ -4488,8 +4450,7 @@ private void applyAndAnimateAdditions(List from, List newItems) {
if (mFilterAsyncTask != null && mFilterAsyncTask.isCancelled()) return;
final T item = newItems.get(position);
if (!mHashItems.contains(item)) {
- if (DEBUG)
- Log.v(TAG, "calculateAdditions add position=" + position + " item=" + item + " searchText=" + mSearchText);
+ Log.v("calculateAdditions add position=%s item=%s searchText=%s", position, item, mSearchText);
if (notifyMoveOfFilteredItems) {
// We add always at the end to animate moved items at the missing position
from.add(item);
@@ -4504,7 +4465,7 @@ private void applyAndAnimateAdditions(List from, List newItems) {
}
}
mHashItems = null;
- if (DEBUG) Log.v(TAG, "calculateAdditions total new=" + in);
+ Log.d("calculateAdditions total new=%s", in);
}
/**
@@ -4520,8 +4481,7 @@ private void applyAndAnimateMovedItems(List from, List newItems) {
final T item = newItems.get(toPosition);
final int fromPosition = from.indexOf(item);
if (fromPosition >= 0 && fromPosition != toPosition) {
- if (DEBUG)
- Log.v(TAG, "calculateMovedItems fromPosition=" + fromPosition + " toPosition=" + toPosition + " searchText=" + mSearchText);
+ Log.v("calculateMovedItems fromPosition=%s toPosition=%s searchText=%s", fromPosition, toPosition, mSearchText);
T movedItem = from.remove(fromPosition);
if (toPosition < from.size()) from.add(toPosition, movedItem);
else from.add(movedItem);
@@ -4529,17 +4489,17 @@ private void applyAndAnimateMovedItems(List from, List newItems) {
move++;
}
}
- if (DEBUG) Log.v(TAG, "calculateMovedItems total move=" + move);
+ Log.v("calculateMovedItems total move=%s", move);
}
private synchronized void executeNotifications(Payload payloadChange) {
if (diffResult != null) {
- if (DEBUG) Log.i(TAG, "Dispatching notifications");
+ Log.i("Dispatching notifications");
mItems = diffUtilCallback.getNewItems(); //Update mItems in the UI Thread
diffResult.dispatchUpdatesTo(this);
diffResult = null;
} else {
- if (DEBUG) Log.i(TAG, "Performing " + mNotifications.size() + " notifications");
+ Log.i("Performing %s notifications", mNotifications.size());
mItems = mTempItems; //Update mItems in the UI Thread
setScrollAnimate(false); //Disable scroll animation
for (Notification notification : mNotifications) {
@@ -4557,7 +4517,7 @@ private synchronized void executeNotifications(Payload payloadChange) {
notifyItemMoved(notification.fromPosition, notification.position);
break;
default:
- if (DEBUG) Log.w(TAG, "notifyDataSetChanged!");
+ Log.w("notifyDataSetChanged!");
notifyDataSetChanged();
break;
}
@@ -4567,7 +4527,7 @@ private synchronized void executeNotifications(Payload payloadChange) {
}
time = System.currentTimeMillis();
time = time - start;
- if (DEBUG) Log.i(TAG, "Animate changes DONE in " + time + "ms");
+ Log.i("Animate changes DONE in %sms", time);
}
/**
@@ -4588,7 +4548,7 @@ private void initializeItemTouchHelper() {
}
if (mItemTouchHelperCallback == null) {
mItemTouchHelperCallback = new ItemTouchHelperCallback(this);
- if (DEBUG) Log.i(TAG, "Initialized default ItemTouchHelperCallback");
+ Log.i("Initialized default ItemTouchHelperCallback");
}
mItemTouchHelper = new ItemTouchHelper(mItemTouchHelperCallback);
mItemTouchHelper.attachToRecyclerView(mRecyclerView);
@@ -4633,7 +4593,7 @@ public final FlexibleAdapter setItemTouchHelperCallback(ItemTouchHelperCallback
mItemTouchHelperCallback = itemTouchHelperCallback;
mItemTouchHelper = null;
initializeItemTouchHelper();
- if (DEBUG) Log.i(TAG, "Initialized custom ItemTouchHelperCallback");
+ Log.i("Initialized custom ItemTouchHelperCallback");
return this;
}
@@ -4664,7 +4624,7 @@ public final boolean isLongPressDragEnabled() {
*/
public final FlexibleAdapter setLongPressDragEnabled(boolean longPressDragEnabled) {
initializeItemTouchHelper();
- if (DEBUG) Log.i(TAG, "Set longPressDragEnabled=" + longPressDragEnabled);
+ Log.i("Set longPressDragEnabled=%s", longPressDragEnabled);
mItemTouchHelperCallback.setLongPressDragEnabled(longPressDragEnabled);
return this;
}
@@ -4694,7 +4654,7 @@ public final boolean isHandleDragEnabled() {
*/
public final FlexibleAdapter setHandleDragEnabled(boolean handleDragEnabled) {
initializeItemTouchHelper();
- if (DEBUG) Log.i(TAG, "Set handleDragEnabled=" + handleDragEnabled);
+ Log.i("Set handleDragEnabled=%s", handleDragEnabled);
this.mItemTouchHelperCallback.setHandleDragEnabled(handleDragEnabled);
return this;
}
@@ -4722,7 +4682,7 @@ public final boolean isSwipeEnabled() {
* @since 5.0.0-b1
*/
public final FlexibleAdapter setSwipeEnabled(boolean swipeEnabled) {
- if (DEBUG) Log.i(TAG, "Set swipeEnabled=" + swipeEnabled);
+ Log.i("Set swipeEnabled=%s", swipeEnabled);
initializeItemTouchHelper();
mItemTouchHelperCallback.setSwipeEnabled(swipeEnabled);
return this;
@@ -4755,8 +4715,7 @@ public void moveItem(int fromPosition, int toPosition) {
* @since 5.0.0-b7
*/
public void moveItem(int fromPosition, int toPosition, @Nullable Object payload) {
- if (DEBUG)
- Log.v(TAG, "moveItem fromPosition=" + fromPosition + " toPosition=" + toPosition);
+ Log.v("moveItem fromPosition=%s toPosition=%s", fromPosition, toPosition);
// Preserve selection
if ((isSelected(fromPosition))) {
removeSelection(fromPosition);
@@ -4792,11 +4751,8 @@ public void swapItems(List list, int fromPosition, int toPosition) {
toPosition < 0 || toPosition >= getItemCount()) {
return;
}
- if (DEBUG) {
- Log.v(TAG, "swapItems from=" +
- fromPosition + " [selected? " + isSelected(fromPosition) + "] to=" +
- toPosition + " [selected? " + isSelected(toPosition) + "]");
- }
+ Log.v("swapItems from=%s [selected? %s] to=%s [selected? %s]",
+ fromPosition, isSelected(fromPosition), toPosition, isSelected(toPosition));
// Collapse expandable before swapping (otherwise items are mixed badly)
if (fromPosition < toPosition && isExpandable(getItem(fromPosition)) && isExpanded(toPosition)) {
@@ -4806,13 +4762,13 @@ public void swapItems(List list, int fromPosition, int toPosition) {
// Perform item swap (for all LayoutManagers)
if (fromPosition < toPosition) {
for (int i = fromPosition; i < toPosition; i++) {
- if (DEBUG) Log.v(TAG, "swapItems from=" + i + " to=" + (i + 1));
+ Log.v("swapItems from=%s to=%s", i, (i + 1));
Collections.swap(mItems, i, i + 1);
swapSelection(i, i + 1);
}
} else {
for (int i = fromPosition; i > toPosition; i--) {
- if (DEBUG) Log.v(TAG, "swapItems from=" + i + " to=" + (i - 1));
+ Log.v("swapItems from=%s to=%s", i, (i - 1));
Collections.swap(mItems, i, i - 1);
swapSelection(i, i - 1);
}
@@ -4947,8 +4903,7 @@ public void onItemSwiped(int position, int direction) {
private void mapViewTypeFrom(T item) {
if (item != null && !mTypeInstances.containsKey(item.getLayoutRes())) {
mTypeInstances.put(item.getLayoutRes(), item);
- if (DEBUG)
- Log.i(TAG, "Mapped viewType " + item.getLayoutRes() + " from " + getClassName(item));
+ Log.i("Mapped viewType %s from %s", item.getLayoutRes(), getClassName(item));
}
}
@@ -4984,10 +4939,8 @@ private void createRestoreSubItemInfo(IExpandable expandable, T item) {
List siblings = getExpandableList(expandable);
int childPosition = siblings.indexOf(item);
mRestoreList.add(new RestoreInfo((T) expandable, item, childPosition));
- if (DEBUG) {
- Log.v(TAG, "Recycled SubItem " + mRestoreList.get(mRestoreList.size() - 1)
- + " with Parent position=" + getGlobalPositionOf(expandable));
- }
+ Log.v("Recycled SubItem %s with Parent position=%s",
+ mRestoreList.get(mRestoreList.size() - 1), getGlobalPositionOf(expandable));
}
/**
@@ -5007,8 +4960,7 @@ private void createRestoreItemInfo(int position, T item) {
if (expandable != null) refItem = (T) expandable;
}
mRestoreList.add(new RestoreInfo(refItem, item));
- if (DEBUG)
- Log.v(TAG, "Recycled Item " + mRestoreList.get(mRestoreList.size() - 1) + " on position=" + position);
+ Log.v("Recycled Item %s on position=%s", mRestoreList.get(mRestoreList.size() - 1), position);
}
/**
@@ -5059,8 +5011,7 @@ public boolean handleMessage(Message message) {
int firstVisibleItem = getFlexibleLayoutManager().findFirstCompletelyVisibleItemPosition();
int lastVisibleItem = getFlexibleLayoutManager().findLastCompletelyVisibleItemPosition();
int itemsToShow = position + subItemsCount - lastVisibleItem;
-// if (DEBUG)
-// Log.v(TAG, "autoScroll itemsToShow=" + itemsToShow + " firstVisibleItem=" + firstVisibleItem + " lastVisibleItem=" + lastVisibleItem + " RvChildCount=" + mRecyclerView.getChildCount());
+// Log.v("autoScroll itemsToShow=%s firstVisibleItem=%s lastVisibleItem=%s RvChildCount=%s", itemsToShow, firstVisibleItem, lastVisibleItem, mRecyclerView.getChildCount());
if (itemsToShow > 0) {
int scrollMax = position - firstVisibleItem;
int scrollMin = Math.max(0, position + subItemsCount - lastVisibleItem);
@@ -5070,8 +5021,7 @@ public boolean handleMessage(Message message) {
scrollBy = scrollBy % spanCount + spanCount;
}
int scrollTo = firstVisibleItem + scrollBy;
-// if (DEBUG)
-// Log.v(TAG, "autoScroll scrollMin=" + scrollMin + " scrollMax=" + scrollMax + " scrollBy=" + scrollBy + " scrollTo=" + scrollTo);
+// Log.v("autoScroll scrollMin=%s scrollMax=%s scrollBy=%s scrollTo=%s", scrollMin, scrollMax, scrollBy, scrollTo);
performScroll(scrollTo);
} else if (position < firstVisibleItem) {
performScroll(position);
@@ -5098,15 +5048,14 @@ public int compare(Integer lhs, Integer rhs) {
}
for (Integer position : selectedPositions) {
if (position >= startPosition) {
-// if (DEBUG)
-// Log.v(TAG, "Adjust Selected position " + position + " to " + Math.max(position + itemCount, startPosition));
+// Log.v("Adjust Selected position %s to %s", position, Math.max(position + itemCount, startPosition));
removeSelection(position);
addAdjustedSelection(Math.max(position + itemCount, startPosition));
adjusted = true;
}
}
- if (DEBUG && adjusted)
- Log.v(TAG, "AdjustedSelected(" + diff + itemCount + ")=" + getSelectedPositions());
+ if (adjusted)
+ Log.v("AdjustedSelected(%s)=%s", (diff + itemCount), getSelectedPositions());
}
/*----------------*/
@@ -5487,7 +5436,6 @@ public String toString() {
private class FilterAsyncTask extends AsyncTask {
- private final String TAG = FilterAsyncTask.class.getSimpleName();
private final List newItems;
private final int what;
@@ -5500,13 +5448,13 @@ private class FilterAsyncTask extends AsyncTask {
@Override
protected void onPreExecute() {
if (endlessLoading) {
- Log.w(TAG, "Cannot filter while endlessLoading");
+ Log.w("Cannot filter while endlessLoading");
this.cancel(true);
}
// Note: In case some items are in pending deletion (Undo started),
// we commit the deletion before starting or resetting the filter.
if (isRestoreInTime() && mDeleteCompleteListener != null) {
- if (DEBUG) Log.d(TAG, "Hiding all deleted items before filtering/updating");
+ Log.d("Hiding all deleted items before filtering/updating");
newItems.removeAll(getDeletedItems());
if (mOriginalList != null) mOriginalList.removeAll(getDeletedItems());
mDeleteCompleteListener.onDeleteConfirmed();
@@ -5515,7 +5463,7 @@ protected void onPreExecute() {
@Override
protected void onCancelled() {
- if (DEBUG) Log.i(TAG, "FilterAsyncTask cancelled!");
+ Log.i("FilterAsyncTask cancelled!");
}
@Override
@@ -5523,16 +5471,16 @@ protected Void doInBackground(Void... params) {
start = System.currentTimeMillis();
switch (what) {
case UPDATE:
- if (DEBUG) Log.d(TAG, "doInBackground - started UPDATE");
+ Log.d("doInBackground - started UPDATE");
prepareItemsForUpdate(newItems);
animateDiff(newItems, Payload.CHANGE);
//animateTo(newItems, Payload.CHANGE);
- if (DEBUG) Log.d(TAG, "doInBackground - ended UPDATE");
+ Log.d("doInBackground - ended UPDATE");
break;
case FILTER:
- if (DEBUG) Log.d(TAG, "doInBackground - started FILTER");
+ Log.d("doInBackground - started FILTER");
filterItemsAsync(newItems);
- if (DEBUG) Log.d(TAG, "doInBackground - ended FILTER");
+ Log.d("doInBackground - ended FILTER");
break;
}
return null;
@@ -5714,9 +5662,8 @@ public boolean areItemsTheSame(int oldItemPosition, int newItemPosition) {
*
* DiffUtil uses this method to check equality instead of {@link Object#equals(Object)}
* so that you can change its behavior depending on your UI.
- * For example, if you are using DiffUtil with a
- * {@link RecyclerView.Adapter RecyclerView.Adapter}, you should
- * return whether the items' visual representations are the same.
+ * For example, if you are using DiffUtil with a {@link RecyclerView.Adapter}, you
+ * should return whether the items' visual representations are the same.
*
* This method is called only if {@link #areItemsTheSame(int, int)} returns
* {@code true} for these items.
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/SelectableAdapter.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/SelectableAdapter.java
index d15a5935..e7159544 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/SelectableAdapter.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/SelectableAdapter.java
@@ -20,7 +20,6 @@
import android.support.annotation.NonNull;
import android.support.v4.view.ViewCompat;
import android.support.v7.widget.RecyclerView;
-import android.util.Log;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
@@ -37,6 +36,8 @@
import eu.davidea.flexibleadapter.common.FlexibleLayoutManager;
import eu.davidea.flexibleadapter.common.IFlexibleLayoutManager;
import eu.davidea.flexibleadapter.utils.FlexibleUtils;
+import eu.davidea.flexibleadapter.utils.Log;
+import eu.davidea.flexibleadapter.utils.Log.Level;
import eu.davidea.viewholders.FlexibleViewHolder;
/**
@@ -51,12 +52,14 @@
*
27/01/2016 Improved Selection, SelectAll, FastScroller
*
29/05/2016 Use of TreeSet instead of ArrayList
*
04/04/2017 Use of FastScrollerDelegate
+ *
05/06/2017 Improved Log system
*/
@SuppressWarnings({"unused", "unchecked", "ConstantConditions", "WeakerAccess"})
public abstract class SelectableAdapter extends RecyclerView.Adapter
implements FastScroller.BubbleTextCreator, FastScroller.OnScrollStateChangeListener, FastScroller.AdapterInterface {
private static final String TAG = SelectableAdapter.class.getSimpleName();
+ @Deprecated
public static boolean DEBUG = false;
/**
@@ -108,8 +111,8 @@ public abstract class SelectableAdapter extends RecyclerView.Adapter
* @since 1.0.0
*/
public SelectableAdapter() {
- Log.i("FlexibleAdapter", "Running version " + BuildConfig.VERSION_NAME);
- mSelectedPositions = new TreeSet<>();
+ Log.iTag("FlexibleAdapter", "Running version %s", BuildConfig.VERSION_NAME);
+ mSelectedPositions = Collections.synchronizedSet(new TreeSet());
mBoundViewHolders = new HashSet<>();
mMode = MODE_IDLE;
@@ -121,14 +124,29 @@ public SelectableAdapter() {
/*----------------*/
/**
- * Call this once, to enable or disable DEBUG logs.
+ * Call this once, to enable or disable logs.
* DEBUG logs are disabled by default.
*
* @param enable true to show DEBUG logs in verbose mode, false to hide them.
* @since 5.0.0-b1
+ * @deprecated Use the new {@link #enableLogs(int)}
*/
+ @Deprecated
public static void enableLogs(boolean enable) {
DEBUG = enable;
+ if (enable) enableLogs(Level.DEBUG);
+ else enableLogs(Level.SUPPRESS);
+ }
+
+ /**
+ * Call this once, to enable or disable internal logs with custom level.
+ * Logs are disabled by default.
+ *
+ * @param level One of {@link Level} value
+ * @since 5.0.0-b1
+ */
+ public static void enableLogs(@Level int level) {
+ Log.setLevel(level);
}
/*--------------*/
@@ -175,8 +193,9 @@ public RecyclerView getRecyclerView() {
/**
* Current instance of the wrapper class for LayoutManager suitable for FlexibleAdapter.
* LayoutManager must be already initialized in the RecyclerView.
+ *
+ * return wrapper class for any non-conventional LayoutManagers or {@code null} if not initialized.
*
- * @return wrapper class for any non-conventional LayoutManagers or {@code null} if not initialized
* @since 5.0.0-rc2
*/
public IFlexibleLayoutManager getFlexibleLayoutManager() {
@@ -215,7 +234,7 @@ public void setFlexibleLayoutManager(IFlexibleLayoutManager flexibleLayoutManage
* @since 2.0.0
*/
public void setMode(@Mode int mode) {
- if (DEBUG) Log.i(TAG, FlexibleUtils.getModeName(mode) + " enabled");
+ Log.i("%s enabled", FlexibleUtils.getModeName(mode));
if (mMode == MODE_SINGLE && mode == MODE_IDLE)
clearSelection();
this.mMode = mode;
@@ -323,8 +342,8 @@ public void toggleSelection(int position) {
} else {
addSelection(position);
}
- if (DEBUG) Log.v(TAG, "toggleSelection " + (contains ? "removed" : "added") +
- " on position " + position + ", current " + mSelectedPositions);
+ Log.v("toggleSelection %s on position %s, current %s",
+ (contains ? "removed" : "added"), position, mSelectedPositions);
}
/**
@@ -388,7 +407,7 @@ protected void swapSelection(int fromPosition, int toPosition) {
public void selectAll(Integer... viewTypes) {
mSelectAll = true;
List viewTypesToSelect = Arrays.asList(viewTypes);
- if (DEBUG) Log.v(TAG, "selectAll ViewTypes to include " + viewTypesToSelect);
+ Log.v("selectAll ViewTypes to include %s", viewTypesToSelect);
int positionStart = 0, itemCount = 0;
for (int i = 0; i < getItemCount(); i++) {
if (isSelectable(i) &&
@@ -404,8 +423,7 @@ public void selectAll(Integer... viewTypes) {
}
}
}
- if (DEBUG)
- Log.d(TAG, "selectAll notifyItemRangeChanged from positionStart=" + positionStart + " itemCount=" + getItemCount());
+ Log.d("selectAll notifyItemRangeChanged from positionStart=%s itemCount=%s", positionStart, getItemCount());
notifySelectionChanged(positionStart, getItemCount());
}
@@ -419,7 +437,7 @@ public void selectAll(Integer... viewTypes) {
* @since 1.0.0
*/
public void clearSelection() {
- if (DEBUG) Log.d(TAG, "clearSelection " + mSelectedPositions);
+ Log.d("clearSelection %s", mSelectedPositions);
// #373 - ConcurrentModificationException with Undo after multiple rapid swipe removals
synchronized (mSelectedPositions) {
Iterator iterator = mSelectedPositions.iterator();
@@ -532,8 +550,8 @@ public Set getSelectedPositionsAsSet() {
*/
public void onSaveInstanceState(Bundle outState) {
outState.putIntegerArrayList(TAG, new ArrayList<>(mSelectedPositions));
- if (DEBUG && getSelectedItemCount() > 0)
- Log.d(TAG, "Saving selection " + mSelectedPositions);
+ if (Log.isDebugEnabled() && getSelectedItemCount() > 0)
+ Log.d("Saving selection %s", mSelectedPositions);
}
/**
@@ -544,8 +562,8 @@ public void onSaveInstanceState(Bundle outState) {
*/
public void onRestoreInstanceState(Bundle savedInstanceState) {
mSelectedPositions.addAll(savedInstanceState.getIntegerArrayList(TAG));
- if (DEBUG && getSelectedItemCount() > 0)
- Log.d(TAG, "Restore selection " + mSelectedPositions);
+ if (Log.isDebugEnabled() && getSelectedItemCount() > 0)
+ Log.d("Restore selection %s", mSelectedPositions);
}
/*---------------*/
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/FlexibleItemAnimator.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/FlexibleItemAnimator.java
index aad73c32..cc915df7 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/FlexibleItemAnimator.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/FlexibleItemAnimator.java
@@ -26,7 +26,6 @@
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.RecyclerView.ViewHolder;
import android.support.v7.widget.SimpleItemAnimator;
-import android.util.Log;
import android.view.View;
import android.view.animation.Interpolator;
import android.view.animation.LinearInterpolator;
@@ -36,7 +35,7 @@
import java.util.Comparator;
import java.util.List;
-import eu.davidea.flexibleadapter.FlexibleAdapter;
+import eu.davidea.flexibleadapter.utils.Log;
import eu.davidea.viewholders.AnimatedViewHolder;
/**
@@ -48,8 +47,6 @@
*/
public class FlexibleItemAnimator extends SimpleItemAnimator {
- private final String TAG = this.getClass().getSimpleName();
-
private ArrayList mPendingRemovals = new ArrayList<>();
private ArrayList mPendingAdditions = new ArrayList<>();
private ArrayList mPendingMoves = new ArrayList<>();
@@ -61,15 +58,15 @@ public class FlexibleItemAnimator extends SimpleItemAnimator {
private ArrayList mMoveAnimations = new ArrayList<>();
private ArrayList mChangeAnimations = new ArrayList<>();
- protected ArrayList mRemoveAnimations = new ArrayList<>();
- protected ArrayList mAddAnimations = new ArrayList<>();
+ private ArrayList mRemoveAnimations = new ArrayList<>();
+ private ArrayList mAddAnimations = new ArrayList<>();
protected Interpolator mInterpolator = new LinearInterpolator();
private static class MoveInfo {
public ViewHolder holder;
- public int fromX, fromY, toX, toY;
+ int fromX, fromY, toX, toY;
private MoveInfo(ViewHolder holder, int fromX, int fromY, int toX, int toY) {
this.holder = holder;
@@ -82,8 +79,8 @@ private MoveInfo(ViewHolder holder, int fromX, int fromY, int toX, int toY) {
private static class ChangeInfo {
- public ViewHolder oldHolder, newHolder;
- public int fromX, fromY, toX, toY;
+ ViewHolder oldHolder, newHolder;
+ int fromX, fromY, toX, toY;
private ChangeInfo(ViewHolder oldHolder, ViewHolder newHolder) {
this.oldHolder = oldHolder;
@@ -263,13 +260,14 @@ public void run() {
* Prepares the View for Remove Animation.
* - If {@link AnimatedViewHolder#preAnimateRemoveImpl()} is implemented and returns
* {@code true}, then ViewHolder has precedence and the implementation of this method is ignored;
- *
- If not, the implementation of this method is therefore performed.
+ *
- If not, the implementation of this method is therefore performed.
* Default value is {@code true}.
*
* @param holder the ViewHolder
* @return {@code true} if a later call to {@link #runPendingAnimations()} is requested,
* false otherwise.
*/
+ @SuppressWarnings("UnusedParameters")
protected boolean preAnimateRemoveImpl(final ViewHolder holder) {
return true;
}
@@ -279,7 +277,7 @@ protected boolean preAnimateRemoveImpl(final ViewHolder holder) {
* - If {@link AnimatedViewHolder#animateRemoveImpl(ViewPropertyAnimatorListener, long, int)} is
* implemented and returns true, then ViewHolder has precedence and the implementation of this
* method is ignored;
- *
- If not, the implementation of this method is therefore performed.
+ *
- If not, the implementation of this method is therefore performed.
*
* @param holder the ViewHolder
* @param index the progressive order of execution
@@ -298,8 +296,7 @@ private boolean preAnimateRemove(final ViewHolder holder) {
}
private void doAnimateRemove(final ViewHolder holder, final int index) {
- if (FlexibleAdapter.DEBUG)
- Log.v(TAG, "AnimateRemove on itemId " + holder.getItemId());
+ Log.v("AnimateRemove on itemId %s", holder.getItemId());
boolean consumed = false;
if (holder instanceof AnimatedViewHolder) {
consumed = ((AnimatedViewHolder) holder).animateRemoveImpl(new DefaultRemoveVpaListener(holder), getRemoveDuration(), index);
@@ -324,7 +321,7 @@ public final boolean animateRemove(final ViewHolder holder) {
* Prepares the View for Add Animation.
* - If {@link AnimatedViewHolder#preAnimateAddImpl()} is implemented and returns
* {@code true}, then ViewHolder has precedence and the implementation of this method is ignored;
- *
- If not, the implementation of this method is therefore performed.
+ *
- If not, the implementation of this method is therefore performed.
* Default value is {@code true}.
*
* @param holder the ViewHolder
@@ -340,7 +337,7 @@ protected boolean preAnimateAddImpl(final ViewHolder holder) {
* - If {@link AnimatedViewHolder#animateAddImpl(ViewPropertyAnimatorListener, long, int)} is
* implemented and returns {@code true}, then ViewHolder has precedence and the implementation
* of this method is ignored;
- *
- If not, the implementation of this method is therefore performed.
+ *
- If not, the implementation of this method is therefore performed.
*
* @param holder the ViewHolder
* @param index the progressive order of execution
@@ -359,8 +356,7 @@ private boolean preAnimateAdd(final ViewHolder holder) {
}
private void doAnimateAdd(final ViewHolder holder, final int index) {
- if (FlexibleAdapter.DEBUG)
- Log.v(TAG, "AnimateAdd on itemId=" + holder.getItemId() + " position=" + holder.getLayoutPosition());
+ Log.v("AnimateAdd on itemId=%s position=%s", holder.getItemId(), holder.getLayoutPosition());
boolean consumed = false;
if (holder instanceof AnimatedViewHolder) {
consumed = ((AnimatedViewHolder) holder).animateAddImpl(new DefaultAddVpaListener(holder), getAddDuration(), index);
@@ -765,7 +761,7 @@ public void endAnimations() {
dispatchAnimationsFinished();
}
- void cancelAll(List viewHolders) {
+ private void cancelAll(List viewHolders) {
for (int i = viewHolders.size() - 1; i >= 0; i--) {
ViewCompat.animate(viewHolders.get(i).itemView).cancel();
}
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/TopSnappedSmoothScroller.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/TopSnappedSmoothScroller.java
index dbbe3952..91518a3b 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/TopSnappedSmoothScroller.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/common/TopSnappedSmoothScroller.java
@@ -26,7 +26,7 @@
* Common class for all Smooth Scroller Layout Managers.
*
* @since 5.0.0-b6 Creation
- *
5.0.0-b8 Class is now public to allow customization of the MILLISECONDS_PER_INCH
+ *
5.0.0-b8 Class is now public to allow customization of the MILLISECONDS_PER_INCH
*/
public class TopSnappedSmoothScroller extends LinearSmoothScroller {
@@ -41,6 +41,7 @@ public class TopSnappedSmoothScroller extends LinearSmoothScroller {
private PointF vectorPosition = new PointF(0, 0);
private IFlexibleLayoutManager layoutManager;
+ @SuppressWarnings("WeakerAccess")
public TopSnappedSmoothScroller(Context context, RecyclerView.LayoutManager layoutManager) {
super(context);
this.layoutManager = new FlexibleLayoutManager(layoutManager);
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ActionModeHelper.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ActionModeHelper.java
index 83a75fa0..510288a2 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ActionModeHelper.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ActionModeHelper.java
@@ -18,10 +18,10 @@
import android.support.annotation.CallSuper;
import android.support.annotation.MenuRes;
import android.support.annotation.NonNull;
+import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.view.ActionMode;
import android.support.v7.widget.RecyclerView;
-import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
@@ -30,6 +30,7 @@
import eu.davidea.flexibleadapter.FlexibleAdapter;
import eu.davidea.flexibleadapter.SelectableAdapter;
import eu.davidea.flexibleadapter.SelectableAdapter.Mode;
+import eu.davidea.flexibleadapter.utils.Log;
/**
* Helper to coordinates the MULTI selection with FlexibleAdapter.
@@ -39,8 +40,6 @@
*/
public class ActionModeHelper implements ActionMode.Callback {
- public static final String TAG = ActionModeHelper.class.getSimpleName();
-
@Mode
private int defaultMode = SelectableAdapter.MODE_IDLE;
@MenuRes
@@ -72,7 +71,7 @@ public ActionModeHelper(@NonNull FlexibleAdapter adapter, @MenuRes int cabMenu)
* @since 5.0.0-b6
*/
public ActionModeHelper(@NonNull FlexibleAdapter adapter, @MenuRes int cabMenu,
- @NonNull ActionMode.Callback callback) {
+ @Nullable ActionMode.Callback callback) {
this(adapter, cabMenu);
this.mCallback = callback;
}
@@ -211,7 +210,7 @@ public void restoreSelection(AppCompatActivity activity) {
public boolean onCreateActionMode(ActionMode actionMode, Menu menu) {
// Inflate the Context Menu
actionMode.getMenuInflater().inflate(mCabMenu, menu);
- if (SelectableAdapter.DEBUG) Log.i(TAG, "ActionMode is active!");
+ Log.d("ActionMode is active!");
// Activate the ActionMode Multi
mAdapter.setMode(SelectableAdapter.MODE_MULTI);
// Notify the provided callback
@@ -246,8 +245,7 @@ public boolean onActionItemClicked(ActionMode actionMode, MenuItem item) {
@CallSuper
@Override
public void onDestroyActionMode(ActionMode actionMode) {
- if (SelectableAdapter.DEBUG)
- Log.i(TAG, "ActionMode is about to be destroyed! New mode will be " + defaultMode);
+ Log.d("ActionMode is about to be destroyed! New mode will be %s", defaultMode);
// Change mode and deselect everything
mAdapter.setMode(defaultMode);
mAdapter.clearSelection();
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/AnimatorHelper.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/AnimatorHelper.java
index 98ca955c..0f47c898 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/AnimatorHelper.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/AnimatorHelper.java
@@ -22,12 +22,11 @@
import android.support.annotation.NonNull;
import android.support.v4.view.ViewCompat;
import android.support.v7.widget.RecyclerView;
-import android.util.Log;
import android.view.View;
import java.util.List;
-import eu.davidea.flexibleadapter.FlexibleAdapter;
+import eu.davidea.flexibleadapter.utils.Log;
/**
* @author Davide Steduto
@@ -35,8 +34,6 @@
*/
public class AnimatorHelper {
- protected static final String TAG = AnimatorHelper.class.getSimpleName();
-
/*-----------*/
/* ANIMATORS */
/*-----------*/
@@ -68,7 +65,7 @@ public static void slideInFromLeftAnimator(
RecyclerView recyclerView, @FloatRange(from = 0.0, to= 1.0) float percent) {
alphaAnimator(animators, view, 0f);
animators.add(ObjectAnimator.ofFloat(view, "translationX", -recyclerView.getLayoutManager().getWidth() * percent, 0));
- if (FlexibleAdapter.DEBUG) Log.v(TAG, " Added LEFT Animator");
+ Log.v("Added LEFT Animator");
}
/**
@@ -84,7 +81,7 @@ public static void slideInFromRightAnimator(
RecyclerView recyclerView, @FloatRange(from = 0.0, to = 1.0) float percent) {
alphaAnimator(animators, view, 0f);
animators.add(ObjectAnimator.ofFloat(view, "translationX", recyclerView.getLayoutManager().getWidth() * percent, 0));
- if (FlexibleAdapter.DEBUG) Log.v(TAG, " Added RIGHT Animator");
+ Log.v("Added RIGHT Animator");
}
/**
@@ -99,7 +96,7 @@ public static void slideInFromTopAnimator(
RecyclerView recyclerView) {
alphaAnimator(animators, view, 0f);
animators.add(ObjectAnimator.ofFloat(view, "translationY", -recyclerView.getMeasuredHeight() >> 1, 0));
- if (FlexibleAdapter.DEBUG) Log.v(TAG, " Added TOP Animator");
+ Log.v("Added TOP Animator");
}
/**
@@ -114,7 +111,7 @@ public static void slideInFromBottomAnimator(
RecyclerView recyclerView) {
alphaAnimator(animators, view, 0f);
animators.add(ObjectAnimator.ofFloat(view, "translationY", recyclerView.getMeasuredHeight() >> 1, 0));
- if (FlexibleAdapter.DEBUG) Log.v(TAG, " Added BOTTOM Animator");
+ Log.v("Added BOTTOM Animator");
}
/**
@@ -130,7 +127,7 @@ public static void scaleAnimator(
alphaAnimator(animators, view, 0f);
animators.add(ObjectAnimator.ofFloat(view, "scaleX", scaleFrom, 1f));
animators.add(ObjectAnimator.ofFloat(view, "scaleY", scaleFrom, 1f));
- if (FlexibleAdapter.DEBUG) Log.v(TAG, " Added SCALE Animator");
+ Log.v("Added SCALE Animator");
}
/**
@@ -143,7 +140,7 @@ public static void scaleAnimator(
public static void flipAnimator(@NonNull List animators, @NonNull View view) {
alphaAnimator(animators, view, 0f);
animators.add(ObjectAnimator.ofFloat(view, "scaleY", 0f, 1f));
- if (FlexibleAdapter.DEBUG) Log.v(TAG, " Added FLIP Animator");
+ Log.v("Added FLIP Animator");
}
/**
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ItemTouchHelperCallback.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ItemTouchHelperCallback.java
index fc593eb2..0c51dac3 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ItemTouchHelperCallback.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/ItemTouchHelperCallback.java
@@ -41,7 +41,6 @@
@SuppressWarnings({"WeakerAccess", "unused"})
public class ItemTouchHelperCallback extends Callback {
- private static final String TAG = ItemTouchHelperCallback.class.getSimpleName();
protected static final float ALPHA_FULL = 1.0f;
protected AdapterCallback mAdapterCallback;
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/StickyHeaderHelper.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/StickyHeaderHelper.java
index 927a68a0..e0fe9f17 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/StickyHeaderHelper.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/StickyHeaderHelper.java
@@ -20,7 +20,6 @@
import android.support.v7.widget.OrientationHelper;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.RecyclerView.OnScrollListener;
-import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
@@ -31,6 +30,7 @@
import eu.davidea.flexibleadapter.FlexibleAdapter.OnStickyHeaderChangeListener;
import eu.davidea.flexibleadapter.R;
import eu.davidea.flexibleadapter.items.IHeader;
+import eu.davidea.flexibleadapter.utils.Log;
import eu.davidea.viewholders.FlexibleViewHolder;
/**
@@ -41,8 +41,6 @@
*/
public final class StickyHeaderHelper extends OnScrollListener {
- private static final String TAG = StickyHeaderHelper.class.getSimpleName();
-
private FlexibleAdapter mAdapter;
private RecyclerView mRecyclerView;
private ViewGroup mStickyHolderLayout;
@@ -83,7 +81,7 @@ public void detachFromRecyclerView() {
mRecyclerView.removeOnScrollListener(this);
mRecyclerView = null;
clearHeaderWithAnimation();
- if (FlexibleAdapter.DEBUG) Log.i(TAG, "StickyHolderLayout detached");
+ Log.d("StickyHolderLayout detached");
}
private FrameLayout createContainer(int width, int height) {
@@ -106,9 +104,9 @@ private void initStickyHeadersHolder() {
oldParentLayout.addView(stickyContainer);
// Initialize Holder Layout
mStickyHolderLayout = (ViewGroup) LayoutInflater.from(mRecyclerView.getContext()).inflate(R.layout.sticky_header_layout, stickyContainer);
- if (FlexibleAdapter.DEBUG) Log.i(TAG, "Default StickyHolderLayout initialized");
- } else if (FlexibleAdapter.DEBUG) {
- Log.i(TAG, "User defined StickyHolderLayout initialized");
+ Log.i("Default StickyHolderLayout initialized");
+ } else {
+ Log.i("User defined StickyHolderLayout initialized");
}
// Show sticky header if exists already
updateOrClearHeader(false);
@@ -158,8 +156,7 @@ private void updateHeader(int headerPosition, boolean updateHeaderContent) {
}
mHeaderPosition = headerPosition;
FlexibleViewHolder holder = getHeaderViewHolder(headerPosition);
- if (FlexibleAdapter.DEBUG)
- Log.d(TAG, "swapHeader newHeaderPosition=" + mHeaderPosition);
+ Log.d("swapHeader newHeaderPosition=%s", mHeaderPosition);
swapHeader(holder);
} else if (updateHeaderContent) {
// #299 - ClassCastException after click on expanded sticky header when AutoCollapse is enabled
@@ -291,7 +288,7 @@ private void resetHeader(FlexibleViewHolder header) {
private void clearHeader() {
if (mStickyHeaderViewHolder != null) {
- if (FlexibleAdapter.DEBUG) Log.d(TAG, "clearHeader");
+ Log.d("clearHeader");
resetHeader(mStickyHeaderViewHolder);
mStickyHolderLayout.setAlpha(0);
mStickyHolderLayout.animate().cancel();
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/UndoHelper.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/UndoHelper.java
index 9f262644..f6fc9794 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/UndoHelper.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/helpers/UndoHelper.java
@@ -273,7 +273,7 @@ public interface OnUndoListener {
/**
* Called when Undo timeout is over and action must be committed in the user Database.
* Due to Java Generic, it's too complicated and not well manageable if we pass the
- * List<T> object.
+ * {@code List} object.
* So, to get deleted items, use {@link FlexibleAdapter#getDeletedItems()} from the
* implementation of this method.
*
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/items/IFilterable.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/items/IFilterable.java
index fcaa11e3..e71e3165 100644
--- a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/items/IFilterable.java
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/items/IFilterable.java
@@ -33,7 +33,7 @@ public interface IFilterable {
* Checks and performs the filter on this item, you can apply the logic and the filter on
* every fields your use case foresees.
* Note: Filter method makes use of {@code HashSet}, in case you implemented
- * {@link #equals(Object)} you should implement {@link #hashCode()} too!
+ * {@link Object#equals(Object)} you should implement {@link Object#hashCode()} too!
*
* @param constraint the search text typed by the user always provided in lowercase
* @return true if this item should be collected by the Adapter for the filtered list, false otherwise
diff --git a/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/utils/Log.java b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/utils/Log.java
new file mode 100644
index 00000000..3ca6d464
--- /dev/null
+++ b/flexible-adapter/src/main/java/eu/davidea/flexibleadapter/utils/Log.java
@@ -0,0 +1,266 @@
+/*
+ * Copyright 2017 Davide Steduto
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package eu.davidea.flexibleadapter.utils;
+
+import android.support.annotation.IntDef;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+
+import static eu.davidea.flexibleadapter.utils.Log.Level.DEBUG;
+import static eu.davidea.flexibleadapter.utils.Log.Level.ERROR;
+import static eu.davidea.flexibleadapter.utils.Log.Level.INFO;
+import static eu.davidea.flexibleadapter.utils.Log.Level.SUPPRESS;
+import static eu.davidea.flexibleadapter.utils.Log.Level.VERBOSE;
+import static eu.davidea.flexibleadapter.utils.Log.Level.WARN;
+
+/**
+ * Utility class that simplifies the use of {@link android.util.Log} by improving the call
+ * to all log methods by supplying arguments as parameters instead of creating a string. This
+ * avoids useless memory allocations when not requested: the StringBuilder itself, the buffer
+ * and the String object. The new methods check in advance if the level is enabled and only
+ * after creates the string message with arguments.
+ * Others features are:
+ *
+ * - Automatic TAG corresponding to the caller class name.
+ * - Runtime log level without the need of props file (useful for libraries).
+ * - Method name with line number.
+ *
+ * Use {@link Level#SUPPRESS} to disable all logs. For instance:
+ *
+ * if (BuildConfig.DEBUG) {
+ * Log.setLevel(Level.INFO);
+ * } else {
+ * Log.setLevel(Level.SUPPRESS);
+ * }
+ *
+ *
+ * @author Davide Steduto
+ * @since 02/06/2017
+ */
+public class Log {
+
+ private static int LEVEL;
+ private static boolean withMethodName;
+ private static boolean withLineNumber;
+
+ private Log() {
+ }
+
+ /**
+ * Annotation interface for log level:
+ * {@link #VERBOSE}, {@link #DEBUG}, {@link #INFO},
+ * {@link #WARN}, {@link #ERROR}, {@link #SUPPRESS}
+ */
+ @IntDef({VERBOSE, DEBUG, INFO, WARN, ERROR, SUPPRESS})
+ @Retention(RetentionPolicy.SOURCE)
+ public @interface Level {
+ int VERBOSE = android.util.Log.VERBOSE;
+ int DEBUG = android.util.Log.DEBUG;
+ int INFO = android.util.Log.INFO;
+ int WARN = android.util.Log.WARN;
+ int ERROR = android.util.Log.ERROR;
+ int SUPPRESS = 10;
+ }
+
+ public static void setLevel(@Level int level) {
+ LEVEL = level;
+ }
+
+ /**
+ * Allows to log method name and line number from where the log is called.
+ * - With method name: {@code [method] msg}.
+ *
- With line number: {@code [method:line] msg}.
+ * Note: Line number needs method name enabled.
+ *
+ * @param method true to print method name at the beginning of the message, false otherwise
+ * @param line true to print line number after the method name, false otherwise
+ */
+ public static void logMethodName(boolean method, boolean line) {
+ withMethodName = method;
+ withLineNumber = line;
+ }
+
+ public static boolean isVerboseEnabled() {
+ return LEVEL <= VERBOSE;
+ }
+
+ public static boolean isDebugEnabled() {
+ return LEVEL <= DEBUG;
+ }
+
+ public static boolean isInfoEnabled() {
+ return LEVEL <= INFO;
+ }
+
+ public static boolean isWarnEnabled() {
+ return LEVEL <= WARN;
+ }
+
+ public static boolean isErrorEnabled() {
+ return LEVEL <= ERROR;
+ }
+
+ /**
+ * Sends a {@link Level#VERBOSE} log message.
+ *
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void v(String msg, Object... args) {
+ if (isVerboseEnabled()) {
+ android.util.Log.v(getTag(), formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * Sends a {@link Level#DEBUG} log message.
+ *
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void d(String msg, Object... args) {
+ if (isDebugEnabled()) {
+ android.util.Log.d(getTag(), formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * Sends an {@link Level#INFO} log message.
+ *
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void i(String msg, Object... args) {
+ if (isInfoEnabled()) {
+ android.util.Log.i(getTag(), formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * As {@link #i(String, Object...)} but with custom tag for one call only.
+ *
+ * @param tag custom tag, used to identify the source of a log message
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void iTag(String tag, String msg, Object... args) {
+ if (isInfoEnabled()) {
+ android.util.Log.i(tag, formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * Sends a {@link Level#WARN} log message.
+ *
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void w(String msg, Object... args) {
+ if (isWarnEnabled()) {
+ android.util.Log.w(getTag(), formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * Sends a {@link Level#WARN} log message with the Exception at the end of the message.
+ *
+ * @param t The exception to log
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void w(Throwable t, String msg, Object... args) {
+ if (isWarnEnabled()) {
+ android.util.Log.w(getTag(), formatMessage(msg, args), t);
+ }
+ }
+
+ /**
+ * Sends an {@link Level#ERROR} log message.
+ *
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void e(String msg, Object... args) {
+ if (isErrorEnabled()) {
+ android.util.Log.e(getTag(), formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * Sends an {@link Level#ERROR} log message with the Exception at the end of the message.
+ *
+ * @param t The exception to log
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void e(Throwable t, String msg, Object... args) {
+ if (isErrorEnabled()) {
+ android.util.Log.e(getTag(), formatMessage(msg, args), t);
+ }
+ }
+
+ /**
+ * What a Terrible Failure: Report a condition that should never happen.
+ *
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void wtf(String msg, Object... args) {
+ if (isErrorEnabled()) {
+ android.util.Log.wtf(getTag(), formatMessage(msg, args));
+ }
+ }
+
+ /**
+ * What a Terrible Failure: Report a condition that should never happen with the Exception
+ * at the end of the message.
+ *
+ * @param t The exception to log
+ * @param msg the message you would like logged
+ * @param args the extra arguments for the message
+ */
+ public static void wtf(Throwable t, String msg, Object... args) {
+ if (isErrorEnabled()) {
+ android.util.Log.wtf(getTag(), formatMessage(msg, args), t);
+ }
+ }
+
+ private static String getTag() {
+ StackTraceElement traceElement = new Throwable().getStackTrace()[2];
+ return traceElement.getFileName().split("[.]")[0];
+ }
+
+ private static String formatMessage(String msg, Object... args) {
+ // In order to have the "null" values logged we need to pass args when null to the formatter
+ // (This can still break depending on conversion of the formatter, see String.format)
+ // else if there is no args, we return the message as-is, otherwise we pass args to formatting normally.
+ return createLog(args != null && args.length == 0 ? msg : String.format(msg, args));
+ }
+
+ private static String createLog(String log) {
+ if (withMethodName) {
+ StackTraceElement traceElement = new Throwable().getStackTrace()[3];
+ if (withLineNumber) {
+ return String.format("[%s:%s] %s", traceElement.getMethodName(), traceElement.getLineNumber(), log);
+ } else {
+ return String.format("[%s] %s", traceElement.getMethodName(), log);
+ }
+ }
+ return log;
+ }
+
+}
\ No newline at end of file