about summary refs log tree commit diff stats
path: root/awk/2222.txt
blob: e608ec7590ba3cd6c4f566538edb39070b2e6ac5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
pre { line-height: 125%; }
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
.highlight .hll { background-color: #ffffcc }
.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 .ges { font-weight: bold; font-style: italic } /* Generic.EmphStrong */
.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 */
import math
import times

import bindings/quickjs
import js/error
import js/javascript
import js/tojs
import utils/opt

type
  EventPhase = enum
    NONE = 0u16
    CAPTURING_PHASE = 1u16
    AT_TARGET = 2u16
    BUBBLING_PHASE = 3u16

  EventFlag = enum
    FLAG_STOP_PROPAGATION
    FLAG_STOP_IMMEDIATE_PROPAGATION
    FLAG_CANCELED
    FLAG_IN_PASSIVE_LISTENER
    FLAG_COMPOSED
    FLAG_INITIALIZED
    FLAG_DISPATCH

  Event* = ref object of RootObj
    ctype {.jsget: "type".}: string
    target {.jsget.}: EventTarget
    currentTarget {.jsget.}: EventTarget
    eventPhase {.jsget.}: uint16
    bubbles {.jsget.}: bool
    cancelable {.jsget.}: bool
    #TODO DOMHighResTimeStamp?
    timeStamp {.jsget.}: float64
    flags: set[EventFlag]
    isTrusted {.jsufget.}: bool

  CustomEvent* = ref object of Event
    ctx: JSContext #TODO get rid of this
    detail {.jsget.}: JSValue

  EventTarget* = ref object of RootObj
    eventListeners*: seq[EventListener]

  EventHandler* = JSValue

  EventListenerCallback = proc (event: Event): Err[JSError]

  EventListener = ref object
    ctype: string
    callback: EventListenerCallback
    capture: bool
    passive: Opt[bool]
    once: bool
    #TODO AbortSignal
    removed: bool

jsDestructor(Event)
jsDestructor(CustomEvent)
jsDestructor(EventTarget)

# Forward declaration hack
var isDefaultPassive*: proc (eventTarget: EventTarget): bool

# Event
proc innerEventCreationSteps(event: Event, ctx: JSContext,
    eventInitDict: JSValue) =
  event.flags = {FLAG_INITIALIZED}
  #TODO this is probably incorrect?
  # I think it measures the time since the first fork. not sure though
  event.timeStamp = round(cpuTime())
  if not JS_IsUndefined(eventInitDict):
    template set(name: static string, value: var bool) =
      let prop = JS_GetPropertyStr(ctx, eventInitDict, name)
      let jsVal = fromJS[bool](ctx, prop)
      if jsVal.isSome:
        value = jsVal.get
    set "bubbles", event.bubbles
    set "cancelable", event.cancelable
    var composed: bool
    set "composed", composed
    if composed:
      event.flags.incl(FLAG_COMPOSED)

#TODO eventInitDict type
proc newEvent(ctx: JSContext, ctype: string, eventInitDict = JS_UNDEFINED):
    Result[Event, JSError] {.jsctor.} =
  if not JS_IsUndefined(eventInitDict) and not JS_IsObject(eventInitDict):
    return err(newTypeError("eventInitDict must be an object"))
  let event = Event()
  event.innerEventCreationSteps(ctx, eventInitDict)
  event.ctype = ctype
  return ok(event)

proc initialize(this: Event, ctype: string, bubbles, cancelable: bool) =
  this.flags.incl(FLAG_INITIALIZED)
  this.isTrusted = false
  this.target = nil
  this.ctype = ctype
  this.bubbles = bubbles
  this.cancelable = cancelable

proc initEvent(this: Event, ctype: string, bubbles, cancelable: bool)
    {.jsfunc.} =
  if FLAG_DISPATCH notin this.flags:
    this.initialize(ctype, bubbles, cancelable)

func srcElement(this: Event): EventTarget {.jsfget.} =
  return this.target

#TODO shadow DOM etc.
func composedPath(this: Event): seq[EventTarget] {.jsfunc.} =
  if this.currentTarget == nil:
    return @[]
  return @[this.currentTarget]

proc stopPropagation(this: Event) {.jsfunc.} =
  this.flags.incl(FLAG_STOP_PROPAGATION)

func cancelBubble(this: Event): bool {.jsfget.} =
  return FLAG_STOP_PROPAGATION in this.flags

proc cancelBubble(this: Event, cancel: bool) {.jsfset.} =
  if cancel:
    this.stopPropagation()

proc stopImmediatePropagation(this: Event) {.jsfunc.} =
  this.flags.incl({FLAG_STOP_PROPAGATION, FLAG_STOP_IMMEDIATE_PROPAGATION})

proc setCanceledFlag(this: Event) =
  if this.cancelable and FLAG_IN_PASSIVE_LISTENER notin this.flags:
    this.flags.incl(FLAG_CANCELED)

proc returnValue(this: Event): bool {.jsfget.} =
  return FLAG_CANCELED notin this.flags

proc returnValue(this: Event, value: bool) {.jsfset.} =
  if not value:
    this.setCanceledFlag()

proc preventDefault(this: Event) {.jsfunc.} =
  this.flags.incl(FLAG_CANCELED)

func defaultPrevented(this: Event): bool {.jsfget.} =
  return FLAG_CANCELED in this.flags

func composed(this: Event): bool {.jsfget.} =
  return FLAG_COMPOSED in this.flags

# CustomEvent
proc newCustomEvent(ctx: JSContext, ctype: string,
    eventInitDict = JS_UNDEFINED): Result[CustomEvent, JSError] {.jsctor.} =
  if not JS_IsUndefined(eventInitDict) and not JS_IsObject(eventInitDict):
    return err(newTypeError("eventInitDict must be an object"))
  let event = CustomEvent()
  event.innerEventCreationSteps(ctx, eventInitDict)
  event.detail = JS_GetPropertyStr(ctx, eventInitDict, "detail")
  event.ctx = ctx
  event.ctype = ctype
  return ok(event)

proc finalize(this: CustomEvent) {.jsfin.} =
  JS_FreeValue(this.ctx, this.detail)

proc initCustomEvent(ctx: JSContext, this: CustomEvent, ctype: string,
    bubbles, cancelable: bool, detail: JSValue) {.jsfunc.} =
  if FLAG_DISPATCH notin this.flags:
    this.initialize(ctype, bubbles, cancelable)
    this.ctx = ctx
    this.detail = detail

# EventTarget
proc newEventTarget(): EventTarget {.jsctor.} =
  return EventTarget()

proc defaultPassiveValue(ctype: string, eventTarget: EventTarget): bool =
  if ctype in ["touchstart", "touchmove", "wheel", "mousewheel"]:
    return true
  return eventTarget.isDefaultPassive()

proc findEventListener(eventTarget: EventTarget, ctype: string,
    callback: EventListenerCallback, capture: bool): int =
  for i in 0 ..< eventTarget.eventListeners.len:
    let it = eventTarget.eventListeners[i]
    if it.ctype == ctype and it.callback == callback and it.capture == capture:
      return i
  return -1

# shared
proc addAnEventListener(eventTarget: EventTarget, listener: EventListener) =
  #TODO signals
  if listener.callback == nil:
    return
  if listener.passive.isNone:
    listener.passive = opt(defaultPassiveValue(listener.ctype, eventTarget))
  if eventTarget.findEventListener(listener.ctype, listener.callback,
      listener.capture) == -1: # dedup
    eventTarget.eventListeners.add(listener)
  #TODO signals

proc removeAnEventListener(eventTarget: EventTarget, i: int) =
  eventTarget.eventListeners[i].removed = true
  eventTarget.eventListeners.delete(i)

proc flatten(ctx: JSContext, options: JSValue): bool =
  if JS_IsBool(options):
    return fromJS[bool](ctx, options).get(false)
  if JS_IsObject(options):
    let x = JS_GetPropertyStr(ctx, options, "capture")
    return fromJS[bool](ctx, x).get(false)
  return false

proc flattenMore(ctx: JSContext, options: JSValue):
    tuple[
      capture: bool,
      once: bool,
      passive: Opt[bool]
      #TODO signals
    ] =
  if JS_IsUndefined(options):
    return
  let capture = flatten(ctx, options)
  var once = false
  var passive: Opt[bool]
  if JS_IsObject(options):
    once = fromJS[bool](ctx, JS_GetPropertyStr(ctx, options, "once"))
      .get(false)
    let x = fromJS[bool](ctx, JS_GetPropertyStr(ctx, options, "passive"))
    if x.isSome:
      passive = opt(x.get)
  return (capture, once, passive)

proc addEventListener(ctx: JSContext, eventTarget: EventTarget,
    callback: EventListenerCallback, options = JS_UNDEFINED) {.jsfunc.} =
  let (capture, once, passive) = flattenMore(ctx, options)
  let listener = EventListener(
    capture: capture,
    passive: passive,
    once: once,
    callback: callback
  )
  eventTarget.addAnEventListener(listener)

proc removeEventListener(ctx: JSContext, eventTarget: EventTarget,
    ctype: string, callback: EventListenerCallback,
    options = JS_UNDEFINED) {.jsfunc.} =
  let capture = flatten(ctx, options)
  let i = eventTarget.findEventListener(ctype, callback, capture)
  if i != -1:
    eventTarget.removeAnEventListener(i)

proc addEventModule*(ctx: JSContext) =
  let eventCID = ctx.registerType(Event)
  ctx.registerType(CustomEvent, parent = eventCID)
  ctx.defineConsts(eventCID, EventPhase, uint16)
  ctx.registerType(EventTarget)
' href='#n1990'>1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075 2076 2077 2078 2079 2080 2081 2082 2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126 2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218 2219 2220 2221 2222
ABET
ABLE
ABLY
ABUT
ACAI
ACED
ACES
ACHE
ACHY
ACID
ACME
ACNE
ACRE
ACTS
ADDS
AEON
AFAR
AFRO
AGED
AGES
AGOG
AHEM
AIDE
AILS
AIMS
AIRS
AIRY
AJAR
AKIN
ALAS
ALLY
ALMS
ALOE
ALSO
ALTO
ALUM
AMEN
AMID
AMMO
AMOK
AMPS
ANDS
ANEW
ANKH
ANON
ANTI
ANTS
APES
APEX
APPS
AQUA
ARCH
ARCS
AREA
ARIA
ARID
ARKS
ARMS
ARMY
ARSE
ARTS
ARTY
ASHY
ASKS
ATOM
ATOP
AUNT
AURA
AUTO
AVID
AVOW
AWAY
AWED
AWES
AWLS
AWRY
AXED
AXES
AXIS
AXLE
BABA
BABE
BABY
BACH
BACK
BADS
BAGS
BAIL
BAIT
BAKE
BALD
BALE
BALK
BALL
BALM
BAND
BANE
BANG
BANK
BANS
BARB
BARD
BARE
BARF
BARK
BARN
BARS
BASE
BASH
BASK
BASS
BAST
BATH
BATS
BAUD
BAWL
BAYS
BEAD
BEAK
BEAM
BEAN
BEAR
BEAT
BEAU
BECK
BEDS
BEEF
BEEN
BEEP
BEER
BEES
BEET
BEGS
BELL
BELT
BEND
BENT
BERG
BERM
BEST
BETA
BETS
BEVY
BEYS
BIAS
BIBS
BIDE
BIDS
BIFF
BIKE
BILE
BILK
BILL
BIND
BIOS
BIRD
BITE
BITS
BLAB
BLAH
BLEB
BLED
BLEW
BLIP
BLOB
BLOC
BLOG
BLOT
BLOW
BLUE
BLUR
BOAR
BOAS
BOAT
BOBS
BODE
BODS
BODY
BOGS
BOGY
BOIL
BOLA
BOLD
BOLO
BOLT
BOMB
BOND
BONE
BONG
BONK
BONY
BOOK
BOOM
BOON
BOOR
BOOS
BOOT
BORE
BORN
BOSS
BOTH
BOTS
BOUT
BOWL
BOWS
BOXY
BOYO
BOYS
BOZO
BRAG
BRAN
BRAS
BRAT
BRAY
BRED
BREW
BRIE
BRIG
BRIM
BRIS
BRIT
BROS
BROW
BUCK
BUDS
BUFF
BUGS
BULB
BULK
BULL
BUMP
BUMS
BUND
BUNG
BUNK
BUNS
BUNT
BUOY
BURB
BURG
BURL
BURN
BURP
BURR
BURY
BUSH
BUSK
BUST
BUSY
BUTT
BUYS
BUZZ
BYES
BYTE
CABS
CAFE
CAFF
CAGE
CAKE
CALF
CALL
CALM
CAME
CAMO
CAMP
CANE
CANS
CAPE
CAPO
CAPS
CARB
CARD
CARE
CARP
CARS
CART
CASE
CASH
CASK
CAST
CATS
CAVE
CAWS
CAYS
CEDE
CELL
CELS
CELT
CENT
CESS
CHAD
CHAI
CHAP
CHAR
CHAT
CHEF
CHEW
CHIC
CHIN
CHIP
CHIT
CHOP
CHOW
CHUB
CHUG
CHUM
CIAO
CITE
CITY
CLAD
CLAM
CLAN
CLAP
CLAW
CLAY
CLEF
CLIP
CLOD
CLOG
CLOP
CLOT
CLUB
CLUE
COAL
COAT
COAX
COBS
COCA
COCO
CODA
CODE
CODS
COED
COGS
COIL
COIN
COKE
COLA
COLD
COLE
COLT
COMA
COMB
COME
COMP
CONE
CONS
COOK
COOL
COOP
COOS
COPE
COPS
COPY
CORD
CORE
CORK
CORN
COST
COSY
COTS
COUP
COVE
COWL
COWS
COZY
CRAB
CRAG
CRAM
CRAP
CRAW
CREW
CRIB
CRIT
CROC
CROP
CROW
CRUD
CRUX
CUBE
CUBS
CUDS
CUED
CUES
CUFF
CULL
CULT
CUPS
CURB
CURD
CURE
CURL
CURT
CUSP
CUSS
CUTE
CUTS
CYAN
CYST
CZAR
DABS
DADA
DADS
DAFT
DAME
DAMN
DAMP
DAMS
DANK
DARE
DARK
DARN
DART
DASH
DATA
DATE
DAWN
DAYS
DAZE
DEAD
DEAF
DEAL
DEAN
DEAR
DEBT
DECK
DEED
DEEM
DEEP
DEER
DEFT
DEFY
DELI
DELL
DELT
DEMO
DENS
DENT
DERM
DESK
DEWS
DEWY
DIAL
DICE
DIED
DIES
DIET
DIGS
DILL
DIME
DIMS
DINE
DING
DINK
DINO
DINT
DIPS
DIRE
DIRT
DISC
DISH
DISK
DISS
DIVA
DIVE
DOCK
DOCS
DODO
DOER
DOES
DOFF
DOGS
DOJO
DOLE
DOLL
DOLT
DOME
DONE
DONG
DOOM
DOOR
DOPE
DORK
DORM
DORY
DOSE
DOTE
DOTH
DOTS
DOUR
DOVE
DOWN
DOXY
DOZE
DOZY
DRAB
DRAG
DRAM
DRAW
DRAY
DREW
DRIP
DROP
DRUG
DRUM
DRYS
DUAL
DUBS
DUCK
DUCT
DUDE
DUDS
DUEL
DUES
DUET
DUFF
DUKE
DULL
DULY
DUMB
DUMP
DUNE
DUNG
DUNK
DUNS
DUOS
DUPE
DUSK
DUST
DUTY
DYAD
DYED
DYER
DYES
EACH
EARL
EARN
EARS
EASE
EAST
EASY
EATS
EAVE
EBBS
ECHO
EDDY
EDGE
EDGY
EDIT
EELS
EGGS
EGGY
EGOS
ELKS
ELMS
ELSE
EMIT
EMMY
EMUS
ENDS
ENVY
EONS
EPEE
EPIC
ERAS
ERRS
ETCH
EURO
EVEN
EVER
EVES
EVIL
EWES
EXAM
EXEC
EXIT
EXON
EXPO
EYED
EYES
FABS
FACE
FACT
FADE
FADS
FAIL
FAIR
FAKE
FALL
FAME
FANG
FANS
FARE
FARM
FART
FAST
FATE
FATS
FAUN
FAVA
FAVE
FAWN
FAZE
FEAR
FEAT
FEED
FEEL
FEES
FEET
FELL
FELT
FEND
FENS
FERN
FESS
FEST
FETA
FETE
FEUD
FIAT
FIBS
FIFE
FIGS
FILE
FILL
FILM
FILO
FIND
FINE
FINK
FINS
FIRE
FIRM
FIRS
FISH
FIST
FITS
FIVE
FIZZ
FLAB
FLAG
FLAK
FLAM
FLAN
FLAP
FLAT
FLAW
FLAX
FLAY
FLEA
FLED
FLEE
FLEW
FLEX
FLIP
FLIT
FLOC
FLOE
FLOG
FLOP
FLOW
FLUB
FLUE
FLUS
FLUX
FOAL
FOAM
FOBS
FOCI
FOES
FOGS
FOGY
FOIL
FOLD
FOLK
FOND
FONT
FOOD
FOOL
FOOT
FOPS
FORD
FORE
FORK
FORM
FORT
FOUL
FOUR
FOWL
FOXY
FRAG
FRAT
FRAY
FREE
FRET
FRIG
FROG
FROM
FUEL
FUCK
FUGU
FULL
FUME
FUND
FUNK
FURL
FURS
FURY
FUSE
FUSS
FUTZ
FUZZ
GAFF
GAGS
GAIN
GAIT
GALA
GALE
GALL
GALS
GAME
GANG
GAPE
GAPS
GARB
GASH
GASP
GATE
GAVE
GAWK
GAYS
GAZE
GEAR
GEEK
GEES
GELS
GEMS
GENE
GENS
GENT
GERM
GETS
GHAT
GHEE
GIFT
GIGS
GILD
GILL
GILT
GINS
GIRD
GIRL
GIST
GITS
GIVE
GLAD
GLAM
GLEE
GLEN
GLIB
GLOB
GLOM
GLOP
GLOW
GLUE
GLUG
GLUM
GLUT
GNAR
GNAT
GNAW
GOAD
GOAL
GOAT
GOBS
GOBY
GODS
GOER
GOES
GOLD
GOLF
GONE
GONG
GOOD
GOOF
GOON
GOOP
GOOS
GORE
GORY
GOSH
GOTH
GOUT
GOWN
GRAB
GRAD
GRAM
GRAN
GRAY
GREW
GREY
GRID
GRIM
GRIN
GRIP
GRIT
GROG
GROW
GRUB
GUFF
GULF
GULL
GULP
GUMS
GUNK
GUNS
GURU
GUSH
GUST
GUTS
GUYS
GYMS
GYRE
GYRO
HACK
HAGS
HAIL
HAIR
HALF
HALL
HALO
HALT
HAMS
HAND
HANG
HANK
HAPS
HARD
HARE
HARK
HARM
HARP
HART
HASH
HATE
HATH
HATS
HAUL
HAVE
HAWK
HAWS
HAYS
HAZE
HAZY
HEAD
HEAL
HEAP
HEAR
HEAT
HECK
HEED
HEEL
HEFT
HEIR
HELD
HELL
HELM
HELP
HEMP
HEMS
HENS
HERB
HERD
HERE
HERO
HERS
HEST
HEWN
HEWS
HICK
HIDE
HIGH
HIKE
HILL
HILT
HIND
HINT
HIPS
HIRE
HISS
HITS
HIVE
HIYA
HOAR
HOAX
HOBO
HOCK
HOED
HOES
HOGS
HOLD
HOLE
HOLO
HOLT
HOLY
HOME
HONE
HONK
HOOD
HOOF
HOOK
HOOP
HOOT
HOPE
HOPS
HORN
HOSE
HOST
HOUR
HOVE
HOWL
HUBS
HUCK
HUED
HUES
HUFF
HUGE
HUGS
HULA
HULK
HULL
HUMP
HUMS
HUNG
HUNK
HUNT
HURL
HURT
HUSH
HUSK
HUTS
HYMN
HYPE
HYPO
ICED
ICES
ICKY
ICON
IDEA
IDLE
IDLY
IDOL
IFFY
ILLS
IMPS
INCH
INFO
INKS
INKY
INNS
INTO
IONS
IOTA
IRIS
IRKS
IRON
ISLE
ISMS
ITCH
ITEM
JABS
JACK
JADE
JAIL
JAKE
JAMB
JAMS
JAPE
JARS
JAVA
JAWA
JAWS
JAYS
JAZZ
JEAN
JEEP
JEER
JEEZ
JELL
JERK
JEST
JETS
JIBE
JIBS
JIGS
JILT
JINK
JINX
JIVE
JOBS
JOCK
JOGS
JOIN
JOKE
JOLT
JOTS
JOWL
JOYS
JUDO
JUGS
JUJU
JUKE
JUMP
JUNK
JURY
JUST
JUTE
JUTS
KALE
KEEL
KEEN
KEEP
KEGS
KELP
KEPT
KETO
KEYS
KHAN
KHAT
KICK
KIDS
KILL
KILN
KILO
KILT
KIND
KING
KIPS
KISS
KITE
KITS
KIWI
KNEE
KNEW
KNIT
KNOB
KNOT
KNOW
KOAN
KOOK
KOTO
LABS
LACE
LACK
LACY
LADS
LADY
LAGS
LAID
LAIN
LAIR
LAKE
LAMA
LAMB
LAME
LAMP
LAND
LANE
LAPS
LARD
LARK
LASH
LASS
LAST
LATE
LAUD
LAVA
LAWN
LAWS
LAYS
LAZE
LAZY
LEAD
LEAF
LEAK
LEAN
LEAP
LEAS
LEEK
LEER
LEET
LEFT
LEGS
LEND
LENS
LENT
LESS
LEST
LEWD
LIAR
LIBS
LICE
LICK
LIDS
LIED
LIEN
LIER
LIES
LIEU
LIFE
LIFT
LIKE
LILT
LILY
LIMA
LIMB
LIME
LIMO
LIMP
LINE
LING
LINK
LINT
LION
LIPS
LISP
LIST
LITE
LIVE
LOAD
LOAF
LOAM
LOAN
LOBE
LOBS
LOCH
LOCK
LOCO
LODE
LOFT
LOGE
LOGO
LOGS
LOIN
LONE
LONG
LOOK
LOOM
LOON
LOOP
LOOS
LOOT
LOPS
LORD
LORE
LOSE
LOSS
LOST
LOTH
LOTS
LOUD
LOUT
LOVE
LOWS
LUBE
LUCK
LUFF
LUGS
LULL
LUMP
LUNE
LUNG
LURE
LURK
LUSH
LUST
LUTE
LUVS
LYNX
LYRE
MACE
MACH
MACK
MACS
MADE
MAGE
MAGI
MAGS
MAID
MAIL
MAIM
MAIN
MAKE
MAKI
MALE
MALL
MALT
MAMA
MANE
MANS
MANY
MAPS
MARE
MARK
MARS
MART
MASH
MASK
MASS
MAST
MATE
MATH
MATS
MAUL
MAWS
MAXI
MAYO
MAZE
MAZY
MEAD
MEAL
MEAN
MEAT
MEEK
MEET
MEGA
MELD
MELT
MEMO
MEND
MENU
MEOW
MERE
MESA
MESH
MESS
META
METE
MEWL
MEWS
MICA
MICE
MICS
MIDS
MILD
MILE
MILK
MILL
MIME
MIND
MINE
MINI
MINK
MINT
MINX
MIRE
MISO
MISS
MIST
MITE
MOAN
MOAT
MOBS
MOCK
MODE
MODS
MOJO
MOLD
MOLE
MOLT
MOMS
MONK
MONO
MOOD
MOON
MOOR
MOOS
MOOT
MOPE
MOPS
MORE
MORN
MOSH
MOSS
MOST
MOTE
MOTH
MOVE
MOWS
MUCH
MUCK
MUDS
MUFF
MUGS
MULE
MULL
MUMS
MUON
MURK
MUSE
MUSH
MUSK
MUST
MUTE
MUTT
MYTH
NAAN
NABS
NAGS
NAIL
NAME
NANA
NANS
NAPE
NAPS
NARC
NARD
NARY
NAVY
NAYS
NEAR
NEAT
NECK
NEED
NEEM
NEON
NERD
NESS
NEST
NETS
NEWS
NEWT
NEXT
NIBS
NICE
NICK
NIGH
NINE
NITE
NOBS
NODE
NODS
NOEL
NOIR
NONE
NOOK
NOON
NOPE
NORI
NORM
NOSE
NOSH
NOSY
NOTE
NOUN
NOVA
NUBS
NUDE
NUKE
NULL
NUMB
NUNS
NUTS
OAFS
OAKS
OAKY
OARS
OATH
OATS
OBEY
OBIT
OBOE
ODDS
ODES
ODOR
OGLE
OGRE
OILS
OILY
OINK
OKAY
OKRA
OLDS
OMEN
OMIT
ONCE
ONES
ONLY
ONTO
ONUS
ONYX
OOPS
OOZE
OOZY
OPAL
OPEN
OPTS
OPUS
ORAL
ORBS
ORCA
ORES
ORGY
ORZO
OUCH
OURS
OUST
OUTS
OVAL
OVEN
OVER
OVUM
OWED
OWES
OWLS
OWNS
PACE
PACK
PACT
PADS
PAGE
PAID
PAIL
PAIN
PAIR
PALE
PALL
PALM
PALP
PALS
PANE
PANG
PANS
PANT
PAPA
PAPS
PARA
PARE
PARK
PARS
PART
PASS
PAST
PATE
PATH
PATS
PAVE
PAWN
PAWS
PAYS
PEAK
PEAL
PEAR
PEAS
PEAT
PECK
PECS
PEED
PEEK
PEEL
PEEP
PEER
PEES
PEGS
PELT
PENS
PENT
PEON
PERK
PERM
PERP
PESO
PEST
PETS
PEWS
PHEW
PICK
PICS
PIED
PIER
PIES
PIGS
PIKA
PIKE
PILE
PILL
PINE
PING
PINK
PINS
PINT
PIPE
PISS
PITA
PITH
PITS
PITY
PLAN
PLAT
PLAY
PLEA
PLEB
PLED
PLEX
PLOD
PLOP
PLOT
PLOW
PLOY
PLUG
PLUM
PLUS
POCK
PODS
POEM
POET
POKE
POKY
POLE
POLL
POLO
POLY
POMP
POND
PONG
PONY
POOF
POOL
POOP
POOR
POPE
POPS
PORE
PORK
PORT
POSE
POSH
POSY
POTS
POUF
POUR
POUT
PRAM
PRAY
PREP
PREY
PREZ
PRIG
PRIM
PROB
PROD
PROF
PROG
PROM
PROP
PROS
PROW
PUBS
PUCK
PUDS
PUFF
PUGS
PUKE
PULL
PULP
PUMA
PUMP
PUNK
PUNS
PUNT
PUNY
PUPA
PUPS
PURE
PURL
PURR
PUSH
PUSS
PUTS
PUTT
PUTZ
PYRE
PYRO
QUAD
QUID
QUIP
QUIT
QUIZ
RACE
RACK
RACY
RADS
RAFT
RAGA
RAGE
RAGS
RAID
RAIL
RAIN
RAJA
RAKE
RAKU
RALE
RAMP
RAMS
RANG
RANK
RANT
RAPS
RAPT
RARE
RASH
RASP
RATE
RATH
RATS
RAVE
RAYS
RAZE
RAZZ
READ
REAL
REAM
REAP
REAR
REDO
REED
REEF
REEK
REEL
REFS
REIN
RELY
REMS
REND
RENT
REPO
REPP
REPS
REST
RIBS
RICE
RICH
RIDE
RIDS
RIFE
RIFF
RIFT
RIGS
RILE
RILL
RIME
RIMS
RIND
RING
RINK
RIOT
RIPE
RIPS
RISE
RISK
RITE
RITZ
ROAD
ROAM
ROAN
ROAR
ROBE
ROBS
ROCK
RODE
RODS
ROES
ROIL
ROLE
ROLL
ROMP
ROMS
ROOF
ROOK
ROOM
ROOS
ROOT
ROPE
ROPY
ROSE
ROSY
ROTE
ROTI
ROTO
ROTS
ROUT
ROUX
ROVE
ROWS
RUBE
RUBS
RUBY
RUCK
RUDE
RUED
RUES
RUFF
RUGS
RUIN
RULE
RUMP
RUMS
RUNE
RUNG
RUNS
RUNT
RUSE
RUSH
RUST
RUTS
SACK
SACS
SAFE
SAGA
SAGE
SAGO
SAGS
SAID
SAIL
SAKE
SAKI
SALE
SALT
SAME
SAND
SANE
SANG
SANK
SAPS
SARI
SASH
SASS
SATE
SAVE
SAWN
SAWS
SAYS
SCAB
SCAD
SCAM
SCAN
SCAR
SCAT
SCOT
SCUD
SCUM
SEAL
SEAM
SEAR
SEAS
SEAT
SECT
SEED
SEEK
SEEM
SEEN
SEEP
SEER
SEES
SELF
SELL
SEMI
SEND
SENT
SEPT
SETS
SEWN
SEWS
SHAM
SHED
SHEW
SHIM
SHIN
SHIP
SHIT
SHIV
SHOD
SHOE
SHOO
SHOP
SHOT
SHOW
SHUN
SHUT
SIBS
SICK
SIDE
SIFT
SIGH
SIGN
SILK
SILL
SILO
SILT
SINE
SING
SINK
SINS
SIPS
SIRE
SIRS
SITE
SITS
SIZE
SKEW
SKID
SKIM
SKIN
SKIP
SKIS
SKIT
SLAB
SLAG
SLAM
SLAP
SLAT
SLAW
SLAY
SLED
SLEW
SLID
SLIM
SLIP
SLIT
SLOB
SLOE
SLOG
SLOP
SLOT
SLOW
SLUG
SLUM
SMOG
SMUG
SNAG
SNAP
SNIP
SNIT
SNOB
SNOT
SNOW
SNUB
SNUG
SOAK
SOAP
SOAR
SOBA
SOBS
SOCK
SODA
SODS
SOFA
SOFT
SOIL
SOLD
SOLE
SOLO
SOME
SONG
SONS
SOON
SOOT
SOPS
SORE
SORT
SOUL
SOUP
SOUR
SOWN
SOWS
SOYA
SPAM
SPAN
SPAR
SPAS
SPAT
SPAY
SPEC
SPED
SPEW
SPIN
SPIT
SPOT
SPRY
SPUD
SPUN
SPUR
STAB
STAG
STAR
STAT
STAY
STEM
STEP
STEW
STIR
STOP
STOW
STUB
STUD
STUN
STYE
SUBS
SUCH
SUCK
SUED
SUES
SUET
SUIT
SULK
SUMO
SUMP
SUMS
SUNG
SUNK
SUNS
SUPS
SURE
SURF
SUSS
SWAB
SWAG
SWAM
SWAN
SWAP
SWAT
SWAY
SWIG
SWIM
SWUM
SYNC
TABS
TACH
TACK
TACO
TACT
TAGS
TAIL
TAKE
TALC
TALE
TALK
TALL
TAME
TAMP
TANG
TANK
TANS
TAPE
TAPS
TARE
TARN
TARO
TARP
TARS
TART
TASK
TAUT
TAXI
TEAK
TEAL
TEAM
TEAR
TEAS
TEAT
TECH
TEEM
TEEN
TEES
TEFF
TELE
TELL
TEMP
TEND
TENT
TERM
TERN
TEST
TEXT
THAN
THAT
THAW
THEE
THEM
THEN
THEY
THIN
THIS
THOU
THRU
THUD
THUG
THUS
TICK
TIDE
TIDY
TIED
TIER
TIES
TIFF
TIKI
TILE
TILL
TILT
TIME
TINE
TING
TINS
TINT
TINY
TIPS
TIRE
TITS
TOAD
TODE
TOED
TOES
TOFU
TOGA
TOIL
TOKE
TOLD
TOLE
TOLL
TOMB
TOME
TONE
TONG
TOOK
TOOL
TOON
TOOT
TOPS
TORE
TORN
TORT
TORY
TOSS
TOTE
TOTS
TOUR
TOUT
TOWN
TOWS
TOYS
TRAM
TRAP
TRAY
TREE
TREK
TREY
TRIG
TRIM
TRIO
TRIP
TROD
TROT
TSAR
TUBA
TUBE
TUBS
TUCK
TUFF
TUFT
TUGS
TUMS
TUNA
TUNE
TURD
TURF
TURK
TURN
TUSH
TUSK
TUTS
TUTU
TWEE
TWIG
TWIN
TWIT
TWOS
TYKE
TYPE
TYPO
UDON
UGLY
UMPS
UNDO
UNIT
UNTO
UPON
URGE
URNS
USED
USER
USES
VAIL
VAIN
VAMP
VANE
VANS
VARY
VASE
VAST
VATS
VEAL
VEER
VEIL
VEIN
VEND
VENT
VERB
VERT
VERY
VEST
VETO
VETS
VIAL
VIBE
VICE
VIDS
VIED
VIES
VIEW
VILE
VIMS
VINE
VINO
VISA
VISE
VITA
VIVA
VOID
VOLE
VOLT
VOTE
VOWS
WACK
WADE
WADS
WAFT
WAGE
WAGS
WAIF
WAIL
WAIT
WAKE
WALK
WALL
WAND
WANE
WANT
WARD
WARE
WARM
WARN
WARP
WARS
WART
WARY
WASH
WASP
WATT
WAVE
WAVY
WAXY
WAYS
WEAK
WEAN
WEAR
WEBS
WEDS
WEED
WEEK
WEEN
WEEP
WELL
WENT
WERE
WEST
WHAT
WHEN
WHOM
WIDE
WIFE
WILD
WILL
WILT
WIND
WINE
WING
WINS
WIPE
WIRE
WISE
WISH
WITH
WOLF
WOOD
WOOL
WORD
WORE
WORK
WORM
WORN
WRAP
YARD
YARN
YEAH
YEAR
YOGA
YOUR
ZERO
ZINC
ZONE
ZOOM