- 
        
        
                +70         
                            - 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
 *  Calculates the minimum number of bits necessary to represent the given number.  The
     *      number should be given in its unsigned form with the starting bits equal to 1 if it is
     *      signed.  Repeatedly compares number to another unsigned int called x.
     *      x is initialized to 1.  The value of x is shifted left i times until x is greater
     *      than number.  Now i is equal to the number of bits the UNSIGNED value of number needs.
     *      The signed value will need one more bit for the sign so i+1 is returned if the number
     *      is signed, and i is returned if the number is unsigned.
 * @param number the number to compute the size of
 * @param bits 1 if number is signed, 0 if unsigned
 */
    public static int minBits(int number, int bits)
    {
    int val = 1;
    for (int x = 1; val <= number && !(bits > 32); x <<= 1) 
    {
        val = val | x;
        bits++;
    }
    if (bits > 32)
            {
                    assert false : ("minBits " + bits + " must not exceed 32");
            }
    return bits;
}
 
 
            Адоб, как обычно, порадовал (условие окончания цикла).
 [color=blue]https://git-wip-us.apache.org/repos/asf/flex-sdk/repo?p=flex-sdk.git;a=blob;f=modules/swfutils/src/java/flash/swf/SwfEncoder.java;h=03a100dda92989d537b00b  96033d614c73c47801;hb=HEAD#l320[/code]
 
             wvxvw,
            17 Августа 2014 wvxvw,
            17 Августа 2014
 
- 
        
        
                +70         
                            - 001
- 002
- 003
- 004
- 005
- 006
- 007
- 008
- 009
- 010
- 011
- 012
- 013
- 014
- 015
- 016
- 017
- 018
- 019
- 020
- 021
- 022
- 023
- 024
- 025
- 026
- 027
- 028
- 029
- 030
- 031
- 032
- 033
- 034
- 035
- 036
- 037
- 038
- 039
- 040
- 041
- 042
- 043
- 044
- 045
- 046
- 047
- 048
- 049
- 050
- 051
- 052
- 053
- 054
- 055
- 056
- 057
- 058
- 059
- 060
- 061
- 062
- 063
- 064
- 065
- 066
- 067
- 068
- 069
- 070
- 071
- 072
- 073
- 074
- 075
- 076
- 077
- 078
- 079
- 080
- 081
- 082
- 083
- 084
- 085
- 086
- 087
- 088
- 089
- 090
- 091
- 092
- 093
- 094
- 095
- 096
- 097
- 098
- 099
- 100
 public void testTranlateScript() throws Exception {
		// Инициализируем бесконечный цикл переводов. Должен переводить пока не
		// кончатся тексты, ну или пока не зависнет. Потом кинет Exception.
		int i = 1;
		while (true) {
			int j = 1;
			// Фильтруем по непереведенному на какой-то язык и нажимаем первую
			// ссылку "Перевести". Нужно указывать алиас языка на который
			// переводим в фильтре.
			driver.findElement(By.id("content_filter_header")).click();
			System.out.println(i
					+ "."
					+ j
					+ "  "
					+ "начинаем настройку фильтра "
					+ driver.findElement(By.id("content_filter_header"))
							.toString());
			j++;
			new Select(driver.findElement(By.id("filter-lang-type")))
					.selectByVisibleText("Не переведено на язык(и)");
			driver.findElement(By.id("filter-lang-alias-en")).click();
			System.out.println(i
					+ "."
					+ j
					+ "  "
					+ "заканчиваем настройку фильтра "
					+ driver.findElement(By.id("filter-lang-alias-en"))
							.toString());
			j++;
			driver.findElement(By.name("btn_filter")).click();
			System.out.println(i + "." + j + "  "
					+ "нажимаем на кнопку Применить "
					+ driver.findElement(By.name("btn_filter")).toString());
			j++;
			driver.findElements(By.linkText("Перевести")).get(0).click();
			System.out.println(i
					+ "."
					+ j
					+ "  "
					+ "нажимаем на первую ссылку Перевести "
					+ driver.findElements(By.linkText("Перевести")).get(0)
							.toString());
			j++;
			// Ищем оригинальный текст и присваеваем его переменной
			for (int second = 0;; second++) {
				if (second >= 60)
					fail("timeout");
				try {
					if (isElementPresent(By.id("original-text")))
						break;
				} catch (Exception e) {
				}
				Thread.sleep(1000);
			}
			// driver.findElement(By.id("original-text")).isDisplayed();
			String text_to_translate = driver.findElement(
					By.id("original-text")).getText();
			System.out.println(i + "." + j + "  " + "текст получен: '"
					+ text_to_translate + "'     "
					+ driver.findElement(By.id("original-text")).toString());
			j++;
			if ((text_to_translate == null) || (text_to_translate.equals(""))) {
				System.out.println(i + "." + j + "  "
						+ "Выход по break (пустой текст):"+ "'" + text_to_translate + "'");
				j++;
				break;
			}
			// Вот это по идее должно не допускать, пустые стринги в тех
			// случаях, если не сработал локатор.
			// Идем в гугл и переводим текст из переменной. Тут нужно
			// указывать
			// алиасы языков с которого и на который переводим.
			driver.get("https://translate.google.com/#ru/en/"
					+ text_to_translate);
			// Ждем элемент с переведенным текстом и присваиваем его новой
			// переменной.
			driver.findElement(By.id("source")).isDisplayed();
			String text_translated = driver.findElement(By.id("result_box"))
					.getText();
			// Возвращаемся на сайт и снова точно также фильтруем.
			driver.get(baseUrl + "/admin/translate");
			driver.findElement(By.id("content_filter_header")).click();
			System.out.println(i
					+ "."
					+ j
					+ "  "
					+ "снова начинаем настройку фильтра "
					+ driver.findElement(By.id("content_filter_header"))
							.toString());
			j++;
			new Select(driver.findElement(By.id("filter-lang-type")))
					.selectByVisibleText("Не переведено на язык(и)");
			driver.findElement(By.id("filter-lang-alias-en")).click();
			System.out.println(i
					+ "."
					+ j
					+ "  "
					+ "снова заканчиваем настройку фильтра "
					+ driver.findElement(By.id("filter-lang-alias-en"))
 
 
            http://pastebin.com/hQdwHepm
         
             jkhne4pijgberg,
            15 Августа 2014 jkhne4pijgberg,
            15 Августа 2014
 
- 
        
        
                +122         
                            - 1
- 2
- 3
 protected SimulationElement getThis(){
	return this;
}
 
 
            
         
             someone,
            08 Августа 2014 someone,
            08 Августа 2014
 
- 
        
        
                +74         
                            - 1
- 2
- 3
- 4
- 5
- 6
- 7
 public static void sleep(long millis, int nanos)  throws InterruptedException {
        // ...
        if (nanos >= 500000 || (nanos != 0 && millis == 0)) {
            millis++;
        }
        sleep(millis);
    }
 
 
            Системе пофиг сколько конкретно ты указал наносекунд . Всё равно никак не проверишь:)
 Java Oracle, Thread::sleep(long,long)
 
             SSSandman,
            08 Августа 2014 SSSandman,
            08 Августа 2014
 
- 
        
        
                +124         
                            - 1
- 2
- 3
- 4
- 5
- 6
- 7
 PYLayerPanel layerPanel = pyLayer.getLayerPanel(); 
int width = layerPanel.getWidth();
int height = layerPanel.getHeight();
double gScale = 1.0;
if(layerPanel != null){
	gScale = layerPanel.getViewport().getScaleFactor();
}
 
 
            Автор вспомнил, что надо бы проверять на null. Только немного не там...
         
             someone,
            08 Августа 2014 someone,
            08 Августа 2014
 
- 
        
        
                +123         
                            - 1
 public <T extends IOrderSubmitRequest & IApiStoreRef> Order buildOrderFromSubmitRequest(final T request) { ... }
 
 
            Типы-пересечения для бедных. Нужна была функция, работающая с несколькими классами без общего предка, реализующими сразу два интерфейса.
         
             someone,
            07 Августа 2014 someone,
            07 Августа 2014
 
- 
        
        
                +69         
                            - 001
- 002
- 003
- 004
- 005
- 006
- 007
- 008
- 009
- 010
- 011
- 012
- 013
- 014
- 015
- 016
- 017
- 018
- 019
- 020
- 021
- 022
- 023
- 024
- 025
- 026
- 027
- 028
- 029
- 030
- 031
- 032
- 033
- 034
- 035
- 036
- 037
- 038
- 039
- 040
- 041
- 042
- 043
- 044
- 045
- 046
- 047
- 048
- 049
- 050
- 051
- 052
- 053
- 054
- 055
- 056
- 057
- 058
- 059
- 060
- 061
- 062
- 063
- 064
- 065
- 066
- 067
- 068
- 069
- 070
- 071
- 072
- 073
- 074
- 075
- 076
- 077
- 078
- 079
- 080
- 081
- 082
- 083
- 084
- 085
- 086
- 087
- 088
- 089
- 090
- 091
- 092
- 093
- 094
- 095
- 096
- 097
- 098
- 099
- 100
 "add()\n";
assert((row_indx >= 0 && row_indx <= rows) && 
(col_indx >= 0 && col_indx < cols)
);
if(row_indx == rows)
addRow();
if(init_flag_arr[row_indx][col_indx])
{
std::cout « "in moving\n";
int uninit_i, uninit_j;
bool found = false;
for(int i = row_indx; found == false && i < rows; i++)
for(int j = col_indx; found == false && j < cols; j++)
if(!init_flag_arr[i][j]) // если флаг == false
{
std::cout « "found!\n";
uninit_i = i;
uninit_j = j;
found = true;
}
if(!found)
{
std::cout « "not found!\n";
addRow(); // добовляем новую строку в матрицу (rows++)
uninit_i = rows - 1;
uninit_j = 0;
}
bool exit = false;
for(int i = uninit_i, j = uninit_j; exit == false; i--)
{
for(; ;j--)
{
if(j == col_indx && i == row_indx)
{
exit = true;
break;
}
if(j == 0)
{
matrix[i][j] = matrix[i - 1][cols - 1];
init_flag_arr[i][j] = init_flag_arr[i - 1][cols - 1];
break; 
}
matrix[i][j] = matrix[i][j - 1];
init_flag_arr[i][j] = init_flag_arr[i][j - 1];
}
j = cols - 1;
}
} 
matrix[row_indx][col_indx] = obj;
init_flag_arr[row_indx][col_indx] = true;
std::cout « "end add()\n";
}
// Для дебага, вывод инициализированных ячеек матрицы
void Matrix::InitTable(std::ostream& os)const // чисто для дебага
{
for(int i = 0; i < rows; i++)
{
for(int j = 0; j < cols; j++)
if(!init_flag_arr[i][j])
os « "false\t";
else
os « "true\t";
os « std::endl;
}
}
// Удаление объекта с матрицы
void Matrix::remove(int row_indx, int col_indx)
{
std::cout « "remove()\n";
assert((row_indx >= 0 && row_indx < rows) && 
(col_indx >= 0 && col_indx < cols)
);
matrix[row_indx][col_indx] = 0;
init_flag_arr[row_indx][col_indx] = false;
std::cout « "end remove()\n";
}
void Matrix::removeRow(int row_indx)
{
assert(row_indx >= 0 && row_indx < rows);
int** new_matrix = new int*[rows - 1];
bool** new_init_flag_arr = new bool*[rows];
for(int i = 0; i < rows - 1; i++)
{
new_matrix[i] = new int[cols];
new_init_flag_arr[i] = new bool[cols];
//for(int j = 0; j < cols; j++)
//{
// new_matrix[i][j] = 0;
// new_init_flag_arr[i][j] = false;
//}/
 
 
            ...
         
             ana_stasia ,
            06 Августа 2014 ana_stasia ,
            06 Августа 2014
 
- 
        
        
                +73         
                            - 1
- 2
- 3
- 4
- 5
 Integer pageNumber = firstPosition / pageSize;
if (firstPosition % pageSize != 0 || pageNumber == 0) {
  pageNumber++;
}
personFilter.setPageNumber(pageNumber - 1);
 
 
            Магия пейдженации
         
             forn,
            04 Августа 2014 forn,
            04 Августа 2014
 
- 
        
        
                +71         
                            - 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
 public StickyRouting getStickyRouting(String groupName, String sbPin, String ccNumber) {
        StickyRouting result = null;
 
        boolean isGroupNameEmpty = StringUtils.isEmpty(groupName) ? true : false;
        boolean isCcNumberEmpty = StringUtils.isEmpty(ccNumber) ? true : false;
        boolean isSbPinEmpty = StringUtils.isEmpty(sbPin) ? true : false;
        ...
}
 
 
            
         
             bfg1989,
            03 Августа 2014 bfg1989,
            03 Августа 2014
 
- 
        
        
                +71         
                            - 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
 public Move move(final Board board) {
	for (final Move move : Move.values()) {
		if ((move.getDx() == Math.signum(this.target.x - board.getCx()))
			&& (move.getDy() == Math.signum(this.target.y - board.getCy()))) {
			return move;
		}
	}
	return null;
}
 
 
            выбираем направление движения. как? перебором!
         
             Lure Of Chaos,
            23 Июля 2014 Lure Of Chaos,
            23 Июля 2014