AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX Blogs
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 11.03.2011, 14:11   #1  
Blog bot is offline
Blog bot
Участник
 
25,492 / 847 (79) +++++++
Регистрация: 28.10.2006
Pawan's Ax blog: How to identify unused labels in application
Источник: http://pawansaxblog.blogspot.com/201...labels-in.html
==============

We often creates labels in our development environment and we not use the labels.Following is a job to identify unused labels in application .

Here my label file is IFC

X++:
static void I4C_UnusedLabels(Args _args)
{
str 50    labelId;
int     i;
int     maxLabel = 2000;
xRefNames   names;
XRefReferences  ref;

str info = "LabelId#LabelStr\n"
;

  while (i <= maxLabel)  {
   labelId = "@IFC" + int2str(i);
   // The particular label file.
   select recid from names
   where names.Name == labelid
   exists join ref
   where names.RecId == ref.xRefNameRecId;

   if (! names.RecId)
   {
    info += strfmt("%1#%2\n", labelId, 
      SysLabel::labelId2String(labelId));
   }

   i++;
  }

}
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Старый 15.03.2011, 07:13   #2  
Blog bot is offline
Blog bot
Участник
 
25,492 / 847 (79) +++++++
Регистрация: 28.10.2006
kamalblogs: Finding unused labels in Dynamics Ax 2009
Источник: http://kamalblogs.wordpress.com/2011...amics-ax-2009/
==============

The pain of unused labels is felt when you start translating your application to support the global versions. As we were porting our application to German we were seeing every possible way to speed up the translation work, one of it was to avoid translating unused labels.  So we tried a few tools that helps us identify this but unfortunately nothing turned helpful. We then resorted to invent our own strategy ….

I’m just reposting what my colleague had already posted on his blog with little more detail and a few additions …

*This job works only if your cross reference is updated*

X++:
static void FindUnUsedLabels()
{
    str 50          labelId;
    str             labelString;
    int             i;
    //set max label to the highest number of labelId in your application
    int             maxLabel = 2000;
    xRefNames       names;
    XRefReferences  ref;

    ;

    while (i <= maxLabel)
    {
        //Sequential generation
        labelId = "@IFC" + int2str(i);

        //Find if the label id has an cross reference
        //record
        select recid from names
            where names.Name == labelid
        exists join ref
            where names.RecId == ref.xRefNameRecId;

        labelString = SysLabel::labelId2String(labelId);

        //If there is no record in cross reference then log it
        if (! names.RecId &&
        //avoid logging labels that are already deleted (This is because of sequential check like IFC1, IFC2, IFC3 etc...)
            labelString != labelId)
        {
            info(strfmt("%1 - %2\n", labelId, SysLabel::labelId2String(labelId)));
        }

        i++;
    }
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Старый 15.03.2011, 07:40   #3  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
блин, хлебом не корми - дай попрограммировать.

ведь есть стандартный функционал
Сервис \ Средства разработки \ Перекрестные ссылки \ Имена

Колонка "Код записи" показывает "Число использований" (да, забыли программисты правильную метку поставить)
Кнопка "Чем используется" показывает строки где именно используется данная метка.

Количество строк в форме "Чем используется" равно числу в колонке "Код записи / Число использований"

Нажмите на изображение для увеличения
Название: 1.PNG
Просмотров: 510
Размер:	56.7 Кб
ID:	6668

================
Чтобы найти неиспользуемые - экспортируйте записи в excel, отфильтруйте там.
Получится гораздо быстрее, нагляднее и эффективнее, нежели программирование.
__________________
полезное на axForum, github, vk, coub.
Старый 15.03.2011, 10:14   #4  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5788 (200) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Ну вот прям сходу отфильтровать в Excel'е не получится, придется вывести список всех меток и формулами выделять те метки, которые не входят в список из перекрестных ссылок, поскольку там, очевеидно, нет меток с нулевым числом использований. Но тут, мне кажется, дело в другом (вроде в Программисте-прагматике даже отдельный подраздел такой есть - "Вездесущая автоматизация"): людям не нужен способ легкого и быстрого ручного поиска неиспользуемых меток - им нужен автоматизированный способ такого поиска, воспроизводимый, сопрягаемый с другими автоматизированными методами анализа. Да, это требует немного больше кода, но зато полностью избавляет от ручного труда.

Последний раз редактировалось gl00mie; 15.03.2011 в 10:17.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
axinthefield: Dynamics AX Event IDs Blog bot DAX Blogs 0 01.03.2011 22:11
semanticax: Dynamics AX 2009 Installation - Application Blog bot DAX Blogs 0 22.12.2010 08:11
Pawan's Ax blog: How To Cache A object Globally in Ax Blog bot DAX Blogs 1 08.08.2010 23:13
Pawan's Ax blog: How To Restore Data In AIFSchemaStore Table Blog bot DAX Blogs 0 01.07.2010 22:07
Pawan's Ax blog: How To Delete All Transaction Data In Ax Blog bot DAX Blogs 4 15.06.2010 11:23

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 23:53.
Powered by vBulletin® v3.8.5. Перевод: zCarot
Контактная информация, Реклама.