]> git.sur5r.net Git - cc65/blobdiff - src/da65/attrtab.h
Merge remote-tracking branch 'upstream/master' into a5200
[cc65] / src / da65 / attrtab.h
index 09f71c13ff119969ab72c9033813de729e1b0af5..c9fb9c35fde0f98a18234914c7ba6e1a761da175 100644 (file)
@@ -1,15 +1,15 @@
 /*****************************************************************************/
 /*                                                                           */
-/*                                attrtab.h                                 */
+/*                                 attrtab.h                                 */
 /*                                                                           */
-/*                      Disassembler attribute table                        */
+/*                       Disassembler attribute table                        */
 /*                                                                           */
 /*                                                                           */
 /*                                                                           */
-/* (C) 2000      Ullrich von Bassewitz                                       */
-/*               Wacholderweg 14                                             */
-/*               D-70597 Stuttgart                                           */
-/* EMail:        uz@musoftware.de                                            */
+/* (C) 2000-2006 Ullrich von Bassewitz                                       */
+/*               Römerstrasse 52                                             */
+/*               D-70794 Filderstadt                                         */
+/* EMail:        uz@cc65.org                                                 */
 /*                                                                           */
 /*                                                                           */
 /* This software is provided 'as-is', without any expressed or implied       */
 
 
 /*****************************************************************************/
-/*                                  Data                                    */
+/*                                   Data                                    */
 /*****************************************************************************/
 
 
 
-typedef enum attr_t attr_t;
-enum attr_t {
-    atDefault  = 0x00,         /* Default style */
-    atCode     = 0x01,
-    atIllegal  = 0x02,
-    atByteTab          = 0x03,         /* Same as illegal */
-    atWordTab  = 0x04,
-    atDWordTab = 0x05,
-    atAddrTab  = 0x06,
-    atRtsTab   = 0x07,
+typedef enum attr_t {
 
-    atStyleMask = 0x0F         /* Output style */
-};
+    /* Styles */
+    atDefault       = 0x0000,   /* Default style */
+    atCode          = 0x0001,
+    atIllegal       = 0x0002,
+    atByteTab       = 0x0003,   /* Same as illegal */
+    atDByteTab      = 0x0004,
+    atWordTab       = 0x0005,
+    atDWordTab      = 0x0006,
+    atAddrTab       = 0x0007,
+    atRtsTab        = 0x0008,
+    atTextTab       = 0x0009,
+    atSkip          = 0x000A,   /* Skip code completely */
+
+    /* Label flags */
+    atNoLabel       = 0x0000,   /* No label for this address */
+    atExtLabel      = 0x0010,   /* External label */
+    atIntLabel      = 0x0020,   /* Internally generated label */
+    atDepLabel      = 0x0040,   /* Dependent label */
+    atUnnamedLabel  = 0x0080,   /* Unnamed label */
+
+    atLabelDefined  = 0x0100,   /* True if we defined the label */
+
+    atStyleMask     = 0x000F,   /* Output style */
+    atLabelMask     = 0x00F0,   /* Label information */
+
+    /* Segment */
+    atSegment       = 0x0100,   /* Code is in a segment */
+    atSegmentChange = 0x0200,   /* Either segment start or segment end */
+} attr_t;
 
 
 
 /*****************************************************************************/
-/*                                  Code                                    */
+/*                                   Code                                    */
 /*****************************************************************************/
 
 
 
+void AddrCheck (unsigned Addr);
+/* Check if the given address has a valid range */
+
+int SegmentDefined (unsigned Start, unsigned End);
+/* Return true if the atSegment bit is set somewhere in the given range */
+
+int HaveSegmentChange (unsigned Addr);
+/* Return true if the segment change attribute is set for the given address */
+
+unsigned GetGranularity (attr_t Style);
+/* Get the granularity for the given style */
+
 void MarkRange (unsigned Start, unsigned End, attr_t Attr);
 /* Mark a range with the given attribute */
 
 void MarkAddr (unsigned Addr, attr_t Attr);
 /* Mark an address with an attribute */
 
-const char* MakeLabelName (unsigned Addr);
-/* Make the default label name from the given address and return it in a
- * static buffer.
- */
+attr_t GetAttr (unsigned Addr);
+/* Return the attribute for the given address */
 
-void AddLabel (unsigned Addr, const char* Name);
-/* Add a label */
-
-int HaveLabel (unsigned Addr);
-/* Check if there is a label for the given address */
-
-const char* GetLabel (unsigned Addr);
-/* Return the label for an address */
-
-unsigned char GetStyle (unsigned Addr);
+attr_t GetStyleAttr (unsigned Addr);
 /* Return the style attribute for the given address */
 
-void DefOutOfRangeLabels (void);
-/* Output any labels that are out of the loaded code range */
+attr_t GetLabelAttr (unsigned Addr);
+/* Return the label attribute for the given address */
 
 
 
 /* End of attrtab.h */
-#endif
-
-
 
+#endif