Psytronica

Web-разработка, иностранные языки, Eclipse и разные разности

Портфолио

Разработка сайтов под ключ с использованием CMS Joomla, Wordpress и др. Написание собственных CMS и расширений для сайтов. Работа с популярными фреймворками.

Санскрит

Программа, позволяющая практиковаться в составлении форм санскритских глаголов.

Verbarium

Приложение-тренажер, позволяющее более эффективно запоминать неправильные испанские глаголы. Легкая и увлекательная подготовка к экзамену.

Eclipse Memory View: AsyncTableRenderingViewer - убрать левые отступы в ячейках HexRendering

26.01.2018
Сделала наследник класса HexRendering, в котором добавила возможность подсветки определенных ячеек. При этом возник странный отступ слева в ячейках таблицы SWT Table. Однако, при просмотре данной таблицы в SPY никаких странных отступов не наблюдалось. Поиск на тему SWT Table remove left padding or indent не дал результатов



Что оказалось:

Данные отступы - вовсе не паддинги и не отступы, а прозрачные картинки icons/full/obj16/memory_obj.png. С какой целью разработчики их добавили, для меня до сих пор остается загадкой, но то, что место они съедают, образуя белые просветы - это факт Сами картинки запрашиваются в классе MemorySegmentLabelAdapter в функции getColumnImageDescriptor Наследование и модификация getAdapter в наследнике HexRendering не дала желаемого результата. У меня появилась возможность подставить большинство собственных картинок. Я создала класс, наследующий ILabelProvider и строка 176 функции getColumnImageDescriptor стала возвращать мой класс вместо null:

ILabelProvider labelProvider = tableRendering.getAdapter(ILabelProvider.class);


Но это сильно не спасло положение, покольку в случае колонки с индексом 0 все равно возвращалась стандартная картинка:

if (columnIndex == 0)
  return DebugPluginImages.getImageDescriptor(IInternalDebugUIConstants.IMG_OBJECT_MEMORY);


Тогда мне пришлось сделать наследник класса AsyncTableRenderingViewer с одной единственной функцией setLabels, из которой я исключила строки:

1
2
3
4
5
6
7
if (imageDescriptors != null) {
    for (int i = 0; i < images.length; i++) {
        if (i < imageDescriptors.length) {
          images[i] = getImage(imageDescriptors[i]);
        }
    }
}


На выходе получился желаемый результат:


Проблема со знаками ??? в Memory Rendering (HexRendering) в Eclipse

20.01.2018

Условия возникновения:

Если при запуске отладочной сессии не было остановки на брейкпоинте, останов случился по нажатию на кнопку "Suspend", то в HexRendering появляются знаки ??, которые не исчезают и при дальнейшей отладке

Причина:

Знаки вопроса в HexRendering появляются в тех случаях, когда у MemoryByte не установлен флаг MemoryByte.READABLE. В моем случае этого произошло, поскольку при начале отладке не было события Suspend и, соответственно, не был получен ответ на GDB команду "-data-read-memory". Проверка происходит в классе HexRendering на строке 43:

if (data[i].isReadable())

Строка со знаками вопроса находится в переменной paddedStr, определенной выше

После того, как я нажимаю на кнопку "Suspend", в GDB логе вижу, что возвращаются запрашиваемые байты, однако, знаки вопроса по-прежнему остаются, даже подсвечиваются красным цветом. Почему?

Проблема заключается в том, что в DsfMemoryBlock новым полученным байтам (в которых установлен флаг MemoryByte.READABLE) происходит присвоение флагов байтов, определенных до Suspend в переменной fBlock (в которых флаг MemoryByte.READABLE не установлен)

Строки 488-489:

newBlock[distance + i].setFlags(fBlock[i].getFlags()); 
newBlock[distance + i].setHistoryKnown(true);

Решение:

Вижу несколько вариантов: один из них - принудительный refresh с пересозданием экземпляра GdbMemoryBlock, но в моем случае было проще создать наследник класса HexRendering и изменить логику проверки

Запуск Joomla 1.5 под PHP 7

20.04.2017
Не так давно у меня возникла необходимость запустить сайт на старенькой Joomla 1.5 под PHP 7.

Сначала Joomla, что и следовало ожидать, запускаться не захотела. После внесения следующего кода все заработало:
  1. В файлах includes/framework.php и administrator/includes/framework.php убрать строки:

  2. @set_magic_quotes_runtime( 0 );
    @ini_set('zend.ze1_compatibility_mode', '0');
    


  3. libraries/joomla/registry/registry.php, на строке 42 нужно заменить фрагмент:

  4. for ($i = 1; $i < $pathNodes; $i ++) {
        if((isset($ns->$nodes[$i]))) $ns =& $ns->$nodes[$i];
    }
    
    if(isset($ns->$nodes[$i])) {
        $result = $ns->$nodes[$i];
    }
    


    на
    for ($i = 1; $i < $pathNodes; $i ++) {
        $nodex = $nodes[$i];
        if((isset($ns->$nodex))) $ns =& $ns->$nodex;
    }
    
    $nodex = $nodes[$i];
    if(isset($ns->$nodex)) {
        $result = $ns->$nodex;
    }
    


Конечно в случае наличия сторонних расширений одного этого кода может быть не достаточно. Все зависит от установленных под Joomla 1.5 расширений.

Результат: мой сайт на Joomla 1.5 заработал, что помогло мне осуществить его миграцию с переработкой.

Вызов wizard'а в Eclipse по кнопке или по shortcut'y в меню

07.03.2017
Периодически у меня возникает задача вызывать в Eclipse определенный wizard непосредственно из кода. Например, вызывать wizard по кнопке или по shortcut'y в меню. Конечно, можно решить эту задачку, привязав shortcut wizard'a к определенной перспективе:


1
2
3
4
5
6
7
8
   <extension
         point="org.eclipse.ui.perspectiveExtensions">
      <perspectiveExtension
            targetID="org.eclipse.jdt.ui.JavaPerspective">
            <newWizardShortcut
               id="my.wizard.id">
            </newWizardShortcut>
...


Но бывают случаи, когда необходимо отображать shortcut визарда независимо от перспективы.

Уже придумано множество способов решения этого вопроса. В частности, перейдя по ссылке, можно увидеть очень удачный способ - вначале происходит проверка существования визарда, чей id передается в функцию параметром:
Invoking an Eclipse Wizard programmatically

Но у этого способа есть один недостаток: нашему визарду не передается элемент, выбранный в Project Explorer, редакторе или где-то еще. Это может создавать неудобства: в частности, если визард осуществляет создание файла в определенном пакете, визард не получит информацию об этом пакете, даже если пакет выбран в файловом дереве.

Если класс wizard'a реализует интерфейс IWorkbenchWizard, ему не передается выделенный элемент selection и не передается workbench, поскольку не вызывается функция
init(IWorkbench workbench, IStructuredSelection selection);
Отсуствие workbench, в свою очередь, может приводить к ряду ошибок при вызове таких функций как selectAndReveal и т.д.

Предлагаемый способ (вместе с хендлером):

MyHandler.java:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
public class MyHandler extends AbstractHandler {

	@Override
	public Object execute(ExecutionEvent event) throws ExecutionException {

		IWorkbenchWindow window = HandlerUtil.getActiveWorkbenchWindowChecked(event);
		openWizard("my.wizard.id", window);
		return null;
	}

	public void openWizard(String id, IWorkbenchWindow window) {
		// First see if this is a "new wizard".
		IWizardDescriptor descriptor = PlatformUI.getWorkbench().getNewWizardRegistry().findWizard(id);
		// If not check if it is an "import wizard".
		if (descriptor == null) {
			descriptor = PlatformUI.getWorkbench().getImportWizardRegistry().findWizard(id);
		}
		// Or maybe an export wizard
		if (descriptor == null) {
			descriptor = PlatformUI.getWorkbench().getExportWizardRegistry().findWizard(id);
		}
		try {
			// Then if we have a wizard, open it.
			if (descriptor != null) {

				IWizard wizard = descriptor.createWizard();

				if (wizard instanceof IWorkbenchWizard) {

					IWorkbenchWizard wb_wizard = (IWorkbenchWizard) wizard;

					ISelection selection = window.getSelectionService().getSelection();
					IStructuredSelection selectionToPass = StructuredSelection.EMPTY;
					if (selection instanceof IStructuredSelection) {
						selectionToPass = descriptor.adaptedSelection((IStructuredSelection) selection);
					} else {
						// Build the selection from the IFile of the editor
						IWorkbenchPart part = window.getPartService().getActivePart();
						if (part instanceof IEditorPart) {
							IEditorInput input = ((IEditorPart) part).getEditorInput();
							Class fileClass = LegacyResourceSupport.getFileClass();
							if (input != null && fileClass != null && input instanceof IAdaptable) {

								IAdaptable adaptable = (IAdaptable)input;
							    Object file = adaptable.getAdapter(fileClass);
								if (file != null) {
									selectionToPass = new StructuredSelection(file);
								}
							}
						}
					}

					wb_wizard.init(PlatformUI.getWorkbench(), selectionToPass);

				}

				WizardDialog dialog = new WizardDialog(PlatformUI.getWorkbench().getDisplay().getActiveShell(), wizard);
				dialog.setTitle(wizard.getWindowTitle());

				dialog.create();

				dialog.open();
			}
		} catch (CoreException e) {
			e.printStackTrace();
		}
	}

}


plugin.xml

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<?xml version="1.0" encoding="UTF-8"?>
<?eclipse version="3.4"?>
<plugin>

   <extension
         point="org.eclipse.ui.newWizards">
      <category
            name="My Wizard Category"
            id="my.wizard.category">
      </category>
      <wizard
            category="my.wizard.category"
            class="my.wizards.myWizardClass"
            hasPages="true"
            icon="icons/sample.gif"
            id="my.wizard.id"
            name="My Sample New Project Wizard"
            project="true">
      </wizard>
   </extension>

   <extension
         point="org.eclipse.ui.commands">
      <category
            name="My Wizard commands"
            id="my.wizards.category">
      </category>
      <command
            name="Show My Wizard"
            defaultHandler="my.wizards.MyHandler"
            categoryId="my.wizards.category"
            id="my.MyHandler">
      </command>
  </extension>   

</plugin>

Eclipse: особые иконки в Project Explorer для проекта с определенной Nature

01.03.2017
Периодически появляется необходимость отображать новые иконки в Project Explorer для разных типов ресурсов, в том числе, для проектов с определенной Nature. Приведу возможное решение:

В начале создается проект плагина (Create > New > Plug-in Project), если еще не создан. Создается plugin.xml

Решить задачу можно двумя способами:

1) Создать точку расширения "org.eclipse.ui.ide.projectNatureImages"

1
2
3
4
5
6
7
     <extension point="org.eclipse.ui.ide.projectNatureImages">
      <image 
        id="myNatureImageId"
        natureId="myNatureId"
        icon="icons/sample.gif">
      </image>
     </extension> 
Это самый простой способ. Но он имеет ограничение: Необходимо, чтобы наша Nature myNatureId шла первой в списке Nature для проекта. Поскольку проект может иметь несколько разных nature и наша nature далеко не всегда может идти первой. Текущее расположение порядка nature можно посмотреть в файле .project

2) Создать декоратор. Точка расширения - "org.eclipse.ui.decorators"

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<extension point="org.eclipse.ui.decorators">
        <decorator
            id="myProjectDecoratorId" 
            label="My Project Decorator" 
            state="true" 
            lightweight="true" 
            icon="icons/sample.gif" 
            location="TOP_RIGHT"
            adaptable="true"
            > 
            <enablement>
            <and>
              <objectClass name="org.eclipse.core.resources.IResource"/>
              <objectState
                  name="nature"
                  value="myNatureId">
              </objectState>                              
            </and>              
            </enablement>
            <description>
              Пример работы декоратора
            </description>

        </decorator>
    </extension> 

Примечание:

  • state(true/false) - флаг обозначает, активирован ли декоратор по умолчанию. Значение по умолчанию данного флага - false. Отключить / включить декоратор во время работы в Eclipse можно, зайдя в Preferences > General > Appearance > Label Decorations

  • lightweight (true/false) - более поздний и функциональный из двух типов декораторов. реализует интерфейс org.eclipse.jface.viewers.ILightweightLabelDecorator В случае lightweight декоратора нет необходимости указывать класс декоратора, в котором описывать работу с изображениями. Все манипуляции с картинками lightweight декоратор берет на себя. Достаточно указать лишь 2 параметра: icon и location

  • adaptable (true/false) - что данное свойство распространяется и на объекты, чьи типы могут быть адаптированы к типу, указанному в objectClass.

Ссылки:

  1. Eclipse Help - Decorators
  2. Understanding Decorators in Eclipse
Облако тегов
Меню
Архив
© Psytronica.ru 2015-2018 Наверх