minor style improve in hb-cff-interp-common.hh

This commit is contained in:
Ebrahim Byagowi 2019-06-28 23:11:52 +04:30 committed by GitHub
parent 9a7b7bd9fc
commit 9db7ce73d7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 30 additions and 61 deletions

View File

@ -226,7 +226,7 @@ struct number_t
void set_fixed (int32_t v) { value = v / 65536.0; } void set_fixed (int32_t v) { value = v / 65536.0; }
int32_t to_fixed () const { return (int32_t) (value * 65536.0); } int32_t to_fixed () const { return (int32_t) (value * 65536.0); }
void set_real (double v) { value = v; } void set_real (double v) { value = v; }
double to_real () const { return value; } double to_real () const { return value; }
int ceil () const { return (int) ::ceil (value); } int ceil () const { return (int) ::ceil (value); }
@ -235,17 +235,10 @@ struct number_t
bool in_int_range () const bool in_int_range () const
{ return ((double) (int16_t) to_int () == value); } { return ((double) (int16_t) to_int () == value); }
bool operator > (const number_t &n) const bool operator > (const number_t &n) const { return value > n.to_real (); }
{ return value > n.to_real (); } bool operator < (const number_t &n) const { return n > *this; }
bool operator >= (const number_t &n) const { return !(*this < n); }
bool operator < (const number_t &n) const bool operator <= (const number_t &n) const { return !(*this > n); }
{ return n > *this; }
bool operator >= (const number_t &n) const
{ return !(*this < n); }
bool operator <= (const number_t &n) const
{ return !(*this > n); }
const number_t &operator += (const number_t &n) const number_t &operator += (const number_t &n)
{ {
@ -255,7 +248,7 @@ struct number_t
} }
protected: protected:
double value; double value;
}; };
/* byte string */ /* byte string */
@ -320,8 +313,7 @@ struct byte_str_t : hb_ubytes_t
/* A byte string associated with the current offset and an error condition */ /* A byte string associated with the current offset and an error condition */
struct byte_str_ref_t struct byte_str_ref_t
{ {
byte_str_ref_t () byte_str_ref_t () { init (); }
{ init (); }
void init () void init ()
{ {
@ -343,13 +335,12 @@ struct byte_str_ref_t
} }
const unsigned char& operator [] (int i) { const unsigned char& operator [] (int i) {
if (unlikely ((unsigned int)(offset + i) >= str.length)) if (unlikely ((unsigned int) (offset + i) >= str.length))
{ {
set_error (); set_error ();
return Null(unsigned char); return Null (unsigned char);
} }
else return str[offset + i];
return str[offset + i];
} }
/* Conversion to byte_str_t */ /* Conversion to byte_str_t */
@ -359,9 +350,7 @@ struct byte_str_ref_t
{ return str.sub_str (offset_, len_); } { return str.sub_str (offset_, len_); }
bool avail (unsigned int count=1) const bool avail (unsigned int count=1) const
{ { return (!in_error () && str.check_limit (offset, count)); }
return (!in_error () && str.check_limit (offset, count));
}
void inc (unsigned int count=1) void inc (unsigned int count=1)
{ {
if (likely (!in_error () && (offset <= str.length) && (offset + count <= str.length))) if (likely (!in_error () && (offset <= str.length) && (offset + count <= str.length)))
@ -400,11 +389,7 @@ struct stack_t
for (unsigned int i = 0; i < elements.length; i++) for (unsigned int i = 0; i < elements.length; i++)
elements[i].init (); elements[i].init ();
} }
void fini () { elements.fini_deep (); }
void fini ()
{
elements.fini_deep ();
}
ELEM& operator [] (unsigned int i) ELEM& operator [] (unsigned int i)
{ {
@ -419,7 +404,6 @@ struct stack_t
else else
set_error (); set_error ();
} }
ELEM &push () ELEM &push ()
{ {
if (likely (count < elements.length)) if (likely (count < elements.length))
@ -441,7 +425,6 @@ struct stack_t
return Crap(ELEM); return Crap(ELEM);
} }
} }
void pop (unsigned int n) void pop (unsigned int n)
{ {
if (likely (count >= n)) if (likely (count >= n))
@ -452,13 +435,12 @@ struct stack_t
const ELEM& peek () const ELEM& peek ()
{ {
if (likely (count > 0)) if (unlikely (count < 0))
return elements[count-1];
else
{ {
set_error (); set_error ();
return Null(ELEM); return Null(ELEM);
} }
return elements[count - 1];
} }
void unpop () void unpop ()
@ -475,7 +457,7 @@ struct stack_t
void set_error () { error = true; } void set_error () { error = true; }
unsigned int get_count () const { return count; } unsigned int get_count () const { return count; }
bool is_empty () const { return count == 0; } bool is_empty () const { return !count; }
static constexpr unsigned kSizeLimit = LIMIT; static constexpr unsigned kSizeLimit = LIMIT;
@ -519,7 +501,7 @@ struct arg_stack_t : stack_t<ARG, 513>
i = 0; i = 0;
S::set_error (); S::set_error ();
} }
return (unsigned)i; return (unsigned) i;
} }
void push_longint_from_substr (byte_str_ref_t& str_ref) void push_longint_from_substr (byte_str_ref_t& str_ref)
@ -538,9 +520,7 @@ struct arg_stack_t : stack_t<ARG, 513>
} }
hb_array_t<const ARG> get_subarray (unsigned int start) const hb_array_t<const ARG> get_subarray (unsigned int start) const
{ { return S::elements.sub_array (start); }
return S::elements.sub_array (start);
}
private: private:
typedef stack_t<ARG, 513> S; typedef stack_t<ARG, 513> S;
@ -605,7 +585,7 @@ struct parsed_values_t
} }
unsigned get_count () const { return values.length; } unsigned get_count () const { return values.length; }
const VAL &get_value (unsigned int i) const { return values[i]; } const VAL &get_value (unsigned int i) const { return values[i]; }
const VAL &operator [] (unsigned int i) const { return get_value (i); } const VAL &operator [] (unsigned int i) const { return get_value (i); }
unsigned int opStart; unsigned int opStart;
@ -644,30 +624,19 @@ struct interp_env_t
return op; return op;
} }
const ARG& eval_arg (unsigned int i) const ARG& eval_arg (unsigned int i) { return argStack[i]; }
{
return argStack[i];
}
ARG& pop_arg () ARG& pop_arg () { return argStack.pop (); }
{ void pop_n_args (unsigned int n) { argStack.pop (n); }
return argStack.pop ();
}
void pop_n_args (unsigned int n) void clear_args () { pop_n_args (argStack.get_count ()); }
{
argStack.pop (n);
}
void clear_args () byte_str_ref_t
{ str_ref;
pop_n_args (argStack.get_count ()); arg_stack_t<ARG>
} argStack;
byte_str_ref_t str_ref;
arg_stack_t<ARG> argStack;
protected: protected:
bool error; bool error;
}; };
typedef interp_env_t<> num_interp_env_t; typedef interp_env_t<> num_interp_env_t;
@ -711,8 +680,8 @@ struct opset_t
}; };
template <typename ENV> template <typename ENV>
struct interpreter_t { struct interpreter_t
{
~interpreter_t() { fini (); } ~interpreter_t() { fini (); }
void fini () { env.fini (); } void fini () { env.fini (); }