<titledata-rh="true">Practice exam B | mf</title><metadata-rh="true"name="viewport"content="width=device-width,initial-scale=1"><metadata-rh="true"name="twitter:card"content="summary_large_image"><metadata-rh="true"property="og:url"content="https://blog.mfocko.xyz/pb071/pexam/garbage_collect"><metadata-rh="true"name="docusaurus_locale"content="en"><metadata-rh="true"name="docsearch:language"content="en"><metadata-rh="true"name="docusaurus_version"content="current"><metadata-rh="true"name="docusaurus_tag"content="docs-pb071-current"><metadata-rh="true"name="docsearch:version"content="current"><metadata-rh="true"name="docsearch:docusaurus_tag"content="docs-pb071-current"><metadata-rh="true"property="og:title"content="Practice exam B | mf"><metadata-rh="true"name="description"content="Garbageeverywhere…
<divrole="region"aria-label="Skip to main content"><aclass="skipToContent_fXgn"href="#__docusaurus_skipToContent_fallback">Skip to main content</a></div><navaria-label="Main"class="navbar navbar--fixed-top"><divclass="navbar__inner"><divclass="navbar__items"><buttonaria-label="Toggle navigation bar"aria-expanded="false"class="navbar__toggle clean-btn"type="button"><svgwidth="30"height="30"viewBox="0 0 30 30"aria-hidden="true"><pathstroke="currentColor"stroke-linecap="round"stroke-miterlimit="10"stroke-width="2"d="M4 7h22M4 15h22M4 23h22"></path></svg></button><aclass="navbar__brand"href="/"><bclass="navbar__title text--truncate">mf</b></a><divclass="navbar__item dropdown dropdown--hoverable"><ahref="#"aria-haspopup="true"aria-expanded="false"role="button"class="navbar__link">Additional FI MU materials</a><ulclass="dropdown__menu"><li><aclass="dropdown__link"href="/ib002/">IB002: Algorithms</a></li><li><aaria-current="page"class="dropdown__link dropdown__link--active"href="/pb071/">PB071: C</a></li><li><aclass="dropdown__link"href="/pb161/">PB161: C++</a></li></ul></div><aclass="navbar__item navbar__link"href="/contributions">Contributions</a><aclass="navbar__item navbar__link"href="/talks">Talks</a></div><divclass="navbar__items navbar__items--right"><aclass="navbar__item navbar__link"href="/blog">Blog</a><divclass="toggle_vylO colorModeToggle_DEke"><buttonclass="clean-btn toggleButton_gllP toggleButtonDisabled_aARS"type="button"disabled=""title="Switch between dark and light mode (currently light mode)"aria-label="Switch between dark and light mode (currently light mode)"aria-live="polite"><svgviewBox="0 0 24 24"width="24"height="24"class="lightToggleIcon_pyhR"><pathfill="currentColor"d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svgviewBox="0 0 24 24"width="24"height="24"class="darkToggleIcon_wfgR"><pathfill="currentColor"d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><divclass="searchBox_ZlJk"><buttontype="button"class="DocSearch DocSearch-Button"aria-label="Search"><spanclass="DocSearch-Button-Container"><svgwidth="20"height="20"class="DocSearch-Search-Icon"viewBox="0 0 20 20"><pathd="M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z"stroke="currentColor"fill="none"fill-rule="evenodd"stroke-linecap="round"stroke-linejoin="round"></path></svg><spanclass="DocSearch-Button-Placeholder">Search</span></span><spanclass="DocSearch-Button-Keys"></span></button></div></div></div><divrole="presentation"class="navbar-sidebar__backdrop"></div></nav><divid="__docusaurus_skipToContent_fallback"class="main-wrappermainWrapper_
<em>faculty computers</em>.</li><li>In browser you are only allowed to have the following tabs open:<ul><li><ahref="https://en.cppreference.com"target="_blank"rel="noopener noreferrer">C documentation</a></li><li>page containing the assignment</li></ul></li><li>You <strong>are not</strong> allowed to use your own source code, e.g. prepared beforehand
or from the seminars.</li><li>You have <strong>5 minutes</strong> to read through the assignment and ask any follow-up
questions should be there something unclear.</li><li>You have <strong>60 minutes</strong> to work on the assignment, afterward your work will be
discussed with your seminar tutor.</li></ul></div></div><p>You have gotten into a trouble during your regular upgrade of your archLinux<supid="fnref-1"><ahref="#fn-1"class="footnote-ref">1</a></sup>
installation… You've been carelessly running the upgrades for months and forgot
about clearing up the caches.</p><p>Your task is to write a program <code>garbage_collect</code> that will evaluate the shell
history provided as a file and will try to find files or directories that are
suspiciously big and decide which of them should be deleted to free some space.</p><h2class="anchor anchorWithStickyNavbar_LWe7"id="format-of-the-shell-history">Format of the shell history<ahref="#format-of-the-shell-history"class="hash-link"aria-label="Direct link to Format of the shell history"title="Direct link to Format of the shell history"></a></h2><p>You are provided one file consisting of the captured buffer of the terminal. You
can see only two commands being used:</p><ol><li><p><code>cd ‹somewhere›</code> that changes the current working directory.</p><p>At the beginning you start in the root of the filesystem (i.e. <code>/</code>).</p><p>You are <strong>guaranteed</strong> that <code>‹somewhere›</code> is:</p><ul><li><code>.</code> that is a current working directory (i.e. does nothing),</li><li><code>..</code> that moves you up one level (in case you are in <code>/</code>, does nothing), or</li><li>is a valid directory in the current working directory.</li></ul><divclass="theme-admonition theme-admonition-caution alert alert--warning admonition_LlT9"><divclass="admonitionHeading_tbUL"><spanclass="admonitionIcon_kALy"><svgviewBox="0 0 16 16"><pathfill-rule="evenodd"d="M8.893 1.5c-.183-.31-.52-.5-.887-.5s-.703.19-.886.5L.138 13.499a.98.98 0 0 0 0 1.001c.193.31.53.501.886.501h13.964c.367 0 .704-.19.877-.5a1.03 1.03 0 0 0 .01-1.002L8.893 1.5zm.133 11.497H6.987v-2.003h2.039v2.003zm0-3.004H6.987V5.987h2.039v4.006z"></path></svg></span>caution</div><divclass="admonitionContent_S0QG"><p>There are no guarantees or restrictions on the names of the files or
directories!</p></div></div></li><li><p><code>ls</code> that will list files in the current working directory and their
respective sizes. If there is a directory in the current working it has <code>dir</code>
instead of the size.</p></li></ol><divclass="codeBlockContainer_Ckt0 theme-code-block"style="--prism-color:#000000;--prism-background-color:#ffffff"><divclass="codeBlockContent_biex"><pretabindex="0"class="prism-code language-text codeBlock_bY9V thin-scrollbar"><codeclass="codeBlockLines_e6Vv"><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ ls</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">dir a</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">14848514 b.txt</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">8504156 c.dat</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">dir d</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd a</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd .</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd .</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd .</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ ls</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">dir e</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">29116 f</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">2557 g</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">62596 h.lst</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd e</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ ls</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">584 i</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd ..</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd ..</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ cd d</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ ls</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">4060174 j</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">8033020 d.log</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">5626152 d.ext</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">7214296 k</span><br></span></code></pre><divclass="buttonGroup__atx"><buttontype="button"aria-label="Copy code to clipboard"title="Copy"class="clean-btn"><spanclass="copyButtonIcons_eSgA"aria-hidden="true"><svgviewBox="0 0 24 24"class="copyButtonIcon_y97N"><pathfill="currentColor"d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svgviewBox="0 0 24 24"class="copyButtonSuccessIcon_LjdS"><pathfill="currentColor"d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>For this input, you will get following file system:</p><divclass="codeBlockContainer_Ckt0 theme-code-block"style="--prism-color:#000000;--prism-background-color:#ffffff"><divclass="codeBlockContent_biex"><pretabindex="0"class="prism-code language-text codeBlock_bY9V thin-scrollbar"><codeclass="codeBlockLines_e6Vv"><spanclass="token-line"style="color:#000000"><spanclass="token plain">- / (dir, size=48381165)</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain"> - a (dir, size=94853)</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain"> - e (dir, size=584)</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain"
directory that is supposed to be listed.</li></ul><p>When your program is being run with this switch, it is is supposed to print out
all files <strong>and</strong> directories that are bigger than the provided <code>min_size</code>.</p><h3class="anchor anchorWithStickyNavbar_LWe7"id="-f-total_size-min_unused"><code>-f ‹total_size›‹min_unused›</code><ahref="#-f-total_size-min_unused"class="hash-link"aria-label="Direct link to -f-total_size-min_unused"title="Direct link to -f-total_size-min_unused"></a></h3><p>With this switch you are provided two additional arguments:</p><ul><li><code>total_size</code> that is a total size of the filesystem<supid="fnref-2"><ahref="#fn-2"class="footnote-ref">2</a></sup>.</li><li><code>min_unused</code> that is a minimum of free space required for an upgrade.</li></ul><p>Your program should find <strong>exactly one</strong> file or a directory that is of the
smallest size, but big enough to free enough space for the upgrade to proceed.</p><p>In other words, if that file or directory is deleted, following should hold:</p><divclass="math math-display"><spanclass="katex-display"><spanclass="katex"><spanclass="katex-mathml"><mathxmlns="http://www.w3.org/1998/Math/MathML"display="block"><semantics><mrow><mrow><mimathvariant="monospace">t</mi><mimathvariant="monospace">o</mi><mimathvariant="monospace">t</mi><mimathvariant="monospace">a</mi><mimathvariant="monospace">l</mi><mimathvariant="monospace">_</mi><mimathvariant="monospace">s</mi><mimathvariant="monospace">i</mi><mimathvariant="monospace">z</mi><mimathvariant="monospace">e</mi></mrow><mo>−</mo><mrow><mimathvariant="monospace">u</mi><mimathvariant="monospace">s</mi><mimathvariant="monospace">e</mi><mimathvariant="monospace">d</mi></mrow><mo>≥</mo><mrow><mimathvariant="monospace">m</mi><mimathvariant="monospace">i</mi><mimathvariant="monospace">n</mi><mimathvariant="monospace">_</mi><mimathvariant="monospace">u</mi><mimathvariant="monospace">n</mi><mimathvariant="monospace">u</mi><mimathvariant="monospace">s</mi><mimathvariant="monospace">e</mi><mimathvariant="monospace">d</mi></mrow></mrow><annotationencoding="application/x-tex">\mathtt{total\_size} - \mathtt{used} \geq \mathtt{min\_unused}</annotation></semantics></math></span><spanclass="katex-html"aria-hidden="true"><spanclass="base"><spanclass="strut"style="height:0.7063em;vertical-align:-0.0951em"></span><spanclass="mord"><spanclass="mord mathtt">total_size</span></span><spanclass="mspace"style="margin-right:0.2222em"></span><spanclass="mbin">−</span><spanclass="mspace"style="margin-right:0.2222em"></span></span><spanclass="base"><spanclass="strut"style="height:0.7719em;vertical-align:-0.136em"></span><spanclass="mord"><spanclass="mord mathtt">used</span></span><spanclass="mspace"style="margin-right:0.2778em"></span><spanclass="mrel">≥</span><spanclass="mspace"style="margin-right:0.2778em"></span></span><spanclass="base"><spanclass="strut"style="height:0.7063em;vertical-align:-0.0951em"></span><spanclass="mord"><spanclass="mord mathtt">min_unused</span></span></span></span></span></span></div><h2class="anchor anchorWithStickyNavbar_LWe7"id="example-usage">Example usage<ahref="#example-usage"class="hash-link"aria-label="Direct link to Example usage"title="Direct link to Example usage"></a></h2><p>You can have a look at the example usage of your program. We can run your
program from the shell like</p><divclass="codeBlockContainer_Ckt0 theme-code-block"style="--prism-color:#000000;--prism-background-color:#ffffff"><divclass="codeBlockContent_biex"><pretabindex="0"class="prism-code language-text codeBlock_bY9V thin-scrollbar"><codeclass="codeBlockLines_e6Vv"><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ ./garbage_collect shell_history.txt -gt 10000000</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">24933642 /d</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">14848514 /b.txt</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">48381165 /</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain"style="display:inline-block"></span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">$ ./garbage_collect shell_history.txt -f 70000000 30000000</span><br></span><spanclass="token-line"style="color:#000000"><spanclass="token plain">24933642 /d</span><br></span></code></pre><divclass="buttonGroup__atx"><buttontype="button"aria-label="Copy code to clipboard"title="Copy"class="clean-btn"><spanclass="copyButtonIcons_eSgA"aria-hidden="true"><svgviewBox="0 0 24 24"class="copyButtonIcon_y97N"><pathfill="currentColor"d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svgviewBox="0 0 24 24"class="copyButtonSuccessIcon_LjdS"><pathfill="currentColor"d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h2class="anchor anchorWithStickyNavbar_LWe7"id="requirements-and-notes">Requirements and notes<ahref="#requirements-and-notes"class="hash-link"aria-label="Direct link to Requirements and notes"title="Direct link to Requirements and notes"></a></h2><ul><li>Define <strong>structures</strong> (and <strong>enumerations</strong>, if applicable) for the parsed
information from the files.</li><li>For keeping the “records”, use some <strong>dynamic</strong> data structure.<ul><li>Don't forget to consider pros and cons of using <em>specific</em> data structures
before going through implementing.</li></ul></li><li>You <strong>are not required</strong> to produce 1:1 output to the provided examples, they
are just a hint to not waste your time tinkering with a user experience.</li><li>If any of the operations on the input files should fail,
<strong>you are expected to</strong> handle the situation <em>accordingly</em>.</li><li>Failures of any other common functions (e.g. functions used for memory
management) should be handled in <strong>the same way</strong> as they were in the
homeworks and seminars.</li><li>Your program <strong>must free</strong> all the resources before exiting.</li></ul><divclass="footnotes"><hr><ol><liid="fn-1">Also applies to Fedora, but… we use arch btw 😉<ahref="#fnref-1"class="footnote-backref">↩</a></li><liid="fn-2">duh!<ahref="#fnref-2"class="footnote-backref">↩</a></li></ol></div></div><footerclass="theme-doc-footer docusaurus-mt-lg"><divclass="theme-doc-footer-edit-meta-row row"><divclass="col"><ahref="https://gitlab.com/mfocko/blog/tree/main/pb071/pexam/b-garbage_collect.md"target="_blank"rel="noreferrer noopener"class="theme-edit-this-page"><svgfill="currentColor"height="20"width="20"viewBox="0 0 40 40"class="iconEdit_Z9Sw"aria-hidden="true"><g><pathd="m34.5 11.7l-3 3.1-6.3-6.3 3.1-3q0.5-0.5 1.2-0.5t1.1 0.5l3.9 3.9q0.5 0.4 0.5 1.1t-0.5 1.2z m-29.5 17.1l18.4-18.5 6.3 6.3-18.4 18.4h-6.3v-6.2z"></path></g></svg>Edit this page</a></div><divclass="col lastUpdated_vwxv"><spanclass="theme-last-updated">Last updated<!----> on <b><timedatetime="2023-05-08T00:00:00.000Z">May 8, 2023</time></b></span></div></div></footer></article><navclass="pagination-nav docusaurus-mt-lg"aria-label="Docs pages"><aclass="pagination-nav__link pagination-nav__link--prev"href="/pb071/category/practice-exams"><divclass="pagination-nav__sublabel">Previous</div><divclass="pagination-nav__label">Practice Exams</div></a><aclass="pagination-nav__link pagination-nav__link--next"href="/pb071/pexam/cams"><divclass="pagination-nav__sublabel">Next</div><divclass="pagination-nav__label">Practice exam C</div></a></nav></div></div><divclass="col col--3"><divclass="tableOfContents_bqdL thin-scrollbar theme-doc-toc-desktop"><ulclass="table-of-contents table-of-contents__left-border"><li><ahref="#format-of-the-shell-history"class="table-of-contents__link toc-highlight">Format of the shell history</a></li><li><ahref="#format-of-the-output"class="table-of-contents__link toc-highlight">Format of the output</a><ul><li><ahref="#-gt-min_size"class="table-of-contents__link toc-highlight"><code>-gt ‹min_size›</code></a></li><li><ahref="#-f-total_size-min_unused"class="table-of-contents__link toc-highlight"><code>-f ‹total_size›‹min_unused›</code></a></li></ul></li><li><ahref="#example-usage"class="table-of-contents__link toc-highlight">Example usage</a></li><li><ahref="#requirements-and-notes"class="table-of-contents__link toc-highlight">Requirements and notes</a></li></ul></div></div></div></div></main></div></div><footerclass="footer footer--dark"><divclass="container container-fluid"><divclass="row footer__links"><divclass="col footer__col"><divclass="footer__title">Git</div><ulclass="footer__items clean-list"><liclass="footer__item"><ahref="https://github.com/mfocko"target="_blank"rel="noopener noreferrer"class="footer__link-item">GitHub<svgwidth="13.5"height="13.5"aria-hidden="true"viewBox="0 0 24 24"class="iconExternalLink_nPIU"><pathfill="currentColor"d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><liclass="footer__item"><ahref="https://gitlab.com/mfocko"target="_blank"rel="noopener noreferrer"class="footer__link-item">GitLab<svgwidth="13.5"height="13.5"aria-hidden="true"viewBox="0 0 24 24"class="iconExternalLink_nPIU"><pathfill="currentColor"d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><liclass="footer__item"><ahref="https://git.mfocko.xyz/mfocko"target="_blank"rel="noopener noreferrer"class="footer__link-item">Gitea (self-hosted)<svgwidth="13.5"height="13.5"aria-hidden="true"viewBox="0 0 24 24"class="iconExternalLink_nPIU"><pathfill="currentColor"d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div><divclass="col footer__col"><divclass="footer__title">Social #1</div><ulclass="footer__items clean-list"><liclass="footer__i