25.01.2013, 23:06 | #21 |
MCTS
|
Версия для AX 2012
Преимущества перед F12: - Сразу открывает объект а не переходит сначала к определению переменной.; - Работает в ряде случаев, когда не работает F12 (системные объекты, параметры методов и т.п.); - Работает с макросами (при полном выделению имени). За идею спасибо Timofey_k; Особенности: - В данной реализации при запуске из job система делает попытку закрыть текущее окно редактора. В качестве воркэраунда используется переоткрытие исходного окна (за идею также спасибо Timofey_k). X++: //AX2012 version public void aaaOpenInAOT(Editor e) { #AOT #define.AOTPathDivider('\\') TreeNode treeNode = TreeNode::findNode(e.path()); xRefTmpReferences xRefTmpReferences; Column nCol = e.columnNo() + 1; Line nLine = e.currentLineNo() + 1; int startCol = e.selectionStartCol(); int endCol = e.selectionEndCol(); str macroName; str nodePath; str curPath = e.path(); ; treeNode.AOTmakeXref(1); xRefTmpReferences = xRefCreate::makeTmp(appl.lastxRef()); select firstonly xRefTmpReferences order by Column desc where xRefTmpReferences.line == nLine && xRefTmpReferences.Column <= nCol; if (!xRefTmpReferences) { e.firstSelectedLine(); macroName = strLRTrim(subStr(e.getLine(), e.selectionStartCol(), endCol - startCol)); if (macroName) { treeNode = TreeNode::findNode(#MacrosPath + #AOTDelimiter + macroName); if (treeNode) { treeNode.AOTedit(); } } return; } nodePath = xRefTmpReferences.calcPath(); if (nodePath) { treeNode = TreeNode::findNode(nodePath); if (treeNode) { if (strScan(curPath, #JobsPath + #AOTPathDivider, 1, strLen(curPath))) { //Workaround for jobs behaviour in the AX2012 SysUtil::editPathLogicalPos(curPath, nLine, nCol); } treeNode.AOTnewWindow(); } } return; } Последний раз редактировалось alex55; 25.01.2013 в 23:14. |
|
|
За это сообщение автора поблагодарили: Logger (3). |
25.11.2013, 10:00 | #22 |
MCTS
|
Можно ли как-то проапгрейдить данный код Открыть в новом окне объект из кода, чтобы в classDeclaration классов открывался именно тот класс, на котором стоит курсор, а не его базовый?
|
|
25.11.2013, 22:38 | #23 |
Боец
|
Спасибо дружище! С выходом 2012R2 старая версия перестала работь и я было уже попрощался с этой фичей. Сравнив твой код с предыдущей версией выяснил что концептуальня разница лишь в одной строке:
До 2012R2: X++: tmpxRefReferences = xRefCreate::makeTmp(infolog.lastxRef()); X++: tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef()); |
|
|
За это сообщение автора поблагодарили: Logger (19). |
31.01.2023, 14:49 | #24 |
Участник
|
Обнаружена еще одна интересная особенность работы с TreeNode.AOTmakeXref()
Оказывается в стандартном коде в большинстве мест этот метод обрамляется отключением записи собираемых перекрестных ссылок в постоянную таблицу, за счет чего ускоряется работа этого метода Например так \Classes\EditorScripts\documentation_HeaderTemplate 2012-я X++: appl.updatexRefSet(true); memberFunction.aoTmakeXref(1); tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef(), memberFunction.treeNodePath()); appl.updatexRefSet(false); X++: infolog.updatexRefSet(this, true); memberFunction.AOTmakeXref(1); tmpxRefReferences = xRefCreate::makeTmp(infolog.lastxRef(), memberFunction.treeNodePath()); infolog.updatexRefSet(this, false); Написал свой метод xRefCreate::makeTmpByTreeNode_MRC, который заменяет вызов X++: appl.updatexRefSet(true); memberFunction.aoTmakeXref(1); tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef(), memberFunction.treeNodePath()); appl.updatexRefSet(false); X++: /// <summary> /// Рекомендуется вместо treeNode.aotMakeXref(1); tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef()); /// </summary> /// <param name="_treeNode"> /// TreeNode, для которого собираем временные перекрестные ссылки /// </param> /// <param name="_flag"> /// 1-й параметр _flag, передаваемый в treeNode.aotMakeXref(_flag) /// </param> /// <param name="_xRefAll"> /// 2-й параметр _xRefAll, передаваемый в treeNode.aotMakeXref(_flag, _xRefAll) /// </param> /// <param name="_path"> /// параметр _path передаваемый в xRefCreate::makeTmp() /// </param> /// <returns> /// Временная таблица xRefTmpReferences с результатами сбора перекрестных ссылок по treenode /// </returns> /// <remarks> /// [url=http://axforum.info/forums/showthread.php?p=299419#post299419]Открыть в новом окне объект из кода[/url] /// В 2012-й вызов treeNode.aotMakeXref(1) работает быстрее если /// обрамить его отключением сохранения перекрестных ссылок /// см. пример в стандартном коде в \Classes\EditorScripts\documentation_HeaderTemplate /// /// метод makeTmpByTreeNode_MRC сделан для удобства, для замены куска кода /// appl.updatexRefSet(true); /// treeNode.aotMakeXref(1); /// tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef(), treeNode.treeNodePath()); /// appl.updatexRefSet(false); /// одной строкой кода с вызовом этого метода /// xRefCreate::makeTmpByTreeNode_MRC(treeNode, 1, false /*default value*/, treeNode.treeNodePath()); /// </remarks> // JEV007437, PKoz 31.01.2023 public static xRefTmpReferences makeTmpByTreeNode_MRC( TreeNode _treeNode, int _flag = 1, // обычно 1 boolean _xRefAll = false, xRefPath _path = '' // в стандарте обычно _treeNode.treeNodePath() ) { xRefTmpReferences tmpxRefReferences; boolean temporaryForbidSaveXref; ; temporaryForbidSaveXref = appl.canUpdatexRef(); if (temporaryForbidSaveXref) { appl.updatexRefSet(true); } _treeNode.aotMakeXref(_flag, _xRefAll); tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef(), _path); if (temporaryForbidSaveXref) { appl.updatexRefSet(false); } return tmpxRefReferences; } |
|
|
За это сообщение автора поблагодарили: demianimp (4), gl00mie (10). |
31.01.2023, 17:31 | #25 |
Участник
|
похоже непонятно описание составил, задают уточняющие вопросы.
в общем в куче мест вместо X++: appl.updatexRefSet(true); memberFunction.aoTmakeXref(1); tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef(), memberFunction.treeNodePath()); appl.updatexRefSet(false); X++: memberFunction.aoTmakeXref(1); tmpxRefReferences = xRefCreate::makeTmp(appl.lastxRef(), memberFunction.treeNodePath()); |
|