-
+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
-
+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
-
+122
- 1
- 2
- 3
protected SimulationElement getThis(){
return this;
}
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
-
+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
-
+123
- 1
public <T extends IOrderSubmitRequest & IApiStoreRef> Order buildOrderFromSubmitRequest(final T request) { ... }
Типы-пересечения для бедных. Нужна была функция, работающая с несколькими классами без общего предка, реализующими сразу два интерфейса.
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
-
+73
- 1
- 2
- 3
- 4
- 5
Integer pageNumber = firstPosition / pageSize;
if (firstPosition % pageSize != 0 || pageNumber == 0) {
pageNumber++;
}
personFilter.setPageNumber(pageNumber - 1);
Магия пейдженации
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
-
+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