Issue with FirebaseRecyclerAdapter, on a null object reference when delete data










0















The display from the Firebase database works fine, but when I try to delete an item from the database, the application crashes, although the deletion occurs. Writes on a null object reference in the string:



String postDescription = dataSnapshot.child("desc").getValue().toString();


Here is my code:



public class PostFragment extends Fragment 

private RecyclerView recyclerPost;

private DatabaseReference postReference;

private View view;
private LinearLayoutManager layoutManager;

public PostFragment()


@Override
public View onCreateView(LayoutInflater inflater, final ViewGroup container, Bundle savedInstanceState)

view = inflater.inflate(R.layout.fragment_post, container, false);

recyclerPost = view.findViewById(R.id.recycler_post);

postReference = FirebaseDatabase.getInstance().getReference().child("Posts");
postReference.keepSynced(true);

layoutManager = new LinearLayoutManager(getContext());
layoutManager.setReverseLayout(true);
layoutManager.setStackFromEnd(true);
recyclerPost.setHasFixedSize(true);
recyclerPost.setLayoutManager(layoutManager);

return view;


@Override
public void onStart()
super.onStart();
Query query = postReference.orderByChild("timestamp");

FirebaseRecyclerOptions<Posts> options =
new FirebaseRecyclerOptions.Builder<Posts>()
.setQuery(query, Posts.class)
.build();

FirebaseRecyclerAdapter adapter = new FirebaseRecyclerAdapter<Posts, PostViewHolder>(options)

@Override
protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model)

final String postId = getRef(position).getKey();
postReference.child(postId).addValueEventListener(new ValueEventListener()
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot)
String postDescription = dataSnapshot.child("desc").getValue().toString();
holder.postDesc.setText(postDescription);


@Override
public void onCancelled(@NonNull DatabaseError databaseError)


);

holder.delBtn.setOnClickListener(new View.OnClickListener()
@Override
public void onClick(View v)
postReference.child(postId).removeValue();

);




@NonNull
@Override
public PostViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int position)
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.blog_item, viewGroup, false);
return new PostViewHolder(view);


;

adapter.startListening();
recyclerPost.setAdapter(adapter);


public class PostViewHolder extends RecyclerView.ViewHolder

private TextView postDesc;
private Button delBtn;
private View view;

public PostViewHolder(@NonNull View itemView)
super(itemView);
view = itemView;
postDesc = (TextView) view.findViewById(R.id.post_description);
delBtn = (Button) view.findViewById(R.id.del_post_btn);






Please tell me the solution to this problem.










share|improve this question
























  • If the application crashes, your logcat should contain an error message and stack trace. Please look those up, and ad them to your question.

    – Frank van Puffelen
    Nov 11 '18 at 15:29















0















The display from the Firebase database works fine, but when I try to delete an item from the database, the application crashes, although the deletion occurs. Writes on a null object reference in the string:



String postDescription = dataSnapshot.child("desc").getValue().toString();


Here is my code:



public class PostFragment extends Fragment 

private RecyclerView recyclerPost;

private DatabaseReference postReference;

private View view;
private LinearLayoutManager layoutManager;

public PostFragment()


@Override
public View onCreateView(LayoutInflater inflater, final ViewGroup container, Bundle savedInstanceState)

view = inflater.inflate(R.layout.fragment_post, container, false);

recyclerPost = view.findViewById(R.id.recycler_post);

postReference = FirebaseDatabase.getInstance().getReference().child("Posts");
postReference.keepSynced(true);

layoutManager = new LinearLayoutManager(getContext());
layoutManager.setReverseLayout(true);
layoutManager.setStackFromEnd(true);
recyclerPost.setHasFixedSize(true);
recyclerPost.setLayoutManager(layoutManager);

return view;


@Override
public void onStart()
super.onStart();
Query query = postReference.orderByChild("timestamp");

FirebaseRecyclerOptions<Posts> options =
new FirebaseRecyclerOptions.Builder<Posts>()
.setQuery(query, Posts.class)
.build();

FirebaseRecyclerAdapter adapter = new FirebaseRecyclerAdapter<Posts, PostViewHolder>(options)

@Override
protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model)

final String postId = getRef(position).getKey();
postReference.child(postId).addValueEventListener(new ValueEventListener()
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot)
String postDescription = dataSnapshot.child("desc").getValue().toString();
holder.postDesc.setText(postDescription);


@Override
public void onCancelled(@NonNull DatabaseError databaseError)


);

holder.delBtn.setOnClickListener(new View.OnClickListener()
@Override
public void onClick(View v)
postReference.child(postId).removeValue();

);




@NonNull
@Override
public PostViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int position)
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.blog_item, viewGroup, false);
return new PostViewHolder(view);


;

adapter.startListening();
recyclerPost.setAdapter(adapter);


public class PostViewHolder extends RecyclerView.ViewHolder

private TextView postDesc;
private Button delBtn;
private View view;

public PostViewHolder(@NonNull View itemView)
super(itemView);
view = itemView;
postDesc = (TextView) view.findViewById(R.id.post_description);
delBtn = (Button) view.findViewById(R.id.del_post_btn);






Please tell me the solution to this problem.










share|improve this question
























  • If the application crashes, your logcat should contain an error message and stack trace. Please look those up, and ad them to your question.

    – Frank van Puffelen
    Nov 11 '18 at 15:29













0












0








0








The display from the Firebase database works fine, but when I try to delete an item from the database, the application crashes, although the deletion occurs. Writes on a null object reference in the string:



String postDescription = dataSnapshot.child("desc").getValue().toString();


Here is my code:



public class PostFragment extends Fragment 

private RecyclerView recyclerPost;

private DatabaseReference postReference;

private View view;
private LinearLayoutManager layoutManager;

public PostFragment()


@Override
public View onCreateView(LayoutInflater inflater, final ViewGroup container, Bundle savedInstanceState)

view = inflater.inflate(R.layout.fragment_post, container, false);

recyclerPost = view.findViewById(R.id.recycler_post);

postReference = FirebaseDatabase.getInstance().getReference().child("Posts");
postReference.keepSynced(true);

layoutManager = new LinearLayoutManager(getContext());
layoutManager.setReverseLayout(true);
layoutManager.setStackFromEnd(true);
recyclerPost.setHasFixedSize(true);
recyclerPost.setLayoutManager(layoutManager);

return view;


@Override
public void onStart()
super.onStart();
Query query = postReference.orderByChild("timestamp");

FirebaseRecyclerOptions<Posts> options =
new FirebaseRecyclerOptions.Builder<Posts>()
.setQuery(query, Posts.class)
.build();

FirebaseRecyclerAdapter adapter = new FirebaseRecyclerAdapter<Posts, PostViewHolder>(options)

@Override
protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model)

final String postId = getRef(position).getKey();
postReference.child(postId).addValueEventListener(new ValueEventListener()
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot)
String postDescription = dataSnapshot.child("desc").getValue().toString();
holder.postDesc.setText(postDescription);


@Override
public void onCancelled(@NonNull DatabaseError databaseError)


);

holder.delBtn.setOnClickListener(new View.OnClickListener()
@Override
public void onClick(View v)
postReference.child(postId).removeValue();

);




@NonNull
@Override
public PostViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int position)
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.blog_item, viewGroup, false);
return new PostViewHolder(view);


;

adapter.startListening();
recyclerPost.setAdapter(adapter);


public class PostViewHolder extends RecyclerView.ViewHolder

private TextView postDesc;
private Button delBtn;
private View view;

public PostViewHolder(@NonNull View itemView)
super(itemView);
view = itemView;
postDesc = (TextView) view.findViewById(R.id.post_description);
delBtn = (Button) view.findViewById(R.id.del_post_btn);






Please tell me the solution to this problem.










share|improve this question
















The display from the Firebase database works fine, but when I try to delete an item from the database, the application crashes, although the deletion occurs. Writes on a null object reference in the string:



String postDescription = dataSnapshot.child("desc").getValue().toString();


Here is my code:



public class PostFragment extends Fragment 

private RecyclerView recyclerPost;

private DatabaseReference postReference;

private View view;
private LinearLayoutManager layoutManager;

public PostFragment()


@Override
public View onCreateView(LayoutInflater inflater, final ViewGroup container, Bundle savedInstanceState)

view = inflater.inflate(R.layout.fragment_post, container, false);

recyclerPost = view.findViewById(R.id.recycler_post);

postReference = FirebaseDatabase.getInstance().getReference().child("Posts");
postReference.keepSynced(true);

layoutManager = new LinearLayoutManager(getContext());
layoutManager.setReverseLayout(true);
layoutManager.setStackFromEnd(true);
recyclerPost.setHasFixedSize(true);
recyclerPost.setLayoutManager(layoutManager);

return view;


@Override
public void onStart()
super.onStart();
Query query = postReference.orderByChild("timestamp");

FirebaseRecyclerOptions<Posts> options =
new FirebaseRecyclerOptions.Builder<Posts>()
.setQuery(query, Posts.class)
.build();

FirebaseRecyclerAdapter adapter = new FirebaseRecyclerAdapter<Posts, PostViewHolder>(options)

@Override
protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model)

final String postId = getRef(position).getKey();
postReference.child(postId).addValueEventListener(new ValueEventListener()
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot)
String postDescription = dataSnapshot.child("desc").getValue().toString();
holder.postDesc.setText(postDescription);


@Override
public void onCancelled(@NonNull DatabaseError databaseError)


);

holder.delBtn.setOnClickListener(new View.OnClickListener()
@Override
public void onClick(View v)
postReference.child(postId).removeValue();

);




@NonNull
@Override
public PostViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int position)
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.blog_item, viewGroup, false);
return new PostViewHolder(view);


;

adapter.startListening();
recyclerPost.setAdapter(adapter);


public class PostViewHolder extends RecyclerView.ViewHolder

private TextView postDesc;
private Button delBtn;
private View view;

public PostViewHolder(@NonNull View itemView)
super(itemView);
view = itemView;
postDesc = (TextView) view.findViewById(R.id.post_description);
delBtn = (Button) view.findViewById(R.id.del_post_btn);






Please tell me the solution to this problem.







android firebase firebase-realtime-database recycler-adapter firebaseui






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 11 '18 at 15:28









Frank van Puffelen

233k29380406




233k29380406










asked Nov 11 '18 at 14:08









BinaryBinary

51




51












  • If the application crashes, your logcat should contain an error message and stack trace. Please look those up, and ad them to your question.

    – Frank van Puffelen
    Nov 11 '18 at 15:29

















  • If the application crashes, your logcat should contain an error message and stack trace. Please look those up, and ad them to your question.

    – Frank van Puffelen
    Nov 11 '18 at 15:29
















If the application crashes, your logcat should contain an error message and stack trace. Please look those up, and ad them to your question.

– Frank van Puffelen
Nov 11 '18 at 15:29





If the application crashes, your logcat should contain an error message and stack trace. Please look those up, and ad them to your question.

– Frank van Puffelen
Nov 11 '18 at 15:29












2 Answers
2






active

oldest

votes


















0














You can try the following:



 postReference.child(postId).addValueEventListener(new ValueEventListener() 
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot)
if(dataSnapshot.exists())
String postDescription = dataSnapshot.child("desc").getValue().toString();
holder.postDesc.setText(postDescription);



@Override
public void onCancelled(@NonNull DatabaseError databaseError)


);


You can use the method exists():




public boolean exists ()



Returns true if the snapshot contains a non-null value.




It will check if the datasnapshot is in the
database, if it is not in the database then you can add a snackbar or a toast.



More information here:



https://firebase.google.com/docs/reference/android/com/google/firebase/database/DataSnapshot#exists()






share|improve this answer






























    0














    Every time a post is added to the adapter/list view, you now create a listener with addValueEventListener in your onBindViewHolder. This listener gets the value from the database, and then keeps listening for changes until you remove it. Since you never remove these listeners, over time they add up and things likely get out of sync.



    The simplest solution is to use addListenerForSingleValueEvent:



    @Override
    protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model) {

    final String postId = getRef(position).getKey();
    postReference.child(postId).addListenerForSingleValueEvent(new ValueEventListener()
    @Override
    public void onDataChange(@NonNull DataSnapshot dataSnapshot)
    String postDescription = dataSnapshot.child("desc").getValue().toString();
    holder.postDesc.setText(postDescription);


    @Override
    public void onCancelled(@NonNull DatabaseError databaseError)
    throw databaseError.toException(); // don't ignore errors

    );


    When you use addListenerForSingleValueEvent, the listener is removed right after onDataChange fires for the first time.






    share|improve this answer






















      Your Answer






      StackExchange.ifUsing("editor", function ()
      StackExchange.using("externalEditor", function ()
      StackExchange.using("snippets", function ()
      StackExchange.snippets.init();
      );
      );
      , "code-snippets");

      StackExchange.ready(function()
      var channelOptions =
      tags: "".split(" "),
      id: "1"
      ;
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function()
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled)
      StackExchange.using("snippets", function()
      createEditor();
      );

      else
      createEditor();

      );

      function createEditor()
      StackExchange.prepareEditor(
      heartbeatType: 'answer',
      autoActivateHeartbeat: false,
      convertImagesToLinks: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      bindNavPrevention: true,
      postfix: "",
      imageUploader:
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      ,
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      );



      );













      draft saved

      draft discarded


















      StackExchange.ready(
      function ()
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53249546%2fissue-with-firebaserecycleradapter-on-a-null-object-reference-when-delete-data%23new-answer', 'question_page');

      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      0














      You can try the following:



       postReference.child(postId).addValueEventListener(new ValueEventListener() 
      @Override
      public void onDataChange(@NonNull DataSnapshot dataSnapshot)
      if(dataSnapshot.exists())
      String postDescription = dataSnapshot.child("desc").getValue().toString();
      holder.postDesc.setText(postDescription);



      @Override
      public void onCancelled(@NonNull DatabaseError databaseError)


      );


      You can use the method exists():




      public boolean exists ()



      Returns true if the snapshot contains a non-null value.




      It will check if the datasnapshot is in the
      database, if it is not in the database then you can add a snackbar or a toast.



      More information here:



      https://firebase.google.com/docs/reference/android/com/google/firebase/database/DataSnapshot#exists()






      share|improve this answer



























        0














        You can try the following:



         postReference.child(postId).addValueEventListener(new ValueEventListener() 
        @Override
        public void onDataChange(@NonNull DataSnapshot dataSnapshot)
        if(dataSnapshot.exists())
        String postDescription = dataSnapshot.child("desc").getValue().toString();
        holder.postDesc.setText(postDescription);



        @Override
        public void onCancelled(@NonNull DatabaseError databaseError)


        );


        You can use the method exists():




        public boolean exists ()



        Returns true if the snapshot contains a non-null value.




        It will check if the datasnapshot is in the
        database, if it is not in the database then you can add a snackbar or a toast.



        More information here:



        https://firebase.google.com/docs/reference/android/com/google/firebase/database/DataSnapshot#exists()






        share|improve this answer

























          0












          0








          0







          You can try the following:



           postReference.child(postId).addValueEventListener(new ValueEventListener() 
          @Override
          public void onDataChange(@NonNull DataSnapshot dataSnapshot)
          if(dataSnapshot.exists())
          String postDescription = dataSnapshot.child("desc").getValue().toString();
          holder.postDesc.setText(postDescription);



          @Override
          public void onCancelled(@NonNull DatabaseError databaseError)


          );


          You can use the method exists():




          public boolean exists ()



          Returns true if the snapshot contains a non-null value.




          It will check if the datasnapshot is in the
          database, if it is not in the database then you can add a snackbar or a toast.



          More information here:



          https://firebase.google.com/docs/reference/android/com/google/firebase/database/DataSnapshot#exists()






          share|improve this answer













          You can try the following:



           postReference.child(postId).addValueEventListener(new ValueEventListener() 
          @Override
          public void onDataChange(@NonNull DataSnapshot dataSnapshot)
          if(dataSnapshot.exists())
          String postDescription = dataSnapshot.child("desc").getValue().toString();
          holder.postDesc.setText(postDescription);



          @Override
          public void onCancelled(@NonNull DatabaseError databaseError)


          );


          You can use the method exists():




          public boolean exists ()



          Returns true if the snapshot contains a non-null value.




          It will check if the datasnapshot is in the
          database, if it is not in the database then you can add a snackbar or a toast.



          More information here:



          https://firebase.google.com/docs/reference/android/com/google/firebase/database/DataSnapshot#exists()







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 11 '18 at 14:30









          Peter HaddadPeter Haddad

          20.8k94257




          20.8k94257























              0














              Every time a post is added to the adapter/list view, you now create a listener with addValueEventListener in your onBindViewHolder. This listener gets the value from the database, and then keeps listening for changes until you remove it. Since you never remove these listeners, over time they add up and things likely get out of sync.



              The simplest solution is to use addListenerForSingleValueEvent:



              @Override
              protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model) {

              final String postId = getRef(position).getKey();
              postReference.child(postId).addListenerForSingleValueEvent(new ValueEventListener()
              @Override
              public void onDataChange(@NonNull DataSnapshot dataSnapshot)
              String postDescription = dataSnapshot.child("desc").getValue().toString();
              holder.postDesc.setText(postDescription);


              @Override
              public void onCancelled(@NonNull DatabaseError databaseError)
              throw databaseError.toException(); // don't ignore errors

              );


              When you use addListenerForSingleValueEvent, the listener is removed right after onDataChange fires for the first time.






              share|improve this answer



























                0














                Every time a post is added to the adapter/list view, you now create a listener with addValueEventListener in your onBindViewHolder. This listener gets the value from the database, and then keeps listening for changes until you remove it. Since you never remove these listeners, over time they add up and things likely get out of sync.



                The simplest solution is to use addListenerForSingleValueEvent:



                @Override
                protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model) {

                final String postId = getRef(position).getKey();
                postReference.child(postId).addListenerForSingleValueEvent(new ValueEventListener()
                @Override
                public void onDataChange(@NonNull DataSnapshot dataSnapshot)
                String postDescription = dataSnapshot.child("desc").getValue().toString();
                holder.postDesc.setText(postDescription);


                @Override
                public void onCancelled(@NonNull DatabaseError databaseError)
                throw databaseError.toException(); // don't ignore errors

                );


                When you use addListenerForSingleValueEvent, the listener is removed right after onDataChange fires for the first time.






                share|improve this answer

























                  0












                  0








                  0







                  Every time a post is added to the adapter/list view, you now create a listener with addValueEventListener in your onBindViewHolder. This listener gets the value from the database, and then keeps listening for changes until you remove it. Since you never remove these listeners, over time they add up and things likely get out of sync.



                  The simplest solution is to use addListenerForSingleValueEvent:



                  @Override
                  protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model) {

                  final String postId = getRef(position).getKey();
                  postReference.child(postId).addListenerForSingleValueEvent(new ValueEventListener()
                  @Override
                  public void onDataChange(@NonNull DataSnapshot dataSnapshot)
                  String postDescription = dataSnapshot.child("desc").getValue().toString();
                  holder.postDesc.setText(postDescription);


                  @Override
                  public void onCancelled(@NonNull DatabaseError databaseError)
                  throw databaseError.toException(); // don't ignore errors

                  );


                  When you use addListenerForSingleValueEvent, the listener is removed right after onDataChange fires for the first time.






                  share|improve this answer













                  Every time a post is added to the adapter/list view, you now create a listener with addValueEventListener in your onBindViewHolder. This listener gets the value from the database, and then keeps listening for changes until you remove it. Since you never remove these listeners, over time they add up and things likely get out of sync.



                  The simplest solution is to use addListenerForSingleValueEvent:



                  @Override
                  protected void onBindViewHolder(@NonNull final PostViewHolder holder, int position, @NonNull final Posts model) {

                  final String postId = getRef(position).getKey();
                  postReference.child(postId).addListenerForSingleValueEvent(new ValueEventListener()
                  @Override
                  public void onDataChange(@NonNull DataSnapshot dataSnapshot)
                  String postDescription = dataSnapshot.child("desc").getValue().toString();
                  holder.postDesc.setText(postDescription);


                  @Override
                  public void onCancelled(@NonNull DatabaseError databaseError)
                  throw databaseError.toException(); // don't ignore errors

                  );


                  When you use addListenerForSingleValueEvent, the listener is removed right after onDataChange fires for the first time.







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 11 '18 at 15:33









                  Frank van PuffelenFrank van Puffelen

                  233k29380406




                  233k29380406



























                      draft saved

                      draft discarded
















































                      Thanks for contributing an answer to Stack Overflow!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid


                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.

                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function ()
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53249546%2fissue-with-firebaserecycleradapter-on-a-null-object-reference-when-delete-data%23new-answer', 'question_page');

                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

                      ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế

                      ⃀⃉⃄⃅⃍,⃂₼₡₰⃉₡₿₢⃉₣⃄₯⃊₮₼₹₱₦₷⃄₪₼₶₳₫⃍₽ ₫₪₦⃆₠₥⃁₸₴₷⃊₹⃅⃈₰⃁₫ ⃎⃍₩₣₷ ₻₮⃊⃀⃄⃉₯,⃏⃊,₦⃅₪,₼⃀₾₧₷₾ ₻ ₸₡ ₾,₭⃈₴⃋,€⃁,₩ ₺⃌⃍⃁₱⃋⃋₨⃊⃁⃃₼,⃎,₱⃍₲₶₡ ⃍⃅₶₨₭,⃉₭₾₡₻⃀ ₼₹⃅₹,₻₭ ⃌