Бюджет 42$ / 2500
руб
в месяц
Создан: 3 года назад
Открыт
Описание
Необходимо решить задачу. 
Жизнь космического торговца очень проста: освобождаешь грузовой отсек своего корабля, чтобы погрузить новые торговые модули. Что находится внутри торговых модулей, разбираться некогда, да и слишком сложно это для простого торговца. Торговцы точно знают лишь то, что внутри модуля лежат «единицы экспорта», которые можно продать заинтересовавшимся.
Глава торговой космической гильдии стал замечать, что внутри торгового модуля остается всё больше и больше «единиц экспорта», которые никому не пригодились, а значит, и не принесли прибыли.
Торговцы решили сделать следующую систему:
- покупатели формируют единый заказ на конкретные "единицы экспорта"из торговых модулей. Такой заказ называется "входной заявкой";
- "входных заявок"может быть несколько;
Для описания заявки был выбрал Javascript и ES6 система модулей. Пример торговой заявки:

import {a, b} from './modules/module_a.js';  
import {c as k, d} from './modules/module_b.js';
Глава хочет найти инженера, способного разобраться во внутреннем устройстве товарных модулей. Инжинеру придётся наладить процесс отсеивания "единиц экспорта"из модулей по данным из "входной заявки"до того, как улетит торговый корабль.

Формат ввода
Несколько инженеров подступались к задаче, но так и не смогли ее решить. Вот какие выводы они сделали:
- из торгового модуля нив коем случае нельзя убирать «единицу экспорт», которая необходима кому-либо в заявке ;
- «единицы экспорта» внутри одного торгового модуля могут быть связаны так, что, убрав одну единицу, модуль обесценивается;
- внутри модуля могут быть переиспользованы «единицы экспорта» из других модулей, однако циклических зависимостей нет;
- гарантируется, что торговые модули состоят только из «единиц экспорта», все единицы именованы, а их имя уникально в рамках одного модуля;
- "единица экспорта"может представлять из себя: констату, функцию, объект, массив, строку, шаблонную строку.
Опираясь на выводы инженеров, вам необходимо разработать технологию, позволяющую максимально облегчать торговые модули, не обесценивая их.
Необходимо реализовать функцию, принимающую на вход: Информацию о заявках, в формате объекта, где:
- ключ – абсолютный путь до модуля от корня,
- значение – строковое представление кода, Второй аргумент функции – массив с абсолютными путями до "входных заявок"торговцев.
В результате выполнения функции исходный код должен измениться таким образом, что остаться должны только используемые экспорты. Менять при этом аргументы import и делать полный dead code elimination в исходном коде не требуется. Главное – удалить неиспользуемые единицы экспорта.
Пример: Первый аргумент.

{  
  "/root/omegaTradersCluster/firstTrader.js":  
    "export const first = () => 12;nnexport const second = {a: 12};n",  
  "/root/entrypoint.js":  
    "import {first} from "./omegaTradersCluster/firstTrader.js";n"  
}
Второй аргумент.

["/root/entrypoint.js"]
Заметим, что second не был использован и его код может быть удален.

Формат вывода
Ответ:
{  
  "/root/omegaTradersCluster/firstTrader.js":  
        "export const first = () => 12;n",  
  "/root/entrypoint.js":  
        "import { first } from "./omegaTradersCluster/firstTrader.js";n"  
}
Для быстрого освоение со структорой AST, рекомендуется использовать интерактивный сайт: astexplorer.net/#/gist/48...

Примечания
Файл с решением оформите по шаблону::

// обязательно используйте этот парсер для построения дерева  
const parser = require('@babel/parser');  
// для обхода дерева можете использовать данную библиотеку  
// или написать свой обход  
// подробнее тут: babeljs.io/docs/en/babel-...  
const traverse = require('@babel/traverse').default;  
// обязательно используйте генератор для формирования ответа  
const generate = require('@babel/generator').default;  
 
module.exports = function (filesInfo, entrypoints) {  
    const result = {};  
 
    for (const [filePath, fileText] of Object.entries(filesInfo)) {  
        // подробнее babeljs.io/docs/en/babel-...  
        // однако дополнительных опций не требуется  
        const ast = parser.parse(fileText, {  
            sourceType: 'module',  
        });  
 
        // какие-то манипуляции с деревом исходного файла  
 
        // генерируем новый код из дерева, не добавляйте дополнительных опций  
        // подробнее babeljs.io/docs/en/babel-...  
        const new_code = generate(ast).code;  
 
        result[filePath] = new_code;  
    }  
 
    return result;  
}
Категория
Источник: fl.ru

Похожие проекты

safe$22
9 0
требуется готовую онлайн анкету на django по приему на работу перенести в whatsapp, telegram и viber. Нужно чтобы кандидат мог с удобством заполнять анкету с телефона, а все заполненные им данные по всем позициям автоматически загружались в нашу базу данных. В нашей базе будет создаваться резюме кандидата......
safe 
28 0
В наличии массив кадастровых номеров (КН), необходимо путем запроса на ПКК определить примерные географические координаты каждого объекта из массива КН (ОКС, ЗУ), вывести в результирующий файл эти ко-ты и ряд сопутствующих данных по этому КН....
1 год назад
safe 
44 1
Необходимо разработать бек и фронт мини-сервиса таким образом, чтоб его можно было развернуть внутри другого проекта....
safe$1111
23 0
Стоит на Бизнесе для своих нужд на простеньком базовом шаблоне, складываю туда контент потихоньку. Нужно начинать приводить в соответствие что бы публика сразу не убегала, а как то цеплялась, да и продвигать не торопясь. Шаблон где порвался от вставки баннеров подправить, для мобилок может сверстать.......
safe$22
55 0
Парсер для сайта stockx. com на питоне (selenium/pyppeteer). Необходим следующий функционал: 1. На главной странице с поиском по ключевым словам найти первый результат из поиска (ссылку на страницу товара) ....
1 год назад
safe$44
49 0
Трипланарная транспортная задача (отправители - транспорт - получатели) генерация исходных данных трехэтапное решение 1....
safe$1111
48 0
Требуется написать парсер маркетплейса, у которого есть только мобильное приложение (IOS, Android). Есть исходный код Android приложения (Java + Kotlin), реверснутый через JADX. Необходимо парсить данные о товарах, полученные по артикулу. За подробностями тг: @markermann)....
1 год назад
 
38 0
Требуется написать софт , который будет делать рассылку по личным сообщениям на площадке Ebay Kleinanzeigen по заранее спаршенным обьявлениям....
1 год назад
 
36 0
Требуется написать софт , который будет делать рассылку по личным сообщениям на площадке Ebay Kleinanzeigen по заранее спаршенным обьявлениям....
1 год назад
 
37 0
Требуется написать софт , который будет делать рассылку по личным сообщениям на площадке Ebay Kleinanzeigen по заранее спаршенным обьявлениям....
1 год назад
 
31 0
Требуется написать софт , который будет делать рассылку по личным сообщениям на площадке Ebay Kleinanzeigen по заранее спаршенным обьявлениям....
1 год назад
 
40 1
Требуется написать софт , который будет делать рассылку по личным сообщениям на площадке Ebay Kleinanzeigen по заранее спаршенным обьявлениям....
1 год назад
$22
59 1
В Геткурсе нужно сделать интеграцию со Сбербанком для оформления рассрочки/кредита. Основная задача – передача суммы и номера заказа при переходе для оформления рассрочки и возврат сведений при удачном оформлении. Эквайринг от Сбербанка к Геткурсу подключён, а готовой интеграции для рассрочки нет. Если......
1 год назад
 
96 0
Нужно сделать бот перехватчик заказов по фильтру такси Максим!...
1 год назад
$33
75 1
Как можно загрузить готовое фото из галереи, если приложение просит загрузить фото и при этом открывает камеру телефона? Нужно вместо использования реальной камеры смоделировать вход камеры и при этом загрузить фото из галереи....
1 год назад
 
117 3
Очень простой криптообменник в виде веб-сайта. Без смарт-контрактов и т. Все платежи вручную....
Смотреть все