Server IP : 103.119.228.120 / Your IP : 3.137.175.80 Web Server : Apache System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64 User : nobody ( 99) PHP Version : 5.6.40 Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/local/ssl/local/ssl/local/ssl/lib/mysqlsh/lib/python3.9/site-packages/antlr4/ |
Upload File : |
# # Copyright (c) 2012-2017 The ANTLR Project. All rights reserved. # Use of this file is governed by the BSD 3-clause license that # can be found in the LICENSE.txt file in the project root. # from io import StringIO from antlr4.Token import Token # need forward declarations IntervalSet = None class IntervalSet(object): __slots__ = ('intervals', 'readonly') def __init__(self): self.intervals = None self.readonly = False def __iter__(self): if self.intervals is not None: for i in self.intervals: for c in i: yield c def __getitem__(self, item): i = 0 for k in self: if i==item: return k else: i += 1 return Token.INVALID_TYPE def addOne(self, v:int): self.addRange(range(v, v+1)) def addRange(self, v:range): if self.intervals is None: self.intervals = list() self.intervals.append(v) else: # find insert pos k = 0 for i in self.intervals: # distinct range -> insert if v.stop<i.start: self.intervals.insert(k, v) return # contiguous range -> adjust elif v.stop==i.start: self.intervals[k] = range(v.start, i.stop) return # overlapping range -> adjust and reduce elif v.start<=i.stop: self.intervals[k] = range(min(i.start,v.start), max(i.stop,v.stop)) self.reduce(k) return k += 1 # greater than any existing self.intervals.append(v) def addSet(self, other:IntervalSet): if other.intervals is not None: for i in other.intervals: self.addRange(i) return self def reduce(self, k:int): # only need to reduce if k is not the last if k<len(self.intervals)-1: l = self.intervals[k] r = self.intervals[k+1] # if r contained in l if l.stop >= r.stop: self.intervals.pop(k+1) self.reduce(k) elif l.stop >= r.start: self.intervals[k] = range(l.start, r.stop) self.intervals.pop(k+1) def complement(self, start, stop): result = IntervalSet() result.addRange(range(start,stop+1)) for i in self.intervals: result.removeRange(i) return result def __contains__(self, item): if self.intervals is None: return False else: return any(item in i for i in self.intervals) def __len__(self): return sum(len(i) for i in self.intervals) def removeRange(self, v): if v.start==v.stop-1: self.removeOne(v.start) elif self.intervals is not None: k = 0 for i in self.intervals: # intervals are ordered if v.stop<=i.start: return # check for including range, split it elif v.start>i.start and v.stop<i.stop: self.intervals[k] = range(i.start, v.start) x = range(v.stop, i.stop) self.intervals.insert(k, x) return # check for included range, remove it elif v.start<=i.start and v.stop>=i.stop: self.intervals.pop(k) k -= 1 # need another pass # check for lower boundary elif v.start<i.stop: self.intervals[k] = range(i.start, v.start) # check for upper boundary elif v.stop<i.stop: self.intervals[k] = range(v.stop, i.stop) k += 1 def removeOne(self, v): if self.intervals is not None: k = 0 for i in self.intervals: # intervals is ordered if v<i.start: return # check for single value range elif v==i.start and v==i.stop-1: self.intervals.pop(k) return # check for lower boundary elif v==i.start: self.intervals[k] = range(i.start+1, i.stop) return # check for upper boundary elif v==i.stop-1: self.intervals[k] = range(i.start, i.stop-1) return # split existing range elif v<i.stop-1: x = range(i.start, v) self.intervals[k] = range(v + 1, i.stop) self.intervals.insert(k, x) return k += 1 def toString(self, literalNames:list, symbolicNames:list): if self.intervals is None: return "{}" with StringIO() as buf: if len(self)>1: buf.write("{") first = True for i in self.intervals: for j in i: if not first: buf.write(", ") buf.write(self.elementName(literalNames, symbolicNames, j)) first = False if len(self)>1: buf.write("}") return buf.getvalue() def elementName(self, literalNames:list, symbolicNames:list, a:int): if a==Token.EOF: return "<EOF>" elif a==Token.EPSILON: return "<EPSILON>" else: if a<len(literalNames) and literalNames[a] != "<INVALID>": return literalNames[a] if a<len(symbolicNames): return symbolicNames[a] return "<UNKNOWN>"