#ifndef NUMBERLIKEARRAY_H #define NUMBERLIKEARRAY_H // Make sure we have NULL. #ifndef NULL #define NULL 0 #endif /* A NumberlikeArray<Blk> object holds a heap-allocated array of Blk with a * length and a capacity and provides basic memory management features. * BigUnsigned and BigUnsignedInABase both subclass it. * * NumberlikeArray provides no information hiding. Subclasses should use * nonpublic inheritance and manually expose members as desired using * declarations like this: * * public: * NumberlikeArray< the-type-argument >::getLength; */ template <class Blk> class NumberlikeArray { public: // Type for the index of a block in the array typedef unsigned int Index; // The number of bits in a block, defined below. static const unsigned int N; // The current allocated capacity of this NumberlikeArray (in blocks) Index cap; // The actual length of the value stored in this NumberlikeArray (in blocks) Index len; // Heap-allocated array of the blocks (can be NULL if len == 0) Blk *blk; // Constructs a ``zero'' NumberlikeArray with the given capacity. NumberlikeArray(Index c) : cap(c), len(0) { blk = (cap > 0) ? (new Blk[cap]) : NULL; } /* Constructs a zero NumberlikeArray without allocating a backing array. * A subclass that doesn't know the needed capacity at initialization * time can use this constructor and then overwrite blk without first * deleting it. */ NumberlikeArray() : cap(0), len(0) { blk = NULL; } // Destructor. Note that `delete NULL' is a no-op. ~NumberlikeArray() { delete [] blk; } /* Ensures that the array has at least the requested capacity; may * destroy the contents. */ void allocate(Index c); /* Ensures that the array has at least the requested capacity; does not * destroy the contents. */ void allocateAndCopy(Index c); // Copy constructor NumberlikeArray(const NumberlikeArray<Blk> &x); // Assignment operator void operator=(const NumberlikeArray<Blk> &x); // Constructor that copies from a given array of blocks NumberlikeArray(const Blk *b, Index blen); // ACCESSORS Index getCapacity() const { return cap; } Index getLength() const { return len; } Blk getBlock(Index i) const { return blk[i]; } bool isEmpty() const { return len == 0; } /* Equality comparison: checks if both objects have the same length and * equal (==) array elements to that length. Subclasses may wish to * override. */ bool operator ==(const NumberlikeArray<Blk> &x) const; bool operator !=(const NumberlikeArray<Blk> &x) const { return !operator ==(x); } }; /* BEGIN TEMPLATE DEFINITIONS. They are present here so that source files that * include this header file can generate the necessary real definitions. */ template <class Blk> const unsigned int NumberlikeArray<Blk>::N = 8 * sizeof(Blk); template <class Blk> void NumberlikeArray<Blk>::allocate(Index c) { // If the requested capacity is more than the current capacity... if (c > cap) { // Delete the old number array delete [] blk; // Allocate the new array cap = c; blk = new Blk[cap]; } } template <class Blk> void NumberlikeArray<Blk>::allocateAndCopy(Index c) { // If the requested capacity is more than the current capacity... if (c > cap) { Blk *oldBlk = blk; // Allocate the new number array cap = c; blk = new Blk[cap]; // Copy number blocks Index i; for (i = 0; i < len; i++) blk[i] = oldBlk[i]; // Delete the old array delete [] oldBlk; } } template <class Blk> NumberlikeArray<Blk>::NumberlikeArray(const NumberlikeArray<Blk> &x) : len(x.len) { // Create array cap = len; blk = new Blk[cap]; // Copy blocks Index i; for (i = 0; i < len; i++) blk[i] = x.blk[i]; } template <class Blk> void NumberlikeArray<Blk>::operator=(const NumberlikeArray<Blk> &x) { /* Calls like a = a have no effect; catch them before the aliasing * causes a problem */ if (this == &x) return; // Copy length len = x.len; // Expand array if necessary allocate(len); // Copy number blocks Index i; for (i = 0; i < len; i++) blk[i] = x.blk[i]; } template <class Blk> NumberlikeArray<Blk>::NumberlikeArray(const Blk *b, Index blen) : cap(blen), len(blen) { // Create array blk = new Blk[cap]; // Copy blocks Index i; for (i = 0; i < len; i++) blk[i] = b[i]; } template <class Blk> bool NumberlikeArray<Blk>::operator ==(const NumberlikeArray<Blk> &x) const { if (len != x.len) // Definitely unequal. return false; else { // Compare corresponding blocks one by one. Index i; for (i = 0; i < len; i++) if (blk[i] != x.blk[i]) return false; // No blocks differed, so the objects are equal. return true; } } #endif 8' href='#n38'>38</a> <a id='n39' href='#n39'>39</a> <a id='n40' href='#n40'>40</a> <a id='n41' href='#n41'>41</a> <a id='n42' href='#n42'>42</a> <a id='n43' href='#n43'>43</a> <a id='n44' href='#n44'>44</a> <a id='n45' href='#n45'>45</a> <a id='n46' href='#n46'>46</a> <a id='n47' href='#n47'>47</a> <a id='n48' href='#n48'>48</a> <a id='n49' href='#n49'>49</a> <a id='n50' href='#n50'>50</a> <a id='n51' href='#n51'>51</a> <a id='n52' href='#n52'>52</a> <a id='n53' href='#n53'>53</a> <a id='n54' href='#n54'>54</a> <a id='n55' href='#n55'>55</a> <a id='n56' href='#n56'>56</a> <a id='n57' href='#n57'>57</a> <a id='n58' href='#n58'>58</a> <a id='n59' href='#n59'>59</a> <a id='n60' href='#n60'>60</a> <a id='n61' href='#n61'>61</a> <a id='n62' href='#n62'>62</a> <a id='n63' href='#n63'>63</a> <a id='n64' href='#n64'>64</a> <a id='n65' href='#n65'>65</a> <a id='n66' href='#n66'>66</a> <a id='n67' href='#n67'>67</a> <a id='n68' href='#n68'>68</a> <a id='n69' href='#n69'>69</a> <a id='n70' href='#n70'>70</a> <a id='n71' href='#n71'>71</a> <a id='n72' href='#n72'>72</a> </pre></td> <td class='lines'><pre><code><style>pre { line-height: 125%; margin: 0; } td.linenos pre { color: #000000; background-color: #f0f0f0; padding: 0 5px 0 5px; } span.linenos { color: #000000; background-color: #f0f0f0; padding: 0 5px 0 5px; } td.linenos pre.special { color: #000000; background-color: #ffffc0; padding: 0 5px 0 5px; } span.linenos.special { color: #000000; background-color: #ffffc0; padding: 0 5px 0 5px; } .highlight .hll { background-color: #ffffcc } .highlight { background: #ffffff; } .highlight .c { color: #888888 } /* Comment */ .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ .highlight .k { color: #008800; font-weight: bold } /* Keyword */ .highlight .ch { color: #888888 } /* Comment.Hashbang */ .highlight .cm { color: #888888 } /* Comment.Multiline */ .highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */ .highlight .cpf { color: #888888 } /* Comment.PreprocFile */ .highlight .c1 { color: #888888 } /* Comment.Single */ .highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */ .highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */ .highlight .ge { font-style: italic } /* Generic.Emph */ .highlight .gr { color: #aa0000 } /* Generic.Error */ .highlight .gh { color: #333333 } /* Generic.Heading */ .highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */ .highlight .go { color: #888888 } /* Generic.Output */ .highlight .gp { color: #555555 } /* Generic.Prompt */ .highlight .gs { font-weight: bold } /* Generic.Strong */ .highlight .gu { color: #666666 } /* Generic.Subheading */ .highlight .gt { color: #aa0000 } /* Generic.Traceback */ .highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */ .highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */ .highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */ .highlight .kp { color: #008800 } /* Keyword.Pseudo */ .highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */ .highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */ .highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */ .highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */ .highlight .na { color: #336699 } /* Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */</style><div class="highlight"><pre><span></span><span class="gd">--- a/libhandle/handle.c</span> <span class="gi">+++ b/libhandle/handle.c</span> <span class="gu">@@ -20,6 +20,7 @@</span> #include <xfs/xfs.h> #include <xfs/handle.h> #include <xfs/parent.h> <span class="gi">+#include <linux/limits.h></span> /* just pick a value we know is more than big enough */ #define MAXHANSIZ 64 <span class="gd">--- a/libhandle/jdm.c</span> <span class="gi">+++ b/libhandle/jdm.c</span> <span class="gu">@@ -20,6 +20,7 @@</span> #include <xfs/handle.h> #include <xfs/jdm.h> #include <xfs/parent.h> <span class="gi">+#include <linux/limits.h></span> /* internal fshandle - typecast to a void for external use */ #define FSHANDLE_SZ 8 <span class="gd">--- a/libdisk/evms.c</span> <span class="gi">+++ b/libdisk/evms.c</span> <span class="gu">@@ -22,6 +22,7 @@</span> #include <fcntl.h> #include <sys/ioctl.h> #include <sys/sysmacros.h> <span class="gi">+#include <sys/stat.h></span> #include <disk/volume.h> #include "evms.h" <span class="gd">--- a/libdisk/evms.h</span> <span class="gi">+++ b/libdisk/evms.h</span> <span class="gu">@@ -16,6 +16,8 @@</span> * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ <span class="gi">+#include <sys/types.h></span> <span class="gi">+</span> #define EVMS_MAJOR 117 #define EVMS_GET_VOL_STRIPE_INFO \ _IOR(EVMS_MAJOR, 0xF0, struct evms_vol_stripe_info_s) <span class="gd">--- a/libdisk/fstype.h</span> <span class="gi">+++ b/libdisk/fstype.h</span> <span class="gu">@@ -192,7 +192,7 @@ struct adfs_super_block {</span> char s_dummy2[62]; char s_checksum[1]; }; <span class="gd">-#define adfsblksize(s) ((uint) s.s_blksize[0])</span> <span class="gi">+#define adfsblksize(s) ((unsigned int) s.s_blksize[0])</span> /* found in first 4 bytes of block 1 */ struct vxfs_super_block { <span class="gd">--- a/fsr/xfs_fsr.c</span> <span class="gi">+++ b/fsr/xfs_fsr.c</span> <span class="gu">@@ -25,6 +25,7 @@</span> #include <xfs/xfs_dinode.h> #include <xfs/xfs_attr_sf.h> <span class="gi">+#include <paths.h></span> #include <fcntl.h> #include <errno.h> #include <malloc.h> <span class="gd">--- a/libdisk/xvm.c</span> <span class="gi">+++ b/libdisk/xvm.c</span> <span class="gu">@@ -22,6 +22,7 @@</span> #include <unistd.h> #include <sys/stat.h> #include <sys/ioctl.h> <span class="gi">+#include <sys/types.h></span> #include <disk/volume.h> #include "xvm.h" </pre></div> </code></pre></td></tr></table> </div> <!-- class=content --> <div class='footer'>generated by <a href='https://git.zx2c4.com/cgit/about/'>cgit v1.2.3</a> (<a href='https://git-scm.com/'>git 2.25.1</a>) at 2025-04-04 22:39:34 +0000</div> </div> <!-- id=cgit --> </body> </html>