Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit bf567be4 authored by Siarhei Vishniakou's avatar Siarhei Vishniakou Committed by Android (Google) Code Review
Browse files

Merge "Remove unused code that has a potential data race."

parents 88f14dd2 acf07d23
Loading
Loading
Loading
Loading
+2 −45
Original line number Original line Diff line number Diff line
@@ -16,62 +16,19 @@


package android.widget;
package android.widget;


import com.android.frameworks.coretests.R;

import android.app.Activity;
import android.app.Activity;
import android.os.Bundle;
import android.os.Bundle;
import android.os.SystemClock;

import android.util.Log;
import com.android.frameworks.coretests.R;


/**
/**
 * An activity for testing the TextView widget.
 * An activity for testing the TextView widget.
 *
 * This class is copied from {@link android.text.method.cts.KeyListenerCtsActivity} in
 * CtsTextTestCase.  The original class is located at
 * cts/tests/tests/text/src/android/text/method/cts/KeyListenerCtsActivity.java
 */
 */
public class TextViewActivity extends Activity {
public class TextViewActivity extends Activity {
    private boolean mHasWindowFocus = false;
    private Object mHasWindowFocusLock = new Object();


    @Override
    @Override
    protected void onCreate(Bundle savedInstanceState) {
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_text_view);
        setContentView(R.layout.activity_text_view);
    }
    }

    @Override
    public void onWindowFocusChanged(boolean hasFocus) {
        super.onWindowFocusChanged(hasFocus);
        if (!hasFocus) {
            Log.w("TextViewActivity", "TextViewActivity lost window focus");
        }
        synchronized(mHasWindowFocusLock) {
            mHasWindowFocus = hasFocus;
            mHasWindowFocusLock.notify();
        }
    }

    /**
     * Blocks the calling thread until the {@link KeyListenerCtsActivity} has window focus or the
     * specified duration (in milliseconds) has passed.
     */
    public boolean waitForWindowFocus(long durationMillis) {
        long elapsedMillis = SystemClock.elapsedRealtime();
        synchronized(mHasWindowFocusLock) {
            mHasWindowFocus = hasWindowFocus();
            while (!mHasWindowFocus && durationMillis > 0) {
                long newElapsedMillis = SystemClock.elapsedRealtime();
                durationMillis -= (newElapsedMillis - elapsedMillis);
                elapsedMillis = newElapsedMillis;
                if (durationMillis > 0) {
                    try {
                        mHasWindowFocusLock.wait(durationMillis);
                    } catch (InterruptedException e) {
                    }
                }
            }
            return mHasWindowFocus;
        }
    }
}
}