<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: converting Arc to Polyline in ObjectARX Forum</title>
    <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7009232#M8434</link>
    <description>&lt;P&gt;Thanks a lot Alex! That worked!!&lt;/P&gt;</description>
    <pubDate>Tue, 11 Apr 2017 13:29:15 GMT</pubDate>
    <dc:creator>Anonymous</dc:creator>
    <dc:date>2017-04-11T13:29:15Z</dc:date>
    <item>
      <title>converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/6985016#M8428</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Is there any way to convert Arc to Polyline in Object Arx, I need to convert two arcs into a single polyline. PEDIT, dosesn't seem work as it calls PEDIT command instead of joining to arcs and creating one polyline out of those. Any help is appreciated.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Harshad&lt;/P&gt;</description>
      <pubDate>Thu, 30 Mar 2017 15:59:37 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/6985016#M8428</guid>
      <dc:creator>Anonymous</dc:creator>
      <dc:date>2017-03-30T15:59:37Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/6985192#M8429</link>
      <description>&lt;P&gt;Hope this code help you start with joining lines/arcs in polyline:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;//-----------------------------------------------------------------------------
//----- acrxEntryPoint.cpp
//-----------------------------------------------------------------------------
#include "StdAfx.h"
#include "resource.h"
 
//-----------------------------------------------------------------------------
#define szRDS _RXST("")
 
//-----------------------------------------------------------------------------
//----- ObjectARX EntryPoint
class CJoinToPlineApp : public AcRxArxApp {
 
public:
  CJoinToPlineApp () : AcRxArxApp () {}
 
  virtual AcRx::AppRetCode On_kInitAppMsg (void *pkt) {
    AcRx::AppRetCode retCode = AcRxArxApp::On_kInitAppMsg (pkt) ;
    return (retCode) ;
  }
 
  virtual AcRx::AppRetCode On_kUnloadAppMsg (void *pkt) {
    AcRx::AppRetCode retCode = AcRxArxApp::On_kUnloadAppMsg (pkt) ;
    return (retCode) ;
  }
 
  virtual void RegisterServerComponents () {
  }
 
  static void JoinToPlineJoinToPline () {
    // Фильтр для выбора отрезков (LINE) и дуг (ARC)
    ACHAR* promptPtrs[] = {
      _T("\nSelect lines and arcs for join in poyline (ENTER - exit): "),
      _T("\nRemove lines and arcs from selection set: ")
    };
 
    ads_name ss;
    resbuf *rbFilter = acutBuildList(RTDXF0,_T("LINE,ARC"),RTNONE);
    int rc = acedSSGet(_T(":$"),promptPtrs,NULL,rbFilter,ss);
    acutRelRb(rbFilter);
 
    if (rc != RTNORM) return;
 
    AcDbObjectIdArray ids;
    if (ObjectIdArrayFromSelSet(ss, ids) != Acad::eOk) return;
    while (ids.length() &amp;gt; 0)
    {
      AcDbEntity *p = MakeJonedPoly(ids);
      if (p) {
        AcDbBlockTableRecordPointer pSpace(acdbCurDwg()-&amp;gt;currentSpaceId(), AcDb::kForWrite);
        if (pSpace.openStatus() != Acad::eOk) return;
        pSpace-&amp;gt;appendAcDbEntity(p);
        p-&amp;gt;close();
      } else {
        acutPrintf(_T("\nError in data!"));
        return;
      }
    }
 
  }
 
  /// &amp;lt;summary&amp;gt;
  /// AcDbObjectIdArray from SelectionSet
  /// &amp;lt;/summary&amp;gt;
  /// &amp;lt;param name="sset"&amp;gt;SelectionSet&amp;lt;/param&amp;gt;
  /// &amp;lt;param name="ids"&amp;gt;AcDbObjectIdArray&amp;lt;/param&amp;gt;
  /// &amp;lt;returns&amp;gt;&amp;lt;/returns&amp;gt;
  static Acad::ErrorStatus ObjectIdArrayFromSelSet(ads_name sset, AcDbObjectIdArray &amp;amp;ids)
  {
    Acad::ErrorStatus es = Acad::eOk;
    long nset = -1;
    if (acedSSLength(sset,&amp;amp;nset) != RTNORM) return Acad::eAmbiguousInput;
    ids.setLogicalLength(nset);
    ads_name en;
    AcDbObjectId id;
    for (long i=0; i &amp;lt; nset; i++) {
      if (acedSSName(sset,i,en) == RTNORM) {
        if ((es = acdbGetObjectId(id,en)) != Acad::eOk) return es;
        ids[i] = id;
      }
    }
    return Acad::eOk;
  }
 
  /// &amp;lt;summary&amp;gt;
  /// Create polyline from lines and arcs.
  /// Those ids will remove from input array
  /// &amp;lt;/summary&amp;gt;
  /// &amp;lt;param name="ids"&amp;gt;Array of id's&amp;lt;/param&amp;gt;
  /// &amp;lt;param name="FUZZ"&amp;gt;The accuracy of determining the distance between points&amp;lt;/param&amp;gt;
  /// &amp;lt;returns&amp;gt;&amp;lt;/returns&amp;gt;
  static AcDbPolyline* MakeJonedPoly(
    AcDbObjectIdArray &amp;amp;ids,
    double FUZZ = AcGeContext::gTol.equalPoint())
  {
    AcDbPolyline *p = new AcDbPolyline();
    p-&amp;gt;setDatabaseDefaults();
    AcDbObjectId idFirst = ids[0];
    AcGePoint3d nextPt = AcGePoint3d::kOrigin;
    AcGePoint3d prevPt = AcGePoint3d::kOrigin;
 
    AcDbObjectPointer&amp;lt;AcDbCurve&amp;gt; c(idFirst,AcDb::kForRead);
    if (c.openStatus() == Acad::eOk) {
      AcGePoint3d ptStart, ptEnd;
      c-&amp;gt;getStartPoint(ptStart); c-&amp;gt;getEndPoint(ptEnd);
      p-&amp;gt;addVertexAt(0, asPnt2d(asDblArray(ptStart)), BulgeFromArc(c, false), 0, 0);
      p-&amp;gt;addVertexAt(1, asPnt2d(asDblArray(ptEnd)), 0, 0, 0);
      nextPt = ptEnd;
      prevPt = ptStart;
    }
 
    ids.remove(idFirst);
    int prevCnt = ids.length() + 1;
 
    while (ids.length() &amp;gt; 0 &amp;amp;&amp;amp; ids.length() &amp;lt; prevCnt)
    {
      prevCnt = ids.length();
      for (int i = 0; i &amp;lt; ids.length(); i++) {
        AcDbObjectId id = ids[i];
        AcDbObjectPointer&amp;lt;AcDbCurve&amp;gt; cv(id,AcDb::kForRead);
        if (cv.openStatus() == Acad::eOk) {
          AcGePoint3d ptStart, ptEnd;
          cv-&amp;gt;getStartPoint(ptStart); cv-&amp;gt;getEndPoint(ptEnd);
          if (ptStart.distanceTo(nextPt) &amp;lt; FUZZ || ptEnd.distanceTo(nextPt) &amp;lt; FUZZ) {
            double bulge = BulgeFromArc(cv, ptEnd.distanceTo(nextPt) &amp;lt; FUZZ);
            p-&amp;gt;setBulgeAt(p-&amp;gt;numVerts() - 1, bulge);
            if (ptStart.distanceTo(nextPt) &amp;lt; FUZZ)
              nextPt = ptEnd;
            else
              nextPt = ptStart;
            p-&amp;gt;addVertexAt(p-&amp;gt;numVerts(), asPnt2d(asDblArray(nextPt)), 0, 0, 0);
            ids.remove(id);
            break;
          } else if (ptStart.distanceTo(prevPt) &amp;lt; FUZZ || ptEnd.distanceTo(prevPt) &amp;lt; FUZZ) {
            double bulge = BulgeFromArc(cv, ptStart.distanceTo(prevPt) &amp;lt; FUZZ);
            if (ptStart.distanceTo(prevPt) &amp;lt; FUZZ)
              prevPt = ptEnd;
            else
              prevPt = ptStart;
            p-&amp;gt;addVertexAt(0, asPnt2d(asDblArray(prevPt)), bulge, 0, 0);
            ids.remove(id);
            break;
          }
        }
      }
    }
    if (p-&amp;gt;numVerts() == 0) {
      delete p;  return NULL;
    }  else  {
      return p;
    }
  }
 
  /// &amp;lt;summary&amp;gt;
  /// Getting bulge of curve
  /// &amp;lt;/summary&amp;gt;
  /// &amp;lt;param name="c"&amp;gt;AcDbCurve pointer&amp;lt;/param&amp;gt;
  /// &amp;lt;param name="clockwise"&amp;gt;direction.&amp;lt;/param&amp;gt;
  /// &amp;lt;returns&amp;gt;&amp;lt;/returns&amp;gt;
  static double BulgeFromArc(AcDbCurve *c, bool clockwise)
  {
    double bulge = 0.0;
    AcDbArc *a = AcDbArc::cast(c);
    if (a == NULL) return bulge;
 
    double newStart =
      (a-&amp;gt;startAngle() &amp;gt; a-&amp;gt;endAngle()) ?
      (a-&amp;gt;startAngle() - 8 * atan(1.0)) :
      (a-&amp;gt;startAngle());
 
    bulge = tan((a-&amp;gt;endAngle() - newStart) / 4.0);
    if (clockwise) bulge = -bulge;
    return bulge;
  }
} ;
 
//-----------------------------------------------------------------------------
IMPLEMENT_ARX_ENTRYPOINT(CJoinToPlineApp)
ACED_ARXCOMMAND_ENTRY_AUTO(CJoinToPlineApp, JoinToPline, JoinToPline, JoinToPline, ACRX_CMD_MODAL, NULL)
&lt;/PRE&gt;</description>
      <pubDate>Thu, 30 Mar 2017 16:59:29 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/6985192#M8429</guid>
      <dc:creator>Alexander.Rivilis</dc:creator>
      <dc:date>2017-03-30T16:59:29Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004444#M8430</link>
      <description>&lt;P&gt;Thanks for the help, Earlier calling _.PEDIT like below, it now calls PEDIT command instead of joining two entities. Is this option or any such option no longer exists in new ARX framework?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;(acedCommandS(RTSTR, _T("_.PEDIT"), RTENAME, ent1, RTSTR, _T("YES"), RTSTR, AO_join, RTENAME, ent2, RTSTR, Null_str, 0);&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Harshad&lt;/P&gt;</description>
      <pubDate>Sat, 08 Apr 2017 14:05:29 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004444#M8430</guid>
      <dc:creator>Anonymous</dc:creator>
      <dc:date>2017-04-08T14:05:29Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004563#M8431</link>
      <description>&lt;P&gt;@Anonymous&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Do you want to merge segments only using the _PEDIT command and do not like my code for joining? OK.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;//-----------------------------------------------------------------------------
//----- acrxEntryPoint.cpp
//-----------------------------------------------------------------------------
#include "StdAfx.h"
#include "acedCmdNF.h"
#include "resource.h"
//-----------------------------------------------------------------------------
#define szRDS _RXST("")
//-----------------------------------------------------------------------------
//----- ObjectARX EntryPoint
class CMyJoinApp : public AcRxArxApp {

public:
  CMyJoinApp() : AcRxArxApp() {}
  virtual AcRx::AppRetCode On_kInitAppMsg(void *pkt) {
    AcRx::AppRetCode retCode = AcRxArxApp::On_kInitAppMsg(pkt);
    return (retCode);
  }
  virtual AcRx::AppRetCode On_kUnloadAppMsg(void *pkt) {
    AcRx::AppRetCode retCode = AcRxArxApp::On_kUnloadAppMsg(pkt);
    return (retCode);
  }
  virtual void RegisterServerComponents() {}

  static void RivilisMyJoin() {
    ads_name en1;  ads_point p;
    while (acedEntSel(_T("\nSelect first segment: "), en1, p) == RTNORM)
    {
      bool bConvertToPoly = false;
      AcDbObjectId id1; acdbGetObjectId(id1, en1);
      if (id1.objectClass() == AcDbLine::desc() ||
          id1.objectClass() == AcDbArc::desc())
      {
        bConvertToPoly = true;
      }
      ads_name en2;
      if (acedEntSel(_T("\nSelect next segment: "), en2, p) == RTNORM)
      {
        if (bConvertToPoly)
          acedCommandS(RTSTR, _T("_PEDIT"), RTENAME, en1, RTSTR, _T("_YES"), RTSTR, _T("_Join"),
            RTENAME, en2, RTSTR, _T(""), RTSTR, _T(""), RTNONE);
        else
          acedCommandS(RTSTR, _T("_PEDIT"), RTENAME, en1, RTSTR, _T("_Join"),
            RTENAME, en2, RTSTR, _T(""), RTSTR, _T(""), RTNONE);
      }
    }
  }
};

//-----------------------------------------------------------------------------
IMPLEMENT_ARX_ENTRYPOINT(CMyJoinApp)

ACED_ARXCOMMAND_ENTRY_AUTO(CMyJoinApp, Rivilis, &lt;STRONG&gt;MyJoin&lt;/STRONG&gt;, &lt;STRONG&gt;MyJoin&lt;/STRONG&gt;, ACRX_CMD_MODAL, NULL)

&lt;/PRE&gt;
&lt;P&gt;Video of &lt;STRONG&gt;MyJoin&lt;/STRONG&gt; command:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;DIV class="iframe-container"&gt;&lt;IFRAME src="https://screencast.autodesk.com/Embed/Timeline/e373a46f-c03d-4b8a-aa12-132a90ee6585" scrolling="no" allowfullscreen="allowfullscreen" webkitallowfullscreen="webkitallowfullscreen" style="display: inline;" width="640" height="620" frameborder="0"&gt;&lt;/IFRAME&gt;&lt;/DIV&gt;</description>
      <pubDate>Sat, 08 Apr 2017 16:31:15 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004563#M8431</guid>
      <dc:creator>Alexander.Rivilis</dc:creator>
      <dc:date>2017-04-08T16:31:15Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004569#M8432</link>
      <description>&lt;P&gt;Hello Alex,&lt;/P&gt;&lt;P&gt;Thanks for your help you ever do, I am converting the old code to new ARX version, so thought of doing minumum changes, I ever appreciate your help and use it in my work, thanks a ton for the same. My purpose was to check if by some means, with minimal changes what was doable, I am going to use the code you gave me, thanks a ton for the same.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;&lt;P&gt;Harshad&lt;/P&gt;</description>
      <pubDate>Sat, 08 Apr 2017 16:37:10 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004569#M8432</guid>
      <dc:creator>Anonymous</dc:creator>
      <dc:date>2017-04-08T16:37:10Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004575#M8433</link>
      <description>&lt;P&gt;I've just remembered that the command _PEDIT is affected by the system variable &lt;A href="https://knowledge.autodesk.com/support/autocad-lt/learn-explore/caas/CloudHelp/cloudhelp/2017/ENU/AutoCAD-LT/files/GUID-ED35EB02-53AD-4725-97DD-346C7E01974D-htm.html" target="_self"&gt;PEDITACCEPT&lt;/A&gt;. So more accurate code is:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;//-----------------------------------------------------------------------------
//----- acrxEntryPoint.cpp
//-----------------------------------------------------------------------------
#include "StdAfx.h"
#include "acedCmdNF.h"
#include "resource.h"
//-----------------------------------------------------------------------------
#define szRDS _RXST("")
//-----------------------------------------------------------------------------
//----- ObjectARX EntryPoint
class CMyJoinApp : public AcRxArxApp {

public:
  CMyJoinApp() : AcRxArxApp() {}
  virtual AcRx::AppRetCode On_kInitAppMsg(void *pkt) {
    AcRx::AppRetCode retCode = AcRxArxApp::On_kInitAppMsg(pkt);
    return (retCode);
  }
  virtual AcRx::AppRetCode On_kUnloadAppMsg(void *pkt) {
    AcRx::AppRetCode retCode = AcRxArxApp::On_kUnloadAppMsg(pkt);
    return (retCode);
  }
  virtual void RegisterServerComponents() {}

  static void RivilisMyJoin() {
    // Check PEDITACCEPT sysvar
    resbuf rb = { 0, RTSHORT, 0 };
    acedGetVar(_T("PEDITACCEPT"), &amp;amp;rb);
    bool bPeditAccept = (rb.resval.rint == 1) ? true : false;
    ads_name en1;  ads_point p;
    while (acedEntSel(_T("\nSelect first segment: "), en1, p) == RTNORM)
    {
      // if PEDITACCEPT == 1 then PEDIT no ask about converting
      bool bConvertToPoly = false;
      if (!bPeditAccept)
      {
        AcDbObjectId id1; acdbGetObjectId(id1, en1);
        if (id1.objectClass() == AcDbLine::desc() ||
          id1.objectClass() == AcDbArc::desc())
        {
          bConvertToPoly = true;
        }
      }
      ads_name en2;
      if (acedEntSel(_T("\nSelect next segment: "), en2, p) == RTNORM)
      {
        if (bConvertToPoly)
          acedCommandS(RTSTR, _T("_PEDIT"), RTENAME, en1, RTSTR, _T("_YES"), RTSTR, _T("_Join"),
            RTENAME, en2, RTSTR, _T(""), RTSTR, _T(""), RTNONE);
        else
          acedCommandS(RTSTR, _T("_PEDIT"), RTENAME, en1, RTSTR, _T("_Join"),
            RTENAME, en2, RTSTR, _T(""), RTSTR, _T(""), RTNONE);
      }
    }
  }
};

//-----------------------------------------------------------------------------
IMPLEMENT_ARX_ENTRYPOINT(CMyJoinApp)

ACED_ARXCOMMAND_ENTRY_AUTO(CMyJoinApp, Rivilis, MyJoin, MyJoin, ACRX_CMD_MODAL, NULL)

&lt;/PRE&gt;</description>
      <pubDate>Sat, 08 Apr 2017 16:49:12 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7004575#M8433</guid>
      <dc:creator>Alexander.Rivilis</dc:creator>
      <dc:date>2017-04-08T16:49:12Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7009232#M8434</link>
      <description>&lt;P&gt;Thanks a lot Alex! That worked!!&lt;/P&gt;</description>
      <pubDate>Tue, 11 Apr 2017 13:29:15 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7009232#M8434</guid>
      <dc:creator>Anonymous</dc:creator>
      <dc:date>2017-04-11T13:29:15Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7028533#M8435</link>
      <description>&lt;P&gt;I draw two Arch &amp;amp; use comment Joint. Then i check properties its being Polyline&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you&lt;/P&gt;&lt;P&gt;Jayhar.M.J&lt;/P&gt;</description>
      <pubDate>Thu, 20 Apr 2017 03:07:37 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7028533#M8435</guid>
      <dc:creator>jayhar</dc:creator>
      <dc:date>2017-04-20T03:07:37Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7729005#M8436</link>
      <description>&lt;P&gt;I need to know how to run the code in Autocad with a screencast ?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;thanks&lt;/P&gt;&lt;P&gt;Automohan&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sat, 27 Jan 2018 17:47:19 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/7729005#M8436</guid>
      <dc:creator>Automohan</dc:creator>
      <dc:date>2018-01-27T17:47:19Z</dc:date>
    </item>
    <item>
      <title>Re: converting Arc to Polyline</title>
      <link>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/8082699#M8437</link>
      <description>&lt;P&gt;Please try it&lt;/P&gt;</description>
      <pubDate>Thu, 21 Jun 2018 12:58:16 GMT</pubDate>
      <guid>https://forums.autodesk.com/t5/objectarx-forum/converting-arc-to-polyline/m-p/8082699#M8437</guid>
      <dc:creator>jayhar</dc:creator>
      <dc:date>2018-06-21T12:58:16Z</dc:date>
    </item>
  </channel>
</rss>

