{"id":3558,"date":"2018-02-10T18:52:20","date_gmt":"2018-02-10T18:52:20","guid":{"rendered":"http:\/\/pensemosweb.com.mx\/index.php\/2018\/02\/10\/como-usar-patrones-glob-shell-linux-javascript\/"},"modified":"2024-04-06T01:34:22","modified_gmt":"2024-04-06T07:34:22","slug":"como-usar-patrones-glob-shell-linux-javascript","status":"publish","type":"post","link":"https:\/\/pensemosweb.com\/en\/como-usar-patrones-glob-shell-linux-javascript\/","title":{"rendered":"\u00bfC\u00f3mo se usan los patrones glob de la shell de linux en Javascript?"},"content":{"rendered":"<h2 class=\"wp-block-heading\">\u00bfQu\u00e9 son los patrones glob?<\/h2>\n\n\n\n<p>En Javascript se utiliza mucho los Patrones Glob, estos permiten seleccionar un n\u00famero de archivos con una sintaxis parecida a las expresiones regulares pero con menos caracteres comod\u00edn y menor complejidad. Un car\u00e1cter comod\u00edn es \u00e9l <code>*<\/code> o el signo de <code>?<\/code>.<\/p>\n\n\n\n<p>Una gran diferencia entre expresiones regulares es que los <strong>patrones glob <\/strong>se ocupan para buscar y filtrar archivos, y las <strong>expresiones regulares <\/strong>funcionan con cadenas de texto.<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>Expresiones regulares trabaja con <strong>Texto<\/strong><\/li>\n\n\n\n<li>Glob trabaja con archivos\/directorios<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\">\u00bfOrigen?<\/h2>\n\n\n\n<p>Tienen su origen en las primeras versiones de Unix, durante la versi\u00f3n 6 para ser exacto, 1969-1975, era el programa <code>\/etc\/glob<\/code>, se usaba para seleccionar un conjunto de archivos en la shell, se llamaba <code>glob<\/code> por ser la abreviaci\u00f3n de <strong>global<\/strong>.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u00bfC\u00f3mo se usan?<\/h2>\n\n\n\n<p>Tambi\u00e9n la funcionalidad es un poco diferente, por ejemplo el <code>*<\/code> en una<strong> expresi\u00f3n regular<\/strong> coincide con la ausencia o cualquier n\u00famero de repeticiones del car\u00e1cter<strong>&nbsp;<\/strong>que le precede.<\/p>\n\n\n\n<p>Por ejemplo <strong><code>a*<\/code><\/strong>, indica cero o m\u00e1s repeticiones de la letra <code>to<\/code>.<\/p>\n\n\n\n<p>Otro ejemplo con car\u00e1cter especial es <strong><code>.*<\/code><\/strong> el cual indica cero o m\u00e1s repeticiones de cualquier car\u00e1cter, excepto car\u00e1cter de nueva de l\u00ednea.<\/p>\n\n\n\n<p>Por otro lado el car\u00e1cter <strong><code>*<\/code><\/strong> en un<strong> patr\u00f3n glob<\/strong> representa la ausencia o cualquier n\u00famero de repeticiones de cualquier car\u00e1cter.<\/p>\n\n\n\n<p>El ejemplo m\u00e1s utilizado es cuando queremos listar archivos con una determinada extensi\u00f3n, por ejemplo:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#0F111A\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewbox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" data-code=\"\/$ ls *.js\" style=\"color:#babed8;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewbox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki material-theme-ocean\" style=\"background-color: #0F111A\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #89DDFF\">\/<\/span><span style=\"color: #BABED8\">$ ls <\/span><span style=\"color: #89DDFF\">*.<\/span><span style=\"color: #BABED8\">js<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre><\/div>\n\n\n\n<p>Muy similar con lo que hacemos en el MS-DOS de windows:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#0F111A\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewbox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" data-code=\"C:\\&gt; dir *.js\" style=\"color:#babed8;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewbox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki material-theme-ocean\" style=\"background-color: #0F111A\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #FFCB6B\">C<\/span><span style=\"color: #89DDFF\">:<\/span><span style=\"color: #BABED8\">\\<\/span><span style=\"color: #89DDFF\">&gt;<\/span><span style=\"color: #BABED8\"> dir <\/span><span style=\"color: #89DDFF\">*.<\/span><span style=\"color: #BABED8\">js<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre><\/div>\n\n\n\n<p>No es necesario un car\u00e1cter antes del <strong>*<\/strong>, como sucede con las expresiones regulares.<\/p>\n\n\n\n<p>Aqu\u00ed abajo un ejemplo donde tenemos un archivo de configuraci\u00f3n de <a href=\"https:\/\/jasmine.github.io\/\" target=\"_blank\" rel=\"noopener noreferrer\">jasmine<\/a>, Jasmine es un framework para realizar pruebas a tu c\u00f3digo Javascript, este archivo de configuraci\u00f3n permite seleccionar que archivos se usar\u00e1n para ejecutar las pruebas:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#0F111A\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewbox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" data-code=\"{  &quot;spec_dir&quot;: &quot;spec&quot;,  &quot;spec_files&quot;: [    &quot;**\/*[sS]pec.js&quot;  ],  &quot;helpers&quot;: [    &quot;helpers\/**\/*.js&quot;  ],  &quot;stopSpecOnExpectationFailure&quot;: false,  &quot;random&quot;: false}\" style=\"color:#babed8;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewbox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki material-theme-ocean\" style=\"background-color: #0F111A\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #89DDFF\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">spec_dir<\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #F07178\">: <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">spec<\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #89DDFF\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">spec_files<\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #F07178\">: [<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">    <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">**\/*[sS]pec.js<\/span><span style=\"color: #89DDFF\">&quot;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  ]<\/span><span style=\"color: #89DDFF\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">helpers<\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #F07178\">: [<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">    <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">helpers\/**\/*.js<\/span><span style=\"color: #89DDFF\">&quot;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  ]<\/span><span style=\"color: #89DDFF\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">stopSpecOnExpectationFailure<\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #F07178\">: <\/span><span style=\"color: #FF9CAC\">false<\/span><span style=\"color: #89DDFF\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F07178\">  <\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #C3E88D\">random<\/span><span style=\"color: #89DDFF\">&quot;<\/span><span style=\"color: #F07178\">: <\/span><span style=\"color: #FF9CAC\">false<\/span><\/span>\n<span class=\"line\"><span style=\"color: #89DDFF\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre><\/div>\n\n\n\n<p>Algo que destacar es el uso de doble asterisco <code>**<\/code>, esto indica cero o m\u00e1s coincidencias de cualquier subdirectorio y archivo, es decir, cero o m\u00e1s niveles de subdirectorios.<\/p>\n\n\n\n<p>Tambi\u00e9n podemos notar el uso de <code>[sS]<\/code>, esta notaci\u00f3n de glob indica que acepta sola una vez ya sea la <code>s<\/code>min\u00fascula o la <code>S<\/code>may\u00fascula.<\/p>\n\n\n\n<p>En el arreglo <code>spec_files<\/code>, su primer elemento es un patr\u00f3n glob, el cual busca en cualquier subdirectorio relativo al directorio definido en <code>spec_dir<\/code>y que tenga cualquier conjunto de letras al principio pero que terminen con <code>spec.js<\/code>either <code>Spec.js<\/code>. Esta definici\u00f3n podr\u00eda obtener las siguientes rutas de archivos:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\/spec\/nombre-archivo.<strong>s<\/strong>pec.js<\/li>\n\n\n\n<li>\/spec\/nombre-archivo.<strong>S<\/strong>pec.js<\/li>\n\n\n\n<li>\/spec\/helpers\/nombre-archivo.<strong>s<\/strong>pec.js<\/li>\n\n\n\n<li>\/spec\/helpers\/nombre-archivo.<strong>S<\/strong>pec.js<\/li>\n\n\n\n<li>\/spec\/esto\/es\/otra\/ruta\/nombre-archivo.<strong>s<\/strong>pec.js<\/li>\n\n\n\n<li>\/spec\/esto\/es\/otra\/ruta\/nombre-archivo.<strong>S<\/strong>pec.js<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">\u00bfD\u00f3nde se utilizan?<\/h2>\n\n\n\n<p>En Javascript se utiliza:<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>Para automatizar tareas que necesitan de la lectura y escritura de archivos<\/li>\n\n\n\n<li>Se utiliza mucho en node.js con herramientas como gulp y webpack<\/li>\n\n\n\n<li>Automatizado de pruebas<\/li>\n\n\n\n<li>Minificado y concatenado para el c\u00f3digo en producci\u00f3n.<\/li>\n<\/ol>","protected":false},"excerpt":{"rendered":"<p>        En Javascript se utiliza mucho los Patrones Glob, estos permiten seleccionar un n\u00famero de archivos con una sintaxis parecida a las expresiones regulares pero con menos caracteres comod\u00edn y menor complejidad. Un car\u00e1cter comod\u00edn es el `*` o el signo de `?`.<\/p>","protected":false},"author":2,"featured_media":3749,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_et_pb_use_builder":"","_et_pb_old_content":"","_et_gb_content_width":"","footnotes":""},"categories":[28],"tags":[54,68],"class_list":["post-3558","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","tag-javascript","tag-intermedio"],"_links":{"self":[{"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/posts\/3558","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/comments?post=3558"}],"version-history":[{"count":2,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/posts\/3558\/revisions"}],"predecessor-version":[{"id":3837,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/posts\/3558\/revisions\/3837"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/media\/3749"}],"wp:attachment":[{"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/media?parent=3558"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/categories?post=3558"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pensemosweb.com\/en\/wp-json\/wp\/v2\/tags?post=3558"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}